]> git.ipfire.org Git - thirdparty/foundation/foundation-sites.git/commitdiff
chore: dist folder from master 6.5.3 11881/head
authorJoe Workman <joe@workmanmail.com>
Tue, 22 Oct 2019 19:37:13 +0000 (12:37 -0700)
committerJoe Workman <joe@workmanmail.com>
Tue, 22 Oct 2019 19:37:13 +0000 (12:37 -0700)
155 files changed:
dist/css/foundation-float.css
dist/css/foundation-float.css.map [new file with mode: 0644]
dist/css/foundation-float.min.css
dist/css/foundation-float.min.css.map [new file with mode: 0644]
dist/css/foundation-prototype.css
dist/css/foundation-prototype.css.map [new file with mode: 0644]
dist/css/foundation-prototype.min.css
dist/css/foundation-prototype.min.css.map [new file with mode: 0644]
dist/css/foundation-rtl.css
dist/css/foundation-rtl.css.map [new file with mode: 0644]
dist/css/foundation-rtl.min.css
dist/css/foundation-rtl.min.css.map [new file with mode: 0644]
dist/css/foundation.css
dist/css/foundation.css.map [new file with mode: 0644]
dist/css/foundation.min.css
dist/css/foundation.min.css.map [new file with mode: 0644]
dist/js/foundation.cjs.js [new file with mode: 0644]
dist/js/foundation.cjs.js.map [new file with mode: 0644]
dist/js/foundation.d.ts
dist/js/foundation.es6.js [new file with mode: 0644]
dist/js/foundation.es6.js.map [new file with mode: 0644]
dist/js/foundation.esm.js [new file with mode: 0644]
dist/js/foundation.esm.js.map [new file with mode: 0644]
dist/js/foundation.js
dist/js/foundation.js.map [new file with mode: 0644]
dist/js/foundation.min.js
dist/js/foundation.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.abide.js
dist/js/plugins/foundation.abide.js.map [new file with mode: 0644]
dist/js/plugins/foundation.abide.min.js
dist/js/plugins/foundation.abide.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.accordion.js
dist/js/plugins/foundation.accordion.js.map [new file with mode: 0644]
dist/js/plugins/foundation.accordion.min.js
dist/js/plugins/foundation.accordion.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.accordionMenu.js
dist/js/plugins/foundation.accordionMenu.js.map [new file with mode: 0644]
dist/js/plugins/foundation.accordionMenu.min.js
dist/js/plugins/foundation.accordionMenu.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.core.js
dist/js/plugins/foundation.core.js.map [new file with mode: 0644]
dist/js/plugins/foundation.core.min.js
dist/js/plugins/foundation.core.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.drilldown.js
dist/js/plugins/foundation.drilldown.js.map [new file with mode: 0644]
dist/js/plugins/foundation.drilldown.min.js
dist/js/plugins/foundation.drilldown.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.dropdown.js
dist/js/plugins/foundation.dropdown.js.map [new file with mode: 0644]
dist/js/plugins/foundation.dropdown.min.js
dist/js/plugins/foundation.dropdown.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.dropdownMenu.js
dist/js/plugins/foundation.dropdownMenu.js.map [new file with mode: 0644]
dist/js/plugins/foundation.dropdownMenu.min.js
dist/js/plugins/foundation.dropdownMenu.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.equalizer.js
dist/js/plugins/foundation.equalizer.js.map [new file with mode: 0644]
dist/js/plugins/foundation.equalizer.min.js
dist/js/plugins/foundation.equalizer.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.interchange.js
dist/js/plugins/foundation.interchange.js.map [new file with mode: 0644]
dist/js/plugins/foundation.interchange.min.js
dist/js/plugins/foundation.interchange.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.magellan.js
dist/js/plugins/foundation.magellan.js.map [new file with mode: 0644]
dist/js/plugins/foundation.magellan.min.js
dist/js/plugins/foundation.magellan.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.offcanvas.js
dist/js/plugins/foundation.offcanvas.js.map [new file with mode: 0644]
dist/js/plugins/foundation.offcanvas.min.js
dist/js/plugins/foundation.offcanvas.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.orbit.js
dist/js/plugins/foundation.orbit.js.map [new file with mode: 0644]
dist/js/plugins/foundation.orbit.min.js
dist/js/plugins/foundation.orbit.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.responsiveAccordionTabs.js
dist/js/plugins/foundation.responsiveAccordionTabs.js.map [new file with mode: 0644]
dist/js/plugins/foundation.responsiveAccordionTabs.min.js
dist/js/plugins/foundation.responsiveAccordionTabs.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.responsiveMenu.js
dist/js/plugins/foundation.responsiveMenu.js.map [new file with mode: 0644]
dist/js/plugins/foundation.responsiveMenu.min.js
dist/js/plugins/foundation.responsiveMenu.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.responsiveToggle.js
dist/js/plugins/foundation.responsiveToggle.js.map [new file with mode: 0644]
dist/js/plugins/foundation.responsiveToggle.min.js
dist/js/plugins/foundation.responsiveToggle.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.reveal.js
dist/js/plugins/foundation.reveal.js.map [new file with mode: 0644]
dist/js/plugins/foundation.reveal.min.js
dist/js/plugins/foundation.reveal.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.slider.js
dist/js/plugins/foundation.slider.js.map [new file with mode: 0644]
dist/js/plugins/foundation.slider.min.js
dist/js/plugins/foundation.slider.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.smoothScroll.js
dist/js/plugins/foundation.smoothScroll.js.map [new file with mode: 0644]
dist/js/plugins/foundation.smoothScroll.min.js
dist/js/plugins/foundation.smoothScroll.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.sticky.js
dist/js/plugins/foundation.sticky.js.map [new file with mode: 0644]
dist/js/plugins/foundation.sticky.min.js
dist/js/plugins/foundation.sticky.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.tabs.js
dist/js/plugins/foundation.tabs.js.map [new file with mode: 0644]
dist/js/plugins/foundation.tabs.min.js
dist/js/plugins/foundation.tabs.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.toggler.js
dist/js/plugins/foundation.toggler.js.map [new file with mode: 0644]
dist/js/plugins/foundation.toggler.min.js
dist/js/plugins/foundation.toggler.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.tooltip.js
dist/js/plugins/foundation.tooltip.js.map [new file with mode: 0644]
dist/js/plugins/foundation.tooltip.min.js
dist/js/plugins/foundation.tooltip.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.box.js
dist/js/plugins/foundation.util.box.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.box.min.js
dist/js/plugins/foundation.util.box.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.imageLoader.js
dist/js/plugins/foundation.util.imageLoader.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.imageLoader.min.js
dist/js/plugins/foundation.util.imageLoader.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.keyboard.js
dist/js/plugins/foundation.util.keyboard.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.keyboard.min.js
dist/js/plugins/foundation.util.keyboard.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.mediaQuery.js
dist/js/plugins/foundation.util.mediaQuery.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.mediaQuery.min.js
dist/js/plugins/foundation.util.mediaQuery.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.motion.js
dist/js/plugins/foundation.util.motion.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.motion.min.js
dist/js/plugins/foundation.util.motion.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.nest.js
dist/js/plugins/foundation.util.nest.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.nest.min.js
dist/js/plugins/foundation.util.nest.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.timer.js
dist/js/plugins/foundation.util.timer.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.timer.min.js
dist/js/plugins/foundation.util.timer.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.timerAndImageLoader.js [deleted file]
dist/js/plugins/foundation.util.timerAndImageLoader.min.js [deleted file]
dist/js/plugins/foundation.util.touch.js
dist/js/plugins/foundation.util.touch.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.touch.min.js
dist/js/plugins/foundation.util.touch.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.triggers.js
dist/js/plugins/foundation.util.triggers.js.map [new file with mode: 0644]
dist/js/plugins/foundation.util.triggers.min.js
dist/js/plugins/foundation.util.triggers.min.js.map [new file with mode: 0644]
dist/js/plugins/foundation.zf.responsiveAccordionTabs.js [deleted file]
dist/js/plugins/foundation.zf.responsiveAccordionTabs.min.js [deleted file]

index 9c80cc8d0d3e9e2d867f44b35b9b905b3998c011..47f731de53300249e42342299abf840c2f7c9a64 100644 (file)
@@ -1,7 +1,7 @@
 @charset "UTF-8";
 /**
  * Foundation for Sites by ZURB
- * Version 6.4.3
+ * Version 6.5.3
  * foundation.zurb.com
  * Licensed under MIT Open Source
  */
     left: auto;
     margin: 0 auto; } }
 
-/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */
-/* Document
-       ========================================================================== */
-/**
-     * 1. Change the default font family in all browsers (opinionated).
-     * 2. Correct the line height in all browsers.
-     * 3. Prevent adjustments of font size after orientation changes in
-     *    IE on Windows Phone and in iOS.
-     */
+/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
 html {
-  font-family: sans-serif;
-  /* 1 */
   line-height: 1.15;
-  /* 2 */
-  -ms-text-size-adjust: 100%;
-  /* 3 */
-  -webkit-text-size-adjust: 100%;
-  /* 3 */ }
-
-/* Sections
-       ========================================================================== */
-/**
-     * Remove the margin in all browsers (opinionated).
-     */
+  -webkit-text-size-adjust: 100%; }
+
 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-.
-     */
-figcaption,
-figure {
-  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 */ }
-
-/**
-     * Add the correct display in IE.
-     */
-main {
-  display: block; }
+  overflow: visible; }
 
-/**
-     * 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 */ }
+  font-size: 1em; }
 
-/* Links
-       ========================================================================== */
-/**
-     * 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 */ }
+  background-color: transparent; }
 
-/**
-     * Remove the outline on focused links when they are also active or hovered
-     * in all browsers (opinionated).
-     */
-a:active,
-a:hover {
-  outline-width: 0; }
-
-/* Text-level semantics
-       ========================================================================== */
-/**
-     * 1. Remove the bottom border in 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 */
-  text-decoration: underline dotted;
-  /* 2 */ }
+  -webkit-text-decoration: underline dotted;
+          text-decoration: underline dotted; }
 
-/**
-     * 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; }
+  font-size: 1em; }
 
-/**
-     * 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%;
@@ -197,237 +68,94 @@ sub {
 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-family: inherit;
   font-size: 100%;
-  /* 1 */
   line-height: 1.15;
-  /* 1 */
-  margin: 0;
-  /* 2 */ }
+  margin: 0; }
 
-/**
-     * Show the overflow in IE.
-     */
-button {
+button,
+input {
   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 */ }
-
 button,
 [type="button"],
 [type="reset"],
 [type="submit"] {
-  /**
-       * Remove the inner border and padding in Firefox.
-       */
-  /**
-       * Restore the focus styles unset by the previous rule.
-       */ }
-  button::-moz-focus-inner,
-  [type="button"]::-moz-focus-inner,
-  [type="reset"]::-moz-focus-inner,
-  [type="submit"]::-moz-focus-inner {
-    border-style: none;
-    padding: 0; }
-  button:-moz-focusring,
-  [type="button"]:-moz-focusring,
-  [type="reset"]:-moz-focusring,
-  [type="submit"]:-moz-focusring {
-    outline: 1px dotted ButtonText; }
-
-/**
-     * Show the overflow in Edge.
-     */
-input {
-  overflow: visible; }
-
-/**
-     * 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 */ }
+  -webkit-appearance: button; }
 
-/**
-     * 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; }
+button::-moz-focus-inner,
+[type="button"]::-moz-focus-inner,
+[type="reset"]::-moz-focus-inner,
+[type="submit"]::-moz-focus-inner {
+  border-style: none;
+  padding: 0; }
 
-/**
-     * 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 */ }
+button:-moz-focusring,
+[type="button"]:-moz-focusring,
+[type="reset"]:-moz-focusring,
+[type="submit"]:-moz-focusring {
+  outline: 1px dotted ButtonText; }
 
-/**
-     * Change the border, margin, and padding in all browsers (opinionated).
-     */
 fieldset {
-  border: 1px solid #c0c0c0;
-  margin: 0 2px;
-  padding: 0.35em 0.625em 0.75em; }
+  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;
   display: table;
-  /* 1 */
   max-width: 100%;
-  /* 1 */
   padding: 0;
-  /* 3 */
-  color: inherit;
-  /* 2 */
-  white-space: normal;
-  /* 1 */ }
+  white-space: normal; }
 
-/**
-     * 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 */ }
+  vertical-align: baseline; }
 
-/**
-     * Remove the default vertical scrollbar in IE.
-     */
 textarea {
   overflow: auto; }
 
-/* Interactive
-       ========================================================================== */
-/*
-     * Add the correct display in Edge, IE, and Firefox.
-     */
+[type="checkbox"],
+[type="radio"] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  padding: 0; }
+
+[type="number"]::-webkit-inner-spin-button,
+[type="number"]::-webkit-outer-spin-button {
+  height: auto; }
+
+[type="search"] {
+  -webkit-appearance: textfield;
+  outline-offset: -2px; }
+
+[type="search"]::-webkit-search-decoration {
+  -webkit-appearance: none; }
+
+::-webkit-file-upload-button {
+  -webkit-appearance: button;
+  font: inherit; }
+
 details {
   display: block; }
 
-/*
-     * Add the correct display in all browsers.
-     */
 summary {
   display: list-item; }
 
-/*
-     * Add the correct display in IE 9-.
-     */
-menu {
-  display: block; }
-
-/* 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; }
 
@@ -511,1355 +239,1387 @@ textarea {
 .is-hidden {
   display: none !important; }
 
-.row {
-  max-width: 75rem;
-  margin-right: auto;
-  margin-left: auto; }
-  .row::before, .row::after {
-    display: table;
-    content: ' '; }
-  .row::after {
-    clear: both; }
-  .row.collapse > .column, .row.collapse > .columns {
-    padding-right: 0;
-    padding-left: 0; }
-  .row .row {
-    margin-right: -0.625rem;
-    margin-left: -0.625rem; }
-    @media print, screen and (min-width: 40em) {
-      .row .row {
-        margin-right: -0.9375rem;
-        margin-left: -0.9375rem; } }
-    @media print, screen and (min-width: 64em) {
-      .row .row {
-        margin-right: -0.9375rem;
-        margin-left: -0.9375rem; } }
-    .row .row.collapse {
-      margin-right: 0;
-      margin-left: 0; }
-  .row.expanded {
-    max-width: none; }
-    .row.expanded .row {
-      margin-right: auto;
-      margin-left: auto; }
-  .row:not(.expanded) .row {
-    max-width: none; }
-  .row.gutter-small > .column, .row.gutter-small > .columns {
-    padding-right: 0.625rem;
-    padding-left: 0.625rem; }
-  .row.gutter-medium > .column, .row.gutter-medium > .columns {
-    padding-right: 0.9375rem;
-    padding-left: 0.9375rem; }
-
-.column, .columns {
+[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],
+textarea {
+  display: block;
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
   width: 100%;
-  float: left;
-  padding-right: 0.625rem;
-  padding-left: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .column, .columns {
-      padding-right: 0.9375rem;
-      padding-left: 0.9375rem; } }
-  .column:last-child:not(:first-child), .columns:last-child:not(:first-child) {
-    float: right; }
-  .column.end:last-child:last-child, .end.columns:last-child:last-child {
-    float: left; }
+  height: 2.4375rem;
+  margin: 0 0 1rem;
+  padding: 0.5rem;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
+          box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
+  font-family: inherit;
+  font-size: 1rem;
+  font-weight: normal;
+  line-height: 1.5;
+  color: #0a0a0a;
+  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none; }
+  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,
+  textarea:focus {
+    outline: none;
+    border: 1px solid #8a8a8a;
+    background-color: #fefefe;
+    -webkit-box-shadow: 0 0 5px #cacaca;
+            box-shadow: 0 0 5px #cacaca;
+    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
 
-.column.row.row, .row.row.columns {
-  float: none; }
+textarea {
+  max-width: 100%; }
+  textarea[rows] {
+    height: auto; }
 
-.row .column.row.row, .row .row.row.columns {
-  margin-right: 0;
-  margin-left: 0;
-  padding-right: 0;
-  padding-left: 0; }
+input:disabled, input[readonly],
+textarea:disabled,
+textarea[readonly] {
+  background-color: #e6e6e6;
+  cursor: not-allowed; }
 
-.small-1 {
-  width: 8.33333%; }
+[type='submit'],
+[type='button'] {
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none;
+  border-radius: 0; }
 
-.small-push-1 {
-  position: relative;
-  left: 8.33333%; }
+input[type='search'] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box; }
 
-.small-pull-1 {
-  position: relative;
-  left: -8.33333%; }
+::-webkit-input-placeholder {
+  color: #cacaca; }
 
-.small-offset-0 {
-  margin-left: 0%; }
+:-ms-input-placeholder {
+  color: #cacaca; }
 
-.small-2 {
-  width: 16.66667%; }
+::-ms-input-placeholder {
+  color: #cacaca; }
 
-.small-push-2 {
-  position: relative;
-  left: 16.66667%; }
+::placeholder {
+  color: #cacaca; }
 
-.small-pull-2 {
-  position: relative;
-  left: -16.66667%; }
+[type='file'],
+[type='checkbox'],
+[type='radio'] {
+  margin: 0 0 1rem; }
 
-.small-offset-1 {
-  margin-left: 8.33333%; }
-
-.small-3 {
-  width: 25%; }
-
-.small-push-3 {
-  position: relative;
-  left: 25%; }
+[type='checkbox'] + label,
+[type='radio'] + label {
+  display: inline-block;
+  vertical-align: baseline;
+  margin-left: 0.5rem;
+  margin-right: 1rem;
+  margin-bottom: 0; }
+  [type='checkbox'] + label[for],
+  [type='radio'] + label[for] {
+    cursor: pointer; }
 
-.small-pull-3 {
-  position: relative;
-  left: -25%; }
+label > [type='checkbox'],
+label > [type='radio'] {
+  margin-right: 0.5rem; }
 
-.small-offset-2 {
-  margin-left: 16.66667%; }
+[type='file'] {
+  width: 100%; }
 
-.small-4 {
-  width: 33.33333%; }
+label {
+  display: block;
+  margin: 0;
+  font-size: 0.875rem;
+  font-weight: normal;
+  line-height: 1.8;
+  color: #0a0a0a; }
+  label.middle {
+    margin: 0 0 1rem;
+    padding: 0.5625rem 0; }
 
-.small-push-4 {
-  position: relative;
-  left: 33.33333%; }
+.help-text {
+  margin-top: -0.5rem;
+  font-size: 0.8125rem;
+  font-style: italic;
+  color: #0a0a0a; }
 
-.small-pull-4 {
-  position: relative;
-  left: -33.33333%; }
+.input-group {
+  display: table;
+  width: 100%;
+  margin-bottom: 1rem; }
+  .input-group > :first-child, .input-group > :first-child.input-group-button > * {
+    border-radius: 0 0 0 0; }
+  .input-group > :last-child, .input-group > :last-child.input-group-button > * {
+    border-radius: 0 0 0 0; }
 
-.small-offset-3 {
-  margin-left: 25%; }
+.input-group-label, .input-group-field, .input-group-button, .input-group-button a,
+.input-group-button input,
+.input-group-button button,
+.input-group-button label {
+  margin: 0;
+  white-space: nowrap;
+  display: table-cell;
+  vertical-align: middle; }
 
-.small-5 {
-  width: 41.66667%; }
+.input-group-label {
+  padding: 0 1rem;
+  border: 1px solid #cacaca;
+  background: #e6e6e6;
+  color: #0a0a0a;
+  text-align: center;
+  white-space: nowrap;
+  width: 1%;
+  height: 100%; }
+  .input-group-label:first-child {
+    border-right: 0; }
+  .input-group-label:last-child {
+    border-left: 0; }
 
-.small-push-5 {
-  position: relative;
-  left: 41.66667%; }
+.input-group-field {
+  border-radius: 0; }
 
-.small-pull-5 {
-  position: relative;
-  left: -41.66667%; }
+.input-group-button {
+  padding-top: 0;
+  padding-bottom: 0;
+  text-align: center;
+  width: 1%;
+  height: 100%; }
+  .input-group-button a,
+  .input-group-button input,
+  .input-group-button button,
+  .input-group-button label {
+    height: 2.4375rem;
+    padding-top: 0;
+    padding-bottom: 0;
+    font-size: 1rem; }
 
-.small-offset-4 {
-  margin-left: 33.33333%; }
+.input-group .input-group-button {
+  display: table-cell; }
 
-.small-6 {
-  width: 50%; }
+fieldset {
+  margin: 0;
+  padding: 0;
+  border: 0; }
 
-.small-push-6 {
-  position: relative;
-  left: 50%; }
+legend {
+  max-width: 100%;
+  margin-bottom: 0.5rem; }
 
-.small-pull-6 {
-  position: relative;
-  left: -50%; }
+.fieldset {
+  margin: 1.125rem 0;
+  padding: 1.25rem;
+  border: 1px solid #cacaca; }
+  .fieldset legend {
+    margin: 0;
+    margin-left: -0.1875rem;
+    padding: 0 0.1875rem; }
 
-.small-offset-5 {
-  margin-left: 41.66667%; }
+select {
+  height: 2.4375rem;
+  margin: 0 0 1rem;
+  padding: 0.5rem;
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  font-family: inherit;
+  font-size: 1rem;
+  font-weight: normal;
+  line-height: 1.5;
+  color: #0a0a0a;
+  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");
+  background-origin: content-box;
+  background-position: right -1rem center;
+  background-repeat: no-repeat;
+  background-size: 9px 6px;
+  padding-right: 1.5rem;
+  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+  @media screen and (min-width: 0\0) {
+    select {
+      background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } }
+  select:focus {
+    outline: none;
+    border: 1px solid #8a8a8a;
+    background-color: #fefefe;
+    -webkit-box-shadow: 0 0 5px #cacaca;
+            box-shadow: 0 0 5px #cacaca;
+    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+  select:disabled {
+    background-color: #e6e6e6;
+    cursor: not-allowed; }
+  select::-ms-expand {
+    display: none; }
+  select[multiple] {
+    height: auto;
+    background-image: none; }
 
-.small-7 {
-  width: 58.33333%; }
+.is-invalid-input:not(:focus) {
+  border-color: #cc4b37;
+  background-color: #f9ecea; }
+  .is-invalid-input:not(:focus)::-webkit-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus):-ms-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus)::-ms-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus)::placeholder {
+    color: #cc4b37; }
 
-.small-push-7 {
-  position: relative;
-  left: 58.33333%; }
+.is-invalid-label {
+  color: #cc4b37; }
 
-.small-pull-7 {
-  position: relative;
-  left: -58.33333%; }
+.form-error {
+  display: none;
+  margin-top: -0.5rem;
+  margin-bottom: 1rem;
+  font-size: 0.75rem;
+  font-weight: bold;
+  color: #cc4b37; }
+  .form-error.is-visible {
+    display: block; }
 
-.small-offset-6 {
-  margin-left: 50%; }
+div,
+dl,
+dt,
+dd,
+ul,
+ol,
+li,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+pre,
+form,
+p,
+blockquote,
+th,
+td {
+  margin: 0;
+  padding: 0; }
 
-.small-8 {
-  width: 66.66667%; }
+p {
+  margin-bottom: 1rem;
+  font-size: inherit;
+  line-height: 1.6;
+  text-rendering: optimizeLegibility; }
 
-.small-push-8 {
-  position: relative;
-  left: 66.66667%; }
+em,
+i {
+  font-style: italic;
+  line-height: inherit; }
 
-.small-pull-8 {
-  position: relative;
-  left: -66.66667%; }
+strong,
+b {
+  font-weight: bold;
+  line-height: inherit; }
 
-.small-offset-7 {
-  margin-left: 58.33333%; }
+small {
+  font-size: 80%;
+  line-height: inherit; }
 
-.small-9 {
-  width: 75%; }
-
-.small-push-9 {
-  position: relative;
-  left: 75%; }
+h1, .h1,
+h2, .h2,
+h3, .h3,
+h4, .h4,
+h5, .h5,
+h6, .h6 {
+  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
+  font-style: normal;
+  font-weight: normal;
+  color: inherit;
+  text-rendering: optimizeLegibility; }
+  h1 small, .h1 small,
+  h2 small, .h2 small,
+  h3 small, .h3 small,
+  h4 small, .h4 small,
+  h5 small, .h5 small,
+  h6 small, .h6 small {
+    line-height: 0;
+    color: #cacaca; }
 
-.small-pull-9 {
-  position: relative;
-  left: -75%; }
+h1, .h1 {
+  font-size: 1.5rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.small-offset-8 {
-  margin-left: 66.66667%; }
+h2, .h2 {
+  font-size: 1.25rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.small-10 {
-  width: 83.33333%; }
+h3, .h3 {
+  font-size: 1.1875rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.small-push-10 {
-  position: relative;
-  left: 83.33333%; }
+h4, .h4 {
+  font-size: 1.125rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.small-pull-10 {
-  position: relative;
-  left: -83.33333%; }
+h5, .h5 {
+  font-size: 1.0625rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.small-offset-9 {
-  margin-left: 75%; }
+h6, .h6 {
+  font-size: 1rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.small-11 {
-  width: 91.66667%; }
+@media print, screen and (min-width: 40em) {
+  h1, .h1 {
+    font-size: 3rem; }
+  h2, .h2 {
+    font-size: 2.5rem; }
+  h3, .h3 {
+    font-size: 1.9375rem; }
+  h4, .h4 {
+    font-size: 1.5625rem; }
+  h5, .h5 {
+    font-size: 1.25rem; }
+  h6, .h6 {
+    font-size: 1rem; } }
 
-.small-push-11 {
-  position: relative;
-  left: 91.66667%; }
+a {
+  line-height: inherit;
+  color: #1779ba;
+  text-decoration: none;
+  cursor: pointer; }
+  a:hover, a:focus {
+    color: #1468a0; }
+  a img {
+    border: 0; }
 
-.small-pull-11 {
-  position: relative;
-  left: -91.66667%; }
+hr {
+  clear: both;
+  max-width: 75rem;
+  height: 0;
+  margin: 1.25rem auto;
+  border-top: 0;
+  border-right: 0;
+  border-bottom: 1px solid #cacaca;
+  border-left: 0; }
 
-.small-offset-10 {
-  margin-left: 83.33333%; }
+ul,
+ol,
+dl {
+  margin-bottom: 1rem;
+  list-style-position: outside;
+  line-height: 1.6; }
 
-.small-12 {
-  width: 100%; }
+li {
+  font-size: inherit; }
 
-.small-offset-11 {
-  margin-left: 91.66667%; }
+ul {
+  margin-left: 1.25rem;
+  list-style-type: disc; }
 
-.small-up-1 > .column, .small-up-1 > .columns {
-  float: left;
-  width: 100%; }
-  .small-up-1 > .column:nth-of-type(1n), .small-up-1 > .columns:nth-of-type(1n) {
-    clear: none; }
-  .small-up-1 > .column:nth-of-type(1n+1), .small-up-1 > .columns:nth-of-type(1n+1) {
-    clear: both; }
-  .small-up-1 > .column:last-child, .small-up-1 > .columns:last-child {
-    float: left; }
+ol {
+  margin-left: 1.25rem; }
 
-.small-up-2 > .column, .small-up-2 > .columns {
-  float: left;
-  width: 50%; }
-  .small-up-2 > .column:nth-of-type(1n), .small-up-2 > .columns:nth-of-type(1n) {
-    clear: none; }
-  .small-up-2 > .column:nth-of-type(2n+1), .small-up-2 > .columns:nth-of-type(2n+1) {
-    clear: both; }
-  .small-up-2 > .column:last-child, .small-up-2 > .columns:last-child {
-    float: left; }
+ul ul, ol ul, ul ol, ol ol {
+  margin-left: 1.25rem;
+  margin-bottom: 0; }
 
-.small-up-3 > .column, .small-up-3 > .columns {
-  float: left;
-  width: 33.33333%; }
-  .small-up-3 > .column:nth-of-type(1n), .small-up-3 > .columns:nth-of-type(1n) {
-    clear: none; }
-  .small-up-3 > .column:nth-of-type(3n+1), .small-up-3 > .columns:nth-of-type(3n+1) {
-    clear: both; }
-  .small-up-3 > .column:last-child, .small-up-3 > .columns:last-child {
-    float: left; }
+dl {
+  margin-bottom: 1rem; }
+  dl dt {
+    margin-bottom: 0.3rem;
+    font-weight: bold; }
 
-.small-up-4 > .column, .small-up-4 > .columns {
-  float: left;
-  width: 25%; }
-  .small-up-4 > .column:nth-of-type(1n), .small-up-4 > .columns:nth-of-type(1n) {
-    clear: none; }
-  .small-up-4 > .column:nth-of-type(4n+1), .small-up-4 > .columns:nth-of-type(4n+1) {
-    clear: both; }
-  .small-up-4 > .column:last-child, .small-up-4 > .columns:last-child {
-    float: left; }
+blockquote {
+  margin: 0 0 1rem;
+  padding: 0.5625rem 1.25rem 0 1.1875rem;
+  border-left: 1px solid #cacaca; }
+  blockquote, blockquote p {
+    line-height: 1.6;
+    color: #8a8a8a; }
 
-.small-up-5 > .column, .small-up-5 > .columns {
-  float: left;
-  width: 20%; }
-  .small-up-5 > .column:nth-of-type(1n), .small-up-5 > .columns:nth-of-type(1n) {
-    clear: none; }
-  .small-up-5 > .column:nth-of-type(5n+1), .small-up-5 > .columns:nth-of-type(5n+1) {
-    clear: both; }
-  .small-up-5 > .column:last-child, .small-up-5 > .columns:last-child {
-    float: left; }
+cite {
+  display: block;
+  font-size: 0.8125rem;
+  color: #8a8a8a; }
+  cite:before {
+    content: "— "; }
 
-.small-up-6 > .column, .small-up-6 > .columns {
-  float: left;
-  width: 16.66667%; }
-  .small-up-6 > .column:nth-of-type(1n), .small-up-6 > .columns:nth-of-type(1n) {
-    clear: none; }
-  .small-up-6 > .column:nth-of-type(6n+1), .small-up-6 > .columns:nth-of-type(6n+1) {
-    clear: both; }
-  .small-up-6 > .column:last-child, .small-up-6 > .columns:last-child {
-    float: left; }
+abbr, abbr[title] {
+  border-bottom: 1px dotted #0a0a0a;
+  cursor: help;
+  text-decoration: none; }
 
-.small-up-7 > .column, .small-up-7 > .columns {
-  float: left;
-  width: 14.28571%; }
-  .small-up-7 > .column:nth-of-type(1n), .small-up-7 > .columns:nth-of-type(1n) {
-    clear: none; }
-  .small-up-7 > .column:nth-of-type(7n+1), .small-up-7 > .columns:nth-of-type(7n+1) {
-    clear: both; }
-  .small-up-7 > .column:last-child, .small-up-7 > .columns:last-child {
-    float: left; }
+figure {
+  margin: 0; }
 
-.small-up-8 > .column, .small-up-8 > .columns {
-  float: left;
-  width: 12.5%; }
-  .small-up-8 > .column:nth-of-type(1n), .small-up-8 > .columns:nth-of-type(1n) {
-    clear: none; }
-  .small-up-8 > .column:nth-of-type(8n+1), .small-up-8 > .columns:nth-of-type(8n+1) {
-    clear: both; }
-  .small-up-8 > .column:last-child, .small-up-8 > .columns:last-child {
-    float: left; }
+code {
+  padding: 0.125rem 0.3125rem 0.0625rem;
+  border: 1px solid #cacaca;
+  background-color: #e6e6e6;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  font-weight: normal;
+  color: #0a0a0a; }
 
-.small-collapse > .column, .small-collapse > .columns {
-  padding-right: 0;
-  padding-left: 0; }
+kbd {
+  margin: 0;
+  padding: 0.125rem 0.25rem 0;
+  background-color: #e6e6e6;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  color: #0a0a0a; }
 
-.small-collapse .row {
-  margin-right: 0;
-  margin-left: 0; }
+.subheader {
+  margin-top: 0.2rem;
+  margin-bottom: 0.5rem;
+  font-weight: normal;
+  line-height: 1.4;
+  color: #8a8a8a; }
 
-.expanded.row .small-collapse.row {
-  margin-right: 0;
-  margin-left: 0; }
+.lead {
+  font-size: 125%;
+  line-height: 1.6; }
 
-.small-uncollapse > .column, .small-uncollapse > .columns {
-  padding-right: 0.625rem;
-  padding-left: 0.625rem; }
+.stat {
+  font-size: 2.5rem;
+  line-height: 1; }
+  p + .stat {
+    margin-top: -1rem; }
 
-.small-centered {
+ul.no-bullet, ol.no-bullet {
+  margin-left: 0;
+  list-style: none; }
+
+.text-left {
+  text-align: left; }
+
+.text-right {
+  text-align: right; }
+
+.text-center {
+  text-align: center; }
+
+.text-justify {
+  text-align: justify; }
+
+@media print, screen and (min-width: 40em) {
+  .medium-text-left {
+    text-align: left; }
+  .medium-text-right {
+    text-align: right; }
+  .medium-text-center {
+    text-align: center; }
+  .medium-text-justify {
+    text-align: justify; } }
+
+@media print, screen and (min-width: 64em) {
+  .large-text-left {
+    text-align: left; }
+  .large-text-right {
+    text-align: right; }
+  .large-text-center {
+    text-align: center; }
+  .large-text-justify {
+    text-align: justify; } }
+
+.show-for-print {
+  display: none !important; }
+
+@media print {
+  * {
+    background: transparent !important;
+    -webkit-box-shadow: none !important;
+            box-shadow: none !important;
+    color: black !important;
+    text-shadow: none !important; }
+  .show-for-print {
+    display: block !important; }
+  .hide-for-print {
+    display: none !important; }
+  table.show-for-print {
+    display: table !important; }
+  thead.show-for-print {
+    display: table-header-group !important; }
+  tbody.show-for-print {
+    display: table-row-group !important; }
+  tr.show-for-print {
+    display: table-row !important; }
+  td.show-for-print {
+    display: table-cell !important; }
+  th.show-for-print {
+    display: table-cell !important; }
+  a,
+  a:visited {
+    text-decoration: underline; }
+  a[href]:after {
+    content: " (" attr(href) ")"; }
+  .ir a:after,
+  a[href^='javascript:']:after,
+  a[href^='#']:after {
+    content: ''; }
+  abbr[title]:after {
+    content: " (" attr(title) ")"; }
+  pre,
+  blockquote {
+    border: 1px solid #8a8a8a;
+    page-break-inside: avoid; }
+  thead {
+    display: table-header-group; }
+  tr,
+  img {
+    page-break-inside: avoid; }
+  img {
+    max-width: 100% !important; }
+  @page {
+    margin: 0.5cm; }
+  p,
+  h2,
+  h3 {
+    orphans: 3;
+    widows: 3; }
+  h2,
+  h3 {
+    page-break-after: avoid; }
+  .print-break-inside {
+    page-break-inside: auto; } }
+
+.row {
+  max-width: 75rem;
   margin-right: auto;
   margin-left: auto; }
-  .small-centered, .small-centered:last-child:not(:first-child) {
-    float: none;
+  .row::before, .row::after {
+    display: table;
+    content: ' '; }
+  .row::after {
     clear: both; }
+  .row.collapse > .column, .row.collapse > .columns {
+    padding-right: 0;
+    padding-left: 0; }
+  .row .row {
+    margin-right: -0.625rem;
+    margin-left: -0.625rem; }
+    @media print, screen and (min-width: 40em) {
+      .row .row {
+        margin-right: -0.9375rem;
+        margin-left: -0.9375rem; } }
+    @media print, screen and (min-width: 64em) {
+      .row .row {
+        margin-right: -0.9375rem;
+        margin-left: -0.9375rem; } }
+    .row .row.collapse {
+      margin-right: 0;
+      margin-left: 0; }
+  .row.expanded {
+    max-width: none; }
+    .row.expanded .row {
+      margin-right: auto;
+      margin-left: auto; }
+  .row:not(.expanded) .row {
+    max-width: none; }
+  .row.gutter-small > .column, .row.gutter-small > .columns {
+    padding-right: 0.625rem;
+    padding-left: 0.625rem; }
+  .row.gutter-medium > .column, .row.gutter-medium > .columns {
+    padding-right: 0.9375rem;
+    padding-left: 0.9375rem; }
 
-.small-uncentered,
-.small-push-0,
-.small-pull-0 {
-  position: static;
+.column, .columns {
+  width: 100%;
   float: left;
+  padding-right: 0.625rem;
+  padding-left: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .column, .columns {
+      padding-right: 0.9375rem;
+      padding-left: 0.9375rem; } }
+  .column, .columns, .column:last-child:not(:first-child), .columns:last-child:not(:first-child) {
+    float: left;
+    clear: none; }
+  .column:last-child:not(:first-child), .columns:last-child:not(:first-child) {
+    float: right; }
+  .column.end:last-child:last-child, .end.columns:last-child:last-child {
+    float: left; }
+
+.column.row.row, .row.row.columns {
+  float: none; }
+
+.row .column.row.row, .row .row.row.columns {
   margin-right: 0;
-  margin-left: 0; }
+  margin-left: 0;
+  padding-right: 0;
+  padding-left: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-1 {
-    width: 8.33333%; }
-  .medium-push-1 {
-    position: relative;
-    left: 8.33333%; }
-  .medium-pull-1 {
-    position: relative;
-    left: -8.33333%; }
-  .medium-offset-0 {
-    margin-left: 0%; }
-  .medium-2 {
-    width: 16.66667%; }
-  .medium-push-2 {
-    position: relative;
-    left: 16.66667%; }
-  .medium-pull-2 {
-    position: relative;
-    left: -16.66667%; }
-  .medium-offset-1 {
-    margin-left: 8.33333%; }
-  .medium-3 {
-    width: 25%; }
-  .medium-push-3 {
-    position: relative;
-    left: 25%; }
-  .medium-pull-3 {
-    position: relative;
-    left: -25%; }
-  .medium-offset-2 {
-    margin-left: 16.66667%; }
-  .medium-4 {
-    width: 33.33333%; }
-  .medium-push-4 {
-    position: relative;
-    left: 33.33333%; }
-  .medium-pull-4 {
-    position: relative;
-    left: -33.33333%; }
-  .medium-offset-3 {
-    margin-left: 25%; }
-  .medium-5 {
-    width: 41.66667%; }
-  .medium-push-5 {
-    position: relative;
-    left: 41.66667%; }
-  .medium-pull-5 {
-    position: relative;
-    left: -41.66667%; }
-  .medium-offset-4 {
-    margin-left: 33.33333%; }
-  .medium-6 {
-    width: 50%; }
-  .medium-push-6 {
-    position: relative;
-    left: 50%; }
-  .medium-pull-6 {
-    position: relative;
-    left: -50%; }
-  .medium-offset-5 {
-    margin-left: 41.66667%; }
-  .medium-7 {
-    width: 58.33333%; }
-  .medium-push-7 {
-    position: relative;
-    left: 58.33333%; }
-  .medium-pull-7 {
-    position: relative;
-    left: -58.33333%; }
-  .medium-offset-6 {
-    margin-left: 50%; }
-  .medium-8 {
-    width: 66.66667%; }
-  .medium-push-8 {
-    position: relative;
-    left: 66.66667%; }
-  .medium-pull-8 {
-    position: relative;
-    left: -66.66667%; }
-  .medium-offset-7 {
-    margin-left: 58.33333%; }
-  .medium-9 {
-    width: 75%; }
-  .medium-push-9 {
-    position: relative;
-    left: 75%; }
-  .medium-pull-9 {
-    position: relative;
-    left: -75%; }
-  .medium-offset-8 {
-    margin-left: 66.66667%; }
-  .medium-10 {
-    width: 83.33333%; }
-  .medium-push-10 {
-    position: relative;
-    left: 83.33333%; }
-  .medium-pull-10 {
-    position: relative;
-    left: -83.33333%; }
-  .medium-offset-9 {
-    margin-left: 75%; }
-  .medium-11 {
-    width: 91.66667%; }
-  .medium-push-11 {
-    position: relative;
-    left: 91.66667%; }
-  .medium-pull-11 {
-    position: relative;
-    left: -91.66667%; }
-  .medium-offset-10 {
-    margin-left: 83.33333%; }
-  .medium-12 {
-    width: 100%; }
-  .medium-offset-11 {
-    margin-left: 91.66667%; }
-  .medium-up-1 > .column, .medium-up-1 > .columns {
-    float: left;
-    width: 100%; }
-    .medium-up-1 > .column:nth-of-type(1n), .medium-up-1 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .medium-up-1 > .column:nth-of-type(1n+1), .medium-up-1 > .columns:nth-of-type(1n+1) {
-      clear: both; }
-    .medium-up-1 > .column:last-child, .medium-up-1 > .columns:last-child {
-      float: left; }
-  .medium-up-2 > .column, .medium-up-2 > .columns {
-    float: left;
-    width: 50%; }
-    .medium-up-2 > .column:nth-of-type(1n), .medium-up-2 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .medium-up-2 > .column:nth-of-type(2n+1), .medium-up-2 > .columns:nth-of-type(2n+1) {
-      clear: both; }
-    .medium-up-2 > .column:last-child, .medium-up-2 > .columns:last-child {
-      float: left; }
-  .medium-up-3 > .column, .medium-up-3 > .columns {
-    float: left;
-    width: 33.33333%; }
-    .medium-up-3 > .column:nth-of-type(1n), .medium-up-3 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .medium-up-3 > .column:nth-of-type(3n+1), .medium-up-3 > .columns:nth-of-type(3n+1) {
-      clear: both; }
-    .medium-up-3 > .column:last-child, .medium-up-3 > .columns:last-child {
-      float: left; }
-  .medium-up-4 > .column, .medium-up-4 > .columns {
-    float: left;
-    width: 25%; }
-    .medium-up-4 > .column:nth-of-type(1n), .medium-up-4 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .medium-up-4 > .column:nth-of-type(4n+1), .medium-up-4 > .columns:nth-of-type(4n+1) {
-      clear: both; }
-    .medium-up-4 > .column:last-child, .medium-up-4 > .columns:last-child {
-      float: left; }
-  .medium-up-5 > .column, .medium-up-5 > .columns {
-    float: left;
-    width: 20%; }
-    .medium-up-5 > .column:nth-of-type(1n), .medium-up-5 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .medium-up-5 > .column:nth-of-type(5n+1), .medium-up-5 > .columns:nth-of-type(5n+1) {
-      clear: both; }
-    .medium-up-5 > .column:last-child, .medium-up-5 > .columns:last-child {
-      float: left; }
-  .medium-up-6 > .column, .medium-up-6 > .columns {
-    float: left;
-    width: 16.66667%; }
-    .medium-up-6 > .column:nth-of-type(1n), .medium-up-6 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .medium-up-6 > .column:nth-of-type(6n+1), .medium-up-6 > .columns:nth-of-type(6n+1) {
-      clear: both; }
-    .medium-up-6 > .column:last-child, .medium-up-6 > .columns:last-child {
-      float: left; }
-  .medium-up-7 > .column, .medium-up-7 > .columns {
-    float: left;
-    width: 14.28571%; }
-    .medium-up-7 > .column:nth-of-type(1n), .medium-up-7 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .medium-up-7 > .column:nth-of-type(7n+1), .medium-up-7 > .columns:nth-of-type(7n+1) {
-      clear: both; }
-    .medium-up-7 > .column:last-child, .medium-up-7 > .columns:last-child {
-      float: left; }
-  .medium-up-8 > .column, .medium-up-8 > .columns {
-    float: left;
-    width: 12.5%; }
-    .medium-up-8 > .column:nth-of-type(1n), .medium-up-8 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .medium-up-8 > .column:nth-of-type(8n+1), .medium-up-8 > .columns:nth-of-type(8n+1) {
-      clear: both; }
-    .medium-up-8 > .column:last-child, .medium-up-8 > .columns:last-child {
-      float: left; }
-  .medium-collapse > .column, .medium-collapse > .columns {
-    padding-right: 0;
-    padding-left: 0; }
-  .medium-collapse .row {
-    margin-right: 0;
-    margin-left: 0; }
-  .expanded.row .medium-collapse.row {
-    margin-right: 0;
-    margin-left: 0; }
-  .medium-uncollapse > .column, .medium-uncollapse > .columns {
-    padding-right: 0.9375rem;
-    padding-left: 0.9375rem; }
-  .medium-centered {
-    margin-right: auto;
-    margin-left: auto; }
-    .medium-centered, .medium-centered:last-child:not(:first-child) {
-      float: none;
-      clear: both; }
-  .medium-uncentered,
-  .medium-push-0,
-  .medium-pull-0 {
-    position: static;
-    float: left;
-    margin-right: 0;
-    margin-left: 0; } }
-
-@media print, screen and (min-width: 64em) {
-  .large-1 {
-    width: 8.33333%; }
-  .large-push-1 {
-    position: relative;
-    left: 8.33333%; }
-  .large-pull-1 {
-    position: relative;
-    left: -8.33333%; }
-  .large-offset-0 {
-    margin-left: 0%; }
-  .large-2 {
-    width: 16.66667%; }
-  .large-push-2 {
-    position: relative;
-    left: 16.66667%; }
-  .large-pull-2 {
-    position: relative;
-    left: -16.66667%; }
-  .large-offset-1 {
-    margin-left: 8.33333%; }
-  .large-3 {
-    width: 25%; }
-  .large-push-3 {
-    position: relative;
-    left: 25%; }
-  .large-pull-3 {
-    position: relative;
-    left: -25%; }
-  .large-offset-2 {
-    margin-left: 16.66667%; }
-  .large-4 {
-    width: 33.33333%; }
-  .large-push-4 {
-    position: relative;
-    left: 33.33333%; }
-  .large-pull-4 {
-    position: relative;
-    left: -33.33333%; }
-  .large-offset-3 {
-    margin-left: 25%; }
-  .large-5 {
-    width: 41.66667%; }
-  .large-push-5 {
-    position: relative;
-    left: 41.66667%; }
-  .large-pull-5 {
-    position: relative;
-    left: -41.66667%; }
-  .large-offset-4 {
-    margin-left: 33.33333%; }
-  .large-6 {
-    width: 50%; }
-  .large-push-6 {
-    position: relative;
-    left: 50%; }
-  .large-pull-6 {
-    position: relative;
-    left: -50%; }
-  .large-offset-5 {
-    margin-left: 41.66667%; }
-  .large-7 {
-    width: 58.33333%; }
-  .large-push-7 {
-    position: relative;
-    left: 58.33333%; }
-  .large-pull-7 {
-    position: relative;
-    left: -58.33333%; }
-  .large-offset-6 {
-    margin-left: 50%; }
-  .large-8 {
-    width: 66.66667%; }
-  .large-push-8 {
-    position: relative;
-    left: 66.66667%; }
-  .large-pull-8 {
-    position: relative;
-    left: -66.66667%; }
-  .large-offset-7 {
-    margin-left: 58.33333%; }
-  .large-9 {
-    width: 75%; }
-  .large-push-9 {
-    position: relative;
-    left: 75%; }
-  .large-pull-9 {
-    position: relative;
-    left: -75%; }
-  .large-offset-8 {
-    margin-left: 66.66667%; }
-  .large-10 {
-    width: 83.33333%; }
-  .large-push-10 {
-    position: relative;
-    left: 83.33333%; }
-  .large-pull-10 {
-    position: relative;
-    left: -83.33333%; }
-  .large-offset-9 {
-    margin-left: 75%; }
-  .large-11 {
-    width: 91.66667%; }
-  .large-push-11 {
-    position: relative;
-    left: 91.66667%; }
-  .large-pull-11 {
-    position: relative;
-    left: -91.66667%; }
-  .large-offset-10 {
-    margin-left: 83.33333%; }
-  .large-12 {
-    width: 100%; }
-  .large-offset-11 {
-    margin-left: 91.66667%; }
-  .large-up-1 > .column, .large-up-1 > .columns {
-    float: left;
-    width: 100%; }
-    .large-up-1 > .column:nth-of-type(1n), .large-up-1 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .large-up-1 > .column:nth-of-type(1n+1), .large-up-1 > .columns:nth-of-type(1n+1) {
-      clear: both; }
-    .large-up-1 > .column:last-child, .large-up-1 > .columns:last-child {
-      float: left; }
-  .large-up-2 > .column, .large-up-2 > .columns {
-    float: left;
-    width: 50%; }
-    .large-up-2 > .column:nth-of-type(1n), .large-up-2 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .large-up-2 > .column:nth-of-type(2n+1), .large-up-2 > .columns:nth-of-type(2n+1) {
-      clear: both; }
-    .large-up-2 > .column:last-child, .large-up-2 > .columns:last-child {
-      float: left; }
-  .large-up-3 > .column, .large-up-3 > .columns {
-    float: left;
-    width: 33.33333%; }
-    .large-up-3 > .column:nth-of-type(1n), .large-up-3 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .large-up-3 > .column:nth-of-type(3n+1), .large-up-3 > .columns:nth-of-type(3n+1) {
-      clear: both; }
-    .large-up-3 > .column:last-child, .large-up-3 > .columns:last-child {
-      float: left; }
-  .large-up-4 > .column, .large-up-4 > .columns {
-    float: left;
-    width: 25%; }
-    .large-up-4 > .column:nth-of-type(1n), .large-up-4 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .large-up-4 > .column:nth-of-type(4n+1), .large-up-4 > .columns:nth-of-type(4n+1) {
-      clear: both; }
-    .large-up-4 > .column:last-child, .large-up-4 > .columns:last-child {
-      float: left; }
-  .large-up-5 > .column, .large-up-5 > .columns {
-    float: left;
-    width: 20%; }
-    .large-up-5 > .column:nth-of-type(1n), .large-up-5 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .large-up-5 > .column:nth-of-type(5n+1), .large-up-5 > .columns:nth-of-type(5n+1) {
-      clear: both; }
-    .large-up-5 > .column:last-child, .large-up-5 > .columns:last-child {
-      float: left; }
-  .large-up-6 > .column, .large-up-6 > .columns {
-    float: left;
-    width: 16.66667%; }
-    .large-up-6 > .column:nth-of-type(1n), .large-up-6 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .large-up-6 > .column:nth-of-type(6n+1), .large-up-6 > .columns:nth-of-type(6n+1) {
-      clear: both; }
-    .large-up-6 > .column:last-child, .large-up-6 > .columns:last-child {
-      float: left; }
-  .large-up-7 > .column, .large-up-7 > .columns {
-    float: left;
-    width: 14.28571%; }
-    .large-up-7 > .column:nth-of-type(1n), .large-up-7 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .large-up-7 > .column:nth-of-type(7n+1), .large-up-7 > .columns:nth-of-type(7n+1) {
-      clear: both; }
-    .large-up-7 > .column:last-child, .large-up-7 > .columns:last-child {
-      float: left; }
-  .large-up-8 > .column, .large-up-8 > .columns {
-    float: left;
-    width: 12.5%; }
-    .large-up-8 > .column:nth-of-type(1n), .large-up-8 > .columns:nth-of-type(1n) {
-      clear: none; }
-    .large-up-8 > .column:nth-of-type(8n+1), .large-up-8 > .columns:nth-of-type(8n+1) {
-      clear: both; }
-    .large-up-8 > .column:last-child, .large-up-8 > .columns:last-child {
-      float: left; }
-  .large-collapse > .column, .large-collapse > .columns {
-    padding-right: 0;
-    padding-left: 0; }
-  .large-collapse .row {
-    margin-right: 0;
-    margin-left: 0; }
-  .expanded.row .large-collapse.row {
-    margin-right: 0;
-    margin-left: 0; }
-  .large-uncollapse > .column, .large-uncollapse > .columns {
-    padding-right: 0.9375rem;
-    padding-left: 0.9375rem; }
-  .large-centered {
-    margin-right: auto;
-    margin-left: auto; }
-    .large-centered, .large-centered:last-child:not(:first-child) {
-      float: none;
-      clear: both; }
-  .large-uncentered,
-  .large-push-0,
-  .large-pull-0 {
-    position: static;
-    float: left;
-    margin-right: 0;
-    margin-left: 0; } }
-
-.column-block {
-  margin-bottom: 1.25rem; }
-  .column-block > :last-child {
-    margin-bottom: 0; }
-  @media print, screen and (min-width: 40em) {
-    .column-block {
-      margin-bottom: 1.875rem; }
-      .column-block > :last-child {
-        margin-bottom: 0; } }
-
-div,
-dl,
-dt,
-dd,
-ul,
-ol,
-li,
-h1,
-h2,
-h3,
-h4,
-h5,
-h6,
-pre,
-form,
-p,
-blockquote,
-th,
-td {
-  margin: 0;
-  padding: 0; }
-
-p {
-  margin-bottom: 1rem;
-  font-size: inherit;
-  line-height: 1.6;
-  text-rendering: optimizeLegibility; }
-
-em,
-i {
-  font-style: italic;
-  line-height: inherit; }
-
-strong,
-b {
-  font-weight: bold;
-  line-height: inherit; }
-
-small {
-  font-size: 80%;
-  line-height: inherit; }
+.small-1 {
+  width: 8.33333%; }
 
-h1, .h1,
-h2, .h2,
-h3, .h3,
-h4, .h4,
-h5, .h5,
-h6, .h6 {
-  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
-  font-style: normal;
-  font-weight: normal;
-  color: inherit;
-  text-rendering: optimizeLegibility; }
-  h1 small, .h1 small,
-  h2 small, .h2 small,
-  h3 small, .h3 small,
-  h4 small, .h4 small,
-  h5 small, .h5 small,
-  h6 small, .h6 small {
-    line-height: 0;
-    color: #cacaca; }
+.small-push-1 {
+  position: relative;
+  left: 8.33333%; }
 
-h1, .h1 {
-  font-size: 1.5rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-pull-1 {
+  position: relative;
+  left: -8.33333%; }
 
-h2, .h2 {
-  font-size: 1.25rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-offset-0 {
+  margin-left: 0%; }
 
-h3, .h3 {
-  font-size: 1.1875rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-2 {
+  width: 16.66667%; }
 
-h4, .h4 {
-  font-size: 1.125rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-push-2 {
+  position: relative;
+  left: 16.66667%; }
 
-h5, .h5 {
-  font-size: 1.0625rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-pull-2 {
+  position: relative;
+  left: -16.66667%; }
 
-h6, .h6 {
-  font-size: 1rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-offset-1 {
+  margin-left: 8.33333%; }
 
-@media print, screen and (min-width: 40em) {
-  h1, .h1 {
-    font-size: 3rem; }
-  h2, .h2 {
-    font-size: 2.5rem; }
-  h3, .h3 {
-    font-size: 1.9375rem; }
-  h4, .h4 {
-    font-size: 1.5625rem; }
-  h5, .h5 {
-    font-size: 1.25rem; }
-  h6, .h6 {
-    font-size: 1rem; } }
+.small-3 {
+  width: 25%; }
 
-a {
-  line-height: inherit;
-  color: #1779ba;
-  text-decoration: none;
-  cursor: pointer; }
-  a:hover, a:focus {
-    color: #1468a0; }
-  a img {
-    border: 0; }
+.small-push-3 {
+  position: relative;
+  left: 25%; }
 
-hr {
-  clear: both;
-  max-width: 75rem;
-  height: 0;
-  margin: 1.25rem auto;
-  border-top: 0;
-  border-right: 0;
-  border-bottom: 1px solid #cacaca;
-  border-left: 0; }
+.small-pull-3 {
+  position: relative;
+  left: -25%; }
 
-ul,
-ol,
-dl {
-  margin-bottom: 1rem;
-  list-style-position: outside;
-  line-height: 1.6; }
+.small-offset-2 {
+  margin-left: 16.66667%; }
 
-li {
-  font-size: inherit; }
+.small-4 {
+  width: 33.33333%; }
 
-ul {
-  margin-left: 1.25rem;
-  list-style-type: disc; }
+.small-push-4 {
+  position: relative;
+  left: 33.33333%; }
 
-ol {
-  margin-left: 1.25rem; }
+.small-pull-4 {
+  position: relative;
+  left: -33.33333%; }
 
-ul ul, ol ul, ul ol, ol ol {
-  margin-left: 1.25rem;
-  margin-bottom: 0; }
+.small-offset-3 {
+  margin-left: 25%; }
 
-dl {
-  margin-bottom: 1rem; }
-  dl dt {
-    margin-bottom: 0.3rem;
-    font-weight: bold; }
+.small-5 {
+  width: 41.66667%; }
 
-blockquote {
-  margin: 0 0 1rem;
-  padding: 0.5625rem 1.25rem 0 1.1875rem;
-  border-left: 1px solid #cacaca; }
-  blockquote, blockquote p {
-    line-height: 1.6;
-    color: #8a8a8a; }
+.small-push-5 {
+  position: relative;
+  left: 41.66667%; }
 
-cite {
-  display: block;
-  font-size: 0.8125rem;
-  color: #8a8a8a; }
-  cite:before {
-    content: "— "; }
+.small-pull-5 {
+  position: relative;
+  left: -41.66667%; }
 
-abbr, abbr[title] {
-  border-bottom: 1px dotted #0a0a0a;
-  cursor: help;
-  text-decoration: none; }
+.small-offset-4 {
+  margin-left: 33.33333%; }
 
-figure {
-  margin: 0; }
+.small-6 {
+  width: 50%; }
 
-code {
-  padding: 0.125rem 0.3125rem 0.0625rem;
-  border: 1px solid #cacaca;
-  background-color: #e6e6e6;
-  font-family: Consolas, "Liberation Mono", Courier, monospace;
-  font-weight: normal;
-  color: #0a0a0a; }
+.small-push-6 {
+  position: relative;
+  left: 50%; }
 
-kbd {
-  margin: 0;
-  padding: 0.125rem 0.25rem 0;
-  background-color: #e6e6e6;
-  font-family: Consolas, "Liberation Mono", Courier, monospace;
-  color: #0a0a0a; }
+.small-pull-6 {
+  position: relative;
+  left: -50%; }
 
-.subheader {
-  margin-top: 0.2rem;
-  margin-bottom: 0.5rem;
-  font-weight: normal;
-  line-height: 1.4;
-  color: #8a8a8a; }
+.small-offset-5 {
+  margin-left: 41.66667%; }
 
-.lead {
-  font-size: 125%;
-  line-height: 1.6; }
+.small-7 {
+  width: 58.33333%; }
 
-.stat {
-  font-size: 2.5rem;
-  line-height: 1; }
-  p + .stat {
-    margin-top: -1rem; }
+.small-push-7 {
+  position: relative;
+  left: 58.33333%; }
 
-ul.no-bullet, ol.no-bullet {
-  margin-left: 0;
-  list-style: none; }
+.small-pull-7 {
+  position: relative;
+  left: -58.33333%; }
 
-.text-left {
-  text-align: left; }
+.small-offset-6 {
+  margin-left: 50%; }
 
-.text-right {
-  text-align: right; }
+.small-8 {
+  width: 66.66667%; }
 
-.text-center {
-  text-align: center; }
+.small-push-8 {
+  position: relative;
+  left: 66.66667%; }
 
-.text-justify {
-  text-align: justify; }
+.small-pull-8 {
+  position: relative;
+  left: -66.66667%; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-text-left {
-    text-align: left; }
-  .medium-text-right {
-    text-align: right; }
-  .medium-text-center {
-    text-align: center; }
-  .medium-text-justify {
-    text-align: justify; } }
+.small-offset-7 {
+  margin-left: 58.33333%; }
 
-@media print, screen and (min-width: 64em) {
-  .large-text-left {
-    text-align: left; }
-  .large-text-right {
-    text-align: right; }
-  .large-text-center {
-    text-align: center; }
-  .large-text-justify {
-    text-align: justify; } }
+.small-9 {
+  width: 75%; }
 
-.show-for-print {
-  display: none !important; }
+.small-push-9 {
+  position: relative;
+  left: 75%; }
 
-@media print {
-  * {
-    background: transparent !important;
-    -webkit-box-shadow: none !important;
-            box-shadow: none !important;
-    color: black !important;
-    text-shadow: none !important; }
-  .show-for-print {
-    display: block !important; }
-  .hide-for-print {
-    display: none !important; }
-  table.show-for-print {
-    display: table !important; }
-  thead.show-for-print {
-    display: table-header-group !important; }
-  tbody.show-for-print {
-    display: table-row-group !important; }
-  tr.show-for-print {
-    display: table-row !important; }
-  td.show-for-print {
-    display: table-cell !important; }
-  th.show-for-print {
-    display: table-cell !important; }
-  a,
-  a:visited {
-    text-decoration: underline; }
-  a[href]:after {
-    content: " (" attr(href) ")"; }
-  .ir a:after,
-  a[href^='javascript:']:after,
-  a[href^='#']:after {
-    content: ''; }
-  abbr[title]:after {
-    content: " (" attr(title) ")"; }
-  pre,
-  blockquote {
-    border: 1px solid #8a8a8a;
-    page-break-inside: avoid; }
-  thead {
-    display: table-header-group; }
-  tr,
-  img {
-    page-break-inside: avoid; }
-  img {
-    max-width: 100% !important; }
-  @page {
-    margin: 0.5cm; }
-  p,
-  h2,
-  h3 {
-    orphans: 3;
-    widows: 3; }
-  h2,
-  h3 {
-    page-break-after: avoid; }
-  .print-break-inside {
-    page-break-inside: auto; } }
+.small-pull-9 {
+  position: relative;
+  left: -75%; }
 
-[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],
-textarea {
-  display: block;
-  -webkit-box-sizing: border-box;
-          box-sizing: border-box;
-  width: 100%;
-  height: 2.4375rem;
-  margin: 0 0 1rem;
-  padding: 0.5rem;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
-          box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
-  font-family: inherit;
-  font-size: 1rem;
-  font-weight: normal;
-  line-height: 1.5;
-  color: #0a0a0a;
-  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none; }
-  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,
-  textarea:focus {
-    outline: none;
-    border: 1px solid #8a8a8a;
-    background-color: #fefefe;
-    -webkit-box-shadow: 0 0 5px #cacaca;
-            box-shadow: 0 0 5px #cacaca;
-    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+.small-offset-8 {
+  margin-left: 66.66667%; }
 
-textarea {
-  max-width: 100%; }
-  textarea[rows] {
-    height: auto; }
+.small-10 {
+  width: 83.33333%; }
 
-input::-webkit-input-placeholder,
-textarea::-webkit-input-placeholder {
-  color: #cacaca; }
+.small-push-10 {
+  position: relative;
+  left: 83.33333%; }
 
-input:-ms-input-placeholder,
-textarea:-ms-input-placeholder {
-  color: #cacaca; }
+.small-pull-10 {
+  position: relative;
+  left: -83.33333%; }
 
-input::placeholder,
-textarea::placeholder {
-  color: #cacaca; }
+.small-offset-9 {
+  margin-left: 75%; }
 
-input:disabled, input[readonly],
-textarea:disabled,
-textarea[readonly] {
-  background-color: #e6e6e6;
-  cursor: not-allowed; }
+.small-11 {
+  width: 91.66667%; }
 
-[type='submit'],
-[type='button'] {
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none;
-  border-radius: 0; }
+.small-push-11 {
+  position: relative;
+  left: 91.66667%; }
 
-input[type='search'] {
-  -webkit-box-sizing: border-box;
-          box-sizing: border-box; }
+.small-pull-11 {
+  position: relative;
+  left: -91.66667%; }
 
-[type='file'],
-[type='checkbox'],
-[type='radio'] {
-  margin: 0 0 1rem; }
+.small-offset-10 {
+  margin-left: 83.33333%; }
 
-[type='checkbox'] + label,
-[type='radio'] + label {
-  display: inline-block;
-  vertical-align: baseline;
-  margin-left: 0.5rem;
-  margin-right: 1rem;
-  margin-bottom: 0; }
-  [type='checkbox'] + label[for],
-  [type='radio'] + label[for] {
-    cursor: pointer; }
+.small-12 {
+  width: 100%; }
 
-label > [type='checkbox'],
-label > [type='radio'] {
-  margin-right: 0.5rem; }
+.small-offset-11 {
+  margin-left: 91.66667%; }
 
-[type='file'] {
+.small-up-1 > .column, .small-up-1 > .columns {
+  float: left;
   width: 100%; }
+  .small-up-1 > .column:nth-of-type(1n), .small-up-1 > .columns:nth-of-type(1n) {
+    clear: none; }
+  .small-up-1 > .column:nth-of-type(1n+1), .small-up-1 > .columns:nth-of-type(1n+1) {
+    clear: both; }
+  .small-up-1 > .column:last-child, .small-up-1 > .columns:last-child {
+    float: left; }
 
-label {
-  display: block;
-  margin: 0;
-  font-size: 0.875rem;
-  font-weight: normal;
-  line-height: 1.8;
-  color: #0a0a0a; }
-  label.middle {
-    margin: 0 0 1rem;
-    padding: 0.5625rem 0; }
+.small-up-2 > .column, .small-up-2 > .columns {
+  float: left;
+  width: 50%; }
+  .small-up-2 > .column:nth-of-type(1n), .small-up-2 > .columns:nth-of-type(1n) {
+    clear: none; }
+  .small-up-2 > .column:nth-of-type(2n+1), .small-up-2 > .columns:nth-of-type(2n+1) {
+    clear: both; }
+  .small-up-2 > .column:last-child, .small-up-2 > .columns:last-child {
+    float: left; }
 
-.help-text {
-  margin-top: -0.5rem;
-  font-size: 0.8125rem;
-  font-style: italic;
-  color: #0a0a0a; }
+.small-up-3 > .column, .small-up-3 > .columns {
+  float: left;
+  width: 33.33333%; }
+  .small-up-3 > .column:nth-of-type(1n), .small-up-3 > .columns:nth-of-type(1n) {
+    clear: none; }
+  .small-up-3 > .column:nth-of-type(3n+1), .small-up-3 > .columns:nth-of-type(3n+1) {
+    clear: both; }
+  .small-up-3 > .column:last-child, .small-up-3 > .columns:last-child {
+    float: left; }
 
-.input-group {
-  display: table;
-  width: 100%;
-  margin-bottom: 1rem; }
-  .input-group > :first-child {
-    border-radius: 0 0 0 0; }
-  .input-group > :last-child > * {
-    border-radius: 0 0 0 0; }
+.small-up-4 > .column, .small-up-4 > .columns {
+  float: left;
+  width: 25%; }
+  .small-up-4 > .column:nth-of-type(1n), .small-up-4 > .columns:nth-of-type(1n) {
+    clear: none; }
+  .small-up-4 > .column:nth-of-type(4n+1), .small-up-4 > .columns:nth-of-type(4n+1) {
+    clear: both; }
+  .small-up-4 > .column:last-child, .small-up-4 > .columns:last-child {
+    float: left; }
 
-.input-group-label, .input-group-field, .input-group-button, .input-group-button a,
-.input-group-button input,
-.input-group-button button,
-.input-group-button label {
-  margin: 0;
-  white-space: nowrap;
-  display: table-cell;
-  vertical-align: middle; }
+.small-up-5 > .column, .small-up-5 > .columns {
+  float: left;
+  width: 20%; }
+  .small-up-5 > .column:nth-of-type(1n), .small-up-5 > .columns:nth-of-type(1n) {
+    clear: none; }
+  .small-up-5 > .column:nth-of-type(5n+1), .small-up-5 > .columns:nth-of-type(5n+1) {
+    clear: both; }
+  .small-up-5 > .column:last-child, .small-up-5 > .columns:last-child {
+    float: left; }
 
-.input-group-label {
-  padding: 0 1rem;
-  border: 1px solid #cacaca;
-  background: #e6e6e6;
-  color: #0a0a0a;
-  text-align: center;
-  white-space: nowrap;
-  width: 1%;
-  height: 100%; }
-  .input-group-label:first-child {
-    border-right: 0; }
-  .input-group-label:last-child {
-    border-left: 0; }
+.small-up-6 > .column, .small-up-6 > .columns {
+  float: left;
+  width: 16.66667%; }
+  .small-up-6 > .column:nth-of-type(1n), .small-up-6 > .columns:nth-of-type(1n) {
+    clear: none; }
+  .small-up-6 > .column:nth-of-type(6n+1), .small-up-6 > .columns:nth-of-type(6n+1) {
+    clear: both; }
+  .small-up-6 > .column:last-child, .small-up-6 > .columns:last-child {
+    float: left; }
 
-.input-group-field {
-  border-radius: 0;
-  height: 2.5rem; }
+.small-up-7 > .column, .small-up-7 > .columns {
+  float: left;
+  width: 14.28571%; }
+  .small-up-7 > .column:nth-of-type(1n), .small-up-7 > .columns:nth-of-type(1n) {
+    clear: none; }
+  .small-up-7 > .column:nth-of-type(7n+1), .small-up-7 > .columns:nth-of-type(7n+1) {
+    clear: both; }
+  .small-up-7 > .column:last-child, .small-up-7 > .columns:last-child {
+    float: left; }
 
-.input-group-button {
-  padding-top: 0;
-  padding-bottom: 0;
-  text-align: center;
-  width: 1%;
-  height: 100%; }
-  .input-group-button a,
-  .input-group-button input,
-  .input-group-button button,
-  .input-group-button label {
-    height: 2.5rem;
-    padding-top: 0;
-    padding-bottom: 0;
-    font-size: 1rem; }
+.small-up-8 > .column, .small-up-8 > .columns {
+  float: left;
+  width: 12.5%; }
+  .small-up-8 > .column:nth-of-type(1n), .small-up-8 > .columns:nth-of-type(1n) {
+    clear: none; }
+  .small-up-8 > .column:nth-of-type(8n+1), .small-up-8 > .columns:nth-of-type(8n+1) {
+    clear: both; }
+  .small-up-8 > .column:last-child, .small-up-8 > .columns:last-child {
+    float: left; }
 
-.input-group .input-group-button {
-  display: table-cell; }
+.small-collapse > .column, .small-collapse > .columns {
+  padding-right: 0;
+  padding-left: 0; }
 
-fieldset {
-  margin: 0;
-  padding: 0;
-  border: 0; }
+.small-collapse .row {
+  margin-right: 0;
+  margin-left: 0; }
 
-legend {
-  max-width: 100%;
-  margin-bottom: 0.5rem; }
+.expanded.row .small-collapse.row {
+  margin-right: 0;
+  margin-left: 0; }
 
-.fieldset {
-  margin: 1.125rem 0;
-  padding: 1.25rem;
-  border: 1px solid #cacaca; }
-  .fieldset legend {
-    margin: 0;
-    margin-left: -0.1875rem;
-    padding: 0 0.1875rem; }
+.small-uncollapse > .column, .small-uncollapse > .columns {
+  padding-right: 0.625rem;
+  padding-left: 0.625rem; }
 
-select {
-  height: 2.4375rem;
-  margin: 0 0 1rem;
-  padding: 0.5rem;
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  font-family: inherit;
-  font-size: 1rem;
-  font-weight: normal;
-  line-height: 1.5;
-  color: #0a0a0a;
-  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");
-  -webkit-background-origin: content-box;
-          background-origin: content-box;
-  background-position: right -1rem center;
-  background-repeat: no-repeat;
-  -webkit-background-size: 9px 6px;
-          background-size: 9px 6px;
-  padding-right: 1.5rem;
-  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-  @media screen and (min-width: 0\0) {
-    select {
-      background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } }
-  select:focus {
-    outline: none;
-    border: 1px solid #8a8a8a;
-    background-color: #fefefe;
-    -webkit-box-shadow: 0 0 5px #cacaca;
-            box-shadow: 0 0 5px #cacaca;
-    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-  select:disabled {
-    background-color: #e6e6e6;
-    cursor: not-allowed; }
-  select::-ms-expand {
-    display: none; }
-  select[multiple] {
-    height: auto;
-    background-image: none; }
+.small-centered {
+  margin-right: auto;
+  margin-left: auto; }
+  .small-centered, .small-centered:last-child:not(:first-child) {
+    float: none;
+    clear: both; }
 
-.is-invalid-input:not(:focus) {
-  border-color: #cc4b37;
-  background-color: #f9ecea; }
-  .is-invalid-input:not(:focus)::-webkit-input-placeholder {
-    color: #cc4b37; }
-  .is-invalid-input:not(:focus):-ms-input-placeholder {
-    color: #cc4b37; }
-  .is-invalid-input:not(:focus)::placeholder {
-    color: #cc4b37; }
+.small-uncentered,
+.small-push-0,
+.small-pull-0 {
+  position: static;
+  margin-right: 0;
+  margin-left: 0; }
+  .small-uncentered, .small-uncentered:last-child:not(:first-child),
+  .small-push-0,
+  .small-push-0:last-child:not(:first-child),
+  .small-pull-0,
+  .small-pull-0:last-child:not(:first-child) {
+    float: left;
+    clear: none; }
+  .small-uncentered:last-child:not(:first-child),
+  .small-push-0:last-child:not(:first-child),
+  .small-pull-0:last-child:not(:first-child) {
+    float: right; }
+
+@media print, screen and (min-width: 40em) {
+  .medium-1 {
+    width: 8.33333%; }
+  .medium-push-1 {
+    position: relative;
+    left: 8.33333%; }
+  .medium-pull-1 {
+    position: relative;
+    left: -8.33333%; }
+  .medium-offset-0 {
+    margin-left: 0%; }
+  .medium-2 {
+    width: 16.66667%; }
+  .medium-push-2 {
+    position: relative;
+    left: 16.66667%; }
+  .medium-pull-2 {
+    position: relative;
+    left: -16.66667%; }
+  .medium-offset-1 {
+    margin-left: 8.33333%; }
+  .medium-3 {
+    width: 25%; }
+  .medium-push-3 {
+    position: relative;
+    left: 25%; }
+  .medium-pull-3 {
+    position: relative;
+    left: -25%; }
+  .medium-offset-2 {
+    margin-left: 16.66667%; }
+  .medium-4 {
+    width: 33.33333%; }
+  .medium-push-4 {
+    position: relative;
+    left: 33.33333%; }
+  .medium-pull-4 {
+    position: relative;
+    left: -33.33333%; }
+  .medium-offset-3 {
+    margin-left: 25%; }
+  .medium-5 {
+    width: 41.66667%; }
+  .medium-push-5 {
+    position: relative;
+    left: 41.66667%; }
+  .medium-pull-5 {
+    position: relative;
+    left: -41.66667%; }
+  .medium-offset-4 {
+    margin-left: 33.33333%; }
+  .medium-6 {
+    width: 50%; }
+  .medium-push-6 {
+    position: relative;
+    left: 50%; }
+  .medium-pull-6 {
+    position: relative;
+    left: -50%; }
+  .medium-offset-5 {
+    margin-left: 41.66667%; }
+  .medium-7 {
+    width: 58.33333%; }
+  .medium-push-7 {
+    position: relative;
+    left: 58.33333%; }
+  .medium-pull-7 {
+    position: relative;
+    left: -58.33333%; }
+  .medium-offset-6 {
+    margin-left: 50%; }
+  .medium-8 {
+    width: 66.66667%; }
+  .medium-push-8 {
+    position: relative;
+    left: 66.66667%; }
+  .medium-pull-8 {
+    position: relative;
+    left: -66.66667%; }
+  .medium-offset-7 {
+    margin-left: 58.33333%; }
+  .medium-9 {
+    width: 75%; }
+  .medium-push-9 {
+    position: relative;
+    left: 75%; }
+  .medium-pull-9 {
+    position: relative;
+    left: -75%; }
+  .medium-offset-8 {
+    margin-left: 66.66667%; }
+  .medium-10 {
+    width: 83.33333%; }
+  .medium-push-10 {
+    position: relative;
+    left: 83.33333%; }
+  .medium-pull-10 {
+    position: relative;
+    left: -83.33333%; }
+  .medium-offset-9 {
+    margin-left: 75%; }
+  .medium-11 {
+    width: 91.66667%; }
+  .medium-push-11 {
+    position: relative;
+    left: 91.66667%; }
+  .medium-pull-11 {
+    position: relative;
+    left: -91.66667%; }
+  .medium-offset-10 {
+    margin-left: 83.33333%; }
+  .medium-12 {
+    width: 100%; }
+  .medium-offset-11 {
+    margin-left: 91.66667%; }
+  .medium-up-1 > .column, .medium-up-1 > .columns {
+    float: left;
+    width: 100%; }
+    .medium-up-1 > .column:nth-of-type(1n), .medium-up-1 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .medium-up-1 > .column:nth-of-type(1n+1), .medium-up-1 > .columns:nth-of-type(1n+1) {
+      clear: both; }
+    .medium-up-1 > .column:last-child, .medium-up-1 > .columns:last-child {
+      float: left; }
+  .medium-up-2 > .column, .medium-up-2 > .columns {
+    float: left;
+    width: 50%; }
+    .medium-up-2 > .column:nth-of-type(1n), .medium-up-2 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .medium-up-2 > .column:nth-of-type(2n+1), .medium-up-2 > .columns:nth-of-type(2n+1) {
+      clear: both; }
+    .medium-up-2 > .column:last-child, .medium-up-2 > .columns:last-child {
+      float: left; }
+  .medium-up-3 > .column, .medium-up-3 > .columns {
+    float: left;
+    width: 33.33333%; }
+    .medium-up-3 > .column:nth-of-type(1n), .medium-up-3 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .medium-up-3 > .column:nth-of-type(3n+1), .medium-up-3 > .columns:nth-of-type(3n+1) {
+      clear: both; }
+    .medium-up-3 > .column:last-child, .medium-up-3 > .columns:last-child {
+      float: left; }
+  .medium-up-4 > .column, .medium-up-4 > .columns {
+    float: left;
+    width: 25%; }
+    .medium-up-4 > .column:nth-of-type(1n), .medium-up-4 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .medium-up-4 > .column:nth-of-type(4n+1), .medium-up-4 > .columns:nth-of-type(4n+1) {
+      clear: both; }
+    .medium-up-4 > .column:last-child, .medium-up-4 > .columns:last-child {
+      float: left; }
+  .medium-up-5 > .column, .medium-up-5 > .columns {
+    float: left;
+    width: 20%; }
+    .medium-up-5 > .column:nth-of-type(1n), .medium-up-5 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .medium-up-5 > .column:nth-of-type(5n+1), .medium-up-5 > .columns:nth-of-type(5n+1) {
+      clear: both; }
+    .medium-up-5 > .column:last-child, .medium-up-5 > .columns:last-child {
+      float: left; }
+  .medium-up-6 > .column, .medium-up-6 > .columns {
+    float: left;
+    width: 16.66667%; }
+    .medium-up-6 > .column:nth-of-type(1n), .medium-up-6 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .medium-up-6 > .column:nth-of-type(6n+1), .medium-up-6 > .columns:nth-of-type(6n+1) {
+      clear: both; }
+    .medium-up-6 > .column:last-child, .medium-up-6 > .columns:last-child {
+      float: left; }
+  .medium-up-7 > .column, .medium-up-7 > .columns {
+    float: left;
+    width: 14.28571%; }
+    .medium-up-7 > .column:nth-of-type(1n), .medium-up-7 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .medium-up-7 > .column:nth-of-type(7n+1), .medium-up-7 > .columns:nth-of-type(7n+1) {
+      clear: both; }
+    .medium-up-7 > .column:last-child, .medium-up-7 > .columns:last-child {
+      float: left; }
+  .medium-up-8 > .column, .medium-up-8 > .columns {
+    float: left;
+    width: 12.5%; }
+    .medium-up-8 > .column:nth-of-type(1n), .medium-up-8 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .medium-up-8 > .column:nth-of-type(8n+1), .medium-up-8 > .columns:nth-of-type(8n+1) {
+      clear: both; }
+    .medium-up-8 > .column:last-child, .medium-up-8 > .columns:last-child {
+      float: left; }
+  .medium-collapse > .column, .medium-collapse > .columns {
+    padding-right: 0;
+    padding-left: 0; }
+  .medium-collapse .row {
+    margin-right: 0;
+    margin-left: 0; }
+  .expanded.row .medium-collapse.row {
+    margin-right: 0;
+    margin-left: 0; }
+  .medium-uncollapse > .column, .medium-uncollapse > .columns {
+    padding-right: 0.9375rem;
+    padding-left: 0.9375rem; }
+  .medium-centered {
+    margin-right: auto;
+    margin-left: auto; }
+    .medium-centered, .medium-centered:last-child:not(:first-child) {
+      float: none;
+      clear: both; }
+  .medium-uncentered,
+  .medium-push-0,
+  .medium-pull-0 {
+    position: static;
+    margin-right: 0;
+    margin-left: 0; }
+    .medium-uncentered, .medium-uncentered:last-child:not(:first-child),
+    .medium-push-0,
+    .medium-push-0:last-child:not(:first-child),
+    .medium-pull-0,
+    .medium-pull-0:last-child:not(:first-child) {
+      float: left;
+      clear: none; }
+    .medium-uncentered:last-child:not(:first-child),
+    .medium-push-0:last-child:not(:first-child),
+    .medium-pull-0:last-child:not(:first-child) {
+      float: right; } }
 
-.is-invalid-label {
-  color: #cc4b37; }
+@media print, screen and (min-width: 64em) {
+  .large-1 {
+    width: 8.33333%; }
+  .large-push-1 {
+    position: relative;
+    left: 8.33333%; }
+  .large-pull-1 {
+    position: relative;
+    left: -8.33333%; }
+  .large-offset-0 {
+    margin-left: 0%; }
+  .large-2 {
+    width: 16.66667%; }
+  .large-push-2 {
+    position: relative;
+    left: 16.66667%; }
+  .large-pull-2 {
+    position: relative;
+    left: -16.66667%; }
+  .large-offset-1 {
+    margin-left: 8.33333%; }
+  .large-3 {
+    width: 25%; }
+  .large-push-3 {
+    position: relative;
+    left: 25%; }
+  .large-pull-3 {
+    position: relative;
+    left: -25%; }
+  .large-offset-2 {
+    margin-left: 16.66667%; }
+  .large-4 {
+    width: 33.33333%; }
+  .large-push-4 {
+    position: relative;
+    left: 33.33333%; }
+  .large-pull-4 {
+    position: relative;
+    left: -33.33333%; }
+  .large-offset-3 {
+    margin-left: 25%; }
+  .large-5 {
+    width: 41.66667%; }
+  .large-push-5 {
+    position: relative;
+    left: 41.66667%; }
+  .large-pull-5 {
+    position: relative;
+    left: -41.66667%; }
+  .large-offset-4 {
+    margin-left: 33.33333%; }
+  .large-6 {
+    width: 50%; }
+  .large-push-6 {
+    position: relative;
+    left: 50%; }
+  .large-pull-6 {
+    position: relative;
+    left: -50%; }
+  .large-offset-5 {
+    margin-left: 41.66667%; }
+  .large-7 {
+    width: 58.33333%; }
+  .large-push-7 {
+    position: relative;
+    left: 58.33333%; }
+  .large-pull-7 {
+    position: relative;
+    left: -58.33333%; }
+  .large-offset-6 {
+    margin-left: 50%; }
+  .large-8 {
+    width: 66.66667%; }
+  .large-push-8 {
+    position: relative;
+    left: 66.66667%; }
+  .large-pull-8 {
+    position: relative;
+    left: -66.66667%; }
+  .large-offset-7 {
+    margin-left: 58.33333%; }
+  .large-9 {
+    width: 75%; }
+  .large-push-9 {
+    position: relative;
+    left: 75%; }
+  .large-pull-9 {
+    position: relative;
+    left: -75%; }
+  .large-offset-8 {
+    margin-left: 66.66667%; }
+  .large-10 {
+    width: 83.33333%; }
+  .large-push-10 {
+    position: relative;
+    left: 83.33333%; }
+  .large-pull-10 {
+    position: relative;
+    left: -83.33333%; }
+  .large-offset-9 {
+    margin-left: 75%; }
+  .large-11 {
+    width: 91.66667%; }
+  .large-push-11 {
+    position: relative;
+    left: 91.66667%; }
+  .large-pull-11 {
+    position: relative;
+    left: -91.66667%; }
+  .large-offset-10 {
+    margin-left: 83.33333%; }
+  .large-12 {
+    width: 100%; }
+  .large-offset-11 {
+    margin-left: 91.66667%; }
+  .large-up-1 > .column, .large-up-1 > .columns {
+    float: left;
+    width: 100%; }
+    .large-up-1 > .column:nth-of-type(1n), .large-up-1 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .large-up-1 > .column:nth-of-type(1n+1), .large-up-1 > .columns:nth-of-type(1n+1) {
+      clear: both; }
+    .large-up-1 > .column:last-child, .large-up-1 > .columns:last-child {
+      float: left; }
+  .large-up-2 > .column, .large-up-2 > .columns {
+    float: left;
+    width: 50%; }
+    .large-up-2 > .column:nth-of-type(1n), .large-up-2 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .large-up-2 > .column:nth-of-type(2n+1), .large-up-2 > .columns:nth-of-type(2n+1) {
+      clear: both; }
+    .large-up-2 > .column:last-child, .large-up-2 > .columns:last-child {
+      float: left; }
+  .large-up-3 > .column, .large-up-3 > .columns {
+    float: left;
+    width: 33.33333%; }
+    .large-up-3 > .column:nth-of-type(1n), .large-up-3 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .large-up-3 > .column:nth-of-type(3n+1), .large-up-3 > .columns:nth-of-type(3n+1) {
+      clear: both; }
+    .large-up-3 > .column:last-child, .large-up-3 > .columns:last-child {
+      float: left; }
+  .large-up-4 > .column, .large-up-4 > .columns {
+    float: left;
+    width: 25%; }
+    .large-up-4 > .column:nth-of-type(1n), .large-up-4 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .large-up-4 > .column:nth-of-type(4n+1), .large-up-4 > .columns:nth-of-type(4n+1) {
+      clear: both; }
+    .large-up-4 > .column:last-child, .large-up-4 > .columns:last-child {
+      float: left; }
+  .large-up-5 > .column, .large-up-5 > .columns {
+    float: left;
+    width: 20%; }
+    .large-up-5 > .column:nth-of-type(1n), .large-up-5 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .large-up-5 > .column:nth-of-type(5n+1), .large-up-5 > .columns:nth-of-type(5n+1) {
+      clear: both; }
+    .large-up-5 > .column:last-child, .large-up-5 > .columns:last-child {
+      float: left; }
+  .large-up-6 > .column, .large-up-6 > .columns {
+    float: left;
+    width: 16.66667%; }
+    .large-up-6 > .column:nth-of-type(1n), .large-up-6 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .large-up-6 > .column:nth-of-type(6n+1), .large-up-6 > .columns:nth-of-type(6n+1) {
+      clear: both; }
+    .large-up-6 > .column:last-child, .large-up-6 > .columns:last-child {
+      float: left; }
+  .large-up-7 > .column, .large-up-7 > .columns {
+    float: left;
+    width: 14.28571%; }
+    .large-up-7 > .column:nth-of-type(1n), .large-up-7 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .large-up-7 > .column:nth-of-type(7n+1), .large-up-7 > .columns:nth-of-type(7n+1) {
+      clear: both; }
+    .large-up-7 > .column:last-child, .large-up-7 > .columns:last-child {
+      float: left; }
+  .large-up-8 > .column, .large-up-8 > .columns {
+    float: left;
+    width: 12.5%; }
+    .large-up-8 > .column:nth-of-type(1n), .large-up-8 > .columns:nth-of-type(1n) {
+      clear: none; }
+    .large-up-8 > .column:nth-of-type(8n+1), .large-up-8 > .columns:nth-of-type(8n+1) {
+      clear: both; }
+    .large-up-8 > .column:last-child, .large-up-8 > .columns:last-child {
+      float: left; }
+  .large-collapse > .column, .large-collapse > .columns {
+    padding-right: 0;
+    padding-left: 0; }
+  .large-collapse .row {
+    margin-right: 0;
+    margin-left: 0; }
+  .expanded.row .large-collapse.row {
+    margin-right: 0;
+    margin-left: 0; }
+  .large-uncollapse > .column, .large-uncollapse > .columns {
+    padding-right: 0.9375rem;
+    padding-left: 0.9375rem; }
+  .large-centered {
+    margin-right: auto;
+    margin-left: auto; }
+    .large-centered, .large-centered:last-child:not(:first-child) {
+      float: none;
+      clear: both; }
+  .large-uncentered,
+  .large-push-0,
+  .large-pull-0 {
+    position: static;
+    margin-right: 0;
+    margin-left: 0; }
+    .large-uncentered, .large-uncentered:last-child:not(:first-child),
+    .large-push-0,
+    .large-push-0:last-child:not(:first-child),
+    .large-pull-0,
+    .large-pull-0:last-child:not(:first-child) {
+      float: left;
+      clear: none; }
+    .large-uncentered:last-child:not(:first-child),
+    .large-push-0:last-child:not(:first-child),
+    .large-pull-0:last-child:not(:first-child) {
+      float: right; } }
 
-.form-error {
-  display: none;
-  margin-top: -0.5rem;
-  margin-bottom: 1rem;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #cc4b37; }
-  .form-error.is-visible {
-    display: block; }
+.column-block {
+  margin-bottom: 1.25rem; }
+  .column-block > :last-child {
+    margin-bottom: 0; }
+  @media print, screen and (min-width: 40em) {
+    .column-block {
+      margin-bottom: 1.875rem; }
+      .column-block > :last-child {
+        margin-bottom: 0; } }
 
 .button {
   display: inline-block;
   vertical-align: middle;
   margin: 0 0 1rem 0;
-  font-family: inherit;
   padding: 0.85em 1em;
-  -webkit-appearance: none;
   border: 1px solid transparent;
   border-radius: 0;
   -webkit-transition: background-color 0.25s ease-out, color 0.25s ease-out;
   transition: background-color 0.25s ease-out, color 0.25s ease-out;
+  font-family: inherit;
   font-size: 0.9rem;
+  -webkit-appearance: none;
   line-height: 1;
   text-align: center;
   cursor: pointer;
@@ -2063,245 +1823,51 @@ select {
           border: 1px solid #ffae00;
           color: #ffae00; }
       .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.alert {
-      border: 1px solid #cc4b37;
-      color: #cc4b37; }
-      .button.clear.alert:hover, .button.clear.alert:focus {
-        border-color: #67251a;
-        color: #67251a; }
-        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
-          border: 1px solid #cc4b37;
-          color: #cc4b37; }
-      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
-        border-color: transparent; }
-  .button.dropdown::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.4em;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #fefefe transparent transparent;
-    position: relative;
-    top: 0.4em;
-    display: inline-block;
-    float: right;
-    margin-left: 1em; }
-  .button.dropdown.hollow::after {
-    border-top-color: #1779ba; }
-  .button.dropdown.hollow.primary::after {
-    border-top-color: #1779ba; }
-  .button.dropdown.hollow.secondary::after {
-    border-top-color: #767676; }
-  .button.dropdown.hollow.success::after {
-    border-top-color: #3adb76; }
-  .button.dropdown.hollow.warning::after {
-    border-top-color: #ffae00; }
-  .button.dropdown.hollow.alert::after {
-    border-top-color: #cc4b37; }
-  .button.arrow-only::after {
-    top: -0.1em;
-    float: none;
-    margin-left: 0; }
-
-a.button:hover, a.button:focus {
-  text-decoration: none; }
-
-.accordion {
-  margin-left: 0;
-  background: #fefefe;
-  list-style-type: none; }
-  .accordion[disabled] .accordion-title {
-    cursor: not-allowed; }
-
-.accordion-item:first-child > :first-child {
-  border-radius: 0 0 0 0; }
-
-.accordion-item:last-child > :last-child {
-  border-radius: 0 0 0 0; }
-
-.accordion-title {
-  position: relative;
-  display: block;
-  padding: 1.25rem 1rem;
-  border: 1px solid #e6e6e6;
-  border-bottom: 0;
-  font-size: 0.75rem;
-  line-height: 1;
-  color: #1779ba; }
-  :last-child:not(.is-active) > .accordion-title {
-    border-bottom: 1px solid #e6e6e6;
-    border-radius: 0 0 0 0; }
-  .accordion-title:hover, .accordion-title:focus {
-    background-color: #e6e6e6; }
-  .accordion-title::before {
-    position: absolute;
-    top: 50%;
-    right: 1rem;
-    margin-top: -0.5rem;
-    content: '+'; }
-  .is-active > .accordion-title::before {
-    content: '\2013'; }
-
-.accordion-content {
-  display: none;
-  padding: 1rem;
-  border: 1px solid #e6e6e6;
-  border-bottom: 0;
-  background-color: #fefefe;
-  color: #0a0a0a; }
-  :last-child > .accordion-content:last-child {
-    border-bottom: 1px solid #e6e6e6; }
-
-.accordion-menu li {
-  width: 100%; }
-
-.accordion-menu a {
-  padding: 0.7rem 1rem; }
-
-.accordion-menu .is-accordion-submenu a {
-  padding: 0.7rem 1rem; }
-
-.accordion-menu .nested.is-accordion-submenu {
-  margin-right: 0;
-  margin-left: 1rem; }
-
-.accordion-menu.align-right .nested.is-accordion-submenu {
-  margin-right: 1rem;
-  margin-left: 0; }
-
-.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {
-  position: relative; }
-  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    position: absolute;
-    top: 50%;
-    margin-top: -3px;
-    right: 1rem; }
-
-.accordion-menu.align-left .is-accordion-submenu-parent > a::after {
-  left: auto;
-  right: 1rem; }
-
-.accordion-menu.align-right .is-accordion-submenu-parent > a::after {
-  right: auto;
-  left: 1rem; }
-
-.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {
-  -webkit-transform: rotate(180deg);
-      -ms-transform: rotate(180deg);
-          transform: rotate(180deg);
-  -webkit-transform-origin: 50% 50%;
-      -ms-transform-origin: 50% 50%;
-          transform-origin: 50% 50%; }
-
-.is-accordion-submenu-parent {
-  position: relative; }
-
-.has-submenu-toggle > a {
-  margin-right: 40px; }
-
-.submenu-toggle {
-  position: absolute;
-  top: 0;
-  right: 0;
-  cursor: pointer;
-  width: 40px;
-  height: 40px; }
-  .submenu-toggle::after {
+        border-color: transparent; }
+    .button.clear.alert {
+      border: 1px solid #cc4b37;
+      color: #cc4b37; }
+      .button.clear.alert:hover, .button.clear.alert:focus {
+        border-color: #67251a;
+        color: #67251a; }
+        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
+          border: 1px solid #cc4b37;
+          color: #cc4b37; }
+      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
+        border-color: transparent; }
+  .button.dropdown::after {
     display: block;
     width: 0;
     height: 0;
-    border: inset 6px;
+    border: inset 0.4em;
     content: '';
     border-bottom-width: 0;
     border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    top: 0;
-    bottom: 0;
-    margin: auto; }
-
-.submenu-toggle[aria-expanded='true']::after {
-  -webkit-transform: scaleY(-1);
-      -ms-transform: scaleY(-1);
-          transform: scaleY(-1);
-  -webkit-transform-origin: 50% 50%;
-      -ms-transform-origin: 50% 50%;
-          transform-origin: 50% 50%; }
-
-.submenu-toggle-text {
-  position: absolute !important;
-  width: 1px;
-  height: 1px;
-  padding: 0;
-  overflow: hidden;
-  clip: rect(0, 0, 0, 0);
-  white-space: nowrap;
-  -webkit-clip-path: inset(50%);
-          clip-path: inset(50%);
-  border: 0; }
-
-.badge {
-  display: inline-block;
-  min-width: 2.1em;
-  padding: 0.3em;
-  border-radius: 50%;
-  font-size: 0.6rem;
-  text-align: center;
-  background: #1779ba;
-  color: #fefefe; }
-  .badge.primary {
-    background: #1779ba;
-    color: #fefefe; }
-  .badge.secondary {
-    background: #767676;
-    color: #fefefe; }
-  .badge.success {
-    background: #3adb76;
-    color: #0a0a0a; }
-  .badge.warning {
-    background: #ffae00;
-    color: #0a0a0a; }
-  .badge.alert {
-    background: #cc4b37;
-    color: #fefefe; }
+    border-color: #fefefe transparent transparent;
+    position: relative;
+    top: 0.4em;
+    display: inline-block;
+    float: right;
+    margin-left: 1em; }
+  .button.dropdown.hollow::after, .button.dropdown.clear::after {
+    border-top-color: #1779ba; }
+  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {
+    border-top-color: #1779ba; }
+  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {
+    border-top-color: #767676; }
+  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {
+    border-top-color: #3adb76; }
+  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {
+    border-top-color: #ffae00; }
+  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {
+    border-top-color: #cc4b37; }
+  .button.arrow-only::after {
+    top: -0.1em;
+    float: none;
+    margin-left: 0; }
 
-.breadcrumbs {
-  margin: 0 0 1rem 0;
-  list-style: none; }
-  .breadcrumbs::before, .breadcrumbs::after {
-    display: table;
-    content: ' '; }
-  .breadcrumbs::after {
-    clear: both; }
-  .breadcrumbs li {
-    float: left;
-    font-size: 0.6875rem;
-    color: #0a0a0a;
-    cursor: default;
-    text-transform: uppercase; }
-    .breadcrumbs li:not(:last-child)::after {
-      position: relative;
-      margin: 0 0.75rem;
-      opacity: 1;
-      content: "/";
-      color: #cacaca; }
-  .breadcrumbs a {
-    color: #1779ba; }
-    .breadcrumbs a:hover {
-      text-decoration: underline; }
-  .breadcrumbs .disabled {
-    color: #cacaca;
-    cursor: not-allowed; }
+a.button:hover, a.button:focus {
+  text-decoration: none; }
 
 .button-group {
   margin-bottom: 1rem;
@@ -2329,7 +1895,7 @@ a.button:hover, a.button:focus {
     .button-group.expanded::before, .button-group.expanded::after {
       display: none; }
     .button-group.expanded .button:first-child:last-child {
-      width: 100%; }
+      width: calc(100% - 1px); }
     .button-group.expanded .button:first-child:nth-last-child(2), .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button {
       display: inline-block;
       width: calc(50% - 1px);
@@ -2394,6 +1960,42 @@ a.button:hover, a.button:focus {
     width: 100%; }
     .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {
       margin-bottom: 0; }
+  .button-group.stacked.expanded, .button-group.stacked-for-small.expanded, .button-group.stacked-for-medium.expanded {
+    margin-right: -1px; }
+    .button-group.stacked.expanded::before, .button-group.stacked.expanded::after, .button-group.stacked-for-small.expanded::before, .button-group.stacked-for-small.expanded::after, .button-group.stacked-for-medium.expanded::before, .button-group.stacked-for-medium.expanded::after {
+      display: none; }
+    .button-group.stacked.expanded .button:first-child:last-child, .button-group.stacked-for-small.expanded .button:first-child:last-child, .button-group.stacked-for-medium.expanded .button:first-child:last-child {
+      width: calc(100% - 1px); }
+    .button-group.stacked.expanded .button:first-child:nth-last-child(2), .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button {
+      display: inline-block;
+      width: calc(50% - 1px);
+      margin-right: 1px; }
+      .button-group.stacked.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child {
+        margin-right: -6px; }
+    .button-group.stacked.expanded .button:first-child:nth-last-child(3), .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button {
+      display: inline-block;
+      width: calc(33.33333% - 1px);
+      margin-right: 1px; }
+      .button-group.stacked.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child {
+        margin-right: -6px; }
+    .button-group.stacked.expanded .button:first-child:nth-last-child(4), .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button {
+      display: inline-block;
+      width: calc(25% - 1px);
+      margin-right: 1px; }
+      .button-group.stacked.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child {
+        margin-right: -6px; }
+    .button-group.stacked.expanded .button:first-child:nth-last-child(5), .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button {
+      display: inline-block;
+      width: calc(20% - 1px);
+      margin-right: 1px; }
+      .button-group.stacked.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child {
+        margin-right: -6px; }
+    .button-group.stacked.expanded .button:first-child:nth-last-child(6), .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button {
+      display: inline-block;
+      width: calc(16.66667% - 1px);
+      margin-right: 1px; }
+      .button-group.stacked.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child {
+        margin-right: -6px; }
   @media print, screen and (min-width: 40em) {
     .button-group.stacked-for-small .button {
       width: auto;
@@ -2402,406 +2004,491 @@ a.button:hover, a.button:focus {
     .button-group.stacked-for-medium .button {
       width: auto;
       margin-bottom: 0; } }
-  @media screen and (max-width: 39.9375em) {
+  @media screen and (max-width: 39.99875em) {
     .button-group.stacked-for-small.expanded {
       display: block; }
       .button-group.stacked-for-small.expanded .button {
         display: block;
         margin-right: 0; } }
+  @media screen and (max-width: 63.99875em) {
+    .button-group.stacked-for-medium.expanded {
+      display: block; }
+      .button-group.stacked-for-medium.expanded .button {
+        display: block;
+        margin-right: 0; } }
 
-.callout {
-  position: relative;
-  margin: 0 0 1rem 0;
-  padding: 1rem;
-  border: 1px solid rgba(10, 10, 10, 0.25);
-  border-radius: 0;
-  background-color: white;
-  color: #0a0a0a; }
-  .callout > :first-child {
-    margin-top: 0; }
-  .callout > :last-child {
-    margin-bottom: 0; }
-  .callout.primary {
-    background-color: #d7ecfa;
-    color: #0a0a0a; }
-  .callout.secondary {
-    background-color: #eaeaea;
-    color: #0a0a0a; }
-  .callout.success {
-    background-color: #e1faea;
+.close-button {
+  position: absolute;
+  color: #8a8a8a;
+  cursor: pointer; }
+  [data-whatinput='mouse'] .close-button {
+    outline: 0; }
+  .close-button:hover, .close-button:focus {
     color: #0a0a0a; }
-  .callout.warning {
-    background-color: #fff3d9;
+  .close-button.small {
+    right: 0.66rem;
+    top: 0.33em;
+    font-size: 1.5em;
+    line-height: 1; }
+  .close-button, .close-button.medium {
+    right: 1rem;
+    top: 0.5rem;
+    font-size: 2em;
+    line-height: 1; }
+
+.label {
+  display: inline-block;
+  padding: 0.33333rem 0.5rem;
+  border-radius: 0;
+  font-size: 0.8rem;
+  line-height: 1;
+  white-space: nowrap;
+  cursor: default;
+  background: #1779ba;
+  color: #fefefe; }
+  .label.primary {
+    background: #1779ba;
+    color: #fefefe; }
+  .label.secondary {
+    background: #767676;
+    color: #fefefe; }
+  .label.success {
+    background: #3adb76;
     color: #0a0a0a; }
-  .callout.alert {
-    background-color: #f7e4e1;
+  .label.warning {
+    background: #ffae00;
     color: #0a0a0a; }
-  .callout.small {
-    padding-top: 0.5rem;
-    padding-right: 0.5rem;
-    padding-bottom: 0.5rem;
-    padding-left: 0.5rem; }
-  .callout.large {
-    padding-top: 3rem;
-    padding-right: 3rem;
-    padding-bottom: 3rem;
-    padding-left: 3rem; }
+  .label.alert {
+    background: #cc4b37;
+    color: #fefefe; }
 
-.card {
+.progress {
+  height: 1rem;
   margin-bottom: 1rem;
-  border: 1px solid #e6e6e6;
   border-radius: 0;
-  background: #fefefe;
-  -webkit-box-shadow: none;
-          box-shadow: none;
-  overflow: hidden;
-  color: #0a0a0a; }
-  .card > :last-child {
-    margin-bottom: 0; }
+  background-color: #cacaca; }
+  .progress.primary .progress-meter {
+    background-color: #1779ba; }
+  .progress.secondary .progress-meter {
+    background-color: #767676; }
+  .progress.success .progress-meter {
+    background-color: #3adb76; }
+  .progress.warning .progress-meter {
+    background-color: #ffae00; }
+  .progress.alert .progress-meter {
+    background-color: #cc4b37; }
 
-.card-divider {
-  padding: 1rem;
-  background: #e6e6e6; }
-  .card-divider > :last-child {
-    margin-bottom: 0; }
+.progress-meter {
+  position: relative;
+  display: block;
+  width: 0%;
+  height: 100%;
+  background-color: #1779ba; }
 
-.card-section {
-  padding: 1rem; }
-  .card-section > :last-child {
-    margin-bottom: 0; }
+.progress-meter-text {
+  position: absolute;
+  top: 50%;
+  left: 50%;
+  -webkit-transform: translate(-50%, -50%);
+      -ms-transform: translate(-50%, -50%);
+          transform: translate(-50%, -50%);
+  margin: 0;
+  font-size: 0.75rem;
+  font-weight: bold;
+  color: #fefefe;
+  white-space: nowrap; }
 
-.card-image {
-  min-height: 1px; }
+.slider {
+  position: relative;
+  height: 0.5rem;
+  margin-top: 1.25rem;
+  margin-bottom: 2.25rem;
+  background-color: #e6e6e6;
+  cursor: pointer;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+  -ms-touch-action: none;
+      touch-action: none; }
 
-.close-button {
+.slider-fill {
   position: absolute;
-  color: #8a8a8a;
-  cursor: pointer; }
-  [data-whatinput='mouse'] .close-button {
-    outline: 0; }
-  .close-button:hover, .close-button:focus {
-    color: #0a0a0a; }
-  .close-button.small {
-    right: 0.66rem;
-    top: 0.33em;
-    font-size: 1.5em;
-    line-height: 1; }
-  .close-button, .close-button.medium {
-    right: 1rem;
-    top: 0.5rem;
-    font-size: 2em;
-    line-height: 1; }
+  top: 0;
+  left: 0;
+  display: inline-block;
+  max-width: 100%;
+  height: 0.5rem;
+  background-color: #cacaca;
+  -webkit-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out; }
+  .slider-fill.is-dragging {
+    -webkit-transition: all 0s linear;
+    transition: all 0s linear; }
 
-.menu {
-  padding: 0;
-  margin: 0;
-  list-style: none;
-  position: relative; }
-  [data-whatinput='mouse'] .menu li {
+.slider-handle {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%);
+  left: 0;
+  z-index: 1;
+  display: inline-block;
+  width: 1.4rem;
+  height: 1.4rem;
+  border-radius: 0;
+  background-color: #1779ba;
+  -webkit-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out;
+  -ms-touch-action: manipulation;
+      touch-action: manipulation; }
+  [data-whatinput='mouse'] .slider-handle {
     outline: 0; }
-  .menu a,
-  .menu .button {
-    line-height: 1;
-    text-decoration: none;
-    display: block;
-    padding: 0.7rem 1rem; }
-  .menu input,
-  .menu select,
-  .menu a,
-  .menu button {
-    margin-bottom: 0; }
-  .menu input {
-    display: inline-block; }
-  .menu li, .menu.horizontal li {
-    display: inline-block; }
-  .menu.vertical li {
-    display: block; }
-  .menu.expanded {
-    display: table;
-    width: 100%; }
-    .menu.expanded > li {
-      display: table-cell;
-      vertical-align: middle; }
-  .menu.simple li + li {
-    margin-left: 1rem; }
-  .menu.simple a {
-    padding: 0; }
-  @media print, screen and (min-width: 40em) {
-    .menu.medium-horizontal li {
-      display: inline-block; }
-    .menu.medium-vertical li {
-      display: block; }
-    .menu.medium-expanded {
-      display: table;
-      width: 100%; }
-      .menu.medium-expanded > li {
-        display: table-cell;
-        vertical-align: middle; }
-    .menu.medium-simple {
-      display: table;
-      width: 100%; }
-      .menu.medium-simple > li {
-        display: table-cell;
-        vertical-align: middle; } }
-  @media print, screen and (min-width: 64em) {
-    .menu.large-horizontal li {
-      display: inline-block; }
-    .menu.large-vertical li {
-      display: block; }
-    .menu.large-expanded {
-      display: table;
-      width: 100%; }
-      .menu.large-expanded > li {
-        display: table-cell;
-        vertical-align: middle; }
-    .menu.large-simple {
-      display: table;
-      width: 100%; }
-      .menu.large-simple > li {
-        display: table-cell;
-        vertical-align: middle; } }
-  .menu.nested {
-    margin-right: 0;
-    margin-left: 1rem; }
-  .menu.icons img,
-  .menu.icons i,
-  .menu.icons svg {
-    vertical-align: middle; }
-    .menu.icons img + span,
-    .menu.icons i + span,
-    .menu.icons svg + span {
-      vertical-align: middle; }
-  .menu.icon-top img,
-  .menu.icon-top i,
-  .menu.icon-top svg, .menu.icon-right img,
-  .menu.icon-right i,
-  .menu.icon-right svg, .menu.icon-bottom img,
-  .menu.icon-bottom i,
-  .menu.icon-bottom svg, .menu.icon-left img,
-  .menu.icon-left i,
-  .menu.icon-left svg {
-    vertical-align: middle; }
-    .menu.icon-top img + span,
-    .menu.icon-top i + span,
-    .menu.icon-top svg + span, .menu.icon-right img + span,
-    .menu.icon-right i + span,
-    .menu.icon-right svg + span, .menu.icon-bottom img + span,
-    .menu.icon-bottom i + span,
-    .menu.icon-bottom svg + span, .menu.icon-left img + span,
-    .menu.icon-left i + span,
-    .menu.icon-left svg + span {
-      vertical-align: middle; }
-  .menu.icon-left li a img,
-  .menu.icon-left li a i,
-  .menu.icon-left li a svg {
-    margin-right: 0.25rem;
-    display: inline-block; }
-  .menu.icon-right li a img,
-  .menu.icon-right li a i,
-  .menu.icon-right li a svg {
-    margin-left: 0.25rem;
-    display: inline-block; }
-  .menu.icon-top li a {
-    text-align: center; }
-    .menu.icon-top li a img,
-    .menu.icon-top li a i,
-    .menu.icon-top li a svg {
-      display: block;
-      margin: 0 auto 0.25rem; }
-  .menu.icon-bottom li a {
-    text-align: center; }
-    .menu.icon-bottom li a img,
-    .menu.icon-bottom li a i,
-    .menu.icon-bottom li a svg {
-      display: block;
-      margin: 0.25rem auto 0; }
-  .menu .is-active > a {
-    background: #1779ba;
-    color: #fefefe; }
-  .menu .active > a {
-    background: #1779ba;
-    color: #fefefe; }
-  .menu.align-left {
-    text-align: left; }
-  .menu.align-right {
-    text-align: right; }
-    .menu.align-right .submenu li {
-      text-align: left; }
-    .menu.align-right.vertical .submenu li {
-      text-align: right; }
-    .menu.align-right .nested {
-      margin-right: 1rem;
-      margin-left: 0; }
-  .menu.align-center {
-    text-align: center; }
-    .menu.align-center .submenu li {
-      text-align: left; }
-  .menu .menu-text {
-    padding: 0.7rem 1rem;
-    font-weight: bold;
-    line-height: 1;
-    color: inherit; }
+  .slider-handle:hover {
+    background-color: #14679e; }
+  .slider-handle.is-dragging {
+    -webkit-transition: all 0s linear;
+    transition: all 0s linear; }
 
-.menu-centered > .menu {
-  text-align: center; }
-  .menu-centered > .menu .submenu li {
-    text-align: left; }
+.slider.disabled,
+.slider[disabled] {
+  opacity: 0.25;
+  cursor: not-allowed; }
+
+.slider.vertical {
+  display: inline-block;
+  width: 0.5rem;
+  height: 12.5rem;
+  margin: 0 1.25rem;
+  -webkit-transform: scale(1, -1);
+      -ms-transform: scale(1, -1);
+          transform: scale(1, -1); }
+  .slider.vertical .slider-fill {
+    top: 0;
+    width: 0.5rem;
+    max-height: 100%; }
+  .slider.vertical .slider-handle {
+    position: absolute;
+    top: 0;
+    left: 50%;
+    width: 1.4rem;
+    height: 1.4rem;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+
+.switch {
+  height: 2rem;
+  position: relative;
+  margin-bottom: 1rem;
+  outline: 0;
+  font-size: 0.875rem;
+  font-weight: bold;
+  color: #fefefe;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none; }
 
-.no-js [data-responsive-menu] ul {
-  display: none; }
+.switch-input {
+  position: absolute;
+  margin-bottom: 0;
+  opacity: 0; }
 
-.menu-icon {
+.switch-paddle {
   position: relative;
-  display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
+  display: block;
+  width: 4rem;
+  height: 2rem;
+  border-radius: 0;
+  background: #cacaca;
+  -webkit-transition: all 0.25s ease-out;
+  transition: all 0.25s ease-out;
+  font-weight: inherit;
+  color: inherit;
   cursor: pointer; }
-  .menu-icon::after {
+  input + .switch-paddle {
+    margin: 0; }
+  .switch-paddle::after {
     position: absolute;
-    top: 0;
-    left: 0;
+    top: 0.25rem;
+    left: 0.25rem;
     display: block;
-    width: 100%;
-    height: 2px;
+    width: 1.5rem;
+    height: 1.5rem;
+    -webkit-transform: translate3d(0, 0, 0);
+            transform: translate3d(0, 0, 0);
+    border-radius: 0;
     background: #fefefe;
-    -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
-            box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+    -webkit-transition: all 0.25s ease-out;
+    transition: all 0.25s ease-out;
     content: ''; }
-  .menu-icon:hover::after {
-    background: #cacaca;
-    -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
-            box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }
+  input:checked ~ .switch-paddle {
+    background: #1779ba; }
+    input:checked ~ .switch-paddle::after {
+      left: 2.25rem; }
+  [data-whatinput='mouse'] input:focus ~ .switch-paddle {
+    outline: 0; }
 
-.menu-icon.dark {
-  position: relative;
-  display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer; }
-  .menu-icon.dark::after {
-    position: absolute;
-    top: 0;
-    left: 0;
-    display: block;
-    width: 100%;
-    height: 2px;
-    background: #0a0a0a;
-    -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-            box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-    content: ''; }
-  .menu-icon.dark:hover::after {
-    background: #8a8a8a;
-    -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
-            box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }
+.switch-active, .switch-inactive {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%); }
 
-.is-drilldown {
-  position: relative;
-  overflow: hidden; }
-  .is-drilldown li {
+.switch-active {
+  left: 8%;
+  display: none; }
+  input:checked + label > .switch-active {
     display: block; }
-  .is-drilldown.animate-height {
-    -webkit-transition: height 0.5s;
-    transition: height 0.5s; }
 
-.drilldown a {
-  padding: 0.7rem 1rem;
-  background: #fefefe; }
+.switch-inactive {
+  right: 15%; }
+  input:checked + label > .switch-inactive {
+    display: none; }
 
-.drilldown .is-drilldown-submenu {
-  position: absolute;
-  top: 0;
-  left: 100%;
-  z-index: -1;
+.switch.tiny {
+  height: 1.5rem; }
+  .switch.tiny .switch-paddle {
+    width: 3rem;
+    height: 1.5rem;
+    font-size: 0.625rem; }
+  .switch.tiny .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 1rem;
+    height: 1rem; }
+  .switch.tiny input:checked ~ .switch-paddle::after {
+    left: 1.75rem; }
+
+.switch.small {
+  height: 1.75rem; }
+  .switch.small .switch-paddle {
+    width: 3.5rem;
+    height: 1.75rem;
+    font-size: 0.75rem; }
+  .switch.small .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 1.25rem;
+    height: 1.25rem; }
+  .switch.small input:checked ~ .switch-paddle::after {
+    left: 2rem; }
+
+.switch.large {
+  height: 2.5rem; }
+  .switch.large .switch-paddle {
+    width: 5rem;
+    height: 2.5rem;
+    font-size: 1rem; }
+  .switch.large .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 2rem;
+    height: 2rem; }
+  .switch.large input:checked ~ .switch-paddle::after {
+    left: 2.75rem; }
+
+table {
+  border-collapse: collapse;
   width: 100%;
-  background: #fefefe;
-  -webkit-transition: -webkit-transform 0.15s linear;
-  transition: -webkit-transform 0.15s linear;
-  transition: transform 0.15s linear;
-  transition: transform 0.15s linear, -webkit-transform 0.15s linear; }
-  .drilldown .is-drilldown-submenu.is-active {
-    z-index: 1;
-    display: block;
-    -webkit-transform: translateX(-100%);
-        -ms-transform: translateX(-100%);
-            transform: translateX(-100%); }
-  .drilldown .is-drilldown-submenu.is-closing {
-    -webkit-transform: translateX(100%);
-        -ms-transform: translateX(100%);
-            transform: translateX(100%); }
-  .drilldown .is-drilldown-submenu a {
-    padding: 0.7rem 1rem; }
+  margin-bottom: 1rem;
+  border-radius: 0; }
+  thead,
+  tbody,
+  tfoot {
+    border: 1px solid #f1f1f1;
+    background-color: #fefefe; }
+  caption {
+    padding: 0.5rem 0.625rem 0.625rem;
+    font-weight: bold; }
+  thead {
+    background: #f8f8f8;
+    color: #0a0a0a; }
+  tfoot {
+    background: #f1f1f1;
+    color: #0a0a0a; }
+  thead tr,
+  tfoot tr {
+    background: transparent; }
+  thead th,
+  thead td,
+  tfoot th,
+  tfoot td {
+    padding: 0.5rem 0.625rem 0.625rem;
+    font-weight: bold;
+    text-align: left; }
+  tbody th,
+  tbody td {
+    padding: 0.5rem 0.625rem 0.625rem; }
+  tbody tr:nth-child(even) {
+    border-bottom: 0;
+    background-color: #f1f1f1; }
+  table.unstriped tbody {
+    background-color: #fefefe; }
+    table.unstriped tbody tr {
+      border-bottom: 0;
+      border-bottom: 1px solid #f1f1f1;
+      background-color: #fefefe; }
 
-.drilldown .nested.is-drilldown-submenu {
-  margin-right: 0;
-  margin-left: 0; }
+@media screen and (max-width: 63.99875em) {
+  table.stack thead {
+    display: none; }
+  table.stack tfoot {
+    display: none; }
+  table.stack tr,
+  table.stack th,
+  table.stack td {
+    display: block; }
+  table.stack td {
+    border-top: 0; } }
+
+table.scroll {
+  display: block;
+  width: 100%;
+  overflow-x: auto; }
+
+table.hover thead tr:hover {
+  background-color: #f3f3f3; }
+
+table.hover tfoot tr:hover {
+  background-color: #ececec; }
+
+table.hover tbody tr:hover {
+  background-color: #f9f9f9; }
+
+table.hover:not(.unstriped) tr:nth-of-type(even):hover {
+  background-color: #ececec; }
+
+.table-scroll {
+  overflow-x: auto; }
+
+.badge {
+  display: inline-block;
+  min-width: 2.1em;
+  padding: 0.3em;
+  border-radius: 50%;
+  font-size: 0.6rem;
+  text-align: center;
+  background: #1779ba;
+  color: #fefefe; }
+  .badge.primary {
+    background: #1779ba;
+    color: #fefefe; }
+  .badge.secondary {
+    background: #767676;
+    color: #fefefe; }
+  .badge.success {
+    background: #3adb76;
+    color: #0a0a0a; }
+  .badge.warning {
+    background: #ffae00;
+    color: #0a0a0a; }
+  .badge.alert {
+    background: #cc4b37;
+    color: #fefefe; }
+
+.breadcrumbs {
+  margin: 0 0 1rem 0;
+  list-style: none; }
+  .breadcrumbs::before, .breadcrumbs::after {
+    display: table;
+    content: ' '; }
+  .breadcrumbs::after {
+    clear: both; }
+  .breadcrumbs li {
+    float: left;
+    font-size: 0.6875rem;
+    color: #0a0a0a;
+    cursor: default;
+    text-transform: uppercase; }
+    .breadcrumbs li:not(:last-child)::after {
+      position: relative;
+      margin: 0 0.75rem;
+      opacity: 1;
+      content: "/";
+      color: #cacaca; }
+  .breadcrumbs a {
+    color: #1779ba; }
+    .breadcrumbs a:hover {
+      text-decoration: underline; }
+  .breadcrumbs .disabled {
+    color: #cacaca;
+    cursor: not-allowed; }
 
-.drilldown .drilldown-submenu-cover-previous {
-  min-height: 100%; }
+.callout {
+  position: relative;
+  margin: 0 0 1rem 0;
+  padding: 1rem;
+  border: 1px solid rgba(10, 10, 10, 0.25);
+  border-radius: 0;
+  background-color: white;
+  color: #0a0a0a; }
+  .callout > :first-child {
+    margin-top: 0; }
+  .callout > :last-child {
+    margin-bottom: 0; }
+  .callout.primary {
+    background-color: #d7ecfa;
+    color: #0a0a0a; }
+  .callout.secondary {
+    background-color: #eaeaea;
+    color: #0a0a0a; }
+  .callout.success {
+    background-color: #e1faea;
+    color: #0a0a0a; }
+  .callout.warning {
+    background-color: #fff3d9;
+    color: #0a0a0a; }
+  .callout.alert {
+    background-color: #f7e4e1;
+    color: #0a0a0a; }
+  .callout.small {
+    padding-top: 0.5rem;
+    padding-right: 0.5rem;
+    padding-bottom: 0.5rem;
+    padding-left: 0.5rem; }
+  .callout.large {
+    padding-top: 3rem;
+    padding-right: 3rem;
+    padding-bottom: 3rem;
+    padding-left: 3rem; }
 
-.drilldown .is-drilldown-submenu-parent > a {
-  position: relative; }
-  .drilldown .is-drilldown-submenu-parent > a::after {
-    position: absolute;
-    top: 50%;
-    margin-top: -6px;
-    right: 1rem;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; }
+.card {
+  margin-bottom: 1rem;
+  border: 1px solid #e6e6e6;
+  border-radius: 0;
+  background: #fefefe;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  overflow: hidden;
+  color: #0a0a0a; }
+  .card > :last-child {
+    margin-bottom: 0; }
 
-.drilldown.align-left .is-drilldown-submenu-parent > a::after {
-  left: auto;
-  right: 1rem;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba; }
+.card-divider {
+  padding: 1rem;
+  background: #e6e6e6; }
+  .card-divider > :last-child {
+    margin-bottom: 0; }
 
-.drilldown.align-right .is-drilldown-submenu-parent > a::after {
-  right: auto;
-  left: 1rem;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent; }
+.card-section {
+  padding: 1rem; }
+  .card-section > :last-child {
+    margin-bottom: 0; }
 
-.drilldown .js-drilldown-back > a::before {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent;
-  border-left-width: 0;
-  display: inline-block;
-  vertical-align: middle;
-  margin-right: 0.75rem;
-  border-left-width: 0; }
+.card-image {
+  min-height: 1px; }
 
 .dropdown-pane {
   position: absolute;
   z-index: 10;
+  display: none;
   width: 300px;
   padding: 1rem;
   visibility: hidden;
-  display: none;
   border: 1px solid #cacaca;
   border-radius: 0;
   background-color: #fefefe;
@@ -2809,8 +2496,8 @@ a.button:hover, a.button:focus {
   .dropdown-pane.is-opening {
     display: block; }
   .dropdown-pane.is-open {
-    visibility: visible;
-    display: block; }
+    display: block;
+    visibility: visible; }
 
 .dropdown-pane.tiny {
   width: 100px; }
@@ -2821,328 +2508,208 @@ a.button:hover, a.button:focus {
 .dropdown-pane.large {
   width: 400px; }
 
-.dropdown.menu > li.opens-left > .is-dropdown-submenu {
-  top: 100%;
-  right: 0;
-  left: auto; }
-
-.dropdown.menu > li.opens-right > .is-dropdown-submenu {
-  top: 100%;
-  right: auto;
-  left: 0; }
-
-.dropdown.menu > li.is-dropdown-submenu-parent > a {
-  position: relative;
-  padding-right: 1.5rem; }
-
-.dropdown.menu > li.is-dropdown-submenu-parent > a::after {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-bottom-width: 0;
-  border-top-style: solid;
-  border-color: #1779ba transparent transparent;
-  right: 5px;
-  left: auto;
-  margin-top: -3px; }
-
-.dropdown.menu a {
-  padding: 0.7rem 1rem; }
-  [data-whatinput='mouse'] .dropdown.menu a {
-    outline: 0; }
-
-.dropdown.menu .is-active > a {
-  background: transparent;
-  color: #1779ba; }
-
-.no-js .dropdown.menu ul {
-  display: none; }
-
-.dropdown.menu .nested.is-dropdown-submenu {
-  margin-right: 0;
-  margin-left: 0; }
-
-.dropdown.menu.vertical > li .is-dropdown-submenu {
-  top: 0; }
-
-.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {
-  right: 100%;
-  left: auto;
-  top: 0; }
-
-.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {
-  right: auto;
-  left: 100%; }
-
-.dropdown.menu.vertical > li > a::after {
-  right: 14px; }
+.pagination {
+  margin-left: 0;
+  margin-bottom: 1rem; }
+  .pagination::before, .pagination::after {
+    display: table;
+    content: ' '; }
+  .pagination::after {
+    clear: both; }
+  .pagination li {
+    margin-right: 0.0625rem;
+    border-radius: 0;
+    font-size: 0.875rem;
+    display: none; }
+    .pagination li:last-child, .pagination li:first-child {
+      display: inline-block; }
+    @media print, screen and (min-width: 40em) {
+      .pagination li {
+        display: inline-block; } }
+  .pagination a,
+  .pagination button {
+    display: block;
+    padding: 0.1875rem 0.625rem;
+    border-radius: 0;
+    color: #0a0a0a; }
+    .pagination a:hover,
+    .pagination button:hover {
+      background: #e6e6e6; }
+  .pagination .current {
+    padding: 0.1875rem 0.625rem;
+    background: #1779ba;
+    color: #fefefe;
+    cursor: default; }
+  .pagination .disabled {
+    padding: 0.1875rem 0.625rem;
+    color: #cacaca;
+    cursor: not-allowed; }
+    .pagination .disabled:hover {
+      background: transparent; }
+  .pagination .ellipsis::after {
+    padding: 0.1875rem 0.625rem;
+    content: '\2026';
+    color: #0a0a0a; }
 
-.dropdown.menu.vertical > li.opens-left > a::after {
-  right: auto;
-  left: 5px;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent; }
+.pagination-previous a::before,
+.pagination-previous.disabled::before {
+  display: inline-block;
+  margin-right: 0.5rem;
+  content: '\00ab'; }
 
-.dropdown.menu.vertical > li.opens-right > a::after {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba; }
+.pagination-next a::after,
+.pagination-next.disabled::after {
+  display: inline-block;
+  margin-left: 0.5rem;
+  content: '\00bb'; }
 
-@media print, screen and (min-width: 40em) {
-  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {
-    top: 100%;
-    right: 0;
-    left: auto; }
-  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
-    top: 100%;
-    right: auto;
-    left: 0; }
-  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {
-    position: relative;
-    padding-right: 1.5rem; }
-  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {
+.has-tip {
+  position: relative;
+  display: inline-block;
+  border-bottom: dotted 1px #8a8a8a;
+  font-weight: bold;
+  cursor: help; }
+
+.tooltip {
+  position: absolute;
+  top: calc(100% + 0.6495rem);
+  z-index: 1200;
+  max-width: 10rem;
+  padding: 0.75rem;
+  border-radius: 0;
+  background-color: #0a0a0a;
+  font-size: 80%;
+  color: #fefefe; }
+  .tooltip::before {
+    position: absolute; }
+  .tooltip.bottom::before {
     display: block;
     width: 0;
     height: 0;
-    border: inset 6px;
+    border: inset 0.75rem;
     content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    right: 5px;
-    left: auto;
-    margin-top: -3px; }
-  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {
-    top: 0; }
-  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto;
-    top: 0; }
-  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
-  .dropdown.menu.medium-vertical > li > a::after {
-    right: 14px; }
-  .dropdown.menu.medium-vertical > li.opens-left > a::after {
-    right: auto;
-    left: 5px;
+    border-top-width: 0;
+    border-bottom-style: solid;
+    border-color: transparent transparent #0a0a0a;
+    bottom: 100%; }
+  .tooltip.bottom.align-center::before {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+  .tooltip.top::before {
     display: block;
     width: 0;
     height: 0;
-    border: inset 6px;
+    border: inset 0.75rem;
     content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .dropdown.menu.medium-vertical > li.opens-right > a::after {
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #0a0a0a transparent transparent;
+    top: 100%;
+    bottom: auto; }
+  .tooltip.top.align-center::before {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+  .tooltip.left::before {
     display: block;
     width: 0;
     height: 0;
-    border: inset 6px;
+    border: inset 0.75rem;
     content: '';
     border-right-width: 0;
     border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; } }
-
-@media print, screen and (min-width: 64em) {
-  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {
-    top: 100%;
-    right: 0;
-    left: auto; }
-  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {
-    top: 100%;
-    right: auto;
-    left: 0; }
-  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {
-    position: relative;
-    padding-right: 1.5rem; }
-  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    right: 5px;
-    left: auto;
-    margin-top: -3px; }
-  .dropdown.menu.large-vertical > li .is-dropdown-submenu {
-    top: 0; }
-  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto;
-    top: 0; }
-  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {
-    right: auto;
+    border-color: transparent transparent transparent #0a0a0a;
     left: 100%; }
-  .dropdown.menu.large-vertical > li > a::after {
-    right: 14px; }
-  .dropdown.menu.large-vertical > li.opens-left > a::after {
-    right: auto;
-    left: 5px;
+  .tooltip.left.align-center::before {
+    bottom: auto;
+    top: 50%;
+    -webkit-transform: translateY(-50%);
+        -ms-transform: translateY(-50%);
+            transform: translateY(-50%); }
+  .tooltip.right::before {
     display: block;
     width: 0;
     height: 0;
-    border: inset 6px;
+    border: inset 0.75rem;
     content: '';
     border-left-width: 0;
     border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .dropdown.menu.large-vertical > li.opens-right > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; } }
-
-.dropdown.menu.align-right .is-dropdown-submenu.first-sub {
-  top: 100%;
-  right: 0;
-  left: auto; }
-
-.is-dropdown-menu.vertical {
-  width: 100px; }
-  .is-dropdown-menu.vertical.align-right {
-    float: right; }
-
-.is-dropdown-submenu-parent {
-  position: relative; }
-  .is-dropdown-submenu-parent a::after {
-    position: absolute;
-    top: 50%;
-    right: 5px;
-    left: auto;
-    margin-top: -6px; }
-  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {
-    top: 100%;
-    left: auto; }
-  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {
+    border-color: transparent #0a0a0a transparent transparent;
     right: 100%;
     left: auto; }
-  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
+  .tooltip.right.align-center::before {
+    bottom: auto;
+    top: 50%;
+    -webkit-transform: translateY(-50%);
+        -ms-transform: translateY(-50%);
+            transform: translateY(-50%); }
+  .tooltip.align-top::before {
+    bottom: auto;
+    top: 10%; }
+  .tooltip.align-bottom::before {
+    bottom: 10%;
+    top: auto; }
+  .tooltip.align-left::before {
+    left: 10%;
+    right: auto; }
+  .tooltip.align-right::before {
+    left: auto;
+    right: 10%; }
 
-.is-dropdown-submenu {
-  position: absolute;
-  top: 0;
-  left: 100%;
-  z-index: 1;
-  display: none;
-  min-width: 200px;
-  border: 1px solid #cacaca;
-  background: #fefefe; }
-  .dropdown .is-dropdown-submenu a {
-    padding: 0.7rem 1rem; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {
-    right: 14px; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; }
-  .is-dropdown-submenu .is-dropdown-submenu {
-    margin-top: -1px; }
-  .is-dropdown-submenu > li {
-    width: 100%; }
-  .is-dropdown-submenu.js-dropdown-active {
-    display: block; }
+.accordion {
+  margin-left: 0;
+  background: #fefefe;
+  list-style-type: none; }
+  .accordion[disabled] .accordion-title {
+    cursor: not-allowed; }
 
-.responsive-embed,
-.flex-video {
+.accordion-item:first-child > :first-child {
+  border-radius: 0 0 0 0; }
+
+.accordion-item:last-child > :last-child {
+  border-radius: 0 0 0 0; }
+
+.accordion-title {
   position: relative;
-  height: 0;
-  margin-bottom: 1rem;
-  padding-bottom: 75%;
-  overflow: hidden; }
-  .responsive-embed iframe,
-  .responsive-embed object,
-  .responsive-embed embed,
-  .responsive-embed video,
-  .flex-video iframe,
-  .flex-video object,
-  .flex-video embed,
-  .flex-video video {
+  display: block;
+  padding: 1.25rem 1rem;
+  border: 1px solid #e6e6e6;
+  border-bottom: 0;
+  font-size: 0.75rem;
+  line-height: 1;
+  color: #1779ba; }
+  :last-child:not(.is-active) > .accordion-title {
+    border-bottom: 1px solid #e6e6e6;
+    border-radius: 0 0 0 0; }
+  .accordion-title:hover, .accordion-title:focus {
+    background-color: #e6e6e6; }
+  .accordion-title::before {
     position: absolute;
-    top: 0;
-    left: 0;
-    width: 100%;
-    height: 100%; }
-  .responsive-embed.widescreen,
-  .flex-video.widescreen {
-    padding-bottom: 56.25%; }
+    top: 50%;
+    right: 1rem;
+    margin-top: -0.5rem;
+    content: '+'; }
+  .is-active > .accordion-title::before {
+    content: '\2013'; }
 
-.label {
-  display: inline-block;
-  padding: 0.33333rem 0.5rem;
-  border-radius: 0;
-  font-size: 0.8rem;
-  line-height: 1;
-  white-space: nowrap;
-  cursor: default;
-  background: #1779ba;
-  color: #fefefe; }
-  .label.primary {
-    background: #1779ba;
-    color: #fefefe; }
-  .label.secondary {
-    background: #767676;
-    color: #fefefe; }
-  .label.success {
-    background: #3adb76;
-    color: #0a0a0a; }
-  .label.warning {
-    background: #ffae00;
-    color: #0a0a0a; }
-  .label.alert {
-    background: #cc4b37;
-    color: #fefefe; }
+.accordion-content {
+  display: none;
+  padding: 1rem;
+  border: 1px solid #e6e6e6;
+  border-bottom: 0;
+  background-color: #fefefe;
+  color: #0a0a0a; }
+  :last-child > .accordion-content:last-child {
+    border-bottom: 1px solid #e6e6e6; }
 
 .media-object {
   display: block;
   margin-bottom: 1rem; }
   .media-object img {
     max-width: none; }
-  @media screen and (max-width: 39.9375em) {
-    .media-object.stack-for-small .media-object-section {
-      padding: 0;
-      padding-bottom: 1rem;
-      display: block; }
-      .media-object.stack-for-small .media-object-section img {
-        width: 100%; } }
 
 .media-object-section {
   display: table-cell;
@@ -3153,1029 +2720,1355 @@ a.button:hover, a.button:focus {
     padding-left: 1rem; }
   .media-object-section > :last-child {
     margin-bottom: 0; }
+  @media screen and (max-width: 39.99875em) {
+    .stack-for-small .media-object-section {
+      padding: 0;
+      padding-bottom: 1rem;
+      display: block; }
+      .stack-for-small .media-object-section img {
+        width: 100%; } }
   .media-object-section.middle {
     vertical-align: middle; }
   .media-object-section.bottom {
     vertical-align: bottom; }
 
-.is-off-canvas-open {
+.orbit {
+  position: relative; }
+
+.orbit-container {
+  position: relative;
+  height: 0;
+  margin: 0;
+  list-style: none;
   overflow: hidden; }
 
-.js-off-canvas-overlay {
-  position: absolute;
-  top: 0;
-  left: 0;
-  z-index: 11;
+.orbit-slide {
   width: 100%;
-  height: 100%;
-  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
-  transition: opacity 0.5s ease, visibility 0.5s ease;
-  background: rgba(254, 254, 254, 0.25);
-  opacity: 0;
-  visibility: hidden;
-  overflow: hidden; }
-  .js-off-canvas-overlay.is-visible {
-    opacity: 1;
-    visibility: visible; }
-  .js-off-canvas-overlay.is-closable {
-    cursor: pointer; }
-  .js-off-canvas-overlay.is-overlay-absolute {
-    position: absolute; }
-  .js-off-canvas-overlay.is-overlay-fixed {
-    position: fixed; }
+  position: absolute; }
+  .orbit-slide.no-motionui.is-active {
+    top: 0;
+    left: 0; }
 
-.off-canvas-wrapper {
-  position: relative;
-  overflow: hidden; }
+.orbit-figure {
+  margin: 0; }
 
-.off-canvas {
-  position: fixed;
-  z-index: 12;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  background: #e6e6e6; }
-  [data-whatinput='mouse'] .off-canvas {
-    outline: 0; }
-  .off-canvas.is-transition-push {
-    z-index: 12; }
-  .off-canvas.is-closed {
-    visibility: hidden; }
-  .off-canvas.is-transition-overlap {
-    z-index: 13; }
-    .off-canvas.is-transition-overlap.is-open {
-      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
-              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
-  .off-canvas.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
+.orbit-image {
+  width: 100%;
+  max-width: 100%;
+  margin: 0; }
 
-.off-canvas-absolute {
+.orbit-caption {
   position: absolute;
-  z-index: 12;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  background: #e6e6e6; }
-  [data-whatinput='mouse'] .off-canvas-absolute {
+  bottom: 0;
+  width: 100%;
+  margin-bottom: 0;
+  padding: 1rem;
+  background-color: rgba(10, 10, 10, 0.5);
+  color: #fefefe; }
+
+.orbit-previous, .orbit-next {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%);
+  z-index: 10;
+  padding: 1rem;
+  color: #fefefe; }
+  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
     outline: 0; }
-  .off-canvas-absolute.is-transition-push {
-    z-index: 12; }
-  .off-canvas-absolute.is-closed {
-    visibility: hidden; }
-  .off-canvas-absolute.is-transition-overlap {
-    z-index: 13; }
-    .off-canvas-absolute.is-transition-overlap.is-open {
-      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
-              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
-  .off-canvas-absolute.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
+  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {
+    background-color: rgba(10, 10, 10, 0.5); }
 
-.position-left {
-  top: 0;
-  left: 0;
-  height: 100%;
-  overflow-y: auto;
-  width: 250px;
-  -webkit-transform: translateX(-250px);
-      -ms-transform: translateX(-250px);
-          transform: translateX(-250px); }
-  .off-canvas-content .off-canvas.position-left {
-    -webkit-transform: translateX(-250px);
-        -ms-transform: translateX(-250px);
-            transform: translateX(-250px); }
-    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-left.has-transition-push {
-    -webkit-transform: translateX(250px);
-        -ms-transform: translateX(250px);
-            transform: translateX(250px); }
-  .position-left.is-transition-push {
-    -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }
+.orbit-previous {
+  left: 0; }
 
-.position-right {
-  top: 0;
-  right: 0;
-  height: 100%;
-  overflow-y: auto;
-  width: 250px;
-  -webkit-transform: translateX(250px);
-      -ms-transform: translateX(250px);
-          transform: translateX(250px); }
-  .off-canvas-content .off-canvas.position-right {
-    -webkit-transform: translateX(250px);
-        -ms-transform: translateX(250px);
-            transform: translateX(250px); }
-    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-right.has-transition-push {
-    -webkit-transform: translateX(-250px);
-        -ms-transform: translateX(-250px);
-            transform: translateX(-250px); }
-  .position-right.is-transition-push {
-    -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }
+.orbit-next {
+  left: auto;
+  right: 0; }
+
+.orbit-bullets {
+  position: relative;
+  margin-top: 0.8rem;
+  margin-bottom: 0.8rem;
+  text-align: center; }
+  [data-whatinput='mouse'] .orbit-bullets {
+    outline: 0; }
+  .orbit-bullets button {
+    width: 1.2rem;
+    height: 1.2rem;
+    margin: 0.1rem;
+    border-radius: 50%;
+    background-color: #cacaca; }
+    .orbit-bullets button:hover {
+      background-color: #8a8a8a; }
+    .orbit-bullets button.is-active {
+      background-color: #8a8a8a; }
+
+.responsive-embed,
+.flex-video {
+  position: relative;
+  height: 0;
+  margin-bottom: 1rem;
+  padding-bottom: 75%;
+  overflow: hidden; }
+  .responsive-embed iframe,
+  .responsive-embed object,
+  .responsive-embed embed,
+  .responsive-embed video,
+  .flex-video iframe,
+  .flex-video object,
+  .flex-video embed,
+  .flex-video video {
+    position: absolute;
+    top: 0;
+    left: 0;
+    width: 100%;
+    height: 100%; }
+  .responsive-embed.widescreen,
+  .flex-video.widescreen {
+    padding-bottom: 56.25%; }
 
-.position-top {
-  top: 0;
-  left: 0;
-  width: 100%;
-  overflow-x: auto;
-  height: 250px;
-  -webkit-transform: translateY(-250px);
-      -ms-transform: translateY(-250px);
-          transform: translateY(-250px); }
-  .off-canvas-content .off-canvas.position-top {
-    -webkit-transform: translateY(-250px);
-        -ms-transform: translateY(-250px);
-            transform: translateY(-250px); }
-    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-top.has-transition-push {
-    -webkit-transform: translateY(250px);
-        -ms-transform: translateY(250px);
-            transform: translateY(250px); }
-  .position-top.is-transition-push {
-    -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }
+.tabs {
+  margin: 0;
+  border: 1px solid #e6e6e6;
+  background: #fefefe;
+  list-style-type: none; }
+  .tabs::before, .tabs::after {
+    display: table;
+    content: ' '; }
+  .tabs::after {
+    clear: both; }
 
-.position-bottom {
-  bottom: 0;
-  left: 0;
-  width: 100%;
-  overflow-x: auto;
-  height: 250px;
-  -webkit-transform: translateY(250px);
-      -ms-transform: translateY(250px);
-          transform: translateY(250px); }
-  .off-canvas-content .off-canvas.position-bottom {
-    -webkit-transform: translateY(250px);
-        -ms-transform: translateY(250px);
-            transform: translateY(250px); }
-    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-bottom.has-transition-push {
-    -webkit-transform: translateY(-250px);
-        -ms-transform: translateY(-250px);
-            transform: translateY(-250px); }
-  .position-bottom.is-transition-push {
-    -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }
+.tabs.vertical > li {
+  display: block;
+  float: none;
+  width: auto; }
 
-.off-canvas-content {
-  -webkit-transform: none;
-      -ms-transform: none;
-          transform: none;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden; }
-  .off-canvas-content.has-transition-push {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
-  .off-canvas-content .off-canvas.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
+.tabs.simple > li > a {
+  padding: 0; }
+  .tabs.simple > li > a:hover {
+    background: transparent; }
 
-@media print, screen and (min-width: 40em) {
-  .position-left.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-left.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-left.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-left {
-      margin-left: 250px; }
-    .position-left.reveal-for-medium ~ .off-canvas-content {
-      margin-left: 250px; }
-  .position-right.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-right.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-right.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-right {
-      margin-right: 250px; }
-    .position-right.reveal-for-medium ~ .off-canvas-content {
-      margin-right: 250px; }
-  .position-top.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-top.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-top.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-top {
-      margin-top: 250px; }
-    .position-top.reveal-for-medium ~ .off-canvas-content {
-      margin-top: 250px; }
-  .position-bottom.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-bottom.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-bottom.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-bottom {
-      margin-bottom: 250px; }
-    .position-bottom.reveal-for-medium ~ .off-canvas-content {
-      margin-bottom: 250px; } }
+.tabs.primary {
+  background: #1779ba; }
+  .tabs.primary > li > a {
+    color: #fefefe; }
+    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
+      background: #1673b1; }
 
-@media print, screen and (min-width: 64em) {
-  .position-left.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-left.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-left.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-left {
-      margin-left: 250px; }
-    .position-left.reveal-for-large ~ .off-canvas-content {
-      margin-left: 250px; }
-  .position-right.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-right.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-right.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-right {
-      margin-right: 250px; }
-    .position-right.reveal-for-large ~ .off-canvas-content {
-      margin-right: 250px; }
-  .position-top.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-top.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-top.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-top {
-      margin-top: 250px; }
-    .position-top.reveal-for-large ~ .off-canvas-content {
-      margin-top: 250px; }
-  .position-bottom.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-bottom.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-bottom.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-bottom {
-      margin-bottom: 250px; }
-    .position-bottom.reveal-for-large ~ .off-canvas-content {
-      margin-bottom: 250px; } }
+.tabs-title {
+  float: left; }
+  .tabs-title > a {
+    display: block;
+    padding: 1.25rem 1.5rem;
+    font-size: 0.75rem;
+    line-height: 1;
+    color: #1779ba; }
+    [data-whatinput='mouse'] .tabs-title > a {
+      outline: 0; }
+    .tabs-title > a:hover {
+      background: #fefefe;
+      color: #1468a0; }
+    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {
+      background: #e6e6e6;
+      color: #1779ba; }
 
-@media print, screen and (min-width: 40em) {
-  .off-canvas.in-canvas-for-medium {
-    visibility: visible;
-    height: auto;
-    position: static;
-    background: inherit;
-    width: inherit;
-    overflow: inherit;
-    -webkit-transition: inherit;
-    transition: inherit; }
-    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {
-      -webkit-box-shadow: none;
-              box-shadow: none;
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas.in-canvas-for-medium .close-button {
-      display: none; } }
+.tabs-content {
+  border: 1px solid #e6e6e6;
+  border-top: 0;
+  background: #fefefe;
+  color: #0a0a0a;
+  -webkit-transition: all 0.5s ease;
+  transition: all 0.5s ease; }
 
-@media print, screen and (min-width: 64em) {
-  .off-canvas.in-canvas-for-large {
-    visibility: visible;
-    height: auto;
-    position: static;
-    background: inherit;
-    width: inherit;
-    overflow: inherit;
-    -webkit-transition: inherit;
-    transition: inherit; }
-    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {
-      -webkit-box-shadow: none;
-              box-shadow: none;
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas.in-canvas-for-large .close-button {
-      display: none; } }
+.tabs-content.vertical {
+  border: 1px solid #e6e6e6;
+  border-left: 0; }
 
-.orbit {
-  position: relative; }
+.tabs-panel {
+  display: none;
+  padding: 1rem; }
+  .tabs-panel.is-active {
+    display: block; }
 
-.orbit-container {
-  position: relative;
-  height: 0;
+.thumbnail {
+  display: inline-block;
+  max-width: 100%;
+  margin-bottom: 1rem;
+  border: 4px solid #fefefe;
+  border-radius: 0;
+  -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
+          box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
+  line-height: 0; }
+
+a.thumbnail {
+  -webkit-transition: -webkit-box-shadow 200ms ease-out;
+  transition: -webkit-box-shadow 200ms ease-out;
+  transition: box-shadow 200ms ease-out;
+  transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; }
+  a.thumbnail:hover, a.thumbnail:focus {
+    -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
+            box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }
+  a.thumbnail image {
+    -webkit-box-shadow: none;
+            box-shadow: none; }
+
+.menu {
+  padding: 0;
   margin: 0;
   list-style: none;
-  overflow: hidden; }
+  position: relative; }
+  [data-whatinput='mouse'] .menu li {
+    outline: 0; }
+  .menu a,
+  .menu .button {
+    line-height: 1;
+    text-decoration: none;
+    display: block;
+    padding: 0.7rem 1rem; }
+  .menu input,
+  .menu select,
+  .menu a,
+  .menu button {
+    margin-bottom: 0; }
+  .menu input {
+    display: inline-block; }
+  .menu li, .menu.horizontal li {
+    display: inline-block; }
+  .menu.vertical li {
+    display: block; }
+  .menu.expanded {
+    display: table;
+    width: 100%; }
+    .menu.expanded > li {
+      display: table-cell;
+      vertical-align: middle; }
+  .menu.simple li + li {
+    margin-left: 1rem; }
+  .menu.simple a {
+    padding: 0; }
+  @media print, screen and (min-width: 40em) {
+    .menu.medium-horizontal li {
+      display: inline-block; }
+    .menu.medium-vertical li {
+      display: block; }
+    .menu.medium-expanded {
+      display: table;
+      width: 100%; }
+      .menu.medium-expanded > li {
+        display: table-cell;
+        vertical-align: middle; }
+    .menu.medium-simple {
+      display: table;
+      width: 100%; }
+      .menu.medium-simple > li {
+        display: table-cell;
+        vertical-align: middle; } }
+  @media print, screen and (min-width: 64em) {
+    .menu.large-horizontal li {
+      display: inline-block; }
+    .menu.large-vertical li {
+      display: block; }
+    .menu.large-expanded {
+      display: table;
+      width: 100%; }
+      .menu.large-expanded > li {
+        display: table-cell;
+        vertical-align: middle; }
+    .menu.large-simple {
+      display: table;
+      width: 100%; }
+      .menu.large-simple > li {
+        display: table-cell;
+        vertical-align: middle; } }
+  .menu.nested {
+    margin-right: 0;
+    margin-left: 1rem; }
+  .menu.icons img,
+  .menu.icons i,
+  .menu.icons svg {
+    vertical-align: middle; }
+    .menu.icons img + span,
+    .menu.icons i + span,
+    .menu.icons svg + span {
+      vertical-align: middle; }
+  .menu.icon-top img,
+  .menu.icon-top i,
+  .menu.icon-top svg, .menu.icon-right img,
+  .menu.icon-right i,
+  .menu.icon-right svg, .menu.icon-bottom img,
+  .menu.icon-bottom i,
+  .menu.icon-bottom svg, .menu.icon-left img,
+  .menu.icon-left i,
+  .menu.icon-left svg {
+    vertical-align: middle; }
+    .menu.icon-top img + span,
+    .menu.icon-top i + span,
+    .menu.icon-top svg + span, .menu.icon-right img + span,
+    .menu.icon-right i + span,
+    .menu.icon-right svg + span, .menu.icon-bottom img + span,
+    .menu.icon-bottom i + span,
+    .menu.icon-bottom svg + span, .menu.icon-left img + span,
+    .menu.icon-left i + span,
+    .menu.icon-left svg + span {
+      vertical-align: middle; }
+  .menu.icon-left li a img,
+  .menu.icon-left li a i,
+  .menu.icon-left li a svg {
+    margin-right: 0.25rem;
+    display: inline-block; }
+  .menu.icon-right li a img,
+  .menu.icon-right li a i,
+  .menu.icon-right li a svg {
+    margin-left: 0.25rem;
+    display: inline-block; }
+  .menu.icon-top li a {
+    text-align: center; }
+    .menu.icon-top li a img,
+    .menu.icon-top li a i,
+    .menu.icon-top li a svg {
+      display: block;
+      margin: 0 auto 0.25rem; }
+  .menu.icon-bottom li a {
+    text-align: center; }
+    .menu.icon-bottom li a img,
+    .menu.icon-bottom li a i,
+    .menu.icon-bottom li a svg {
+      display: block;
+      margin: 0.25rem auto 0; }
+  .menu .is-active > a {
+    background: #1779ba;
+    color: #fefefe; }
+  .menu .active > a {
+    background: #1779ba;
+    color: #fefefe; }
+  .menu.align-left {
+    text-align: left; }
+  .menu.align-right {
+    text-align: right; }
+    .menu.align-right .submenu li {
+      text-align: left; }
+    .menu.align-right.vertical .submenu li {
+      text-align: right; }
+    .menu.align-right .nested {
+      margin-right: 1rem;
+      margin-left: 0; }
+  .menu.align-center {
+    text-align: center; }
+    .menu.align-center .submenu li {
+      text-align: left; }
+  .menu .menu-text {
+    padding: 0.7rem 1rem;
+    font-weight: bold;
+    line-height: 1;
+    color: inherit; }
+
+.menu-centered > .menu {
+  text-align: center; }
+  .menu-centered > .menu .submenu li {
+    text-align: left; }
+
+.no-js [data-responsive-menu] ul {
+  display: none; }
+
+.menu-icon {
+  position: relative;
+  display: inline-block;
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
+  cursor: pointer; }
+  .menu-icon::after {
+    position: absolute;
+    top: 0;
+    left: 0;
+    display: block;
+    width: 100%;
+    height: 2px;
+    background: #fefefe;
+    -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+            box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+    content: ''; }
+  .menu-icon:hover::after {
+    background: #cacaca;
+    -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
+            box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }
+
+.menu-icon.dark {
+  position: relative;
+  display: inline-block;
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
+  cursor: pointer; }
+  .menu-icon.dark::after {
+    position: absolute;
+    top: 0;
+    left: 0;
+    display: block;
+    width: 100%;
+    height: 2px;
+    background: #0a0a0a;
+    -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
+            box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
+    content: ''; }
+  .menu-icon.dark:hover::after {
+    background: #8a8a8a;
+    -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
+            box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }
 
-.orbit-slide {
+.accordion-menu li {
   width: 100%; }
-  .orbit-slide.no-motionui.is-active {
-    top: 0;
-    left: 0; }
 
-.orbit-figure {
-  margin: 0; }
+.accordion-menu a {
+  padding: 0.7rem 1rem; }
 
-.orbit-image {
-  width: 100%;
-  max-width: 100%;
-  margin: 0; }
+.accordion-menu .is-accordion-submenu a {
+  padding: 0.7rem 1rem; }
 
-.orbit-caption {
-  position: absolute;
-  bottom: 0;
-  width: 100%;
-  margin-bottom: 0;
-  padding: 1rem;
-  background-color: rgba(10, 10, 10, 0.5);
-  color: #fefefe; }
+.accordion-menu .nested.is-accordion-submenu {
+  margin-right: 0;
+  margin-left: 1rem; }
 
-.orbit-previous, .orbit-next {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%);
-  z-index: 10;
-  padding: 1rem;
-  color: #fefefe; }
-  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
-    outline: 0; }
-  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {
-    background-color: rgba(10, 10, 10, 0.5); }
+.accordion-menu.align-right .nested.is-accordion-submenu {
+  margin-right: 1rem;
+  margin-left: 0; }
 
-.orbit-previous {
-  left: 0; }
+.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {
+  position: relative; }
+  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    position: absolute;
+    top: 50%;
+    margin-top: -3px;
+    right: 1rem; }
 
-.orbit-next {
-  left: auto;
-  right: 0; }
+.accordion-menu.align-left .is-accordion-submenu-parent > a::after {
+  right: 1rem;
+  left: auto; }
 
-.orbit-bullets {
-  position: relative;
-  margin-top: 0.8rem;
-  margin-bottom: 0.8rem;
-  text-align: center; }
-  [data-whatinput='mouse'] .orbit-bullets {
-    outline: 0; }
-  .orbit-bullets button {
-    width: 1.2rem;
-    height: 1.2rem;
-    margin: 0.1rem;
-    border-radius: 50%;
-    background-color: #cacaca; }
-    .orbit-bullets button:hover {
-      background-color: #8a8a8a; }
-    .orbit-bullets button.is-active {
-      background-color: #8a8a8a; }
+.accordion-menu.align-right .is-accordion-submenu-parent > a::after {
+  right: auto;
+  left: 1rem; }
 
-.pagination {
-  margin-left: 0;
-  margin-bottom: 1rem; }
-  .pagination::before, .pagination::after {
-    display: table;
-    content: ' '; }
-  .pagination::after {
-    clear: both; }
-  .pagination li {
-    margin-right: 0.0625rem;
-    border-radius: 0;
-    font-size: 0.875rem;
-    display: none; }
-    .pagination li:last-child, .pagination li:first-child {
-      display: inline-block; }
-    @media print, screen and (min-width: 40em) {
-      .pagination li {
-        display: inline-block; } }
-  .pagination a,
-  .pagination button {
-    display: block;
-    padding: 0.1875rem 0.625rem;
-    border-radius: 0;
-    color: #0a0a0a; }
-    .pagination a:hover,
-    .pagination button:hover {
-      background: #e6e6e6; }
-  .pagination .current {
-    padding: 0.1875rem 0.625rem;
-    background: #1779ba;
-    color: #fefefe;
-    cursor: default; }
-  .pagination .disabled {
-    padding: 0.1875rem 0.625rem;
-    color: #cacaca;
-    cursor: not-allowed; }
-    .pagination .disabled:hover {
-      background: transparent; }
-  .pagination .ellipsis::after {
-    padding: 0.1875rem 0.625rem;
-    content: '\2026';
-    color: #0a0a0a; }
+.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {
+  -webkit-transform: rotate(180deg);
+      -ms-transform: rotate(180deg);
+          transform: rotate(180deg);
+  -webkit-transform-origin: 50% 50%;
+      -ms-transform-origin: 50% 50%;
+          transform-origin: 50% 50%; }
 
-.pagination-previous a::before,
-.pagination-previous.disabled::before {
-  display: inline-block;
-  margin-right: 0.5rem;
-  content: '\00ab'; }
+.is-accordion-submenu-parent {
+  position: relative; }
 
-.pagination-next a::after,
-.pagination-next.disabled::after {
-  display: inline-block;
-  margin-left: 0.5rem;
-  content: '\00bb'; }
+.has-submenu-toggle > a {
+  margin-right: 40px; }
 
-.progress {
-  height: 1rem;
-  margin-bottom: 1rem;
-  border-radius: 0;
-  background-color: #cacaca; }
-  .progress.primary .progress-meter {
-    background-color: #1779ba; }
-  .progress.secondary .progress-meter {
-    background-color: #767676; }
-  .progress.success .progress-meter {
-    background-color: #3adb76; }
-  .progress.warning .progress-meter {
-    background-color: #ffae00; }
-  .progress.alert .progress-meter {
-    background-color: #cc4b37; }
+.submenu-toggle {
+  position: absolute;
+  top: 0;
+  right: 0;
+  width: 40px;
+  height: 40px;
+  cursor: pointer; }
+  .submenu-toggle::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    top: 0;
+    bottom: 0;
+    margin: auto; }
 
-.progress-meter {
-  position: relative;
-  display: block;
-  width: 0%;
-  height: 100%;
-  background-color: #1779ba; }
+.submenu-toggle[aria-expanded='true']::after {
+  -webkit-transform: scaleY(-1);
+      -ms-transform: scaleY(-1);
+          transform: scaleY(-1);
+  -webkit-transform-origin: 50% 50%;
+      -ms-transform-origin: 50% 50%;
+          transform-origin: 50% 50%; }
 
-.progress-meter-text {
-  position: absolute;
-  top: 50%;
-  left: 50%;
-  -webkit-transform: translate(-50%, -50%);
-      -ms-transform: translate(-50%, -50%);
-          transform: translate(-50%, -50%);
-  position: absolute;
-  margin: 0;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #fefefe;
-  white-space: nowrap; }
+.submenu-toggle-text {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  padding: 0;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
+  white-space: nowrap;
+  border: 0; }
 
-.slider {
+.is-drilldown {
   position: relative;
-  height: 0.5rem;
-  margin-top: 1.25rem;
-  margin-bottom: 2.25rem;
-  background-color: #e6e6e6;
-  cursor: pointer;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none;
-  -ms-touch-action: none;
-      touch-action: none; }
+  overflow: hidden; }
+  .is-drilldown li {
+    display: block; }
+  .is-drilldown.animate-height {
+    -webkit-transition: height 0.5s;
+    transition: height 0.5s; }
+
+.drilldown a {
+  padding: 0.7rem 1rem;
+  background: #fefefe; }
 
-.slider-fill {
+.drilldown .is-drilldown-submenu {
   position: absolute;
   top: 0;
-  left: 0;
-  display: inline-block;
-  max-width: 100%;
-  height: 0.5rem;
-  background-color: #cacaca;
-  -webkit-transition: all 0.2s ease-in-out;
-  transition: all 0.2s ease-in-out; }
-  .slider-fill.is-dragging {
-    -webkit-transition: all 0s linear;
-    transition: all 0s linear; }
-
-.slider-handle {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%);
-  left: 0;
-  z-index: 1;
-  display: inline-block;
-  width: 1.4rem;
-  height: 1.4rem;
-  border-radius: 0;
-  background-color: #1779ba;
-  -webkit-transition: all 0.2s ease-in-out;
-  transition: all 0.2s ease-in-out;
-  -ms-touch-action: manipulation;
-      touch-action: manipulation; }
-  [data-whatinput='mouse'] .slider-handle {
-    outline: 0; }
-  .slider-handle:hover {
-    background-color: #14679e; }
-  .slider-handle.is-dragging {
-    -webkit-transition: all 0s linear;
-    transition: all 0s linear; }
+  left: 100%;
+  z-index: -1;
+  width: 100%;
+  background: #fefefe;
+  -webkit-transition: -webkit-transform 0.15s linear;
+  transition: -webkit-transform 0.15s linear;
+  transition: transform 0.15s linear;
+  transition: transform 0.15s linear, -webkit-transform 0.15s linear; }
+  .drilldown .is-drilldown-submenu.is-active {
+    z-index: 1;
+    display: block;
+    -webkit-transform: translateX(-100%);
+        -ms-transform: translateX(-100%);
+            transform: translateX(-100%); }
+  .drilldown .is-drilldown-submenu.is-closing {
+    -webkit-transform: translateX(100%);
+        -ms-transform: translateX(100%);
+            transform: translateX(100%); }
+  .drilldown .is-drilldown-submenu a {
+    padding: 0.7rem 1rem; }
 
-.slider.disabled,
-.slider[disabled] {
-  opacity: 0.25;
-  cursor: not-allowed; }
+.drilldown .nested.is-drilldown-submenu {
+  margin-right: 0;
+  margin-left: 0; }
 
-.slider.vertical {
-  display: inline-block;
-  width: 0.5rem;
-  height: 12.5rem;
-  margin: 0 1.25rem;
-  -webkit-transform: scale(1, -1);
-      -ms-transform: scale(1, -1);
-          transform: scale(1, -1); }
-  .slider.vertical .slider-fill {
-    top: 0;
-    width: 0.5rem;
-    max-height: 100%; }
-  .slider.vertical .slider-handle {
-    position: absolute;
-    top: 0;
-    left: 50%;
-    width: 1.4rem;
-    height: 1.4rem;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
+.drilldown .drilldown-submenu-cover-previous {
+  min-height: 100%; }
 
-.sticky-container {
+.drilldown .is-drilldown-submenu-parent > a {
   position: relative; }
+  .drilldown .is-drilldown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba;
+    position: absolute;
+    top: 50%;
+    margin-top: -6px;
+    right: 1rem; }
 
-.sticky {
-  position: relative;
-  z-index: 0;
-  -webkit-transform: translate3d(0, 0, 0);
-          transform: translate3d(0, 0, 0); }
-
-.sticky.is-stuck {
-  position: fixed;
-  z-index: 5;
-  width: 100%; }
-  .sticky.is-stuck.is-at-top {
-    top: 0; }
-  .sticky.is-stuck.is-at-bottom {
-    bottom: 0; }
-
-.sticky.is-anchored {
-  position: relative;
-  right: auto;
+.drilldown.align-left .is-drilldown-submenu-parent > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba;
+  right: 1rem;
   left: auto; }
-  .sticky.is-anchored.is-at-bottom {
-    bottom: 0; }
 
-body.is-reveal-open {
-  overflow: hidden; }
+.drilldown.align-right .is-drilldown-submenu-parent > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  right: auto;
+  left: 1rem; }
 
-html.is-reveal-open,
-html.is-reveal-open body {
-  min-height: 100%;
-  overflow: hidden;
-  position: fixed;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none; }
+.drilldown .js-drilldown-back > a::before {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  display: inline-block;
+  vertical-align: middle;
+  margin-right: 0.75rem; }
 
-.reveal-overlay {
-  position: fixed;
-  top: 0;
+.dropdown.menu > li.opens-left > .is-dropdown-submenu {
+  top: 100%;
   right: 0;
-  bottom: 0;
-  left: 0;
-  z-index: 1005;
-  display: none;
-  background-color: rgba(10, 10, 10, 0.45);
-  overflow-y: scroll; }
-
-.reveal {
-  z-index: 1006;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  display: none;
-  padding: 1rem;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  position: relative;
-  top: 100px;
-  margin-right: auto;
-  margin-left: auto;
-  overflow-y: auto; }
-  [data-whatinput='mouse'] .reveal {
-    outline: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal {
-      min-height: 0; } }
-  .reveal .column, .reveal .columns {
-    min-width: 0; }
-  .reveal > :last-child {
-    margin-bottom: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal {
-      width: 600px;
-      max-width: 75rem; } }
-  .reveal.collapse {
-    padding: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal.tiny {
-      width: 30%;
-      max-width: 75rem; } }
-  @media print, screen and (min-width: 40em) {
-    .reveal.small {
-      width: 50%;
-      max-width: 75rem; } }
-  @media print, screen and (min-width: 40em) {
-    .reveal.large {
-      width: 90%;
-      max-width: 75rem; } }
-  .reveal.full {
-    top: 0;
-    left: 0;
-    width: 100%;
-    max-width: none;
-    height: 100%;
-    height: 100vh;
-    min-height: 100vh;
-    margin-left: 0;
-    border: 0;
-    border-radius: 0; }
-  @media screen and (max-width: 39.9375em) {
-    .reveal {
-      top: 0;
-      left: 0;
-      width: 100%;
-      max-width: none;
-      height: 100%;
-      height: 100vh;
-      min-height: 100vh;
-      margin-left: 0;
-      border: 0;
-      border-radius: 0; } }
-  .reveal.without-overlay {
-    position: fixed; }
-
-.switch {
-  height: 2rem;
-  position: relative;
-  margin-bottom: 1rem;
-  outline: 0;
-  font-size: 0.875rem;
-  font-weight: bold;
-  color: #fefefe;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none; }
+  left: auto; }
 
-.switch-input {
-  position: absolute;
-  margin-bottom: 0;
-  opacity: 0; }
+.dropdown.menu > li.opens-right > .is-dropdown-submenu {
+  top: 100%;
+  right: auto;
+  left: 0; }
 
-.switch-paddle {
+.dropdown.menu > li.is-dropdown-submenu-parent > a {
   position: relative;
+  padding-right: 1.5rem; }
+
+.dropdown.menu > li.is-dropdown-submenu-parent > a::after {
   display: block;
-  width: 4rem;
-  height: 2rem;
-  border-radius: 0;
-  background: #cacaca;
-  -webkit-transition: all 0.25s ease-out;
-  transition: all 0.25s ease-out;
-  font-weight: inherit;
-  color: inherit;
-  cursor: pointer; }
-  input + .switch-paddle {
-    margin: 0; }
-  .switch-paddle::after {
-    position: absolute;
-    top: 0.25rem;
-    left: 0.25rem;
-    display: block;
-    width: 1.5rem;
-    height: 1.5rem;
-    -webkit-transform: translate3d(0, 0, 0);
-            transform: translate3d(0, 0, 0);
-    border-radius: 0;
-    background: #fefefe;
-    -webkit-transition: all 0.25s ease-out;
-    transition: all 0.25s ease-out;
-    content: ''; }
-  input:checked ~ .switch-paddle {
-    background: #1779ba; }
-    input:checked ~ .switch-paddle::after {
-      left: 2.25rem; }
-  [data-whatinput='mouse'] input:focus ~ .switch-paddle {
-    outline: 0; }
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-bottom-width: 0;
+  border-top-style: solid;
+  border-color: #1779ba transparent transparent;
+  right: 5px;
+  left: auto;
+  margin-top: -3px; }
 
-.switch-active, .switch-inactive {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%); }
+[data-whatinput='mouse'] .dropdown.menu a {
+  outline: 0; }
 
-.switch-active {
-  left: 8%;
+.dropdown.menu > li > a {
+  padding: 0.7rem 1rem; }
+
+.dropdown.menu > li.is-active > a {
+  background: transparent;
+  color: #1779ba; }
+
+.no-js .dropdown.menu ul {
   display: none; }
-  input:checked + label > .switch-active {
-    display: block; }
 
-.switch-inactive {
-  right: 15%; }
-  input:checked + label > .switch-inactive {
-    display: none; }
+.dropdown.menu .nested.is-dropdown-submenu {
+  margin-right: 0;
+  margin-left: 0; }
 
-.switch.tiny {
-  height: 1.5rem; }
-  .switch.tiny .switch-paddle {
-    width: 3rem;
-    height: 1.5rem;
-    font-size: 0.625rem; }
-  .switch.tiny .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 1rem;
-    height: 1rem; }
-  .switch.tiny input:checked ~ .switch-paddle::after {
-    left: 1.75rem; }
+.dropdown.menu.vertical > li .is-dropdown-submenu {
+  top: 0; }
 
-.switch.small {
-  height: 1.75rem; }
-  .switch.small .switch-paddle {
-    width: 3.5rem;
-    height: 1.75rem;
-    font-size: 0.75rem; }
-  .switch.small .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 1.25rem;
-    height: 1.25rem; }
-  .switch.small input:checked ~ .switch-paddle::after {
-    left: 2rem; }
+.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {
+  top: 0;
+  right: 100%;
+  left: auto; }
 
-.switch.large {
-  height: 2.5rem; }
-  .switch.large .switch-paddle {
-    width: 5rem;
-    height: 2.5rem;
-    font-size: 1rem; }
-  .switch.large .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 2rem;
-    height: 2rem; }
-  .switch.large input:checked ~ .switch-paddle::after {
-    left: 2.75rem; }
+.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {
+  right: auto;
+  left: 100%; }
+
+.dropdown.menu.vertical > li > a::after {
+  right: 14px; }
+
+.dropdown.menu.vertical > li.opens-left > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  right: auto;
+  left: 5px; }
+
+.dropdown.menu.vertical > li.opens-right > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba; }
+
+@media print, screen and (min-width: 40em) {
+  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {
+    top: 100%;
+    right: 0;
+    left: auto; }
+  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
+    top: 100%;
+    right: auto;
+    left: 0; }
+  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {
+    position: relative;
+    padding-right: 1.5rem; }
+  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    right: 5px;
+    left: auto;
+    margin-top: -3px; }
+  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {
+    top: 0; }
+  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {
+    top: 0;
+    right: 100%;
+    left: auto; }
+  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
+  .dropdown.menu.medium-vertical > li > a::after {
+    right: 14px; }
+  .dropdown.menu.medium-vertical > li.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .dropdown.menu.medium-vertical > li.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; } }
+
+@media print, screen and (min-width: 64em) {
+  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {
+    top: 100%;
+    right: 0;
+    left: auto; }
+  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {
+    top: 100%;
+    right: auto;
+    left: 0; }
+  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {
+    position: relative;
+    padding-right: 1.5rem; }
+  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    right: 5px;
+    left: auto;
+    margin-top: -3px; }
+  .dropdown.menu.large-vertical > li .is-dropdown-submenu {
+    top: 0; }
+  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {
+    top: 0;
+    right: 100%;
+    left: auto; }
+  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
+  .dropdown.menu.large-vertical > li > a::after {
+    right: 14px; }
+  .dropdown.menu.large-vertical > li.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .dropdown.menu.large-vertical > li.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; } }
+
+.dropdown.menu.align-right .is-dropdown-submenu.first-sub {
+  top: 100%;
+  right: 0;
+  left: auto; }
+
+.is-dropdown-menu.vertical {
+  width: 100px; }
+  .is-dropdown-menu.vertical.align-right {
+    float: right; }
 
-table {
-  border-collapse: collapse;
-  width: 100%;
-  margin-bottom: 1rem;
-  border-radius: 0; }
-  table thead,
-  table tbody,
-  table tfoot {
-    border: 1px solid #f1f1f1;
-    background-color: #fefefe; }
-  table caption {
-    padding: 0.5rem 0.625rem 0.625rem;
-    font-weight: bold; }
-  table thead {
-    background: #f8f8f8;
-    color: #0a0a0a; }
-  table tfoot {
-    background: #f1f1f1;
-    color: #0a0a0a; }
-  table thead tr,
-  table tfoot tr {
-    background: transparent; }
-  table thead th,
-  table thead td,
-  table tfoot th,
-  table tfoot td {
-    padding: 0.5rem 0.625rem 0.625rem;
-    font-weight: bold;
-    text-align: left; }
-  table tbody th,
-  table tbody td {
-    padding: 0.5rem 0.625rem 0.625rem; }
-  table tbody tr:nth-child(even) {
-    border-bottom: 0;
-    background-color: #f1f1f1; }
-  table.unstriped tbody {
-    background-color: #fefefe; }
-    table.unstriped tbody tr {
-      border-bottom: 0;
-      border-bottom: 1px solid #f1f1f1;
-      background-color: #fefefe; }
+.is-dropdown-submenu-parent {
+  position: relative; }
+  .is-dropdown-submenu-parent a::after {
+    position: absolute;
+    top: 50%;
+    right: 5px;
+    left: auto;
+    margin-top: -6px; }
+  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {
+    top: 100%;
+    left: auto; }
+  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {
+    right: 100%;
+    left: auto; }
+  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
 
-@media screen and (max-width: 63.9375em) {
-  table.stack thead {
-    display: none; }
-  table.stack tfoot {
-    display: none; }
-  table.stack tr,
-  table.stack th,
-  table.stack td {
+.is-dropdown-submenu {
+  position: absolute;
+  top: 0;
+  left: 100%;
+  z-index: 1;
+  display: none;
+  min-width: 200px;
+  border: 1px solid #cacaca;
+  background: #fefefe; }
+  .dropdown .is-dropdown-submenu a {
+    padding: 0.7rem 1rem; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {
+    right: 14px; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; }
+  .is-dropdown-submenu .is-dropdown-submenu {
+    margin-top: -1px; }
+  .is-dropdown-submenu > li {
+    width: 100%; }
+  .is-dropdown-submenu.js-dropdown-active {
     display: block; }
-  table.stack td {
-    border-top: 0; } }
 
-table.scroll {
-  display: block;
+.is-off-canvas-open {
+  overflow: hidden; }
+
+.js-off-canvas-overlay {
+  position: absolute;
+  top: 0;
+  left: 0;
+  z-index: 11;
   width: 100%;
-  overflow-x: auto; }
+  height: 100%;
+  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
+  transition: opacity 0.5s ease, visibility 0.5s ease;
+  background: rgba(254, 254, 254, 0.25);
+  opacity: 0;
+  visibility: hidden;
+  overflow: hidden; }
+  .js-off-canvas-overlay.is-visible {
+    opacity: 1;
+    visibility: visible; }
+  .js-off-canvas-overlay.is-closable {
+    cursor: pointer; }
+  .js-off-canvas-overlay.is-overlay-absolute {
+    position: absolute; }
+  .js-off-canvas-overlay.is-overlay-fixed {
+    position: fixed; }
 
-table.hover thead tr:hover {
-  background-color: #f3f3f3; }
+.off-canvas-wrapper {
+  position: relative;
+  overflow: hidden; }
 
-table.hover tfoot tr:hover {
-  background-color: #ececec; }
+.off-canvas {
+  position: fixed;
+  z-index: 12;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  background: #e6e6e6; }
+  [data-whatinput='mouse'] .off-canvas {
+    outline: 0; }
+  .off-canvas.is-transition-push {
+    z-index: 12; }
+  .off-canvas.is-closed {
+    visibility: hidden; }
+  .off-canvas.is-transition-overlap {
+    z-index: 13; }
+    .off-canvas.is-transition-overlap.is-open {
+      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
+              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
+  .off-canvas.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-table.hover tbody tr:hover {
-  background-color: #f9f9f9; }
+.off-canvas-absolute {
+  position: absolute;
+  z-index: 12;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  background: #e6e6e6; }
+  [data-whatinput='mouse'] .off-canvas-absolute {
+    outline: 0; }
+  .off-canvas-absolute.is-transition-push {
+    z-index: 12; }
+  .off-canvas-absolute.is-closed {
+    visibility: hidden; }
+  .off-canvas-absolute.is-transition-overlap {
+    z-index: 13; }
+    .off-canvas-absolute.is-transition-overlap.is-open {
+      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
+              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
+  .off-canvas-absolute.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-table.hover:not(.unstriped) tr:nth-of-type(even):hover {
-  background-color: #ececec; }
+.position-left {
+  top: 0;
+  left: 0;
+  height: 100%;
+  overflow-y: auto;
+  width: 250px;
+  -webkit-transform: translateX(-250px);
+      -ms-transform: translateX(-250px);
+          transform: translateX(-250px); }
+  .off-canvas-content .off-canvas.position-left {
+    -webkit-transform: translateX(-250px);
+        -ms-transform: translateX(-250px);
+            transform: translateX(-250px); }
+    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-left.has-transition-push {
+    -webkit-transform: translateX(250px);
+        -ms-transform: translateX(250px);
+            transform: translateX(250px); }
+  .position-left.is-transition-push {
+    -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }
 
-.table-scroll {
-  overflow-x: auto; }
-  .table-scroll table {
-    width: auto; }
+.position-right {
+  top: 0;
+  right: 0;
+  height: 100%;
+  overflow-y: auto;
+  width: 250px;
+  -webkit-transform: translateX(250px);
+      -ms-transform: translateX(250px);
+          transform: translateX(250px); }
+  .off-canvas-content .off-canvas.position-right {
+    -webkit-transform: translateX(250px);
+        -ms-transform: translateX(250px);
+            transform: translateX(250px); }
+    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-right.has-transition-push {
+    -webkit-transform: translateX(-250px);
+        -ms-transform: translateX(-250px);
+            transform: translateX(-250px); }
+  .position-right.is-transition-push {
+    -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }
 
-.tabs {
-  margin: 0;
-  border: 1px solid #e6e6e6;
-  background: #fefefe;
-  list-style-type: none; }
-  .tabs::before, .tabs::after {
-    display: table;
-    content: ' '; }
-  .tabs::after {
-    clear: both; }
+.position-top {
+  top: 0;
+  left: 0;
+  width: 100%;
+  overflow-x: auto;
+  height: 250px;
+  -webkit-transform: translateY(-250px);
+      -ms-transform: translateY(-250px);
+          transform: translateY(-250px); }
+  .off-canvas-content .off-canvas.position-top {
+    -webkit-transform: translateY(-250px);
+        -ms-transform: translateY(-250px);
+            transform: translateY(-250px); }
+    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-top.has-transition-push {
+    -webkit-transform: translateY(250px);
+        -ms-transform: translateY(250px);
+            transform: translateY(250px); }
+  .position-top.is-transition-push {
+    -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }
 
-.tabs.vertical > li {
-  display: block;
-  float: none;
-  width: auto; }
+.position-bottom {
+  bottom: 0;
+  left: 0;
+  width: 100%;
+  overflow-x: auto;
+  height: 250px;
+  -webkit-transform: translateY(250px);
+      -ms-transform: translateY(250px);
+          transform: translateY(250px); }
+  .off-canvas-content .off-canvas.position-bottom {
+    -webkit-transform: translateY(250px);
+        -ms-transform: translateY(250px);
+            transform: translateY(250px); }
+    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-bottom.has-transition-push {
+    -webkit-transform: translateY(-250px);
+        -ms-transform: translateY(-250px);
+            transform: translateY(-250px); }
+  .position-bottom.is-transition-push {
+    -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }
 
-.tabs.simple > li > a {
-  padding: 0; }
-  .tabs.simple > li > a:hover {
-    background: transparent; }
+.off-canvas-content {
+  -webkit-transform: none;
+      -ms-transform: none;
+          transform: none;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden; }
+  .off-canvas-content.has-transition-push {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
+  .off-canvas-content .off-canvas.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-.tabs.primary {
-  background: #1779ba; }
-  .tabs.primary > li > a {
-    color: #fefefe; }
-    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
-      background: #1673b1; }
+@media print, screen and (min-width: 40em) {
+  .position-left.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-left.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-left.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-left {
+      margin-left: 250px; }
+    .position-left.reveal-for-medium ~ .off-canvas-content {
+      margin-left: 250px; }
+  .position-right.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-right.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-right.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-right {
+      margin-right: 250px; }
+    .position-right.reveal-for-medium ~ .off-canvas-content {
+      margin-right: 250px; }
+  .position-top.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-top.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-top.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-top {
+      margin-top: 250px; }
+    .position-top.reveal-for-medium ~ .off-canvas-content {
+      margin-top: 250px; }
+  .position-bottom.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-bottom.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-bottom.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-bottom {
+      margin-bottom: 250px; }
+    .position-bottom.reveal-for-medium ~ .off-canvas-content {
+      margin-bottom: 250px; } }
 
-.tabs-title {
-  float: left; }
-  .tabs-title > a {
-    display: block;
-    padding: 1.25rem 1.5rem;
-    font-size: 0.75rem;
-    line-height: 1;
-    color: #1779ba; }
-    .tabs-title > a:hover {
-      background: #fefefe;
-      color: #1468a0; }
-    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {
-      background: #e6e6e6;
-      color: #1779ba; }
+@media print, screen and (min-width: 64em) {
+  .position-left.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-left.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-left.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-left {
+      margin-left: 250px; }
+    .position-left.reveal-for-large ~ .off-canvas-content {
+      margin-left: 250px; }
+  .position-right.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-right.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-right.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-right {
+      margin-right: 250px; }
+    .position-right.reveal-for-large ~ .off-canvas-content {
+      margin-right: 250px; }
+  .position-top.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-top.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-top.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-top {
+      margin-top: 250px; }
+    .position-top.reveal-for-large ~ .off-canvas-content {
+      margin-top: 250px; }
+  .position-bottom.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-bottom.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-bottom.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-bottom {
+      margin-bottom: 250px; }
+    .position-bottom.reveal-for-large ~ .off-canvas-content {
+      margin-bottom: 250px; } }
 
-.tabs-content {
-  border: 1px solid #e6e6e6;
-  border-top: 0;
-  background: #fefefe;
-  color: #0a0a0a;
-  -webkit-transition: all 0.5s ease;
-  transition: all 0.5s ease; }
+@media print, screen and (min-width: 40em) {
+  .off-canvas.in-canvas-for-medium {
+    visibility: visible;
+    height: auto;
+    position: static;
+    background: none;
+    width: auto;
+    overflow: visible;
+    -webkit-transition: none;
+    transition: none; }
+    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {
+      -webkit-box-shadow: none;
+              box-shadow: none;
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas.in-canvas-for-medium .close-button {
+      display: none; } }
+
+@media print, screen and (min-width: 64em) {
+  .off-canvas.in-canvas-for-large {
+    visibility: visible;
+    height: auto;
+    position: static;
+    background: none;
+    width: auto;
+    overflow: visible;
+    -webkit-transition: none;
+    transition: none; }
+    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {
+      -webkit-box-shadow: none;
+              box-shadow: none;
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas.in-canvas-for-large .close-button {
+      display: none; } }
 
-.tabs-content.vertical {
-  border: 1px solid #e6e6e6;
-  border-left: 0; }
+html.is-reveal-open {
+  position: fixed;
+  width: 100%;
+  overflow-y: hidden; }
+  html.is-reveal-open.zf-has-scroll {
+    overflow-y: scroll; }
+  html.is-reveal-open body {
+    overflow-y: hidden; }
 
-.tabs-panel {
+.reveal-overlay {
+  position: fixed;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  z-index: 1005;
   display: none;
-  padding: 1rem; }
-  .tabs-panel.is-active {
-    display: block; }
+  background-color: rgba(10, 10, 10, 0.45);
+  overflow-y: auto; }
 
-.thumbnail {
-  display: inline-block;
-  max-width: 100%;
-  margin-bottom: 1rem;
-  border: solid 4px #fefefe;
+.reveal {
+  z-index: 1006;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  display: none;
+  padding: 1rem;
+  border: 1px solid #cacaca;
   border-radius: 0;
-  -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-          box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-  line-height: 0; }
+  background-color: #fefefe;
+  position: relative;
+  top: 100px;
+  margin-right: auto;
+  margin-left: auto;
+  overflow-y: auto; }
+  [data-whatinput='mouse'] .reveal {
+    outline: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal {
+      min-height: 0; } }
+  .reveal .column, .reveal .columns {
+    min-width: 0; }
+  .reveal > :last-child {
+    margin-bottom: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal {
+      width: 600px;
+      max-width: 75rem; } }
+  .reveal.collapse {
+    padding: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal.tiny {
+      width: 30%;
+      max-width: 75rem; } }
+  @media print, screen and (min-width: 40em) {
+    .reveal.small {
+      width: 50%;
+      max-width: 75rem; } }
+  @media print, screen and (min-width: 40em) {
+    .reveal.large {
+      width: 90%;
+      max-width: 75rem; } }
+  .reveal.full {
+    top: 0;
+    right: 0;
+    bottom: 0;
+    left: 0;
+    width: 100%;
+    max-width: none;
+    height: 100%;
+    min-height: 100%;
+    margin-left: 0;
+    border: 0;
+    border-radius: 0; }
+  @media screen and (max-width: 39.99875em) {
+    .reveal {
+      top: 0;
+      right: 0;
+      bottom: 0;
+      left: 0;
+      width: 100%;
+      max-width: none;
+      height: 100%;
+      min-height: 100%;
+      margin-left: 0;
+      border: 0;
+      border-radius: 0; } }
+  .reveal.without-overlay {
+    position: fixed; }
 
-a.thumbnail {
-  -webkit-transition: -webkit-box-shadow 200ms ease-out;
-  transition: -webkit-box-shadow 200ms ease-out;
-  transition: box-shadow 200ms ease-out;
-  transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; }
-  a.thumbnail:hover, a.thumbnail:focus {
-    -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
-            box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }
-  a.thumbnail image {
-    -webkit-box-shadow: none;
-            box-shadow: none; }
+.sticky-container {
+  position: relative; }
+
+.sticky {
+  position: relative;
+  z-index: 0;
+  -webkit-transform: translate3d(0, 0, 0);
+          transform: translate3d(0, 0, 0); }
+
+.sticky.is-stuck {
+  position: fixed;
+  z-index: 5;
+  width: 100%; }
+  .sticky.is-stuck.is-at-top {
+    top: 0; }
+  .sticky.is-stuck.is-at-bottom {
+    bottom: 0; }
+
+.sticky.is-anchored {
+  position: relative;
+  right: auto;
+  left: auto; }
+  .sticky.is-anchored.is-at-bottom {
+    bottom: 0; }
 
 .title-bar {
   padding: 0.5rem;
@@ -4202,102 +4095,6 @@ a.thumbnail {
   vertical-align: middle;
   font-weight: bold; }
 
-.has-tip {
-  position: relative;
-  display: inline-block;
-  border-bottom: dotted 1px #8a8a8a;
-  font-weight: bold;
-  cursor: help; }
-
-.tooltip {
-  position: absolute;
-  top: calc(100% + 0.6495rem);
-  z-index: 1200;
-  max-width: 10rem;
-  padding: 0.75rem;
-  border-radius: 0;
-  background-color: #0a0a0a;
-  font-size: 80%;
-  color: #fefefe; }
-  .tooltip::before {
-    position: absolute; }
-  .tooltip.bottom::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-top-width: 0;
-    border-bottom-style: solid;
-    border-color: transparent transparent #0a0a0a;
-    bottom: 100%; }
-  .tooltip.bottom.align-center::before {
-    left: 50%;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
-  .tooltip.top::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #0a0a0a transparent transparent;
-    top: 100%;
-    bottom: auto; }
-  .tooltip.top.align-center::before {
-    left: 50%;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
-  .tooltip.left::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #0a0a0a;
-    left: 100%; }
-  .tooltip.left.align-center::before {
-    bottom: auto;
-    top: 50%;
-    -webkit-transform: translateY(-50%);
-        -ms-transform: translateY(-50%);
-            transform: translateY(-50%); }
-  .tooltip.right::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #0a0a0a transparent transparent;
-    right: 100%;
-    left: auto; }
-  .tooltip.right.align-center::before {
-    bottom: auto;
-    top: 50%;
-    -webkit-transform: translateY(-50%);
-        -ms-transform: translateY(-50%);
-            transform: translateY(-50%); }
-  .tooltip.align-top::before {
-    bottom: auto;
-    top: 10%; }
-  .tooltip.align-bottom::before {
-    bottom: 10%;
-    top: auto; }
-  .tooltip.align-left::before {
-    left: 10%;
-    right: auto; }
-  .tooltip.align-right::before {
-    left: auto;
-    right: 10%; }
-
 .top-bar {
   padding: 0.5rem; }
   .top-bar::before, .top-bar::after {
@@ -4323,11 +4120,11 @@ a.thumbnail {
     .top-bar .top-bar-left,
     .top-bar .top-bar-right {
       width: auto; } }
-  @media screen and (max-width: 63.9375em) {
+  @media screen and (max-width: 63.99875em) {
     .top-bar.stacked-for-medium .top-bar-left,
     .top-bar.stacked-for-medium .top-bar-right {
       width: 100%; } }
-  @media screen and (max-width: 74.9375em) {
+  @media screen and (max-width: 74.99875em) {
     .top-bar.stacked-for-large .top-bar-left,
     .top-bar.stacked-for-large .top-bar-right {
       width: 100%; } }
@@ -4345,13 +4142,31 @@ a.thumbnail {
 .top-bar-right {
   float: right; }
 
+.float-left {
+  float: left !important; }
+
+.float-right {
+  float: right !important; }
+
+.float-center {
+  display: block;
+  margin-right: auto;
+  margin-left: auto; }
+
+.clearfix::before, .clearfix::after {
+  display: table;
+  content: ' '; }
+
+.clearfix::after {
+  clear: both; }
+
 .hide {
   display: none !important; }
 
 .invisible {
   visibility: hidden; }
 
-@media screen and (max-width: 39.9375em) {
+@media screen and (max-width: 39.99875em) {
   .hide-for-small-only {
     display: none !important; } }
 
@@ -4363,15 +4178,15 @@ a.thumbnail {
   .hide-for-medium {
     display: none !important; } }
 
-@media screen and (max-width: 39.9375em) {
+@media screen and (max-width: 39.99875em) {
   .show-for-medium {
     display: none !important; } }
 
-@media screen and (min-width: 40em) and (max-width: 63.9375em) {
+@media screen and (min-width: 40em) and (max-width: 63.99875em) {
   .hide-for-medium-only {
     display: none !important; } }
 
-@media screen and (max-width: 39.9375em), screen and (min-width: 64em) {
+@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {
   .show-for-medium-only {
     display: none !important; } }
 
@@ -4379,15 +4194,15 @@ a.thumbnail {
   .hide-for-large {
     display: none !important; } }
 
-@media screen and (max-width: 63.9375em) {
+@media screen and (max-width: 63.99875em) {
   .show-for-large {
     display: none !important; } }
 
-@media screen and (min-width: 64em) and (max-width: 74.9375em) {
+@media screen and (min-width: 64em) and (max-width: 74.99875em) {
   .hide-for-large-only {
     display: none !important; } }
 
-@media screen and (max-width: 63.9375em), screen and (min-width: 75em) {
+@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {
   .show-for-large-only {
     display: none !important; } }
 
@@ -4400,8 +4215,6 @@ a.thumbnail {
   overflow: hidden;
   clip: rect(0, 0, 0, 0);
   white-space: nowrap;
-  -webkit-clip-path: inset(50%);
-          clip-path: inset(50%);
   border: 0; }
 
 .show-on-focus:active, .show-on-focus:focus {
@@ -4410,9 +4223,7 @@ a.thumbnail {
   height: auto;
   overflow: visible;
   clip: auto;
-  white-space: normal;
-  -webkit-clip-path: none;
-          clip-path: none; }
+  white-space: normal; }
 
 .show-for-landscape,
 .hide-for-portrait {
@@ -4438,22 +4249,4 @@ a.thumbnail {
     .show-for-portrait {
       display: block !important; } }
 
-.float-left {
-  float: left !important; }
-
-.float-right {
-  float: right !important; }
-
-.float-center {
-  display: block;
-  margin-right: auto;
-  margin-left: auto; }
-
-.clearfix::before, .clearfix::after {
-  display: table;
-  content: ' '; }
-
-.clearfix::after {
-  clear: both; }
-
 /*# sourceMappingURL=foundation-float.css.map */
diff --git a/dist/css/foundation-float.css.map b/dist/css/foundation-float.css.map
new file mode 100644 (file)
index 0000000..c6027ec
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation-float.css","../scss/foundation.scss","../scss/util/_breakpoint.scss","../scss/components/_reveal.scss","../scss/vendor/normalize.scss","../scss/_global.scss","../scss/util/_unit.scss","../scss/util/_mixins.scss","../scss/forms/_text.scss","../scss/forms/_checkbox.scss","../scss/forms/_label.scss","../scss/forms/_help-text.scss","../scss/forms/_input-group.scss","../scss/forms/_fieldset.scss","../scss/forms/_select.scss","../scss/forms/_error.scss","../scss/typography/_base.scss","../scss/typography/_helpers.scss","../scss/typography/_alignment.scss","../scss/typography/_print.scss","../scss/grid/_classes.scss","../scss/grid/_row.scss","../scss/grid/_gutter.scss","../scss/grid/_size.scss","../scss/grid/_column.scss","../scss/grid/_position.scss","../scss/grid/_layout.scss","../scss/components/_button.scss","../scss/components/_button-group.scss","../scss/components/_close-button.scss","../scss/components/_label.scss","../scss/components/_progress-bar.scss","../scss/forms/_progress.scss","../scss/components/_slider.scss","../scss/forms/_range.scss","../scss/components/_switch.scss","../scss/components/_table.scss","../scss/util/_color.scss","../scss/components/_badge.scss","../scss/components/_breadcrumbs.scss","../scss/components/_callout.scss","../scss/components/_card.scss","../scss/components/_dropdown.scss","../scss/components/_pagination.scss","../scss/components/_tooltip.scss","../scss/components/_accordion.scss","../scss/components/_media-object.scss","../scss/components/_orbit.scss","../scss/components/_responsive-embed.scss","../scss/util/_math.scss","../scss/components/_tabs.scss","../scss/components/_thumbnail.scss","../scss/components/_menu.scss","../scss/components/_menu-icon.scss","../scss/components/_accordion-menu.scss","../scss/components/_drilldown.scss","../scss/components/_dropdown-menu.scss","../scss/components/_off-canvas.scss","../scss/components/_sticky.scss","../scss/components/_title-bar.scss","../scss/components/_top-bar.scss","../scss/components/_float.scss","../scss/components/_visibility.scss"],"names":[],"mappings":"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kB;EAClB,eAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,gBAHmD,EAAA;;ALsFjD;EKtDJ,qBDrCqD,EAAA;;AJyEjD;EGxFJ,UCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,SAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,UAHmD,EAAA;;ALsFjD;EKtDJ,sBDrCqD,EAAA;;AJyEjD;EGxFJ,gBCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,eAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,gBAHmD,EAAA;;ALsFjD;EKtDJ,gBDrCqD,EAAA;;AJyEjD;EGxFJ,gBCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,eAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,gBAHmD,EAAA;;ALsFjD;EKtDJ,sBDrCqD,EAAA;;AJyEjD;EGxFJ,UCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,SAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,UAHmD,EAAA;;ALsFjD;EKtDJ,sBDrCqD,EAAA;;AJyEjD;EGxFJ,gBCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,eAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,gBAHmD,EAAA;;ALsFjD;EKtDJ,gBDrCqD,EAAA;;AJyEjD;EGxFJ,gBCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,eAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,gBAHmD,EAAA;;ALsFjD;EKtDJ,sBDrCqD,EAAA;;AJyEjD;EGxFJ,UCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,SAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,UAHmD,EAAA;;ALsFjD;EKtDJ,sBDrCqD,EAAA;;AJyEjD;EGxFJ,gBCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,eAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,gBAHmD,EAAA;;ALsFjD;EKtDJ,gBDrCqD,EAAA;;AJyEjD;EGxFJ,gBCeqD,EAAA;;AJ+E/C;EKxEJ,kBAAkB;EAClB,eAHmD,EAAA;;AL8E/C;EK5EJ,kBAAkB;EAClB,gBAHmD,EAAA;;ALsFjD;EKtDJ,sBDrCqD,EAAA;;AJyEjD;EGxFJ,WCeqD,EAAA;;AJ2FjD;EKtDJ,sBDrCqD,EAAA;;AJkGjD;EMzGF,WrBoGuD;EqBnGvD,WAAuB,EAAA;ENwGrB;IMjFA,WAAW,EAAA;ENiFX;IM7EA,WAAW,EAAA;EN6EX;IMzEA,WrBoEqD,EAAA;;AeKrD;EMzGF,WrBoGuD;EqBnGvD,UAAuB,EAAA;ENwGrB;IMjFA,WAAW,EAAA;ENiFX;IM7EA,WAAW,EAAA;EN6EX;IMzEA,WrBoEqD,EAAA;;AeKrD;EMzGF,WrBoGuD;EqBnGvD,gBAAuB,EAAA;ENwGrB;IMjFA,WAAW,EAAA;ENiFX;IM7EA,WAAW,EAAA;EN6EX;IMzEA,WrBoEqD,EAAA;;AeKrD;EMzGF,WrBoGuD;EqBnGvD,UAAuB,EAAA;ENwGrB;IMjFA,WAAW,EAAA;ENiFX;IM7EA,WAAW,EAAA;EN6EX;IMzEA,WrBoEqD,EAAA;;AeKrD;EMzGF,WrBoGuD;EqBnGvD,UAAuB,EAAA;ENwGrB;IMjFA,WAAW,EAAA;ENiFX;IM7EA,WAAW,EAAA;EN6EX;IMzEA,WrBoEqD,EAAA;;AeKrD;EMzGF,WrBoGuD;EqBnGvD,gBAAuB,EAAA;ENwGrB;IMjFA,WAAW,EAAA;ENiFX;IM7EA,WAAW,EAAA;EN6EX;IMzEA,WrBoEqD,EAAA;;AeKrD;EMzGF,WrBoGuD;EqBnGvD,gBAAuB,EAAA;ENwGrB;IMjFA,WAAW,EAAA;ENiFX;IM7EA,WAAW,EAAA;EN6EX;IMzEA,WrBoEqD,EAAA;;AeKrD;EMzGF,WrBoGuD;EqBnGvD,YAAuB,EAAA;ENwGrB;IMjFA,WAAW,EAAA;ENiFX;IM7EA,WAAW,EAAA;EN6EX;IMzEA,WrBoEqD,EAAA;;AeWvD;EE/GA,gBhBuES;EgBtET,ehBsES,EAAA;;AcwCT;EAII,eAAe;EACf,cAAc,EAAA;;AAIlB;EACE,eAAe;EACf,cAAc,EAAA;;AAGhB;EE7HA,uBAFqC;EAGrC,sBAHqC,EAAA;;AFoIrC;EK1GA,kBAAkB;EAClB,iBAAiB,EAAA;EALjB;IACE,WAAW;IACX,WAAW,EAAA;;ALiHb;;;EKnGF,gBAAgB;EAChB,eAAe;EACf,cAAc,EAAA;EAzCZ;;;;;IACE,WpBsGqD;IoBrGrD,WAAW,EAAA;EAKX;;;IACE,YpBgGoD,EAAA;;AH2CtD;EkBhEA;IGxFJ,eCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,cAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,eAHmD,EAAA;ELsFjD;IKtDJ,eDxCgC,EAAA;EJ4E5B;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,qBDrCqD,EAAA;EJyEjD;IGxFJ,UCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,SAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,UAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,gBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,UCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,SAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,UAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,gBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,UCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,SAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,UAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,gBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,WCeqD,EAAA;EJ2FjD;IKtDJ,sBDrCqD,EAAA;EJkGjD;IMzGF,WrBoGuD;IqBnGvD,WAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,UAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,gBAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,UAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,UAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,gBAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,gBAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,YAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeWvD;IE/GA,gBhBuES;IgBtET,ehBsES,EAAA;EcwCT;IAII,eAAe;IACf,cAAc,EAAA;EAIlB;IACE,eAAe;IACf,cAAc,EAAA;EAGhB;IE7HA,wBAFqC;IAGrC,uBAHqC,EAAA;EFoIrC;IK1GA,kBAAkB;IAClB,iBAAiB,EAAA;IALjB;MACE,WAAW;MACX,WAAW,EAAA;ELiHb;;;IKnGF,gBAAgB;IAChB,eAAe;IACf,cAAc,EAAA;IAzCZ;;;;;MACE,WpBsGqD;MoBrGrD,WAAW,EAAA;IAKX;;;MACE,YpBgGoD,EAAA,EoB/FrD;;AvB0ID;EkBhEA;IGxFJ,eCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,cAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,eAHmD,EAAA;ELsFjD;IKtDJ,eDxCgC,EAAA;EJ4E5B;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,qBDrCqD,EAAA;EJyEjD;IGxFJ,UCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,SAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,UAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,gBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,UCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,SAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,UAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,gBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,UCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,SAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,UAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,gBDrCqD,EAAA;EJyEjD;IGxFJ,gBCeqD,EAAA;EJ+E/C;IKxEJ,kBAAkB;IAClB,eAHmD,EAAA;EL8E/C;IK5EJ,kBAAkB;IAClB,gBAHmD,EAAA;ELsFjD;IKtDJ,sBDrCqD,EAAA;EJyEjD;IGxFJ,WCeqD,EAAA;EJ2FjD;IKtDJ,sBDrCqD,EAAA;EJkGjD;IMzGF,WrBoGuD;IqBnGvD,WAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,UAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,gBAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,UAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,UAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiFX;MM7EA,WAAW,EAAA;IN6EX;MMzEA,WrBoEqD,EAAA;EeKrD;IMzGF,WrBoGuD;IqBnGvD,gBAAuB,EAAA;INwGrB;MMjFA,WAAW,EAAA;INiF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","file":"foundation-float.css","sourcesContent":["@charset \"UTF-8\";\n/**\n * Foundation for Sites by ZURB\n * Version 6.5.3\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n@media print, screen and (min-width: 40em) {\n  .reveal, .reveal.tiny, .reveal.small, .reveal.large {\n    right: auto;\n    left: auto;\n    margin: 0 auto; } }\n\n/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  line-height: 1.15;\n  -webkit-text-size-adjust: 100%; }\n\nbody {\n  margin: 0; }\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0; }\n\nhr {\n  box-sizing: content-box;\n  height: 0;\n  overflow: visible; }\n\npre {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\na {\n  background-color: transparent; }\n\nabbr[title] {\n  border-bottom: none;\n  text-decoration: underline;\n  text-decoration: underline dotted; }\n\nb,\nstrong {\n  font-weight: bolder; }\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\nsmall {\n  font-size: 80%; }\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline; }\n\nsub {\n  bottom: -0.25em; }\n\nsup {\n  top: -0.5em; }\n\nimg {\n  border-style: none; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: 100%;\n  line-height: 1.15;\n  margin: 0; }\n\nbutton,\ninput {\n  overflow: visible; }\n\nbutton,\nselect {\n  text-transform: none; }\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button; }\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0; }\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText; }\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em; }\n\nlegend {\n  box-sizing: border-box;\n  color: inherit;\n  display: table;\n  max-width: 100%;\n  padding: 0;\n  white-space: normal; }\n\nprogress {\n  vertical-align: baseline; }\n\ntextarea {\n  overflow: auto; }\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  padding: 0; }\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto; }\n\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  outline-offset: -2px; }\n\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none; }\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  font: inherit; }\n\ndetails {\n  display: block; }\n\nsummary {\n  display: list-item; }\n\ntemplate {\n  display: none; }\n\n[hidden] {\n  display: none; }\n\n.foundation-mq {\n  font-family: \"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em\"; }\n\nhtml {\n  box-sizing: border-box;\n  font-size: 100%; }\n\n*,\n*::before,\n*::after {\n  box-sizing: inherit; }\n\nbody {\n  margin: 0;\n  padding: 0;\n  background: #fefefe;\n  font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale; }\n\nimg {\n  display: inline-block;\n  vertical-align: middle;\n  max-width: 100%;\n  height: auto;\n  -ms-interpolation-mode: bicubic; }\n\ntextarea {\n  height: auto;\n  min-height: 50px;\n  border-radius: 0; }\n\nselect {\n  box-sizing: border-box;\n  width: 100%;\n  border-radius: 0; }\n\n.map_canvas img,\n.map_canvas embed,\n.map_canvas object,\n.mqa-display img,\n.mqa-display embed,\n.mqa-display object {\n  max-width: none !important; }\n\nbutton {\n  padding: 0;\n  appearance: none;\n  border: 0;\n  border-radius: 0;\n  background: transparent;\n  line-height: 1;\n  cursor: auto; }\n  [data-whatinput='mouse'] button {\n    outline: 0; }\n\npre {\n  overflow: auto; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit; }\n\n.is-visible {\n  display: block !important; }\n\n.is-hidden {\n  display: none !important; }\n\n[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],\ntextarea {\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n  appearance: none; }\n  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,\n  textarea:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n\ntextarea {\n  max-width: 100%; }\n  textarea[rows] {\n    height: auto; }\n\ninput:disabled, input[readonly],\ntextarea:disabled,\ntextarea[readonly] {\n  background-color: #e6e6e6;\n  cursor: not-allowed; }\n\n[type='submit'],\n[type='button'] {\n  appearance: none;\n  border-radius: 0; }\n\ninput[type='search'] {\n  box-sizing: border-box; }\n\n::placeholder {\n  color: #cacaca; }\n\n[type='file'],\n[type='checkbox'],\n[type='radio'] {\n  margin: 0 0 1rem; }\n\n[type='checkbox'] + label,\n[type='radio'] + label {\n  display: inline-block;\n  vertical-align: baseline;\n  margin-left: 0.5rem;\n  margin-right: 1rem;\n  margin-bottom: 0; }\n  [type='checkbox'] + label[for],\n  [type='radio'] + label[for] {\n    cursor: pointer; }\n\nlabel > [type='checkbox'],\nlabel > [type='radio'] {\n  margin-right: 0.5rem; }\n\n[type='file'] {\n  width: 100%; }\n\nlabel {\n  display: block;\n  margin: 0;\n  font-size: 0.875rem;\n  font-weight: normal;\n  line-height: 1.8;\n  color: #0a0a0a; }\n  label.middle {\n    margin: 0 0 1rem;\n    padding: 0.5625rem 0; }\n\n.help-text {\n  margin-top: -0.5rem;\n  font-size: 0.8125rem;\n  font-style: italic;\n  color: #0a0a0a; }\n\n.input-group {\n  display: table;\n  width: 100%;\n  margin-bottom: 1rem; }\n  .input-group > :first-child, .input-group > :first-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n  .input-group > :last-child, .input-group > :last-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n\n.input-group-label, .input-group-field, .input-group-button, .input-group-button a,\n.input-group-button input,\n.input-group-button button,\n.input-group-button label {\n  margin: 0;\n  white-space: nowrap;\n  display: table-cell;\n  vertical-align: middle; }\n\n.input-group-label {\n  padding: 0 1rem;\n  border: 1px solid #cacaca;\n  background: #e6e6e6;\n  color: #0a0a0a;\n  text-align: center;\n  white-space: nowrap;\n  width: 1%;\n  height: 100%; }\n  .input-group-label:first-child {\n    border-right: 0; }\n  .input-group-label:last-child {\n    border-left: 0; }\n\n.input-group-field {\n  border-radius: 0; }\n\n.input-group-button {\n  padding-top: 0;\n  padding-bottom: 0;\n  text-align: center;\n  width: 1%;\n  height: 100%; }\n  .input-group-button a,\n  .input-group-button input,\n  .input-group-button button,\n  .input-group-button label {\n    height: 2.4375rem;\n    padding-top: 0;\n    padding-bottom: 0;\n    font-size: 1rem; }\n\n.input-group .input-group-button {\n  display: table-cell; }\n\nfieldset {\n  margin: 0;\n  padding: 0;\n  border: 0; }\n\nlegend {\n  max-width: 100%;\n  margin-bottom: 0.5rem; }\n\n.fieldset {\n  margin: 1.125rem 0;\n  padding: 1.25rem;\n  border: 1px solid #cacaca; }\n  .fieldset legend {\n    margin: 0;\n    margin-left: -0.1875rem;\n    padding: 0 0.1875rem; }\n\nselect {\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  appearance: none;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>\");\n  background-origin: content-box;\n  background-position: right -1rem center;\n  background-repeat: no-repeat;\n  background-size: 9px 6px;\n  padding-right: 1.5rem;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  @media screen and (min-width: 0\\0) {\n    select {\n      background-image: url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==\"); } }\n  select:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  select:disabled {\n    background-color: #e6e6e6;\n    cursor: not-allowed; }\n  select::-ms-expand {\n    display: none; }\n  select[multiple] {\n    height: auto;\n    background-image: none; }\n\n.is-invalid-input:not(:focus) {\n  border-color: #cc4b37;\n  background-color: #f9ecea; }\n  .is-invalid-input:not(:focus)::placeholder {\n    color: #cc4b37; }\n\n.is-invalid-label {\n  color: #cc4b37; }\n\n.form-error {\n  display: none;\n  margin-top: -0.5rem;\n  margin-bottom: 1rem;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #cc4b37; }\n  .form-error.is-visible {\n    display: block; }\n\ndiv,\ndl,\ndt,\ndd,\nul,\nol,\nli,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\npre,\nform,\np,\nblockquote,\nth,\ntd {\n  margin: 0;\n  padding: 0; }\n\np {\n  margin-bottom: 1rem;\n  font-size: inherit;\n  line-height: 1.6;\n  text-rendering: optimizeLegibility; }\n\nem,\ni {\n  font-style: italic;\n  line-height: inherit; }\n\nstrong,\nb {\n  font-weight: bold;\n  line-height: inherit; }\n\nsmall {\n  font-size: 80%;\n  line-height: inherit; }\n\nh1, .h1,\nh2, .h2,\nh3, .h3,\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n  font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  color: inherit;\n  text-rendering: optimizeLegibility; }\n  h1 small, .h1 small,\n  h2 small, .h2 small,\n  h3 small, .h3 small,\n  h4 small, .h4 small,\n  h5 small, .h5 small,\n  h6 small, .h6 small {\n    line-height: 0;\n    color: #cacaca; }\n\nh1, .h1 {\n  font-size: 1.5rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh2, .h2 {\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh3, .h3 {\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh4, .h4 {\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh5, .h5 {\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh6, .h6 {\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n  h1, .h1 {\n    font-size: 3rem; }\n  h2, .h2 {\n    font-size: 2.5rem; }\n  h3, .h3 {\n    font-size: 1.9375rem; }\n  h4, .h4 {\n    font-size: 1.5625rem; }\n  h5, .h5 {\n    font-size: 1.25rem; }\n  h6, .h6 {\n    font-size: 1rem; } }\n\na {\n  line-height: inherit;\n  color: #1779ba;\n  text-decoration: none;\n  cursor: pointer; }\n  a:hover, a:focus {\n    color: #1468a0; }\n  a img {\n    border: 0; }\n\nhr {\n  clear: both;\n  max-width: 75rem;\n  height: 0;\n  margin: 1.25rem auto;\n  border-top: 0;\n  border-right: 0;\n  border-bottom: 1px solid #cacaca;\n  border-left: 0; }\n\nul,\nol,\ndl {\n  margin-bottom: 1rem;\n  list-style-position: outside;\n  line-height: 1.6; }\n\nli {\n  font-size: inherit; }\n\nul {\n  margin-left: 1.25rem;\n  list-style-type: disc; }\n\nol {\n  margin-left: 1.25rem; }\n\nul ul, ol ul, ul ol, ol ol {\n  margin-left: 1.25rem;\n  margin-bottom: 0; }\n\ndl {\n  margin-bottom: 1rem; }\n  dl dt {\n    margin-bottom: 0.3rem;\n    font-weight: bold; }\n\nblockquote {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 1.25rem 0 1.1875rem;\n  border-left: 1px solid #cacaca; }\n  blockquote, blockquote p {\n    line-height: 1.6;\n    color: #8a8a8a; }\n\ncite {\n  display: block;\n  font-size: 0.8125rem;\n  color: #8a8a8a; }\n  cite:before {\n    content: \"— \"; }\n\nabbr, abbr[title] {\n  border-bottom: 1px dotted #0a0a0a;\n  cursor: help;\n  text-decoration: none; }\n\nfigure {\n  margin: 0; }\n\ncode {\n  padding: 0.125rem 0.3125rem 0.0625rem;\n  border: 1px solid #cacaca;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  font-weight: normal;\n  color: #0a0a0a; }\n\nkbd {\n  margin: 0;\n  padding: 0.125rem 0.25rem 0;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  color: #0a0a0a; }\n\n.subheader {\n  margin-top: 0.2rem;\n  margin-bottom: 0.5rem;\n  font-weight: normal;\n  line-height: 1.4;\n  color: #8a8a8a; }\n\n.lead {\n  font-size: 125%;\n  line-height: 1.6; }\n\n.stat {\n  font-size: 2.5rem;\n  line-height: 1; }\n  p + .stat {\n    margin-top: -1rem; }\n\nul.no-bullet, ol.no-bullet {\n  margin-left: 0;\n  list-style: none; }\n\n.text-left {\n  text-align: left; }\n\n.text-right {\n  text-align: right; }\n\n.text-center {\n  text-align: center; }\n\n.text-justify {\n  text-align: justify; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-text-left {\n    text-align: left; }\n  .medium-text-right {\n    text-align: right; }\n  .medium-text-center {\n    text-align: center; }\n  .medium-text-justify {\n    text-align: justify; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-text-left {\n    text-align: left; }\n  .large-text-right {\n    text-align: right; }\n  .large-text-center {\n    text-align: center; }\n  .large-text-justify {\n    text-align: justify; } }\n\n.show-for-print {\n  display: none !important; }\n\n@media print {\n  * {\n    background: transparent !important;\n    box-shadow: none !important;\n    color: black !important;\n    text-shadow: none !important; }\n  .show-for-print {\n    display: block !important; }\n  .hide-for-print {\n    display: none !important; }\n  table.show-for-print {\n    display: table !important; }\n  thead.show-for-print {\n    display: table-header-group !important; }\n  tbody.show-for-print {\n    display: table-row-group !important; }\n  tr.show-for-print {\n    display: table-row !important; }\n  td.show-for-print {\n    display: table-cell !important; }\n  th.show-for-print {\n    display: table-cell !important; }\n  a,\n  a:visited {\n    text-decoration: underline; }\n  a[href]:after {\n    content: \" (\" attr(href) \")\"; }\n  .ir a:after,\n  a[href^='javascript:']:after,\n  a[href^='#']:after {\n    content: ''; }\n  abbr[title]:after {\n    content: \" (\" attr(title) \")\"; }\n  pre,\n  blockquote {\n    border: 1px solid #8a8a8a;\n    page-break-inside: avoid; }\n  thead {\n    display: table-header-group; }\n  tr,\n  img {\n    page-break-inside: avoid; }\n  img {\n    max-width: 100% !important; }\n  @page {\n    margin: 0.5cm; }\n  p,\n  h2,\n  h3 {\n    orphans: 3;\n    widows: 3; }\n  h2,\n  h3 {\n    page-break-after: avoid; }\n  .print-break-inside {\n    page-break-inside: auto; } }\n\n.row {\n  max-width: 75rem;\n  margin-right: auto;\n  margin-left: auto; }\n  .row::before, .row::after {\n    display: table;\n    content: ' '; }\n  .row::after {\n    clear: both; }\n  .row.collapse > .column, .row.collapse > .columns {\n    padding-right: 0;\n    padding-left: 0; }\n  .row .row {\n    margin-right: -0.625rem;\n    margin-left: -0.625rem; }\n    @media print, screen and (min-width: 40em) {\n      .row .row {\n        margin-right: -0.9375rem;\n        margin-left: -0.9375rem; } }\n    @media print, screen and (min-width: 64em) {\n      .row .row {\n        margin-right: -0.9375rem;\n        margin-left: -0.9375rem; } }\n    .row .row.collapse {\n      margin-right: 0;\n      margin-left: 0; }\n  .row.expanded {\n    max-width: none; }\n    .row.expanded .row {\n      margin-right: auto;\n      margin-left: auto; }\n  .row:not(.expanded) .row {\n    max-width: none; }\n  .row.gutter-small > .column, .row.gutter-small > .columns {\n    padding-right: 0.625rem;\n    padding-left: 0.625rem; }\n  .row.gutter-medium > .column, .row.gutter-medium > .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem; }\n\n.column, .columns {\n  width: 100%;\n  float: left;\n  padding-right: 0.625rem;\n  padding-left: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .column, .columns {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n  .column, .columns, .column:last-child:not(:first-child), .columns:last-child:not(:first-child) {\n    float: left;\n    clear: none; }\n  .column:last-child:not(:first-child), .columns:last-child:not(:first-child) {\n    float: right; }\n  .column.end:last-child:last-child, .end.columns:last-child:last-child {\n    float: left; }\n\n.column.row.row, .row.row.columns {\n  float: none; }\n\n.row .column.row.row, .row .row.row.columns {\n  margin-right: 0;\n  margin-left: 0;\n  padding-right: 0;\n  padding-left: 0; }\n\n.small-1 {\n  width: 8.33333%; }\n\n.small-push-1 {\n  position: relative;\n  left: 8.33333%; }\n\n.small-pull-1 {\n  position: relative;\n  left: -8.33333%; }\n\n.small-offset-0 {\n  margin-left: 0%; }\n\n.small-2 {\n  width: 16.66667%; }\n\n.small-push-2 {\n  position: relative;\n  left: 16.66667%; }\n\n.small-pull-2 {\n  position: relative;\n  left: -16.66667%; }\n\n.small-offset-1 {\n  margin-left: 8.33333%; }\n\n.small-3 {\n  width: 25%; }\n\n.small-push-3 {\n  position: relative;\n  left: 25%; }\n\n.small-pull-3 {\n  position: relative;\n  left: -25%; }\n\n.small-offset-2 {\n  margin-left: 16.66667%; }\n\n.small-4 {\n  width: 33.33333%; }\n\n.small-push-4 {\n  position: relative;\n  left: 33.33333%; }\n\n.small-pull-4 {\n  position: relative;\n  left: -33.33333%; }\n\n.small-offset-3 {\n  margin-left: 25%; }\n\n.small-5 {\n  width: 41.66667%; }\n\n.small-push-5 {\n  position: relative;\n  left: 41.66667%; }\n\n.small-pull-5 {\n  position: relative;\n  left: -41.66667%; }\n\n.small-offset-4 {\n  margin-left: 33.33333%; }\n\n.small-6 {\n  width: 50%; }\n\n.small-push-6 {\n  position: relative;\n  left: 50%; }\n\n.small-pull-6 {\n  position: relative;\n  left: -50%; }\n\n.small-offset-5 {\n  margin-left: 41.66667%; }\n\n.small-7 {\n  width: 58.33333%; }\n\n.small-push-7 {\n  position: relative;\n  left: 58.33333%; }\n\n.small-pull-7 {\n  position: relative;\n  left: -58.33333%; }\n\n.small-offset-6 {\n  margin-left: 50%; }\n\n.small-8 {\n  width: 66.66667%; }\n\n.small-push-8 {\n  position: relative;\n  left: 66.66667%; }\n\n.small-pull-8 {\n  position: relative;\n  left: -66.66667%; }\n\n.small-offset-7 {\n  margin-left: 58.33333%; }\n\n.small-9 {\n  width: 75%; }\n\n.small-push-9 {\n  position: relative;\n  left: 75%; }\n\n.small-pull-9 {\n  position: relative;\n  left: -75%; }\n\n.small-offset-8 {\n  margin-left: 66.66667%; }\n\n.small-10 {\n  width: 83.33333%; }\n\n.small-push-10 {\n  position: relative;\n  left: 83.33333%; }\n\n.small-pull-10 {\n  position: relative;\n  left: -83.33333%; }\n\n.small-offset-9 {\n  margin-left: 75%; }\n\n.small-11 {\n  width: 91.66667%; }\n\n.small-push-11 {\n  position: relative;\n  left: 91.66667%; }\n\n.small-pull-11 {\n  position: relative;\n  left: -91.66667%; }\n\n.small-offset-10 {\n  margin-left: 83.33333%; }\n\n.small-12 {\n  width: 100%; }\n\n.small-offset-11 {\n  margin-left: 91.66667%; }\n\n.small-up-1 > .column, .small-up-1 > .columns {\n  float: left;\n  width: 100%; }\n  .small-up-1 > .column:nth-of-type(1n), .small-up-1 > .columns:nth-of-type(1n) {\n    clear: none; }\n  .small-up-1 > .column:nth-of-type(1n+1), .small-up-1 > .columns:nth-of-type(1n+1) {\n    clear: both; }\n  .small-up-1 > .column:last-child, .small-up-1 > .columns:last-child {\n    float: left; }\n\n.small-up-2 > .column, .small-up-2 > .columns {\n  float: left;\n  width: 50%; }\n  .small-up-2 > .column:nth-of-type(1n), .small-up-2 > .columns:nth-of-type(1n) {\n    clear: none; }\n  .small-up-2 > .column:nth-of-type(2n+1), .small-up-2 > .columns:nth-of-type(2n+1) {\n    clear: both; }\n  .small-up-2 > .column:last-child, .small-up-2 > .columns:last-child {\n    float: left; }\n\n.small-up-3 > .column, .small-up-3 > .columns {\n  float: left;\n  width: 33.33333%; }\n  .small-up-3 > .column:nth-of-type(1n), .small-up-3 > .columns:nth-of-type(1n) {\n    clear: none; }\n  .small-up-3 > .column:nth-of-type(3n+1), .small-up-3 > .columns:nth-of-type(3n+1) {\n    clear: both; }\n  .small-up-3 > .column:last-child, .small-up-3 > .columns:last-child {\n    float: left; }\n\n.small-up-4 > .column, .small-up-4 > .columns {\n  float: left;\n  width: 25%; }\n  .small-up-4 > .column:nth-of-type(1n), .small-up-4 > .columns:nth-of-type(1n) {\n    clear: none; }\n  .small-up-4 > .column:nth-of-type(4n+1), .small-up-4 > .columns:nth-of-type(4n+1) {\n    clear: both; }\n  .small-up-4 > .column:last-child, .small-up-4 > .columns:last-child {\n    float: left; }\n\n.small-up-5 > .column, .small-up-5 > .columns {\n  float: left;\n  width: 20%; }\n  .small-up-5 > .column:nth-of-type(1n), .small-up-5 > .columns:nth-of-type(1n) {\n    clear: none; }\n  .small-up-5 > .column:nth-of-type(5n+1), .small-up-5 > .columns:nth-of-type(5n+1) {\n    clear: both; }\n  .small-up-5 > .column:last-child, .small-up-5 > .columns:last-child {\n    float: left; }\n\n.small-up-6 > .column, .small-up-6 > .columns {\n  float: left;\n  width: 16.66667%; }\n  .small-up-6 > .column:nth-of-type(1n), .small-up-6 > .columns:nth-of-type(1n) {\n    clear: none; }\n  .small-up-6 > .column:nth-of-type(6n+1), .small-up-6 > .columns:nth-of-type(6n+1) {\n    clear: both; }\n  .small-up-6 > .column:last-child, .small-up-6 > .columns:last-child {\n    float: left; }\n\n.small-up-7 > .column, .small-up-7 > .columns {\n  float: left;\n  width: 14.28571%; }\n  .small-up-7 > .column:nth-of-type(1n), .small-up-7 > .columns:nth-of-type(1n) {\n    clear: none; }\n  .small-up-7 > .column:nth-of-type(7n+1), .small-up-7 > .columns:nth-of-type(7n+1) {\n    clear: both; }\n  .small-up-7 > .column:last-child, .small-up-7 > .columns:last-child {\n    float: left; }\n\n.small-up-8 > .column, .small-up-8 > .columns {\n  float: left;\n  width: 12.5%; }\n  .small-up-8 > .column:nth-of-type(1n), .small-up-8 > .columns:nth-of-type(1n) {\n    clear: none; }\n  .small-up-8 > .column:nth-of-type(8n+1), .small-up-8 > .columns:nth-of-type(8n+1) {\n    clear: both; }\n  .small-up-8 > .column:last-child, .small-up-8 > .columns:last-child {\n    float: left; }\n\n.small-collapse > .column, .small-collapse > .columns {\n  padding-right: 0;\n  padding-left: 0; }\n\n.small-collapse .row {\n  margin-right: 0;\n  margin-left: 0; }\n\n.expanded.row .small-collapse.row {\n  margin-right: 0;\n  margin-left: 0; }\n\n.small-uncollapse > .column, .small-uncollapse > .columns {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem; }\n\n.small-centered {\n  margin-right: auto;\n  margin-left: auto; }\n  .small-centered, .small-centered:last-child:not(:first-child) {\n    float: none;\n    clear: both; }\n\n.small-uncentered,\n.small-push-0,\n.small-pull-0 {\n  position: static;\n  margin-right: 0;\n  margin-left: 0; }\n  .small-uncentered, .small-uncentered:last-child:not(:first-child),\n  .small-push-0,\n  .small-push-0:last-child:not(:first-child),\n  .small-pull-0,\n  .small-pull-0:last-child:not(:first-child) {\n    float: left;\n    clear: none; }\n  .small-uncentered:last-child:not(:first-child),\n  .small-push-0:last-child:not(:first-child),\n  .small-pull-0:last-child:not(:first-child) {\n    float: right; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-1 {\n    width: 8.33333%; }\n  .medium-push-1 {\n    position: relative;\n    left: 8.33333%; }\n  .medium-pull-1 {\n    position: relative;\n    left: -8.33333%; }\n  .medium-offset-0 {\n    margin-left: 0%; }\n  .medium-2 {\n    width: 16.66667%; }\n  .medium-push-2 {\n    position: relative;\n    left: 16.66667%; }\n  .medium-pull-2 {\n    position: relative;\n    left: -16.66667%; }\n  .medium-offset-1 {\n    margin-left: 8.33333%; }\n  .medium-3 {\n    width: 25%; }\n  .medium-push-3 {\n    position: relative;\n    left: 25%; }\n  .medium-pull-3 {\n    position: relative;\n    left: -25%; }\n  .medium-offset-2 {\n    margin-left: 16.66667%; }\n  .medium-4 {\n    width: 33.33333%; }\n  .medium-push-4 {\n    position: relative;\n    left: 33.33333%; }\n  .medium-pull-4 {\n    position: relative;\n    left: -33.33333%; }\n  .medium-offset-3 {\n    margin-left: 25%; }\n  .medium-5 {\n    width: 41.66667%; }\n  .medium-push-5 {\n    position: relative;\n    left: 41.66667%; }\n  .medium-pull-5 {\n    position: relative;\n    left: -41.66667%; }\n  .medium-offset-4 {\n    margin-left: 33.33333%; }\n  .medium-6 {\n    width: 50%; }\n  .medium-push-6 {\n    position: relative;\n    left: 50%; }\n  .medium-pull-6 {\n    position: relative;\n    left: -50%; }\n  .medium-offset-5 {\n    margin-left: 41.66667%; }\n  .medium-7 {\n    width: 58.33333%; }\n  .medium-push-7 {\n    position: relative;\n    left: 58.33333%; }\n  .medium-pull-7 {\n    position: relative;\n    left: -58.33333%; }\n  .medium-offset-6 {\n    margin-left: 50%; }\n  .medium-8 {\n    width: 66.66667%; }\n  .medium-push-8 {\n    position: relative;\n    left: 66.66667%; }\n  .medium-pull-8 {\n    position: relative;\n    left: -66.66667%; }\n  .medium-offset-7 {\n    margin-left: 58.33333%; }\n  .medium-9 {\n    width: 75%; }\n  .medium-push-9 {\n    position: relative;\n    left: 75%; }\n  .medium-pull-9 {\n    position: relative;\n    left: -75%; }\n  .medium-offset-8 {\n    margin-left: 66.66667%; }\n  .medium-10 {\n    width: 83.33333%; }\n  .medium-push-10 {\n    position: relative;\n    left: 83.33333%; }\n  .medium-pull-10 {\n    position: relative;\n    left: -83.33333%; }\n  .medium-offset-9 {\n    margin-left: 75%; }\n  .medium-11 {\n    width: 91.66667%; }\n  .medium-push-11 {\n    position: relative;\n    left: 91.66667%; }\n  .medium-pull-11 {\n    position: relative;\n    left: -91.66667%; }\n  .medium-offset-10 {\n    margin-left: 83.33333%; }\n  .medium-12 {\n    width: 100%; }\n  .medium-offset-11 {\n    margin-left: 91.66667%; }\n  .medium-up-1 > .column, .medium-up-1 > .columns {\n    float: left;\n    width: 100%; }\n    .medium-up-1 > .column:nth-of-type(1n), .medium-up-1 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .medium-up-1 > .column:nth-of-type(1n+1), .medium-up-1 > .columns:nth-of-type(1n+1) {\n      clear: both; }\n    .medium-up-1 > .column:last-child, .medium-up-1 > .columns:last-child {\n      float: left; }\n  .medium-up-2 > .column, .medium-up-2 > .columns {\n    float: left;\n    width: 50%; }\n    .medium-up-2 > .column:nth-of-type(1n), .medium-up-2 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .medium-up-2 > .column:nth-of-type(2n+1), .medium-up-2 > .columns:nth-of-type(2n+1) {\n      clear: both; }\n    .medium-up-2 > .column:last-child, .medium-up-2 > .columns:last-child {\n      float: left; }\n  .medium-up-3 > .column, .medium-up-3 > .columns {\n    float: left;\n    width: 33.33333%; }\n    .medium-up-3 > .column:nth-of-type(1n), .medium-up-3 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .medium-up-3 > .column:nth-of-type(3n+1), .medium-up-3 > .columns:nth-of-type(3n+1) {\n      clear: both; }\n    .medium-up-3 > .column:last-child, .medium-up-3 > .columns:last-child {\n      float: left; }\n  .medium-up-4 > .column, .medium-up-4 > .columns {\n    float: left;\n    width: 25%; }\n    .medium-up-4 > .column:nth-of-type(1n), .medium-up-4 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .medium-up-4 > .column:nth-of-type(4n+1), .medium-up-4 > .columns:nth-of-type(4n+1) {\n      clear: both; }\n    .medium-up-4 > .column:last-child, .medium-up-4 > .columns:last-child {\n      float: left; }\n  .medium-up-5 > .column, .medium-up-5 > .columns {\n    float: left;\n    width: 20%; }\n    .medium-up-5 > .column:nth-of-type(1n), .medium-up-5 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .medium-up-5 > .column:nth-of-type(5n+1), .medium-up-5 > .columns:nth-of-type(5n+1) {\n      clear: both; }\n    .medium-up-5 > .column:last-child, .medium-up-5 > .columns:last-child {\n      float: left; }\n  .medium-up-6 > .column, .medium-up-6 > .columns {\n    float: left;\n    width: 16.66667%; }\n    .medium-up-6 > .column:nth-of-type(1n), .medium-up-6 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .medium-up-6 > .column:nth-of-type(6n+1), .medium-up-6 > .columns:nth-of-type(6n+1) {\n      clear: both; }\n    .medium-up-6 > .column:last-child, .medium-up-6 > .columns:last-child {\n      float: left; }\n  .medium-up-7 > .column, .medium-up-7 > .columns {\n    float: left;\n    width: 14.28571%; }\n    .medium-up-7 > .column:nth-of-type(1n), .medium-up-7 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .medium-up-7 > .column:nth-of-type(7n+1), .medium-up-7 > .columns:nth-of-type(7n+1) {\n      clear: both; }\n    .medium-up-7 > .column:last-child, .medium-up-7 > .columns:last-child {\n      float: left; }\n  .medium-up-8 > .column, .medium-up-8 > .columns {\n    float: left;\n    width: 12.5%; }\n    .medium-up-8 > .column:nth-of-type(1n), .medium-up-8 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .medium-up-8 > .column:nth-of-type(8n+1), .medium-up-8 > .columns:nth-of-type(8n+1) {\n      clear: both; }\n    .medium-up-8 > .column:last-child, .medium-up-8 > .columns:last-child {\n      float: left; }\n  .medium-collapse > .column, .medium-collapse > .columns {\n    padding-right: 0;\n    padding-left: 0; }\n  .medium-collapse .row {\n    margin-right: 0;\n    margin-left: 0; }\n  .expanded.row .medium-collapse.row {\n    margin-right: 0;\n    margin-left: 0; }\n  .medium-uncollapse > .column, .medium-uncollapse > .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem; }\n  .medium-centered {\n    margin-right: auto;\n    margin-left: auto; }\n    .medium-centered, .medium-centered:last-child:not(:first-child) {\n      float: none;\n      clear: both; }\n  .medium-uncentered,\n  .medium-push-0,\n  .medium-pull-0 {\n    position: static;\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-uncentered, .medium-uncentered:last-child:not(:first-child),\n    .medium-push-0,\n    .medium-push-0:last-child:not(:first-child),\n    .medium-pull-0,\n    .medium-pull-0:last-child:not(:first-child) {\n      float: left;\n      clear: none; }\n    .medium-uncentered:last-child:not(:first-child),\n    .medium-push-0:last-child:not(:first-child),\n    .medium-pull-0:last-child:not(:first-child) {\n      float: right; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-1 {\n    width: 8.33333%; }\n  .large-push-1 {\n    position: relative;\n    left: 8.33333%; }\n  .large-pull-1 {\n    position: relative;\n    left: -8.33333%; }\n  .large-offset-0 {\n    margin-left: 0%; }\n  .large-2 {\n    width: 16.66667%; }\n  .large-push-2 {\n    position: relative;\n    left: 16.66667%; }\n  .large-pull-2 {\n    position: relative;\n    left: -16.66667%; }\n  .large-offset-1 {\n    margin-left: 8.33333%; }\n  .large-3 {\n    width: 25%; }\n  .large-push-3 {\n    position: relative;\n    left: 25%; }\n  .large-pull-3 {\n    position: relative;\n    left: -25%; }\n  .large-offset-2 {\n    margin-left: 16.66667%; }\n  .large-4 {\n    width: 33.33333%; }\n  .large-push-4 {\n    position: relative;\n    left: 33.33333%; }\n  .large-pull-4 {\n    position: relative;\n    left: -33.33333%; }\n  .large-offset-3 {\n    margin-left: 25%; }\n  .large-5 {\n    width: 41.66667%; }\n  .large-push-5 {\n    position: relative;\n    left: 41.66667%; }\n  .large-pull-5 {\n    position: relative;\n    left: -41.66667%; }\n  .large-offset-4 {\n    margin-left: 33.33333%; }\n  .large-6 {\n    width: 50%; }\n  .large-push-6 {\n    position: relative;\n    left: 50%; }\n  .large-pull-6 {\n    position: relative;\n    left: -50%; }\n  .large-offset-5 {\n    margin-left: 41.66667%; }\n  .large-7 {\n    width: 58.33333%; }\n  .large-push-7 {\n    position: relative;\n    left: 58.33333%; }\n  .large-pull-7 {\n    position: relative;\n    left: -58.33333%; }\n  .large-offset-6 {\n    margin-left: 50%; }\n  .large-8 {\n    width: 66.66667%; }\n  .large-push-8 {\n    position: relative;\n    left: 66.66667%; }\n  .large-pull-8 {\n    position: relative;\n    left: -66.66667%; }\n  .large-offset-7 {\n    margin-left: 58.33333%; }\n  .large-9 {\n    width: 75%; }\n  .large-push-9 {\n    position: relative;\n    left: 75%; }\n  .large-pull-9 {\n    position: relative;\n    left: -75%; }\n  .large-offset-8 {\n    margin-left: 66.66667%; }\n  .large-10 {\n    width: 83.33333%; }\n  .large-push-10 {\n    position: relative;\n    left: 83.33333%; }\n  .large-pull-10 {\n    position: relative;\n    left: -83.33333%; }\n  .large-offset-9 {\n    margin-left: 75%; }\n  .large-11 {\n    width: 91.66667%; }\n  .large-push-11 {\n    position: relative;\n    left: 91.66667%; }\n  .large-pull-11 {\n    position: relative;\n    left: -91.66667%; }\n  .large-offset-10 {\n    margin-left: 83.33333%; }\n  .large-12 {\n    width: 100%; }\n  .large-offset-11 {\n    margin-left: 91.66667%; }\n  .large-up-1 > .column, .large-up-1 > .columns {\n    float: left;\n    width: 100%; }\n    .large-up-1 > .column:nth-of-type(1n), .large-up-1 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .large-up-1 > .column:nth-of-type(1n+1), .large-up-1 > .columns:nth-of-type(1n+1) {\n      clear: both; }\n    .large-up-1 > .column:last-child, .large-up-1 > .columns:last-child {\n      float: left; }\n  .large-up-2 > .column, .large-up-2 > .columns {\n    float: left;\n    width: 50%; }\n    .large-up-2 > .column:nth-of-type(1n), .large-up-2 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .large-up-2 > .column:nth-of-type(2n+1), .large-up-2 > .columns:nth-of-type(2n+1) {\n      clear: both; }\n    .large-up-2 > .column:last-child, .large-up-2 > .columns:last-child {\n      float: left; }\n  .large-up-3 > .column, .large-up-3 > .columns {\n    float: left;\n    width: 33.33333%; }\n    .large-up-3 > .column:nth-of-type(1n), .large-up-3 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .large-up-3 > .column:nth-of-type(3n+1), .large-up-3 > .columns:nth-of-type(3n+1) {\n      clear: both; }\n    .large-up-3 > .column:last-child, .large-up-3 > .columns:last-child {\n      float: left; }\n  .large-up-4 > .column, .large-up-4 > .columns {\n    float: left;\n    width: 25%; }\n    .large-up-4 > .column:nth-of-type(1n), .large-up-4 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .large-up-4 > .column:nth-of-type(4n+1), .large-up-4 > .columns:nth-of-type(4n+1) {\n      clear: both; }\n    .large-up-4 > .column:last-child, .large-up-4 > .columns:last-child {\n      float: left; }\n  .large-up-5 > .column, .large-up-5 > .columns {\n    float: left;\n    width: 20%; }\n    .large-up-5 > .column:nth-of-type(1n), .large-up-5 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .large-up-5 > .column:nth-of-type(5n+1), .large-up-5 > .columns:nth-of-type(5n+1) {\n      clear: both; }\n    .large-up-5 > .column:last-child, .large-up-5 > .columns:last-child {\n      float: left; }\n  .large-up-6 > .column, .large-up-6 > .columns {\n    float: left;\n    width: 16.66667%; }\n    .large-up-6 > .column:nth-of-type(1n), .large-up-6 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .large-up-6 > .column:nth-of-type(6n+1), .large-up-6 > .columns:nth-of-type(6n+1) {\n      clear: both; }\n    .large-up-6 > .column:last-child, .large-up-6 > .columns:last-child {\n      float: left; }\n  .large-up-7 > .column, .large-up-7 > .columns {\n    float: left;\n    width: 14.28571%; }\n    .large-up-7 > .column:nth-of-type(1n), .large-up-7 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .large-up-7 > .column:nth-of-type(7n+1), .large-up-7 > .columns:nth-of-type(7n+1) {\n      clear: both; }\n    .large-up-7 > .column:last-child, .large-up-7 > .columns:last-child {\n      float: left; }\n  .large-up-8 > .column, .large-up-8 > .columns {\n    float: left;\n    width: 12.5%; }\n    .large-up-8 > .column:nth-of-type(1n), .large-up-8 > .columns:nth-of-type(1n) {\n      clear: none; }\n    .large-up-8 > .column:nth-of-type(8n+1), .large-up-8 > .columns:nth-of-type(8n+1) {\n      clear: both; }\n    .large-up-8 > .column:last-child, .large-up-8 > .columns:last-child {\n      float: left; }\n  .large-collapse > .column, .large-collapse > .columns {\n    padding-right: 0;\n    padding-left: 0; }\n  .large-collapse .row {\n    margin-right: 0;\n    margin-left: 0; }\n  .expanded.row .large-collapse.row {\n    margin-right: 0;\n    margin-left: 0; }\n  .large-uncollapse > .column, .large-uncollapse > .columns {\n    padding-right: 0.9375rem;\n    padding-left: 0.9375rem; }\n  .large-centered {\n    margin-right: auto;\n    margin-left: auto; }\n    .large-centered, .large-centered:last-child:not(:first-child) {\n      float: none;\n      clear: both; }\n  .large-uncentered,\n  .large-push-0,\n  .large-pull-0 {\n    position: static;\n    margin-right: 0;\n    margin-left: 0; }\n    .large-uncentered, .large-uncentered:last-child:not(:first-child),\n    .large-push-0,\n    .large-push-0:last-child:not(:first-child),\n    .large-pull-0,\n    .large-pull-0:last-child:not(:first-child) {\n      float: left;\n      clear: none; }\n    .large-uncentered:last-child:not(:first-child),\n    .large-push-0:last-child:not(:first-child),\n    .large-pull-0:last-child:not(:first-child) {\n      float: right; } }\n\n.column-block {\n  margin-bottom: 1.25rem; }\n  .column-block > :last-child {\n    margin-bottom: 0; }\n  @media print, screen and (min-width: 40em) {\n    .column-block {\n      margin-bottom: 1.875rem; }\n      .column-block > :last-child {\n        margin-bottom: 0; } }\n\n.button {\n  display: inline-block;\n  vertical-align: middle;\n  margin: 0 0 1rem 0;\n  padding: 0.85em 1em;\n  border: 1px solid transparent;\n  border-radius: 0;\n  transition: background-color 0.25s ease-out, color 0.25s ease-out;\n  font-family: inherit;\n  font-size: 0.9rem;\n  -webkit-appearance: none;\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n  background-color: #1779ba;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .button {\n    outline: 0; }\n  .button:hover, .button:focus {\n    background-color: #14679e;\n    color: #fefefe; }\n  .button.tiny {\n    font-size: 0.6rem; }\n  .button.small {\n    font-size: 0.75rem; }\n  .button.large {\n    font-size: 1.25rem; }\n  .button.expanded {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0; }\n  .button.primary {\n    background-color: #1779ba;\n    color: #fefefe; }\n    .button.primary:hover, .button.primary:focus {\n      background-color: #126195;\n      color: #fefefe; }\n  .button.secondary {\n    background-color: #767676;\n    color: #fefefe; }\n    .button.secondary:hover, .button.secondary:focus {\n      background-color: #5e5e5e;\n      color: #fefefe; }\n  .button.success {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n    .button.success:hover, .button.success:focus {\n      background-color: #22bb5b;\n      color: #0a0a0a; }\n  .button.warning {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n    .button.warning:hover, .button.warning:focus {\n      background-color: #cc8b00;\n      color: #0a0a0a; }\n  .button.alert {\n    background-color: #cc4b37;\n    color: #fefefe; }\n    .button.alert:hover, .button.alert:focus {\n      background-color: #a53b2a;\n      color: #fefefe; }\n  .button.disabled, .button[disabled] {\n    opacity: 0.25;\n    cursor: not-allowed; }\n    .button.disabled, .button.disabled:hover, .button.disabled:focus, .button[disabled], .button[disabled]:hover, .button[disabled]:focus {\n      background-color: #1779ba;\n      color: #fefefe; }\n    .button.disabled.primary, .button[disabled].primary {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.primary, .button.disabled.primary:hover, .button.disabled.primary:focus, .button[disabled].primary, .button[disabled].primary:hover, .button[disabled].primary:focus {\n        background-color: #1779ba;\n        color: #fefefe; }\n    .button.disabled.secondary, .button[disabled].secondary {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.secondary, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary, .button[disabled].secondary:hover, .button[disabled].secondary:focus {\n        background-color: #767676;\n        color: #fefefe; }\n    .button.disabled.success, .button[disabled].success {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.success, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success, .button[disabled].success:hover, .button[disabled].success:focus {\n        background-color: #3adb76;\n        color: #0a0a0a; }\n    .button.disabled.warning, .button[disabled].warning {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.warning, .button.disabled.warning:hover, .button.disabled.warning:focus, .button[disabled].warning, .button[disabled].warning:hover, .button[disabled].warning:focus {\n        background-color: #ffae00;\n        color: #0a0a0a; }\n    .button.disabled.alert, .button[disabled].alert {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.alert, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert, .button[disabled].alert:hover, .button[disabled].alert:focus {\n        background-color: #cc4b37;\n        color: #fefefe; }\n  .button.hollow {\n    border: 1px solid #1779ba;\n    color: #1779ba; }\n    .button.hollow, .button.hollow:hover, .button.hollow:focus {\n      background-color: transparent; }\n    .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {\n      background-color: transparent; }\n    .button.hollow:hover, .button.hollow:focus {\n      border-color: #0c3d5d;\n      color: #0c3d5d; }\n      .button.hollow:hover.disabled, .button.hollow:hover[disabled], .button.hollow:focus.disabled, .button.hollow:focus[disabled] {\n        border: 1px solid #1779ba;\n        color: #1779ba; }\n    .button.hollow.primary {\n      border: 1px solid #1779ba;\n      color: #1779ba; }\n      .button.hollow.primary:hover, .button.hollow.primary:focus {\n        border-color: #0c3d5d;\n        color: #0c3d5d; }\n        .button.hollow.primary:hover.disabled, .button.hollow.primary:hover[disabled], .button.hollow.primary:focus.disabled, .button.hollow.primary:focus[disabled] {\n          border: 1px solid #1779ba;\n          color: #1779ba; }\n    .button.hollow.secondary {\n      border: 1px solid #767676;\n      color: #767676; }\n      .button.hollow.secondary:hover, .button.hollow.secondary:focus {\n        border-color: #3b3b3b;\n        color: #3b3b3b; }\n        .button.hollow.secondary:hover.disabled, .button.hollow.secondary:hover[disabled], .button.hollow.secondary:focus.disabled, .button.hollow.secondary:focus[disabled] {\n          border: 1px solid #767676;\n          color: #767676; }\n    .button.hollow.success {\n      border: 1px solid #3adb76;\n      color: #3adb76; }\n      .button.hollow.success:hover, .button.hollow.success:focus {\n        border-color: #157539;\n        color: #157539; }\n        .button.hollow.success:hover.disabled, .button.hollow.success:hover[disabled], .button.hollow.success:focus.disabled, .button.hollow.success:focus[disabled] {\n          border: 1px solid #3adb76;\n          color: #3adb76; }\n    .button.hollow.warning {\n      border: 1px solid #ffae00;\n      color: #ffae00; }\n      .button.hollow.warning:hover, .button.hollow.warning:focus {\n        border-color: #805700;\n        color: #805700; }\n        .button.hollow.warning:hover.disabled, .button.hollow.warning:hover[disabled], .button.hollow.warning:focus.disabled, .button.hollow.warning:focus[disabled] {\n          border: 1px solid #ffae00;\n          color: #ffae00; }\n    .button.hollow.alert {\n      border: 1px solid #cc4b37;\n      color: #cc4b37; }\n      .button.hollow.alert:hover, .button.hollow.alert:focus {\n        border-color: #67251a;\n        color: #67251a; }\n        .button.hollow.alert:hover.disabled, .button.hollow.alert:hover[disabled], .button.hollow.alert:focus.disabled, .button.hollow.alert:focus[disabled] {\n          border: 1px solid #cc4b37;\n          color: #cc4b37; }\n  .button.clear {\n    border: 1px solid #1779ba;\n    color: #1779ba; }\n    .button.clear, .button.clear:hover, .button.clear:focus {\n      background-color: transparent; }\n    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {\n      background-color: transparent; }\n    .button.clear:hover, .button.clear:focus {\n      border-color: #0c3d5d;\n      color: #0c3d5d; }\n      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {\n        border: 1px solid #1779ba;\n        color: #1779ba; }\n    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {\n      border-color: transparent; }\n    .button.clear.primary {\n      border: 1px solid #1779ba;\n      color: #1779ba; }\n      .button.clear.primary:hover, .button.clear.primary:focus {\n        border-color: #0c3d5d;\n        color: #0c3d5d; }\n        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {\n          border: 1px solid #1779ba;\n          color: #1779ba; }\n      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.secondary {\n      border: 1px solid #767676;\n      color: #767676; }\n      .button.clear.secondary:hover, .button.clear.secondary:focus {\n        border-color: #3b3b3b;\n        color: #3b3b3b; }\n        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {\n          border: 1px solid #767676;\n          color: #767676; }\n      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.success {\n      border: 1px solid #3adb76;\n      color: #3adb76; }\n      .button.clear.success:hover, .button.clear.success:focus {\n        border-color: #157539;\n        color: #157539; }\n        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {\n          border: 1px solid #3adb76;\n          color: #3adb76; }\n      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.warning {\n      border: 1px solid #ffae00;\n      color: #ffae00; }\n      .button.clear.warning:hover, .button.clear.warning:focus {\n        border-color: #805700;\n        color: #805700; }\n        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {\n          border: 1px solid #ffae00;\n          color: #ffae00; }\n      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.alert {\n      border: 1px solid #cc4b37;\n      color: #cc4b37; }\n      .button.clear.alert:hover, .button.clear.alert:focus {\n        border-color: #67251a;\n        color: #67251a; }\n        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {\n          border: 1px solid #cc4b37;\n          color: #cc4b37; }\n      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {\n        border-color: transparent; }\n  .button.dropdown::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.4em;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #fefefe transparent transparent;\n    position: relative;\n    top: 0.4em;\n    display: inline-block;\n    float: right;\n    margin-left: 1em; }\n  .button.dropdown.hollow::after, .button.dropdown.clear::after {\n    border-top-color: #1779ba; }\n  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {\n    border-top-color: #1779ba; }\n  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {\n    border-top-color: #767676; }\n  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {\n    border-top-color: #3adb76; }\n  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {\n    border-top-color: #ffae00; }\n  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {\n    border-top-color: #cc4b37; }\n  .button.arrow-only::after {\n    top: -0.1em;\n    float: none;\n    margin-left: 0; }\n\na.button:hover, a.button:focus {\n  text-decoration: none; }\n\n.button-group {\n  margin-bottom: 1rem;\n  font-size: 0; }\n  .button-group::before, .button-group::after {\n    display: table;\n    content: ' '; }\n  .button-group::after {\n    clear: both; }\n  .button-group .button {\n    margin: 0;\n    margin-right: 1px;\n    margin-bottom: 1px;\n    font-size: 0.9rem; }\n    .button-group .button:last-child {\n      margin-right: 0; }\n  .button-group.tiny .button {\n    font-size: 0.6rem; }\n  .button-group.small .button {\n    font-size: 0.75rem; }\n  .button-group.large .button {\n    font-size: 1.25rem; }\n  .button-group.expanded {\n    margin-right: -1px; }\n    .button-group.expanded::before, .button-group.expanded::after {\n      display: none; }\n    .button-group.expanded .button:first-child:last-child {\n      width: calc(100% - 1px); }\n    .button-group.expanded .button:first-child:nth-last-child(2), .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button {\n      display: inline-block;\n      width: calc(50% - 1px);\n      margin-right: 1px; }\n      .button-group.expanded .button:first-child:nth-last-child(2):last-child, .button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child {\n        margin-right: -6px; }\n    .button-group.expanded .button:first-child:nth-last-child(3), .button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button {\n      display: inline-block;\n      width: calc(33.33333% - 1px);\n      margin-right: 1px; }\n      .button-group.expanded .button:first-child:nth-last-child(3):last-child, .button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child {\n        margin-right: -6px; }\n    .button-group.expanded .button:first-child:nth-last-child(4), .button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button {\n      display: inline-block;\n      width: calc(25% - 1px);\n      margin-right: 1px; }\n      .button-group.expanded .button:first-child:nth-last-child(4):last-child, .button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child {\n        margin-right: -6px; }\n    .button-group.expanded .button:first-child:nth-last-child(5), .button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button {\n      display: inline-block;\n      width: calc(20% - 1px);\n      margin-right: 1px; }\n      .button-group.expanded .button:first-child:nth-last-child(5):last-child, .button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child {\n        margin-right: -6px; }\n    .button-group.expanded .button:first-child:nth-last-child(6), .button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button {\n      display: inline-block;\n      width: calc(16.66667% - 1px);\n      margin-right: 1px; }\n      .button-group.expanded .button:first-child:nth-last-child(6):last-child, .button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child {\n        margin-right: -6px; }\n  .button-group.primary .button {\n    background-color: #1779ba;\n    color: #fefefe; }\n    .button-group.primary .button:hover, .button-group.primary .button:focus {\n      background-color: #126195;\n      color: #fefefe; }\n  .button-group.secondary .button {\n    background-color: #767676;\n    color: #fefefe; }\n    .button-group.secondary .button:hover, .button-group.secondary .button:focus {\n      background-color: #5e5e5e;\n      color: #fefefe; }\n  .button-group.success .button {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n    .button-group.success .button:hover, .button-group.success .button:focus {\n      background-color: #22bb5b;\n      color: #0a0a0a; }\n  .button-group.warning .button {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n    .button-group.warning .button:hover, .button-group.warning .button:focus {\n      background-color: #cc8b00;\n      color: #0a0a0a; }\n  .button-group.alert .button {\n    background-color: #cc4b37;\n    color: #fefefe; }\n    .button-group.alert .button:hover, .button-group.alert .button:focus {\n      background-color: #a53b2a;\n      color: #fefefe; }\n  .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {\n    width: 100%; }\n    .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {\n      margin-bottom: 0; }\n  .button-group.stacked.expanded, .button-group.stacked-for-small.expanded, .button-group.stacked-for-medium.expanded {\n    margin-right: -1px; }\n    .button-group.stacked.expanded::before, .button-group.stacked.expanded::after, .button-group.stacked-for-small.expanded::before, .button-group.stacked-for-small.expanded::after, .button-group.stacked-for-medium.expanded::before, .button-group.stacked-for-medium.expanded::after {\n      display: none; }\n    .button-group.stacked.expanded .button:first-child:last-child, .button-group.stacked-for-small.expanded .button:first-child:last-child, .button-group.stacked-for-medium.expanded .button:first-child:last-child {\n      width: calc(100% - 1px); }\n    .button-group.stacked.expanded .button:first-child:nth-last-child(2), .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button {\n      display: inline-block;\n      width: calc(50% - 1px);\n      margin-right: 1px; }\n      .button-group.stacked.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2) ~ .button:last-child {\n        margin-right: -6px; }\n    .button-group.stacked.expanded .button:first-child:nth-last-child(3), .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button {\n      display: inline-block;\n      width: calc(33.33333% - 1px);\n      margin-right: 1px; }\n      .button-group.stacked.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3) ~ .button:last-child {\n        margin-right: -6px; }\n    .button-group.stacked.expanded .button:first-child:nth-last-child(4), .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button {\n      display: inline-block;\n      width: calc(25% - 1px);\n      margin-right: 1px; }\n      .button-group.stacked.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4) ~ .button:last-child {\n        margin-right: -6px; }\n    .button-group.stacked.expanded .button:first-child:nth-last-child(5), .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button {\n      display: inline-block;\n      width: calc(20% - 1px);\n      margin-right: 1px; }\n      .button-group.stacked.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5) ~ .button:last-child {\n        margin-right: -6px; }\n    .button-group.stacked.expanded .button:first-child:nth-last-child(6), .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6), .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button {\n      display: inline-block;\n      width: calc(16.66667% - 1px);\n      margin-right: 1px; }\n      .button-group.stacked.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):last-child, .button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6) ~ .button:last-child {\n        margin-right: -6px; }\n  @media print, screen and (min-width: 40em) {\n    .button-group.stacked-for-small .button {\n      width: auto;\n      margin-bottom: 0; } }\n  @media print, screen and (min-width: 64em) {\n    .button-group.stacked-for-medium .button {\n      width: auto;\n      margin-bottom: 0; } }\n  @media screen and (max-width: 39.99875em) {\n    .button-group.stacked-for-small.expanded {\n      display: block; }\n      .button-group.stacked-for-small.expanded .button {\n        display: block;\n        margin-right: 0; } }\n  @media screen and (max-width: 63.99875em) {\n    .button-group.stacked-for-medium.expanded {\n      display: block; }\n      .button-group.stacked-for-medium.expanded .button {\n        display: block;\n        margin-right: 0; } }\n\n.close-button {\n  position: absolute;\n  color: #8a8a8a;\n  cursor: pointer; }\n  [data-whatinput='mouse'] .close-button {\n    outline: 0; }\n  .close-button:hover, .close-button:focus {\n    color: #0a0a0a; }\n  .close-button.small {\n    right: 0.66rem;\n    top: 0.33em;\n    font-size: 1.5em;\n    line-height: 1; }\n  .close-button, .close-button.medium {\n    right: 1rem;\n    top: 0.5rem;\n    font-size: 2em;\n    line-height: 1; }\n\n.label {\n  display: inline-block;\n  padding: 0.33333rem 0.5rem;\n  border-radius: 0;\n  font-size: 0.8rem;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n  background: #1779ba;\n  color: #fefefe; }\n  .label.primary {\n    background: #1779ba;\n    color: #fefefe; }\n  .label.secondary {\n    background: #767676;\n    color: #fefefe; }\n  .label.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .label.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .label.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.progress {\n  height: 1rem;\n  margin-bottom: 1rem;\n  border-radius: 0;\n  background-color: #cacaca; }\n  .progress.primary .progress-meter {\n    background-color: #1779ba; }\n  .progress.secondary .progress-meter {\n    background-color: #767676; }\n  .progress.success .progress-meter {\n    background-color: #3adb76; }\n  .progress.warning .progress-meter {\n    background-color: #ffae00; }\n  .progress.alert .progress-meter {\n    background-color: #cc4b37; }\n\n.progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: #1779ba; }\n\n.progress-meter-text {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #fefefe;\n  white-space: nowrap; }\n\n.slider {\n  position: relative;\n  height: 0.5rem;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n  background-color: #e6e6e6;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none; }\n\n.slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: inline-block;\n  max-width: 100%;\n  height: 0.5rem;\n  background-color: #cacaca;\n  transition: all 0.2s ease-in-out; }\n  .slider-fill.is-dragging {\n    transition: all 0s linear; }\n\n.slider-handle {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  left: 0;\n  z-index: 1;\n  display: inline-block;\n  width: 1.4rem;\n  height: 1.4rem;\n  border-radius: 0;\n  background-color: #1779ba;\n  transition: all 0.2s ease-in-out;\n  touch-action: manipulation; }\n  [data-whatinput='mouse'] .slider-handle {\n    outline: 0; }\n  .slider-handle:hover {\n    background-color: #14679e; }\n  .slider-handle.is-dragging {\n    transition: all 0s linear; }\n\n.slider.disabled,\n.slider[disabled] {\n  opacity: 0.25;\n  cursor: not-allowed; }\n\n.slider.vertical {\n  display: inline-block;\n  width: 0.5rem;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1); }\n  .slider.vertical .slider-fill {\n    top: 0;\n    width: 0.5rem;\n    max-height: 100%; }\n  .slider.vertical .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: 1.4rem;\n    height: 1.4rem;\n    transform: translateX(-50%); }\n\n.switch {\n  height: 2rem;\n  position: relative;\n  margin-bottom: 1rem;\n  outline: 0;\n  font-size: 0.875rem;\n  font-weight: bold;\n  color: #fefefe;\n  user-select: none; }\n\n.switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0; }\n\n.switch-paddle {\n  position: relative;\n  display: block;\n  width: 4rem;\n  height: 2rem;\n  border-radius: 0;\n  background: #cacaca;\n  transition: all 0.25s ease-out;\n  font-weight: inherit;\n  color: inherit;\n  cursor: pointer; }\n  input + .switch-paddle {\n    margin: 0; }\n  .switch-paddle::after {\n    position: absolute;\n    top: 0.25rem;\n    left: 0.25rem;\n    display: block;\n    width: 1.5rem;\n    height: 1.5rem;\n    transform: translate3d(0, 0, 0);\n    border-radius: 0;\n    background: #fefefe;\n    transition: all 0.25s ease-out;\n    content: ''; }\n  input:checked ~ .switch-paddle {\n    background: #1779ba; }\n    input:checked ~ .switch-paddle::after {\n      left: 2.25rem; }\n  [data-whatinput='mouse'] input:focus ~ .switch-paddle {\n    outline: 0; }\n\n.switch-active, .switch-inactive {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%); }\n\n.switch-active {\n  left: 8%;\n  display: none; }\n  input:checked + label > .switch-active {\n    display: block; }\n\n.switch-inactive {\n  right: 15%; }\n  input:checked + label > .switch-inactive {\n    display: none; }\n\n.switch.tiny {\n  height: 1.5rem; }\n  .switch.tiny .switch-paddle {\n    width: 3rem;\n    height: 1.5rem;\n    font-size: 0.625rem; }\n  .switch.tiny .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 1rem;\n    height: 1rem; }\n  .switch.tiny input:checked ~ .switch-paddle::after {\n    left: 1.75rem; }\n\n.switch.small {\n  height: 1.75rem; }\n  .switch.small .switch-paddle {\n    width: 3.5rem;\n    height: 1.75rem;\n    font-size: 0.75rem; }\n  .switch.small .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 1.25rem;\n    height: 1.25rem; }\n  .switch.small input:checked ~ .switch-paddle::after {\n    left: 2rem; }\n\n.switch.large {\n  height: 2.5rem; }\n  .switch.large .switch-paddle {\n    width: 5rem;\n    height: 2.5rem;\n    font-size: 1rem; }\n  .switch.large .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 2rem;\n    height: 2rem; }\n  .switch.large input:checked ~ .switch-paddle::after {\n    left: 2.75rem; }\n\ntable {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: 1rem;\n  border-radius: 0; }\n  thead,\n  tbody,\n  tfoot {\n    border: 1px solid #f1f1f1;\n    background-color: #fefefe; }\n  caption {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold; }\n  thead {\n    background: #f8f8f8;\n    color: #0a0a0a; }\n  tfoot {\n    background: #f1f1f1;\n    color: #0a0a0a; }\n  thead tr,\n  tfoot tr {\n    background: transparent; }\n  thead th,\n  thead td,\n  tfoot th,\n  tfoot td {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold;\n    text-align: left; }\n  tbody th,\n  tbody td {\n    padding: 0.5rem 0.625rem 0.625rem; }\n  tbody tr:nth-child(even) {\n    border-bottom: 0;\n    background-color: #f1f1f1; }\n  table.unstriped tbody {\n    background-color: #fefefe; }\n    table.unstriped tbody tr {\n      border-bottom: 0;\n      border-bottom: 1px solid #f1f1f1;\n      background-color: #fefefe; }\n\n@media screen and (max-width: 63.99875em) {\n  table.stack thead {\n    display: none; }\n  table.stack tfoot {\n    display: none; }\n  table.stack tr,\n  table.stack th,\n  table.stack td {\n    display: block; }\n  table.stack td {\n    border-top: 0; } }\n\ntable.scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto; }\n\ntable.hover thead tr:hover {\n  background-color: #f3f3f3; }\n\ntable.hover tfoot tr:hover {\n  background-color: #ececec; }\n\ntable.hover tbody tr:hover {\n  background-color: #f9f9f9; }\n\ntable.hover:not(.unstriped) tr:nth-of-type(even):hover {\n  background-color: #ececec; }\n\n.table-scroll {\n  overflow-x: auto; }\n\n.badge {\n  display: inline-block;\n  min-width: 2.1em;\n  padding: 0.3em;\n  border-radius: 50%;\n  font-size: 0.6rem;\n  text-align: center;\n  background: #1779ba;\n  color: #fefefe; }\n  .badge.primary {\n    background: #1779ba;\n    color: #fefefe; }\n  .badge.secondary {\n    background: #767676;\n    color: #fefefe; }\n  .badge.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .badge.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .badge.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.breadcrumbs {\n  margin: 0 0 1rem 0;\n  list-style: none; }\n  .breadcrumbs::before, .breadcrumbs::after {\n    display: table;\n    content: ' '; }\n  .breadcrumbs::after {\n    clear: both; }\n  .breadcrumbs li {\n    float: left;\n    font-size: 0.6875rem;\n    color: #0a0a0a;\n    cursor: default;\n    text-transform: uppercase; }\n    .breadcrumbs li:not(:last-child)::after {\n      position: relative;\n      margin: 0 0.75rem;\n      opacity: 1;\n      content: \"/\";\n      color: #cacaca; }\n  .breadcrumbs a {\n    color: #1779ba; }\n    .breadcrumbs a:hover {\n      text-decoration: underline; }\n  .breadcrumbs .disabled {\n    color: #cacaca;\n    cursor: not-allowed; }\n\n.callout {\n  position: relative;\n  margin: 0 0 1rem 0;\n  padding: 1rem;\n  border: 1px solid rgba(10, 10, 10, 0.25);\n  border-radius: 0;\n  background-color: white;\n  color: #0a0a0a; }\n  .callout > :first-child {\n    margin-top: 0; }\n  .callout > :last-child {\n    margin-bottom: 0; }\n  .callout.primary {\n    background-color: #d7ecfa;\n    color: #0a0a0a; }\n  .callout.secondary {\n    background-color: #eaeaea;\n    color: #0a0a0a; }\n  .callout.success {\n    background-color: #e1faea;\n    color: #0a0a0a; }\n  .callout.warning {\n    background-color: #fff3d9;\n    color: #0a0a0a; }\n  .callout.alert {\n    background-color: #f7e4e1;\n    color: #0a0a0a; }\n  .callout.small {\n    padding-top: 0.5rem;\n    padding-right: 0.5rem;\n    padding-bottom: 0.5rem;\n    padding-left: 0.5rem; }\n  .callout.large {\n    padding-top: 3rem;\n    padding-right: 3rem;\n    padding-bottom: 3rem;\n    padding-left: 3rem; }\n\n.card {\n  margin-bottom: 1rem;\n  border: 1px solid #e6e6e6;\n  border-radius: 0;\n  background: #fefefe;\n  box-shadow: none;\n  overflow: hidden;\n  color: #0a0a0a; }\n  .card > :last-child {\n    margin-bottom: 0; }\n\n.card-divider {\n  padding: 1rem;\n  background: #e6e6e6; }\n  .card-divider > :last-child {\n    margin-bottom: 0; }\n\n.card-section {\n  padding: 1rem; }\n  .card-section > :last-child {\n    margin-bottom: 0; }\n\n.card-image {\n  min-height: 1px; }\n\n.dropdown-pane {\n  position: absolute;\n  z-index: 10;\n  display: none;\n  width: 300px;\n  padding: 1rem;\n  visibility: hidden;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-size: 1rem; }\n  .dropdown-pane.is-opening {\n    display: block; }\n  .dropdown-pane.is-open {\n    display: block;\n    visibility: visible; }\n\n.dropdown-pane.tiny {\n  width: 100px; }\n\n.dropdown-pane.small {\n  width: 200px; }\n\n.dropdown-pane.large {\n  width: 400px; }\n\n.pagination {\n  margin-left: 0;\n  margin-bottom: 1rem; }\n  .pagination::before, .pagination::after {\n    display: table;\n    content: ' '; }\n  .pagination::after {\n    clear: both; }\n  .pagination li {\n    margin-right: 0.0625rem;\n    border-radius: 0;\n    font-size: 0.875rem;\n    display: none; }\n    .pagination li:last-child, .pagination li:first-child {\n      display: inline-block; }\n    @media print, screen and (min-width: 40em) {\n      .pagination li {\n        display: inline-block; } }\n  .pagination a,\n  .pagination button {\n    display: block;\n    padding: 0.1875rem 0.625rem;\n    border-radius: 0;\n    color: #0a0a0a; }\n    .pagination a:hover,\n    .pagination button:hover {\n      background: #e6e6e6; }\n  .pagination .current {\n    padding: 0.1875rem 0.625rem;\n    background: #1779ba;\n    color: #fefefe;\n    cursor: default; }\n  .pagination .disabled {\n    padding: 0.1875rem 0.625rem;\n    color: #cacaca;\n    cursor: not-allowed; }\n    .pagination .disabled:hover {\n      background: transparent; }\n  .pagination .ellipsis::after {\n    padding: 0.1875rem 0.625rem;\n    content: '\\2026';\n    color: #0a0a0a; }\n\n.pagination-previous a::before,\n.pagination-previous.disabled::before {\n  display: inline-block;\n  margin-right: 0.5rem;\n  content: '\\00ab'; }\n\n.pagination-next a::after,\n.pagination-next.disabled::after {\n  display: inline-block;\n  margin-left: 0.5rem;\n  content: '\\00bb'; }\n\n.has-tip {\n  position: relative;\n  display: inline-block;\n  border-bottom: dotted 1px #8a8a8a;\n  font-weight: bold;\n  cursor: help; }\n\n.tooltip {\n  position: absolute;\n  top: calc(100% + 0.6495rem);\n  z-index: 1200;\n  max-width: 10rem;\n  padding: 0.75rem;\n  border-radius: 0;\n  background-color: #0a0a0a;\n  font-size: 80%;\n  color: #fefefe; }\n  .tooltip::before {\n    position: absolute; }\n  .tooltip.bottom::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent #0a0a0a;\n    bottom: 100%; }\n  .tooltip.bottom.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.top::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #0a0a0a transparent transparent;\n    top: 100%;\n    bottom: auto; }\n  .tooltip.top.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.left::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #0a0a0a;\n    left: 100%; }\n  .tooltip.left.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.right::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #0a0a0a transparent transparent;\n    right: 100%;\n    left: auto; }\n  .tooltip.right.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.align-top::before {\n    bottom: auto;\n    top: 10%; }\n  .tooltip.align-bottom::before {\n    bottom: 10%;\n    top: auto; }\n  .tooltip.align-left::before {\n    left: 10%;\n    right: auto; }\n  .tooltip.align-right::before {\n    left: auto;\n    right: 10%; }\n\n.accordion {\n  margin-left: 0;\n  background: #fefefe;\n  list-style-type: none; }\n  .accordion[disabled] .accordion-title {\n    cursor: not-allowed; }\n\n.accordion-item:first-child > :first-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-item:last-child > :last-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-title {\n  position: relative;\n  display: block;\n  padding: 1.25rem 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  font-size: 0.75rem;\n  line-height: 1;\n  color: #1779ba; }\n  :last-child:not(.is-active) > .accordion-title {\n    border-bottom: 1px solid #e6e6e6;\n    border-radius: 0 0 0 0; }\n  .accordion-title:hover, .accordion-title:focus {\n    background-color: #e6e6e6; }\n  .accordion-title::before {\n    position: absolute;\n    top: 50%;\n    right: 1rem;\n    margin-top: -0.5rem;\n    content: '+'; }\n  .is-active > .accordion-title::before {\n    content: '\\2013'; }\n\n.accordion-content {\n  display: none;\n  padding: 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  background-color: #fefefe;\n  color: #0a0a0a; }\n  :last-child > .accordion-content:last-child {\n    border-bottom: 1px solid #e6e6e6; }\n\n.media-object {\n  display: block;\n  margin-bottom: 1rem; }\n  .media-object img {\n    max-width: none; }\n\n.media-object-section {\n  display: table-cell;\n  vertical-align: top; }\n  .media-object-section:first-child {\n    padding-right: 1rem; }\n  .media-object-section:last-child:not(:nth-child(2)) {\n    padding-left: 1rem; }\n  .media-object-section > :last-child {\n    margin-bottom: 0; }\n  @media screen and (max-width: 39.99875em) {\n    .stack-for-small .media-object-section {\n      padding: 0;\n      padding-bottom: 1rem;\n      display: block; }\n      .stack-for-small .media-object-section img {\n        width: 100%; } }\n  .media-object-section.middle {\n    vertical-align: middle; }\n  .media-object-section.bottom {\n    vertical-align: bottom; }\n\n.orbit {\n  position: relative; }\n\n.orbit-container {\n  position: relative;\n  height: 0;\n  margin: 0;\n  list-style: none;\n  overflow: hidden; }\n\n.orbit-slide {\n  width: 100%;\n  position: absolute; }\n  .orbit-slide.no-motionui.is-active {\n    top: 0;\n    left: 0; }\n\n.orbit-figure {\n  margin: 0; }\n\n.orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0; }\n\n.orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: 1rem;\n  background-color: rgba(10, 10, 10, 0.5);\n  color: #fefefe; }\n\n.orbit-previous, .orbit-next {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  z-index: 10;\n  padding: 1rem;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {\n    outline: 0; }\n  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {\n    background-color: rgba(10, 10, 10, 0.5); }\n\n.orbit-previous {\n  left: 0; }\n\n.orbit-next {\n  left: auto;\n  right: 0; }\n\n.orbit-bullets {\n  position: relative;\n  margin-top: 0.8rem;\n  margin-bottom: 0.8rem;\n  text-align: center; }\n  [data-whatinput='mouse'] .orbit-bullets {\n    outline: 0; }\n  .orbit-bullets button {\n    width: 1.2rem;\n    height: 1.2rem;\n    margin: 0.1rem;\n    border-radius: 50%;\n    background-color: #cacaca; }\n    .orbit-bullets button:hover {\n      background-color: #8a8a8a; }\n    .orbit-bullets button.is-active {\n      background-color: #8a8a8a; }\n\n.responsive-embed,\n.flex-video {\n  position: relative;\n  height: 0;\n  margin-bottom: 1rem;\n  padding-bottom: 75%;\n  overflow: hidden; }\n  .responsive-embed iframe,\n  .responsive-embed object,\n  .responsive-embed embed,\n  .responsive-embed video,\n  .flex-video iframe,\n  .flex-video object,\n  .flex-video embed,\n  .flex-video video {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%; }\n  .responsive-embed.widescreen,\n  .flex-video.widescreen {\n    padding-bottom: 56.25%; }\n\n.tabs {\n  margin: 0;\n  border: 1px solid #e6e6e6;\n  background: #fefefe;\n  list-style-type: none; }\n  .tabs::before, .tabs::after {\n    display: table;\n    content: ' '; }\n  .tabs::after {\n    clear: both; }\n\n.tabs.vertical > li {\n  display: block;\n  float: none;\n  width: auto; }\n\n.tabs.simple > li > a {\n  padding: 0; }\n  .tabs.simple > li > a:hover {\n    background: transparent; }\n\n.tabs.primary {\n  background: #1779ba; }\n  .tabs.primary > li > a {\n    color: #fefefe; }\n    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {\n      background: #1673b1; }\n\n.tabs-title {\n  float: left; }\n  .tabs-title > a {\n    display: block;\n    padding: 1.25rem 1.5rem;\n    font-size: 0.75rem;\n    line-height: 1;\n    color: #1779ba; }\n    [data-whatinput='mouse'] .tabs-title > a {\n      outline: 0; }\n    .tabs-title > a:hover {\n      background: #fefefe;\n      color: #1468a0; }\n    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {\n      background: #e6e6e6;\n      color: #1779ba; }\n\n.tabs-content {\n  border: 1px solid #e6e6e6;\n  border-top: 0;\n  background: #fefefe;\n  color: #0a0a0a;\n  transition: all 0.5s ease; }\n\n.tabs-content.vertical {\n  border: 1px solid #e6e6e6;\n  border-left: 0; }\n\n.tabs-panel {\n  display: none;\n  padding: 1rem; }\n  .tabs-panel.is-active {\n    display: block; }\n\n.thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: 1rem;\n  border: 4px solid #fefefe;\n  border-radius: 0;\n  box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);\n  line-height: 0; }\n\na.thumbnail {\n  transition: box-shadow 200ms ease-out; }\n  a.thumbnail:hover, a.thumbnail:focus {\n    box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }\n  a.thumbnail image {\n    box-shadow: none; }\n\n.menu {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative; }\n  [data-whatinput='mouse'] .menu li {\n    outline: 0; }\n  .menu a,\n  .menu .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: 0.7rem 1rem; }\n  .menu input,\n  .menu select,\n  .menu a,\n  .menu button {\n    margin-bottom: 0; }\n  .menu input {\n    display: inline-block; }\n  .menu li, .menu.horizontal li {\n    display: inline-block; }\n  .menu.vertical li {\n    display: block; }\n  .menu.expanded {\n    display: table;\n    width: 100%; }\n    .menu.expanded > li {\n      display: table-cell;\n      vertical-align: middle; }\n  .menu.simple li + li {\n    margin-left: 1rem; }\n  .menu.simple a {\n    padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .menu.medium-horizontal li {\n      display: inline-block; }\n    .menu.medium-vertical li {\n      display: block; }\n    .menu.medium-expanded {\n      display: table;\n      width: 100%; }\n      .menu.medium-expanded > li {\n        display: table-cell;\n        vertical-align: middle; }\n    .menu.medium-simple {\n      display: table;\n      width: 100%; }\n      .menu.medium-simple > li {\n        display: table-cell;\n        vertical-align: middle; } }\n  @media print, screen and (min-width: 64em) {\n    .menu.large-horizontal li {\n      display: inline-block; }\n    .menu.large-vertical li {\n      display: block; }\n    .menu.large-expanded {\n      display: table;\n      width: 100%; }\n      .menu.large-expanded > li {\n        display: table-cell;\n        vertical-align: middle; }\n    .menu.large-simple {\n      display: table;\n      width: 100%; }\n      .menu.large-simple > li {\n        display: table-cell;\n        vertical-align: middle; } }\n  .menu.nested {\n    margin-right: 0;\n    margin-left: 1rem; }\n  .menu.icons img,\n  .menu.icons i,\n  .menu.icons svg {\n    vertical-align: middle; }\n    .menu.icons img + span,\n    .menu.icons i + span,\n    .menu.icons svg + span {\n      vertical-align: middle; }\n  .menu.icon-top img,\n  .menu.icon-top i,\n  .menu.icon-top svg, .menu.icon-right img,\n  .menu.icon-right i,\n  .menu.icon-right svg, .menu.icon-bottom img,\n  .menu.icon-bottom i,\n  .menu.icon-bottom svg, .menu.icon-left img,\n  .menu.icon-left i,\n  .menu.icon-left svg {\n    vertical-align: middle; }\n    .menu.icon-top img + span,\n    .menu.icon-top i + span,\n    .menu.icon-top svg + span, .menu.icon-right img + span,\n    .menu.icon-right i + span,\n    .menu.icon-right svg + span, .menu.icon-bottom img + span,\n    .menu.icon-bottom i + span,\n    .menu.icon-bottom svg + span, .menu.icon-left img + span,\n    .menu.icon-left i + span,\n    .menu.icon-left svg + span {\n      vertical-align: middle; }\n  .menu.icon-left li a img,\n  .menu.icon-left li a i,\n  .menu.icon-left li a svg {\n    margin-right: 0.25rem;\n    display: inline-block; }\n  .menu.icon-right li a img,\n  .menu.icon-right li a i,\n  .menu.icon-right li a svg {\n    margin-left: 0.25rem;\n    display: inline-block; }\n  .menu.icon-top li a {\n    text-align: center; }\n    .menu.icon-top li a img,\n    .menu.icon-top li a i,\n    .menu.icon-top li a svg {\n      display: block;\n      margin: 0 auto 0.25rem; }\n  .menu.icon-bottom li a {\n    text-align: center; }\n    .menu.icon-bottom li a img,\n    .menu.icon-bottom li a i,\n    .menu.icon-bottom li a svg {\n      display: block;\n      margin: 0.25rem auto 0; }\n  .menu .is-active > a {\n    background: #1779ba;\n    color: #fefefe; }\n  .menu .active > a {\n    background: #1779ba;\n    color: #fefefe; }\n  .menu.align-left {\n    text-align: left; }\n  .menu.align-right {\n    text-align: right; }\n    .menu.align-right .submenu li {\n      text-align: left; }\n    .menu.align-right.vertical .submenu li {\n      text-align: right; }\n    .menu.align-right .nested {\n      margin-right: 1rem;\n      margin-left: 0; }\n  .menu.align-center {\n    text-align: center; }\n    .menu.align-center .submenu li {\n      text-align: left; }\n  .menu .menu-text {\n    padding: 0.7rem 1rem;\n    font-weight: bold;\n    line-height: 1;\n    color: inherit; }\n\n.menu-centered > .menu {\n  text-align: center; }\n  .menu-centered > .menu .submenu li {\n    text-align: left; }\n\n.no-js [data-responsive-menu] ul {\n  display: none; }\n\n.menu-icon {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #fefefe;\n    box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;\n    content: ''; }\n  .menu-icon:hover::after {\n    background: #cacaca;\n    box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }\n\n.menu-icon.dark {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon.dark::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #0a0a0a;\n    box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;\n    content: ''; }\n  .menu-icon.dark:hover::after {\n    background: #8a8a8a;\n    box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }\n\n.accordion-menu li {\n  width: 100%; }\n\n.accordion-menu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .is-accordion-submenu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .nested.is-accordion-submenu {\n  margin-right: 0;\n  margin-left: 1rem; }\n\n.accordion-menu.align-right .nested.is-accordion-submenu {\n  margin-right: 1rem;\n  margin-left: 0; }\n\n.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n  position: relative; }\n  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    position: absolute;\n    top: 50%;\n    margin-top: -3px;\n    right: 1rem; }\n\n.accordion-menu.align-left .is-accordion-submenu-parent > a::after {\n  right: 1rem;\n  left: auto; }\n\n.accordion-menu.align-right .is-accordion-submenu-parent > a::after {\n  right: auto;\n  left: 1rem; }\n\n.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n  transform: rotate(180deg);\n  transform-origin: 50% 50%; }\n\n.is-accordion-submenu-parent {\n  position: relative; }\n\n.has-submenu-toggle > a {\n  margin-right: 40px; }\n\n.submenu-toggle {\n  position: absolute;\n  top: 0;\n  right: 0;\n  width: 40px;\n  height: 40px;\n  cursor: pointer; }\n  .submenu-toggle::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    top: 0;\n    bottom: 0;\n    margin: auto; }\n\n.submenu-toggle[aria-expanded='true']::after {\n  transform: scaleY(-1);\n  transform-origin: 50% 50%; }\n\n.submenu-toggle-text {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  white-space: nowrap;\n  border: 0; }\n\n.is-drilldown {\n  position: relative;\n  overflow: hidden; }\n  .is-drilldown li {\n    display: block; }\n  .is-drilldown.animate-height {\n    transition: height 0.5s; }\n\n.drilldown a {\n  padding: 0.7rem 1rem;\n  background: #fefefe; }\n\n.drilldown .is-drilldown-submenu {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  z-index: -1;\n  width: 100%;\n  background: #fefefe;\n  transition: transform 0.15s linear; }\n  .drilldown .is-drilldown-submenu.is-active {\n    z-index: 1;\n    display: block;\n    transform: translateX(-100%); }\n  .drilldown .is-drilldown-submenu.is-closing {\n    transform: translateX(100%); }\n  .drilldown .is-drilldown-submenu a {\n    padding: 0.7rem 1rem; }\n\n.drilldown .nested.is-drilldown-submenu {\n  margin-right: 0;\n  margin-left: 0; }\n\n.drilldown .drilldown-submenu-cover-previous {\n  min-height: 100%; }\n\n.drilldown .is-drilldown-submenu-parent > a {\n  position: relative; }\n  .drilldown .is-drilldown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba;\n    position: absolute;\n    top: 50%;\n    margin-top: -6px;\n    right: 1rem; }\n\n.drilldown.align-left .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba;\n  right: 1rem;\n  left: auto; }\n\n.drilldown.align-right .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  right: auto;\n  left: 1rem; }\n\n.drilldown .js-drilldown-back > a::before {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: 0.75rem; }\n\n.dropdown.menu > li.opens-left > .is-dropdown-submenu {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.dropdown.menu > li.opens-right > .is-dropdown-submenu {\n  top: 100%;\n  right: auto;\n  left: 0; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a {\n  position: relative;\n  padding-right: 1.5rem; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-bottom-width: 0;\n  border-top-style: solid;\n  border-color: #1779ba transparent transparent;\n  right: 5px;\n  left: auto;\n  margin-top: -3px; }\n\n[data-whatinput='mouse'] .dropdown.menu a {\n  outline: 0; }\n\n.dropdown.menu > li > a {\n  padding: 0.7rem 1rem; }\n\n.dropdown.menu > li.is-active > a {\n  background: transparent;\n  color: #1779ba; }\n\n.no-js .dropdown.menu ul {\n  display: none; }\n\n.dropdown.menu .nested.is-dropdown-submenu {\n  margin-right: 0;\n  margin-left: 0; }\n\n.dropdown.menu.vertical > li .is-dropdown-submenu {\n  top: 0; }\n\n.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {\n  top: 0;\n  right: 100%;\n  left: auto; }\n\n.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%; }\n\n.dropdown.menu.vertical > li > a::after {\n  right: 14px; }\n\n.dropdown.menu.vertical > li.opens-left > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  right: auto;\n  left: 5px; }\n\n.dropdown.menu.vertical > li.opens-right > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba; }\n\n@media print, screen and (min-width: 40em) {\n  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    right: 5px;\n    left: auto;\n    margin-top: -3px; }\n  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.medium-vertical > li > a::after {\n    right: 14px; }\n  .dropdown.menu.medium-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.medium-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; } }\n\n@media print, screen and (min-width: 64em) {\n  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    right: 5px;\n    left: auto;\n    margin-top: -3px; }\n  .dropdown.menu.large-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.large-vertical > li > a::after {\n    right: 14px; }\n  .dropdown.menu.large-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.large-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; } }\n\n.dropdown.menu.align-right .is-dropdown-submenu.first-sub {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.is-dropdown-menu.vertical {\n  width: 100px; }\n  .is-dropdown-menu.vertical.align-right {\n    float: right; }\n\n.is-dropdown-submenu-parent {\n  position: relative; }\n  .is-dropdown-submenu-parent a::after {\n    position: absolute;\n    top: 50%;\n    right: 5px;\n    left: auto;\n    margin-top: -6px; }\n  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {\n    top: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n\n.is-dropdown-submenu {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  z-index: 1;\n  display: none;\n  min-width: 200px;\n  border: 1px solid #cacaca;\n  background: #fefefe; }\n  .dropdown .is-dropdown-submenu a {\n    padding: 0.7rem 1rem; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {\n    right: 14px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; }\n  .is-dropdown-submenu .is-dropdown-submenu {\n    margin-top: -1px; }\n  .is-dropdown-submenu > li {\n    width: 100%; }\n  .is-dropdown-submenu.js-dropdown-active {\n    display: block; }\n\n.is-off-canvas-open {\n  overflow: hidden; }\n\n.js-off-canvas-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 11;\n  width: 100%;\n  height: 100%;\n  transition: opacity 0.5s ease, visibility 0.5s ease;\n  background: rgba(254, 254, 254, 0.25);\n  opacity: 0;\n  visibility: hidden;\n  overflow: hidden; }\n  .js-off-canvas-overlay.is-visible {\n    opacity: 1;\n    visibility: visible; }\n  .js-off-canvas-overlay.is-closable {\n    cursor: pointer; }\n  .js-off-canvas-overlay.is-overlay-absolute {\n    position: absolute; }\n  .js-off-canvas-overlay.is-overlay-fixed {\n    position: fixed; }\n\n.off-canvas-wrapper {\n  position: relative;\n  overflow: hidden; }\n\n.off-canvas {\n  position: fixed;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas {\n    outline: 0; }\n  .off-canvas.is-transition-push {\n    z-index: 12; }\n  .off-canvas.is-closed {\n    visibility: hidden; }\n  .off-canvas.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n.off-canvas-absolute {\n  position: absolute;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas-absolute {\n    outline: 0; }\n  .off-canvas-absolute.is-transition-push {\n    z-index: 12; }\n  .off-canvas-absolute.is-closed {\n    visibility: hidden; }\n  .off-canvas-absolute.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas-absolute.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas-absolute.is-open {\n    transform: translate(0, 0); }\n\n.position-left {\n  top: 0;\n  left: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(-250px); }\n  .off-canvas-content .off-canvas.position-left {\n    transform: translateX(-250px); }\n    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-left.has-transition-push {\n    transform: translateX(250px); }\n  .position-left.is-transition-push {\n    box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-right {\n  top: 0;\n  right: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(250px); }\n  .off-canvas-content .off-canvas.position-right {\n    transform: translateX(250px); }\n    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-right.has-transition-push {\n    transform: translateX(-250px); }\n  .position-right.is-transition-push {\n    box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-top {\n  top: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(-250px); }\n  .off-canvas-content .off-canvas.position-top {\n    transform: translateY(-250px); }\n    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-top.has-transition-push {\n    transform: translateY(250px); }\n  .position-top.is-transition-push {\n    box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-bottom {\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(250px); }\n  .off-canvas-content .off-canvas.position-bottom {\n    transform: translateY(250px); }\n    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-bottom.has-transition-push {\n    transform: translateY(-250px); }\n  .position-bottom.is-transition-push {\n    box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.off-canvas-content {\n  transform: none;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden; }\n  .off-canvas-content.has-transition-push {\n    transform: translate(0, 0); }\n  .off-canvas-content .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n@media print, screen and (min-width: 40em) {\n  .position-left.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-medium ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-medium ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-medium ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-medium ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 64em) {\n  .position-left.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-large ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-large ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-large ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-large ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 40em) {\n  .off-canvas.in-canvas-for-medium {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-medium .close-button {\n      display: none; } }\n\n@media print, screen and (min-width: 64em) {\n  .off-canvas.in-canvas-for-large {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-large .close-button {\n      display: none; } }\n\nhtml.is-reveal-open {\n  position: fixed;\n  width: 100%;\n  overflow-y: hidden; }\n  html.is-reveal-open.zf-has-scroll {\n    overflow-y: scroll; }\n  html.is-reveal-open body {\n    overflow-y: hidden; }\n\n.reveal-overlay {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1005;\n  display: none;\n  background-color: rgba(10, 10, 10, 0.45);\n  overflow-y: auto; }\n\n.reveal {\n  z-index: 1006;\n  backface-visibility: hidden;\n  display: none;\n  padding: 1rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  position: relative;\n  top: 100px;\n  margin-right: auto;\n  margin-left: auto;\n  overflow-y: auto; }\n  [data-whatinput='mouse'] .reveal {\n    outline: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      min-height: 0; } }\n  .reveal .column, .reveal .columns {\n    min-width: 0; }\n  .reveal > :last-child {\n    margin-bottom: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      width: 600px;\n      max-width: 75rem; } }\n  .reveal.collapse {\n    padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal.tiny {\n      width: 30%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.small {\n      width: 50%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.large {\n      width: 90%;\n      max-width: 75rem; } }\n  .reveal.full {\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    max-width: none;\n    height: 100%;\n    min-height: 100%;\n    margin-left: 0;\n    border: 0;\n    border-radius: 0; }\n  @media screen and (max-width: 39.99875em) {\n    .reveal {\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      width: 100%;\n      max-width: none;\n      height: 100%;\n      min-height: 100%;\n      margin-left: 0;\n      border: 0;\n      border-radius: 0; } }\n  .reveal.without-overlay {\n    position: fixed; }\n\n.sticky-container {\n  position: relative; }\n\n.sticky {\n  position: relative;\n  z-index: 0;\n  transform: translate3d(0, 0, 0); }\n\n.sticky.is-stuck {\n  position: fixed;\n  z-index: 5;\n  width: 100%; }\n  .sticky.is-stuck.is-at-top {\n    top: 0; }\n  .sticky.is-stuck.is-at-bottom {\n    bottom: 0; }\n\n.sticky.is-anchored {\n  position: relative;\n  right: auto;\n  left: auto; }\n  .sticky.is-anchored.is-at-bottom {\n    bottom: 0; }\n\n.title-bar {\n  padding: 0.5rem;\n  background: #0a0a0a;\n  color: #fefefe; }\n  .title-bar::before, .title-bar::after {\n    display: table;\n    content: ' '; }\n  .title-bar::after {\n    clear: both; }\n  .title-bar .menu-icon {\n    margin-left: 0.25rem;\n    margin-right: 0.25rem; }\n\n.title-bar-left {\n  float: left; }\n\n.title-bar-right {\n  float: right;\n  text-align: right; }\n\n.title-bar-title {\n  display: inline-block;\n  vertical-align: middle;\n  font-weight: bold; }\n\n.top-bar {\n  padding: 0.5rem; }\n  .top-bar::before, .top-bar::after {\n    display: table;\n    content: ' '; }\n  .top-bar::after {\n    clear: both; }\n  .top-bar,\n  .top-bar ul {\n    background-color: #e6e6e6; }\n  .top-bar input {\n    max-width: 200px;\n    margin-right: 1rem; }\n  .top-bar .input-group-field {\n    width: 100%;\n    margin-right: 0; }\n  .top-bar input.button {\n    width: auto; }\n  .top-bar .top-bar-left,\n  .top-bar .top-bar-right {\n    width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .top-bar .top-bar-left,\n    .top-bar .top-bar-right {\n      width: auto; } }\n  @media screen and (max-width: 63.99875em) {\n    .top-bar.stacked-for-medium .top-bar-left,\n    .top-bar.stacked-for-medium .top-bar-right {\n      width: 100%; } }\n  @media screen and (max-width: 74.99875em) {\n    .top-bar.stacked-for-large .top-bar-left,\n    .top-bar.stacked-for-large .top-bar-right {\n      width: 100%; } }\n\n.top-bar-title {\n  display: inline-block;\n  float: left;\n  padding: 0.5rem 1rem 0.5rem 0; }\n  .top-bar-title .menu-icon {\n    bottom: 2px; }\n\n.top-bar-left {\n  float: left; }\n\n.top-bar-right {\n  float: right; }\n\n.float-left {\n  float: left !important; }\n\n.float-right {\n  float: right !important; }\n\n.float-center {\n  display: block;\n  margin-right: auto;\n  margin-left: auto; }\n\n.clearfix::before, .clearfix::after {\n  display: table;\n  content: ' '; }\n\n.clearfix::after {\n  clear: both; }\n\n.hide {\n  display: none !important; }\n\n.invisible {\n  visibility: hidden; }\n\n@media screen and (max-width: 39.99875em) {\n  .hide-for-small-only {\n    display: none !important; } }\n\n@media screen and (max-width: 0em), screen and (min-width: 40em) {\n  .show-for-small-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 40em) {\n  .hide-for-medium {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em) {\n  .show-for-medium {\n    display: none !important; } }\n\n@media screen and (min-width: 40em) and (max-width: 63.99875em) {\n  .hide-for-medium-only {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {\n  .show-for-medium-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 64em) {\n  .hide-for-large {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em) {\n  .show-for-large {\n    display: none !important; } }\n\n@media screen and (min-width: 64em) and (max-width: 74.99875em) {\n  .hide-for-large-only {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {\n  .show-for-large-only {\n    display: none !important; } }\n\n.show-for-sr,\n.show-on-focus {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  white-space: nowrap;\n  border: 0; }\n\n.show-on-focus:active, .show-on-focus:focus {\n  position: static !important;\n  width: auto;\n  height: auto;\n  overflow: visible;\n  clip: auto;\n  white-space: normal; }\n\n.show-for-landscape,\n.hide-for-portrait {\n  display: block !important; }\n  @media screen and (orientation: landscape) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: block !important; } }\n  @media screen and (orientation: portrait) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: none !important; } }\n\n.hide-for-landscape,\n.show-for-portrait {\n  display: none !important; }\n  @media screen and (orientation: landscape) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: none !important; } }\n  @media screen and (orientation: portrait) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: block !important; } }\n","/**\n * Foundation for Sites by ZURB\n * Version 6.5.3\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n\n// Dependencies\n@import 'vendor/normalize';\n@import '../_vendor/sassy-lists/stylesheets/helpers/missing-dependencies';\n@import '../_vendor/sassy-lists/stylesheets/helpers/true';\n@import '../_vendor/sassy-lists/stylesheets/functions/contain';\n@import '../_vendor/sassy-lists/stylesheets/functions/purge';\n@import '../_vendor/sassy-lists/stylesheets/functions/remove';\n@import '../_vendor/sassy-lists/stylesheets/functions/replace';\n@import '../_vendor/sassy-lists/stylesheets/functions/to-list';\n\n// --- Settings ---\n// import your own `settings` here or\n// import and modify the default settings through\n// @import 'settings/settings';\n\n// --- Components ---\n// Utilities\n@import 'util/util';\n// Global styles\n@import 'global';\n@import 'forms/forms';\n@import 'typography/typography';\n\n// Grids\n@import 'grid/grid';\n@import 'xy-grid/xy-grid';\n// Generic components\n@import 'components/button';\n@import 'components/button-group';\n@import 'components/close-button';\n@import 'components/label';\n@import 'components/progress-bar';\n@import 'components/slider';\n@import 'components/switch';\n@import 'components/table';\n// Basic components\n@import 'components/badge';\n@import 'components/breadcrumbs';\n@import 'components/callout';\n@import 'components/card';\n@import 'components/dropdown';\n@import 'components/pagination';\n@import 'components/tooltip';\n\n// Containers\n@import 'components/accordion';\n@import 'components/media-object';\n@import 'components/orbit';\n@import 'components/responsive-embed';\n@import 'components/tabs';\n@import 'components/thumbnail';\n// Menu-based containers\n@import 'components/menu';\n@import 'components/menu-icon';\n@import 'components/accordion-menu';\n@import 'components/drilldown';\n@import 'components/dropdown-menu';\n\n// Layout components\n@import 'components/off-canvas';\n@import 'components/reveal';\n@import 'components/sticky';\n@import 'components/title-bar';\n@import 'components/top-bar';\n\n// Helpers\n@import 'components/float';\n@import 'components/flex';\n@import 'components/visibility';\n@import 'prototype/prototype';\n\n\n@mixin foundation-everything(\n  $flex: true,\n  $prototype: false\n) {\n  @if $flex {\n    $global-flexbox: true !global;\n  }\n\n  // Global styles\n  @include foundation-global-styles;\n  @include foundation-forms;\n  @include foundation-typography;\n\n  // Grids\n  @if not $flex {\n    @include foundation-grid;\n  }\n  @else {\n    @if $xy-grid {\n      @include foundation-xy-grid-classes;\n    }\n    @else {\n      @include foundation-flex-grid;\n    }\n  }\n\n  // Generic components\n  @include foundation-button;\n  @include foundation-button-group;\n  @include foundation-close-button;\n  @include foundation-label;\n  @include foundation-progress-bar;\n  @include foundation-slider;\n  @include foundation-switch;\n  @include foundation-table;\n  // Basic components\n  @include foundation-badge;\n  @include foundation-breadcrumbs;\n  @include foundation-callout;\n  @include foundation-card;\n  @include foundation-dropdown;\n  @include foundation-pagination;\n  @include foundation-tooltip;\n\n  // Containers\n  @include foundation-accordion;\n  @include foundation-media-object;\n  @include foundation-orbit;\n  @include foundation-responsive-embed;\n  @include foundation-tabs;\n  @include foundation-thumbnail;\n  // Menu-based containers\n  @include foundation-menu;\n  @include foundation-menu-icon;\n  @include foundation-accordion-menu;\n  @include foundation-drilldown-menu;\n  @include foundation-dropdown-menu;\n\n  // Layout components\n  @include foundation-off-canvas;\n  @include foundation-reveal;\n  @include foundation-sticky;\n  @include foundation-title-bar;\n  @include foundation-top-bar;\n\n  // Helpers\n  @include foundation-float-classes;\n  @if $flex { @include foundation-flex-classes; }\n  @include foundation-visibility-classes;\n  @if $prototype { @include foundation-prototype-classes; }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group breakpoints\n////\n\n/// A list of named breakpoints. You can use these with the `breakpoint()` mixin to quickly create media queries.\n/// @type Map\n$breakpoints: (\n  small: 0,\n  medium: 640px,\n  large: 1024px,\n  xlarge: 1200px,\n  xxlarge: 1440px,\n) !default;\n\n/// The largest named breakpoint in which to include print as a media type\n/// @type Keyword\n$print-breakpoint: large !default;\n\n$-zf-zero-breakpoint: small !default;\n\n$-zf-breakpoints-keys: map-to-list($breakpoints, 'keys');\n\n@if nth(map-values($breakpoints), 1) != 0 {\n  @error 'The first key in the $breakpoints map must have a value of \"0\".';\n}\n@else {\n  $-zf-zero-breakpoint: nth(map-keys($breakpoints), 1);\n}\n\n/// All of the names in this list will be output as classes in your CSS, like `.small-12`, `.medium-6`, and so on. Each value in this list must also be in the `$breakpoints` map.\n/// @type List\n$breakpoint-classes: (small medium large) !default;\n\n/// Generates a media query string matching the input value. Refer to the documentation for the `breakpoint()` mixin to see what the possible inputs are.\n///\n/// @param {Keyword|Number} $val [small] - Breakpoint name, or px, rem, or em value to process.\n@function breakpoint($val: $-zf-zero-breakpoint) {\n  // Size or keyword\n  $bp: nth($val, 1);\n  // Value for max-width media queries\n  $bp-max: 0;\n  // Direction of media query (up, down, or only)\n  $dir: if(length($val) > 1, nth($val, 2), up);\n  // Eventual output\n  $str: '';\n  // Is it a named media query?\n  $named: false;\n\n  // Orientation media queries have a unique syntax\n  @if $bp == 'landscape' or $bp == 'portrait' {\n    @return '(orientation: #{$bp})';\n  }\n  @else if $bp == 'retina' {\n    @return '(-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi)';\n  }\n\n  // Try to pull a named breakpoint out of the $breakpoints map\n  @if type-of($bp) == 'string' {\n    @if map-has-key($breakpoints, $bp) {\n      @if $dir == 'only' or $dir == 'down' {\n        $bp-max: -zf-map-next($breakpoints, $bp);\n      }\n\n      $bp: map-get($breakpoints, $bp);\n      $named: true;\n    }\n    @else {\n      $bp: 0;\n      @warn 'breakpoint(): \"#{$val}\" is not defined in your $breakpoints setting.';\n    }\n  }\n\n  // Convert any pixel, rem, or unitless value to em\n  $bp: -zf-bp-to-em($bp);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/zurb/foundation-sites/issues/11313\n  @if $bp-max {\n    $bp-max: -zf-bp-to-em($bp-max) - .00125;\n  }\n\n  // Conditions to skip media query creation\n  // - It's a named breakpoint that resolved to \"0 down\" or \"0 up\"\n  // - It's a numeric breakpoint that resolved to \"0 \" + anything\n  @if $bp > 0em or $dir == 'only' or $dir == 'down' {\n    // `only` ranges use the format `(min-width: n) and (max-width: n)`\n    @if $dir == 'only' {\n      // Only named media queries can have an \"only\" range\n      @if $named == true {\n        // Only use \"min-width\" if the floor is greater than 0\n        @if $bp > 0em {\n          $str: $str + '(min-width: #{$bp})';\n\n          // Only add \"and\" to the media query if there's a ceiling\n          @if $bp-max != null {\n            $str: $str + ' and ';\n          }\n        }\n\n        // Only use \"max-width\" if there's a ceiling\n        @if $bp-max != null {\n          $str: $str + '(max-width: #{$bp-max})';\n        }\n      }\n      @else {\n        @warn 'breakpoint(): Only named media queries can have an `only` range.';\n      }\n    }\n\n    // `down` ranges use the format `(max-width: n)`\n    @else if $dir == 'down' {\n      $max: if($named, $bp-max, $bp);\n\n      // Skip media query creation if input value is exactly \"0 down\",\n      // unless the function was called as \"small down\", in which case it's just \"small only\"\n      @if $named or $bp > 0em {\n        @if $max != null {\n          $str: $str + '(max-width: #{$max})';\n        }\n      }\n    }\n\n    // `up` ranges use the format `(min-width: n)`\n    @else if $bp > 0em {\n      $str: $str + '(min-width: #{$bp})';\n    }\n  }\n\n  @return $str;\n}\n\n/// Wraps a media query around the content you put inside the mixin. This mixin accepts a number of values:\n///  - If a string is passed, the mixin will look for it in the `$breakpoints` map, and use a media query there.\n///  - If a pixel value is passed, it will be converted to an em value using `$global-font-size` as the base.\n///  - If a rem value is passed, the unit will be changed to em.\n///  - If an em value is passed, the value will be used as-is.\n///\n/// @param {Keyword|Number} $value - Breakpoint name, or px, rem, or em value to process.\n///\n/// @output If the breakpoint is \"0px and larger\", outputs the content as-is. Otherwise, outputs the content wrapped in a media query.\n@mixin breakpoint($value) {\n  $str: breakpoint($value);\n  $bp: index($-zf-breakpoints-keys, $value);\n  $pbp: index($-zf-breakpoints-keys, $print-breakpoint);\n\n  $old-zf-size: null;\n\n  // Make breakpoint size available as a variable\n  @if global-variable-exists(-zf-size) {\n    $old-zf-size: $-zf-size;\n  }\n  $-zf-size: nth($value, 1) !global; // get the first value to account for `only` and `down` keywords\n\n  // If $str is still an empty string, no media query is needed\n  @if $str == '' {\n    @content;\n  }\n\n  // Otherwise, wrap the content in a media query\n  @else {\n    // For named breakpoints less than or equal to $print-breakpoint, add print to the media types\n    @if $bp != null and $bp <= $pbp {\n      @media print, screen and #{$str} {\n        @content;\n       }\n    }\n    @else {\n      @media screen and #{$str} {\n        @content;\n      }\n    }\n  }\n\n  $-zf-size: $old-zf-size !global;\n}\n\n/// Converts the breakpoints map to a URL-encoded string, like this: `key1=value1&key2=value2`. The value is then dropped into the CSS for a special `<meta>` tag, which is read by the Foundation JavaScript. This is how we transfer values from Sass to JavaScript, so they can be defined in one place.\n/// @access private\n///\n/// @param {Map} $map - Map to convert.\n///\n/// @returns {String} A string containing the map's contents.\n@function -zf-bp-serialize($map) {\n  $str: '';\n  @each $key, $value in $map {\n    $str: $str + $key + '=' + -zf-bp-to-em($value) + '&';\n  }\n  $str: str-slice($str, 1, -2);\n\n  @return $str;\n}\n\n/// Find the next key in a map.\n/// @access private\n///\n/// @param {Map} $map - Map to traverse.\n/// @param {Mixed} $key - Key to use as a starting point.\n///\n/// @returns {Mixed} The value for the key after `$key`, if `$key` was found. If `$key` was not found, or `$key` was the last value in the map, returns `null`.\n@function -zf-map-next($map, $key) {\n\n  // Store the keys of the map as a list\n  $values: map-keys($map);\n\n  $i: 0;\n\n  // If the Key Exists, Get the index of the key within the map and add 1 to it for the next breakpoint in the map\n  @if (map-has-key($map, $key)) {\n    $i: index($values, $key) + 1;\n  }\n\n  // If the key doesn't exist, or it's the last key in the map, return null\n  @if ($i > length($map) or $i == 0) {\n    @return null;\n  }\n  // Otherwise, return the value\n  @else {\n    @return map-get($map, nth($values, $i));\n  }\n\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $key - Key to use as last breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-breakpoints-less-than($key) {\n  $list: ();\n  $found_key: false;\n\n  @each $name in $-zf-breakpoints-keys {\n    @if ($name == $key) {\n      $found_key: true;\n    }\n    @if not $found_key {\n      $list: append($list, $name);\n    }\n  }\n  @return $list;\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $breakpoint - a named or non-named breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-closest-named-breakpoint($breakpoint) {\n  $last: $-zf-zero-breakpoint;\n  $found: false;\n\n  $value: unitless-calc($breakpoint, 1px);\n  @each $key, $val in $breakpoints {\n    @if not $found {\n      @if unitless-calc($val) > $value {\n        $found: true;\n      } @else {\n        $last: $key;\n      }\n    }\n  }\n\n  @return $last;\n}\n\n/// Get a value for a breakpoint from a responsive config map or single value.\n/// - If the config is a single value, return it regardless of `$value`.\n/// - If the config is a map and has the key `$value`, the exact breakpoint value is returned.\n/// - If the config is a map and does *not* have the breakpoint, the value matching the next lowest breakpoint in the config map is returned.\n/// @access private\n///\n/// @param {Number|Map} $map - Responsive config map or single value.\n/// @param {Keyword} $value - Breakpoint name to use.\n///\n/// @return {Mixed} The corresponding breakpoint value.\n@function -zf-get-bp-val($map, $value) {\n  // If the given map is a single value, return it\n  @if type-of($map) == 'number' {\n    @return $map;\n  }\n\n\n  // Check if the breakpoint name exists globally\n  @if not map-has-key($breakpoints, $value) {\n    @if type-of($value) == 'number' {\n      $value: -zf-closest-named-breakpoint($value);\n    } @else {\n      @return null;\n    }\n  }\n  // Check if the breakpoint name exists in the local config map\n  @else if map-has-key($map, $value) {\n    // If it does, just return the value\n    @return map-get($map, $value);\n  }\n  // Otherwise, find the next lowest breakpoint and return that value\n  @else {\n    $anchor: null;\n    $found: false;\n\n    @each $key, $val in $breakpoints {\n      @if not $found {\n        @if map-has-key($map, $key) {\n          $anchor: $key;\n        }\n        @if $key == $value {\n          $found: true;\n        }\n      }\n    }\n\n    @return map-get($map, $anchor);\n  }\n}\n\n$small-up: '';\n$small-only: '';\n\n@if map-has-key($breakpoints, small) {\n  $small-up: screen;\n  $small-only: unquote('screen and #{breakpoint(small only)}');\n}\n\n$medium-up: '';\n$medium-only: '';\n\n@if map-has-key($breakpoints, medium) {\n  $medium-up: unquote('screen and #{breakpoint(medium)}');\n  $medium-only: unquote('screen and #{breakpoint(medium only)}');\n}\n\n$large-up: '';\n$large-only: '';\n\n@if map-has-key($breakpoints, large) {\n  $large-up: unquote('screen and #{breakpoint(large)}');\n  $large-only: unquote('screen and #{breakpoint(large only)}');\n}\n\n$xlarge-up: '';\n$xlarge-only: '';\n\n@if map-has-key($breakpoints, xlarge) {\n  $xlarge-up: unquote('screen and #{breakpoint(xlarge)}');\n  $xlarge-only: unquote('screen and #{breakpoint(xlarge only)}');\n}\n\n$xxlarge-up: '';\n\n@if map-has-key($breakpoints, xxlarge) {\n  $xxlarge-up: unquote('screen and #{breakpoint(xxlarge)}');\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group reveal\n////\n\n/// Default background color of a modal.\n/// @type Color\n$reveal-background: $white !default;\n\n/// Default width of a modal, with no class applied.\n/// @type Number\n$reveal-width: 600px !default;\n\n/// Default maximum width of a modal.\n/// @type Number\n$reveal-max-width: $global-width !default;\n\n/// Default padding inside a modal.\n/// @type Number\n$reveal-padding: $global-padding !default;\n\n/// Default border around a modal.\n/// @type Number\n$reveal-border: 1px solid $medium-gray !default;\n\n/// Default radius for modal.\n/// @type Number\n$reveal-radius: $global-radius !default;\n\n/// z-index for modals. The overlay uses this value, while the modal itself uses this value plus one.\n/// @type Number\n$reveal-zindex: 1005 !default;\n\n/// Background color of modal overlays.\n/// @type Color\n$reveal-overlay-background: rgba($black, 0.45) !default;\n\n\n// Placeholder selector for medium-and-up modals\n// Prevents duplicate CSS when defining multiple Reveal sizes\n// This should be in the same breakpoint then `@mixin reveal-modal-width`\n@include breakpoint(medium) {\n  %reveal-centered {\n    right: auto;\n    left: auto;\n    margin: 0 auto;\n  }\n}\n\n\n/// Adds styles for a modal overlay.\n/// @param {Color} $background [$reveal-overlay-background] - Background color of the overlay.\n@mixin reveal-overlay($background: $reveal-overlay-background) {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: $reveal-zindex;\n\n  display: none;\n  background-color: $background;\n  overflow-y: auto;\n}\n\n/// Adds base styles for a modal.\n@mixin reveal-modal-base {\n  @include disable-mouse-outline;\n  z-index: $reveal-zindex + 1;\n  // Workaround android browser z-index bug\n  backface-visibility: hidden;\n\n  display: none;\n  padding: $reveal-padding;\n\n  border: $reveal-border;\n  border-radius: $reveal-radius;\n  background-color: $reveal-background;\n\n  @include breakpoint(medium) {\n    min-height: 0;\n  }\n\n  // Make sure rows don't have a min-width on them\n  .column {\n    min-width: 0;\n  }\n\n  // Strip margins from the last item in the modal\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adjusts the width of a modal.\n/// @param {Number} $width - Width of the modal. Generally a percentage.\n/// @param {Number} $max-width [$reveal-max-width] - Maximum width of the modal.\n@mixin reveal-modal-width(\n  $width: $reveal-width,\n  $max-width: $reveal-max-width\n) {\n  // Extends must be made outside of breakpoints for compatibility with newer Sass versions (libsass v3.5)\n  @extend %reveal-centered;\n  @include breakpoint(medium) {\n    width: $width;\n    max-width: $max-width;\n  }\n}\n\n/// Creates a full-screen modal, which stretches the full width and height of the window.\n@mixin reveal-modal-fullscreen {\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n\n  width: 100%;\n  max-width: none;\n  height: 100%;\n  min-height: 100%;\n  margin-left: 0;\n\n  border: 0;\n  border-radius: 0;\n}\n\n@mixin foundation-reveal {\n\n  /// Disables the scroll when Reveal is shown to prevent the background from shifting\n  html.is-reveal-open {\n    position: fixed;\n    width: 100%;\n    overflow-y: hidden;\n\n    &.zf-has-scroll {\n      overflow-y: scroll;\n    }\n\n    body { // sass-lint:disable-line no-qualifying-elements\n      overflow-y: hidden;\n    }\n  }\n\n  // Overlay\n  .reveal-overlay {\n    @include reveal-overlay;\n  }\n\n  // Modal container\n  .reveal {\n    @include reveal-modal-base;\n    @include reveal-modal-width($reveal-width);\n    position: relative;\n    top: 100px;\n    margin-right: auto;\n    margin-left: auto;\n    overflow-y: auto;\n\n    // Remove padding\n    &.collapse {\n      padding: 0;\n    }\n\n    // Sizing classes\n    &.tiny  { @include reveal-modal-width(30%); }\n    &.small { @include reveal-modal-width(50%); }\n    &.large { @include reveal-modal-width(90%); }\n\n    // Full-screen mode\n    &.full {\n      @include reveal-modal-fullscreen;\n    }\n\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include reveal-modal-fullscreen;\n    }\n\n    &.without-overlay {\n      position: fixed;\n    }\n  }\n}\n","@mixin foundation-normalize() {\n  /*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\n\n  // Document\n  // ==========================================================================\n\n  // 1. Correct the line height in all browsers.\n  // 2. Prevent adjustments of font size after orientation changes in iOS.\n\n  html {\n    line-height: 1.15; // 1\n    -webkit-text-size-adjust: 100%; // 2\n  }\n\n  // Sections\n  // ==========================================================================\n\n  // Remove the margin in all browsers.\n\n  body {\n    margin: 0;\n  }\n\n  // Correct the font size and margin on `h1` elements within `section` and\n  // `article` contexts in Chrome, Firefox, and Safari.\n\n  h1 {\n    font-size: 2em;\n    margin: 0.67em 0;\n  }\n\n  // Grouping content\n  // ==========================================================================\n\n  // 1. Add the correct box sizing in Firefox.\n  // 2. Show the overflow in Edge and IE.\n\n  hr {\n    box-sizing: content-box; // 1\n    height: 0; // 1\n    overflow: visible; // 2\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  pre {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Text-level semantics\n  // ==========================================================================\n\n  // Remove the gray background on active links in IE 10.\n\n  a {\n    background-color: transparent;\n  }\n\n  // 1. Remove the bottom border in Chrome 57-\n  // 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n\n  abbr[title] {\n    border-bottom: none; // 1\n    text-decoration: underline; // 2\n    text-decoration: underline dotted; // 2\n  }\n\n  // Add the correct font weight in Chrome, Edge, and Safari.\n\n  b,\n  strong {\n    font-weight: bolder;\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  code,\n  kbd,\n  samp {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Add the correct font size in all browsers.\n\n  small {\n    font-size: 80%;\n  }\n\n  // Prevent `sub` and `sup` elements from affecting the line height in\n  // all browsers.\n\n  sub,\n  sup {\n    font-size: 75%;\n    line-height: 0;\n    position: relative;\n    vertical-align: baseline;\n  }\n\n  sub {\n    bottom: -0.25em;\n  }\n\n  sup {\n    top: -0.5em;\n  }\n\n  // Embedded content\n  // ==========================================================================\n\n  // Remove the border on images inside links in IE 10.\n\n  img {\n    border-style: none;\n  }\n\n  // Forms\n  // ==========================================================================\n\n  // 1. Change the font styles in all browsers.\n  // 2. Remove the margin in Firefox and Safari.\n\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit; // 1\n    font-size: 100%; // 1\n    line-height: 1.15; // 1\n    margin: 0; // 2\n  }\n\n  // Show the overflow in IE.\n  // 1. Show the overflow in Edge.\n\n  button,\n  input { // 1\n    overflow: visible;\n  }\n\n  // Remove the inheritance of text transform in Edge, Firefox, and IE.\n  // 1. Remove the inheritance of text transform in Firefox.\n\n  button,\n  select { // 1\n    text-transform: none;\n  }\n\n  // Correct the inability to style clickable types in iOS and Safari.\n\n  button,\n  [type=\"button\"],\n  [type=\"reset\"],\n  [type=\"submit\"] {\n    -webkit-appearance: button;\n  }\n\n  // Remove the inner border and padding in Firefox.\n\n  button::-moz-focus-inner,\n  [type=\"button\"]::-moz-focus-inner,\n  [type=\"reset\"]::-moz-focus-inner,\n  [type=\"submit\"]::-moz-focus-inner {\n    border-style: none;\n    padding: 0;\n  }\n\n  // Restore the focus styles unset by the previous rule.\n\n  button:-moz-focusring,\n  [type=\"button\"]:-moz-focusring,\n  [type=\"reset\"]:-moz-focusring,\n  [type=\"submit\"]:-moz-focusring {\n    outline: 1px dotted ButtonText;\n  }\n\n  // Correct the padding in Firefox.\n\n  fieldset {\n    padding: 0.35em 0.75em 0.625em;\n  }\n\n  // 1. Correct the text wrapping in Edge and IE.\n  // 2. Correct the color inheritance from `fieldset` elements in IE.\n  // 3. Remove the padding so developers are not caught out when they zero out\n  //    `fieldset` elements in all browsers.\n\n  legend {\n    box-sizing: border-box; // 1\n    color: inherit; // 2\n    display: table; // 1\n    max-width: 100%; // 1\n    padding: 0; // 3\n    white-space: normal; // 1\n  }\n\n  // Add the correct vertical alignment in Chrome, Firefox, and Opera.\n\n  progress {\n    vertical-align: baseline;\n  }\n\n  // Remove the default vertical scrollbar in IE 10+.\n\n  textarea {\n    overflow: auto;\n  }\n\n  // 1. Add the correct box sizing in IE 10.\n  // 2. Remove the padding in IE 10.\n\n  [type=\"checkbox\"],\n  [type=\"radio\"] {\n    box-sizing: border-box; // 1\n    padding: 0; // 2\n  }\n\n  // Correct the cursor style of increment and decrement buttons in Chrome.\n\n  [type=\"number\"]::-webkit-inner-spin-button,\n  [type=\"number\"]::-webkit-outer-spin-button {\n    height: auto;\n  }\n\n  // 1. Correct the odd appearance in Chrome and Safari.\n  // 2. Correct the outline style in Safari.\n\n  [type=\"search\"] {\n    -webkit-appearance: textfield; // 1\n    outline-offset: -2px; // 2\n  }\n\n  // Remove the inner padding in Chrome and Safari on macOS.\n\n  [type=\"search\"]::-webkit-search-decoration {\n    -webkit-appearance: none;\n  }\n\n  // 1. Correct the inability to style clickable types in iOS and Safari.\n  // 2. Change font properties to `inherit` in Safari.\n\n  ::-webkit-file-upload-button {\n    -webkit-appearance: button; // 1\n    font: inherit; // 2\n  }\n\n  // Interactive\n  // ==========================================================================\n\n  // Add the correct display in Edge, IE 10+, and Firefox.\n\n  details {\n    display: block;\n  }\n\n  // Add the correct display in all browsers.\n\n  summary {\n    display: list-item;\n  }\n\n  // Misc\n  // ==========================================================================\n\n  // Add the correct display in IE 10+.\n\n  template {\n    display: none;\n  }\n\n  // Add the correct display in IE 10.\n\n  [hidden] {\n    display: none;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-color-literals, no-qualifying-elements\n\n////\n/// @group global\n////\n\n@import 'util/util';\n\n/// Font size attribute applied to `<html>` and `<body>`. We use 100% by default so the value is inherited from the user's browser settings.\n/// @type Number\n$global-font-size: 100% !default;\n\n/// Global width of your site. Used by the grid to determine row width.\n/// @type Number\n$global-width: rem-calc(1200) !default;\n\n/// Default line height for all type. `$global-lineheight` is 24px while `$global-font-size` is 16px\n/// @type Number\n$global-lineheight: 1.5 !default;\n\n/// Colors used for buttons, callouts, links, etc. There must always be a color called `primary`.\n/// @type Map\n$foundation-palette: (\n  primary: #1779ba,\n  secondary: #767676,\n  success: #3adb76,\n  warning: #ffae00,\n  alert: #cc4b37,\n) !default;\n\n/// Color used for light gray UI items.\n/// @type Color\n$light-gray: #e6e6e6 !default;\n\n/// Color used for medium gray UI items.\n/// @type Color\n$medium-gray: #cacaca !default;\n\n/// Color used for dark gray UI items.\n/// @type Color\n$dark-gray: #8a8a8a !default;\n\n/// Color used for black ui items.\n/// @type Color\n$black: #0a0a0a !default;\n\n/// Color used for white ui items.\n/// @type Color\n$white: #fefefe !default;\n\n/// Background color of the body.\n/// @type Color\n$body-background: $white !default;\n\n/// Text color of the body.\n/// @type Color\n$body-font-color: $black !default;\n\n/// Font stack of the body.\n/// @type List\n$body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif !default;\n\n/// Set to `true` to enable antialiased type, using the `-webkit-font-smoothing` and `-moz-osx-font-smoothing` CSS properties.\n/// @type Boolean\n$body-antialiased: true !default;\n\n/// Global value used for margin on components.\n/// @type Number\n$global-margin: 1rem !default;\n\n/// Global value used for padding on components.\n/// @type Number\n$global-padding: 1rem !default;\n\n/// Global value used for positioning on components.\n/// @type Number\n$global-position: 1rem !default;\n\n/// Global font weight used for normal type.\n/// @type Keyword | Number\n$global-weight-normal: normal !default;\n\n/// Global font weight used for bold type.\n/// @type Keyword | Number\n$global-weight-bold: bold !default;\n\n/// Global value used for all elements that have a border radius.\n/// @type Number\n$global-radius: 0 !default;\n\n/// Global value used for all menu styles. Can be overwritten at individual menu component level.\n/// @type Number\n$global-menu-padding: 0.7rem 1rem !default;\n\n/// Global value used for all menu styles. Nested margin for submenu.\n$global-menu-nested-margin: 1rem !default;\n\n/// Sets the text direction of the CSS. Can be either `ltr` or `rtl`.\n/// @type Keyword\n$global-text-direction: ltr !default;\n\n/// Enables flexbox for components that support it.\n/// @type Boolean\n$global-flexbox: true !default;\n\n/// Enabled responsive breakpoints for prototypes if applicable\n/// @type Boolean\n$global-prototype-breakpoints: false !default;\n\n/// Button cursor's value, `auto` by default\n/// @type Keyword\n$global-button-cursor: auto !default;\n\n@if not map-has-key($foundation-palette, primary) {\n  @error 'In $foundation-palette, you must have a color named \"primary\".';\n}\n\n// Internal variables used for text direction\n$global-left: if($global-text-direction == rtl, right, left);\n$global-right: if($global-text-direction == rtl, left, right);\n\n// Internal variable that contains the flex justifying options\n$-zf-flex-justify: -zf-flex-justify($global-text-direction);\n\n/// Global tolerance for color pick contrast.\n/// @type Number\n$global-color-pick-contrast-tolerance: 0 !default;\n\n// Internal variables used for colors\n@include add-foundation-colors;\n\n@mixin foundation-global-styles {\n  @include foundation-normalize;\n\n  // These styles are applied to a <meta> tag, which is read by the Foundation JavaScript\n  .foundation-mq {\n    font-family: '#{-zf-bp-serialize($breakpoints)}';\n  }\n\n  html {\n    box-sizing: border-box;\n    font-size: $global-font-size;\n  }\n\n  // Set box-sizing globally to handle padding and border widths\n  *,\n  *::before,\n  *::after {\n    box-sizing: inherit;\n  }\n\n  // Default body styles\n  body {\n    margin: 0;\n    padding: 0;\n\n    background: $body-background;\n\n    font-family: $body-font-family;\n    font-weight: $global-weight-normal;\n    line-height: $global-lineheight;\n    color: $body-font-color;\n\n    @if ($body-antialiased) {\n      -webkit-font-smoothing: antialiased; // sass-lint:disable-line no-vendor-prefixes\n      -moz-osx-font-smoothing: grayscale; // sass-lint:disable-line no-vendor-prefixes\n    }\n  }\n\n  img {\n    // Get rid of gap under images by making them display: inline-block; by default\n    display: inline-block;\n    vertical-align: middle;\n\n    // Grid defaults to get images and embeds to work properly\n    max-width: 100%;\n    height: auto;\n    -ms-interpolation-mode: bicubic;\n  }\n\n  // Make sure textarea takes on height automatically\n  textarea {\n    height: auto;\n    min-height: 50px;\n    border-radius: $global-radius;\n  }\n\n  // Make select elements are 100% width by default\n  select {\n    box-sizing: border-box;\n    width: 100%;\n    border-radius: $global-radius;\n  }\n\n  // Styles Google Maps and MapQuest embeds properly\n  // sass-lint:disable-line no-ids\n  .map_canvas,\n  .mqa-display {\n    img,\n    embed,\n    object {\n      max-width: none !important;\n    }\n  }\n\n  // Reset <button> styles created by most browsers\n  button {\n    @include disable-mouse-outline;\n    padding: 0;\n    appearance: none;\n    border: 0;\n    border-radius: $global-radius;\n    background: transparent;\n    line-height: 1;\n    cursor: $global-button-cursor;\n  }\n\n  // Prevent text overflow on pre\n  pre {\n    overflow: auto;\n  }\n\n  // Make reset inherit font-family instead of settings sans-serif\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit;\n  }\n\n  // Internal classes to show/hide elements in JavaScript\n  .is-visible {\n    display: block !important;\n  }\n\n  .is-hidden {\n    display: none !important;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n$global-font-size: 100% !default;\n\n/// Removes the unit (e.g. px, em, rem) from a value, returning the number only.\n///\n/// @param {Number} $num - Number to strip unit from.\n///\n/// @returns {Number} The same number, sans unit.\n@function strip-unit($num) {\n  @return $num / ($num * 0 + 1);\n}\n\n/// Converts one or more pixel values into matching rem values.\n///\n/// @param {Number|List} $values - One or more values to convert. Be sure to separate them with spaces and not commas. If you need to convert a comma-separated list, wrap the list in parentheses.\n/// @param {Number} $base [null] - The base value to use when calculating the `rem`. If you're using Foundation out of the box, this is 16px. If this parameter is `null`, the function will reference the `$global-font-size` variable as the base.\n///\n/// @returns {List} A list of converted values.\n@function rem-calc($values, $base: null) {\n  $rem-values: ();\n  $count: length($values);\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // If the base font size is a %, then multiply it by 16px\n  // This is because 100% font size = 16px in most all browsers\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  // Using rem as base allows correct scaling\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if $count == 1 {\n    @return -zf-to-rem($values, $base);\n  }\n\n  @for $i from 1 through $count {\n    $rem-values: append($rem-values, -zf-to-rem(nth($values, $i), $base));\n  }\n\n  @return $rem-values;\n}\n\n// Converts a unitless, pixel, or rem value to em, for use in breakpoints.\n@function -zf-bp-to-em($value) {\n  // Pixel and unitless values are converted to rems\n  @if unit($value) == 'px' or unitless($value) {\n    $value: rem-calc($value, $base: 16px);\n  }\n\n  // Then the value is converted to ems\n  @return strip-unit($value) * 1em;\n}\n\n/// Converts a pixel value to matching rem value. *Any* value passed, regardless of unit, is assumed to be a pixel value. By default, the base pixel value used to calculate the rem value is taken from the `$global-font-size` variable.\n/// @access private\n///\n/// @param {Number} $value - Pixel value to convert.\n/// @param {Number} $base [null] - Base for pixel conversion.\n///\n/// @returns {Number} A number in rems, calculated based on the given value and the base pixel value. rem values are passed through as is.\n@function -zf-to-rem($value, $base: null) {\n  // Check if the value is a number\n  @if type-of($value) != 'number' {\n    @warn inspect($value) + ' was passed to rem-calc(), which is not a number.';\n    @return $value;\n  }\n\n  // Transform em into rem if someone hands over 'em's\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * 1rem;\n  }\n\n  // Calculate rem if units for $value is not rem or em\n  @if unit($value) != 'rem' {\n    $value: strip-unit($value) / strip-unit($base) * 1rem;\n  }\n\n  // Turn 0rem into 0\n  @if $value == 0rem {\n    $value: 0;\n  }\n\n  @return $value;\n}\n\n/// Converts a pixel, percentage, rem or em value to a unitless value based on a given font size. Ideal for working out unitless line heights.\n///\n/// @param {Number} $value - Value to convert to a unitless line height\n/// @param {Number} $base - The font size to use to work out the line height - defaults to $global-font-size\n///\n/// @return {Number} - Unitless number\n@function unitless-calc($value, $base: null) {\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // First, lets convert our $base to pixels\n\n  // If the base font size is a %, then multiply it by 16px\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if unit($base) == 'em' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  // Now let's convert our value to pixels too\n  @if unit($value) == '%' {\n    $value: ($value / 100%) * $base;\n  }\n\n  @if unit($value) == 'rem' {\n    $value: strip-unit($value) * $base;\n  }\n\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * $base;\n  }\n\n  // 'px'\n  @if unit($value) == 'px' {\n    @return strip-unit($value) / strip-unit($base);\n  }\n\n  // assume that line-heights greater than 10 are meant to be absolute in 'px'\n  @if unitless($value) and ($value > 10) {\n    @return $value / strip-unit($base);\n  }\n\n  @return $value;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Creates an inner box-shadow for only one side\n///\n/// @param {Keyword} $side - Side the shadow is supposed to appear. Can be `top`, `left`, `right` or `bottom`.\n/// @param {Number} $size - Width for the target side.\n/// @param {Color} $color - Color of the shadow.\n@mixin inner-side-shadow(\n  $side: bottom,\n  $size: 20px,\n  $color: rgba($black, 0.25)\n) {\n\n  $helper: round($size * 0.65);\n\n  @if ($side == top) {\n    box-shadow: inset 0 $helper $size (-1)*$helper $color;\n  } @else if ($side == left) {\n    box-shadow: inset $helper 0 $size (-1)*$helper $color;\n  } @else if ($side == right) {\n    box-shadow: inset (-1)*$helper 0 $size (-1)*$helper $color;\n  } @else if ($side == bottom) {\n    box-shadow: inset 0 (-1)*$helper $size (-1)*$helper $color;\n  }\n}\n\n/// Creates a CSS triangle, which can be used for dropdown arrows, dropdown pips, and more. Use this mixin inside a `&::before` or `&::after` selector, to attach the triangle to an existing element.\n///\n/// @param {Number} $triangle-size - Width of the triangle.\n/// @param {Color} $triangle-color - Color of the triangle.\n/// @param {Keyword} $triangle-direction - Direction the triangle points. Can be `up`, `right`, `down`, or `left`.\n@mixin css-triangle(\n  $triangle-size,\n  $triangle-color,\n  $triangle-direction\n) {\n  display: block;\n  width: 0;\n  height: 0;\n\n  border: inset $triangle-size;\n\n  content: '';\n\n  @if ($triangle-direction == down) {\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: $triangle-color transparent transparent;\n  }\n  @if ($triangle-direction == up) {\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == right) {\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == left) {\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent $triangle-color transparent transparent;\n  }\n}\n\n/// Creates a menu icon with a set width, height, number of bars, and colors. The mixin uses the height of the icon and the weight of the bars to determine spacing. <div class=\"docs-example-burger\"></div>\n///\n/// @param {Color} $color [$black] - Color to use for the icon.\n/// @param {Color} $color-hover [$dark-gray] - Color to use when the icon is hovered over.\n/// @param {Number} $width [20px] - Width of the icon.\n/// @param {Number} $height [16px] - Height of the icon.\n/// @param {Number} $weight [2px] - Height of individual bars in the icon.\n/// @param {Number} $bars [3] - Number of bars in the icon.\n@mixin hamburger(\n  $color: $black,\n  $color-hover: $dark-gray,\n  $width: 20px,\n  $height: 16px,\n  $weight: 2px,\n  $bars: 3\n) {\n  // box-shadow CSS output\n  $shadow: ();\n  $hover-shadow: ();\n\n  // Spacing between bars is calculated based on the total height of the icon and the weight of each bar\n  $spacing: ($height - ($weight * $bars)) / ($bars - 1);\n\n  @if unit($spacing) == 'px' {\n    $spacing: floor($spacing);\n  }\n\n  @for $i from 2 through $bars {\n    $offset: ($weight + $spacing) * ($i - 1);\n    $shadow: append($shadow, 0 $offset 0 $color, comma);\n  }\n\n  // Icon container\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: $width;\n  height: $height;\n  cursor: pointer;\n\n  // Icon bars\n  &::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n\n    display: block;\n    width: 100%;\n    height: $weight;\n\n    background: $color;\n    box-shadow: $shadow;\n\n    content: '';\n  }\n\n  // Hover state\n  @if $color-hover {\n    // Generate CSS\n    @for $i from 2 through $bars {\n      $offset: ($weight + $spacing) * ($i - 1);\n      $hover-shadow: append($hover-shadow, 0 $offset 0 $color-hover, comma);\n    }\n\n    &:hover::after {\n      background: $color-hover;\n      box-shadow: $hover-shadow;\n    }\n  }\n}\n\n/// Adds a downward-facing triangle as a background image to an element. The image is formatted as an SVG, making it easy to change the color. Because Internet Explorer doesn't support encoded SVGs as background images, a PNG fallback is also included.\n/// There are two PNG fallbacks: a black triangle and a white triangle. The one used depends on the lightness of the input color.\n///\n/// @param {Color} $color [$black] - Color to use for the triangle.\n@mixin background-triangle($color: $black) {\n  $rgb: 'rgb%28#{round(red($color))}, #{round(green($color))}, #{round(blue($color))}%29';\n\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: #{$rgb}'></polygon></svg>\");\n\n  @media screen and (min-width:0\\0) {\n    @if lightness($color) < 60% {\n      // White triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==');\n    }\n    @else {\n      // Black triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAMBJREFUeNrEllsOhCAMRVszC9IlzU7KCmVHTJsoMWYMUtpyv9BgbuXQB5ZSdgBYYY4ycgBivk8KYFsQMfMiTTBP4o3nUzCKzOabLJbLy2/g31evGkAginR4/ZegKH5qX3bJCscA3t0x3kgO5tQFyhhFf50xRqFLbyMUNJQzgyjGS/wgCpvKqkRBpuWrE4V9d+1E4dPUXqIg107SQOE/2DRQxMwTDygIInVDET9T3lCoj/6j/VCmGjZOl2lKpZ8AAwDQP7zIimDGFQAAAABJRU5ErkJggg==');\n    }\n  }\n}\n\n/// Applies the micro clearfix hack popularized by Nicolas Gallagher. Include this mixin on a container if its children are all floated, to give the container a proper height.\n/// The clearfix is augmented with specific styles to prevent borders in flexbox environments\n/// @link http://nicolasgallagher.com/micro-clearfix-hack/ Micro Clearfix Hack\n/// @link http://danisadesigner.com/blog/flexbox-clear-fix-pseudo-elements/ Flexbox fix\n@mixin clearfix {\n  &::before,\n  &::after {\n    display: table;\n    content: ' ';\n\n    @if $global-flexbox {\n      flex-basis: 0;\n      order: 1;\n    }\n  }\n\n  &::after {\n    clear: both;\n  }\n}\n\n/// Adds CSS for a \"quantity query\" selector that automatically sizes elements based on how many there are inside a container.\n/// @link http://alistapart.com/article/quantity-queries-for-css Quantity Queries for CSS\n///\n/// @param {Number} $max - Maximum number of items to detect. The higher this number is, the more CSS that's required to cover each number of items.\n/// @param {Keyword} $elem [li] - Tag to use for sibling selectors.\n@mixin auto-width($max, $elem: li) {\n  @for $i from 2 through $max {\n    &:nth-last-child(#{$i}):first-child,\n    &:nth-last-child(#{$i}):first-child ~ #{$elem} {\n      width: percentage(1 / $i);\n    }\n  }\n}\n\n/// Removes the focus ring around an element when a mouse input is detected.\n@mixin disable-mouse-outline {\n  [data-whatinput='mouse'] & {\n    outline: 0;\n  }\n}\n\n/// Makes an element visually hidden, but still accessible to keyboards and assistive devices.\n/// @link http://snook.ca/archives/html_and_css/hiding-content-for-accessibility Hiding Content for Accessibility\n/// @link http://hugogiraudel.com/2016/10/13/css-hide-and-seek/\n@mixin element-invisible {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0,0,0,0);\n  white-space: nowrap;\n  border: 0;\n}\n\n/// Reverses the CSS output created by the `element-invisible()` mixin.\n@mixin element-invisible-off {\n  position: static !important;\n  width: auto;\n  height: auto;\n  overflow: visible;\n  clip: auto;\n  white-space: normal;\n}\n\n/// Vertically centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin vertical-center {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Horizontally centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin horizontal-center {\n  position: absolute;\n  left: 50%;\n  transform: translateX(-50%);\n}\n\n/// Absolutely centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin absolute-center {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n}\n\n/// Iterates through breakpoints defined in `$breakpoint-classes` and prints the CSS inside the mixin at each breakpoint's media query. Use this with the grid, or any other component that has responsive classes.\n///\n/// @param {Boolean} $small [true] - If `false`, the mixin will skip the `small` breakpoint. Use this with components that don't prefix classes with `small-`, only `medium-` and up.\n/// @param {Boolean} $auto-insert-breakpoints [true] - If `false`, the mixin will iterate over breakpoints without doing the media query itself. Useful for more complex media query generation as in the margin grid.\n@mixin -zf-each-breakpoint($small: true, $auto-insert-breakpoints: true) {\n  $list: $breakpoint-classes;\n\n  @if not $small {\n    $list: sl-remove($list, $-zf-zero-breakpoint);\n  }\n\n  @each $name in $list {\n    $old-zf-size: null;\n    @if global-variable-exists(-zf-size) {\n      $old-zf-size: $-zf-size;\n    }\n    $-zf-size: $name !global;\n\n    @if $auto-insert-breakpoints {\n      @include breakpoint($name) {\n        @content;\n      }\n    }\n    @else {\n      @content;\n    }\n\n    $-zf-size: $old-zf-size !global;\n  }\n}\n\n/// Generate the `@content` passed to the mixin with a value `$-zf-bp-value` related to a breakpoint, depending on the `$name` parameter:\n/// - For a single value, `$-zf-bp-value` is this value.\n/// - For a breakpoint name, `$-zf-bp-value` is the corresponding breakpoint value in `$map`.\n/// - For \"auto\", `$-zf-bp-value` is the corresponding breakpoint value in `$map` and is passed to `@content`, which is made responsive for each breakpoint of `$map`.\n/// @param {Number|Array|Keyword} $name [auto] - Single value, breakpoint name, or list of breakpoint names to use. \"auto\" by default.\n/// @param {Number|Map} $map - Map of breakpoints and values or single value to use.\n@mixin -zf-breakpoint-value(\n  $name: auto,\n  $map: null\n) {\n  @if $name == auto and type-of($map) == 'map' {\n    // \"auto\"\n    @each $k, $v in $map {\n      @include breakpoint($k) {\n        @include -zf-breakpoint-value($v, $map) {\n          @content;\n        }\n      }\n    }\n  }\n  @else {\n    // breakpoint name\n    @if type-of($name) == 'string' {\n      $name: -zf-get-bp-val($map, $name);\n    }\n\n    // breakpoint value\n    $-zf-bp-value: $name !global;\n    @content;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Font color of text inputs.\n/// @type Color\n$input-color: $black !default;\n\n/// Font color of placeholder text within text inputs.\n/// @type Color\n$input-placeholder-color: $medium-gray !default;\n\n/// Font family of text inputs.\n/// @type Font\n$input-font-family: inherit !default;\n\n/// Font size of text inputs.\n/// @type Number\n$input-font-size: rem-calc(16) !default;\n\n/// Font weight of text inputs.\n/// @type Keyword\n$input-font-weight: $global-weight-normal !default;\n\n/// Line height of text inputs.\n/// @type Keyword\n$input-line-height: $global-lineheight !default;\n\n/// Background color of text inputs.\n/// @type Color\n$input-background: $white !default;\n\n/// Background color of focused of text inputs.\n/// @type Color\n$input-background-focus: $white !default;\n\n/// Background color of disabled text inputs.\n/// @type Color\n$input-background-disabled: $light-gray !default;\n\n/// Border around text inputs.\n/// @type Border\n$input-border: 1px solid $medium-gray !default;\n\n/// Border around focused text inputs.\n/// @type Color\n$input-border-focus: 1px solid $dark-gray !default;\n\n/// Padding of text inputs.\n/// @type Color\n$input-padding: $form-spacing / 2 !default;\n\n/// Box shadow inside text inputs when not focused.\n/// @type Shadow\n$input-shadow: inset 0 1px 2px rgba($black, 0.1) !default;\n\n/// Box shadow outside text inputs when focused.\n/// @type Shadow\n$input-shadow-focus: 0 0 5px $medium-gray !default;\n\n/// Cursor to use when hovering over a disabled text input.\n/// @type Cursor\n$input-cursor-disabled: not-allowed !default;\n\n/// Properties to transition on text inputs.\n/// @type Transition\n$input-transition: box-shadow 0.5s, border-color 0.25s ease-in-out !default;\n\n/// Enables the up/down buttons that Chrome and Firefox add to `<input type='number'>` elements.\n/// @type Boolean\n$input-number-spinners: true !default;\n\n/// Radius for text inputs.\n/// @type Border\n$input-radius: $global-radius !default;\n\n/// Border radius for form buttons, defaulted to global-radius.\n/// @type Number\n$form-button-radius: $global-radius !default;\n\n@mixin form-element {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  border: $input-border;\n  border-radius: $input-radius;\n  background-color: $input-background;\n  box-shadow: $input-shadow;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n}\n\n@mixin foundation-form-text {\n  // Text inputs\n  #{text-inputs()},\n  textarea {\n    @include form-element;\n    appearance: none;\n  }\n\n  // Text areas\n  textarea {\n    max-width: 100%;\n\n    &[rows] {\n      height: auto;\n    }\n  }\n\n  input,\n  textarea {\n    // Disabled/readonly state\n    &:disabled,\n    &[readonly] {\n      background-color: $input-background-disabled;\n      cursor: $input-cursor-disabled;\n    }\n  }\n\n  // Reset styles on button-like inputs\n  [type='submit'],\n  [type='button'] {\n    appearance: none;\n    border-radius: $form-button-radius;\n  }\n\n  // Reset Normalize setting content-box to search elements\n  input[type='search'] { // sass-lint:disable-line no-qualifying-elements\n    box-sizing: border-box;\n  }\n\n  // Number input styles\n  [type='number'] {\n    @if not $input-number-spinners {\n      -moz-appearance: textfield; // sass-lint:disable-line no-vendor-prefixes\n\n      &::-webkit-inner-spin-button,\n      &::-webkit-outer-spin-button {\n        -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n        margin: 0;\n      }\n    }\n  }\n\n  // Placeholder text\n  ::placeholder {\n    color: $input-placeholder-color;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n@mixin foundation-form-checkbox {\n  [type='file'],\n  [type='checkbox'],\n  [type='radio'] {\n    margin: 0 0 $form-spacing;\n  }\n\n  // Styles for input/label siblings\n  [type='checkbox'] + label,\n  [type='radio'] + label {\n    display: inline-block;\n    vertical-align: baseline;\n\n    margin-#{$global-left}: $form-spacing * 0.5;\n    margin-#{$global-right}: $form-spacing;\n    margin-bottom: 0;\n\n    &[for] {\n      cursor: pointer;\n    }\n  }\n\n  // Styles for inputs inside labels\n  label > [type='checkbox'],\n  label > [type='radio'] {\n    margin-#{$global-right}: $form-spacing * 0.5;\n  }\n\n  // Normalize file input width\n  [type='file'] {\n    width: 100%;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color for form labels.\n/// @type Color\n$form-label-color: $black !default;\n\n/// Font size for form labels.\n/// @type Number\n$form-label-font-size: rem-calc(14) !default;\n\n/// Font weight for form labels.\n/// @type Keyword\n$form-label-font-weight: $global-weight-normal !default;\n\n/// Line height for form labels. The higher the number, the more space between the label and its input field.\n/// @type Number\n$form-label-line-height: 1.8 !default;\n\n@mixin form-label {\n  display: block;\n  margin: 0;\n\n  font-size: $form-label-font-size;\n  font-weight: $form-label-font-weight;\n  line-height: $form-label-line-height;\n  color: $form-label-color;\n}\n\n@mixin form-label-middle {\n  $input-border-width: get-border-value($input-border, width);\n\n  margin: 0 0 $form-spacing;\n  padding: ($form-spacing / 2 + rem-calc($input-border-width)) 0;\n}\n\n@mixin foundation-form-label {\n  label {\n    @include form-label;\n\n    &.middle {\n      @include form-label-middle;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default color for help text.\n/// @type Color\n$helptext-color: $black !default;\n\n/// Default font size for help text.\n/// @type Number\n$helptext-font-size: rem-calc(13) !default;\n\n/// Default font style for help text.\n/// @type Keyword\n$helptext-font-style: italic !default;\n\n@mixin foundation-form-helptext {\n  .help-text {\n    $margin-top: ($form-spacing * 0.5) * -1;\n\n    margin-top: $margin-top;\n    font-size: $helptext-font-size;\n    font-style: $helptext-font-style;\n    color: $helptext-color;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color of labels prefixed to an input.\n/// @type Color\n$input-prefix-color: $black !default;\n\n/// Background color of labels prefixed to an input.\n/// @type Color\n$input-prefix-background: $light-gray !default;\n\n/// Border around labels prefixed to an input.\n/// @type Border\n$input-prefix-border: 1px solid $medium-gray !default;\n\n/// Left/right padding of an pre/postfixed input label\n$input-prefix-padding: 1rem !default;\n\n@mixin foundation-form-prepostfix {\n  $height: ($input-font-size * $input-line-height) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  .input-group {\n    display: if($global-flexbox, flex, table);\n    width: 100%;\n    margin-bottom: $form-spacing;\n\n    @if $global-flexbox {\n      align-items: stretch;\n    }\n\n    > :first-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, 0 $input-radius $input-radius 0, $input-radius 0 0 $input-radius);\n      }\n    }\n\n    > :last-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, $input-radius 0 0 $input-radius, 0 $input-radius $input-radius 0);\n      }\n    }\n  }\n\n  %input-group-child {\n    margin: 0;\n    white-space: nowrap;\n\n    @if not $global-flexbox {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n\n  .input-group-label {\n    @extend %input-group-child;\n    padding: 0 $input-prefix-padding;\n    border: $input-prefix-border;\n    background: $input-prefix-background;\n\n    color: $input-prefix-color;\n    text-align: center;\n    white-space: nowrap;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n      align-items: center;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    @if has-value($input-prefix-border) {\n      &:first-child {\n        border-#{$global-right}: 0;\n      }\n\n      &:last-child {\n        border-#{$global-left}: 0;\n      }\n    }\n  }\n\n  .input-group-field {\n    @extend %input-group-child;\n    border-radius: 0;\n\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n      min-width: 0;\n    }\n  }\n\n  .input-group-button {\n    @extend %input-group-child;\n    padding-top: 0;\n    padding-bottom: 0;\n    text-align: center;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    a,\n    input,\n    button,\n    label {\n      @extend %input-group-child;\n\n      @if $global-flexbox {\n        align-self: stretch;\n        height: auto;\n      }\n      @else {\n        height: $height;\n      }\n      padding-top: 0;\n      padding-bottom: 0;\n      font-size: $input-font-size;\n    }\n  }\n\n  // Specificity bump needed to prevent override by buttons\n  @if not $global-flexbox {\n    .input-group {\n      .input-group-button {\n        display: table-cell;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default border around custom fieldsets.\n/// @type Border\n$fieldset-border: 1px solid $medium-gray !default;\n\n/// Default padding inside custom fieldsets.\n/// @type Number\n$fieldset-padding: rem-calc(20) !default;\n\n/// Default margin around custom fieldsets.\n/// @type Number\n$fieldset-margin: rem-calc(18 0) !default;\n\n/// Default padding between the legend text and fieldset border.\n/// @type Number\n$legend-padding: rem-calc(0 3) !default;\n\n@mixin fieldset {\n  margin: $fieldset-margin;\n  padding: $fieldset-padding;\n  border: $fieldset-border;\n\n  legend {\n    // Covers up the fieldset's border to create artificial padding\n    margin: 0;\n    margin-#{$global-left}: rem-calc(-3);\n    padding: $legend-padding;\n  }\n}\n\n@mixin foundation-form-fieldset {\n  fieldset {\n    margin: 0;\n    padding: 0;\n    border: 0;\n  }\n\n  legend {\n    max-width: 100%;\n    margin-bottom: $form-spacing * 0.5;\n  }\n\n  .fieldset {\n    @include fieldset;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Background color for select menus.\n/// @type Color\n$select-background: $white !default;\n\n/// Color of the dropdown triangle inside select menus. Set to `transparent` to remove it entirely.\n/// @type Color\n$select-triangle-color: $dark-gray !default;\n\n/// Default radius for select menus.\n/// @type Color\n$select-radius: $global-radius !default;\n\n@mixin form-select {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  appearance: none;\n  border: $input-border;\n  border-radius: $select-radius;\n  background-color: $select-background;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if $select-triangle-color != transparent {\n    @include background-triangle($select-triangle-color);\n    background-origin: content-box;\n    background-position: $global-right (-$form-spacing) center;\n    background-repeat: no-repeat;\n    background-size: 9px 6px;\n\n    padding-#{$global-right}: ($form-spacing * 1.5);\n  }\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n\n  // Disabled state\n  &:disabled {\n    background-color: $input-background-disabled;\n    cursor: $input-cursor-disabled;\n  }\n\n  // Hide the dropdown arrow shown in newer IE versions\n  &::-ms-expand {\n    display: none;\n  }\n\n  &[multiple] {\n    height: auto;\n    background-image: none;\n  }\n}\n\n@mixin foundation-form-select {\n  select {\n    @include form-select;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group abide\n////\n\n/// Sets if error styles should be added to inputs.\n/// @type Boolean\n$abide-inputs: true !default;\n\n/// Sets if error styles should be added to labels.\n/// @type Boolean\n$abide-labels: true !default;\n\n/// Background color to use for invalid text inputs.\n/// @type Color\n$input-background-invalid: get-color(alert) !default;\n\n/// Color to use for labels of invalid inputs.\n/// @type Color\n$form-label-color-invalid: get-color(alert) !default;\n\n/// Default font color for form error text.\n/// @type Color\n$input-error-color: get-color(alert) !default;\n\n/// Default font size for form error text.\n/// @type Number\n$input-error-font-size: rem-calc(12) !default;\n\n/// Default font weight for form error text.\n/// @type Keyword\n$input-error-font-weight: $global-weight-bold !default;\n\n/// Styles the background and border of an input field to have an error state.\n///\n/// @param {Color} $background [$alert-color] - Color to use for the background and border.\n/// @param {Number} $background-lighten [10%] - Lightness level of the background color.\n@mixin form-input-error(\n  $background: $input-background-invalid,\n  $background-lighten: 10%\n) {\n  &:not(:focus) {\n    border-color: $background;\n    background-color: mix($background, $white, $background-lighten);\n\n    &::placeholder {\n      color: $background;\n    }\n  }\n}\n\n/// Adds error styles to a form element, using the values in the settings file.\n@mixin form-error {\n  display: none;\n  margin-top: $form-spacing * -0.5;\n  margin-bottom: $form-spacing;\n\n  font-size: $input-error-font-size;\n  font-weight: $input-error-font-weight;\n  color: $input-error-color;\n}\n\n@mixin foundation-form-error {\n  @if $abide-inputs {\n    // Error class for invalid inputs\n    .is-invalid-input {\n      @include form-input-error;\n    }\n  }\n\n  @if $abide-labels {\n    // Error class for labels of invalid outputs\n    .is-invalid-label {\n      color: $form-label-color-invalid;\n    }\n  }\n\n  // Form error element\n  .form-error {\n    @include form-error;\n\n    &.is-visible {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group typography-base\n////\n\n// Base Typography\n// - - - - - - - - - - - - - - -\n// These are styles applied to basic HTML tags, including:\n//   - Paragraphs <p>\n//   - Bold/italics <b> <strong> <i> <em>\n//   - Small text <small>\n//   - Headings <h1>-<h6>\n//   - Anchors <a>\n//   - Dividers <hr>\n//   - Lists <ul> <ol> <dl>\n//   - Blockquotes <blockquote>\n//   - Code blocks <code>\n//   - Abbreviations <abbr>\n//   - Citations <cite>\n//   - Keystrokes <kbd>\n\n/// Font family for header elements.\n/// @type String | List\n$header-font-family: $body-font-family !default;\n\n/// Font weight of headers.\n/// @type String\n$header-font-weight: $global-weight-normal !default;\n\n/// Font style (e.g. italicized) of headers.\n/// @type String\n$header-font-style: normal !default;\n\n/// Font stack used for elements that use monospaced type, such as code samples\n/// @type String | List\n$font-family-monospace: Consolas, 'Liberation Mono', Courier, monospace !default;\n\n/// Color of headers.\n/// @type Color\n$header-color: inherit !default;\n\n/// Line height of headers.\n/// @type Number\n$header-lineheight: 1.4 !default;\n\n/// Bottom margin of headers.\n/// @type Number\n$header-margin-bottom: 0.5rem !default;\n\n/// Styles for headings at various screen sizes. Each key is a breakpoint, and each value is a map of heading styles.\n/// @type Map\n$header-styles: (\n  small: (\n    'h1': ('font-size': 24),\n    'h2': ('font-size': 20),\n    'h3': ('font-size': 19),\n    'h4': ('font-size': 18),\n    'h5': ('font-size': 17),\n    'h6': ('font-size': 16),\n  ),\n  medium: (\n    'h1': ('font-size': 48),\n    'h2': ('font-size': 40),\n    'h3': ('font-size': 31),\n    'h4': ('font-size': 25),\n    'h5': ('font-size': 20),\n    'h6': ('font-size': 16),\n  ),\n) !default;\n\n// $header-styles map is built from $header-sizes in order to ensure downward compatibility\n// when $header-sizes is depreciated, $header-styles needs to get !default values like settings.scss\n@function build_from_header-sizes($header-sizes) {\n  @warn 'Note, that $header-sizes has been replaced with $header-styles. $header-sizes still works, but it is going to be depreciated.';\n  $header-styles: ();\n  @each $size, $headers in $header-sizes {\n    $header-map: ();\n    @each $header, $font-size in $headers {\n      $header-map: map-merge($header-map, ($header: ('font-size': $font-size)));\n    }\n    $header-styles: map-merge($header-styles, ($size: $header-map));\n  }\n  @return $header-styles;\n}\n\n// If it exists $headers-sizes is used to build $header-styles. See the documentation.\n@if variable-exists(header-sizes) {\n  $header-styles: build_from_header-sizes($header-sizes);\n}\n\n/// Text rendering method of headers.\n/// @type String\n$header-text-rendering: optimizeLegibility !default;\n\n/// Font size of `<small>` elements.\n/// @type Number\n$small-font-size: 80% !default;\n\n/// Color of `<small>` elements when placed inside headers.\n/// @type Color\n$header-small-font-color: $medium-gray !default;\n\n/// Line height of text inside `<p>` elements.\n/// @type Number\n$paragraph-lineheight: 1.6 !default;\n\n/// Bottom margin of paragraphs.\n/// @type Number\n$paragraph-margin-bottom: 1rem !default;\n\n/// Text rendering method for paragraph text.\n/// @type String\n$paragraph-text-rendering: optimizeLegibility !default;\n\n/// Text color of code samples.\n/// @type Color\n$code-color: $black !default;\n\n/// Font family of code samples.\n/// @type String | List\n$code-font-family: $font-family-monospace !default;\n\n/// Font weight of text in code samples.\n/// @type String\n$code-font-weight: $global-weight-normal !default;\n\n/// Background color of code samples.\n/// @type Color\n$code-background: $light-gray !default;\n\n/// Border around code samples.\n/// @type List\n$code-border: 1px solid $medium-gray !default;\n\n/// Padding around text of code samples.\n/// @type Number | List\n$code-padding: rem-calc(2 5 1) !default;\n\n/// Default color for links.\n/// @type Color\n$anchor-color: $primary-color !default;\n\n/// Default color for links on hover.\n/// @type Color\n$anchor-color-hover: scale-color($anchor-color, $lightness: -14%) !default;\n\n/// Default text decoration for links.\n/// @type String\n$anchor-text-decoration: none !default;\n\n/// Default text decoration for links on hover.\n/// @type String\n$anchor-text-decoration-hover: none !default;\n\n/// Maximum width of a divider.\n/// @type Number\n$hr-width: $global-width !default;\n\n/// Default border for a divider.\n/// @type List\n$hr-border: 1px solid $medium-gray !default;\n\n/// Default margin for a divider.\n/// @type Number | List\n$hr-margin: rem-calc(20) auto !default;\n\n/// Line height for items in a list.\n/// @type Number\n$list-lineheight: $paragraph-lineheight !default;\n\n/// Bottom margin for items in a list.\n/// @type Number\n$list-margin-bottom: $paragraph-margin-bottom !default;\n\n/// Bullet type to use for unordered lists (e.g., `square`, `circle`, `disc`).\n/// @type String\n$list-style-type: disc !default;\n\n/// Positioning for bullets on unordered list items.\n/// @type String\n$list-style-position: outside !default;\n\n/// Left (or right) margin for lists.\n/// @type Number\n$list-side-margin: 1.25rem !default;\n\n/// Left (or right) margin for a list inside a list.\n/// @type Number\n$list-nested-side-margin: 1.25rem !default;\n\n/// Bottom margin for `<dl>` elements.\n/// @type Number\n$defnlist-margin-bottom: 1rem !default;\n\n/// Font weight for `<dt>` elements.\n/// @type String\n$defnlist-term-weight: $global-weight-bold !default;\n\n/// Spacing between `<dt>` and `<dd>` elements.\n/// @type Number\n$defnlist-term-margin-bottom: 0.3rem !default;\n\n/// Text color of `<blockquote>` elements.\n/// @type Color\n$blockquote-color: $dark-gray !default;\n\n/// Padding inside a `<blockquote>` element.\n/// @type Number | List\n$blockquote-padding: rem-calc(9 20 0 19) !default;\n\n/// Side border for `<blockquote>` elements.\n/// @type List\n$blockquote-border: 1px solid $medium-gray !default;\n\n/// Font size for `<cite>` elements.\n/// @type Number\n$cite-font-size: rem-calc(13) !default;\n\n/// Text color for `<cite>` elements.\n/// @type Color\n$cite-color: $dark-gray !default;\n\n/// Pseudo content for `<cite>` elements.\n/// @type String\n$cite-pseudo-content: '\\2014 \\0020' !default;\n\n/// Font family for `<kbd>` elements.\n/// @type String | List\n$keystroke-font: $font-family-monospace !default;\n\n/// Text color for `<kbd>` elements.\n/// @type Color\n$keystroke-color: $black !default;\n\n/// Background color for `<kbd>` elements.\n/// @type Color\n$keystroke-background: $light-gray !default;\n\n/// Padding for `<kbd>` elements.\n/// @type Number | List\n$keystroke-padding: rem-calc(2 4 0) !default;\n\n/// Border radius for `<kbd>` elements.\n/// @type Number | List\n$keystroke-radius: $global-radius !default;\n\n/// Bottom border style for `<abbr>` elements.\n/// @type List\n$abbr-underline: 1px dotted $black !default;\n\n@mixin foundation-typography-base {\n  // Typography resets\n  div,\n  dl,\n  dt,\n  dd,\n  ul,\n  ol,\n  li,\n  h1,\n  h2,\n  h3,\n  h4,\n  h5,\n  h6,\n  pre,\n  form,\n  p,\n  blockquote,\n  th,\n  td {\n    margin: 0;\n    padding: 0;\n  }\n\n  // Paragraphs\n  p {\n    margin-bottom: $paragraph-margin-bottom;\n\n    font-size: inherit;\n    line-height: $paragraph-lineheight;\n    text-rendering: $paragraph-text-rendering;\n  }\n\n  // Emphasized text\n  em,\n  i {\n    font-style: italic;\n    line-height: inherit;\n  }\n\n  // Strong text\n  strong,\n  b {\n    font-weight: $global-weight-bold;\n    line-height: inherit;\n  }\n\n  // Small text\n  small {\n    font-size: $small-font-size;\n    line-height: inherit;\n  }\n\n  // Headings\n  h1, .h1,\n  h2, .h2,\n  h3, .h3,\n  h4, .h4,\n  h5, .h5,\n  h6, .h6 {\n    font-family: $header-font-family;\n    font-style: $header-font-style;\n    font-weight: $header-font-weight;\n    color: $header-color;\n    text-rendering: $header-text-rendering;\n\n    small {\n      line-height: 0;\n      color: $header-small-font-color;\n    }\n  }\n\n  // Heading styles\n  @each $size, $headers in $header-styles {\n    @include breakpoint($size) {\n      @each $header, $header-defs in $headers {\n        $font-size-temp: 1rem;\n        #{$header}, .#{$header} {\n\n          @if map-has-key($header-defs, font-size) {\n            $font-size-temp: rem-calc(map-get($header-defs, font-size));\n            font-size: $font-size-temp;\n          } @else if map-has-key($header-defs, fs) {\n            $font-size-temp: rem-calc(map-get($header-defs, fs));\n            font-size: $font-size-temp;\n          } @else if $size == $-zf-zero-breakpoint {\n            font-size: $font-size-temp;\n          }\n          @if map-has-key($header-defs, line-height) {\n            line-height: unitless-calc(map-get($header-defs, line-height), $font-size-temp);\n          } @else if map-has-key($header-defs, lh) {\n            line-height: unitless-calc(map-get($header-defs, lh), $font-size-temp);\n          } @else if $size == $-zf-zero-breakpoint {\n            line-height: unitless-calc($header-lineheight, $font-size-temp);\n          }\n\n          @if map-has-key($header-defs, margin-top) {\n            margin-top: rem-calc(map-get($header-defs, margin-top));\n          } @else if map-has-key($header-defs, mt) {\n            margin-top: rem-calc(map-get($header-defs, mt));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-top: 0;\n          }\n          @if map-has-key($header-defs, margin-bottom) {\n            margin-bottom: rem-calc(map-get($header-defs, margin-bottom));\n          } @else if map-has-key($header-defs, mb) {\n            margin-bottom: rem-calc(map-get($header-defs, mb));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-bottom: rem-calc($header-margin-bottom);\n          }\n        }\n      }\n    }\n  }\n\n  // Links\n  a {\n    line-height: inherit;\n    color: $anchor-color;\n    text-decoration: $anchor-text-decoration;\n\n    cursor: pointer;\n\n    &:hover,\n    &:focus {\n      color: $anchor-color-hover;\n      @if $anchor-text-decoration-hover != $anchor-text-decoration {\n        text-decoration: $anchor-text-decoration-hover;\n      }\n    }\n\n    img {\n      border: 0;\n    }\n  }\n\n  // Horizontal rule\n  hr {\n    clear: both;\n\n    max-width: $hr-width;\n    height: 0;\n    margin: $hr-margin;\n\n    border-top: 0;\n    border-right: 0;\n    border-bottom: $hr-border;\n    border-left: 0;\n  }\n\n  // Lists\n  ul,\n  ol,\n  dl {\n    margin-bottom: $list-margin-bottom;\n    list-style-position: $list-style-position;\n    line-height: $list-lineheight;\n  }\n\n  // List items\n  li {\n    font-size: inherit;\n  }\n\n  // Unordered lists\n  ul {\n    margin-#{$global-left}: $list-side-margin;\n    list-style-type: $list-style-type;\n  }\n\n  // Ordered lists\n  ol {\n    margin-#{$global-left}: $list-side-margin;\n  }\n\n  // Nested unordered/ordered lists\n  ul, ol {\n    & & {\n      margin-#{$global-left}: $list-nested-side-margin;\n      margin-bottom: 0;\n    }\n  }\n\n  // Definition lists\n  dl {\n    margin-bottom: $defnlist-margin-bottom;\n\n    dt {\n      margin-bottom: $defnlist-term-margin-bottom;\n      font-weight: $defnlist-term-weight;\n    }\n  }\n\n  // Blockquotes\n  blockquote {\n    margin: 0 0 $paragraph-margin-bottom;\n    padding: $blockquote-padding;\n    border-#{$global-left}: $blockquote-border;\n\n    &, p {\n      line-height: $paragraph-lineheight;\n      color: $blockquote-color;\n    }\n  }\n\n  // Citations\n  cite {\n    display: block;\n    font-size: $cite-font-size;\n    color: $cite-color;\n\n    &:before {\n      content: $cite-pseudo-content;\n    }\n  }\n\n  // Abbreviations\n  abbr, abbr[title] {\n    border-bottom: $abbr-underline;\n    cursor: help;\n    text-decoration: none;\n  }\n\n  // Figures\n  figure {\n    margin: 0;\n  }\n\n  // Code\n  code {\n    padding: $code-padding;\n\n    border: $code-border;\n    background-color: $code-background;\n\n    font-family: $code-font-family;\n    font-weight: $code-font-weight;\n    color: $code-color;\n  }\n\n  // Keystrokes\n  kbd {\n    margin: 0;\n    padding: $keystroke-padding;\n\n    background-color: $keystroke-background;\n\n    font-family: $keystroke-font;\n    color: $keystroke-color;\n\n    @if has-value($keystroke-radius) {\n      border-radius: $keystroke-radius;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group typography-helpers\n////\n\n/// Default font size for lead paragraphs.\n/// @type Number\n$lead-font-size: $global-font-size * 1.25 !default;\n\n/// Default line height for lead paragraphs.\n/// @type String\n$lead-lineheight: 1.6 !default;\n\n/// Default line height for subheaders.\n/// @type Number\n$subheader-lineheight: 1.4 !default;\n\n/// Default font color for subheaders.\n/// @type Color\n$subheader-color: $dark-gray !default;\n\n/// Default font weight for subheaders.\n/// @type String\n$subheader-font-weight: $global-weight-normal !default;\n\n/// Default top margin for subheaders.\n/// @type Number\n$subheader-margin-top: 0.2rem !default;\n\n/// Default bottom margin for subheaders.\n/// @type Number\n$subheader-margin-bottom: 0.5rem !default;\n\n/// Default font size for statistic numbers.\n/// @type Number\n$stat-font-size: 2.5rem !default;\n\n@mixin foundation-typography-helpers {\n  // Use to create a subheading under a main header\n  // Make sure you pair the two elements in a <header> element, like this:\n  // <header>\n  //   <h1>Heading</h1>\n  //   <h2>Subheading</h2>\n  // </header>\n  .subheader {\n    margin-top: $subheader-margin-top;\n    margin-bottom: $subheader-margin-bottom;\n\n    font-weight: $subheader-font-weight;\n    line-height: $subheader-lineheight;\n    color: $subheader-color;\n  }\n\n  // Use to style an introductory lead, deck, blurb, etc.\n  .lead {\n    font-size: $lead-font-size;\n    line-height: $lead-lineheight;\n  }\n\n  // Use to style a large number to display a statistic\n  .stat {\n    font-size: $stat-font-size;\n    line-height: 1;\n\n    p + & {\n      margin-top: -1rem;\n    }\n  }\n\n  ul, ol {\n    // Use to remove numbers from ordered list & bullets from unordered list\n    &.no-bullet {\n      margin-#{$global-left}: 0;\n      list-style: none;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@mixin foundation-text-alignment {\n  @each $size in $breakpoint-classes {\n    @include breakpoint($size) {\n      @each $align in (left, right, center, justify) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-text-#{$align} {\n            text-align: $align;\n          }\n        }\n        @else {\n          .text-#{$align} {\n            text-align: $align;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// If `true`, all elements will have transparent backgrounds when printed, to save on ink.\n/// @type Boolean\n/// @group global\n$print-transparent-backgrounds: true !default;\n\n/// If `true`, displays next to all links their \"href\" when printed.\n/// @type Boolean\n/// @group global\n$print-hrefs: true !default;\n\n// sass-lint:disable-all\n\n@mixin foundation-print-styles {\n  .show-for-print { display: none !important; }\n\n  @media print {\n    * {\n      @if $print-transparent-backgrounds {\n        background: transparent !important;\n      }\n\n      box-shadow: none !important;\n\n      color: black !important; // Black prints faster: h5bp.com/s\n      text-shadow: none !important;\n    }\n\n    .show-for-print { display: block !important; }\n    .hide-for-print { display: none !important; }\n\n    table.show-for-print { display: table !important; }\n    thead.show-for-print { display: table-header-group !important; }\n    tbody.show-for-print { display: table-row-group !important; }\n    tr.show-for-print { display: table-row !important; }\n    td.show-for-print { display: table-cell !important; }\n    th.show-for-print { display: table-cell !important; }\n\n    // Display the URL of a link after the text\n    a,\n    a:visited { text-decoration: underline;}\n    @if $print-hrefs {\n      a[href]:after { content: ' (' attr(href) ')'; }\n    }\n\n    // Don't display the URL for images or JavaScript/internal links\n    .ir a:after,\n    a[href^='javascript:']:after,\n    a[href^='#']:after { content: ''; }\n\n    // Display what an abbreviation stands for after the text\n    abbr[title]:after { content: ' (' attr(title) ')'; }\n\n    // Prevent page breaks in the middle of a blockquote or preformatted text block\n    pre,\n    blockquote {\n      border: 1px solid $dark-gray;\n      page-break-inside: avoid;\n    }\n\n    // h5bp.com/t\n    thead { display: table-header-group; }\n\n    tr,\n    img { page-break-inside: avoid; }\n\n    img { max-width: 100% !important; }\n\n    @page { margin: 0.5cm; }\n\n    p,\n    h2,\n    h3 {\n      orphans: 3;\n      widows: 3;\n    }\n\n    // Avoid page breaks after a heading\n    h2,\n    h3 { page-break-after: avoid; }\n\n    // Helper to re-allow page breaks in the middle of certain elements (e.g. pre, blockquote, tr)\n    .print-break-inside {\n      page-break-inside: auto;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Outputs CSS classes for the grid.\n/// @access private\n@mixin foundation-grid(\n  $row: 'row',\n  $column: 'column',\n  $column-row: 'column-row',\n  $gutter: 'gutter',\n  $push: 'push',\n  $pull: 'pull',\n  $center: 'centered',\n  $uncenter: 'uncentered',\n  $collapse: 'collapse',\n  $uncollapse: 'uncollapse',\n  $offset: 'offset',\n  $end: 'end',\n  $expanded: 'expanded',\n  $block: 'block'\n) {\n  // Row\n  .#{$row} {\n    @include grid-row;\n\n    // Collapsing\n    &.#{$collapse} {\n      > .#{$column} {\n        @include grid-col-collapse;\n      }\n    }\n\n    // Nesting\n    & .#{$row} {\n      @include grid-row-nest($grid-column-gutter);\n\n      &.#{$collapse} {\n        margin-right: 0;\n        margin-left: 0;\n      }\n    }\n\n    // Expanded (full-width) row\n    &.#{$expanded} {\n      @include grid-row-size(expand);\n\n      .#{$row} {\n        margin-right: auto;\n        margin-left: auto;\n      }\n    }\n\n    &:not(.#{$expanded}) .#{$row} {\n      @include grid-row-size(expand);\n    }\n\n    @if type-of($grid-column-gutter) == 'map' {\n      // Static (unresponsive) row gutters\n      //\n      @each $breakpoint, $value in $grid-column-gutter {\n        &.#{$gutter}-#{$breakpoint} {\n          > .#{$column} {\n            @include grid-col-gutter($value);\n          }\n        }\n      }\n    }\n  }\n\n  // Column\n  .#{$column} {\n    @include grid-col;\n\n    @if $grid-column-align-edge {\n      &.#{$end} {\n        @include grid-col-end;\n      }\n    }\n  }\n\n  // Column row\n  // The double .row class is needed to bump up the specificity\n  .#{$column}.#{$row}.#{$row} {\n    float: none;\n  }\n\n  // To properly nest a column row, padding and margin is removed\n  .#{$row} .#{$column}.#{$row}.#{$row} {\n    margin-right: 0;\n    margin-left: 0;\n    padding-right: 0;\n    padding-left: 0;\n  }\n\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $grid-column-count {\n      // Column width\n      .#{$-zf-size}-#{$i} {\n        @include grid-col-size($i);\n      }\n\n      // Source ordering\n      @if $i < $grid-column-count {\n        .#{$-zf-size}-#{$push}-#{$i} {\n          @include grid-col-pos($i);\n        }\n\n        .#{$-zf-size}-#{$pull}-#{$i} {\n          @include grid-col-pos(-$i);\n        }\n      }\n\n      // Offsets\n      $o: $i - 1;\n\n      .#{$-zf-size}-#{$offset}-#{$o} {\n        @include grid-col-off($o);\n      }\n    }\n\n    // Block grid\n    @for $i from 1 through $block-grid-max {\n      .#{$-zf-size}-up-#{$i} {\n        @include grid-layout($i, '.#{$column}');\n      }\n    }\n\n    // Responsive collapsing\n    .#{$-zf-size}-#{$collapse} {\n      > .#{$column} { @include grid-col-collapse; }\n\n      .#{$row} {\n        margin-right: 0;\n        margin-left: 0;\n      }\n    }\n\n    .#{$expanded}.#{$row} .#{$-zf-size}-#{$collapse}.#{$row} {\n      margin-right: 0;\n      margin-left: 0;\n    }\n\n    .#{$-zf-size}-#{$uncollapse} {\n      > .#{$column} { @include grid-col-gutter($-zf-size); }\n    }\n\n    // Positioning\n    .#{$-zf-size}-#{$center} {\n      @include grid-col-pos(center);\n    }\n\n    // Gutter adjustment\n    .#{$-zf-size}-#{$uncenter},\n    .#{$-zf-size}-#{$push}-0,\n    .#{$-zf-size}-#{$pull}-0 {\n      @include grid-col-unpos;\n    }\n  }\n\n  // Block grid columns\n  .#{$column}-#{$block} {\n    @include grid-column-margin;\n  }\n\n  @if $column == 'column' and has-value($grid-column-alias) {\n    .#{$grid-column-alias} {\n      // sass-lint:disable-block placeholder-in-extend\n      @extend .column;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Change the behavior of columns defined inside this mixin to use a different column count.\n/// @content\n///\n/// @param {Number} $columns - Number of columns to use.\n/// @param {Boolean} $root [false]\n///   If `false`, selectors inside this mixin will nest inside the parent selector.\n///   If `true`, selectors will not nest.\n@mixin grid-context(\n  $columns,\n  $root: false\n) {\n  // Store the current column count so it can be re-set later\n  $old-grid-column-count: $grid-column-count;\n  $grid-column-count: $columns !global;\n\n  @if $root {\n    @at-root { @content; }\n  }\n  @else {\n    @content;\n  }\n\n  // Restore the old column count\n  $grid-column-count: $old-grid-column-count !global;\n}\n\n/// Creates a grid row.\n/// @content\n///\n/// @param {Number} $columns [null] - Column count for this row. `null` will use the default column count.\n/// @param {Keywords} $behavior [null]\n///   Modifications to the default grid styles. `nest` indicates the row will be placed inside another row. `collapse` indicates that the columns inside this row will not have padding. `nest collapse` combines both behaviors.\n/// @param {Keyword|Number} $size [$grid-row-width] Maximum size of the row. Set to `expand` to make the row taking the full width.\n/// @param {Boolean} $cf [true] - Whether or not to include a clearfix.\n/// @param {Number|Map} $gutters [$grid-column-gutter] - Gutter map or single value to use when inverting margins. Responsive gutter settings by default.\n@mixin grid-row(\n  $columns: null,\n  $behavior: null,\n  $size: $grid-row-width,\n  $cf: true,\n  $gutters: $grid-column-gutter\n) {\n  $margin: auto;\n\n  @if index($behavior, nest) != null {\n    @include grid-row-nest($gutters);\n\n    @if index($behavior, collapse) != null {\n      margin-right: 0;\n      margin-left: 0;\n    }\n  }\n  @else {\n    @include grid-row-size($size);\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  @if $cf {\n    @include clearfix;\n  }\n\n  @if $columns != null {\n    @include grid-context($columns) {\n      @content;\n    }\n  }\n}\n\n/// Inverts the margins of a row to nest it inside of a column.\n///\n/// @param {Number|Map} $gutters [$grid-column-gutter] - Gutter map or single value to use when inverting margins. Responsive gutter settings by default.\n@mixin grid-row-nest($gutters: $grid-column-gutter) {\n  @include -zf-each-breakpoint {\n    $margin: rem-calc(-zf-get-bp-val($gutters, $-zf-size)) / 2 * -1;\n\n    margin-right: $margin;\n    margin-left: $margin;\n  }\n}\n\n/// Set a grid row size\n///\n/// @param {Keyword|Number} $size [$grid-row-width] Maximum size of the row. Set to `expand` to make the row taking the full width.\n@mixin grid-row-size($size: $grid-row-width) {\n  @if $size == expand {\n    $size: none;\n  }\n\n  max-width: $size;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Set the gutters on a column\n/// @param {Number|Keyword} $gutter [auto]\n///   Spacing between columns, accepts multiple values:\n///   - A single value will make the gutter that exact size.\n///   - A breakpoint name will make the gutter the corresponding size in the $gutters map.\n///   - \"auto\" will make the gutter responsive, using the $gutters map values.\n/// @param {Number|Map} $gutters [$grid-column-gutter] - Gutter map or single value to use. Responsive gutter settings by default.\n@mixin grid-column-gutter(\n  $gutter: auto,\n  $gutters: $grid-column-gutter\n) {\n  @include -zf-breakpoint-value($gutter, $gutters) {\n    $padding: rem-calc($-zf-bp-value) / 2;\n\n    padding-right: $padding;\n    padding-left: $padding;\n  }\n}\n\n/// Collapse the gutters on a column by removing the padding. **Note:** only use this mixin within a breakpoint. To collapse a column's gutters on all screen sizes, use the `$gutter` parameter of the `grid-column()` mixin instead.\n@mixin grid-column-collapse {\n  @include grid-column-gutter(0);\n}\n\n/// Shorthand for `grid-column-gutter()`.\n/// @alias grid-column-gutter\n@mixin grid-col-gutter(\n  $gutter: auto,\n  $gutters: $grid-column-gutter\n) {\n  @include grid-column-gutter($gutter, $gutters);\n}\n\n/// Shorthand for `grid-column-collapse()`.\n/// @alias grid-column-collapse\n@mixin grid-col-collapse {\n  @include grid-column-collapse;\n}\n\n/// Sets bottom margin on grid columns to match gutters\n/// @param {Number|Keyword} $margin [auto]\n///   The bottom margin on grid columns, accepts multiple values:\n///   - A single value will make the margin that exact size.\n///   - A breakpoint name will make the margin the corresponding size in the $margins map.\n///   - \"auto\" will make the margin responsive, using the $margins map values.\n/// @param {Number|Map} $margins [$grid-column-gutter] - Map or single value to use. Responsive gutter settings by default.\n@mixin grid-column-margin (\n  $margin: auto,\n  $margins: $grid-column-gutter\n) {\n  @include -zf-breakpoint-value($margin, $margins) {\n    $margin-bottom: rem-calc($-zf-bp-value);\n    margin-bottom: $margin-bottom;\n\n    > :last-child {\n      margin-bottom: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Set the width of a grid column.\n///\n/// @param {Number|List} $width [$grid-column-count] - Width to make the column. You can pass in any value accepted by the `grid-column()` function, such as `6`, `50%`, or `1 of 2`.\n@mixin grid-column-size(\n  $columns: $grid-column-count\n) {\n  width: grid-column($columns);\n}\n\n/// Shorthand for `grid-column-size()`.\n/// @alias grid-column-size\n@mixin grid-col-size(\n  $columns: $grid-column-count\n) {\n  @include grid-column-size($columns);\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Calculates the width of a column based on a number of factors.\n///\n/// @param {Number|List} $columns\n///   Width of the column. Accepts multiple values:\n///   - A percentage value will make the column that exact size.\n///   - A single digit will make the column span that number of columns wide, taking into account the column count of the parent row.\n///   - A list of the format \"x of y\" (without quotes) will make a column that is *x* columns wide, assuming *y* total columns for the parent.\n///\n/// @returns {Number} A calculated percentage value.\n@function grid-column($columns) {\n  $width: 0%;\n\n  // Parsing percents, decimals, and column counts\n  @if type-of($columns) == 'number' {\n    @if unit($columns) == '%' {\n      $width: $columns;\n    }\n    @else if $columns < 1 {\n      $width: percentage($columns);\n    }\n    @else {\n      $width: percentage($columns / $grid-column-count);\n    }\n  }\n\n  // Parsing \"n of n\" expressions\n  @else if type-of($columns) == 'list' {\n    @if length($columns) != 3 {\n      @error 'Wrong syntax for grid-column(). Use the format \"n of n\".';\n    }\n    @else {\n      $width: percentage(nth($columns, 1) / nth($columns, 3));\n    }\n  }\n\n  // Anything else is incorrect\n  @else {\n    @error 'Wrong syntax for grid-column(). Use a number, decimal, percentage, or \"n of n\".';\n  }\n\n  @return $width;\n}\n\n/// Creates a grid column.\n///\n/// @param {Mixed} $columns [$grid-column-count] - Width of the column. Refer to the `grid-column()` function to see possible values.\n/// @param {Mixed} $gutters [$grid-column-gutter] - Spacing between columns. Refer to the `grid-column-gutter()` function to see possible values.\n@mixin grid-column(\n  $columns: $grid-column-count,\n  $gutters: $grid-column-gutter\n) {\n  @include grid-column-size($columns);\n  float: $global-left;\n\n  // Gutters\n  @include grid-column-gutter($gutters: $gutters);\n\n  // Position\n  @include grid-col-pos(auto);\n}\n\n/// Creates a grid column row. This is the equivalent of adding `.row` and `.column` to the same element.\n///\n/// @param {Mixed} $gutters [$grid-column-gutter] - Width of the gutters on either side of the column row. Refer to the `grid-column-gutter()` function to see possible values.\n@mixin grid-column-row(\n  $gutters: $grid-column-gutter\n) {\n  @include grid-row;\n  @include grid-column($gutters: $gutters);\n\n  &,\n  &:last-child {\n    float: none;\n  }\n}\n\n/// Shorthand for `grid-column()`.\n/// @alias grid-column\n@function grid-col(\n  $columns: $grid-column-count\n) {\n  @return grid-column($columns);\n}\n\n/// Shorthand for `grid-column()`.\n/// @alias grid-column\n@mixin grid-col(\n  $columns: $grid-column-count,\n  $gutters: $grid-column-gutter\n) {\n  @include grid-column($columns, $gutters);\n}\n\n/// Shorthand for `grid-column-row()`.\n/// @alias grid-column-row\n@mixin grid-col-row(\n  $gutters: $grid-column-gutter\n) {\n  @include grid-column-row($gutters);\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Reposition a column.\n///\n/// @param {Number|Keyword} $position - It can be:\n///   * A number: The column will move equal to the width of the column count\n///     specified. A positive number will push the column to the right, while\n///     a negative number will pull it to the left.\n///   * `center`: Column will be centered\n///   * `auto`: Column will be pushed to the left (or to the right for the last column).\n@mixin grid-column-position($position) {\n  // Auto positioning\n  @if $position == auto {\n    &, &:last-child:not(:first-child) {\n      float: $global-left;\n      clear: none;\n    }\n\n    // Last column alignment\n    @if $grid-column-align-edge {\n      &:last-child:not(:first-child) {\n        float: $global-right;\n      }\n    }\n  }\n\n  // Push/pull\n  @else if type-of($position) == 'number' {\n    $offset: percentage($position / $grid-column-count);\n\n    position: relative;\n    #{$global-left}: $offset;\n  }\n\n  // Center positioning\n  @else if $position == center {\n    &, &:last-child:not(:first-child) {\n      float: none;\n      clear: both;\n    }\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  @else {\n    @warn 'Wrong syntax for grid-column-position(). Enter a positive or negative number, \"center\" or \"auto\".';\n  }\n}\n\n/// Reset a position definition.\n@mixin grid-column-unposition {\n  @include grid-column-position(auto);\n  position: static;\n  margin-right: 0;\n  margin-left: 0;\n}\n\n/// Offsets a column to the right by `$n` columns.\n/// @param {Number|List} $n - Width to offset by. You can pass in any value accepted by the `grid-column()` mixin, such as `6`, `50%`, or `1 of 2`.\n@mixin grid-column-offset($n) {\n  margin-#{$global-left}: grid-column($n);\n}\n\n/// Disable the default behavior of the last column in a row aligning to the opposite edge.\n@mixin grid-column-end {\n  // This extra specificity is required for the property to be applied\n  &:last-child:last-child {\n    float: $global-left;\n  }\n}\n\n/// Shorthand for `grid-column-position()`.\n/// @alias grid-column-position\n@mixin grid-col-pos($position) {\n  @include grid-column-position($position);\n}\n\n/// Shorthand for `grid-column-unposition()`.\n/// @alias grid-column-unposition\n@mixin grid-col-unpos {\n  @include grid-column-unposition;\n}\n\n/// Shorthand for `grid-column-offset()`.\n/// @alias grid-column-offset\n@mixin grid-col-off($n) {\n  @include grid-column-offset($n);\n}\n\n/// Shorthand for `grid-column-end()`.\n/// @alias grid-column-end\n@mixin grid-col-end {\n  @include grid-column-end;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group grid\n////\n\n/// Sizes child elements so that `$n` number of items appear on each row.\n///\n/// @param {Number} $n - Number of elements to display per row.\n/// @param {String} $selector ['.column'] - Selector(s) to use for child elements.\n/// @param {Number|List} $gutter\n///   The gutter to apply to child elements. Accepts multiple values:\n///   - $grid-column-gutter will use the values in the $grid-column-gutter map, including breakpoint sizes.\n///   - A fixed numeric value will apply this gutter to all breakpoints.\n@mixin grid-layout(\n  $n,\n  $selector: '.column',\n  $gutter: null\n) {\n  & > #{$selector} {\n    float: $global-left;\n    width: percentage(1/$n);\n\n    // If a $gutter value is passed\n    @if($gutter) {\n      // Gutters\n      @if type-of($gutter) == 'map' {\n        @each $breakpoint, $value in $gutter {\n          $padding: rem-calc($value) / 2;\n\n          @include breakpoint($breakpoint) {\n            padding-right: $padding;\n            padding-left: $padding;\n          }\n        }\n      }\n      @else if type-of($gutter) == 'number' and strip-unit($gutter) > 0 {\n        $padding: rem-calc($gutter) / 2;\n        padding-right: $padding;\n        padding-left: $padding;\n      }\n    }\n\n    &:nth-of-type(1n) {\n      clear: none;\n    }\n\n    &:nth-of-type(#{$n}n+1) {\n      clear: both;\n    }\n\n    &:last-child {\n      float: $global-left;\n    }\n  }\n}\n\n/// Adds extra CSS to block grid children so the last items in the row center automatically. Apply this to the columns, not the row.\n///\n/// @param {Number} $n - Number of items that appear in each row.\n@mixin grid-layout-center-last($n) {\n  @for $i from 1 to $n {\n    @if $i == 1 {\n      &:nth-child(#{$n}n+1):last-child {\n        margin-left: (100 - 100/$n * $i) / 2 * 1%;\n      }\n    }\n    @else {\n      &:nth-child(#{$n}n+1):nth-last-child(#{$i}) {\n        margin-left: (100 - 100/$n * $i) / 2 * 1%;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group button\n////\n\n/// Font family for button elements.\n/// @type Font\n$button-font-family: inherit !default;\n\n/// Padding inside buttons.\n/// @type List\n$button-padding: 0.85em 1em !default;\n\n/// Margin around buttons.\n/// @type List\n$button-margin: 0 0 $global-margin 0 !default;\n\n/// Default fill for buttons. Can either be `solid` or `hollow`.\n/// @type Keyword\n$button-fill: solid !default;\n\n/// Default background color for buttons.\n/// @type Color\n$button-background: $primary-color !default;\n\n/// Background color on hover for buttons.\n/// @type Color\n$button-background-hover: scale-color($button-background, $lightness: -15%) !default;\n\n/// Font color for buttons.\n/// @type List\n$button-color: $white !default;\n\n/// Alternative font color for buttons.\n/// @type List\n$button-color-alt: $black !default;\n\n/// Border radius for buttons, defaulted to global-radius.\n/// @type Number\n$button-radius: $global-radius !default;\n\n/// Border width for hollow outline buttons\n/// @type Number\n$button-hollow-border-width: 1px !default;\n\n/// Sizes for buttons.\n/// @type Map\n$button-sizes: (\n  tiny: 0.6rem,\n  small: 0.75rem,\n  default: 0.9rem,\n  large: 1.25rem,\n) !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$button-palette: $foundation-palette !default;\n\n/// opacity for a disabled button.\n/// @type List\n$button-opacity-disabled: 0.25 !default;\n\n/// Background color lightness on hover for buttons.\n/// @type Number\n$button-background-hover-lightness: -20% !default;\n\n/// Color lightness on hover for hollow buttons.\n/// @type Number\n$button-hollow-hover-lightness: -50% !default;\n\n// Internal: flip from margin-right to margin-left for defaults\n@if $global-text-direction == 'rtl' {\n  $button-margin: 0 0 $global-margin $global-margin !default;\n}\n\n/// transitions for buttons.\n/// @type List\n$button-transition: background-color 0.25s ease-out, color 0.25s ease-out !default;\n\n/// Additional responsive classes for .expanded\n/// @type Boolean\n$button-responsive-expanded: false !default;\n\n// TODO: Document button-base() mixin\n@mixin button-base {\n  @include disable-mouse-outline;\n  display: inline-block;\n  vertical-align: middle;\n  margin: $button-margin;\n\n  @if (type-of($button-padding) == 'map') {\n    @each $size, $padding in $button-padding {\n      @include breakpoint($size) {\n        padding: $padding;\n      }\n    }\n  }\n  @else {\n    padding: $button-padding;\n  }\n\n  border: 1px solid transparent;\n  border-radius: $button-radius;\n  transition: $button-transition;\n  font-family: $button-font-family;\n  font-size: map-get($button-sizes, default);\n  -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n}\n\n/// Expands a button to make it full-width.\n/// @param {Boolean} $expand [true] - Set to `true` to enable the expand behavior. Set to `false` to reverse this behavior.\n@mixin button-expand($expand: true) {\n  @if $expand {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0;\n  }\n  @else {\n    display: inline-block;\n    width: auto;\n    margin: $button-margin;\n  }\n}\n\n/// Sets the visual style of a button.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n@mixin button-style(\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $background-hover-lightness: $button-background-hover-lightness\n) {\n  @if $color == auto {\n    $color: color-pick-contrast($background, ($button-color, $button-color-alt));\n  }\n\n  @if $background-hover == auto {\n    $background-hover: scale-color($background, $lightness: $background-hover-lightness);\n  }\n\n  background-color: $background;\n  color: $color;\n\n  &:hover, &:focus {\n    background-color: $background-hover;\n    color: $color;\n  }\n}\n\n/// Removes background fill on hover and focus for hollow buttons.\n@mixin button-hollow {\n  &,\n  &:hover,\n  &:focus {\n    background-color: transparent;\n  }\n\n  &.disabled,\n  &[disabled] {\n    &,\n    &:hover, &:focus {\n      background-color: transparent;\n    }\n  }\n}\n\n@mixin button-hollow-style(\n  $color: $button-background,\n  $hover-lightness: $button-hollow-hover-lightness,\n  $border-width: $button-hollow-border-width\n) {\n  $color-hover: scale-color($color, $lightness: $hover-lightness);\n\n  border: $border-width solid $color;\n  color: $color;\n\n  &:hover, &:focus {\n    border-color: $color-hover;\n    color: $color-hover;\n    &.disabled,\n    &[disabled] {\n      border: $border-width solid $color;\n      color: $color;\n    }\n  }\n}\n\n/// Adds disabled styles to a button by fading the element, reseting the cursor, and disabling pointer events.\n/// @param {Color} $background [$button-background] - Background color of the disabled button.\n/// @param {Color} $color [$button-color] - Text color of the disabled button. Set to `auto` to have the mixin automatically generate a color based on the background color.\n@mixin button-disabled(\n  $background: $button-background,\n  $color: $button-color\n) {\n  @if $color == auto {\n    $color: color-pick-contrast($background, ($button-color, $button-color-alt));\n  }\n\n  opacity: $button-opacity-disabled;\n  cursor: not-allowed;\n\n  &, &:hover, &:focus {\n    background-color: $background;\n    color: $color;\n  }\n}\n\n/// Adds a dropdown arrow to a button.\n/// @param {Number} $size [0.4em] - Size of the arrow. We recommend using an `em` value so the triangle scales when used inside different sizes of buttons.\n/// @param {Color} $color [white] - Color of the arrow.\n/// @param {Number} $offset [$button-padding] - Distance between the arrow and the text of the button. Defaults to whatever the right padding of a button is.\n@mixin button-dropdown(\n  $size: 0.4em,\n  $color: $white,\n  $offset: get-side($button-padding, right)\n) {\n  &::after {\n    @include css-triangle($size, $color, down);\n    position: relative;\n    top: 0.4em; // Aligns the arrow with the text of the button\n\n    display: inline-block;\n    float: #{$global-right};\n    margin-#{$global-left}: $offset;\n  }\n}\n\n/// Adds all styles for a button. For more granular control over styles, use the individual button mixins.\n/// @param {Boolean} $expand [false] - Set to `true` to make the button full-width.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n/// @param {Keyword} $style [solid] - Set to `hollow` to create a hollow button. The color defined in `$background` will be used as the primary color of the button.\n@mixin button(\n  $expand: false,\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $style: $button-fill\n) {\n  @include button-base;\n\n  @if $style == solid {\n    @include button-style($background, $background-hover, $color);\n  }\n  @else if $style == hollow {\n    @include button-hollow;\n    @include button-hollow-style($background);\n  }\n\n  @if $expand {\n    @include button-expand;\n  }\n}\n\n@mixin foundation-button {\n  .button {\n    @include button;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} {\n        font-size: $value;\n      }\n    }\n\n    &.expanded { @include button-expand; }\n\n    @if $button-responsive-expanded {\n      @each $size in $breakpoint-classes {\n        @include breakpoint(#{$size} only) {\n          &.#{$size}-only-expanded {\n            @include button-expand;\n          }\n        }\n        @if $size != $-zf-zero-breakpoint {\n          @include breakpoint(#{$size} down) {\n            &.#{$size}-down-expanded {\n              @include button-expand;\n            }\n          }\n\n          @include breakpoint(#{$size}) {\n            &.#{$size}-expanded {\n              @include button-expand;\n            }\n          }\n        }\n      }\n    }\n\n    // Colors\n    @each $name, $color in $button-palette {\n      @if $button-fill != hollow {\n        &.#{$name} {\n          @include button-style($color, auto, auto);\n        }\n      }\n      @else {\n        &.#{$name} {\n          @include button-hollow-style($color);\n        }\n\n        &.#{$name}.dropdown::after {\n          border-top-color: $color;\n        }\n      }\n    }\n\n    // Disabled style\n    &.disabled,\n    &[disabled] {\n      @include button-disabled;\n\n      @each $name, $color in $button-palette {\n        &.#{$name} {\n          @include button-disabled($color, auto);\n        }\n      }\n    }\n\n    // Hollow style\n    @if $button-fill != hollow {\n      &.hollow {\n        @include button-hollow;\n        @include button-hollow-style;\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-hollow-style($color);\n          }\n        }\n      }\n    }\n\n    // Clear style\n    @if $button-fill != clear {\n      &.clear {\n        @include button-hollow;\n        @include button-hollow-style;\n\n        &, &:hover, &:focus {\n          &, &.disabled, &[disabled] {\n            border-color: transparent;\n          }\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-hollow-style($color);\n\n            &, &:hover,\n            &:focus {\n              &,\n              &.disabled,\n              &[disabled] {\n                border-color: transparent;\n              }\n            }\n          }\n        }\n      }\n    }\n\n    // Dropdown arrow\n    &.dropdown {\n      @include button-dropdown;\n\n      @if $button-fill == hollow {\n        &::after {\n          border-top-color: $button-background;\n        }\n      }\n\n      &.hollow, &.clear {\n        &::after {\n          border-top-color: $button-background;\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            &::after {\n              border-top-color: $color;\n            }\n          }\n        }\n      }\n    }\n\n    // Button with dropdown arrow only\n    &.arrow-only::after {\n      top: -0.1em;\n      float: none;\n      margin-#{$global-left}: 0;\n    }\n  }\n\n  a.button { // sass-lint:disable-line no-qualifying-elements\n    &:hover,\n    &:focus {\n      text-decoration: none;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group button-group\n////\n\n/// Margin for button groups.\n/// @type Number\n$buttongroup-margin: 1rem !default;\n\n/// Margin between buttons in a button group.\n/// @type Number\n$buttongroup-spacing: 1px !default;\n\n/// Selector for the buttons inside a button group.\n/// @type String\n$buttongroup-child-selector: '.button' !default;\n\n/// Maximum number of buttons that can be in an even-width button group. (Only needed when $global-flexbox: false;)\n/// @type Number\n$buttongroup-expand-max: 6 !default;\n\n/// Determines if $button-radius is applied to each button or the button group as a whole. Use $global-radius in _settings.scss to change radius.\n/// @type Boolean\n$buttongroup-radius-on-each: true !default;\n\n/// Add styles for a button group container.\n/// @param {String} $child-selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group(\n  $child-selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing\n) {\n  @include clearfix;\n  margin-bottom: $buttongroup-margin;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    align-items: stretch;\n  }\n  @else {\n    font-size: 0;\n  }\n\n  #{$child-selector} {\n    margin: 0;\n    margin-#{$global-right}: $spacing;\n    margin-bottom: $spacing;\n    font-size: map-get($button-sizes, default);\n\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n\n    &:last-child {\n      margin-#{$global-right}: 0;\n    }\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $button-radius;\n        border-bottom-#{$global-left}-radius: $button-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $button-radius;\n        border-bottom-#{$global-right}-radius: $button-radius;\n      }\n    }\n\n  }\n}\n\n/// Creates a full-width button group, making each button equal width.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group-expand(\n  $selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing,\n  $count: null\n) {\n  @if not $global-flexbox {\n    margin-#{$global-right}: -$spacing;\n\n    &::before,\n    &::after {\n      display: none;\n    }\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n    @else {\n      // One child\n      &:first-child {\n        &:last-child {\n          width: calc(100% - #{$spacing});\n        }\n      }\n\n      // Two or more childreen\n      @for $i from 2 through $buttongroup-expand-max {\n        &:first-child:nth-last-child(#{$i}) {\n          &, &:first-child:nth-last-child(#{$i}) ~ #{$selector} {\n            display: inline-block;\n            width: calc(#{percentage(1 / $i)} - #{$spacing});\n            margin-#{$global-right}: $spacing;\n\n            &:last-child {\n              margin-#{$global-right}: $spacing * -$buttongroup-expand-max;\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n/// Stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-stack(\n  $selector: $buttongroup-child-selector\n) {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 100%;\n    }\n    @else {\n      width: 100%;\n    }\n\n    &:last-child {\n      margin-bottom: 0;\n    }\n\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: $global-radius;\n      }\n\n      &:last-child {\n        margin-bottom: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n      }\n    }\n\n  }\n}\n\n/// Un-stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-unstack(\n  $selector: $buttongroup-child-selector\n) {\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n    @else {\n      width: auto;\n    }\n    margin-bottom: 0;\n\n    @if not $buttongroup-radius-on-each {\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-left}-radius: 0;\n      }\n    }\n\n  }\n}\n\n@mixin foundation-button-group {\n  .button-group {\n    @include button-group;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} #{$buttongroup-child-selector} {\n        font-size: $value;\n      }\n    }\n\n    // Even-width Group\n    &.expanded {\n      @include button-group-expand;\n    }\n\n    // Colors\n    @each $name, $color in $button-palette {\n      @if $button-fill != hollow {\n        &.#{$name} #{$buttongroup-child-selector} {\n          @include button-style($color, auto, auto);\n        }\n      }\n      @else {\n        &.#{$name} #{$buttongroup-child-selector} {\n          @include button-hollow;\n          @include button-hollow-style($color);\n        }\n      }\n    }\n\n    &.stacked,\n    &.stacked-for-small,\n    &.stacked-for-medium {\n      @include button-group-stack;\n\n      &.expanded {\n        @include button-group-expand;\n      }\n    }\n\n    &.stacked-for-small {\n      @include breakpoint(medium) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-medium {\n      @include breakpoint(large) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-small.expanded {\n      @include breakpoint(small only) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n\n    &.stacked-for-medium.expanded {\n      @include breakpoint(medium down) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group close-button\n////\n\n/// Default position of the close button. The first value should be `right` or `left`, and the second value should be `top` or `bottom`.\n/// @type List\n$closebutton-position: right top !default;\n\n/// Right (or left) offset(s) for a close button.\n/// @type Number|Map\n$closebutton-offset-horizontal: (\n  small: 0.66rem,\n  medium: 1rem,\n) !default;\n\n/// Top (or bottom) offset(s) for a close button.\n/// @type Number|Map\n$closebutton-offset-vertical: (\n  small: 0.33em,\n  medium: 0.5rem,\n) !default;\n\n/// Default font size(s) of the close button.\n/// @type Number|Map\n$closebutton-size: (\n  small: 1.5em,\n  medium: 2em,\n) !default;\n\n/// The line-height of the close button. It affects the spacing of the element.\n/// @type Number\n$closebutton-lineheight: 1 !default;\n\n/// Default color of the close button.\n/// @type Color\n$closebutton-color: $dark-gray !default;\n\n/// Default color of the close button when being hovered on.\n/// @type Color\n$closebutton-color-hover: $black !default;\n\n\n/// Get the size and position for a close button. If the input value is a number, the number is returned. If the input value is a config map and the map has the key `$size`, the value is returned.\n///\n/// @param {Number|Map} $value - A number or map that represents the size or position value(s) of the close button.\n/// @param {Keyword} $size - The size of the close button to use.\n///\n/// @return {Number} The given number or the value found in the map.\n@function -zf-get-size-val($value, $size) {\n  // Check if the value is a number\n  @if type-of($value) == 'number' {\n    // If it is, just return the number\n    @return $value;\n  }\n\n  // Check if the size name exists in the value map\n  @else if map-has-key($value, $size) {\n    // If it does, return the value\n    @return map-get($value, $size);\n  }\n}\n\n/// Sets the size and position of a close button.\n/// @param {Keyword} $size [medium] - The size to use. Set to `small` to create a small close button. The 'medium' values defined in `$closebutton-*` variables will be used as the default size and position of the close button.\n@mixin close-button-size($size) {\n  $x: nth($closebutton-position, 1);\n  $y: nth($closebutton-position, 2);\n\n  #{$x}: -zf-get-size-val($closebutton-offset-horizontal, $size);\n  #{$y}: -zf-get-size-val($closebutton-offset-vertical, $size);\n  font-size: -zf-get-size-val($closebutton-size, $size);\n  line-height: -zf-get-size-val($closebutton-lineheight, $size);\n}\n\n/// Adds styles for a close button, using the styles in the settings variables.\n@mixin close-button {\n  $x: nth($closebutton-position, 1);\n  $y: nth($closebutton-position, 2);\n\n  @include disable-mouse-outline;\n  position: absolute;\n  color: $closebutton-color;\n  cursor: pointer;\n\n  &:hover,\n  &:focus {\n    color: $closebutton-color-hover;\n  }\n}\n\n@mixin foundation-close-button {\n  .close-button {\n    @include close-button;\n\n    &.small { @include close-button-size(small) }\n    &, &.medium { @include close-button-size(medium) }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group label\n////\n\n/// Default background color for labels.\n/// @type Color\n$label-background: $primary-color !default;\n\n/// Default text color for labels.\n/// @type Color\n$label-color: $white !default;\n\n/// Alternate text color for labels.\n/// @type Color\n$label-color-alt: $black !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$label-palette: $foundation-palette !default;\n\n/// Default font size for labels.\n/// @type Number\n$label-font-size: 0.8rem !default;\n\n/// Default padding inside labels.\n/// @type Number\n$label-padding: 0.33333rem 0.5rem !default;\n\n/// Default radius of labels.\n/// @type Number\n$label-radius: $global-radius !default;\n\n/// Generates base styles for a label.\n@mixin label {\n  display: inline-block;\n  padding: $label-padding;\n\n  border-radius: $label-radius;\n\n  font-size: $label-font-size;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n}\n\n@mixin foundation-label {\n  .label {\n    @include label;\n\n    background: $label-background;\n    color: $label-color;\n\n    @each $name, $color in $label-palette {\n      &.#{$name} {\n        background: $color;\n        color: color-pick-contrast($color, ($label-color, $label-color-alt));\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// Adds styles for a progress bar container.\n@mixin progress-container {\n  height: $progress-height;\n  margin-bottom: $progress-margin-bottom;\n  border-radius: $progress-radius;\n  background-color: $progress-background;\n}\n\n/// Adds styles for the inner meter of a progress bar.\n@mixin progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: $progress-meter-background;\n\n  @if has-value($progress-radius) {\n    border-radius: $global-radius;\n  }\n}\n\n/// Adds styles for text in the progress meter.\n@mixin progress-meter-text {\n  @include absolute-center;\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: $white;\n  white-space: nowrap;\n\n  @if has-value($progress-radius) {\n    border-radius: $progress-radius;\n  }\n}\n\n@mixin foundation-progress-bar {\n  // Progress bar\n  .progress {\n    @include progress-container;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        .progress-meter {\n          background-color: $color;\n        }\n      }\n    }\n  }\n\n  // Inner meter\n  .progress-meter {\n    @include progress-meter;\n  }\n\n  // Inner meter text\n  .progress-meter-text {\n    @include progress-meter-text;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group progress-bar\n////\n\n/// Height of a progress bar.\n/// @type Number\n$progress-height: 1rem !default;\n\n/// Background color of a progress bar.\n/// @type Color\n$progress-background: $medium-gray !default;\n\n/// Bottom margin of a progress bar.\n/// @type Number\n$progress-margin-bottom: $global-margin !default;\n\n/// Default color of a progress bar's meter.\n/// @type Color\n$progress-meter-background: $primary-color !default;\n\n/// Default radius of a progress bar.\n/// @type Number\n$progress-radius: $global-radius !default;\n\n@mixin foundation-progress-element {\n  progress {\n    display: block;\n    width: 100%;\n    height: $progress-height;\n    margin-bottom: $progress-margin-bottom;\n\n    appearance: none;\n\n    @if has-value($progress-radius) {\n      border-radius: $progress-radius;\n    }\n\n    // For Firefox\n    border: 0;\n    background: $progress-background;\n\n    &::-webkit-progress-bar {\n      background: $progress-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    &::-webkit-progress-value {\n      background: $progress-meter-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    &::-moz-progress-bar {\n      background: $progress-meter-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        // Internet Explorer sets the fill with color\n        color: $color;\n\n        &::-webkit-progress-value {\n          background: $color;\n        }\n\n        &::-moz-progress-bar {\n          background: $color;\n        }\n      }\n    }\n\n    // For IE and Edge\n    &::-ms-fill { // sass-lint:disable-line no-vendor-prefixes\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n\n      border: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// [TODO] Check how plugin confirms disabled or vertical status\n// [TODO] Check if transition: all; is necessary\n\n////\n/// @group slider\n////\n\n/// Default slider width of a vertical slider. (Doesn't apply to the native slider.)\n/// @type Number\n$slider-width-vertical: 0.5rem !default;\n\n/// Transition properties to apply to the slider handle and fill. (Doesn't apply to the native slider.)\n/// @type Transition\n$slider-transition: all 0.2s ease-in-out !default;\n\n/// Adds the general styles for sliders.\n@mixin slider-container {\n  position: relative;\n  height: $slider-height;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n\n  background-color: $slider-background;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none;\n}\n\n/// Adds the general styles for active fill for sliders.\n@mixin slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n\n  display: inline-block;\n  max-width: 100%;\n  height: $slider-height;\n\n  background-color: $slider-fill-background;\n  transition: $slider-transition;\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n/// Adds the general styles for the slider handles.\n@mixin slider-handle {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  left: 0;\n  z-index: 1;\n\n  display: inline-block;\n  width: $slider-handle-width;\n  height: $slider-handle-height;\n\n  border-radius: $slider-radius;\n  background-color: $slider-handle-background;\n  transition: $slider-transition;\n  touch-action: manipulation;\n\n  &:hover {\n    background-color: scale-color($slider-handle-background, $lightness: -15%);\n  }\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n@mixin slider-disabled {\n  opacity: $slider-opacity-disabled;\n  cursor: not-allowed;\n}\n\n@mixin slider-vertical {\n  display: inline-block;\n  width: $slider-width-vertical;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1);\n\n  .slider-fill {\n    top: 0;\n    width: $slider-width-vertical;\n    max-height: 100%;\n  }\n\n  .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: $slider-handle-height;\n    height: $slider-handle-width;\n    transform: translateX(-50%);\n  }\n}\n\n@mixin foundation-slider {\n  // Container\n  .slider {\n    @include slider-container;\n  }\n\n  // Fill area\n  .slider-fill {\n    @include slider-fill;\n  }\n\n  // Draggable handle\n  .slider-handle {\n    @include slider-handle;\n  }\n\n  // Disabled state\n  .slider.disabled,\n  .slider[disabled] {\n    @include slider-disabled;\n  }\n\n  // Vertical slider\n  .slider.vertical {\n    @include slider-vertical;\n  }\n\n  // RTL support\n  @if $global-text-direction == rtl {\n    .slider:not(.vertical) {\n      transform: scale(-1, 1);\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group slider\n////\n\n/// Default height of the slider.\n/// @type Number\n$slider-height: 0.5rem !default;\n\n/// Default background color of the slider's track.\n/// @type Color\n$slider-background: $light-gray !default;\n\n/// Default color of the active fill color of the slider.\n/// @type Color\n$slider-fill-background: $medium-gray !default;\n\n/// Default height of the handle of the slider.\n/// @type Number\n$slider-handle-height: 1.4rem !default;\n\n/// Default width of the handle of the slider.\n/// @type Number\n$slider-handle-width: 1.4rem !default;\n\n/// Default color of the handle for the slider.\n/// @type Color\n$slider-handle-background: $primary-color !default;\n\n/// Default fade amount of a disabled slider.\n/// @type Number\n$slider-opacity-disabled: 0.25 !default;\n\n/// Default radius for slider.\n/// @type Number\n$slider-radius: $global-radius !default;\n\n@mixin foundation-range-input {\n  input[type='range'] {  // sass-lint:disable-line no-qualifying-elements\n    $margin: ($slider-handle-height - $slider-height) / 2;\n\n    display: block;\n    width: 100%;\n    height: auto;\n    margin-top: $margin;\n    margin-bottom: $margin;\n\n    appearance: none;\n    border: 0;\n    line-height: 1;\n    cursor: pointer;\n\n    @if has-value($slider-radius) {\n      border-radius: $slider-radius;\n    }\n\n    &:focus {\n      outline: 0;\n    }\n\n    &[disabled] {\n      opacity: $slider-opacity-disabled;\n    }\n\n    // sass-lint:disable no-vendor-prefix\n\n    // Chrome/Safari\n    &::-webkit-slider-runnable-track {\n      height: $slider-height;\n      background: $slider-background;\n    }\n\n    &::-webkit-slider-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      margin-top: -$margin;\n\n      -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    // Firefox\n    &::-moz-range-track {\n      height: $slider-height;\n      -moz-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-background;\n    }\n\n    &::-moz-range-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      margin-top: -$margin;\n\n      -moz-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    // Internet Explorer\n    &::-ms-track {\n      height: $slider-height;\n\n      border: 0;\n      border-top: $margin solid $body-background;\n      border-bottom: $margin solid $body-background;\n      background: $slider-background;\n\n      overflow: visible;\n      color: transparent;\n    }\n\n    &::-ms-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      border: 0;\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    &::-ms-fill-lower {\n      background: $slider-fill-background;\n    }\n\n    &::-ms-fill-upper {\n      background: $slider-background;\n    }\n\n    @at-root {\n      output {\n        vertical-align: middle;\n        margin-left: 0.5em;\n        line-height: $slider-handle-height;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group switch\n////\n\n/// Background color of a switch.\n/// @type Color\n$switch-background: $medium-gray !default;\n\n/// Background active color of a switch.\n/// @type Color\n$switch-background-active: $primary-color !default;\n\n/// Height of a switch, with no class applied.\n/// @type Number\n$switch-height: 2rem !default;\n\n/// Height of a switch with .tiny class.\n/// @type Number\n$switch-height-tiny: 1.5rem !default;\n\n/// Height of a switch with .small class.\n/// @type Number\n$switch-height-small: 1.75rem !default;\n\n/// Height of a switch with .large class.\n/// @type Number\n$switch-height-large: 2.5rem !default;\n\n/// Border radius of the switch\n/// @type Number\n$switch-radius: $global-radius !default;\n\n/// border around a modal.\n/// @type Number\n$switch-margin: $global-margin !default;\n\n/// Background color for the switch container and paddle.\n/// @type Color\n$switch-paddle-background: $white !default;\n\n/// Spacing between a switch paddle and the edge of the body.\n/// @type Number\n$switch-paddle-offset: 0.25rem !default;\n\n/// border radius of the switch paddle\n/// @type Number\n$switch-paddle-radius: $global-radius !default;\n\n/// switch transition.\n/// @type Number\n$switch-paddle-transition: all 0.25s ease-out !default;\n\n// make them variables\n// ask about accessibility on label\n// change class name for text\n\n/// Adds styles for a switch container. Apply this to a container class.\n@mixin switch-container {\n  position: relative;\n  margin-bottom: $switch-margin;\n  outline: 0;\n\n  // These properties cascade down to the switch text\n  font-size: rem-calc(14);\n  font-weight: bold;\n  color: $white;\n\n  user-select: none;\n}\n\n/// Adds styles for a switch input. Apply this to an `<input>` within a switch.\n@mixin switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0;\n}\n\n/// Adds styles for the background and paddle of a switch. Apply this to a `<label>` within a switch.\n@mixin switch-paddle {\n  $switch-width: $switch-height * 2;\n  $paddle-height: $switch-height - ($switch-paddle-offset * 2);\n  $paddle-width: $switch-height - ($switch-paddle-offset * 2);\n  $paddle-active-offest: $switch-width - $paddle-width - $switch-paddle-offset;\n\n  position: relative;\n  display: block;\n  width: $switch-width;\n  height: $switch-height;\n\n  border-radius: $switch-radius;\n  background: $switch-background;\n  transition: $switch-paddle-transition;\n\n  // Resetting these <label> presets so type styles cascade down\n  font-weight: inherit;\n  color: inherit;\n\n  cursor: pointer;\n\n  // Needed to override specificity\n  input + & {\n    margin: 0;\n  }\n\n  // The paddle itself\n  &::after {\n    position: absolute;\n    top: $switch-paddle-offset;\n    #{$global-left}: $switch-paddle-offset;\n\n    display: block;\n    width: $paddle-width;\n    height: $paddle-height;\n\n    transform: translate3d(0, 0, 0);\n    border-radius: $switch-paddle-radius;\n    background: $switch-paddle-background;\n    transition: $switch-paddle-transition;\n    content: '';\n  }\n\n  // Change the visual style when the switch is active\n  input:checked ~ & {\n    background: $switch-background-active;\n\n    &::after {\n      #{$global-left}: $paddle-active-offest;\n    }\n  }\n\n  input:focus ~ & {\n    @include disable-mouse-outline;\n  }\n}\n\n/// Adds base styles for active/inactive text inside a switch. Apply this to text elements inside the switch `<label>`.\n@mixin switch-text {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Adds styles for the active state text within a switch.\n@mixin switch-text-active {\n  #{$global-left}: 8%;\n  display: none;\n\n  input:checked + label > & {\n    display: block;\n  }\n}\n\n/// Adds styles for the inactive state text within a switch.\n@mixin switch-text-inactive {\n  #{$global-right}: 15%;\n\n  input:checked + label > & {\n    display: none;\n  }\n}\n\n/// Changes the size of a switch by modifying the size of the body and paddle. Apply this to a switch container.\n/// @param {Number} $font-size [1rem] - Font size of label text within the switch.\n/// @param {Number} $switch-height [2rem] - Height of the switch body.\n/// @param {Number} $paddle-offset [0.25rem] - Spacing between the switch paddle and the edge of the switch body.\n@mixin switch-size(\n  $font-size: 1rem,\n  $switch-height: 2rem,\n  $paddle-offset: 0.25rem\n) {\n\n  $switch-width: $switch-height * 2;\n  $paddle-width: $switch-height - ($paddle-offset * 2);\n  $paddle-height: $switch-height - ($paddle-offset * 2);\n  $paddle-active-offest: $switch-width - $paddle-width - $paddle-offset;\n\n  height: $switch-height;\n\n  .switch-paddle {\n    width: $switch-width;\n    height: $switch-height;\n    font-size: $font-size;\n  }\n\n  .switch-paddle::after {\n    top: $paddle-offset;\n    #{$global-left}: $paddle-offset;\n    width: $paddle-width;\n    height: $paddle-height;\n  }\n\n  input:checked ~ .switch-paddle::after {\n    #{$global-left}: $paddle-active-offest;\n  }\n}\n\n@mixin foundation-switch {\n  // Container class\n  .switch {\n    height: $switch-height;\n    @include switch-container;\n  }\n\n  // <input> element\n  .switch-input {\n    @include switch-input;\n  }\n\n  // <label> element\n  .switch-paddle {\n    @include switch-paddle;\n  }\n\n  // Base label text styles\n  %switch-text {\n    @include switch-text;\n  }\n\n  // Active label text styles\n  .switch-active {\n    @extend %switch-text;\n    @include switch-text-active;\n  }\n\n  // Inactive label text styles\n  .switch-inactive {\n    @extend %switch-text;\n    @include switch-text-inactive;\n  }\n\n  // Switch sizes\n  .switch.tiny {\n    @include switch-size(rem-calc(10), $switch-height-tiny, $switch-paddle-offset);\n  }\n\n  .switch.small {\n    @include switch-size(rem-calc(12), $switch-height-small, $switch-paddle-offset);\n  }\n\n  .switch.large {\n    @include switch-size(rem-calc(16), $switch-height-large, $switch-paddle-offset);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-qualifying-elements\n\n////\n/// @group table\n////\n\n/// Default color for table background.\n/// @type Color\n$table-background: $white  !default;\n\n/// Default scale for darkening the striped table rows and the table border.\n/// @type Number\n$table-color-scale: 5% !default;\n\n/// Default style for table border.\n/// @type List\n$table-border: 1px solid smart-scale($table-background, $table-color-scale) !default;\n\n/// Default padding for table.\n/// @type Number\n$table-padding: rem-calc(8 10 10) !default;\n\n/// Default scale for darkening the table rows on hover.\n/// @type Number\n$table-hover-scale: 2% !default;\n\n/// Default color of standard rows on hover.\n/// @type List\n$table-row-hover: darken($table-background, $table-hover-scale) !default;\n\n/// Default color of striped rows on hover.\n/// @type List\n$table-row-stripe-hover: darken($table-background, $table-color-scale + $table-hover-scale) !default;\n\n/// If `true`, tables are striped by default and an .unstriped class is created. If `false`, a .striped class is created.\n/// @type Boolean\n$table-is-striped: true !default;\n\n/// Default background color for striped rows.\n/// @type Color\n$table-striped-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default value for showing the stripe on rows of the tables, excluding the header and footer. If even, the even rows will have a background color. If odd, the odd rows will have a background color. If empty, or any other value, the table rows will have no striping.\n/// @type Keyword\n$table-stripe: even !default;\n\n/// Default color for header background.\n/// @type Color\n$table-head-background: smart-scale($table-background, $table-color-scale / 2) !default;\n\n/// Default color of header rows on hover.\n/// @type List\n$table-head-row-hover: darken($table-head-background, $table-hover-scale) !default;\n\n/// Default color for footer background.\n/// @type Color\n$table-foot-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default color of footer rows on hover.\n/// @type List\n$table-foot-row-hover: darken($table-foot-background, $table-hover-scale) !default;\n\n/// Default font color for header.\n/// @type Color\n$table-head-font-color: $body-font-color !default;\n\n/// Default font color for footer.\n/// @type Color\n$table-foot-font-color: $body-font-color !default;\n\n/// Default value for showing the header when using stacked tables.\n/// @type Boolean\n$show-header-for-stacked: false !default;\n\n/// Breakpoint at which stacked table switches from mobile to desktop view.\n/// @type Breakpoint\n$table-stack-breakpoint: medium !default;\n\n@mixin -zf-table-stripe($stripe: $table-stripe) {\n  tr {\n    // If stripe is set to even, darken the even rows.\n    @if $stripe == even {\n      &:nth-child(even) {\n        border-bottom: 0;\n        background-color: $table-striped-background;\n      }\n    }\n\n    // If stripe is set to odd, darken the odd rows.\n    @else if $stripe == odd {\n      &:nth-child(odd) {\n        background-color: $table-striped-background;\n      }\n    }\n  }\n}\n\n@mixin -zf-table-unstripe() {\n  tr {\n    border-bottom: 0;\n    border-bottom: $table-border;\n    background-color: $table-background;\n  }\n}\n\n@mixin -zf-table-children-styles($stripe: $table-stripe, $is-striped: $table-is-striped) {\n  thead,\n  tbody,\n  tfoot {\n    border: $table-border;\n    background-color: $table-background;\n  }\n\n  // Caption\n  caption {\n    padding: $table-padding;\n    font-weight: $global-weight-bold;\n  }\n\n  // Table head\n  thead {\n    background: $table-head-background;\n    color: $table-head-font-color;\n  }\n\n  // Table foot\n  tfoot {\n    background: $table-foot-background;\n    color: $table-foot-font-color;\n  }\n\n  // Table head and foot\n  thead,\n  tfoot {\n    // Rows within head and foot\n    tr {\n      background: transparent;\n    }\n\n    // Cells within head and foot\n    th,\n    td {\n      padding: $table-padding;\n      font-weight: $global-weight-bold;\n      text-align: #{$global-left};\n    }\n  }\n\n  // Table rows\n  tbody {\n    th,\n    td {\n      padding: $table-padding;\n    }\n  }\n\n  // If tables are striped\n  @if $is-striped == true {\n    tbody {\n      @include -zf-table-stripe($stripe);\n    }\n\n    &.unstriped {\n      tbody {\n        @include -zf-table-unstripe();\n        background-color: $table-background;\n      }\n    }\n  }\n\n  // If tables are not striped\n  @else if $is-striped == false {\n    tbody {\n      @include -zf-table-unstripe();\n    }\n\n    &.striped {\n      tbody {\n        @include -zf-table-stripe($stripe);\n      }\n    }\n  }\n}\n\n/// Adds the general styles for tables.\n/// @param {Keyword} $stripe [$table-stripe] - Uses keywords even, odd, or none to darken rows of the table. The default value is even.\n@mixin table(\n  $stripe: $table-stripe,\n  $nest: false\n) {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: $global-margin;\n  border-radius: $global-radius;\n\n  @if $nest {\n    @include -zf-table-children-styles($stripe);\n  }\n  @else {\n    @at-root {\n      @include -zf-table-children-styles($stripe);\n    }\n  }\n}\n\n/// Adds the ability to horizontally scroll the table when the content overflows horizontally.\n@mixin table-scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto;\n}\n\n/// Slightly darkens the table rows on hover.\n@mixin table-hover {\n  thead tr {\n    //Darkens the table header rows on hover.\n    &:hover {\n      background-color: $table-head-row-hover;\n    }\n  }\n\n  tfoot tr {\n    //Darkens the table footer rows on hover.\n    &:hover {\n      background-color: $table-foot-row-hover;\n    }\n  }\n\n  tbody tr {\n    //Darkens the non-striped table rows on hover.\n    &:hover {\n      background-color: $table-row-hover;\n    }\n  }\n\n  @if $table-is-striped == true {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &:not(.unstriped) tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &:not(.unstriped) tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n\n  @else if $table-is-striped == false {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &.striped tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &.striped tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n}\n\n/// Adds styles for a stacked table. Useful for small-screen layouts.\n/// @param {Boolean} $header [$show-header-for-stacked] - Show the first th of header when stacked.\n@mixin table-stack($header: $show-header-for-stacked) {\n  @if $header {\n    thead {\n      th {\n        display: block;\n      }\n    }\n  }\n  @else {\n    thead {\n      display: none;\n    }\n  }\n\n  tfoot {\n    display: none;\n  }\n\n  tr,\n  th,\n  td {\n    display: block;\n  }\n\n  td {\n    border-top: 0;\n  }\n}\n\n@mixin foundation-table($nest: false) {\n  table {\n    @include table($nest: $nest);\n  }\n\n  table.stack {\n    @include breakpoint($table-stack-breakpoint down) {\n      @include table-stack;\n    }\n  }\n\n  table.scroll {\n    @include table-scroll;\n  }\n\n  table.hover {\n    @include table-hover;\n  }\n\n  .table-scroll {\n    overflow-x: auto;\n\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@import 'math';\n\n$contrast-warnings: true !default;\n\n////\n/// @group functions\n////\n\n/// Checks the luminance of `$color`.\n///\n/// @param {Color} $color - Color to check the luminance of.\n///\n/// @returns {Number} The luminance of `$color`.\n@function color-luminance($color) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n  $rgba: red($color), green($color), blue($color);\n  $rgba2: ();\n\n  @for $i from 1 through 3 {\n    $rgb: nth($rgba, $i);\n    $rgb: $rgb / 255;\n\n    $rgb: if($rgb < 0.03928, $rgb / 12.92, pow(($rgb + 0.055) / 1.055, 2.4));\n\n    $rgba2: append($rgba2, $rgb);\n  }\n\n  @return 0.2126 * nth($rgba2, 1) + 0.7152 * nth($rgba2, 2) + 0.0722 * nth($rgba2, 3);\n}\n\n/// Checks the contrast ratio of two colors.\n///\n/// @param {Color} $color1 - First color to compare.\n/// @param {Color} $color2 - Second color to compare.\n///\n/// @returns {Number} The contrast ratio of the compared colors.\n@function color-contrast($color1, $color2) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef\n  $luminance1: color-luminance($color1) + 0.05;\n  $luminance2: color-luminance($color2) + 0.05;\n  $ratio: $luminance1 / $luminance2;\n\n  @if $luminance2 > $luminance1 {\n    $ratio: 1 / $ratio;\n  }\n\n  $ratio: round($ratio * 10) / 10;\n\n  @return $ratio;\n}\n\n/// Checks the luminance of `$base`, and returns the color from `$colors` (list of colors) that has the most contrast.\n///\n/// @param {Color} $base - Color to check luminance.\n/// @param {List} $colors [($white, $black)] - Colors to compare.\n/// @param {Number} $tolerance [$global-color-pick-contrast-tolerance] - Contrast tolerance.\n///\n/// @returns {Color} the color from `$colors` (list of colors) that has the most contrast.\n@function color-pick-contrast($base, $colors: ($white, $black), $tolerance: $global-color-pick-contrast-tolerance) {\n  $contrast: color-contrast($base, nth($colors, 1));\n  $best: nth($colors, 1);\n\n  @for $i from 2 through length($colors) {\n    $current-contrast: color-contrast($base, nth($colors, $i));\n    @if ($current-contrast - $contrast > $tolerance) {\n      $contrast: color-contrast($base, nth($colors, $i));\n      $best: nth($colors, $i);\n    }\n  }\n\n  @if ($contrast-warnings and $contrast < 3) {\n    @warn \"Contrast ratio of #{$best} on #{$base} is pretty bad, just #{$contrast}\";\n  }\n\n  @return $best;\n}\n\n/// Scales a color to be darker if it's light, or lighter if it's dark. Use this function to tint a color appropriate to its lightness.\n///\n/// @param {Color} $color - Color to scale.\n/// @param {Percentage} $scale [5%] - Amount to scale up or down.\n/// @param {Percentage} $threshold [40%] - Threshold of lightness to check against.\n///\n/// @returns {Color} A scaled color.\n@function smart-scale($color, $scale: 5%, $threshold: 40%) {\n  @if lightness($color) > $threshold {\n    $scale: -$scale;\n  }\n  @return scale-color($color, $lightness: $scale);\n}\n\n/// Get color from foundation-palette\n///\n/// @param {key} color key from foundation-palette\n///\n/// @returns {Color} color from foundation-palette\n@function get-color($key) {\n  @if map-has-key($foundation-palette, $key) {\n    @return map-get($foundation-palette, $key);\n  }\n  @else {\n    @error 'given $key is not available in $foundation-palette';\n  }\n}\n\n/// Transfers the colors in the `$foundation-palette` map into variables, such as `$primary-color` and `$secondary-color`. Call this mixin below the Global section of your settings file to properly migrate your codebase.\n@mixin add-foundation-colors() {\n  @if map-has-key($foundation-palette, primary) {\n    $primary-color: map-get($foundation-palette, primary) !global;\n  } @else {\n    $primary-color: #1779ba !global;\n  }\n  @if map-has-key($foundation-palette, secondary) {\n    $secondary-color: map-get($foundation-palette, secondary) !global;\n  } @else {\n    $secondary-color: #767676 !global;\n  }\n  @if map-has-key($foundation-palette, success) {\n    $success-color: map-get($foundation-palette, success) !global;\n  } @else {\n    $success-color: #3adb76 !global;\n  }\n  @if map-has-key($foundation-palette, warning) {\n    $warning-color: map-get($foundation-palette, warning) !global;\n  } @else {\n    $warning-color: #ffae00 !global;\n  }\n  @if map-has-key($foundation-palette, alert) {\n    $alert-color: map-get($foundation-palette, alert) !global;\n  } @else {\n    $alert-color: #cc4b37 !global;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group badge\n////\n\n/// Default background color for badges.\n/// @type Color\n$badge-background: $primary-color !default;\n\n/// Default text color for badges.\n/// @type Color\n$badge-color: $white !default;\n\n/// Alternate text color for badges.\n/// @type Color\n$badge-color-alt: $black !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$badge-palette: $foundation-palette !default;\n\n/// Default padding inside badges.\n/// @type Number\n$badge-padding: 0.3em !default;\n\n/// Minimum width of a badge.\n/// @type Number\n$badge-minwidth: 2.1em !default;\n\n/// Default font size for badges.\n/// @type Number\n$badge-font-size: 0.6rem !default;\n\n/// Generates the base styles for a badge.\n@mixin badge {\n  display: inline-block;\n  min-width: $badge-minwidth;\n  padding: $badge-padding;\n\n  border-radius: 50%;\n\n  font-size: $badge-font-size;\n  text-align: center;\n}\n\n@mixin foundation-badge {\n  .badge {\n    @include badge;\n\n    background: $badge-background;\n    color: $badge-color;\n\n    @each $name, $color in $badge-palette {\n      &.#{$name} {\n        background: $color;\n        color: color-pick-contrast($color, ($badge-color, $badge-color-alt));\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group breadcrumbs\n////\n\n/// Margin around a breadcrumbs container.\n/// @type Number\n$breadcrumbs-margin: 0 0 $global-margin 0 !default;\n\n/// Font size of breadcrumb links.\n/// @type Number\n$breadcrumbs-item-font-size: rem-calc(11) !default;\n\n/// Color of breadcrumb links.\n/// @type Color\n$breadcrumbs-item-color: $primary-color !default;\n\n/// Color of the active breadcrumb link.\n/// @type Color\n$breadcrumbs-item-color-current: $black !default;\n\n/// Opacity of disabled breadcrumb links.\n/// @type Number\n$breadcrumbs-item-color-disabled: $medium-gray !default;\n\n/// Margin between breadcrumb items.\n/// @type Number\n$breadcrumbs-item-margin: 0.75rem !default;\n\n/// If `true`, makes breadcrumb links uppercase.\n/// @type Boolean\n$breadcrumbs-item-uppercase: true !default;\n\n/// If `true`, adds a seperator between breadcrumb links.\n/// @type Boolean\n$breadcrumbs-item-separator: true !default;\n\n// If it exists $breadcrumbs-item-slash is used to build $breadcrumbs-item-separator. See the documentation.\n@if variable-exists(breadcrumbs-item-slash) {\n  $breadcrumbs-item-separator: $breadcrumbs-item-slash;\n}\n\n/// Used character for the breadcrumb separator.\n/// @type Content\n$breadcrumbs-item-separator-item: '/' !default;\n\n/// Used character for the breadcrumb separator in rtl mode.\n/// @type Content\n$breadcrumbs-item-separator-item-rtl: '\\\\' !default;\n\n/// Color of breadcrumb item.\n/// @type Color\n$breadcrumbs-item-separator-color: $medium-gray !default;\n\n// If it exists $breadcrumbs-item-slash-color is used to build $breadcrumbs-item-separator-color. See the documentation.\n@if variable-exists(breadcrumbs-item-slash-color) {\n  $breadcrumbs-item-separator-color: $breadcrumbs-item-slash-color;\n}\n\n/// Adds styles for a breadcrumbs container, along with the styles for the `<li>` and `<a>` elements inside of it.\n@mixin breadcrumbs-container {\n  @include clearfix;\n  margin: $breadcrumbs-margin;\n  list-style: none;\n\n  // Item wrapper\n  li {\n    float: #{$global-left};\n\n    font-size: $breadcrumbs-item-font-size;\n    color: $breadcrumbs-item-color-current;\n    cursor: default;\n\n    @if $breadcrumbs-item-uppercase {\n      text-transform: uppercase;\n    }\n\n    @if $breadcrumbs-item-separator {\n      // Need to escape the backslash\n      $separator: if($global-text-direction == 'ltr', $breadcrumbs-item-separator-item, $breadcrumbs-item-separator-item-rtl);\n\n      &:not(:last-child) {\n        &::after {\n          position: relative;\n          margin: 0 $breadcrumbs-item-margin;\n          opacity: 1;\n          content: $separator;\n          color: $breadcrumbs-item-separator-color;\n        }\n      }\n    }\n    @else {\n      margin-#{$global-right}: $breadcrumbs-item-margin;\n    }\n  }\n\n  // Page links\n  a {\n    color: $breadcrumbs-item-color;\n\n    &:hover {\n      text-decoration: underline;\n    }\n  }\n}\n\n@mixin foundation-breadcrumbs {\n  .breadcrumbs {\n    @include breadcrumbs-container;\n\n    .disabled {\n      color: $breadcrumbs-item-color-disabled;\n      cursor: not-allowed;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group callout\n////\n\n/// Default background color.\n/// @type Color\n$callout-background: $white !default;\n\n/// Default fade value for callout backgrounds.\n/// @type Number\n$callout-background-fade: 85% !default;\n\n/// Default border style for callouts.\n/// @type List\n$callout-border: 1px solid rgba($black, 0.25) !default;\n\n/// Default bottom margin for callouts.\n/// @type Number\n$callout-margin: 0 0 1rem 0 !default;\n\n/// Default inner padding for callouts.\n/// @type Number\n$callout-padding: 1rem !default;\n\n/// Default font color for callouts.\n/// @type Color\n$callout-font-color: $body-font-color !default;\n\n/// Default font color for callouts, if the callout has a dark background.\n/// @type Color\n$callout-font-color-alt: $body-background !default;\n\n/// Default border radius for callouts.\n/// @type Color\n$callout-radius: $global-radius !default;\n\n/// Amount to tint links used within colored panels. Set to `false` to disable this feature.\n/// @type Number | Boolean\n$callout-link-tint: 30% !default;\n\n/// Adds basic styles for a callout, including padding and margin.\n@mixin callout-base() {\n  position: relative;\n  margin: $callout-margin;\n  padding: $callout-padding;\n\n  border: $callout-border;\n  border-radius: $callout-radius;\n\n  // Respect the padding, fool.\n  > :first-child {\n    margin-top: 0;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Generate quick styles for a callout using a single color as a baseline.\n/// @param {Color} $color [$callout-background] - Color to use.\n@mixin callout-style($color: $callout-background) {\n  $background: scale-color($color, $lightness: $callout-background-fade);\n\n  background-color: $background;\n  color: color-pick-contrast($background, ($callout-font-color, $callout-font-color-alt));\n}\n\n@mixin callout-size($padding) {\n  padding-top: $padding;\n  padding-right: $padding;\n  padding-bottom: $padding;\n  padding-left: $padding;\n}\n\n\n/// Adds styles for a callout.\n/// @param {Color} $color [$callout-background] - Color to use.\n@mixin callout($color: $callout-background) {\n  @include callout-base;\n  @include callout-style($color);\n}\n\n@mixin foundation-callout {\n  .callout {\n    @include callout;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        @include callout-style($color);\n      }\n    }\n\n    &.small {\n      @include callout-size(0.5rem);\n    }\n\n    &.large {\n      @include callout-size(3rem);\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group card\n////\n\n/// Default background color.\n/// @type Color\n$card-background: $white !default;\n\n/// Default font color for cards.\n/// @type Color\n$card-font-color: $body-font-color !default;\n\n/// Default background.\n/// @type Color\n$card-divider-background: $light-gray !default;\n\n/// Default border style.\n/// @type List\n$card-border: 1px solid $light-gray !default;\n\n/// Default card shadow.\n/// @type List\n$card-shadow: none !default;\n\n/// Default border radius.\n/// @type List\n$card-border-radius: $global-radius !default;\n\n/// Default padding.\n/// @type Number\n$card-padding: $global-padding !default;\n\n/// Default bottom margin.\n/// @type number\n$card-margin-bottom: $global-margin !default;\n\n/// Adds styles for a card container.\n/// @param {Color} $background - Background color of the card.\n/// @param {Color} $color - font color of the card.\n/// @param {Number} $margin - Bottom margin of the card.\n/// @param {List} $border - Border around the card.\n/// @param {List} $radius - border radius of the card.\n/// @param {List} $shadow - box shadow of the card.\n@mixin card-container(\n  $background: $card-background,\n  $color: $card-font-color,\n  $margin: $card-margin-bottom,\n  $border: $card-border,\n  $radius: $card-border-radius,\n  $shadow: $card-shadow\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex-direction: column;\n    flex-grow: 1;\n  }\n\n  margin-bottom: $margin;\n\n  border: $border;\n  border-radius: $radius;\n\n  background: $background;\n  box-shadow: $shadow;\n\n  overflow: hidden;\n  color: $color;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card divider.\n@mixin card-divider(\n  $background: $card-divider-background,\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex: 0 1 auto;\n  }\n\n  padding: $padding;\n  background: $background;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card section.\n@mixin card-section(\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    flex: 1 0 auto;\n  }\n\n  padding: $padding;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n@mixin foundation-card {\n  .card {\n    @include card-container;\n  }\n\n  .card-divider {\n    @include card-divider;\n  }\n\n  .card-section {\n    @include card-section;\n  }\n\n  // For IE 11 - Flexbug\n  // https://github.com/philipwalton/flexbugs/issues/75\n  .card-image {\n    min-height: 1px;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown\n////\n\n/// Padding for dropdown panes.\n/// @type List\n$dropdown-padding: 1rem !default;\n\n/// Background for dropdown panes.\n/// @type Color\n$dropdown-background: $body-background !default;\n\n/// Border for dropdown panes.\n/// @type List\n$dropdown-border: 1px solid $medium-gray !default;\n\n/// Font size for dropdown panes.\n/// @type List\n$dropdown-font-size: 1rem !default;\n\n/// Width for dropdown panes.\n/// @type Number\n$dropdown-width: 300px !default;\n\n/// Border radius dropdown panes.\n/// @type Number\n$dropdown-radius: $global-radius !default;\n\n/// Sizes for dropdown panes. Each size is a CSS class you can apply.\n/// @type Map\n$dropdown-sizes: (\n  tiny: 100px,\n  small: 200px,\n  large: 400px,\n) !default;\n\n/// Applies styles for a basic dropdown.\n@mixin dropdown-container {\n  position: absolute;\n  z-index: 10;\n\n  display: none;\n\n  width: $dropdown-width;\n  padding: $dropdown-padding;\n\n  visibility: hidden;\n  border: $dropdown-border;\n  border-radius: $dropdown-radius;\n  background-color: $dropdown-background;\n\n  font-size: $dropdown-font-size;\n\n\n  // Allow an intermittent state to do positioning before making visible.\n  &.is-opening {\n    display: block;\n  }\n\n  &.is-open {\n    display: block;\n    visibility: visible;\n  }\n}\n\n@mixin foundation-dropdown {\n  .dropdown-pane {\n    @include dropdown-container;\n  }\n\n  @each $name, $size in $dropdown-sizes {\n    .dropdown-pane {\n      &.#{$name} {\n        width: $size;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group pagination\n////\n\n/// Font size of pagination items.\n/// @type Number\n$pagination-font-size: rem-calc(14) !default;\n\n/// Default bottom margin of the pagination object.\n/// @type Number\n$pagination-margin-bottom: $global-margin !default;\n\n/// Text color of pagination items.\n/// @type Color\n$pagination-item-color: $black !default;\n\n/// Padding inside of pagination items.\n/// @type Number\n$pagination-item-padding: rem-calc(3 10) !default;\n\n/// Right margin to separate pagination items.\n/// @type Number\n$pagination-item-spacing: rem-calc(1) !default;\n\n/// Default radius for pagination items.\n/// @type Number\n$pagination-radius: $global-radius !default;\n\n/// Background color of pagination items on hover.\n/// @type Color\n$pagination-item-background-hover: $light-gray !default;\n\n/// Background color of pagination item for the current page.\n/// @type Color\n$pagination-item-background-current: $primary-color !default;\n\n/// Text color of the pagination item for the current page.\n/// @type Color\n$pagination-item-color-current: $white !default;\n\n/// Text color of a disabled pagination item.\n/// @type Color\n$pagination-item-color-disabled: $medium-gray !default;\n\n/// Color of the ellipsis in a pagination menu.\n/// @type Color\n$pagination-ellipsis-color: $black !default;\n\n/// If `false`, don't display page number links on mobile, only next/previous links\n/// and optionally current page number.\n/// @type Boolean\n$pagination-mobile-items: false !default;\n\n/// If `true`, display the current page number on mobile even if `$pagination-mobile-items` is set to `false`.\n/// This parameter will only override the visibility setting of the current item for `$pagination-mobile-items: false;`,\n/// it will not affect the current page number visibility when `$pagination-mobile-items` is set to `true`.\n/// @type Boolean\n$pagination-mobile-current-item: false !default;\n\n/// If `true`, arrows are added to the next and previous links of pagination.\n/// @type Boolean\n$pagination-arrows: true !default;\n\n/// Adds styles for a pagination container. Apply this to a `<ul>`.\n@mixin pagination-container (\n  $margin-bottom: $pagination-margin-bottom,\n  $font-size: $pagination-font-size,\n  $spacing: $pagination-item-spacing,\n  $radius: $pagination-radius,\n  $color: $pagination-item-color,\n  $padding: $pagination-item-padding,\n  $background-hover: $pagination-item-background-hover\n) {\n  @include clearfix;\n  margin-#{$global-left}: 0;\n  margin-bottom: $margin-bottom;\n\n  // List item\n  li {\n    margin-#{$global-right}: $spacing;\n    border-radius: $radius;\n    font-size: $font-size;\n\n    @if $pagination-mobile-items {\n      display: inline-block;\n    }\n    @else {\n      display: none;\n\n      &:last-child,\n      &:first-child {\n        display: inline-block;\n      }\n\n      @if $pagination-mobile-current-item {\n        &.current {\n          display: inline-block;\n        }\n      }\n\n      @include breakpoint(medium) {\n        display: inline-block;\n      }\n    }\n  }\n\n  // Page links\n  a,\n  button {\n    display: block;\n    padding: $padding;\n    border-radius: $radius;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n    }\n  }\n}\n\n/// Adds styles for the current pagination item. Apply this to an `<a>`.\n@mixin pagination-item-current (\n  $padding: $pagination-item-padding,\n  $background-current: $pagination-item-background-current,\n  $color-current: $pagination-item-color-current\n) {\n  padding: $padding;\n  background: $background-current;\n  color: $color-current;\n  cursor: default;\n}\n\n/// Adds styles for a disabled pagination item. Apply this to an `<a>`.\n@mixin pagination-item-disabled (\n  $padding: $pagination-item-padding,\n  $color: $pagination-item-color-disabled\n) {\n  padding: $padding;\n  color: $color;\n  cursor: not-allowed;\n\n  &:hover {\n    background: transparent;\n  }\n}\n\n/// Adds styles for an ellipsis for use in a pagination list.\n@mixin pagination-ellipsis (\n  $padding: $pagination-item-padding,\n  $color: $pagination-ellipsis-color\n) {\n  padding: $padding;\n  content: '\\2026';\n  color: $color;\n}\n\n@mixin foundation-pagination {\n  .pagination {\n    @include pagination-container;\n\n    .current {\n      @include pagination-item-current;\n    }\n\n    .disabled {\n      @include pagination-item-disabled;\n    }\n\n    .ellipsis::after {\n      @include pagination-ellipsis;\n    }\n  }\n\n  @if $pagination-arrows {\n    .pagination-previous a::before,\n    .pagination-previous.disabled::before {\n      display: inline-block;\n      margin-#{$global-right}: 0.5rem;\n      content: '\\00ab';\n    }\n\n    .pagination-next a::after,\n    .pagination-next.disabled::after {\n      display: inline-block;\n      margin-#{$global-left}: 0.5rem;\n      content: '\\00bb';\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group tooltip\n////\n\n/// Default cursor of the defined term.\n/// @type Keyword\n$has-tip-cursor: help !default;\n\n/// Default font weight of the defined term.\n/// @type Keyword | Number\n$has-tip-font-weight: $global-weight-bold !default;\n\n/// Default border bottom of the defined term.\n/// @type List\n$has-tip-border-bottom: dotted 1px $dark-gray !default;\n\n/// Default color of the tooltip background.\n/// @type Color\n$tooltip-background-color: $black !default;\n\n/// Default color of the tooltip font.\n/// @type Color\n$tooltip-color: $white !default;\n\n/// Default padding of the tooltip background.\n/// @type Number\n$tooltip-padding: 0.75rem !default;\n\n/// Default max width for tooltips.\n/// @type Number\n$tooltip-max-width: 10rem !default;\n\n/// Default font size of the tooltip text. By default, we recommend a smaller font size than the body copy.\n/// @type Number\n$tooltip-font-size: $small-font-size !default;\n\n/// Default pip width for tooltips.\n/// @type Number\n$tooltip-pip-width: 0.75rem !default;\n\n/// Default pip height for tooltips. This is helpful for calculating the distance of the tooltip from the tooltip word.\n/// @type Number\n$tooltip-pip-height: $tooltip-pip-width * 0.866 !default;\n\n/// Default radius for tooltips.\n/// @type Number\n$tooltip-radius: $global-radius !default;\n\n@mixin has-tip {\n  position: relative;\n  display: inline-block;\n\n  border-bottom: $has-tip-border-bottom;\n  font-weight: $has-tip-font-weight;\n  cursor: $has-tip-cursor;\n}\n\n@mixin tooltip {\n  position: absolute;\n  top: calc(100% + #{$tooltip-pip-height});\n  z-index: 1200;\n\n  max-width: $tooltip-max-width;\n  padding: $tooltip-padding;\n\n  border-radius: $tooltip-radius;\n  background-color: $tooltip-background-color;\n  font-size: $tooltip-font-size;\n  color: $tooltip-color;\n\n  &::before {\n    position: absolute;\n  }\n\n  &.bottom {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, up);\n      bottom: 100%;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.top {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, down);\n      top: 100%;\n      bottom: auto;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.left {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, right);\n      left: 100%;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.right {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, left);\n      right: 100%;\n      left: auto;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.align-top::before {\n    bottom: auto;\n    top: 10%;\n  }\n\n  &.align-bottom::before {\n    bottom: 10%;\n    top: auto;\n  }\n\n  &.align-left::before {\n    left: 10%;\n    right: auto;\n  }\n\n  &.align-right::before {\n    left: auto;\n    right: 10%;\n  }\n}\n\n@mixin foundation-tooltip {\n  .has-tip {\n    @include has-tip;\n  }\n\n  .tooltip {\n    @include tooltip;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group accordion\n////\n\n/// Default background color of an accordion group.\n/// @type Color\n$accordion-background: $white !default;\n\n/// If `true`, adds plus and minus icons to the side of each accordion title.\n/// @type Boolean\n$accordion-plusminus: true !default;\n\n/// Font size of accordion titles.\n/// @type Number\n$accordion-title-font-size: rem-calc(12) !default;\n\n/// Default text color for items in a Menu.\n/// @type Color\n$accordion-item-color: $primary-color !default;\n\n/// Default background color on hover for items in a Menu.\n/// @type Color\n$accordion-item-background-hover: $light-gray !default;\n\n/// Default padding of an accordion item.\n/// @type Number | List\n$accordion-item-padding: 1.25rem 1rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$accordion-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$accordion-content-border: 1px solid $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$accordion-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$accordion-content-padding: 1rem !default;\n\n/// Adds styles for an accordion container. Apply this to the same element that gets `data-accordion`.\n@mixin accordion-container (\n  $background: $accordion-background\n) {\n  margin-#{$global-left}: 0;\n  background: $background;\n  list-style-type: none;\n\n  &[disabled] {\n    .accordion-title {\n      cursor: not-allowed;\n    }\n  }\n}\n\n/// Adds styles for the accordion item. Apply this to the list item within an accordion ul.\n@mixin accordion-item {\n  &:first-child > :first-child {\n    border-radius: $global-radius $global-radius 0 0;\n  }\n\n  &:last-child > :last-child {\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n}\n\n/// Adds styles for the title of an accordion item. Apply this to the link within an accordion item.\n@mixin accordion-title (\n  $padding: $accordion-item-padding,\n  $font-size: $accordion-title-font-size,\n  $color: $accordion-item-color,\n  $border: $accordion-content-border,\n  $background-hover: $accordion-item-background-hover\n) {\n  position: relative;\n  display: block;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n\n  font-size: $font-size;\n  line-height: 1;\n  color: $color;\n\n  :last-child:not(.is-active) > & {\n    border-bottom: $border;\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n\n  &:hover,\n  &:focus {\n    background-color: $background-hover;\n  }\n\n  @if $accordion-plusminus {\n    &::before {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 1rem;\n      margin-top: -0.5rem;\n      content: '+';\n    }\n\n    .is-active > &::before {\n      content: '\\2013';\n    }\n  }\n}\n\n/// Adds styles for accordion content. Apply this to the content pane below an accordion item's title.\n@mixin accordion-content (\n  $padding: $accordion-content-padding,\n  $border: $accordion-content-border,\n  $background: $accordion-content-background,\n  $color: $accordion-content-color\n) {\n  display: none;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n  background-color: $background;\n\n  color: $color;\n\n  :last-child > &:last-child {\n    border-bottom: $border;\n  }\n}\n\n@mixin foundation-accordion {\n  .accordion {\n    @include accordion-container;\n  }\n\n  .accordion-item {\n    @include accordion-item;\n  }\n\n  .accordion-title {\n    @include accordion-title;\n  }\n\n  .accordion-content {\n    @include accordion-content;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group media-object\n////\n\n/// Bottom margin of a media object.\n/// @type Number\n$mediaobject-margin-bottom: $global-margin !default;\n\n/// Left and right padding on sections within a media object.\n/// @type Number\n$mediaobject-section-padding: $global-padding !default;\n\n/// Width of images within a media object, when the object is stacked vertically. Set to 'auto' to use the image's natural width.\n/// @type Number\n$mediaobject-image-width-stacked: 100% !default;\n\n/// Adds styles for a media object container.\n@mixin media-object-container {\n  display: if($global-flexbox, flex, block);\n  margin-bottom: $mediaobject-margin-bottom;\n\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n  }\n\n  img {\n    max-width: none;\n  }\n\n  @if $global-flexbox {\n    &.stack-for-#{$-zf-zero-breakpoint} {\n      @include breakpoint($-zf-zero-breakpoint only) {\n        flex-wrap: wrap;\n      }\n    }\n  }\n}\n\n/// Adds styles for sections within a media object.\n/// @param {Number} $padding [$mediaobject-section-padding] - Padding between sections.\n@mixin media-object-section($padding: $mediaobject-section-padding) {\n  @if $global-flexbox {\n    flex: 0 1 auto;\n  }\n  @else {\n    display: table-cell;\n    vertical-align: top;\n  }\n\n  &:first-child {\n    padding-#{$global-right}: $padding;\n  }\n\n  &:last-child:not(:nth-child(2)) {\n    padding-#{$global-left}: $padding;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n\n  .stack-for-#{$-zf-zero-breakpoint} & {\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include media-object-stack;\n    }\n  }\n\n  @if $global-flexbox {\n    &.main-section {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    &.middle {\n      vertical-align: middle;\n    }\n\n    &.bottom {\n      vertical-align: bottom;\n    }\n  }\n}\n\n/// Adds styles to stack sections of a media object. Apply this to the section elements, not the container.\n@mixin media-object-stack {\n  padding: 0;\n  padding-bottom: $mediaobject-section-padding;\n\n  @if $global-flexbox {\n    flex-basis: 100%;\n    max-width: 100%;\n  }\n  @else {\n    display: block;\n  }\n\n  img {\n    width: $mediaobject-image-width-stacked;\n  }\n}\n\n@mixin foundation-media-object {\n  .media-object {\n    @include media-object-container;\n  }\n\n  .media-object-section {\n    @include media-object-section;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group orbit\n////\n\n/// Default color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background: $medium-gray !default;\n\n/// Default active color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background-active: $dark-gray !default;\n\n/// Default diameter for Orbit's bullets.\n/// @type Number\n$orbit-bullet-diameter: 1.2rem !default;\n\n/// Default margin between Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin: 0.1rem !default;\n\n/// Default distance from slide region for Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin-top: 0.8rem !default;\n\n/// Default bottom margin from Orbit's bullets to whatever content may lurk below it.\n/// @type Number\n$orbit-bullet-margin-bottom: 0.8rem !default;\n\n/// Default background color for Orbit's caption.\n/// @type Color\n$orbit-caption-background: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's caption.\n/// @type Number\n$orbit-caption-padding: 1rem !default;\n\n/// Default background color for Orbit's controls when hovered.\n/// @type Color\n$orbit-control-background-hover: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's controls.\n/// @type Number\n$orbit-control-padding: 1rem !default;\n\n/// Default z-index for Orbit's controls.\n/// @type Number\n$orbit-control-zindex: 10 !default;\n\n/// Adds styles for the outer Orbit wrapper. These styles are used on the `.orbit` class.\n@mixin orbit-wrapper {\n  position: relative;\n}\n\n/// Adds styles for the inner Orbit slide container. These styles are used on the `.orbit-container` class.\n@mixin orbit-container {\n  position: relative;\n  height: 0; // Prevent FOUC by not showing until JS sets height\n  margin: 0;\n  list-style: none;\n  overflow: hidden;\n}\n\n/// Adds styles for the individual slides of an Orbit slider. These styles are used on the `.orbit-slide` class.\n@mixin orbit-slide {\n  width: 100%;\n  position: absolute;\n\n  &.no-motionui {\n    &.is-active {\n      top: 0;\n      left: 0;\n    }\n  }\n}\n\n@mixin orbit-figure {\n  margin: 0;\n}\n\n/// Adds styles for a slide containing an image. These styles are used on the `.orbit-image` class.\n@mixin orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0;\n}\n\n/// Adds styles for an orbit slide caption. These styles are used on the `.orbit-caption` class.\n@mixin orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: $orbit-caption-padding;\n\n  background-color: $orbit-caption-background;\n  color: color-pick-contrast($orbit-caption-background);\n}\n\n/// Adds base styles for the next/previous buttons in an Orbit slider. These styles are shared between the `.orbit-next` and `.orbit-previous` classes in the default CSS.\n@mixin orbit-control {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  z-index: $orbit-control-zindex;\n  padding: $orbit-control-padding;\n  color: $white;\n\n  &:hover,\n  &:active,\n  &:focus {\n    background-color: $orbit-control-background-hover;\n  }\n}\n\n/// Adds styles for the Orbit previous button. These styles are used on the `.orbit-previous` class.\n@mixin orbit-previous {\n  #{$global-left}: 0;\n}\n\n/// Adds styles for the Orbit next button. These styles are used on the `.orbit-next` class.\n@mixin orbit-next {\n  #{$global-left}: auto;\n  #{$global-right}: 0;\n}\n\n/// Adds styles for a container of Orbit bullets. /// Adds styles for the Orbit previous button. These styles are used on the `.orbit-bullets` class.\n@mixin orbit-bullets {\n  @include disable-mouse-outline;\n  position: relative;\n  margin-top: $orbit-bullet-margin-top;\n  margin-bottom: $orbit-bullet-margin-bottom;\n  text-align: center;\n\n  button {\n    width: $orbit-bullet-diameter;\n    height: $orbit-bullet-diameter;\n    margin: $orbit-bullet-margin;\n\n    border-radius: 50%;\n    background-color: $orbit-bullet-background;\n\n    &:hover {\n      background-color: $orbit-bullet-background-active;\n    }\n\n    &.is-active {\n      background-color: $orbit-bullet-background-active;\n    }\n  }\n}\n\n@mixin foundation-orbit {\n  .orbit {\n    @include orbit-wrapper;\n  }\n\n  .orbit-container {\n    @include orbit-container;\n  }\n\n  .orbit-slide {\n    @include orbit-slide;\n  }\n\n  .orbit-figure {\n    @include orbit-figure;\n  }\n\n  .orbit-image {\n    @include orbit-image;\n  }\n\n  .orbit-caption {\n    @include orbit-caption;\n  }\n\n  %orbit-control {\n    @include orbit-control;\n  }\n\n  .orbit-previous {\n    @extend %orbit-control;\n    @include orbit-previous;\n  }\n\n  .orbit-next {\n    @extend %orbit-control;\n    @include orbit-next;\n  }\n\n  .orbit-bullets {\n    @include orbit-bullets;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group responsive-embed\n////\n\n/// Margin below a responsive embed container.\n/// @type Number\n$responsive-embed-margin-bottom: rem-calc(16) !default;\n\n/// Aspect ratios used to determine padding-bottom of responsive embed containers.\n/// @type Map\n$responsive-embed-ratios: (\n  default: 4 by 3,\n  widescreen: 16 by 9,\n) !default;\n\n/// Creates a responsive embed container.\n/// @param {String|List} $ratio [default] - Ratio of the container. Can be a key from the `$responsive-embed-ratios` map or a list formatted as `x by y`.\n@mixin responsive-embed($ratio: default) {\n  @if type-of($ratio) == 'string' {\n    $ratio: map-get($responsive-embed-ratios, $ratio);\n  }\n  position: relative;\n  height: 0;\n  margin-bottom: $responsive-embed-margin-bottom;\n  padding-bottom: ratio-to-percentage($ratio);\n  overflow: hidden;\n\n  iframe,\n  object,\n  embed,\n  video {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 0;\n    width: 100%;\n    height: 100%;\n  }\n}\n\n@mixin foundation-responsive-embed {\n  .responsive-embed,\n  .flex-video {\n    @include responsive-embed($ratio: default);\n\n    $ratios: map-remove($responsive-embed-ratios,default);\n\n    @each $name, $ratio in $ratios {\n      &.#{$name} {\n        padding-bottom: ratio-to-percentage($ratio);\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Finds the greatest common divisor of two integers.\n///\n/// @param {Number} $a - First number to compare.\n/// @param {Number} $b - Second number to compare.\n///\n/// @returns {Number} The greatest common divisor.\n@function gcd($a, $b) {\n  // From: http://rosettacode.org/wiki/Greatest_common_divisor#JavaScript\n  @if ($b != 0) {\n    @return gcd($b, $a % $b);\n  }\n  @else {\n    @return abs($a);\n  }\n}\n\n/// Handles decimal exponents by trying to convert them into a fraction and then use a nth-root-algorithm for parts of the calculation\n///\n/// @param {Number} $base - The base number.\n/// @param {Number} $exponent - The exponent.\n///\n/// @returns {Number} The product of the exponentiation.\n@function pow($base, $exponent, $prec: 16) {\n  @if (floor($exponent) != $exponent) {\n    $prec2 : pow(10, $prec);\n    $exponent: round($exponent * $prec2);\n    $denominator: gcd($exponent, $prec2);\n    @return nth-root(pow($base, $exponent / $denominator), $prec2 / $denominator, $prec);\n  }\n\n  $value: $base;\n  @if $exponent > 1 {\n    @for $i from 2 through $exponent {\n      $value: $value * $base;\n    }\n  }\n  @else if $exponent < 1 {\n    @for $i from 0 through -$exponent {\n      $value: $value / $base;\n    }\n  }\n\n  @return $value;\n}\n\n@function nth-root($num, $n: 2, $prec: 12) {\n  // From: http://rosettacode.org/wiki/Nth_root#JavaScript\n  $x: 1;\n\n  @for $i from 0 through $prec {\n    $x: 1 / $n * (($n - 1) * $x + ($num / pow($x, $n - 1)));\n  }\n\n  @return $x;\n}\n\n/// Calculates the height as a percentage of the width for a given ratio.\n/// @param {List} $ratio - Ratio to use to calculate the height, formatted as `x by y`.\n/// @return {Number} A percentage value for the height relative to the width of a responsive container.\n@function ratio-to-percentage($ratio) {\n  $w: nth($ratio, 1);\n  $h: nth($ratio, 3);\n  @return $h / $w * 100%;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group tabs\n////\n\n/// Default margin of the tab bar.\n/// @type Number\n$tab-margin: 0 !default;\n\n/// Default background color of a tab bar.\n/// @type Color\n$tab-background: $white !default;\n\n/// Font color of tab item.\n/// @type Color\n$tab-color: $primary-color !default;\n\n/// Active background color of a tab bar.\n/// @type Color\n$tab-background-active: $light-gray !default;\n\n/// Active font color of tab item.\n/// @type Color\n$tab-active-color: $primary-color !default;\n\n/// Font size of tab items.\n/// @type Number\n$tab-item-font-size: rem-calc(12) !default;\n\n/// Default background color on hover for items in a Menu.\n$tab-item-background-hover: $white !default;\n\n/// Default padding of a tab item.\n/// @type Number\n$tab-item-padding: 1.25rem 1.5rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$tab-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$tab-content-border: $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$tab-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$tab-content-padding: 1rem !default;\n\n/// Adds styles for a tab container. Apply this to a `<ul>`.\n@mixin tabs-container (\n  $margin: $tab-margin,\n  $background: $tab-background,\n  $border-color: $tab-content-border\n) {\n  @include clearfix;\n  margin: $margin;\n  border: 1px solid $border-color;\n  background: $background;\n  list-style-type: none;\n}\n\n/// Augments a tab container to have vertical tabs. Use this in conjunction with `tabs-container()`.\n@mixin tabs-container-vertical {\n  > li {\n    display: block;\n    float: none;\n    width: auto;\n  }\n}\n\n/// Adds styles for the links within a tab container. Apply this to the `<li>` elements inside a tab container.\n@mixin tabs-title (\n  $padding: $tab-item-padding,\n  $font-size: $tab-item-font-size,\n  $color: $tab-color,\n  $color-active: $tab-active-color,\n  $background-hover: $tab-item-background-hover,\n  $background-active: $tab-background-active\n) {\n  float: #{$global-left};\n\n  > a {\n    @include disable-mouse-outline;\n    display: block;\n    padding: $padding;\n    font-size: $font-size;\n    line-height: 1;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n      color: scale-color($color, $lightness: -14%);\n    }\n\n    &:focus,\n    &[aria-selected='true'] {\n      background: $background-active;\n      color: $color-active;\n    }\n  }\n}\n\n/// Adds styles for the wrapper that surrounds a tab group's content panes.\n@mixin tabs-content (\n  $background: $tab-content-background,\n  $color: $tab-content-color,\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-top: 0;\n  background: $background;\n  color: $color;\n  transition: all 0.5s ease;\n}\n\n/// Augments a tab content container to have a vertical style, by shifting the border around. Use this in conjunction with `tabs-content()`.\n@mixin tabs-content-vertical (\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-#{$global-left}: 0;\n}\n\n/// Adds styles for an individual tab content panel within the tab content container.\n@mixin tabs-panel (\n  $padding: $tab-content-padding\n) {\n  display: none;\n  padding: $padding;\n\n  &.is-active {\n    display: block;\n  }\n}\n\n@mixin foundation-tabs {\n  .tabs {\n    @include tabs-container;\n  }\n\n  // Vertical\n  .tabs.vertical {\n    @include tabs-container-vertical;\n  }\n\n  // Simple\n  .tabs.simple {\n    > li > a {\n      padding: 0;\n\n      &:hover {\n        background: transparent;\n      }\n    }\n  }\n\n  // Primary color\n  .tabs.primary {\n    background: $primary-color;\n\n    > li > a {\n      color: color-pick-contrast($primary-color);\n\n      &:hover,\n      &:focus {\n        background: smart-scale($primary-color);\n      }\n    }\n  }\n\n  .tabs-title {\n    @include tabs-title;\n  }\n\n  .tabs-content {\n    @include tabs-content;\n  }\n\n  .tabs-content.vertical {\n    @include tabs-content-vertical;\n  }\n\n  .tabs-panel {\n    @include tabs-panel;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group thumbnail\n////\n\n/// Border around thumbnail images.\n/// @type Border\n$thumbnail-border: 4px solid $white !default;\n\n/// Bottom margin for thumbnail images.\n/// @type Length\n$thumbnail-margin-bottom: $global-margin !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow: 0 0 0 1px rgba($black, 0.2) !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow-hover: 0 0 6px 1px rgba($primary-color, 0.5) !default;\n\n/// Transition proprties for thumbnail images.\n/// @type Transition\n$thumbnail-transition: box-shadow 200ms ease-out !default;\n\n/// Default radius for thumbnail images.\n/// @type Number\n$thumbnail-radius: $global-radius !default;\n\n/// Adds thumbnail styles to an element.\n@mixin thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: $thumbnail-margin-bottom;\n\n  border: $thumbnail-border;\n  border-radius: $thumbnail-radius;\n  box-shadow: $thumbnail-shadow;\n\n  line-height: 0;\n}\n\n@mixin thumbnail-link {\n  transition: $thumbnail-transition;\n\n  &:hover,\n  &:focus {\n    box-shadow: $thumbnail-shadow-hover;\n  }\n\n  image {\n    box-shadow: none;\n  }\n}\n\n@mixin foundation-thumbnail {\n  .thumbnail {\n    @include thumbnail;\n  }\n\n  a.thumbnail {\n    @include thumbnail-link;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group menu\n////\n\n/// Margin of a menu.\n/// @type Number\n$menu-margin: 0 !default;\n\n/// Left-hand margin of a nested menu.\n/// @type Number\n$menu-nested-margin: $global-menu-nested-margin !default;\n\n/// Padding for items in a pill menu.\n/// @type Number\n$menu-items-padding: $global-menu-padding !default;\n\n/// margin for items in a simple menu.\n/// @type Number\n$menu-simple-margin: 1rem !default;\n\n/// Text color of an active menu item.\n/// @type Color\n$menu-item-color-active: $white !default;\n\n/// Background color of an active menu item.\n/// @type Color\n$menu-item-background-active: get-color(primary) !default;\n\n/// Spacing between an icon and text in a menu item.\n/// @type Number\n$menu-icon-spacing: 0.25rem !default;\n\n/// Backward compatibility for menu state. If true, this duplicate `active` with `is-active`. \n/// But please note that `active` will be removed in upcoming versions.\n/// @type Boolean\n$menu-state-back-compat: true !default;\n\n/// Backward compatibility for menu centered. If true, this duplicate `.menu-centered > .menu` with `.menu.align-center`. \n/// But please note that `menu-centered` will be removed in upcoming versions.\n/// @type Boolean\n$menu-centered-back-compat: true !default;\n\n/// Backward compatibility for using `icon-*` classes without `.icons` classes\n/// But please note that this backward compatibility will be removed in upcoming versions.\n/// @type Boolean\n$menu-icons-back-compat: true !default;\n\n/// Creates the base styles for a Menu.\n@mixin menu-base {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: wrap;\n  }\n\n  li {\n    @include disable-mouse-outline;\n  }\n\n  a,\n  .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: $menu-items-padding;\n  }\n\n  // Reset styles of inner elements\n  input,\n  select,\n  a,\n  button {\n    margin-bottom: 0;\n  }\n\n  input {\n    display: inline-block;\n  }\n}\n\n/// Expands the items of a Menu, so each item is the same width.\n@mixin menu-expand {\n  @if $global-flexbox {\n    li {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    display: table;\n    width: 100%;\n\n    > li {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n}\n\n/// Align menu items.\n@mixin menu-align($alignment) {\n  @if $alignment == left {\n    @if $global-flexbox {\n      justify-content: flex-start;\n    }\n    @else {\n      text-align: $global-left;\n    }\n  }\n  @else if $alignment == right {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: flex-end;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n\n      &.vertical li {\n        display: block;\n        text-align: $global-right;\n\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n    @else {\n      text-align: $global-right;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n\n      &.vertical {\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n  }\n  @else if $alignment == center {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: center;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n    }\n    @else {\n      text-align: center;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n    }\n  }\n}\n\n/// Sets the direction of a Menu.\n/// @param {Keyword} $dir [horizontal] - Direction of the Menu. Can be `horizontal` or `vertical`.\n@mixin menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    @if $global-flexbox {\n      flex-wrap: wrap;\n      flex-direction: row;\n    }\n    @else {\n      li {\n        display: inline-block;\n      }\n    }\n  }\n  @else if $dir == vertical {\n    @if $global-flexbox {\n      flex-wrap: nowrap;\n      flex-direction: column;\n    }\n    @else {\n      li {\n        display: block;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for menu-direction() must be horizontal or vertical.';\n  }\n}\n\n/// Creates a simple Menu, which has no padding or hover state.\n/// @param {Keyword} $dir [$global-left] - Direction of the menu. This effects the side of the `<li>` that receives the margin.\n/// @param {Number} $margin [$menu-simple-margin] - The margin to apply to each `<li>`.\n@mixin menu-simple($dir: $global-left, $margin: $menu-simple-margin) {\n  @if $global-flexbox {\n    align-items: center;\n  }\n\n  li + li {\n    margin-#{$dir}: $margin;\n  }\n\n  a {\n    padding: 0;\n  }\n}\n\n/// Adds styles for a nested Menu, by adding `margin-left` to the menu.\n/// @param {Keyword|Number} $margin [$menu-nested-margin] - Length of the margin.\n/// @param {Keyword} $nested-alignment [left] - Alignment of the nested class\n@mixin menu-nested(\n  $margin: $menu-nested-margin,\n  $nested-alignment: left\n) {\n  @if $nested-alignment == right {\n    margin-#{$global-right}: $margin;\n    margin-#{$global-left}: 0;\n  }\n  @else {\n    margin-#{$global-right}: 0;\n    margin-#{$global-left}: $margin;\n  }\n\n}\n\n/// Adds basic styles for icons in menus.\n@mixin menu-icons() {\n  @if $global-flexbox {\n    a {\n      display: flex;\n    }\n  }\n  @else {\n    img,\n    i,\n    svg {\n      vertical-align: middle;\n\n      + span {\n        vertical-align: middle;\n      }\n    }\n  }\n}\n\n/// Adds position classes for icons within a menu.\n@mixin menu-icon-position($position: left, $spacing: $menu-icon-spacing) {\n  @if $position == left {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-right}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-left}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: 0 auto $spacing;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: $spacing auto 0;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n}\n\n@mixin menu-text {\n  padding: $global-menu-padding;\n\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n@mixin menu-state-active {\n  background: $menu-item-background-active;\n  color: $menu-item-color-active;\n}\n\n@mixin foundation-menu {\n  .menu {\n    @include menu-base;\n\n    // Default orientation: horizontal\n    &, &.horizontal {\n      @include menu-direction(horizontal);\n    }\n\n    // Vertical orientation modifier\n    &.vertical {\n      @include menu-direction(vertical);\n    }\n\n    // Even-width modifier for horizontal orientation\n    &.expanded {\n      @include menu-expand;\n    }\n\n    // Simple\n    &.simple {\n      @include menu-simple;\n    }\n\n    // Breakpoint specific versions\n    @include -zf-each-breakpoint($small: false) {\n      &.#{$-zf-size}-horizontal {\n        @include menu-direction(horizontal);\n      }\n\n      &.#{$-zf-size}-vertical {\n        @include menu-direction(vertical);\n      }\n\n      &.#{$-zf-size}-expanded {\n        @include menu-expand;\n      }\n\n      &.#{$-zf-size}-simple {\n        @include menu-expand;\n      }\n    }\n\n    // Nesting\n    &.nested {\n      @include menu-nested;\n    }\n\n    // Icon Base Styles\n    &.icons {\n      @include menu-icons;\n    }\n\n    // Backward Compatibility for active state\n    @if $menu-icons-back-compat {\n      &.icon-top,\n      &.icon-right,\n      &.icon-bottom,\n      &.icon-left {\n        @include menu-icons;\n      }\n    }\n\n    // Icon Left\n    &.icon-left {\n      @include menu-icon-position(left);\n    }\n\n    // Icon Right\n    &.icon-right {\n      @include menu-icon-position(right);\n    }\n\n    // Icon Top\n    &.icon-top {\n      @include menu-icon-position(top);\n    }\n\n    // Icon Bottom\n    &.icon-bottom {\n      @include menu-icon-position(bottom);\n    }\n\n    // Active state\n    .is-active > a {\n      @include menu-state-active;\n    }\n    \n    // Backward Compatibility for active state\n    @if $menu-state-back-compat {\n      .active > a {\n        @include menu-state-active;\n      }\n    }\n\n    // Align left\n    &.align-#{$global-left} {\n      @include menu-align(left);\n    }\n\n    // Align right\n    &.align-#{$global-right} {\n      @include menu-align(right);\n\n      .nested {\n        @include menu-nested($nested-alignment: right);\n      }\n    }\n\n    // Align center\n    &.align-center {\n      @include menu-align(center);\n    }\n\n    .menu-text {\n      @include menu-text;\n    }\n  }\n\n  @if $menu-centered-back-compat {\n    .menu-centered {\n      > .menu {\n        @if $global-flexbox {\n          justify-content: center;\n        }\n        \n        @include menu-align(center);\n      }\n    }\n  }\n\n  // Prevent FOUC when using the Responsive Menu plugin\n  .no-js [data-responsive-menu] ul {\n    display: none;\n  }\n}\n","@mixin foundation-menu-icon {\n  .menu-icon {\n    @include hamburger($color: $titlebar-icon-color, $color-hover: $titlebar-icon-color-hover);\n  }\n\n  .menu-icon.dark {\n    @include hamburger;\n  }\n}\n","////\n/// @group accordion-menu\n////\n\n/// Sets accordion menu padding.\n/// @type Number\n$accordionmenu-padding: $global-menu-padding !default;\n\n/// Sets accordion menu nested margin\n/// @type Number\n$accordionmenu-nested-margin: $global-menu-nested-margin !default;\n\n/// Sets accordion menu submenu padding.\n/// @type Number\n$accordionmenu-submenu-padding: $accordionmenu-padding !default;\n\n/// Sets if accordion menus have the default arrow styles.\n/// @type Boolean\n$accordionmenu-arrows: true !default;\n\n/// Sets accordion menu arrow color if arrow is used.\n/// @type Color\n$accordionmenu-arrow-color: $primary-color !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-item-background: null !default;\n\n/// Sets accordion menu item border.\n/// @type Color\n$accordionmenu-border: null !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-submenu-toggle-background: null !default;\n\n/// Sets accordion menu item padding.\n/// @type List\n$accordion-submenu-toggle-border: $accordionmenu-border !default;\n\n/// Sets accordion menu submenu toggle background width.\n/// @type Number\n$accordionmenu-submenu-toggle-width: 40px !default;\n\n/// Sets accordion menu submenu toggle background height.\n/// @type Number\n$accordionmenu-submenu-toggle-height: $accordionmenu-submenu-toggle-width !default;\n\n/// Sets accordion menu arrow size if arrow is used.\n/// @type Length\n$accordionmenu-arrow-size: 6px !default;\n\n@mixin zf-accordion-menu-left-right-arrows {\n  .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($accordionmenu-arrow-size, $accordionmenu-arrow-color, down);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * ($accordionmenu-arrow-size / 2);\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-accordion-submenu-parent > a::after {\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-accordion-submenu-parent > a::after {\n    right: auto;\n    left: 1rem;\n  }\n}\n@mixin foundation-accordion-menu {\n\n  .accordion-menu {\n    @if $accordionmenu-border {\n      border-bottom: $accordionmenu-border;\n    }\n\n    li {\n      @if $accordionmenu-border {\n        border-top: $accordionmenu-border;\n        border-right: $accordionmenu-border;\n        border-left: $accordionmenu-border;\n      }\n      width: 100%;\n    }\n\n    a {\n      @if $accordionmenu-item-background {\n        background: $accordionmenu-item-background;\n      }\n      padding: $accordionmenu-padding;\n    }\n\n    .is-accordion-submenu a {\n      padding: $accordionmenu-submenu-padding;\n    }\n\n    .nested.is-accordion-submenu {\n      @include menu-nested($accordionmenu-nested-margin);\n    }\n\n    &.align-#{$global-right} {\n      .nested.is-accordion-submenu {\n        @include menu-nested($accordionmenu-nested-margin, right);\n      }\n    }\n\n    @if $accordionmenu-arrows {\n      @include zf-accordion-menu-left-right-arrows;\n\n      .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n        transform: rotate(180deg);\n        transform-origin: 50% 50%;\n      }\n    }\n  }\n\n  .is-accordion-submenu li {\n    @if $accordionmenu-border {\n      border-right: 0;\n      border-left: 0;\n    }\n  }\n\n  .is-accordion-submenu-parent {\n    position: relative;\n  }\n\n  .has-submenu-toggle > a {\n    margin-#{$global-right}: $accordionmenu-submenu-toggle-width;\n  }\n\n  // Submenu toggle\n  .submenu-toggle {\n    position: absolute;\n    top: 0;\n    #{$global-right}: 0;\n\n    width: $accordionmenu-submenu-toggle-width;\n    height: $accordionmenu-submenu-toggle-height;\n\n    cursor: pointer;\n\n    border-#{$global-left}: $accordion-submenu-toggle-border;\n\n    @if $accordionmenu-submenu-toggle-background {\n      background: $accordionmenu-submenu-toggle-background;\n    }\n\n    // Add the arrow to the toggle\n    &::after {\n      @include css-triangle(6px, $accordionmenu-arrow-color, down);\n\n      top: 0;\n      bottom: 0;\n      margin: auto;\n    }\n  }\n\n  // Rotate the arrow when menu is open\n  .submenu-toggle[aria-expanded='true']::after {\n    transform: scaleY(-1);\n    transform-origin: 50% 50%;\n  }\n\n  .submenu-toggle-text {\n    @include element-invisible;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group drilldown\n////\n\n/// Transition property to use for animating menus.\n/// @type Transition\n$drilldown-transition: transform 0.15s linear !default;\n\n/// Adds arrows to drilldown items with submenus, as well as the back button.\n/// @type Boolean\n$drilldown-arrows: true !default;\n\n/// Sets drilldown menu item padding.\n/// @type Number\n$drilldown-padding: $global-menu-padding !default;\n\n/// Sets drilldown menu nested margin\n/// @type Number\n$drilldown-nested-margin: 0 !default;\n\n/// Background color for drilldown top level items.\n/// @type Color\n$drilldown-background: $white !default;\n\n/// Sets drilldown menu item padding in the submenu.\n/// @type Number\n$drilldown-submenu-padding: $drilldown-padding !default;\n\n/// Background color for drilldown submenus.\n/// @type Color\n$drilldown-submenu-background: $white !default;\n\n/// Sets drilldown arrow color if arrow is used.\n/// @type Color\n$drilldown-arrow-color: $primary-color !default;\n\n/// Sets drilldown arrow size if arrow is used.\n/// @type Length\n$drilldown-arrow-size: 6px !default;\n\n@mixin zf-drilldown-left-right-arrows {\n  .is-drilldown-submenu-parent > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-right);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * $drilldown-arrow-size;\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 1rem;\n  }\n\n}\n\n@mixin foundation-drilldown-menu {\n  // Applied to the Menu container\n  .is-drilldown {\n    position: relative;\n    overflow: hidden;\n\n    li {\n      display: block;\n    }\n\n    &.animate-height {\n      transition: height 0.5s;\n    }\n  }\n\n  // The top level <ul>\n  .drilldown {\n    a {\n      padding: $drilldown-padding;\n      background: $drilldown-background;\n    }\n\n    // Applied to submenu <ul>s\n    .is-drilldown-submenu {\n      position: absolute;\n      top: 0;\n      #{$global-left}: 100%;\n      z-index: -1;\n\n      width: 100%;\n      background: $drilldown-submenu-background;\n      transition: $drilldown-transition;\n\n      &.is-active {\n        z-index: 1;\n        display: block;\n        transform: translateX(if($global-text-direction == ltr, -100%, 100%));\n      }\n\n      &.is-closing {\n        transform: translateX(if($global-text-direction == ltr, 100%, -100%));\n      }\n\n      // Submenu item padding\n      a {\n        padding: $drilldown-submenu-padding;\n      }\n    }\n\n    .nested.is-drilldown-submenu {\n      @include menu-nested($drilldown-nested-margin);\n    }\n\n    .drilldown-submenu-cover-previous {\n      min-height: 100%;\n    }\n\n    @if $drilldown-arrows {\n      @include zf-drilldown-left-right-arrows;\n\n      .js-drilldown-back > a::before {\n        @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-left);\n        display: inline-block;\n        vertical-align: middle;\n        margin-#{$global-right}: 0.75rem; // Creates space between the arrow and the text\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown-menu\n////\n\n/// Enables arrows for items with dropdown menus.\n/// @type Boolean\n$dropdownmenu-arrows: true !default;\n\n/// Sets dropdown menu arrow color if arrow is used.\n/// @type Color\n$dropdownmenu-arrow-color: $anchor-color !default;\n\n/// Sets dropdown menu arrow size if arrow is used.\n/// @type Length\n$dropdownmenu-arrow-size: 6px !default;\n\n/// Sets dropdown menu arrow padding for aligning the arrow correctly.\n/// @type Length\n$dropdownmenu-arrow-padding: 1.5rem !default;\n\n/// Minimum width of dropdown sub-menus.\n/// @type Length\n$dropdownmenu-min-width: 200px !default;\n\n/// Background color for top level items.\n/// @type Color\n$dropdownmenu-background: null !default;\n\n/// Background color for dropdowns.\n/// @type Color\n$dropdownmenu-submenu-background: $white !default;\n\n/// Padding for top level items.\n/// @type Number\n$dropdownmenu-padding: $global-menu-padding !default;\n\n/// Sets dropdown menu nested margin\n/// @type Number\n$dropdownmenu-nested-margin: 0 !default;\n\n/// Padding for sub-menu items.\n/// @type Number\n$dropdownmenu-submenu-padding: $dropdownmenu-padding !default;\n\n/// Border for dropdown sub-menus.\n/// @type List\n$dropdownmenu-border: 1px solid $medium-gray !default;\n\n// Border width for dropdown sub-menus.\n// Used to adjust top margin of a sub-menu if a border is used.\n// @type Length\n$dropdownmenu-border-width: nth($dropdownmenu-border, 1);\n\n/// Text color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-color-active: get-color(primary) !default;\n\n/// Background color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-background-active: transparent !default;\n\n@mixin zf-dropdown-left-right-arrows {\n  > a::after {\n    #{$global-right}: 14px;\n  }\n\n  &.opens-left > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 5px;\n  }\n\n  &.opens-right > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n  }\n}\n\n@mixin dropdown-menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    > li.opens-left { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n\n    > li.opens-right { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: auto;\n        left: 0;\n      }\n    }\n\n    @if $dropdownmenu-arrows {\n      > li.is-dropdown-submenu-parent > a { // sass-lint:disable-line no-qualifying-elements\n        position: relative;\n        padding-#{$global-right}: $dropdownmenu-arrow-padding;\n      }\n\n      > li.is-dropdown-submenu-parent > a::after { // sass-lint:disable-line no-qualifying-elements\n        @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, down);\n        #{$global-right}: 5px;\n        #{$global-left}: auto;\n        margin-top: -1 * ($dropdownmenu-arrow-size / 2);\n      }\n    }\n  }\n  @else if $dir == vertical {\n    > li {\n      .is-dropdown-submenu {\n        top: 0;\n      }\n\n      &.opens-left {\n        > .is-dropdown-submenu {\n          top: 0;\n          right: 100%;\n          left: auto;\n        }\n      }\n\n      &.opens-right {\n        > .is-dropdown-submenu {\n          right: auto;\n          left: 100%;\n        }\n      }\n\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for dropdown-menu-direction() must be horizontal or vertical.';\n  }\n}\n\n@mixin foundation-dropdown-menu {\n  .dropdown.menu {\n    @include dropdown-menu-direction(horizontal);\n\n    a {\n      @include disable-mouse-outline;\n    }\n\n    // Top-level item\n    > li > a {\n      background: $dropdownmenu-background;\n      padding: $dropdownmenu-padding;\n    }\n\n    // Top-level item active state\n    > li.is-active > a {\n      background: $dropdown-menu-item-background-active;\n      color: $dropdown-menu-item-color-active;\n    }\n\n    .no-js & ul {\n      display: none;\n    }\n\n    .nested.is-dropdown-submenu {\n      @include menu-nested($dropdownmenu-nested-margin);\n    }\n\n    &.vertical {\n      @include dropdown-menu-direction(vertical);\n    }\n\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        @include breakpoint($size) {\n          &.#{$size}-horizontal {\n            @include dropdown-menu-direction(horizontal);\n          }\n\n          &.#{$size}-vertical {\n            @include dropdown-menu-direction(vertical);\n          }\n        }\n      }\n    }\n\n    &.align-right {\n      .is-dropdown-submenu.first-sub {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n  }\n\n  .is-dropdown-menu.vertical {\n    width: 100px;\n\n    &.align-right {\n      float: right;\n    }\n  }\n\n  .is-dropdown-submenu-parent {\n    position: relative;\n\n    a::after {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 5px;\n      #{$global-left}: auto;\n      margin-top: -1 * $dropdownmenu-arrow-size;\n    }\n\n    &.opens-inner > .is-dropdown-submenu {\n\n      top: 100%;\n      @if $global-text-direction == 'rtl' {\n        right: auto;\n      }\n      @else {\n        left: auto;\n      }\n    }\n\n    &.opens-left > .is-dropdown-submenu {\n      right: 100%;\n      left: auto;\n    }\n\n    &.opens-right > .is-dropdown-submenu {\n      right: auto;\n      left: 100%;\n    }\n  }\n\n  .is-dropdown-submenu {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 100%;\n    z-index: 1;\n\n    display: none;\n    min-width: $dropdownmenu-min-width;\n\n    border: $dropdownmenu-border;\n    background: $dropdownmenu-submenu-background;\n\n    .dropdown & a {\n      padding: $dropdownmenu-submenu-padding;\n    }\n\n    .is-dropdown-submenu-parent {\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n\n    @if (type-of($dropdownmenu-border-width) == 'number') {\n      .is-dropdown-submenu {\n        margin-top: (-$dropdownmenu-border-width);\n      }\n    }\n\n    > li {\n      width: 100%;\n    }\n\n    // [TODO] Cut back specificity\n    //&:not(.js-dropdown-nohover) > .is-dropdown-submenu-parent:hover > &, // why is this line needed? Opening is handled by JS and this causes some ugly flickering when the sub is re-positioned automatically...\n    &.js-dropdown-active {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group off-canvas\n////\n\n/// Width map of a left/right off-canvas panel.\n/// @type Map\n$offcanvas-sizes: (\n  small: 250px,\n) !default;\n\n/// Height map of a top/bottom off-canvas panel.\n/// @type Map\n$offcanvas-vertical-sizes: (\n  small: 250px,\n) !default;\n\n/// Background color of an off-canvas panel.\n/// @type Color\n$offcanvas-background: $light-gray !default;\n\n/// Box shadow for the off-canvas overlap panel.\n/// @type Shadow\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7) !default;\n\n/// Inner box shadow size for the off-canvas push panel.\n/// @type Number\n$offcanvas-inner-shadow-size: 20px !default;\n\n/// Inner box shadow color for the off-canvas push panel.\n/// @type Color\n$offcanvas-inner-shadow-color: rgba($black, 0.25) !default;\n\n/// Z-index of an off-canvas content overlay.\n/// @type Number\n$offcanvas-overlay-zindex: 11 !default;\n\n/// Z-index of an off-canvas panel with the `push` transition.\n/// @type Number\n$offcanvas-push-zindex: 12 !default;\n\n/// Z-index of an off-canvas panel with the `overlap` transition.\n/// @type Number\n$offcanvas-overlap-zindex: 13 !default;\n\n/// Z-index of an off-canvas panel using the `reveal-for-*` classes or mixin.\n/// @type Number\n$offcanvas-reveal-zindex: 12 !default;\n\n/// Length of the animation on an off-canvas panel.\n/// @type Number\n$offcanvas-transition-length: 0.5s !default;\n\n/// Timing function of the animation on an off-canvas panel.\n/// @type Keyword\n$offcanvas-transition-timing: ease !default;\n\n/// If `true`, a revealed off-canvas will be fixed-position, and scroll with the screen.\n/// @type Bool\n$offcanvas-fixed-reveal: true !default;\n\n/// Background color for the overlay that appears when an off-canvas panel is open.\n/// @type Color\n$offcanvas-exit-background: rgba($white, 0.25) !default;\n\n/// CSS class used for the main content area. The off-canvas mixins use this to target the page content.\n$maincontent-class: 'off-canvas-content' !default;\n\n/// Adds baseline styles for off-canvas. This CSS is required to make the other pieces work.\n@mixin off-canvas-basics {\n\n  /// Transform deprecated size settings into map & show warning\n  @if variable-exists(offcanvas-size) {\n    $offcanvas-sizes: (small: $offcanvas-size, medium: $offcanvas-size) !global;\n    @warn '$offcanvas-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-sizes instead';\n  }\n  @if variable-exists(offcanvas-vertical-size) {\n    $offcanvas-vertical-sizes: (small: $offcanvas-vertical-size, medium: $offcanvas-vertical-size) !global;\n    @warn '$offcanvas-vertical-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-vertical-sizes instead';\n  }\n\n  // Checks the z-indexes and increase them due to backwards compatibility.\n  // This is necessary because the overlay's z-index is new since v6.4 and may be identical to the user custom settings of the push z-index.\n  @if $offcanvas-push-zindex <= $offcanvas-overlay-zindex { $offcanvas-push-zindex: $offcanvas-overlay-zindex + 1 !global; }\n  @if $offcanvas-overlap-zindex <= $offcanvas-push-zindex { $offcanvas-overlap-zindex: $offcanvas-push-zindex + 1 !global; }\n  @if $offcanvas-reveal-zindex <= $offcanvas-overlay-zindex { $offcanvas-reveal-zindex: $offcanvas-overlay-zindex + 1 !global; }\n\n  // Hides overflow on body when an off-canvas panel is open.\n  .is-off-canvas-open {\n    overflow: hidden;\n  }\n\n  // Off-canvas overlay (generated by JavaScript)\n  .js-off-canvas-overlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    z-index: $offcanvas-overlay-zindex;\n\n    width: 100%;\n    height: 100%;\n\n    transition: opacity $offcanvas-transition-length $offcanvas-transition-timing, visibility $offcanvas-transition-length $offcanvas-transition-timing;\n\n    background: $offcanvas-exit-background;\n\n    opacity: 0;\n    visibility: hidden;\n\n    overflow: hidden;\n\n    &.is-visible {\n      opacity: 1;\n      visibility: visible;\n    }\n\n    &.is-closable {\n      cursor: pointer;\n    }\n\n    &.is-overlay-absolute {\n      position: absolute;\n    }\n\n    &.is-overlay-fixed {\n      position: fixed;\n    }\n  }\n}\n\n// Adds basic styles for an off-canvas wrapper.\n@mixin off-canvas-wrapper() {\n  position: relative;\n  overflow: hidden;\n}\n\n/// Adds basic styles for an off-canvas panel.\n@mixin off-canvas-base(\n  $background: $offcanvas-background,\n  $transition: $offcanvas-transition-length $offcanvas-transition-timing,\n  $fixed: true\n) {\n  @include disable-mouse-outline;\n\n  @if $fixed == true {\n    position: fixed;\n  }\n  @else {\n    position: absolute;\n  }\n\n  // Set the off-canvas z-index.\n  z-index: $offcanvas-push-zindex;\n\n  // Increase CSS specificity\n  &.is-transition-push {\n    z-index: $offcanvas-push-zindex;\n  }\n\n  transition: transform $transition;\n  backface-visibility: hidden;\n\n  background: $background;\n\n  // Hide inactive off-canvas within the content that have the same position\n  &.is-closed {\n    visibility: hidden;\n  }\n\n  // Overlap only styles.\n  &.is-transition-overlap {\n    z-index: $offcanvas-overlap-zindex;\n\n    &.is-open {\n      box-shadow: $offcanvas-shadow;\n    }\n  }\n\n  // Sets transform to 0 to show an off-canvas panel.\n  &.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles to position an off-canvas panel to the left/right/top/bottom.\n@mixin off-canvas-position(\n  $position: left,\n  $orientation: horizontal,\n  $sizes: if($orientation == horizontal, $offcanvas-sizes, $offcanvas-vertical-sizes)\n) {\n  @if $position == left {\n    top: 0;\n    left: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    top: 0;\n    right: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX(-$size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    top: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY(-$size);\n          }\n        }\n      }\n    }\n  }\n\n  // If $offcanvas-inner-shadow-size is set, add inner box-shadow.\n  // This mimics the off-canvas panel having a lower z-index, without having to have one.\n  @if $offcanvas-inner-shadow-size {\n    &.is-transition-push {\n      @if $position == left {\n        @include inner-side-shadow(right, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == right {\n        @include inner-side-shadow(left, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == top {\n        @include inner-side-shadow(bottom, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == bottom {\n        @include inner-side-shadow(top, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n    }\n  }\n\n}\n\n/// Sets the styles for the content container.\n@mixin off-canvas-content() {\n  transform: none;\n  transition: transform $offcanvas-transition-length $offcanvas-transition-timing;\n  backface-visibility: hidden;\n\n  // Transform scope until the element is closed (makes sure transitionend gets triggered)\n  &.has-transition-push {\n    transform: translate(0, 0);\n  }\n\n  // Consider element & content, nested in another content\n  .off-canvas.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles that reveal an off-canvas panel.\n@mixin off-canvas-reveal(\n$position: left,\n$zindex: $offcanvas-reveal-zindex,\n$content: $maincontent-class,\n$breakpoint: small\n) {\n  transform: none;\n  z-index: $zindex;\n  transition: none;\n  visibility: visible;\n\n  @if not $offcanvas-fixed-reveal {\n    position: absolute;\n  }\n\n  .close-button {\n    display: none;\n  }\n\n  // Consider revealed element is nested in content\n  .#{$maincontent-class} & {\n    transform: none;\n  }\n\n  @at-root .#{$content}.has-reveal-#{$position} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n\n  // backwards compatibility (prior to v6.4)\n  & ~ .#{$content} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n}\n\n/// Overrides the off-canvas styles\n@mixin in-canvas() {\n  visibility: visible;\n  height: auto;\n  position: static;\n  background: none;\n  width: auto;\n  overflow: visible;\n  transition: none;\n\n  // Increase CSS specificity\n  &.position-left,\n  &.position-right,\n  &.position-top,\n  &.position-bottom {\n    box-shadow: none;\n    transform: none;\n  }\n\n  .close-button {\n    display: none;\n  }\n}\n\n@mixin foundation-off-canvas {\n  @include off-canvas-basics;\n\n  // Off-canvas wrapper\n  .off-canvas-wrapper {\n    @include off-canvas-wrapper;\n  }\n\n  // Off-canvas container\n  .off-canvas {\n    @include off-canvas-base;\n\n    // Force position absolute for nested off-canvas because fixed doesn't work for push transition within the transform scope.\n    @at-root .#{$maincontent-class} & {\n      // NOTE: since overlap transition is currently forced if nested, there's no need to force position absolute until nested push transition is supported.\n      // position: absolute;\n    }\n  }\n\n  // Off-canvas container with absolute position\n  .off-canvas-absolute {\n    @include off-canvas-base($fixed: false);\n  }\n\n  // Off-canvas position classes\n  .position-left    { @include off-canvas-position(left,   horizontal); }\n  .position-right   { @include off-canvas-position(right,  horizontal); }\n  .position-top     { @include off-canvas-position(top,    vertical); }\n  .position-bottom  { @include off-canvas-position(bottom, vertical); }\n\n  .off-canvas-content {\n    @include off-canvas-content;\n  }\n\n  // Reveal off-canvas panel on larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .position-left.reveal-for-#{$name} {\n          @include off-canvas-reveal(left, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-right.reveal-for-#{$name} {\n          @include off-canvas-reveal(right, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-top.reveal-for-#{$name} {\n          @include off-canvas-reveal(top, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-bottom.reveal-for-#{$name} {\n          @include off-canvas-reveal(bottom, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n      }\n    }\n  }\n\n  // Move in-canvas for larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .off-canvas.in-canvas-for-#{$name} {\n          @include in-canvas;\n        }\n      }\n    }\n  }\n}\n\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@mixin foundation-sticky {\n  .sticky-container {\n    position: relative;\n  }\n\n  .sticky {\n    position: relative;\n    z-index: 0;\n    transform: translate3d(0, 0, 0);\n  }\n\n  .sticky.is-stuck {\n    position: fixed;\n    z-index: 5;\n    width: 100%;\n\n    &.is-at-top {\n      top: 0;\n    }\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n\n  .sticky.is-anchored {\n    position: relative;\n    right: auto;\n    left: auto;\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group title-bar\n////\n\n/// Background color of a title bar.\n/// @type Color\n$titlebar-background: $black !default;\n\n/// Color of text inside a title bar.\n/// @type Color\n$titlebar-color: $white !default;\n\n/// Padding inside a title bar.\n/// @type Length\n$titlebar-padding: 0.5rem !default;\n\n/// Font weight of text inside a title bar.\n/// @type Weight\n$titlebar-text-font-weight: bold !default;\n\n/// Color of menu icons inside a title bar.\n/// @type Color\n$titlebar-icon-color: $white !default;\n\n/// Color of menu icons inside a title bar on hover.\n/// @type Color\n$titlebar-icon-color-hover: $medium-gray !default;\n\n/// Spacing between the menu icon and text inside a title bar.\n/// @type Length\n$titlebar-icon-spacing: 0.25rem !default;\n\n@mixin foundation-title-bar {\n  .title-bar {\n    padding: $titlebar-padding;\n    background: $titlebar-background;\n    color: $titlebar-color;\n\n    @if $global-flexbox {\n      display: flex;\n      justify-content: flex-start;\n      align-items: center;\n    }\n    @else {\n      @include clearfix;\n    }\n\n    .menu-icon {\n      margin-#{$global-left}: $titlebar-icon-spacing;\n      margin-#{$global-right}: $titlebar-icon-spacing;\n    }\n  }\n\n  @if $global-flexbox {\n    .title-bar-left,\n    .title-bar-right {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n\n    .title-bar-right {\n      text-align: right;\n    }\n  }\n  @else {\n    .title-bar-left {\n      float: left;\n    }\n\n    .title-bar-right {\n      float: right;\n      text-align: right;\n    }\n  }\n\n  .title-bar-title {\n    display: inline-block;\n    vertical-align: middle;\n    font-weight: $titlebar-text-font-weight;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group top-bar\n////\n\n/// Padding for the top bar.\n/// @type Number\n$topbar-padding: 0.5rem !default;\n\n/// Background color for the top bar. This color also cascades to menus within the top bar.\n/// @type Color\n$topbar-background: $light-gray !default;\n\n/// Background color submenus within the top bar. Usefull if $topbar-background is transparent.\n/// @type Color\n$topbar-submenu-background: $topbar-background !default;\n\n/// Spacing for the top bar title.\n/// @type Number\n$topbar-title-spacing: 0.5rem 1rem 0.5rem 0 !default;\n\n/// Maximum width of `<input>` elements inside the top bar.\n/// @type Number\n$topbar-input-width: 200px !default;\n\n/// Breakpoint at which top bar switches from mobile to desktop view.\n/// @type Breakpoint\n$topbar-unstack-breakpoint: medium !default;\n\n/// Adds styles for a top bar container.\n@mixin top-bar-container {\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    justify-content: space-between;\n    align-items: center;\n  }\n  @else {\n    @include clearfix;\n  }\n\n  padding: $topbar-padding;\n\n  &,\n  ul {\n    background-color: $topbar-background;\n  }\n\n  // Check if $topbar-background is differnt from $topbar-background-submenu\n  @if ($topbar-background != $topbar-submenu-background) {\n    ul ul {\n      background-color: $topbar-submenu-background;\n    }\n  }\n\n  // Restrain width of inputs by default to make them easier to arrange\n  input {\n    max-width: $topbar-input-width;\n    margin-#{$global-right}: 1rem;\n  }\n\n  // The above styles shouldn't apply to input group fields\n  .input-group-field {\n    width: 100%;\n    margin-#{$global-right}: 0;\n  }\n\n  input.button { // sass-lint:disable-line no-qualifying-elements\n    width: auto;\n  }\n}\n\n/// Makes sections of a top bar stack on top of each other.\n@mixin top-bar-stacked {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 100%;\n      max-width: 100%;\n    }\n  }\n  @else {\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      width: 100%;\n    }\n  }\n}\n\n/// Undoes the CSS applied by the `top-bar-stacked()` mixin.\n@mixin top-bar-unstack {\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n\n    .top-bar-left {\n      flex: 1 1 auto;\n      margin-right: auto;\n    }\n\n    .top-bar-right {\n      flex: 0 1 auto;\n      margin-left: auto;\n    }\n  }\n  @else {\n    .top-bar-left,\n    .top-bar-right {\n      width: auto;\n    }\n  }\n}\n\n@mixin foundation-top-bar {\n  // Top bar container\n  .top-bar {\n    @include top-bar-container;\n\n    // Stack on small screens by default\n    @include top-bar-stacked;\n\n    @include breakpoint($topbar-unstack-breakpoint) {\n      @include top-bar-unstack;\n    }\n\n    // Generate classes for stacking on each screen size (defined in $breakpoint-classes)\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        &.stacked-for-#{$size} {\n          @include breakpoint($size down) {\n            @include top-bar-stacked;\n          }\n        }\n      }\n    }\n  }\n\n  // Sub-sections\n  @if $global-flexbox {\n    .top-bar-title {\n      flex: 0 0 auto;\n      margin: $topbar-title-spacing;\n    }\n\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 auto;\n    }\n  }\n  @else {\n    .top-bar-title {\n      display: inline-block;\n      float: left;\n      padding: $topbar-title-spacing;\n\n      .menu-icon {\n        bottom: 2px;\n      }\n    }\n\n    .top-bar-left {\n      float: left;\n    }\n\n    .top-bar-right {\n      float: right;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group float\n////\n\n@mixin foundation-float-classes {\n  .float-left {\n    float: left !important;\n  }\n\n  .float-right {\n    float: right !important;\n  }\n\n  .float-center {\n    display: block;\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  .clearfix {\n    @include clearfix;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// Hide an element by default, only displaying it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for($size) {\n  $size: map-get($breakpoints, $size);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/zurb/foundation-sites/issues/11313\n  $size: -zf-bp-to-em($size) - .00125;\n\n  @include breakpoint($size down) {\n    display: none !important;\n  }\n}\n\n/// Hide an element by default, only displaying it within a certain breakpoint.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for-only($size) {\n  $lower-bound-size: map-get($breakpoints, $size);\n  $upper-bound-size: -zf-map-next($breakpoints, $size);\n\n  // more often than not this will be correct, just one time round the loop it won't so set in scope here\n  $lower-bound: -zf-bp-to-em($lower-bound-size) - .00125;\n  // test actual lower-bound-size, if 0 set it to 0em\n  @if strip-unit($lower-bound-size) == 0 {\n    $lower-bound: -zf-bp-to-em($lower-bound-size);\n  }\n\n  @if $upper-bound-size == null {\n    @media screen and (max-width: $lower-bound) {\n      display: none !important;\n    }\n  }\n  @else {\n    $upper-bound: -zf-bp-to-em($upper-bound-size);\n\n    @media screen and (max-width: $lower-bound), screen and (min-width: $upper-bound) {\n      display: none !important;\n    }\n  }\n}\n\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for($size) {\n  @include breakpoint($size) {\n    display: none !important;\n  }\n}\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for-only($size) {\n  @include breakpoint($size only) {\n    display: none !important;\n  }\n}\n\n@mixin foundation-visibility-classes {\n  // Basic hiding classes\n  .hide {\n    display: none !important;\n  }\n\n  .invisible {\n    visibility: hidden;\n  }\n\n  // Responsive visibility classes\n  @each $size in $breakpoint-classes {\n    @if $size != $-zf-zero-breakpoint {\n      .hide-for-#{$size} {\n        @include hide-for($size);\n      }\n\n      .show-for-#{$size} {\n        @include show-for($size);\n      }\n    }\n\n    .hide-for-#{$size}-only {\n      @include hide-for-only($size);\n    }\n\n    .show-for-#{$size}-only {\n      @include show-for-only($size);\n    }\n  }\n\n  // Screen reader visibility classes\n  // Need a \"hide-for-sr\" class? Add aria-hidden='true' to the element\n  .show-for-sr,\n  .show-on-focus {\n    @include element-invisible;\n  }\n\n  // Only display the element when it's focused\n  .show-on-focus {\n    &:active,\n    &:focus {\n      @include element-invisible-off;\n    }\n  }\n\n  // Landscape and portrait visibility\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: block !important;\n\n    @include breakpoint(landscape) {\n      display: block !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: none !important;\n    }\n  }\n\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: none !important;\n\n    @include breakpoint(landscape) {\n      display: none !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: block !important;\n    }\n  }\n}\n"]}
\ No newline at end of file
index 455b035e2edca6100bc1523c3117abb024455b78..fa121079bbf72b1ff5af8fb79446f3de03bd980d 100644 (file)
@@ -1 +1,2 @@
-@charset "UTF-8";@media print,screen and (min-width:40em){.reveal,.reveal.large,.reveal.small,.reveal.tiny{right:auto;left:auto;margin:0 auto}}/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */html{font-family:sans-serif;line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure{display:block}figure{margin:1em 40px}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}main{display:block}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}a:active,a:hover{outline-width:0}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}input{overflow:visible}[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{-webkit-box-sizing:border-box;box-sizing:border-box;display:table;max-width:100%;padding:0;color:inherit;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}details{display:block}summary{display:list-item}menu{display:block}canvas{display:inline-block}template{display:none}[hidden]{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{-webkit-box-sizing:border-box;box-sizing:border-box;font-size:100%}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;padding:0;background:#fefefe;font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle;max-width:100%;height:auto;-ms-interpolation-mode:bicubic}textarea{height:auto;min-height:50px;border-radius:0}select{-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;border-radius:0}.map_canvas embed,.map_canvas img,.map_canvas object,.mqa-display embed,.mqa-display img,.mqa-display object{max-width:none!important}button{padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:0;background:0 0;line-height:1;cursor:auto}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}button,input,optgroup,select,textarea{font-family:inherit}.is-visible{display:block!important}.is-hidden{display:none!important}.row{max-width:75rem;margin-right:auto;margin-left:auto}.row::after,.row::before{display:table;content:' '}.row::after{clear:both}.row.collapse>.column,.row.collapse>.columns{padding-right:0;padding-left:0}.row .row{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.row .row{margin-right:-.9375rem;margin-left:-.9375rem}}@media print,screen and (min-width:64em){.row .row{margin-right:-.9375rem;margin-left:-.9375rem}}.row .row.collapse{margin-right:0;margin-left:0}.row.expanded{max-width:none}.row.expanded .row{margin-right:auto;margin-left:auto}.row:not(.expanded) .row{max-width:none}.row.gutter-small>.column,.row.gutter-small>.columns{padding-right:.625rem;padding-left:.625rem}.row.gutter-medium>.column,.row.gutter-medium>.columns{padding-right:.9375rem;padding-left:.9375rem}.column,.columns{width:100%;float:left;padding-right:.625rem;padding-left:.625rem}@media print,screen and (min-width:40em){.column,.columns{padding-right:.9375rem;padding-left:.9375rem}}.column:last-child:not(:first-child),.columns:last-child:not(:first-child){float:right}.column.end:last-child:last-child,.end.columns:last-child:last-child{float:left}.column.row.row,.row.row.columns{float:none}.row .column.row.row,.row .row.row.columns{margin-right:0;margin-left:0;padding-right:0;padding-left:0}.small-1{width:8.33333%}.small-push-1{position:relative;left:8.33333%}.small-pull-1{position:relative;left:-8.33333%}.small-offset-0{margin-left:0}.small-2{width:16.66667%}.small-push-2{position:relative;left:16.66667%}.small-pull-2{position:relative;left:-16.66667%}.small-offset-1{margin-left:8.33333%}.small-3{width:25%}.small-push-3{position:relative;left:25%}.small-pull-3{position:relative;left:-25%}.small-offset-2{margin-left:16.66667%}.small-4{width:33.33333%}.small-push-4{position:relative;left:33.33333%}.small-pull-4{position:relative;left:-33.33333%}.small-offset-3{margin-left:25%}.small-5{width:41.66667%}.small-push-5{position:relative;left:41.66667%}.small-pull-5{position:relative;left:-41.66667%}.small-offset-4{margin-left:33.33333%}.small-6{width:50%}.small-push-6{position:relative;left:50%}.small-pull-6{position:relative;left:-50%}.small-offset-5{margin-left:41.66667%}.small-7{width:58.33333%}.small-push-7{position:relative;left:58.33333%}.small-pull-7{position:relative;left:-58.33333%}.small-offset-6{margin-left:50%}.small-8{width:66.66667%}.small-push-8{position:relative;left:66.66667%}.small-pull-8{position:relative;left:-66.66667%}.small-offset-7{margin-left:58.33333%}.small-9{width:75%}.small-push-9{position:relative;left:75%}.small-pull-9{position:relative;left:-75%}.small-offset-8{margin-left:66.66667%}.small-10{width:83.33333%}.small-push-10{position:relative;left:83.33333%}.small-pull-10{position:relative;left:-83.33333%}.small-offset-9{margin-left:75%}.small-11{width:91.66667%}.small-push-11{position:relative;left:91.66667%}.small-pull-11{position:relative;left:-91.66667%}.small-offset-10{margin-left:83.33333%}.small-12{width:100%}.small-offset-11{margin-left:91.66667%}.small-up-1>.column,.small-up-1>.columns{float:left;width:100%}.small-up-1>.column:nth-of-type(1n),.small-up-1>.columns:nth-of-type(1n){clear:none}.small-up-1>.column:nth-of-type(1n+1),.small-up-1>.columns:nth-of-type(1n+1){clear:both}.small-up-1>.column:last-child,.small-up-1>.columns:last-child{float:left}.small-up-2>.column,.small-up-2>.columns{float:left;width:50%}.small-up-2>.column:nth-of-type(1n),.small-up-2>.columns:nth-of-type(1n){clear:none}.small-up-2>.column:nth-of-type(2n+1),.small-up-2>.columns:nth-of-type(2n+1){clear:both}.small-up-2>.column:last-child,.small-up-2>.columns:last-child{float:left}.small-up-3>.column,.small-up-3>.columns{float:left;width:33.33333%}.small-up-3>.column:nth-of-type(1n),.small-up-3>.columns:nth-of-type(1n){clear:none}.small-up-3>.column:nth-of-type(3n+1),.small-up-3>.columns:nth-of-type(3n+1){clear:both}.small-up-3>.column:last-child,.small-up-3>.columns:last-child{float:left}.small-up-4>.column,.small-up-4>.columns{float:left;width:25%}.small-up-4>.column:nth-of-type(1n),.small-up-4>.columns:nth-of-type(1n){clear:none}.small-up-4>.column:nth-of-type(4n+1),.small-up-4>.columns:nth-of-type(4n+1){clear:both}.small-up-4>.column:last-child,.small-up-4>.columns:last-child{float:left}.small-up-5>.column,.small-up-5>.columns{float:left;width:20%}.small-up-5>.column:nth-of-type(1n),.small-up-5>.columns:nth-of-type(1n){clear:none}.small-up-5>.column:nth-of-type(5n+1),.small-up-5>.columns:nth-of-type(5n+1){clear:both}.small-up-5>.column:last-child,.small-up-5>.columns:last-child{float:left}.small-up-6>.column,.small-up-6>.columns{float:left;width:16.66667%}.small-up-6>.column:nth-of-type(1n),.small-up-6>.columns:nth-of-type(1n){clear:none}.small-up-6>.column:nth-of-type(6n+1),.small-up-6>.columns:nth-of-type(6n+1){clear:both}.small-up-6>.column:last-child,.small-up-6>.columns:last-child{float:left}.small-up-7>.column,.small-up-7>.columns{float:left;width:14.28571%}.small-up-7>.column:nth-of-type(1n),.small-up-7>.columns:nth-of-type(1n){clear:none}.small-up-7>.column:nth-of-type(7n+1),.small-up-7>.columns:nth-of-type(7n+1){clear:both}.small-up-7>.column:last-child,.small-up-7>.columns:last-child{float:left}.small-up-8>.column,.small-up-8>.columns{float:left;width:12.5%}.small-up-8>.column:nth-of-type(1n),.small-up-8>.columns:nth-of-type(1n){clear:none}.small-up-8>.column:nth-of-type(8n+1),.small-up-8>.columns:nth-of-type(8n+1){clear:both}.small-up-8>.column:last-child,.small-up-8>.columns:last-child{float:left}.small-collapse>.column,.small-collapse>.columns{padding-right:0;padding-left:0}.small-collapse .row{margin-right:0;margin-left:0}.expanded.row .small-collapse.row{margin-right:0;margin-left:0}.small-uncollapse>.column,.small-uncollapse>.columns{padding-right:.625rem;padding-left:.625rem}.small-centered{margin-right:auto;margin-left:auto}.small-centered,.small-centered:last-child:not(:first-child){float:none;clear:both}.small-pull-0,.small-push-0,.small-uncentered{position:static;float:left;margin-right:0;margin-left:0}@media print,screen and (min-width:40em){.medium-1{width:8.33333%}.medium-push-1{position:relative;left:8.33333%}.medium-pull-1{position:relative;left:-8.33333%}.medium-offset-0{margin-left:0}.medium-2{width:16.66667%}.medium-push-2{position:relative;left:16.66667%}.medium-pull-2{position:relative;left:-16.66667%}.medium-offset-1{margin-left:8.33333%}.medium-3{width:25%}.medium-push-3{position:relative;left:25%}.medium-pull-3{position:relative;left:-25%}.medium-offset-2{margin-left:16.66667%}.medium-4{width:33.33333%}.medium-push-4{position:relative;left:33.33333%}.medium-pull-4{position:relative;left:-33.33333%}.medium-offset-3{margin-left:25%}.medium-5{width:41.66667%}.medium-push-5{position:relative;left:41.66667%}.medium-pull-5{position:relative;left:-41.66667%}.medium-offset-4{margin-left:33.33333%}.medium-6{width:50%}.medium-push-6{position:relative;left:50%}.medium-pull-6{position:relative;left:-50%}.medium-offset-5{margin-left:41.66667%}.medium-7{width:58.33333%}.medium-push-7{position:relative;left:58.33333%}.medium-pull-7{position:relative;left:-58.33333%}.medium-offset-6{margin-left:50%}.medium-8{width:66.66667%}.medium-push-8{position:relative;left:66.66667%}.medium-pull-8{position:relative;left:-66.66667%}.medium-offset-7{margin-left:58.33333%}.medium-9{width:75%}.medium-push-9{position:relative;left:75%}.medium-pull-9{position:relative;left:-75%}.medium-offset-8{margin-left:66.66667%}.medium-10{width:83.33333%}.medium-push-10{position:relative;left:83.33333%}.medium-pull-10{position:relative;left:-83.33333%}.medium-offset-9{margin-left:75%}.medium-11{width:91.66667%}.medium-push-11{position:relative;left:91.66667%}.medium-pull-11{position:relative;left:-91.66667%}.medium-offset-10{margin-left:83.33333%}.medium-12{width:100%}.medium-offset-11{margin-left:91.66667%}.medium-up-1>.column,.medium-up-1>.columns{float:left;width:100%}.medium-up-1>.column:nth-of-type(1n),.medium-up-1>.columns:nth-of-type(1n){clear:none}.medium-up-1>.column:nth-of-type(1n+1),.medium-up-1>.columns:nth-of-type(1n+1){clear:both}.medium-up-1>.column:last-child,.medium-up-1>.columns:last-child{float:left}.medium-up-2>.column,.medium-up-2>.columns{float:left;width:50%}.medium-up-2>.column:nth-of-type(1n),.medium-up-2>.columns:nth-of-type(1n){clear:none}.medium-up-2>.column:nth-of-type(2n+1),.medium-up-2>.columns:nth-of-type(2n+1){clear:both}.medium-up-2>.column:last-child,.medium-up-2>.columns:last-child{float:left}.medium-up-3>.column,.medium-up-3>.columns{float:left;width:33.33333%}.medium-up-3>.column:nth-of-type(1n),.medium-up-3>.columns:nth-of-type(1n){clear:none}.medium-up-3>.column:nth-of-type(3n+1),.medium-up-3>.columns:nth-of-type(3n+1){clear:both}.medium-up-3>.column:last-child,.medium-up-3>.columns:last-child{float:left}.medium-up-4>.column,.medium-up-4>.columns{float:left;width:25%}.medium-up-4>.column:nth-of-type(1n),.medium-up-4>.columns:nth-of-type(1n){clear:none}.medium-up-4>.column:nth-of-type(4n+1),.medium-up-4>.columns:nth-of-type(4n+1){clear:both}.medium-up-4>.column:last-child,.medium-up-4>.columns:last-child{float:left}.medium-up-5>.column,.medium-up-5>.columns{float:left;width:20%}.medium-up-5>.column:nth-of-type(1n),.medium-up-5>.columns:nth-of-type(1n){clear:none}.medium-up-5>.column:nth-of-type(5n+1),.medium-up-5>.columns:nth-of-type(5n+1){clear:both}.medium-up-5>.column:last-child,.medium-up-5>.columns:last-child{float:left}.medium-up-6>.column,.medium-up-6>.columns{float:left;width:16.66667%}.medium-up-6>.column:nth-of-type(1n),.medium-up-6>.columns:nth-of-type(1n){clear:none}.medium-up-6>.column:nth-of-type(6n+1),.medium-up-6>.columns:nth-of-type(6n+1){clear:both}.medium-up-6>.column:last-child,.medium-up-6>.columns:last-child{float:left}.medium-up-7>.column,.medium-up-7>.columns{float:left;width:14.28571%}.medium-up-7>.column:nth-of-type(1n),.medium-up-7>.columns:nth-of-type(1n){clear:none}.medium-up-7>.column:nth-of-type(7n+1),.medium-up-7>.columns:nth-of-type(7n+1){clear:both}.medium-up-7>.column:last-child,.medium-up-7>.columns:last-child{float:left}.medium-up-8>.column,.medium-up-8>.columns{float:left;width:12.5%}.medium-up-8>.column:nth-of-type(1n),.medium-up-8>.columns:nth-of-type(1n){clear:none}.medium-up-8>.column:nth-of-type(8n+1),.medium-up-8>.columns:nth-of-type(8n+1){clear:both}.medium-up-8>.column:last-child,.medium-up-8>.columns:last-child{float:left}.medium-collapse>.column,.medium-collapse>.columns{padding-right:0;padding-left:0}.medium-collapse .row{margin-right:0;margin-left:0}.expanded.row .medium-collapse.row{margin-right:0;margin-left:0}.medium-uncollapse>.column,.medium-uncollapse>.columns{padding-right:.9375rem;padding-left:.9375rem}.medium-centered{margin-right:auto;margin-left:auto}.medium-centered,.medium-centered:last-child:not(:first-child){float:none;clear:both}.medium-pull-0,.medium-push-0,.medium-uncentered{position:static;float:left;margin-right:0;margin-left:0}}@media print,screen and (min-width:64em){.large-1{width:8.33333%}.large-push-1{position:relative;left:8.33333%}.large-pull-1{position:relative;left:-8.33333%}.large-offset-0{margin-left:0}.large-2{width:16.66667%}.large-push-2{position:relative;left:16.66667%}.large-pull-2{position:relative;left:-16.66667%}.large-offset-1{margin-left:8.33333%}.large-3{width:25%}.large-push-3{position:relative;left:25%}.large-pull-3{position:relative;left:-25%}.large-offset-2{margin-left:16.66667%}.large-4{width:33.33333%}.large-push-4{position:relative;left:33.33333%}.large-pull-4{position:relative;left:-33.33333%}.large-offset-3{margin-left:25%}.large-5{width:41.66667%}.large-push-5{position:relative;left:41.66667%}.large-pull-5{position:relative;left:-41.66667%}.large-offset-4{margin-left:33.33333%}.large-6{width:50%}.large-push-6{position:relative;left:50%}.large-pull-6{position:relative;left:-50%}.large-offset-5{margin-left:41.66667%}.large-7{width:58.33333%}.large-push-7{position:relative;left:58.33333%}.large-pull-7{position:relative;left:-58.33333%}.large-offset-6{margin-left:50%}.large-8{width:66.66667%}.large-push-8{position:relative;left:66.66667%}.large-pull-8{position:relative;left:-66.66667%}.large-offset-7{margin-left:58.33333%}.large-9{width:75%}.large-push-9{position:relative;left:75%}.large-pull-9{position:relative;left:-75%}.large-offset-8{margin-left:66.66667%}.large-10{width:83.33333%}.large-push-10{position:relative;left:83.33333%}.large-pull-10{position:relative;left:-83.33333%}.large-offset-9{margin-left:75%}.large-11{width:91.66667%}.large-push-11{position:relative;left:91.66667%}.large-pull-11{position:relative;left:-91.66667%}.large-offset-10{margin-left:83.33333%}.large-12{width:100%}.large-offset-11{margin-left:91.66667%}.large-up-1>.column,.large-up-1>.columns{float:left;width:100%}.large-up-1>.column:nth-of-type(1n),.large-up-1>.columns:nth-of-type(1n){clear:none}.large-up-1>.column:nth-of-type(1n+1),.large-up-1>.columns:nth-of-type(1n+1){clear:both}.large-up-1>.column:last-child,.large-up-1>.columns:last-child{float:left}.large-up-2>.column,.large-up-2>.columns{float:left;width:50%}.large-up-2>.column:nth-of-type(1n),.large-up-2>.columns:nth-of-type(1n){clear:none}.large-up-2>.column:nth-of-type(2n+1),.large-up-2>.columns:nth-of-type(2n+1){clear:both}.large-up-2>.column:last-child,.large-up-2>.columns:last-child{float:left}.large-up-3>.column,.large-up-3>.columns{float:left;width:33.33333%}.large-up-3>.column:nth-of-type(1n),.large-up-3>.columns:nth-of-type(1n){clear:none}.large-up-3>.column:nth-of-type(3n+1),.large-up-3>.columns:nth-of-type(3n+1){clear:both}.large-up-3>.column:last-child,.large-up-3>.columns:last-child{float:left}.large-up-4>.column,.large-up-4>.columns{float:left;width:25%}.large-up-4>.column:nth-of-type(1n),.large-up-4>.columns:nth-of-type(1n){clear:none}.large-up-4>.column:nth-of-type(4n+1),.large-up-4>.columns:nth-of-type(4n+1){clear:both}.large-up-4>.column:last-child,.large-up-4>.columns:last-child{float:left}.large-up-5>.column,.large-up-5>.columns{float:left;width:20%}.large-up-5>.column:nth-of-type(1n),.large-up-5>.columns:nth-of-type(1n){clear:none}.large-up-5>.column:nth-of-type(5n+1),.large-up-5>.columns:nth-of-type(5n+1){clear:both}.large-up-5>.column:last-child,.large-up-5>.columns:last-child{float:left}.large-up-6>.column,.large-up-6>.columns{float:left;width:16.66667%}.large-up-6>.column:nth-of-type(1n),.large-up-6>.columns:nth-of-type(1n){clear:none}.large-up-6>.column:nth-of-type(6n+1),.large-up-6>.columns:nth-of-type(6n+1){clear:both}.large-up-6>.column:last-child,.large-up-6>.columns:last-child{float:left}.large-up-7>.column,.large-up-7>.columns{float:left;width:14.28571%}.large-up-7>.column:nth-of-type(1n),.large-up-7>.columns:nth-of-type(1n){clear:none}.large-up-7>.column:nth-of-type(7n+1),.large-up-7>.columns:nth-of-type(7n+1){clear:both}.large-up-7>.column:last-child,.large-up-7>.columns:last-child{float:left}.large-up-8>.column,.large-up-8>.columns{float:left;width:12.5%}.large-up-8>.column:nth-of-type(1n),.large-up-8>.columns:nth-of-type(1n){clear:none}.large-up-8>.column:nth-of-type(8n+1),.large-up-8>.columns:nth-of-type(8n+1){clear:both}.large-up-8>.column:last-child,.large-up-8>.columns:last-child{float:left}.large-collapse>.column,.large-collapse>.columns{padding-right:0;padding-left:0}.large-collapse .row{margin-right:0;margin-left:0}.expanded.row .large-collapse.row{margin-right:0;margin-left:0}.large-uncollapse>.column,.large-uncollapse>.columns{padding-right:.9375rem;padding-left:.9375rem}.large-centered{margin-right:auto;margin-left:auto}.large-centered,.large-centered:last-child:not(:first-child){float:none;clear:both}.large-pull-0,.large-push-0,.large-uncentered{position:static;float:left;margin-right:0;margin-left:0}}.column-block{margin-bottom:1.25rem}.column-block>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.column-block{margin-bottom:1.875rem}.column-block>:last-child{margin-bottom:0}}blockquote,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,li,ol,p,pre,td,th,ul{margin:0;padding:0}p{margin-bottom:1rem;font-size:inherit;line-height:1.6;text-rendering:optimizeLegibility}em,i{font-style:italic;line-height:inherit}b,strong{font-weight:700;line-height:inherit}small{font-size:80%;line-height:inherit}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-style:normal;font-weight:400;color:inherit;text-rendering:optimizeLegibility}.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small,h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{line-height:0;color:#cacaca}.h1,h1{font-size:1.5rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h2,h2{font-size:1.25rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h3,h3{font-size:1.1875rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h4,h4{font-size:1.125rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h5,h5{font-size:1.0625rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h6,h6{font-size:1rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}@media print,screen and (min-width:40em){.h1,h1{font-size:3rem}.h2,h2{font-size:2.5rem}.h3,h3{font-size:1.9375rem}.h4,h4{font-size:1.5625rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}}a{line-height:inherit;color:#1779ba;text-decoration:none;cursor:pointer}a:focus,a:hover{color:#1468a0}a img{border:0}hr{clear:both;max-width:75rem;height:0;margin:1.25rem auto;border-top:0;border-right:0;border-bottom:1px solid #cacaca;border-left:0}dl,ol,ul{margin-bottom:1rem;list-style-position:outside;line-height:1.6}li{font-size:inherit}ul{margin-left:1.25rem;list-style-type:disc}ol{margin-left:1.25rem}ol ol,ol ul,ul ol,ul ul{margin-left:1.25rem;margin-bottom:0}dl{margin-bottom:1rem}dl dt{margin-bottom:.3rem;font-weight:700}blockquote{margin:0 0 1rem;padding:.5625rem 1.25rem 0 1.1875rem;border-left:1px solid #cacaca}blockquote,blockquote p{line-height:1.6;color:#8a8a8a}cite{display:block;font-size:.8125rem;color:#8a8a8a}cite:before{content:"— "}abbr,abbr[title]{border-bottom:1px dotted #0a0a0a;cursor:help;text-decoration:none}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:400;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;color:#0a0a0a}.subheader{margin-top:.2rem;margin-bottom:.5rem;font-weight:400;line-height:1.4;color:#8a8a8a}.lead{font-size:125%;line-height:1.6}.stat{font-size:2.5rem;line-height:1}p+.stat{margin-top:-1rem}ol.no-bullet,ul.no-bullet{margin-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}@media print,screen and (min-width:40em){.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}}@media print,screen and (min-width:64em){.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}}.show-for-print{display:none!important}@media print{*{background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}.show-for-print{display:block!important}.hide-for-print{display:none!important}table.show-for-print{display:table!important}thead.show-for-print{display:table-header-group!important}tbody.show-for-print{display:table-row-group!important}tr.show-for-print{display:table-row!important}td.show-for-print{display:table-cell!important}th.show-for-print{display:table-cell!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}.ir a:after,a[href^='#']:after,a[href^='javascript:']:after{content:''}abbr[title]:after{content:" (" attr(title) ")"}blockquote,pre{border:1px solid #8a8a8a;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.print-break-inside{page-break-inside:auto}}[type=color],[type=date],[type=datetime-local],[type=datetime],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],textarea{display:block;-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;height:2.4375rem;margin:0 0 1rem;padding:.5rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;-webkit-box-shadow:inset 0 1px 2px rgba(10,10,10,.1);box-shadow:inset 0 1px 2px rgba(10,10,10,.1);font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s;-webkit-appearance:none;-moz-appearance:none;appearance:none}[type=color]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=datetime]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,textarea:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}textarea{max-width:100%}textarea[rows]{height:auto}input::-webkit-input-placeholder,textarea::-webkit-input-placeholder{color:#cacaca}input:-ms-input-placeholder,textarea:-ms-input-placeholder{color:#cacaca}input::placeholder,textarea::placeholder{color:#cacaca}input:disabled,input[readonly],textarea:disabled,textarea[readonly]{background-color:#e6e6e6;cursor:not-allowed}[type=button],[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}input[type=search]{-webkit-box-sizing:border-box;box-sizing:border-box}[type=checkbox],[type=file],[type=radio]{margin:0 0 1rem}[type=checkbox]+label,[type=radio]+label{display:inline-block;vertical-align:baseline;margin-left:.5rem;margin-right:1rem;margin-bottom:0}[type=checkbox]+label[for],[type=radio]+label[for]{cursor:pointer}label>[type=checkbox],label>[type=radio]{margin-right:.5rem}[type=file]{width:100%}label{display:block;margin:0;font-size:.875rem;font-weight:400;line-height:1.8;color:#0a0a0a}label.middle{margin:0 0 1rem;padding:.5625rem 0}.help-text{margin-top:-.5rem;font-size:.8125rem;font-style:italic;color:#0a0a0a}.input-group{display:table;width:100%;margin-bottom:1rem}.input-group>:first-child{border-radius:0}.input-group>:last-child>*{border-radius:0}.input-group-button,.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label,.input-group-field,.input-group-label{margin:0;white-space:nowrap;display:table-cell;vertical-align:middle}.input-group-label{padding:0 1rem;border:1px solid #cacaca;background:#e6e6e6;color:#0a0a0a;text-align:center;white-space:nowrap;width:1%;height:100%}.input-group-label:first-child{border-right:0}.input-group-label:last-child{border-left:0}.input-group-field{border-radius:0;height:2.5rem}.input-group-button{padding-top:0;padding-bottom:0;text-align:center;width:1%;height:100%}.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label{height:2.5rem;padding-top:0;padding-bottom:0;font-size:1rem}.input-group .input-group-button{display:table-cell}fieldset{margin:0;padding:0;border:0}legend{max-width:100%;margin-bottom:.5rem}.fieldset{margin:1.125rem 0;padding:1.25rem;border:1px solid #cacaca}.fieldset legend{margin:0;margin-left:-.1875rem;padding:0 .1875rem}select{height:2.4375rem;margin:0 0 1rem;padding:.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");-webkit-background-origin:content-box;background-origin:content-box;background-position:right -1rem center;background-repeat:no-repeat;-webkit-background-size:9px 6px;background-size:9px 6px;padding-right:1.5rem;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}@media screen and (min-width:0\0){select{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==)}}select:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}select:disabled{background-color:#e6e6e6;cursor:not-allowed}select::-ms-expand{display:none}select[multiple]{height:auto;background-image:none}.is-invalid-input:not(:focus){border-color:#cc4b37;background-color:#f9ecea}.is-invalid-input:not(:focus)::-webkit-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus):-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::placeholder{color:#cc4b37}.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700;color:#cc4b37}.form-error.is-visible{display:block}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem 0;font-family:inherit;padding:.85em 1em;-webkit-appearance:none;border:1px solid transparent;border-radius:0;-webkit-transition:background-color .25s ease-out,color .25s ease-out;transition:background-color .25s ease-out,color .25s ease-out;font-size:.9rem;line-height:1;text-align:center;cursor:pointer;background-color:#1779ba;color:#fefefe}[data-whatinput=mouse] .button{outline:0}.button:focus,.button:hover{background-color:#14679e;color:#fefefe}.button.tiny{font-size:.6rem}.button.small{font-size:.75rem}.button.large{font-size:1.25rem}.button.expanded{display:block;width:100%;margin-right:0;margin-left:0}.button.primary{background-color:#1779ba;color:#fefefe}.button.primary:focus,.button.primary:hover{background-color:#126195;color:#fefefe}.button.secondary{background-color:#767676;color:#fefefe}.button.secondary:focus,.button.secondary:hover{background-color:#5e5e5e;color:#fefefe}.button.success{background-color:#3adb76;color:#0a0a0a}.button.success:focus,.button.success:hover{background-color:#22bb5b;color:#0a0a0a}.button.warning{background-color:#ffae00;color:#0a0a0a}.button.warning:focus,.button.warning:hover{background-color:#cc8b00;color:#0a0a0a}.button.alert{background-color:#cc4b37;color:#fefefe}.button.alert:focus,.button.alert:hover{background-color:#a53b2a;color:#fefefe}.button.disabled,.button[disabled]{opacity:.25;cursor:not-allowed}.button.disabled,.button.disabled:focus,.button.disabled:hover,.button[disabled],.button[disabled]:focus,.button[disabled]:hover{background-color:#1779ba;color:#fefefe}.button.disabled.primary,.button[disabled].primary{opacity:.25;cursor:not-allowed}.button.disabled.primary,.button.disabled.primary:focus,.button.disabled.primary:hover,.button[disabled].primary,.button[disabled].primary:focus,.button[disabled].primary:hover{background-color:#1779ba;color:#fefefe}.button.disabled.secondary,.button[disabled].secondary{opacity:.25;cursor:not-allowed}.button.disabled.secondary,.button.disabled.secondary:focus,.button.disabled.secondary:hover,.button[disabled].secondary,.button[disabled].secondary:focus,.button[disabled].secondary:hover{background-color:#767676;color:#fefefe}.button.disabled.success,.button[disabled].success{opacity:.25;cursor:not-allowed}.button.disabled.success,.button.disabled.success:focus,.button.disabled.success:hover,.button[disabled].success,.button[disabled].success:focus,.button[disabled].success:hover{background-color:#3adb76;color:#0a0a0a}.button.disabled.warning,.button[disabled].warning{opacity:.25;cursor:not-allowed}.button.disabled.warning,.button.disabled.warning:focus,.button.disabled.warning:hover,.button[disabled].warning,.button[disabled].warning:focus,.button[disabled].warning:hover{background-color:#ffae00;color:#0a0a0a}.button.disabled.alert,.button[disabled].alert{opacity:.25;cursor:not-allowed}.button.disabled.alert,.button.disabled.alert:focus,.button.disabled.alert:hover,.button[disabled].alert,.button[disabled].alert:focus,.button[disabled].alert:hover{background-color:#cc4b37;color:#fefefe}.button.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow.disabled,.button.hollow.disabled:focus,.button.hollow.disabled:hover,.button.hollow[disabled],.button.hollow[disabled]:focus,.button.hollow[disabled]:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow:focus.disabled,.button.hollow:focus[disabled],.button.hollow:hover.disabled,.button.hollow:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary:focus.disabled,.button.hollow.primary:focus[disabled],.button.hollow.primary:hover.disabled,.button.hollow.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.secondary:focus.disabled,.button.hollow.secondary:focus[disabled],.button.hollow.secondary:hover.disabled,.button.hollow.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.success:focus.disabled,.button.hollow.success:focus[disabled],.button.hollow.success:hover.disabled,.button.hollow.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.warning:focus.disabled,.button.hollow.warning:focus[disabled],.button.hollow.warning:hover.disabled,.button.hollow.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.button.hollow.alert:focus.disabled,.button.hollow.alert:focus[disabled],.button.hollow.alert:hover.disabled,.button.hollow.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear:focus,.button.clear:hover{background-color:transparent}.button.clear.disabled,.button.clear.disabled:focus,.button.clear.disabled:hover,.button.clear[disabled],.button.clear[disabled]:focus,.button.clear[disabled]:hover{background-color:transparent}.button.clear:focus,.button.clear:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover.disabled,.button.clear:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear.disabled,.button.clear:focus,.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover,.button.clear:hover.disabled,.button.clear:hover[disabled],.button.clear[disabled]{border-color:transparent}.button.clear.primary{border:1px solid #1779ba;color:#1779ba}.button.clear.primary:focus,.button.clear.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear.primary,.button.clear.primary.disabled,.button.clear.primary:focus,.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover,.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled],.button.clear.primary[disabled]{border-color:transparent}.button.clear.secondary{border:1px solid #767676;color:#767676}.button.clear.secondary:focus,.button.clear.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.clear.secondary,.button.clear.secondary.disabled,.button.clear.secondary:focus,.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover,.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled],.button.clear.secondary[disabled]{border-color:transparent}.button.clear.success{border:1px solid #3adb76;color:#3adb76}.button.clear.success:focus,.button.clear.success:hover{border-color:#157539;color:#157539}.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover.disabled,.button.clear.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.clear.success,.button.clear.success.disabled,.button.clear.success:focus,.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover,.button.clear.success:hover.disabled,.button.clear.success:hover[disabled],.button.clear.success[disabled]{border-color:transparent}.button.clear.warning{border:1px solid #ffae00;color:#ffae00}.button.clear.warning:focus,.button.clear.warning:hover{border-color:#805700;color:#805700}.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.clear.warning,.button.clear.warning.disabled,.button.clear.warning:focus,.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover,.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled],.button.clear.warning[disabled]{border-color:transparent}.button.clear.alert{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert:focus,.button.clear.alert:hover{border-color:#67251a;color:#67251a}.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert,.button.clear.alert.disabled,.button.clear.alert:focus,.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover,.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled],.button.clear.alert[disabled]{border-color:transparent}.button.dropdown::after{display:block;width:0;height:0;border:inset .4em;content:'';border-bottom-width:0;border-top-style:solid;border-color:#fefefe transparent transparent;position:relative;top:.4em;display:inline-block;float:right;margin-left:1em}.button.dropdown.hollow::after{border-top-color:#1779ba}.button.dropdown.hollow.primary::after{border-top-color:#1779ba}.button.dropdown.hollow.secondary::after{border-top-color:#767676}.button.dropdown.hollow.success::after{border-top-color:#3adb76}.button.dropdown.hollow.warning::after{border-top-color:#ffae00}.button.dropdown.hollow.alert::after{border-top-color:#cc4b37}.button.arrow-only::after{top:-.1em;float:none;margin-left:0}a.button:focus,a.button:hover{text-decoration:none}.accordion{margin-left:0;background:#fefefe;list-style-type:none}.accordion[disabled] .accordion-title{cursor:not-allowed}.accordion-item:first-child>:first-child{border-radius:0}.accordion-item:last-child>:last-child{border-radius:0}.accordion-title{position:relative;display:block;padding:1.25rem 1rem;border:1px solid #e6e6e6;border-bottom:0;font-size:.75rem;line-height:1;color:#1779ba}:last-child:not(.is-active)>.accordion-title{border-bottom:1px solid #e6e6e6;border-radius:0}.accordion-title:focus,.accordion-title:hover{background-color:#e6e6e6}.accordion-title::before{position:absolute;top:50%;right:1rem;margin-top:-.5rem;content:'+'}.is-active>.accordion-title::before{content:'\2013'}.accordion-content{display:none;padding:1rem;border:1px solid #e6e6e6;border-bottom:0;background-color:#fefefe;color:#0a0a0a}:last-child>.accordion-content:last-child{border-bottom:1px solid #e6e6e6}.accordion-menu li{width:100%}.accordion-menu a{padding:.7rem 1rem}.accordion-menu .is-accordion-submenu a{padding:.7rem 1rem}.accordion-menu .nested.is-accordion-submenu{margin-right:0;margin-left:1rem}.accordion-menu.align-right .nested.is-accordion-submenu{margin-right:1rem;margin-left:0}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a{position:relative}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;right:1rem}.accordion-menu.align-left .is-accordion-submenu-parent>a::after{left:auto;right:1rem}.accordion-menu.align-right .is-accordion-submenu-parent>a::after{right:auto;left:1rem}.accordion-menu .is-accordion-submenu-parent[aria-expanded=true]>a::after{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.is-accordion-submenu-parent{position:relative}.has-submenu-toggle>a{margin-right:40px}.submenu-toggle{position:absolute;top:0;right:0;cursor:pointer;width:40px;height:40px}.submenu-toggle::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;top:0;bottom:0;margin:auto}.submenu-toggle[aria-expanded=true]::after{-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.submenu-toggle-text{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center;background:#1779ba;color:#fefefe}.badge.primary{background:#1779ba;color:#fefefe}.badge.secondary{background:#767676;color:#fefefe}.badge.success{background:#3adb76;color:#0a0a0a}.badge.warning{background:#ffae00;color:#0a0a0a}.badge.alert{background:#cc4b37;color:#fefefe}.breadcrumbs{margin:0 0 1rem 0;list-style:none}.breadcrumbs::after,.breadcrumbs::before{display:table;content:' '}.breadcrumbs::after{clear:both}.breadcrumbs li{float:left;font-size:.6875rem;color:#0a0a0a;cursor:default;text-transform:uppercase}.breadcrumbs li:not(:last-child)::after{position:relative;margin:0 .75rem;opacity:1;content:"/";color:#cacaca}.breadcrumbs a{color:#1779ba}.breadcrumbs a:hover{text-decoration:underline}.breadcrumbs .disabled{color:#cacaca;cursor:not-allowed}.button-group{margin-bottom:1rem;font-size:0}.button-group::after,.button-group::before{display:table;content:' '}.button-group::after{clear:both}.button-group .button{margin:0;margin-right:1px;margin-bottom:1px;font-size:.9rem}.button-group .button:last-child{margin-right:0}.button-group.tiny .button{font-size:.6rem}.button-group.small .button{font-size:.75rem}.button-group.large .button{font-size:1.25rem}.button-group.expanded{margin-right:-1px}.button-group.expanded::after,.button-group.expanded::before{display:none}.button-group.expanded .button:first-child:last-child{width:100%}.button-group.expanded .button:first-child:nth-last-child(2),.button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button{display:inline-block;width:calc(50% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(2):last-child{margin-right:-6px}.button-group.expanded .button:first-child:nth-last-child(3),.button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button{display:inline-block;width:calc(33.33333% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(3):last-child{margin-right:-6px}.button-group.expanded .button:first-child:nth-last-child(4),.button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button{display:inline-block;width:calc(25% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(4):last-child{margin-right:-6px}.button-group.expanded .button:first-child:nth-last-child(5),.button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button{display:inline-block;width:calc(20% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(5):last-child{margin-right:-6px}.button-group.expanded .button:first-child:nth-last-child(6),.button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button{display:inline-block;width:calc(16.66667% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(6):last-child{margin-right:-6px}.button-group.primary .button{background-color:#1779ba;color:#fefefe}.button-group.primary .button:focus,.button-group.primary .button:hover{background-color:#126195;color:#fefefe}.button-group.secondary .button{background-color:#767676;color:#fefefe}.button-group.secondary .button:focus,.button-group.secondary .button:hover{background-color:#5e5e5e;color:#fefefe}.button-group.success .button{background-color:#3adb76;color:#0a0a0a}.button-group.success .button:focus,.button-group.success .button:hover{background-color:#22bb5b;color:#0a0a0a}.button-group.warning .button{background-color:#ffae00;color:#0a0a0a}.button-group.warning .button:focus,.button-group.warning .button:hover{background-color:#cc8b00;color:#0a0a0a}.button-group.alert .button{background-color:#cc4b37;color:#fefefe}.button-group.alert .button:focus,.button-group.alert .button:hover{background-color:#a53b2a;color:#fefefe}.button-group.stacked .button,.button-group.stacked-for-medium .button,.button-group.stacked-for-small .button{width:100%}.button-group.stacked .button:last-child,.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.button-group.stacked-for-small .button{width:auto;margin-bottom:0}}@media print,screen and (min-width:64em){.button-group.stacked-for-medium .button{width:auto;margin-bottom:0}}@media screen and (max-width:39.9375em){.button-group.stacked-for-small.expanded{display:block}.button-group.stacked-for-small.expanded .button{display:block;margin-right:0}}.callout{position:relative;margin:0 0 1rem 0;padding:1rem;border:1px solid rgba(10,10,10,.25);border-radius:0;background-color:#fff;color:#0a0a0a}.callout>:first-child{margin-top:0}.callout>:last-child{margin-bottom:0}.callout.primary{background-color:#d7ecfa;color:#0a0a0a}.callout.secondary{background-color:#eaeaea;color:#0a0a0a}.callout.success{background-color:#e1faea;color:#0a0a0a}.callout.warning{background-color:#fff3d9;color:#0a0a0a}.callout.alert{background-color:#f7e4e1;color:#0a0a0a}.callout.small{padding-top:.5rem;padding-right:.5rem;padding-bottom:.5rem;padding-left:.5rem}.callout.large{padding-top:3rem;padding-right:3rem;padding-bottom:3rem;padding-left:3rem}.card{margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;color:#0a0a0a}.card>:last-child{margin-bottom:0}.card-divider{padding:1rem;background:#e6e6e6}.card-divider>:last-child{margin-bottom:0}.card-section{padding:1rem}.card-section>:last-child{margin-bottom:0}.card-image{min-height:1px}.close-button{position:absolute;color:#8a8a8a;cursor:pointer}[data-whatinput=mouse] .close-button{outline:0}.close-button:focus,.close-button:hover{color:#0a0a0a}.close-button.small{right:.66rem;top:.33em;font-size:1.5em;line-height:1}.close-button,.close-button.medium{right:1rem;top:.5rem;font-size:2em;line-height:1}.menu{padding:0;margin:0;list-style:none;position:relative}[data-whatinput=mouse] .menu li{outline:0}.menu .button,.menu a{line-height:1;text-decoration:none;display:block;padding:.7rem 1rem}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu input{display:inline-block}.menu li,.menu.horizontal li{display:inline-block}.menu.vertical li{display:block}.menu.expanded{display:table;width:100%}.menu.expanded>li{display:table-cell;vertical-align:middle}.menu.simple li+li{margin-left:1rem}.menu.simple a{padding:0}@media print,screen and (min-width:40em){.menu.medium-horizontal li{display:inline-block}.menu.medium-vertical li{display:block}.menu.medium-expanded{display:table;width:100%}.menu.medium-expanded>li{display:table-cell;vertical-align:middle}.menu.medium-simple{display:table;width:100%}.menu.medium-simple>li{display:table-cell;vertical-align:middle}}@media print,screen and (min-width:64em){.menu.large-horizontal li{display:inline-block}.menu.large-vertical li{display:block}.menu.large-expanded{display:table;width:100%}.menu.large-expanded>li{display:table-cell;vertical-align:middle}.menu.large-simple{display:table;width:100%}.menu.large-simple>li{display:table-cell;vertical-align:middle}}.menu.nested{margin-right:0;margin-left:1rem}.menu.icons i,.menu.icons img,.menu.icons svg{vertical-align:middle}.menu.icons i+span,.menu.icons img+span,.menu.icons svg+span{vertical-align:middle}.menu.icon-bottom i,.menu.icon-bottom img,.menu.icon-bottom svg,.menu.icon-left i,.menu.icon-left img,.menu.icon-left svg,.menu.icon-right i,.menu.icon-right img,.menu.icon-right svg,.menu.icon-top i,.menu.icon-top img,.menu.icon-top svg{vertical-align:middle}.menu.icon-bottom i+span,.menu.icon-bottom img+span,.menu.icon-bottom svg+span,.menu.icon-left i+span,.menu.icon-left img+span,.menu.icon-left svg+span,.menu.icon-right i+span,.menu.icon-right img+span,.menu.icon-right svg+span,.menu.icon-top i+span,.menu.icon-top img+span,.menu.icon-top svg+span{vertical-align:middle}.menu.icon-left li a i,.menu.icon-left li a img,.menu.icon-left li a svg{margin-right:.25rem;display:inline-block}.menu.icon-right li a i,.menu.icon-right li a img,.menu.icon-right li a svg{margin-left:.25rem;display:inline-block}.menu.icon-top li a{text-align:center}.menu.icon-top li a i,.menu.icon-top li a img,.menu.icon-top li a svg{display:block;margin:0 auto .25rem}.menu.icon-bottom li a{text-align:center}.menu.icon-bottom li a i,.menu.icon-bottom li a img,.menu.icon-bottom li a svg{display:block;margin:.25rem auto 0}.menu .is-active>a{background:#1779ba;color:#fefefe}.menu .active>a{background:#1779ba;color:#fefefe}.menu.align-left{text-align:left}.menu.align-right{text-align:right}.menu.align-right .submenu li{text-align:left}.menu.align-right.vertical .submenu li{text-align:right}.menu.align-right .nested{margin-right:1rem;margin-left:0}.menu.align-center{text-align:center}.menu.align-center .submenu li{text-align:left}.menu .menu-text{padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered>.menu{text-align:center}.menu-centered>.menu .submenu li{text-align:left}.no-js [data-responsive-menu] ul{display:none}.menu-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#fefefe;-webkit-box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:''}.menu-icon:hover::after{background:#cacaca;-webkit-box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.menu-icon.dark{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon.dark::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;-webkit-box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:''}.menu-icon.dark:hover::after{background:#8a8a8a;-webkit-box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a;box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a}.is-drilldown{position:relative;overflow:hidden}.is-drilldown li{display:block}.is-drilldown.animate-height{-webkit-transition:height .5s;transition:height .5s}.drilldown a{padding:.7rem 1rem;background:#fefefe}.drilldown .is-drilldown-submenu{position:absolute;top:0;left:100%;z-index:-1;width:100%;background:#fefefe;-webkit-transition:-webkit-transform .15s linear;transition:-webkit-transform .15s linear;transition:transform .15s linear;transition:transform .15s linear,-webkit-transform .15s linear}.drilldown .is-drilldown-submenu.is-active{z-index:1;display:block;-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%)}.drilldown .is-drilldown-submenu.is-closing{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%)}.drilldown .is-drilldown-submenu a{padding:.7rem 1rem}.drilldown .nested.is-drilldown-submenu{margin-right:0;margin-left:0}.drilldown .drilldown-submenu-cover-previous{min-height:100%}.drilldown .is-drilldown-submenu-parent>a{position:relative}.drilldown .is-drilldown-submenu-parent>a::after{position:absolute;top:50%;margin-top:-6px;right:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.drilldown.align-left .is-drilldown-submenu-parent>a::after{left:auto;right:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.drilldown.align-right .is-drilldown-submenu-parent>a::after{right:auto;left:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.drilldown .js-drilldown-back>a::before{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;border-left-width:0;display:inline-block;vertical-align:middle;margin-right:.75rem;border-left-width:0}.dropdown-pane{position:absolute;z-index:10;width:300px;padding:1rem;visibility:hidden;display:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-opening{display:block}.dropdown-pane.is-open{visibility:visible;display:block}.dropdown-pane.tiny{width:100px}.dropdown-pane.small{width:200px}.dropdown-pane.large{width:400px}.dropdown.menu>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu a{padding:.7rem 1rem}[data-whatinput=mouse] .dropdown.menu a{outline:0}.dropdown.menu .is-active>a{background:0 0;color:#1779ba}.no-js .dropdown.menu ul{display:none}.dropdown.menu .nested.is-dropdown-submenu{margin-right:0;margin-left:0}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.vertical>li>a::after{right:14px}.dropdown.menu.vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}@media print,screen and (min-width:40em){.dropdown.menu.medium-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.medium-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.medium-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.medium-vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.medium-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.medium-vertical>li>a::after{right:14px}.dropdown.menu.medium-vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.medium-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}@media print,screen and (min-width:64em){.dropdown.menu.large-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.large-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.large-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.large-vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.large-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.large-vertical>li>a::after{right:14px}.dropdown.menu.large-vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.large-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}.dropdown.menu.align-right .is-dropdown-submenu.first-sub{top:100%;right:0;left:auto}.is-dropdown-menu.vertical{width:100px}.is-dropdown-menu.vertical.align-right{float:right}.is-dropdown-submenu-parent{position:relative}.is-dropdown-submenu-parent a::after{position:absolute;top:50%;right:5px;left:auto;margin-top:-6px}.is-dropdown-submenu-parent.opens-inner>.is-dropdown-submenu{top:100%;left:auto}.is-dropdown-submenu-parent.opens-left>.is-dropdown-submenu{right:100%;left:auto}.is-dropdown-submenu-parent.opens-right>.is-dropdown-submenu{right:auto;left:100%}.is-dropdown-submenu{position:absolute;top:0;left:100%;z-index:1;display:none;min-width:200px;border:1px solid #cacaca;background:#fefefe}.dropdown .is-dropdown-submenu a{padding:.7rem 1rem}.is-dropdown-submenu .is-dropdown-submenu-parent>a::after{right:14px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.is-dropdown-submenu .is-dropdown-submenu{margin-top:-1px}.is-dropdown-submenu>li{width:100%}.is-dropdown-submenu.js-dropdown-active{display:block}.flex-video,.responsive-embed{position:relative;height:0;margin-bottom:1rem;padding-bottom:75%;overflow:hidden}.flex-video embed,.flex-video iframe,.flex-video object,.flex-video video,.responsive-embed embed,.responsive-embed iframe,.responsive-embed object,.responsive-embed video{position:absolute;top:0;left:0;width:100%;height:100%}.flex-video.widescreen,.responsive-embed.widescreen{padding-bottom:56.25%}.label{display:inline-block;padding:.33333rem .5rem;border-radius:0;font-size:.8rem;line-height:1;white-space:nowrap;cursor:default;background:#1779ba;color:#fefefe}.label.primary{background:#1779ba;color:#fefefe}.label.secondary{background:#767676;color:#fefefe}.label.success{background:#3adb76;color:#0a0a0a}.label.warning{background:#ffae00;color:#0a0a0a}.label.alert{background:#cc4b37;color:#fefefe}.media-object{display:block;margin-bottom:1rem}.media-object img{max-width:none}@media screen and (max-width:39.9375em){.media-object.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;display:block}.media-object.stack-for-small .media-object-section img{width:100%}}.media-object-section{display:table-cell;vertical-align:top}.media-object-section:first-child{padding-right:1rem}.media-object-section:last-child:not(:nth-child(2)){padding-left:1rem}.media-object-section>:last-child{margin-bottom:0}.media-object-section.middle{vertical-align:middle}.media-object-section.bottom{vertical-align:bottom}.is-off-canvas-open{overflow:hidden}.js-off-canvas-overlay{position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;-webkit-transition:opacity .5s ease,visibility .5s ease;transition:opacity .5s ease,visibility .5s ease;background:rgba(254,254,254,.25);opacity:0;visibility:hidden;overflow:hidden}.js-off-canvas-overlay.is-visible{opacity:1;visibility:visible}.js-off-canvas-overlay.is-closable{cursor:pointer}.js-off-canvas-overlay.is-overlay-absolute{position:absolute}.js-off-canvas-overlay.is-overlay-fixed{position:fixed}.off-canvas-wrapper{position:relative;overflow:hidden}.off-canvas{position:fixed;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-push{z-index:12}.off-canvas.is-closed{visibility:hidden}.off-canvas.is-transition-overlap{z-index:13}.off-canvas.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-absolute{position:absolute;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas-absolute{outline:0}.off-canvas-absolute.is-transition-push{z-index:12}.off-canvas-absolute.is-closed{visibility:hidden}.off-canvas-absolute.is-transition-overlap{z-index:13}.off-canvas-absolute.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas-absolute.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.position-left{top:0;left:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-left.has-transition-push{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.position-left.is-transition-push{-webkit-box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25)}.position-right{top:0;right:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-right.has-transition-push{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.position-right.is-transition-push{-webkit-box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25)}.position-top{top:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-top.has-transition-push{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.position-top.is-transition-push{-webkit-box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25)}.position-bottom{bottom:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-bottom.has-transition-push{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.position-bottom.is-transition-push{-webkit-box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25)}.off-canvas-content{-webkit-transform:none;-ms-transform:none;transform:none;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.off-canvas-content.has-transition-push{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content .off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}@media print,screen and (min-width:40em){.position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-medium .close-button{display:none}.off-canvas-content .position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-medium .close-button{display:none}.off-canvas-content .position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-medium .close-button{display:none}.off-canvas-content .position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-medium .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:64em){.position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-large .close-button{display:none}.off-canvas-content .position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-large .close-button{display:none}.off-canvas-content .position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-large .close-button{display:none}.off-canvas-content .position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-large .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:40em){.off-canvas.in-canvas-for-medium{visibility:visible;height:auto;position:static;background:inherit;width:inherit;overflow:inherit;-webkit-transition:inherit;transition:inherit}.off-canvas.in-canvas-for-medium.position-bottom,.off-canvas.in-canvas-for-medium.position-left,.off-canvas.in-canvas-for-medium.position-right,.off-canvas.in-canvas-for-medium.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-medium .close-button{display:none}}@media print,screen and (min-width:64em){.off-canvas.in-canvas-for-large{visibility:visible;height:auto;position:static;background:inherit;width:inherit;overflow:inherit;-webkit-transition:inherit;transition:inherit}.off-canvas.in-canvas-for-large.position-bottom,.off-canvas.in-canvas-for-large.position-left,.off-canvas.in-canvas-for-large.position-right,.off-canvas.in-canvas-for-large.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-large .close-button{display:none}}.orbit{position:relative}.orbit-container{position:relative;height:0;margin:0;list-style:none;overflow:hidden}.orbit-slide{width:100%}.orbit-slide.no-motionui.is-active{top:0;left:0}.orbit-figure{margin:0}.orbit-image{width:100%;max-width:100%;margin:0}.orbit-caption{position:absolute;bottom:0;width:100%;margin-bottom:0;padding:1rem;background-color:rgba(10,10,10,.5);color:#fefefe}.orbit-next,.orbit-previous{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);z-index:10;padding:1rem;color:#fefefe}[data-whatinput=mouse] .orbit-next,[data-whatinput=mouse] .orbit-previous{outline:0}.orbit-next:active,.orbit-next:focus,.orbit-next:hover,.orbit-previous:active,.orbit-previous:focus,.orbit-previous:hover{background-color:rgba(10,10,10,.5)}.orbit-previous{left:0}.orbit-next{left:auto;right:0}.orbit-bullets{position:relative;margin-top:.8rem;margin-bottom:.8rem;text-align:center}[data-whatinput=mouse] .orbit-bullets{outline:0}.orbit-bullets button{width:1.2rem;height:1.2rem;margin:.1rem;border-radius:50%;background-color:#cacaca}.orbit-bullets button:hover{background-color:#8a8a8a}.orbit-bullets button.is-active{background-color:#8a8a8a}.pagination{margin-left:0;margin-bottom:1rem}.pagination::after,.pagination::before{display:table;content:' '}.pagination::after{clear:both}.pagination li{margin-right:.0625rem;border-radius:0;font-size:.875rem;display:none}.pagination li:first-child,.pagination li:last-child{display:inline-block}@media print,screen and (min-width:40em){.pagination li{display:inline-block}}.pagination a,.pagination button{display:block;padding:.1875rem .625rem;border-radius:0;color:#0a0a0a}.pagination a:hover,.pagination button:hover{background:#e6e6e6}.pagination .current{padding:.1875rem .625rem;background:#1779ba;color:#fefefe;cursor:default}.pagination .disabled{padding:.1875rem .625rem;color:#cacaca;cursor:not-allowed}.pagination .disabled:hover{background:0 0}.pagination .ellipsis::after{padding:.1875rem .625rem;content:'\2026';color:#0a0a0a}.pagination-previous a::before,.pagination-previous.disabled::before{display:inline-block;margin-right:.5rem;content:'\00ab'}.pagination-next a::after,.pagination-next.disabled::after{display:inline-block;margin-left:.5rem;content:'\00bb'}.progress{height:1rem;margin-bottom:1rem;border-radius:0;background-color:#cacaca}.progress.primary .progress-meter{background-color:#1779ba}.progress.secondary .progress-meter{background-color:#767676}.progress.success .progress-meter{background-color:#3adb76}.progress.warning .progress-meter{background-color:#ffae00}.progress.alert .progress-meter{background-color:#cc4b37}.progress-meter{position:relative;display:block;width:0%;height:100%;background-color:#1779ba}.progress-meter-text{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);transform:translate(-50%,-50%);position:absolute;margin:0;font-size:.75rem;font-weight:700;color:#fefefe;white-space:nowrap}.slider{position:relative;height:.5rem;margin-top:1.25rem;margin-bottom:2.25rem;background-color:#e6e6e6;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none}.slider-fill{position:absolute;top:0;left:0;display:inline-block;max-width:100%;height:.5rem;background-color:#cacaca;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.slider-fill.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider-handle{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;-ms-touch-action:manipulation;touch-action:manipulation}[data-whatinput=mouse] .slider-handle{outline:0}.slider-handle:hover{background-color:#14679e}.slider-handle.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider.disabled,.slider[disabled]{opacity:.25;cursor:not-allowed}.slider.vertical{display:inline-block;width:.5rem;height:12.5rem;margin:0 1.25rem;-webkit-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scale(1,-1)}.slider.vertical .slider-fill{top:0;width:.5rem;max-height:100%}.slider.vertical .slider-handle{position:absolute;top:0;left:50%;width:1.4rem;height:1.4rem;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.sticky-container{position:relative}.sticky{position:relative;z-index:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.sticky.is-stuck{position:fixed;z-index:5;width:100%}.sticky.is-stuck.is-at-top{top:0}.sticky.is-stuck.is-at-bottom{bottom:0}.sticky.is-anchored{position:relative;right:auto;left:auto}.sticky.is-anchored.is-at-bottom{bottom:0}body.is-reveal-open{overflow:hidden}html.is-reveal-open,html.is-reveal-open body{min-height:100%;overflow:hidden;position:fixed;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;display:none;background-color:rgba(10,10,10,.45);overflow-y:scroll}.reveal{z-index:1006;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:none;padding:1rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;position:relative;top:100px;margin-right:auto;margin-left:auto;overflow-y:auto}[data-whatinput=mouse] .reveal{outline:0}@media print,screen and (min-width:40em){.reveal{min-height:0}}.reveal .column,.reveal .columns{min-width:0}.reveal>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.reveal{width:600px;max-width:75rem}}.reveal.collapse{padding:0}@media print,screen and (min-width:40em){.reveal.tiny{width:30%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.small{width:50%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.large{width:90%;max-width:75rem}}.reveal.full{top:0;left:0;width:100%;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}@media screen and (max-width:39.9375em){.reveal{top:0;left:0;width:100%;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}}.reveal.without-overlay{position:fixed}.switch{height:2rem;position:relative;margin-bottom:1rem;outline:0;font-size:.875rem;font-weight:700;color:#fefefe;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.switch-input{position:absolute;margin-bottom:0;opacity:0}.switch-paddle{position:relative;display:block;width:4rem;height:2rem;border-radius:0;background:#cacaca;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;font-weight:inherit;color:inherit;cursor:pointer}input+.switch-paddle{margin:0}.switch-paddle::after{position:absolute;top:.25rem;left:.25rem;display:block;width:1.5rem;height:1.5rem;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);border-radius:0;background:#fefefe;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;content:''}input:checked~.switch-paddle{background:#1779ba}input:checked~.switch-paddle::after{left:2.25rem}[data-whatinput=mouse] input:focus~.switch-paddle{outline:0}.switch-active,.switch-inactive{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.switch-active{left:8%;display:none}input:checked+label>.switch-active{display:block}.switch-inactive{right:15%}input:checked+label>.switch-inactive{display:none}.switch.tiny{height:1.5rem}.switch.tiny .switch-paddle{width:3rem;height:1.5rem;font-size:.625rem}.switch.tiny .switch-paddle::after{top:.25rem;left:.25rem;width:1rem;height:1rem}.switch.tiny input:checked~.switch-paddle::after{left:1.75rem}.switch.small{height:1.75rem}.switch.small .switch-paddle{width:3.5rem;height:1.75rem;font-size:.75rem}.switch.small .switch-paddle::after{top:.25rem;left:.25rem;width:1.25rem;height:1.25rem}.switch.small input:checked~.switch-paddle::after{left:2rem}.switch.large{height:2.5rem}.switch.large .switch-paddle{width:5rem;height:2.5rem;font-size:1rem}.switch.large .switch-paddle::after{top:.25rem;left:.25rem;width:2rem;height:2rem}.switch.large input:checked~.switch-paddle::after{left:2.75rem}table{border-collapse:collapse;width:100%;margin-bottom:1rem;border-radius:0}table tbody,table tfoot,table thead{border:1px solid #f1f1f1;background-color:#fefefe}table caption{padding:.5rem .625rem .625rem;font-weight:700}table thead{background:#f8f8f8;color:#0a0a0a}table tfoot{background:#f1f1f1;color:#0a0a0a}table tfoot tr,table thead tr{background:0 0}table tfoot td,table tfoot th,table thead td,table thead th{padding:.5rem .625rem .625rem;font-weight:700;text-align:left}table tbody td,table tbody th{padding:.5rem .625rem .625rem}table tbody tr:nth-child(even){border-bottom:0;background-color:#f1f1f1}table.unstriped tbody{background-color:#fefefe}table.unstriped tbody tr{border-bottom:0;border-bottom:1px solid #f1f1f1;background-color:#fefefe}@media screen and (max-width:63.9375em){table.stack thead{display:none}table.stack tfoot{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}}table.scroll{display:block;width:100%;overflow-x:auto}table.hover thead tr:hover{background-color:#f3f3f3}table.hover tfoot tr:hover{background-color:#ececec}table.hover tbody tr:hover{background-color:#f9f9f9}table.hover:not(.unstriped) tr:nth-of-type(even):hover{background-color:#ececec}.table-scroll{overflow-x:auto}.table-scroll table{width:auto}.tabs{margin:0;border:1px solid #e6e6e6;background:#fefefe;list-style-type:none}.tabs::after,.tabs::before{display:table;content:' '}.tabs::after{clear:both}.tabs.vertical>li{display:block;float:none;width:auto}.tabs.simple>li>a{padding:0}.tabs.simple>li>a:hover{background:0 0}.tabs.primary{background:#1779ba}.tabs.primary>li>a{color:#fefefe}.tabs.primary>li>a:focus,.tabs.primary>li>a:hover{background:#1673b1}.tabs-title{float:left}.tabs-title>a{display:block;padding:1.25rem 1.5rem;font-size:.75rem;line-height:1;color:#1779ba}.tabs-title>a:hover{background:#fefefe;color:#1468a0}.tabs-title>a:focus,.tabs-title>a[aria-selected=true]{background:#e6e6e6;color:#1779ba}.tabs-content{border:1px solid #e6e6e6;border-top:0;background:#fefefe;color:#0a0a0a;-webkit-transition:all .5s ease;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-left:0}.tabs-panel{display:none;padding:1rem}.tabs-panel.is-active{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:solid 4px #fefefe;border-radius:0;-webkit-box-shadow:0 0 0 1px rgba(10,10,10,.2);box-shadow:0 0 0 1px rgba(10,10,10,.2);line-height:0}a.thumbnail{-webkit-transition:-webkit-box-shadow .2s ease-out;transition:-webkit-box-shadow .2s ease-out;transition:box-shadow .2s ease-out;transition:box-shadow .2s ease-out,-webkit-box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{-webkit-box-shadow:0 0 6px 1px rgba(23,121,186,.5);box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{-webkit-box-shadow:none;box-shadow:none}.title-bar{padding:.5rem;background:#0a0a0a;color:#fefefe}.title-bar::after,.title-bar::before{display:table;content:' '}.title-bar::after{clear:both}.title-bar .menu-icon{margin-left:.25rem;margin-right:.25rem}.title-bar-left{float:left}.title-bar-right{float:right;text-align:right}.title-bar-title{display:inline-block;vertical-align:middle;font-weight:700}.has-tip{position:relative;display:inline-block;border-bottom:dotted 1px #8a8a8a;font-weight:700;cursor:help}.tooltip{position:absolute;top:calc(100% + .6495rem);z-index:1200;max-width:10rem;padding:.75rem;border-radius:0;background-color:#0a0a0a;font-size:80%;color:#fefefe}.tooltip::before{position:absolute}.tooltip.bottom::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;bottom:100%}.tooltip.bottom.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.top::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.top.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.left::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.right::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.tooltip.right.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.align-top::before{bottom:auto;top:10%}.tooltip.align-bottom::before{bottom:10%;top:auto}.tooltip.align-left::before{left:10%;right:auto}.tooltip.align-right::before{left:auto;right:10%}.top-bar{padding:.5rem}.top-bar::after,.top-bar::before{display:table;content:' '}.top-bar::after{clear:both}.top-bar,.top-bar ul{background-color:#e6e6e6}.top-bar input{max-width:200px;margin-right:1rem}.top-bar .input-group-field{width:100%;margin-right:0}.top-bar input.button{width:auto}.top-bar .top-bar-left,.top-bar .top-bar-right{width:100%}@media print,screen and (min-width:40em){.top-bar .top-bar-left,.top-bar .top-bar-right{width:auto}}@media screen and (max-width:63.9375em){.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{width:100%}}@media screen and (max-width:74.9375em){.top-bar.stacked-for-large .top-bar-left,.top-bar.stacked-for-large .top-bar-right{width:100%}}.top-bar-title{display:inline-block;float:left;padding:.5rem 1rem .5rem 0}.top-bar-title .menu-icon{bottom:2px}.top-bar-left{float:left}.top-bar-right{float:right}.hide{display:none!important}.invisible{visibility:hidden}@media screen and (max-width:39.9375em){.hide-for-small-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media print,screen and (min-width:40em){.hide-for-medium{display:none!important}}@media screen and (max-width:39.9375em){.show-for-medium{display:none!important}}@media screen and (min-width:40em) and (max-width:63.9375em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:39.9375em),screen and (min-width:64em){.show-for-medium-only{display:none!important}}@media print,screen and (min-width:64em){.hide-for-large{display:none!important}}@media screen and (max-width:63.9375em){.show-for-large{display:none!important}}@media screen and (min-width:64em) and (max-width:74.9375em){.hide-for-large-only{display:none!important}}@media screen and (max-width:63.9375em),screen and (min-width:75em){.show-for-large-only{display:none!important}}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal;-webkit-clip-path:none;clip-path:none}.hide-for-portrait,.show-for-landscape{display:block!important}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}}.hide-for-landscape,.show-for-portrait{display:none!important}@media screen and (orientation:landscape){.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-landscape,.show-for-portrait{display:block!important}}.float-left{float:left!important}.float-right{float:right!important}.float-center{display:block;margin-right:auto;margin-left:auto}.clearfix::after,.clearfix::before{display:table;content:' '}.clearfix::after{clear:both}
\ No newline at end of file
+@charset "UTF-8";@media print,screen and (min-width:40em){.reveal,.reveal.large,.reveal.small,.reveal.tiny{right:auto;left:auto;margin:0 auto}}/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}h1{font-size:2em;margin:.67em 0}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{-webkit-box-sizing:border-box;box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{-webkit-box-sizing:border-box;box-sizing:border-box;font-size:100%}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;padding:0;background:#fefefe;font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle;max-width:100%;height:auto;-ms-interpolation-mode:bicubic}textarea{height:auto;min-height:50px;border-radius:0}select{-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;border-radius:0}.map_canvas embed,.map_canvas img,.map_canvas object,.mqa-display embed,.mqa-display img,.mqa-display object{max-width:none!important}button{padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:0;background:0 0;line-height:1;cursor:auto}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}button,input,optgroup,select,textarea{font-family:inherit}.is-visible{display:block!important}.is-hidden{display:none!important}[type=color],[type=date],[type=datetime-local],[type=datetime],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],textarea{display:block;-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;height:2.4375rem;margin:0 0 1rem;padding:.5rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;-webkit-box-shadow:inset 0 1px 2px rgba(10,10,10,.1);box-shadow:inset 0 1px 2px rgba(10,10,10,.1);font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s;-webkit-appearance:none;-moz-appearance:none;appearance:none}[type=color]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=datetime]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,textarea:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}textarea{max-width:100%}textarea[rows]{height:auto}input:disabled,input[readonly],textarea:disabled,textarea[readonly]{background-color:#e6e6e6;cursor:not-allowed}[type=button],[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}input[type=search]{-webkit-box-sizing:border-box;box-sizing:border-box}::-webkit-input-placeholder{color:#cacaca}:-ms-input-placeholder{color:#cacaca}::-ms-input-placeholder{color:#cacaca}::placeholder{color:#cacaca}[type=checkbox],[type=file],[type=radio]{margin:0 0 1rem}[type=checkbox]+label,[type=radio]+label{display:inline-block;vertical-align:baseline;margin-left:.5rem;margin-right:1rem;margin-bottom:0}[type=checkbox]+label[for],[type=radio]+label[for]{cursor:pointer}label>[type=checkbox],label>[type=radio]{margin-right:.5rem}[type=file]{width:100%}label{display:block;margin:0;font-size:.875rem;font-weight:400;line-height:1.8;color:#0a0a0a}label.middle{margin:0 0 1rem;padding:.5625rem 0}.help-text{margin-top:-.5rem;font-size:.8125rem;font-style:italic;color:#0a0a0a}.input-group{display:table;width:100%;margin-bottom:1rem}.input-group>:first-child,.input-group>:first-child.input-group-button>*{border-radius:0}.input-group>:last-child,.input-group>:last-child.input-group-button>*{border-radius:0}.input-group-button,.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label,.input-group-field,.input-group-label{margin:0;white-space:nowrap;display:table-cell;vertical-align:middle}.input-group-label{padding:0 1rem;border:1px solid #cacaca;background:#e6e6e6;color:#0a0a0a;text-align:center;white-space:nowrap;width:1%;height:100%}.input-group-label:first-child{border-right:0}.input-group-label:last-child{border-left:0}.input-group-field{border-radius:0}.input-group-button{padding-top:0;padding-bottom:0;text-align:center;width:1%;height:100%}.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label{height:2.4375rem;padding-top:0;padding-bottom:0;font-size:1rem}.input-group .input-group-button{display:table-cell}fieldset{margin:0;padding:0;border:0}legend{max-width:100%;margin-bottom:.5rem}.fieldset{margin:1.125rem 0;padding:1.25rem;border:1px solid #cacaca}.fieldset legend{margin:0;margin-left:-.1875rem;padding:0 .1875rem}select{height:2.4375rem;margin:0 0 1rem;padding:.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");background-origin:content-box;background-position:right -1rem center;background-repeat:no-repeat;background-size:9px 6px;padding-right:1.5rem;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}@media screen and (min-width:0\0){select{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==)}}select:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}select:disabled{background-color:#e6e6e6;cursor:not-allowed}select::-ms-expand{display:none}select[multiple]{height:auto;background-image:none}.is-invalid-input:not(:focus){border-color:#cc4b37;background-color:#f9ecea}.is-invalid-input:not(:focus)::-webkit-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus):-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::placeholder{color:#cc4b37}.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700;color:#cc4b37}.form-error.is-visible{display:block}blockquote,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,li,ol,p,pre,td,th,ul{margin:0;padding:0}p{margin-bottom:1rem;font-size:inherit;line-height:1.6;text-rendering:optimizeLegibility}em,i{font-style:italic;line-height:inherit}b,strong{font-weight:700;line-height:inherit}small{font-size:80%;line-height:inherit}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-style:normal;font-weight:400;color:inherit;text-rendering:optimizeLegibility}.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small,h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{line-height:0;color:#cacaca}.h1,h1{font-size:1.5rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h2,h2{font-size:1.25rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h3,h3{font-size:1.1875rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h4,h4{font-size:1.125rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h5,h5{font-size:1.0625rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h6,h6{font-size:1rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}@media print,screen and (min-width:40em){.h1,h1{font-size:3rem}.h2,h2{font-size:2.5rem}.h3,h3{font-size:1.9375rem}.h4,h4{font-size:1.5625rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}}a{line-height:inherit;color:#1779ba;text-decoration:none;cursor:pointer}a:focus,a:hover{color:#1468a0}a img{border:0}hr{clear:both;max-width:75rem;height:0;margin:1.25rem auto;border-top:0;border-right:0;border-bottom:1px solid #cacaca;border-left:0}dl,ol,ul{margin-bottom:1rem;list-style-position:outside;line-height:1.6}li{font-size:inherit}ul{margin-left:1.25rem;list-style-type:disc}ol{margin-left:1.25rem}ol ol,ol ul,ul ol,ul ul{margin-left:1.25rem;margin-bottom:0}dl{margin-bottom:1rem}dl dt{margin-bottom:.3rem;font-weight:700}blockquote{margin:0 0 1rem;padding:.5625rem 1.25rem 0 1.1875rem;border-left:1px solid #cacaca}blockquote,blockquote p{line-height:1.6;color:#8a8a8a}cite{display:block;font-size:.8125rem;color:#8a8a8a}cite:before{content:"— "}abbr,abbr[title]{border-bottom:1px dotted #0a0a0a;cursor:help;text-decoration:none}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:400;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;color:#0a0a0a}.subheader{margin-top:.2rem;margin-bottom:.5rem;font-weight:400;line-height:1.4;color:#8a8a8a}.lead{font-size:125%;line-height:1.6}.stat{font-size:2.5rem;line-height:1}p+.stat{margin-top:-1rem}ol.no-bullet,ul.no-bullet{margin-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}@media print,screen and (min-width:40em){.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}}@media print,screen and (min-width:64em){.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}}.show-for-print{display:none!important}@media print{*{background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}.show-for-print{display:block!important}.hide-for-print{display:none!important}table.show-for-print{display:table!important}thead.show-for-print{display:table-header-group!important}tbody.show-for-print{display:table-row-group!important}tr.show-for-print{display:table-row!important}td.show-for-print{display:table-cell!important}th.show-for-print{display:table-cell!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}.ir a:after,a[href^='#']:after,a[href^='javascript:']:after{content:''}abbr[title]:after{content:" (" attr(title) ")"}blockquote,pre{border:1px solid #8a8a8a;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.print-break-inside{page-break-inside:auto}}.row{max-width:75rem;margin-right:auto;margin-left:auto}.row::after,.row::before{display:table;content:' '}.row::after{clear:both}.row.collapse>.column,.row.collapse>.columns{padding-right:0;padding-left:0}.row .row{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.row .row{margin-right:-.9375rem;margin-left:-.9375rem}}@media print,screen and (min-width:64em){.row .row{margin-right:-.9375rem;margin-left:-.9375rem}}.row .row.collapse{margin-right:0;margin-left:0}.row.expanded{max-width:none}.row.expanded .row{margin-right:auto;margin-left:auto}.row:not(.expanded) .row{max-width:none}.row.gutter-small>.column,.row.gutter-small>.columns{padding-right:.625rem;padding-left:.625rem}.row.gutter-medium>.column,.row.gutter-medium>.columns{padding-right:.9375rem;padding-left:.9375rem}.column,.columns{width:100%;float:left;padding-right:.625rem;padding-left:.625rem}@media print,screen and (min-width:40em){.column,.columns{padding-right:.9375rem;padding-left:.9375rem}}.column,.column:last-child:not(:first-child),.columns,.columns:last-child:not(:first-child){float:left;clear:none}.column:last-child:not(:first-child),.columns:last-child:not(:first-child){float:right}.column.end:last-child:last-child,.end.columns:last-child:last-child{float:left}.column.row.row,.row.row.columns{float:none}.row .column.row.row,.row .row.row.columns{margin-right:0;margin-left:0;padding-right:0;padding-left:0}.small-1{width:8.33333%}.small-push-1{position:relative;left:8.33333%}.small-pull-1{position:relative;left:-8.33333%}.small-offset-0{margin-left:0}.small-2{width:16.66667%}.small-push-2{position:relative;left:16.66667%}.small-pull-2{position:relative;left:-16.66667%}.small-offset-1{margin-left:8.33333%}.small-3{width:25%}.small-push-3{position:relative;left:25%}.small-pull-3{position:relative;left:-25%}.small-offset-2{margin-left:16.66667%}.small-4{width:33.33333%}.small-push-4{position:relative;left:33.33333%}.small-pull-4{position:relative;left:-33.33333%}.small-offset-3{margin-left:25%}.small-5{width:41.66667%}.small-push-5{position:relative;left:41.66667%}.small-pull-5{position:relative;left:-41.66667%}.small-offset-4{margin-left:33.33333%}.small-6{width:50%}.small-push-6{position:relative;left:50%}.small-pull-6{position:relative;left:-50%}.small-offset-5{margin-left:41.66667%}.small-7{width:58.33333%}.small-push-7{position:relative;left:58.33333%}.small-pull-7{position:relative;left:-58.33333%}.small-offset-6{margin-left:50%}.small-8{width:66.66667%}.small-push-8{position:relative;left:66.66667%}.small-pull-8{position:relative;left:-66.66667%}.small-offset-7{margin-left:58.33333%}.small-9{width:75%}.small-push-9{position:relative;left:75%}.small-pull-9{position:relative;left:-75%}.small-offset-8{margin-left:66.66667%}.small-10{width:83.33333%}.small-push-10{position:relative;left:83.33333%}.small-pull-10{position:relative;left:-83.33333%}.small-offset-9{margin-left:75%}.small-11{width:91.66667%}.small-push-11{position:relative;left:91.66667%}.small-pull-11{position:relative;left:-91.66667%}.small-offset-10{margin-left:83.33333%}.small-12{width:100%}.small-offset-11{margin-left:91.66667%}.small-up-1>.column,.small-up-1>.columns{float:left;width:100%}.small-up-1>.column:nth-of-type(1n),.small-up-1>.columns:nth-of-type(1n){clear:none}.small-up-1>.column:nth-of-type(1n+1),.small-up-1>.columns:nth-of-type(1n+1){clear:both}.small-up-1>.column:last-child,.small-up-1>.columns:last-child{float:left}.small-up-2>.column,.small-up-2>.columns{float:left;width:50%}.small-up-2>.column:nth-of-type(1n),.small-up-2>.columns:nth-of-type(1n){clear:none}.small-up-2>.column:nth-of-type(2n+1),.small-up-2>.columns:nth-of-type(2n+1){clear:both}.small-up-2>.column:last-child,.small-up-2>.columns:last-child{float:left}.small-up-3>.column,.small-up-3>.columns{float:left;width:33.33333%}.small-up-3>.column:nth-of-type(1n),.small-up-3>.columns:nth-of-type(1n){clear:none}.small-up-3>.column:nth-of-type(3n+1),.small-up-3>.columns:nth-of-type(3n+1){clear:both}.small-up-3>.column:last-child,.small-up-3>.columns:last-child{float:left}.small-up-4>.column,.small-up-4>.columns{float:left;width:25%}.small-up-4>.column:nth-of-type(1n),.small-up-4>.columns:nth-of-type(1n){clear:none}.small-up-4>.column:nth-of-type(4n+1),.small-up-4>.columns:nth-of-type(4n+1){clear:both}.small-up-4>.column:last-child,.small-up-4>.columns:last-child{float:left}.small-up-5>.column,.small-up-5>.columns{float:left;width:20%}.small-up-5>.column:nth-of-type(1n),.small-up-5>.columns:nth-of-type(1n){clear:none}.small-up-5>.column:nth-of-type(5n+1),.small-up-5>.columns:nth-of-type(5n+1){clear:both}.small-up-5>.column:last-child,.small-up-5>.columns:last-child{float:left}.small-up-6>.column,.small-up-6>.columns{float:left;width:16.66667%}.small-up-6>.column:nth-of-type(1n),.small-up-6>.columns:nth-of-type(1n){clear:none}.small-up-6>.column:nth-of-type(6n+1),.small-up-6>.columns:nth-of-type(6n+1){clear:both}.small-up-6>.column:last-child,.small-up-6>.columns:last-child{float:left}.small-up-7>.column,.small-up-7>.columns{float:left;width:14.28571%}.small-up-7>.column:nth-of-type(1n),.small-up-7>.columns:nth-of-type(1n){clear:none}.small-up-7>.column:nth-of-type(7n+1),.small-up-7>.columns:nth-of-type(7n+1){clear:both}.small-up-7>.column:last-child,.small-up-7>.columns:last-child{float:left}.small-up-8>.column,.small-up-8>.columns{float:left;width:12.5%}.small-up-8>.column:nth-of-type(1n),.small-up-8>.columns:nth-of-type(1n){clear:none}.small-up-8>.column:nth-of-type(8n+1),.small-up-8>.columns:nth-of-type(8n+1){clear:both}.small-up-8>.column:last-child,.small-up-8>.columns:last-child{float:left}.small-collapse>.column,.small-collapse>.columns{padding-right:0;padding-left:0}.small-collapse .row{margin-right:0;margin-left:0}.expanded.row .small-collapse.row{margin-right:0;margin-left:0}.small-uncollapse>.column,.small-uncollapse>.columns{padding-right:.625rem;padding-left:.625rem}.small-centered{margin-right:auto;margin-left:auto}.small-centered,.small-centered:last-child:not(:first-child){float:none;clear:both}.small-pull-0,.small-push-0,.small-uncentered{position:static;margin-right:0;margin-left:0}.small-pull-0,.small-pull-0:last-child:not(:first-child),.small-push-0,.small-push-0:last-child:not(:first-child),.small-uncentered,.small-uncentered:last-child:not(:first-child){float:left;clear:none}.small-pull-0:last-child:not(:first-child),.small-push-0:last-child:not(:first-child),.small-uncentered:last-child:not(:first-child){float:right}@media print,screen and (min-width:40em){.medium-1{width:8.33333%}.medium-push-1{position:relative;left:8.33333%}.medium-pull-1{position:relative;left:-8.33333%}.medium-offset-0{margin-left:0}.medium-2{width:16.66667%}.medium-push-2{position:relative;left:16.66667%}.medium-pull-2{position:relative;left:-16.66667%}.medium-offset-1{margin-left:8.33333%}.medium-3{width:25%}.medium-push-3{position:relative;left:25%}.medium-pull-3{position:relative;left:-25%}.medium-offset-2{margin-left:16.66667%}.medium-4{width:33.33333%}.medium-push-4{position:relative;left:33.33333%}.medium-pull-4{position:relative;left:-33.33333%}.medium-offset-3{margin-left:25%}.medium-5{width:41.66667%}.medium-push-5{position:relative;left:41.66667%}.medium-pull-5{position:relative;left:-41.66667%}.medium-offset-4{margin-left:33.33333%}.medium-6{width:50%}.medium-push-6{position:relative;left:50%}.medium-pull-6{position:relative;left:-50%}.medium-offset-5{margin-left:41.66667%}.medium-7{width:58.33333%}.medium-push-7{position:relative;left:58.33333%}.medium-pull-7{position:relative;left:-58.33333%}.medium-offset-6{margin-left:50%}.medium-8{width:66.66667%}.medium-push-8{position:relative;left:66.66667%}.medium-pull-8{position:relative;left:-66.66667%}.medium-offset-7{margin-left:58.33333%}.medium-9{width:75%}.medium-push-9{position:relative;left:75%}.medium-pull-9{position:relative;left:-75%}.medium-offset-8{margin-left:66.66667%}.medium-10{width:83.33333%}.medium-push-10{position:relative;left:83.33333%}.medium-pull-10{position:relative;left:-83.33333%}.medium-offset-9{margin-left:75%}.medium-11{width:91.66667%}.medium-push-11{position:relative;left:91.66667%}.medium-pull-11{position:relative;left:-91.66667%}.medium-offset-10{margin-left:83.33333%}.medium-12{width:100%}.medium-offset-11{margin-left:91.66667%}.medium-up-1>.column,.medium-up-1>.columns{float:left;width:100%}.medium-up-1>.column:nth-of-type(1n),.medium-up-1>.columns:nth-of-type(1n){clear:none}.medium-up-1>.column:nth-of-type(1n+1),.medium-up-1>.columns:nth-of-type(1n+1){clear:both}.medium-up-1>.column:last-child,.medium-up-1>.columns:last-child{float:left}.medium-up-2>.column,.medium-up-2>.columns{float:left;width:50%}.medium-up-2>.column:nth-of-type(1n),.medium-up-2>.columns:nth-of-type(1n){clear:none}.medium-up-2>.column:nth-of-type(2n+1),.medium-up-2>.columns:nth-of-type(2n+1){clear:both}.medium-up-2>.column:last-child,.medium-up-2>.columns:last-child{float:left}.medium-up-3>.column,.medium-up-3>.columns{float:left;width:33.33333%}.medium-up-3>.column:nth-of-type(1n),.medium-up-3>.columns:nth-of-type(1n){clear:none}.medium-up-3>.column:nth-of-type(3n+1),.medium-up-3>.columns:nth-of-type(3n+1){clear:both}.medium-up-3>.column:last-child,.medium-up-3>.columns:last-child{float:left}.medium-up-4>.column,.medium-up-4>.columns{float:left;width:25%}.medium-up-4>.column:nth-of-type(1n),.medium-up-4>.columns:nth-of-type(1n){clear:none}.medium-up-4>.column:nth-of-type(4n+1),.medium-up-4>.columns:nth-of-type(4n+1){clear:both}.medium-up-4>.column:last-child,.medium-up-4>.columns:last-child{float:left}.medium-up-5>.column,.medium-up-5>.columns{float:left;width:20%}.medium-up-5>.column:nth-of-type(1n),.medium-up-5>.columns:nth-of-type(1n){clear:none}.medium-up-5>.column:nth-of-type(5n+1),.medium-up-5>.columns:nth-of-type(5n+1){clear:both}.medium-up-5>.column:last-child,.medium-up-5>.columns:last-child{float:left}.medium-up-6>.column,.medium-up-6>.columns{float:left;width:16.66667%}.medium-up-6>.column:nth-of-type(1n),.medium-up-6>.columns:nth-of-type(1n){clear:none}.medium-up-6>.column:nth-of-type(6n+1),.medium-up-6>.columns:nth-of-type(6n+1){clear:both}.medium-up-6>.column:last-child,.medium-up-6>.columns:last-child{float:left}.medium-up-7>.column,.medium-up-7>.columns{float:left;width:14.28571%}.medium-up-7>.column:nth-of-type(1n),.medium-up-7>.columns:nth-of-type(1n){clear:none}.medium-up-7>.column:nth-of-type(7n+1),.medium-up-7>.columns:nth-of-type(7n+1){clear:both}.medium-up-7>.column:last-child,.medium-up-7>.columns:last-child{float:left}.medium-up-8>.column,.medium-up-8>.columns{float:left;width:12.5%}.medium-up-8>.column:nth-of-type(1n),.medium-up-8>.columns:nth-of-type(1n){clear:none}.medium-up-8>.column:nth-of-type(8n+1),.medium-up-8>.columns:nth-of-type(8n+1){clear:both}.medium-up-8>.column:last-child,.medium-up-8>.columns:last-child{float:left}.medium-collapse>.column,.medium-collapse>.columns{padding-right:0;padding-left:0}.medium-collapse .row{margin-right:0;margin-left:0}.expanded.row .medium-collapse.row{margin-right:0;margin-left:0}.medium-uncollapse>.column,.medium-uncollapse>.columns{padding-right:.9375rem;padding-left:.9375rem}.medium-centered{margin-right:auto;margin-left:auto}.medium-centered,.medium-centered:last-child:not(:first-child){float:none;clear:both}.medium-pull-0,.medium-push-0,.medium-uncentered{position:static;margin-right:0;margin-left:0}.medium-pull-0,.medium-pull-0:last-child:not(:first-child),.medium-push-0,.medium-push-0:last-child:not(:first-child),.medium-uncentered,.medium-uncentered:last-child:not(:first-child){float:left;clear:none}.medium-pull-0:last-child:not(:first-child),.medium-push-0:last-child:not(:first-child),.medium-uncentered:last-child:not(:first-child){float:right}}@media print,screen and (min-width:64em){.large-1{width:8.33333%}.large-push-1{position:relative;left:8.33333%}.large-pull-1{position:relative;left:-8.33333%}.large-offset-0{margin-left:0}.large-2{width:16.66667%}.large-push-2{position:relative;left:16.66667%}.large-pull-2{position:relative;left:-16.66667%}.large-offset-1{margin-left:8.33333%}.large-3{width:25%}.large-push-3{position:relative;left:25%}.large-pull-3{position:relative;left:-25%}.large-offset-2{margin-left:16.66667%}.large-4{width:33.33333%}.large-push-4{position:relative;left:33.33333%}.large-pull-4{position:relative;left:-33.33333%}.large-offset-3{margin-left:25%}.large-5{width:41.66667%}.large-push-5{position:relative;left:41.66667%}.large-pull-5{position:relative;left:-41.66667%}.large-offset-4{margin-left:33.33333%}.large-6{width:50%}.large-push-6{position:relative;left:50%}.large-pull-6{position:relative;left:-50%}.large-offset-5{margin-left:41.66667%}.large-7{width:58.33333%}.large-push-7{position:relative;left:58.33333%}.large-pull-7{position:relative;left:-58.33333%}.large-offset-6{margin-left:50%}.large-8{width:66.66667%}.large-push-8{position:relative;left:66.66667%}.large-pull-8{position:relative;left:-66.66667%}.large-offset-7{margin-left:58.33333%}.large-9{width:75%}.large-push-9{position:relative;left:75%}.large-pull-9{position:relative;left:-75%}.large-offset-8{margin-left:66.66667%}.large-10{width:83.33333%}.large-push-10{position:relative;left:83.33333%}.large-pull-10{position:relative;left:-83.33333%}.large-offset-9{margin-left:75%}.large-11{width:91.66667%}.large-push-11{position:relative;left:91.66667%}.large-pull-11{position:relative;left:-91.66667%}.large-offset-10{margin-left:83.33333%}.large-12{width:100%}.large-offset-11{margin-left:91.66667%}.large-up-1>.column,.large-up-1>.columns{float:left;width:100%}.large-up-1>.column:nth-of-type(1n),.large-up-1>.columns:nth-of-type(1n){clear:none}.large-up-1>.column:nth-of-type(1n+1),.large-up-1>.columns:nth-of-type(1n+1){clear:both}.large-up-1>.column:last-child,.large-up-1>.columns:last-child{float:left}.large-up-2>.column,.large-up-2>.columns{float:left;width:50%}.large-up-2>.column:nth-of-type(1n),.large-up-2>.columns:nth-of-type(1n){clear:none}.large-up-2>.column:nth-of-type(2n+1),.large-up-2>.columns:nth-of-type(2n+1){clear:both}.large-up-2>.column:last-child,.large-up-2>.columns:last-child{float:left}.large-up-3>.column,.large-up-3>.columns{float:left;width:33.33333%}.large-up-3>.column:nth-of-type(1n),.large-up-3>.columns:nth-of-type(1n){clear:none}.large-up-3>.column:nth-of-type(3n+1),.large-up-3>.columns:nth-of-type(3n+1){clear:both}.large-up-3>.column:last-child,.large-up-3>.columns:last-child{float:left}.large-up-4>.column,.large-up-4>.columns{float:left;width:25%}.large-up-4>.column:nth-of-type(1n),.large-up-4>.columns:nth-of-type(1n){clear:none}.large-up-4>.column:nth-of-type(4n+1),.large-up-4>.columns:nth-of-type(4n+1){clear:both}.large-up-4>.column:last-child,.large-up-4>.columns:last-child{float:left}.large-up-5>.column,.large-up-5>.columns{float:left;width:20%}.large-up-5>.column:nth-of-type(1n),.large-up-5>.columns:nth-of-type(1n){clear:none}.large-up-5>.column:nth-of-type(5n+1),.large-up-5>.columns:nth-of-type(5n+1){clear:both}.large-up-5>.column:last-child,.large-up-5>.columns:last-child{float:left}.large-up-6>.column,.large-up-6>.columns{float:left;width:16.66667%}.large-up-6>.column:nth-of-type(1n),.large-up-6>.columns:nth-of-type(1n){clear:none}.large-up-6>.column:nth-of-type(6n+1),.large-up-6>.columns:nth-of-type(6n+1){clear:both}.large-up-6>.column:last-child,.large-up-6>.columns:last-child{float:left}.large-up-7>.column,.large-up-7>.columns{float:left;width:14.28571%}.large-up-7>.column:nth-of-type(1n),.large-up-7>.columns:nth-of-type(1n){clear:none}.large-up-7>.column:nth-of-type(7n+1),.large-up-7>.columns:nth-of-type(7n+1){clear:both}.large-up-7>.column:last-child,.large-up-7>.columns:last-child{float:left}.large-up-8>.column,.large-up-8>.columns{float:left;width:12.5%}.large-up-8>.column:nth-of-type(1n),.large-up-8>.columns:nth-of-type(1n){clear:none}.large-up-8>.column:nth-of-type(8n+1),.large-up-8>.columns:nth-of-type(8n+1){clear:both}.large-up-8>.column:last-child,.large-up-8>.columns:last-child{float:left}.large-collapse>.column,.large-collapse>.columns{padding-right:0;padding-left:0}.large-collapse .row{margin-right:0;margin-left:0}.expanded.row .large-collapse.row{margin-right:0;margin-left:0}.large-uncollapse>.column,.large-uncollapse>.columns{padding-right:.9375rem;padding-left:.9375rem}.large-centered{margin-right:auto;margin-left:auto}.large-centered,.large-centered:last-child:not(:first-child){float:none;clear:both}.large-pull-0,.large-push-0,.large-uncentered{position:static;margin-right:0;margin-left:0}.large-pull-0,.large-pull-0:last-child:not(:first-child),.large-push-0,.large-push-0:last-child:not(:first-child),.large-uncentered,.large-uncentered:last-child:not(:first-child){float:left;clear:none}.large-pull-0:last-child:not(:first-child),.large-push-0:last-child:not(:first-child),.large-uncentered:last-child:not(:first-child){float:right}}.column-block{margin-bottom:1.25rem}.column-block>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.column-block{margin-bottom:1.875rem}.column-block>:last-child{margin-bottom:0}}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem 0;padding:.85em 1em;border:1px solid transparent;border-radius:0;-webkit-transition:background-color .25s ease-out,color .25s ease-out;transition:background-color .25s ease-out,color .25s ease-out;font-family:inherit;font-size:.9rem;-webkit-appearance:none;line-height:1;text-align:center;cursor:pointer;background-color:#1779ba;color:#fefefe}[data-whatinput=mouse] .button{outline:0}.button:focus,.button:hover{background-color:#14679e;color:#fefefe}.button.tiny{font-size:.6rem}.button.small{font-size:.75rem}.button.large{font-size:1.25rem}.button.expanded{display:block;width:100%;margin-right:0;margin-left:0}.button.primary{background-color:#1779ba;color:#fefefe}.button.primary:focus,.button.primary:hover{background-color:#126195;color:#fefefe}.button.secondary{background-color:#767676;color:#fefefe}.button.secondary:focus,.button.secondary:hover{background-color:#5e5e5e;color:#fefefe}.button.success{background-color:#3adb76;color:#0a0a0a}.button.success:focus,.button.success:hover{background-color:#22bb5b;color:#0a0a0a}.button.warning{background-color:#ffae00;color:#0a0a0a}.button.warning:focus,.button.warning:hover{background-color:#cc8b00;color:#0a0a0a}.button.alert{background-color:#cc4b37;color:#fefefe}.button.alert:focus,.button.alert:hover{background-color:#a53b2a;color:#fefefe}.button.disabled,.button[disabled]{opacity:.25;cursor:not-allowed}.button.disabled,.button.disabled:focus,.button.disabled:hover,.button[disabled],.button[disabled]:focus,.button[disabled]:hover{background-color:#1779ba;color:#fefefe}.button.disabled.primary,.button[disabled].primary{opacity:.25;cursor:not-allowed}.button.disabled.primary,.button.disabled.primary:focus,.button.disabled.primary:hover,.button[disabled].primary,.button[disabled].primary:focus,.button[disabled].primary:hover{background-color:#1779ba;color:#fefefe}.button.disabled.secondary,.button[disabled].secondary{opacity:.25;cursor:not-allowed}.button.disabled.secondary,.button.disabled.secondary:focus,.button.disabled.secondary:hover,.button[disabled].secondary,.button[disabled].secondary:focus,.button[disabled].secondary:hover{background-color:#767676;color:#fefefe}.button.disabled.success,.button[disabled].success{opacity:.25;cursor:not-allowed}.button.disabled.success,.button.disabled.success:focus,.button.disabled.success:hover,.button[disabled].success,.button[disabled].success:focus,.button[disabled].success:hover{background-color:#3adb76;color:#0a0a0a}.button.disabled.warning,.button[disabled].warning{opacity:.25;cursor:not-allowed}.button.disabled.warning,.button.disabled.warning:focus,.button.disabled.warning:hover,.button[disabled].warning,.button[disabled].warning:focus,.button[disabled].warning:hover{background-color:#ffae00;color:#0a0a0a}.button.disabled.alert,.button[disabled].alert{opacity:.25;cursor:not-allowed}.button.disabled.alert,.button.disabled.alert:focus,.button.disabled.alert:hover,.button[disabled].alert,.button[disabled].alert:focus,.button[disabled].alert:hover{background-color:#cc4b37;color:#fefefe}.button.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow.disabled,.button.hollow.disabled:focus,.button.hollow.disabled:hover,.button.hollow[disabled],.button.hollow[disabled]:focus,.button.hollow[disabled]:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow:focus.disabled,.button.hollow:focus[disabled],.button.hollow:hover.disabled,.button.hollow:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary:focus.disabled,.button.hollow.primary:focus[disabled],.button.hollow.primary:hover.disabled,.button.hollow.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.secondary:focus.disabled,.button.hollow.secondary:focus[disabled],.button.hollow.secondary:hover.disabled,.button.hollow.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.success:focus.disabled,.button.hollow.success:focus[disabled],.button.hollow.success:hover.disabled,.button.hollow.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.warning:focus.disabled,.button.hollow.warning:focus[disabled],.button.hollow.warning:hover.disabled,.button.hollow.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.button.hollow.alert:focus.disabled,.button.hollow.alert:focus[disabled],.button.hollow.alert:hover.disabled,.button.hollow.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear:focus,.button.clear:hover{background-color:transparent}.button.clear.disabled,.button.clear.disabled:focus,.button.clear.disabled:hover,.button.clear[disabled],.button.clear[disabled]:focus,.button.clear[disabled]:hover{background-color:transparent}.button.clear:focus,.button.clear:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover.disabled,.button.clear:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear.disabled,.button.clear:focus,.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover,.button.clear:hover.disabled,.button.clear:hover[disabled],.button.clear[disabled]{border-color:transparent}.button.clear.primary{border:1px solid #1779ba;color:#1779ba}.button.clear.primary:focus,.button.clear.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear.primary,.button.clear.primary.disabled,.button.clear.primary:focus,.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover,.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled],.button.clear.primary[disabled]{border-color:transparent}.button.clear.secondary{border:1px solid #767676;color:#767676}.button.clear.secondary:focus,.button.clear.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.clear.secondary,.button.clear.secondary.disabled,.button.clear.secondary:focus,.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover,.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled],.button.clear.secondary[disabled]{border-color:transparent}.button.clear.success{border:1px solid #3adb76;color:#3adb76}.button.clear.success:focus,.button.clear.success:hover{border-color:#157539;color:#157539}.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover.disabled,.button.clear.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.clear.success,.button.clear.success.disabled,.button.clear.success:focus,.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover,.button.clear.success:hover.disabled,.button.clear.success:hover[disabled],.button.clear.success[disabled]{border-color:transparent}.button.clear.warning{border:1px solid #ffae00;color:#ffae00}.button.clear.warning:focus,.button.clear.warning:hover{border-color:#805700;color:#805700}.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.clear.warning,.button.clear.warning.disabled,.button.clear.warning:focus,.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover,.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled],.button.clear.warning[disabled]{border-color:transparent}.button.clear.alert{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert:focus,.button.clear.alert:hover{border-color:#67251a;color:#67251a}.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert,.button.clear.alert.disabled,.button.clear.alert:focus,.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover,.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled],.button.clear.alert[disabled]{border-color:transparent}.button.dropdown::after{display:block;width:0;height:0;border:inset .4em;content:'';border-bottom-width:0;border-top-style:solid;border-color:#fefefe transparent transparent;position:relative;top:.4em;display:inline-block;float:right;margin-left:1em}.button.dropdown.clear::after,.button.dropdown.hollow::after{border-top-color:#1779ba}.button.dropdown.clear.primary::after,.button.dropdown.hollow.primary::after{border-top-color:#1779ba}.button.dropdown.clear.secondary::after,.button.dropdown.hollow.secondary::after{border-top-color:#767676}.button.dropdown.clear.success::after,.button.dropdown.hollow.success::after{border-top-color:#3adb76}.button.dropdown.clear.warning::after,.button.dropdown.hollow.warning::after{border-top-color:#ffae00}.button.dropdown.clear.alert::after,.button.dropdown.hollow.alert::after{border-top-color:#cc4b37}.button.arrow-only::after{top:-.1em;float:none;margin-left:0}a.button:focus,a.button:hover{text-decoration:none}.button-group{margin-bottom:1rem;font-size:0}.button-group::after,.button-group::before{display:table;content:' '}.button-group::after{clear:both}.button-group .button{margin:0;margin-right:1px;margin-bottom:1px;font-size:.9rem}.button-group .button:last-child{margin-right:0}.button-group.tiny .button{font-size:.6rem}.button-group.small .button{font-size:.75rem}.button-group.large .button{font-size:1.25rem}.button-group.expanded{margin-right:-1px}.button-group.expanded::after,.button-group.expanded::before{display:none}.button-group.expanded .button:first-child:last-child{width:calc(100% - 1px)}.button-group.expanded .button:first-child:nth-last-child(2),.button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button{display:inline-block;width:calc(50% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(2):last-child{margin-right:-6px}.button-group.expanded .button:first-child:nth-last-child(3),.button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button{display:inline-block;width:calc(33.33333% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(3):last-child{margin-right:-6px}.button-group.expanded .button:first-child:nth-last-child(4),.button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button{display:inline-block;width:calc(25% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(4):last-child{margin-right:-6px}.button-group.expanded .button:first-child:nth-last-child(5),.button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button{display:inline-block;width:calc(20% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(5):last-child{margin-right:-6px}.button-group.expanded .button:first-child:nth-last-child(6),.button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button{display:inline-block;width:calc(16.66667% - 1px);margin-right:1px}.button-group.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button:last-child,.button-group.expanded .button:first-child:nth-last-child(6):last-child{margin-right:-6px}.button-group.primary .button{background-color:#1779ba;color:#fefefe}.button-group.primary .button:focus,.button-group.primary .button:hover{background-color:#126195;color:#fefefe}.button-group.secondary .button{background-color:#767676;color:#fefefe}.button-group.secondary .button:focus,.button-group.secondary .button:hover{background-color:#5e5e5e;color:#fefefe}.button-group.success .button{background-color:#3adb76;color:#0a0a0a}.button-group.success .button:focus,.button-group.success .button:hover{background-color:#22bb5b;color:#0a0a0a}.button-group.warning .button{background-color:#ffae00;color:#0a0a0a}.button-group.warning .button:focus,.button-group.warning .button:hover{background-color:#cc8b00;color:#0a0a0a}.button-group.alert .button{background-color:#cc4b37;color:#fefefe}.button-group.alert .button:focus,.button-group.alert .button:hover{background-color:#a53b2a;color:#fefefe}.button-group.stacked .button,.button-group.stacked-for-medium .button,.button-group.stacked-for-small .button{width:100%}.button-group.stacked .button:last-child,.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child{margin-bottom:0}.button-group.stacked-for-medium.expanded,.button-group.stacked-for-small.expanded,.button-group.stacked.expanded{margin-right:-1px}.button-group.stacked-for-medium.expanded::after,.button-group.stacked-for-medium.expanded::before,.button-group.stacked-for-small.expanded::after,.button-group.stacked-for-small.expanded::before,.button-group.stacked.expanded::after,.button-group.stacked.expanded::before{display:none}.button-group.stacked-for-medium.expanded .button:first-child:last-child,.button-group.stacked-for-small.expanded .button:first-child:last-child,.button-group.stacked.expanded .button:first-child:last-child{width:calc(100% - 1px)}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2),.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2),.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button,.button-group.stacked.expanded .button:first-child:nth-last-child(2),.button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button{display:inline-block;width:calc(50% - 1px);margin-right:1px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button:last-child,.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(2):last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button:last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(2):last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(2):first-child:nth-last-child(2)~.button:last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(2):last-child{margin-right:-6px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3),.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3),.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button,.button-group.stacked.expanded .button:first-child:nth-last-child(3),.button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button{display:inline-block;width:calc(33.33333% - 1px);margin-right:1px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button:last-child,.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(3):last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button:last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(3):last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(3):first-child:nth-last-child(3)~.button:last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(3):last-child{margin-right:-6px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4),.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4),.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button,.button-group.stacked.expanded .button:first-child:nth-last-child(4),.button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button{display:inline-block;width:calc(25% - 1px);margin-right:1px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button:last-child,.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(4):last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button:last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(4):last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(4):first-child:nth-last-child(4)~.button:last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(4):last-child{margin-right:-6px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5),.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5),.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button,.button-group.stacked.expanded .button:first-child:nth-last-child(5),.button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button{display:inline-block;width:calc(20% - 1px);margin-right:1px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button:last-child,.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(5):last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button:last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(5):last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(5):first-child:nth-last-child(5)~.button:last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(5):last-child{margin-right:-6px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6),.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6),.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button,.button-group.stacked.expanded .button:first-child:nth-last-child(6),.button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button{display:inline-block;width:calc(16.66667% - 1px);margin-right:1px}.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button:last-child,.button-group.stacked-for-medium.expanded .button:first-child:nth-last-child(6):last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button:last-child,.button-group.stacked-for-small.expanded .button:first-child:nth-last-child(6):last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(6):first-child:nth-last-child(6)~.button:last-child,.button-group.stacked.expanded .button:first-child:nth-last-child(6):last-child{margin-right:-6px}@media print,screen and (min-width:40em){.button-group.stacked-for-small .button{width:auto;margin-bottom:0}}@media print,screen and (min-width:64em){.button-group.stacked-for-medium .button{width:auto;margin-bottom:0}}@media screen and (max-width:39.99875em){.button-group.stacked-for-small.expanded{display:block}.button-group.stacked-for-small.expanded .button{display:block;margin-right:0}}@media screen and (max-width:63.99875em){.button-group.stacked-for-medium.expanded{display:block}.button-group.stacked-for-medium.expanded .button{display:block;margin-right:0}}.close-button{position:absolute;color:#8a8a8a;cursor:pointer}[data-whatinput=mouse] .close-button{outline:0}.close-button:focus,.close-button:hover{color:#0a0a0a}.close-button.small{right:.66rem;top:.33em;font-size:1.5em;line-height:1}.close-button,.close-button.medium{right:1rem;top:.5rem;font-size:2em;line-height:1}.label{display:inline-block;padding:.33333rem .5rem;border-radius:0;font-size:.8rem;line-height:1;white-space:nowrap;cursor:default;background:#1779ba;color:#fefefe}.label.primary{background:#1779ba;color:#fefefe}.label.secondary{background:#767676;color:#fefefe}.label.success{background:#3adb76;color:#0a0a0a}.label.warning{background:#ffae00;color:#0a0a0a}.label.alert{background:#cc4b37;color:#fefefe}.progress{height:1rem;margin-bottom:1rem;border-radius:0;background-color:#cacaca}.progress.primary .progress-meter{background-color:#1779ba}.progress.secondary .progress-meter{background-color:#767676}.progress.success .progress-meter{background-color:#3adb76}.progress.warning .progress-meter{background-color:#ffae00}.progress.alert .progress-meter{background-color:#cc4b37}.progress-meter{position:relative;display:block;width:0%;height:100%;background-color:#1779ba}.progress-meter-text{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);transform:translate(-50%,-50%);margin:0;font-size:.75rem;font-weight:700;color:#fefefe;white-space:nowrap}.slider{position:relative;height:.5rem;margin-top:1.25rem;margin-bottom:2.25rem;background-color:#e6e6e6;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none}.slider-fill{position:absolute;top:0;left:0;display:inline-block;max-width:100%;height:.5rem;background-color:#cacaca;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.slider-fill.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider-handle{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;-ms-touch-action:manipulation;touch-action:manipulation}[data-whatinput=mouse] .slider-handle{outline:0}.slider-handle:hover{background-color:#14679e}.slider-handle.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider.disabled,.slider[disabled]{opacity:.25;cursor:not-allowed}.slider.vertical{display:inline-block;width:.5rem;height:12.5rem;margin:0 1.25rem;-webkit-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scale(1,-1)}.slider.vertical .slider-fill{top:0;width:.5rem;max-height:100%}.slider.vertical .slider-handle{position:absolute;top:0;left:50%;width:1.4rem;height:1.4rem;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.switch{height:2rem;position:relative;margin-bottom:1rem;outline:0;font-size:.875rem;font-weight:700;color:#fefefe;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.switch-input{position:absolute;margin-bottom:0;opacity:0}.switch-paddle{position:relative;display:block;width:4rem;height:2rem;border-radius:0;background:#cacaca;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;font-weight:inherit;color:inherit;cursor:pointer}input+.switch-paddle{margin:0}.switch-paddle::after{position:absolute;top:.25rem;left:.25rem;display:block;width:1.5rem;height:1.5rem;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);border-radius:0;background:#fefefe;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;content:''}input:checked~.switch-paddle{background:#1779ba}input:checked~.switch-paddle::after{left:2.25rem}[data-whatinput=mouse] input:focus~.switch-paddle{outline:0}.switch-active,.switch-inactive{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.switch-active{left:8%;display:none}input:checked+label>.switch-active{display:block}.switch-inactive{right:15%}input:checked+label>.switch-inactive{display:none}.switch.tiny{height:1.5rem}.switch.tiny .switch-paddle{width:3rem;height:1.5rem;font-size:.625rem}.switch.tiny .switch-paddle::after{top:.25rem;left:.25rem;width:1rem;height:1rem}.switch.tiny input:checked~.switch-paddle::after{left:1.75rem}.switch.small{height:1.75rem}.switch.small .switch-paddle{width:3.5rem;height:1.75rem;font-size:.75rem}.switch.small .switch-paddle::after{top:.25rem;left:.25rem;width:1.25rem;height:1.25rem}.switch.small input:checked~.switch-paddle::after{left:2rem}.switch.large{height:2.5rem}.switch.large .switch-paddle{width:5rem;height:2.5rem;font-size:1rem}.switch.large .switch-paddle::after{top:.25rem;left:.25rem;width:2rem;height:2rem}.switch.large input:checked~.switch-paddle::after{left:2.75rem}table{border-collapse:collapse;width:100%;margin-bottom:1rem;border-radius:0}tbody,tfoot,thead{border:1px solid #f1f1f1;background-color:#fefefe}caption{padding:.5rem .625rem .625rem;font-weight:700}thead{background:#f8f8f8;color:#0a0a0a}tfoot{background:#f1f1f1;color:#0a0a0a}tfoot tr,thead tr{background:0 0}tfoot td,tfoot th,thead td,thead th{padding:.5rem .625rem .625rem;font-weight:700;text-align:left}tbody td,tbody th{padding:.5rem .625rem .625rem}tbody tr:nth-child(even){border-bottom:0;background-color:#f1f1f1}table.unstriped tbody{background-color:#fefefe}table.unstriped tbody tr{border-bottom:0;border-bottom:1px solid #f1f1f1;background-color:#fefefe}@media screen and (max-width:63.99875em){table.stack thead{display:none}table.stack tfoot{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}}table.scroll{display:block;width:100%;overflow-x:auto}table.hover thead tr:hover{background-color:#f3f3f3}table.hover tfoot tr:hover{background-color:#ececec}table.hover tbody tr:hover{background-color:#f9f9f9}table.hover:not(.unstriped) tr:nth-of-type(even):hover{background-color:#ececec}.table-scroll{overflow-x:auto}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center;background:#1779ba;color:#fefefe}.badge.primary{background:#1779ba;color:#fefefe}.badge.secondary{background:#767676;color:#fefefe}.badge.success{background:#3adb76;color:#0a0a0a}.badge.warning{background:#ffae00;color:#0a0a0a}.badge.alert{background:#cc4b37;color:#fefefe}.breadcrumbs{margin:0 0 1rem 0;list-style:none}.breadcrumbs::after,.breadcrumbs::before{display:table;content:' '}.breadcrumbs::after{clear:both}.breadcrumbs li{float:left;font-size:.6875rem;color:#0a0a0a;cursor:default;text-transform:uppercase}.breadcrumbs li:not(:last-child)::after{position:relative;margin:0 .75rem;opacity:1;content:"/";color:#cacaca}.breadcrumbs a{color:#1779ba}.breadcrumbs a:hover{text-decoration:underline}.breadcrumbs .disabled{color:#cacaca;cursor:not-allowed}.callout{position:relative;margin:0 0 1rem 0;padding:1rem;border:1px solid rgba(10,10,10,.25);border-radius:0;background-color:#fff;color:#0a0a0a}.callout>:first-child{margin-top:0}.callout>:last-child{margin-bottom:0}.callout.primary{background-color:#d7ecfa;color:#0a0a0a}.callout.secondary{background-color:#eaeaea;color:#0a0a0a}.callout.success{background-color:#e1faea;color:#0a0a0a}.callout.warning{background-color:#fff3d9;color:#0a0a0a}.callout.alert{background-color:#f7e4e1;color:#0a0a0a}.callout.small{padding-top:.5rem;padding-right:.5rem;padding-bottom:.5rem;padding-left:.5rem}.callout.large{padding-top:3rem;padding-right:3rem;padding-bottom:3rem;padding-left:3rem}.card{margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;color:#0a0a0a}.card>:last-child{margin-bottom:0}.card-divider{padding:1rem;background:#e6e6e6}.card-divider>:last-child{margin-bottom:0}.card-section{padding:1rem}.card-section>:last-child{margin-bottom:0}.card-image{min-height:1px}.dropdown-pane{position:absolute;z-index:10;display:none;width:300px;padding:1rem;visibility:hidden;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-opening{display:block}.dropdown-pane.is-open{display:block;visibility:visible}.dropdown-pane.tiny{width:100px}.dropdown-pane.small{width:200px}.dropdown-pane.large{width:400px}.pagination{margin-left:0;margin-bottom:1rem}.pagination::after,.pagination::before{display:table;content:' '}.pagination::after{clear:both}.pagination li{margin-right:.0625rem;border-radius:0;font-size:.875rem;display:none}.pagination li:first-child,.pagination li:last-child{display:inline-block}@media print,screen and (min-width:40em){.pagination li{display:inline-block}}.pagination a,.pagination button{display:block;padding:.1875rem .625rem;border-radius:0;color:#0a0a0a}.pagination a:hover,.pagination button:hover{background:#e6e6e6}.pagination .current{padding:.1875rem .625rem;background:#1779ba;color:#fefefe;cursor:default}.pagination .disabled{padding:.1875rem .625rem;color:#cacaca;cursor:not-allowed}.pagination .disabled:hover{background:0 0}.pagination .ellipsis::after{padding:.1875rem .625rem;content:'\2026';color:#0a0a0a}.pagination-previous a::before,.pagination-previous.disabled::before{display:inline-block;margin-right:.5rem;content:'\00ab'}.pagination-next a::after,.pagination-next.disabled::after{display:inline-block;margin-left:.5rem;content:'\00bb'}.has-tip{position:relative;display:inline-block;border-bottom:dotted 1px #8a8a8a;font-weight:700;cursor:help}.tooltip{position:absolute;top:calc(100% + .6495rem);z-index:1200;max-width:10rem;padding:.75rem;border-radius:0;background-color:#0a0a0a;font-size:80%;color:#fefefe}.tooltip::before{position:absolute}.tooltip.bottom::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;bottom:100%}.tooltip.bottom.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.top::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.top.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.left::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.right::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.tooltip.right.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.align-top::before{bottom:auto;top:10%}.tooltip.align-bottom::before{bottom:10%;top:auto}.tooltip.align-left::before{left:10%;right:auto}.tooltip.align-right::before{left:auto;right:10%}.accordion{margin-left:0;background:#fefefe;list-style-type:none}.accordion[disabled] .accordion-title{cursor:not-allowed}.accordion-item:first-child>:first-child{border-radius:0}.accordion-item:last-child>:last-child{border-radius:0}.accordion-title{position:relative;display:block;padding:1.25rem 1rem;border:1px solid #e6e6e6;border-bottom:0;font-size:.75rem;line-height:1;color:#1779ba}:last-child:not(.is-active)>.accordion-title{border-bottom:1px solid #e6e6e6;border-radius:0}.accordion-title:focus,.accordion-title:hover{background-color:#e6e6e6}.accordion-title::before{position:absolute;top:50%;right:1rem;margin-top:-.5rem;content:'+'}.is-active>.accordion-title::before{content:'\2013'}.accordion-content{display:none;padding:1rem;border:1px solid #e6e6e6;border-bottom:0;background-color:#fefefe;color:#0a0a0a}:last-child>.accordion-content:last-child{border-bottom:1px solid #e6e6e6}.media-object{display:block;margin-bottom:1rem}.media-object img{max-width:none}.media-object-section{display:table-cell;vertical-align:top}.media-object-section:first-child{padding-right:1rem}.media-object-section:last-child:not(:nth-child(2)){padding-left:1rem}.media-object-section>:last-child{margin-bottom:0}@media screen and (max-width:39.99875em){.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;display:block}.stack-for-small .media-object-section img{width:100%}}.media-object-section.middle{vertical-align:middle}.media-object-section.bottom{vertical-align:bottom}.orbit{position:relative}.orbit-container{position:relative;height:0;margin:0;list-style:none;overflow:hidden}.orbit-slide{width:100%;position:absolute}.orbit-slide.no-motionui.is-active{top:0;left:0}.orbit-figure{margin:0}.orbit-image{width:100%;max-width:100%;margin:0}.orbit-caption{position:absolute;bottom:0;width:100%;margin-bottom:0;padding:1rem;background-color:rgba(10,10,10,.5);color:#fefefe}.orbit-next,.orbit-previous{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);z-index:10;padding:1rem;color:#fefefe}[data-whatinput=mouse] .orbit-next,[data-whatinput=mouse] .orbit-previous{outline:0}.orbit-next:active,.orbit-next:focus,.orbit-next:hover,.orbit-previous:active,.orbit-previous:focus,.orbit-previous:hover{background-color:rgba(10,10,10,.5)}.orbit-previous{left:0}.orbit-next{left:auto;right:0}.orbit-bullets{position:relative;margin-top:.8rem;margin-bottom:.8rem;text-align:center}[data-whatinput=mouse] .orbit-bullets{outline:0}.orbit-bullets button{width:1.2rem;height:1.2rem;margin:.1rem;border-radius:50%;background-color:#cacaca}.orbit-bullets button:hover{background-color:#8a8a8a}.orbit-bullets button.is-active{background-color:#8a8a8a}.flex-video,.responsive-embed{position:relative;height:0;margin-bottom:1rem;padding-bottom:75%;overflow:hidden}.flex-video embed,.flex-video iframe,.flex-video object,.flex-video video,.responsive-embed embed,.responsive-embed iframe,.responsive-embed object,.responsive-embed video{position:absolute;top:0;left:0;width:100%;height:100%}.flex-video.widescreen,.responsive-embed.widescreen{padding-bottom:56.25%}.tabs{margin:0;border:1px solid #e6e6e6;background:#fefefe;list-style-type:none}.tabs::after,.tabs::before{display:table;content:' '}.tabs::after{clear:both}.tabs.vertical>li{display:block;float:none;width:auto}.tabs.simple>li>a{padding:0}.tabs.simple>li>a:hover{background:0 0}.tabs.primary{background:#1779ba}.tabs.primary>li>a{color:#fefefe}.tabs.primary>li>a:focus,.tabs.primary>li>a:hover{background:#1673b1}.tabs-title{float:left}.tabs-title>a{display:block;padding:1.25rem 1.5rem;font-size:.75rem;line-height:1;color:#1779ba}[data-whatinput=mouse] .tabs-title>a{outline:0}.tabs-title>a:hover{background:#fefefe;color:#1468a0}.tabs-title>a:focus,.tabs-title>a[aria-selected=true]{background:#e6e6e6;color:#1779ba}.tabs-content{border:1px solid #e6e6e6;border-top:0;background:#fefefe;color:#0a0a0a;-webkit-transition:all .5s ease;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-left:0}.tabs-panel{display:none;padding:1rem}.tabs-panel.is-active{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:4px solid #fefefe;border-radius:0;-webkit-box-shadow:0 0 0 1px rgba(10,10,10,.2);box-shadow:0 0 0 1px rgba(10,10,10,.2);line-height:0}a.thumbnail{-webkit-transition:-webkit-box-shadow .2s ease-out;transition:-webkit-box-shadow .2s ease-out;transition:box-shadow .2s ease-out;transition:box-shadow .2s ease-out,-webkit-box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{-webkit-box-shadow:0 0 6px 1px rgba(23,121,186,.5);box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{-webkit-box-shadow:none;box-shadow:none}.menu{padding:0;margin:0;list-style:none;position:relative}[data-whatinput=mouse] .menu li{outline:0}.menu .button,.menu a{line-height:1;text-decoration:none;display:block;padding:.7rem 1rem}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu input{display:inline-block}.menu li,.menu.horizontal li{display:inline-block}.menu.vertical li{display:block}.menu.expanded{display:table;width:100%}.menu.expanded>li{display:table-cell;vertical-align:middle}.menu.simple li+li{margin-left:1rem}.menu.simple a{padding:0}@media print,screen and (min-width:40em){.menu.medium-horizontal li{display:inline-block}.menu.medium-vertical li{display:block}.menu.medium-expanded{display:table;width:100%}.menu.medium-expanded>li{display:table-cell;vertical-align:middle}.menu.medium-simple{display:table;width:100%}.menu.medium-simple>li{display:table-cell;vertical-align:middle}}@media print,screen and (min-width:64em){.menu.large-horizontal li{display:inline-block}.menu.large-vertical li{display:block}.menu.large-expanded{display:table;width:100%}.menu.large-expanded>li{display:table-cell;vertical-align:middle}.menu.large-simple{display:table;width:100%}.menu.large-simple>li{display:table-cell;vertical-align:middle}}.menu.nested{margin-right:0;margin-left:1rem}.menu.icons i,.menu.icons img,.menu.icons svg{vertical-align:middle}.menu.icons i+span,.menu.icons img+span,.menu.icons svg+span{vertical-align:middle}.menu.icon-bottom i,.menu.icon-bottom img,.menu.icon-bottom svg,.menu.icon-left i,.menu.icon-left img,.menu.icon-left svg,.menu.icon-right i,.menu.icon-right img,.menu.icon-right svg,.menu.icon-top i,.menu.icon-top img,.menu.icon-top svg{vertical-align:middle}.menu.icon-bottom i+span,.menu.icon-bottom img+span,.menu.icon-bottom svg+span,.menu.icon-left i+span,.menu.icon-left img+span,.menu.icon-left svg+span,.menu.icon-right i+span,.menu.icon-right img+span,.menu.icon-right svg+span,.menu.icon-top i+span,.menu.icon-top img+span,.menu.icon-top svg+span{vertical-align:middle}.menu.icon-left li a i,.menu.icon-left li a img,.menu.icon-left li a svg{margin-right:.25rem;display:inline-block}.menu.icon-right li a i,.menu.icon-right li a img,.menu.icon-right li a svg{margin-left:.25rem;display:inline-block}.menu.icon-top li a{text-align:center}.menu.icon-top li a i,.menu.icon-top li a img,.menu.icon-top li a svg{display:block;margin:0 auto .25rem}.menu.icon-bottom li a{text-align:center}.menu.icon-bottom li a i,.menu.icon-bottom li a img,.menu.icon-bottom li a svg{display:block;margin:.25rem auto 0}.menu .is-active>a{background:#1779ba;color:#fefefe}.menu .active>a{background:#1779ba;color:#fefefe}.menu.align-left{text-align:left}.menu.align-right{text-align:right}.menu.align-right .submenu li{text-align:left}.menu.align-right.vertical .submenu li{text-align:right}.menu.align-right .nested{margin-right:1rem;margin-left:0}.menu.align-center{text-align:center}.menu.align-center .submenu li{text-align:left}.menu .menu-text{padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered>.menu{text-align:center}.menu-centered>.menu .submenu li{text-align:left}.no-js [data-responsive-menu] ul{display:none}.menu-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#fefefe;-webkit-box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:''}.menu-icon:hover::after{background:#cacaca;-webkit-box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.menu-icon.dark{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon.dark::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;-webkit-box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:''}.menu-icon.dark:hover::after{background:#8a8a8a;-webkit-box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a;box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a}.accordion-menu li{width:100%}.accordion-menu a{padding:.7rem 1rem}.accordion-menu .is-accordion-submenu a{padding:.7rem 1rem}.accordion-menu .nested.is-accordion-submenu{margin-right:0;margin-left:1rem}.accordion-menu.align-right .nested.is-accordion-submenu{margin-right:1rem;margin-left:0}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a{position:relative}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;right:1rem}.accordion-menu.align-left .is-accordion-submenu-parent>a::after{right:1rem;left:auto}.accordion-menu.align-right .is-accordion-submenu-parent>a::after{right:auto;left:1rem}.accordion-menu .is-accordion-submenu-parent[aria-expanded=true]>a::after{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.is-accordion-submenu-parent{position:relative}.has-submenu-toggle>a{margin-right:40px}.submenu-toggle{position:absolute;top:0;right:0;width:40px;height:40px;cursor:pointer}.submenu-toggle::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;top:0;bottom:0;margin:auto}.submenu-toggle[aria-expanded=true]::after{-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.submenu-toggle-text{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.is-drilldown{position:relative;overflow:hidden}.is-drilldown li{display:block}.is-drilldown.animate-height{-webkit-transition:height .5s;transition:height .5s}.drilldown a{padding:.7rem 1rem;background:#fefefe}.drilldown .is-drilldown-submenu{position:absolute;top:0;left:100%;z-index:-1;width:100%;background:#fefefe;-webkit-transition:-webkit-transform .15s linear;transition:-webkit-transform .15s linear;transition:transform .15s linear;transition:transform .15s linear,-webkit-transform .15s linear}.drilldown .is-drilldown-submenu.is-active{z-index:1;display:block;-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%)}.drilldown .is-drilldown-submenu.is-closing{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%)}.drilldown .is-drilldown-submenu a{padding:.7rem 1rem}.drilldown .nested.is-drilldown-submenu{margin-right:0;margin-left:0}.drilldown .drilldown-submenu-cover-previous{min-height:100%}.drilldown .is-drilldown-submenu-parent>a{position:relative}.drilldown .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;position:absolute;top:50%;margin-top:-6px;right:1rem}.drilldown.align-left .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;right:1rem;left:auto}.drilldown.align-right .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:1rem}.drilldown .js-drilldown-back>a::before{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;display:inline-block;vertical-align:middle;margin-right:.75rem}.dropdown.menu>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}[data-whatinput=mouse] .dropdown.menu a{outline:0}.dropdown.menu>li>a{padding:.7rem 1rem}.dropdown.menu>li.is-active>a{background:0 0;color:#1779ba}.no-js .dropdown.menu ul{display:none}.dropdown.menu .nested.is-dropdown-submenu{margin-right:0;margin-left:0}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.vertical>li>a::after{right:14px}.dropdown.menu.vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}@media print,screen and (min-width:40em){.dropdown.menu.medium-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.medium-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.medium-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.medium-vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.medium-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.medium-vertical>li>a::after{right:14px}.dropdown.menu.medium-vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.medium-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}@media print,screen and (min-width:64em){.dropdown.menu.large-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.large-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.large-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.large-vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.large-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.large-vertical>li>a::after{right:14px}.dropdown.menu.large-vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.large-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}.dropdown.menu.align-right .is-dropdown-submenu.first-sub{top:100%;right:0;left:auto}.is-dropdown-menu.vertical{width:100px}.is-dropdown-menu.vertical.align-right{float:right}.is-dropdown-submenu-parent{position:relative}.is-dropdown-submenu-parent a::after{position:absolute;top:50%;right:5px;left:auto;margin-top:-6px}.is-dropdown-submenu-parent.opens-inner>.is-dropdown-submenu{top:100%;left:auto}.is-dropdown-submenu-parent.opens-left>.is-dropdown-submenu{right:100%;left:auto}.is-dropdown-submenu-parent.opens-right>.is-dropdown-submenu{right:auto;left:100%}.is-dropdown-submenu{position:absolute;top:0;left:100%;z-index:1;display:none;min-width:200px;border:1px solid #cacaca;background:#fefefe}.dropdown .is-dropdown-submenu a{padding:.7rem 1rem}.is-dropdown-submenu .is-dropdown-submenu-parent>a::after{right:14px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.is-dropdown-submenu .is-dropdown-submenu{margin-top:-1px}.is-dropdown-submenu>li{width:100%}.is-dropdown-submenu.js-dropdown-active{display:block}.is-off-canvas-open{overflow:hidden}.js-off-canvas-overlay{position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;-webkit-transition:opacity .5s ease,visibility .5s ease;transition:opacity .5s ease,visibility .5s ease;background:rgba(254,254,254,.25);opacity:0;visibility:hidden;overflow:hidden}.js-off-canvas-overlay.is-visible{opacity:1;visibility:visible}.js-off-canvas-overlay.is-closable{cursor:pointer}.js-off-canvas-overlay.is-overlay-absolute{position:absolute}.js-off-canvas-overlay.is-overlay-fixed{position:fixed}.off-canvas-wrapper{position:relative;overflow:hidden}.off-canvas{position:fixed;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-push{z-index:12}.off-canvas.is-closed{visibility:hidden}.off-canvas.is-transition-overlap{z-index:13}.off-canvas.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-absolute{position:absolute;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas-absolute{outline:0}.off-canvas-absolute.is-transition-push{z-index:12}.off-canvas-absolute.is-closed{visibility:hidden}.off-canvas-absolute.is-transition-overlap{z-index:13}.off-canvas-absolute.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas-absolute.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.position-left{top:0;left:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-left.has-transition-push{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.position-left.is-transition-push{-webkit-box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25)}.position-right{top:0;right:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-right.has-transition-push{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.position-right.is-transition-push{-webkit-box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25)}.position-top{top:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-top.has-transition-push{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.position-top.is-transition-push{-webkit-box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25)}.position-bottom{bottom:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-bottom.has-transition-push{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.position-bottom.is-transition-push{-webkit-box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25)}.off-canvas-content{-webkit-transform:none;-ms-transform:none;transform:none;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.off-canvas-content.has-transition-push{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content .off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}@media print,screen and (min-width:40em){.position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-medium .close-button{display:none}.off-canvas-content .position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-medium .close-button{display:none}.off-canvas-content .position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-medium .close-button{display:none}.off-canvas-content .position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-medium .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:64em){.position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-large .close-button{display:none}.off-canvas-content .position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-large .close-button{display:none}.off-canvas-content .position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-large .close-button{display:none}.off-canvas-content .position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-large .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:40em){.off-canvas.in-canvas-for-medium{visibility:visible;height:auto;position:static;background:0 0;width:auto;overflow:visible;-webkit-transition:none;transition:none}.off-canvas.in-canvas-for-medium.position-bottom,.off-canvas.in-canvas-for-medium.position-left,.off-canvas.in-canvas-for-medium.position-right,.off-canvas.in-canvas-for-medium.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-medium .close-button{display:none}}@media print,screen and (min-width:64em){.off-canvas.in-canvas-for-large{visibility:visible;height:auto;position:static;background:0 0;width:auto;overflow:visible;-webkit-transition:none;transition:none}.off-canvas.in-canvas-for-large.position-bottom,.off-canvas.in-canvas-for-large.position-left,.off-canvas.in-canvas-for-large.position-right,.off-canvas.in-canvas-for-large.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-large .close-button{display:none}}html.is-reveal-open{position:fixed;width:100%;overflow-y:hidden}html.is-reveal-open.zf-has-scroll{overflow-y:scroll}html.is-reveal-open body{overflow-y:hidden}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;display:none;background-color:rgba(10,10,10,.45);overflow-y:auto}.reveal{z-index:1006;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:none;padding:1rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;position:relative;top:100px;margin-right:auto;margin-left:auto;overflow-y:auto}[data-whatinput=mouse] .reveal{outline:0}@media print,screen and (min-width:40em){.reveal{min-height:0}}.reveal .column,.reveal .columns{min-width:0}.reveal>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.reveal{width:600px;max-width:75rem}}.reveal.collapse{padding:0}@media print,screen and (min-width:40em){.reveal.tiny{width:30%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.small{width:50%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.large{width:90%;max-width:75rem}}.reveal.full{top:0;right:0;bottom:0;left:0;width:100%;max-width:none;height:100%;min-height:100%;margin-left:0;border:0;border-radius:0}@media screen and (max-width:39.99875em){.reveal{top:0;right:0;bottom:0;left:0;width:100%;max-width:none;height:100%;min-height:100%;margin-left:0;border:0;border-radius:0}}.reveal.without-overlay{position:fixed}.sticky-container{position:relative}.sticky{position:relative;z-index:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.sticky.is-stuck{position:fixed;z-index:5;width:100%}.sticky.is-stuck.is-at-top{top:0}.sticky.is-stuck.is-at-bottom{bottom:0}.sticky.is-anchored{position:relative;right:auto;left:auto}.sticky.is-anchored.is-at-bottom{bottom:0}.title-bar{padding:.5rem;background:#0a0a0a;color:#fefefe}.title-bar::after,.title-bar::before{display:table;content:' '}.title-bar::after{clear:both}.title-bar .menu-icon{margin-left:.25rem;margin-right:.25rem}.title-bar-left{float:left}.title-bar-right{float:right;text-align:right}.title-bar-title{display:inline-block;vertical-align:middle;font-weight:700}.top-bar{padding:.5rem}.top-bar::after,.top-bar::before{display:table;content:' '}.top-bar::after{clear:both}.top-bar,.top-bar ul{background-color:#e6e6e6}.top-bar input{max-width:200px;margin-right:1rem}.top-bar .input-group-field{width:100%;margin-right:0}.top-bar input.button{width:auto}.top-bar .top-bar-left,.top-bar .top-bar-right{width:100%}@media print,screen and (min-width:40em){.top-bar .top-bar-left,.top-bar .top-bar-right{width:auto}}@media screen and (max-width:63.99875em){.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{width:100%}}@media screen and (max-width:74.99875em){.top-bar.stacked-for-large .top-bar-left,.top-bar.stacked-for-large .top-bar-right{width:100%}}.top-bar-title{display:inline-block;float:left;padding:.5rem 1rem .5rem 0}.top-bar-title .menu-icon{bottom:2px}.top-bar-left{float:left}.top-bar-right{float:right}.float-left{float:left!important}.float-right{float:right!important}.float-center{display:block;margin-right:auto;margin-left:auto}.clearfix::after,.clearfix::before{display:table;content:' '}.clearfix::after{clear:both}.hide{display:none!important}.invisible{visibility:hidden}@media screen and (max-width:39.99875em){.hide-for-small-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media print,screen and (min-width:40em){.hide-for-medium{display:none!important}}@media screen and (max-width:39.99875em){.show-for-medium{display:none!important}}@media screen and (min-width:40em) and (max-width:63.99875em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:39.99875em),screen and (min-width:64em){.show-for-medium-only{display:none!important}}@media print,screen and (min-width:64em){.hide-for-large{display:none!important}}@media screen and (max-width:63.99875em){.show-for-large{display:none!important}}@media screen and (min-width:64em) and (max-width:74.99875em){.hide-for-large-only{display:none!important}}@media screen and (max-width:63.99875em),screen and (min-width:75em){.show-for-large-only{display:none!important}}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}.hide-for-portrait,.show-for-landscape{display:block!important}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}}.hide-for-landscape,.show-for-portrait{display:none!important}@media screen and (orientation:landscape){.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-landscape,.show-for-portrait{display:block!important}}
+/*# sourceMappingURL=foundation-float.min.css.map */
diff --git a/dist/css/foundation-float.min.css.map b/dist/css/foundation-float.min.css.map
new file mode 100644 (file)
index 0000000..b41ed84
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation-float.min.css"],"names":[],"mappings":"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MACrB,MACE,QAAS,mBAEX,IADA,GAEE,kBAAmB,MACrB,IACE,UAAW,eACb,MACE,OAAQ,KAEV,GACA,GAFA,EAGE,QAAS,EACT,OAAQ,EACV,GACA,GACE,iBAAkB,MACpB,oBACE,kBAAmB,MAEvB,KACE,UAAW,MACX,aAAc,KACd,YAAa,KACC,YAAd,aACE,QAAS,MACT,QAAS,IACX,YACE,MAAO,KACT,sBAAyB,uBACvB,cAAe,EACf,aAAc,EAChB,UACE,aAAc,SACd,YAAa,SACb,aAAc,4BACZ,UACE,aAAc,UACd,YAAa,WACjB,aAAc,4BACZ,UACE,aAAc,UACd,YAAa,WACjB,mBACE,aAAc,EACd,YAAa,EACjB,cACE,UAAW,KACX,mBACE,aAAc,KACd,YAAa,KACjB,yBACE,UAAW,KACb,0BAA6B,2BAC3B,cAAe,QACf,aAAc,QAChB,2BAA8B,4BAC5B,cAAe,SACf,aAAc,SAElB,QAAS,SACP,MAAO,KACP,MAAO,KACP,cAAe,QACf,aAAc,QACd,aAAc,4BACZ,QAAS,SACP,cAAe,SACf,aAAc,UAClB,QAAmB,qCAAV,SAAgD,sCACvD,MAAO,KACP,MAAO,KACT,qCAAsC,sCACpC,MAAO,MACT,kCAAmC,mCACjC,MAAO,KAEX,gBAAiB,iBACf,MAAO,KAET,qBAAsB,sBACpB,aAAc,EACd,YAAa,EACb,cAAe,EACf,aAAc,EAEhB,SACE,MAAO,SAET,cACE,SAAU,SACV,KAAM,SAER,cACE,SAAU,SACV,KAAM,UAER,gBACE,YAAa,EAEf,SACE,MAAO,UAET,cACE,SAAU,SACV,KAAM,UAER,cACE,SAAU,SACV,KAAM,WAER,gBACE,YAAa,SAEf,SACE,MAAO,IAET,cACE,SAAU,SACV,KAAM,IAER,cACE,SAAU,SACV,KAAM,KAER,gBACE,YAAa,UAEf,SACE,MAAO,UAET,cACE,SAAU,SACV,KAAM,UAER,cACE,SAAU,SACV,KAAM,WAER,gBACE,YAAa,IAEf,SACE,MAAO,UAET,cACE,SAAU,SACV,KAAM,UAER,cACE,SAAU,SACV,KAAM,WAER,gBACE,YAAa,UAEf,SACE,MAAO,IAET,cACE,SAAU,SACV,KAAM,IAER,cACE,SAAU,SACV,KAAM,KAER,gBACE,YAAa,UAEf,SACE,MAAO,UAET,cACE,SAAU,SACV,KAAM,UAER,cACE,SAAU,SACV,KAAM,WAER,gBACE,YAAa,IAEf,SACE,MAAO,UAET,cACE,SAAU,SACV,KAAM,UAER,cACE,SAAU,SACV,KAAM,WAER,gBACE,YAAa,UAEf,SACE,MAAO,IAET,cACE,SAAU,SACV,KAAM,IAER,cACE,SAAU,SACV,KAAM,KAER,gBACE,YAAa,UAEf,UACE,MAAO,UAET,eACE,SAAU,SACV,KAAM,UAER,eACE,SAAU,SACV,KAAM,WAER,gBACE,YAAa,IAEf,UACE,MAAO,UAET,eACE,SAAU,SACV,KAAM,UAER,eACE,SAAU,SACV,KAAM,WAER,iBACE,YAAa,UAEf,UACE,MAAO,KAET,iBACE,YAAa,UAEf,oBAAuB,qBACrB,MAAO,KACP,MAAO,KACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KAEX,oBAAuB,qBACrB,MAAO,KACP,MAAO,IACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KAEX,oBAAuB,qBACrB,MAAO,KACP,MAAO,UACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KAEX,oBAAuB,qBACrB,MAAO,KACP,MAAO,IACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KAEX,oBAAuB,qBACrB,MAAO,KACP,MAAO,IACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KAEX,oBAAuB,qBACrB,MAAO,KACP,MAAO,UACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KAEX,oBAAuB,qBACrB,MAAO,KACP,MAAO,UACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KAEX,oBAAuB,qBACrB,MAAO,KACP,MAAO,MACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KAEX,wBAA2B,yBACzB,cAAe,EACf,aAAc,EAEhB,qBACE,aAAc,EACd,YAAa,EAEf,kCACE,aAAc,EACd,YAAa,EAEf,0BAA6B,2BAC3B,cAAe,QACf,aAAc,QAEhB,gBACE,aAAc,KACd,YAAa,KACb,gBAAiB,6CACf,MAAO,KACP,MAAO,KAIX,cADA,cADA,kBAGE,SAAU,OACV,aAAc,EACd,YAAa,EAIb,cACA,2CAHA,cACA,2CAFA,kBAAmB,+CAKjB,MAAO,KACP,MAAO,KAGT,2CADA,2CADA,+CAGE,MAAO,MAEX,aAAc,4BACZ,UACE,MAAO,SACT,eACE,SAAU,SACV,KAAM,SACR,eACE,SAAU,SACV,KAAM,UACR,iBACE,YAAa,EACf,UACE,MAAO,UACT,eACE,SAAU,SACV,KAAM,UACR,eACE,SAAU,SACV,KAAM,WACR,iBACE,YAAa,SACf,UACE,MAAO,IACT,eACE,SAAU,SACV,KAAM,IACR,eACE,SAAU,SACV,KAAM,KACR,iBACE,YAAa,UACf,UACE,MAAO,UACT,eACE,SAAU,SACV,KAAM,UACR,eACE,SAAU,SACV,KAAM,WACR,iBACE,YAAa,IACf,UACE,MAAO,UACT,eACE,SAAU,SACV,KAAM,UACR,eACE,SAAU,SACV,KAAM,WACR,iBACE,YAAa,UACf,UACE,MAAO,IACT,eACE,SAAU,SACV,KAAM,IACR,eACE,SAAU,SACV,KAAM,KACR,iBACE,YAAa,UACf,UACE,MAAO,UACT,eACE,SAAU,SACV,KAAM,UACR,eACE,SAAU,SACV,KAAM,WACR,iBACE,YAAa,IACf,UACE,MAAO,UACT,eACE,SAAU,SACV,KAAM,UACR,eACE,SAAU,SACV,KAAM,WACR,iBACE,YAAa,UACf,UACE,MAAO,IACT,eACE,SAAU,SACV,KAAM,IACR,eACE,SAAU,SACV,KAAM,KACR,iBACE,YAAa,UACf,WACE,MAAO,UACT,gBACE,SAAU,SACV,KAAM,UACR,gBACE,SAAU,SACV,KAAM,WACR,iBACE,YAAa,IACf,WACE,MAAO,UACT,gBACE,SAAU,SACV,KAAM,UACR,gBACE,SAAU,SACV,KAAM,WACR,kBACE,YAAa,UACf,WACE,MAAO,KACT,kBACE,YAAa,UACf,qBAAwB,sBACtB,MAAO,KACP,MAAO,KACP,qCAAwC,sCACtC,MAAO,KACT,uCAA0C,wCACxC,MAAO,KACT,gCAAmC,iCACjC,MAAO,KACX,qBAAwB,sBACtB,MAAO,KACP,MAAO,IACP,qCAAwC,sCACtC,MAAO,KACT,uCAA0C,wCACxC,MAAO,KACT,gCAAmC,iCACjC,MAAO,KACX,qBAAwB,sBACtB,MAAO,KACP,MAAO,UACP,qCAAwC,sCACtC,MAAO,KACT,uCAA0C,wCACxC,MAAO,KACT,gCAAmC,iCACjC,MAAO,KACX,qBAAwB,sBACtB,MAAO,KACP,MAAO,IACP,qCAAwC,sCACtC,MAAO,KACT,uCAA0C,wCACxC,MAAO,KACT,gCAAmC,iCACjC,MAAO,KACX,qBAAwB,sBACtB,MAAO,KACP,MAAO,IACP,qCAAwC,sCACtC,MAAO,KACT,uCAA0C,wCACxC,MAAO,KACT,gCAAmC,iCACjC,MAAO,KACX,qBAAwB,sBACtB,MAAO,KACP,MAAO,UACP,qCAAwC,sCACtC,MAAO,KACT,uCAA0C,wCACxC,MAAO,KACT,gCAAmC,iCACjC,MAAO,KACX,qBAAwB,sBACtB,MAAO,KACP,MAAO,UACP,qCAAwC,sCACtC,MAAO,KACT,uCAA0C,wCACxC,MAAO,KACT,gCAAmC,iCACjC,MAAO,KACX,qBAAwB,sBACtB,MAAO,KACP,MAAO,MACP,qCAAwC,sCACtC,MAAO,KACT,uCAA0C,wCACxC,MAAO,KACT,gCAAmC,iCACjC,MAAO,KACX,yBAA4B,0BAC1B,cAAe,EACf,aAAc,EAChB,sBACE,aAAc,EACd,YAAa,EACf,mCACE,aAAc,EACd,YAAa,EACf,2BAA8B,4BAC5B,cAAe,SACf,aAAc,SAChB,iBACE,aAAc,KACd,YAAa,KACb,iBAAkB,8CAChB,MAAO,KACP,MAAO,KAGX,eADA,eADA,mBAGE,SAAU,OACV,aAAc,EACd,YAAa,EAIb,eACA,4CAHA,eACA,4CAFA,mBAAoB,gDAKlB,MAAO,KACP,MAAO,KAGT,4CADA,4CADA,gDAGE,MAAO,OAEb,aAAc,4BACZ,SACE,MAAO,SACT,cACE,SAAU,SACV,KAAM,SACR,cACE,SAAU,SACV,KAAM,UACR,gBACE,YAAa,EACf,SACE,MAAO,UACT,cACE,SAAU,SACV,KAAM,UACR,cACE,SAAU,SACV,KAAM,WACR,gBACE,YAAa,SACf,SACE,MAAO,IACT,cACE,SAAU,SACV,KAAM,IACR,cACE,SAAU,SACV,KAAM,KACR,gBACE,YAAa,UACf,SACE,MAAO,UACT,cACE,SAAU,SACV,KAAM,UACR,cACE,SAAU,SACV,KAAM,WACR,gBACE,YAAa,IACf,SACE,MAAO,UACT,cACE,SAAU,SACV,KAAM,UACR,cACE,SAAU,SACV,KAAM,WACR,gBACE,YAAa,UACf,SACE,MAAO,IACT,cACE,SAAU,SACV,KAAM,IACR,cACE,SAAU,SACV,KAAM,KACR,gBACE,YAAa,UACf,SACE,MAAO,UACT,cACE,SAAU,SACV,KAAM,UACR,cACE,SAAU,SACV,KAAM,WACR,gBACE,YAAa,IACf,SACE,MAAO,UACT,cACE,SAAU,SACV,KAAM,UACR,cACE,SAAU,SACV,KAAM,WACR,gBACE,YAAa,UACf,SACE,MAAO,IACT,cACE,SAAU,SACV,KAAM,IACR,cACE,SAAU,SACV,KAAM,KACR,gBACE,YAAa,UACf,UACE,MAAO,UACT,eACE,SAAU,SACV,KAAM,UACR,eACE,SAAU,SACV,KAAM,WACR,gBACE,YAAa,IACf,UACE,MAAO,UACT,eACE,SAAU,SACV,KAAM,UACR,eACE,SAAU,SACV,KAAM,WACR,iBACE,YAAa,UACf,UACE,MAAO,KACT,iBACE,YAAa,UACf,oBAAuB,qBACrB,MAAO,KACP,MAAO,KACP,oCAAuC,qCACrC,MAAO,KACT,sCAAyC,uCACvC,MAAO,KACT,+BAAkC,gCAChC,MAAO,KACX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","file":"foundation-float.min.css","sourcesContent":[]}
\ No newline at end of file
index 12c82839d5f4292b3437dfb429ac046e4afde9c7..8bba50f03d42ed43939284ac0307ea8acc7d9bb5 100644 (file)
@@ -1,7 +1,7 @@
 @charset "UTF-8";
 /**
  * Foundation for Sites by ZURB
- * Version 6.4.3
+ * Version 6.5.3
  * foundation.zurb.com
  * Licensed under MIT Open Source
  */
     left: auto;
     margin: 0 auto; } }
 
-/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */
-/* Document
-       ========================================================================== */
-/**
-     * 1. Change the default font family in all browsers (opinionated).
-     * 2. Correct the line height in all browsers.
-     * 3. Prevent adjustments of font size after orientation changes in
-     *    IE on Windows Phone and in iOS.
-     */
+/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
 html {
-  font-family: sans-serif;
-  /* 1 */
   line-height: 1.15;
-  /* 2 */
-  -ms-text-size-adjust: 100%;
-  /* 3 */
-  -webkit-text-size-adjust: 100%;
-  /* 3 */ }
-
-/* Sections
-       ========================================================================== */
-/**
-     * Remove the margin in all browsers (opinionated).
-     */
+  -webkit-text-size-adjust: 100%; }
+
 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-.
-     */
-figcaption,
-figure {
-  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 */ }
-
-/**
-     * Add the correct display in IE.
-     */
-main {
-  display: block; }
+  overflow: visible; }
 
-/**
-     * 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 */ }
+  font-size: 1em; }
 
-/* Links
-       ========================================================================== */
-/**
-     * 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 */ }
+  background-color: transparent; }
 
-/**
-     * Remove the outline on focused links when they are also active or hovered
-     * in all browsers (opinionated).
-     */
-a:active,
-a:hover {
-  outline-width: 0; }
-
-/* Text-level semantics
-       ========================================================================== */
-/**
-     * 1. Remove the bottom border in 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 */
-  text-decoration: underline dotted;
-  /* 2 */ }
+  -webkit-text-decoration: underline dotted;
+          text-decoration: underline dotted; }
 
-/**
-     * 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; }
+  font-size: 1em; }
 
-/**
-     * 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%;
@@ -197,237 +68,94 @@ sub {
 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-family: inherit;
   font-size: 100%;
-  /* 1 */
   line-height: 1.15;
-  /* 1 */
-  margin: 0;
-  /* 2 */ }
+  margin: 0; }
 
-/**
-     * Show the overflow in IE.
-     */
-button {
+button,
+input {
   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 */ }
-
 button,
 [type="button"],
 [type="reset"],
 [type="submit"] {
-  /**
-       * Remove the inner border and padding in Firefox.
-       */
-  /**
-       * Restore the focus styles unset by the previous rule.
-       */ }
-  button::-moz-focus-inner,
-  [type="button"]::-moz-focus-inner,
-  [type="reset"]::-moz-focus-inner,
-  [type="submit"]::-moz-focus-inner {
-    border-style: none;
-    padding: 0; }
-  button:-moz-focusring,
-  [type="button"]:-moz-focusring,
-  [type="reset"]:-moz-focusring,
-  [type="submit"]:-moz-focusring {
-    outline: 1px dotted ButtonText; }
-
-/**
-     * Show the overflow in Edge.
-     */
-input {
-  overflow: visible; }
-
-/**
-     * 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 */ }
+  -webkit-appearance: button; }
 
-/**
-     * 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; }
+button::-moz-focus-inner,
+[type="button"]::-moz-focus-inner,
+[type="reset"]::-moz-focus-inner,
+[type="submit"]::-moz-focus-inner {
+  border-style: none;
+  padding: 0; }
 
-/**
-     * 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 */ }
+button:-moz-focusring,
+[type="button"]:-moz-focusring,
+[type="reset"]:-moz-focusring,
+[type="submit"]:-moz-focusring {
+  outline: 1px dotted ButtonText; }
 
-/**
-     * Change the border, margin, and padding in all browsers (opinionated).
-     */
 fieldset {
-  border: 1px solid #c0c0c0;
-  margin: 0 2px;
-  padding: 0.35em 0.625em 0.75em; }
+  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;
   display: table;
-  /* 1 */
   max-width: 100%;
-  /* 1 */
   padding: 0;
-  /* 3 */
-  color: inherit;
-  /* 2 */
-  white-space: normal;
-  /* 1 */ }
+  white-space: normal; }
 
-/**
-     * 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 */ }
+  vertical-align: baseline; }
 
-/**
-     * Remove the default vertical scrollbar in IE.
-     */
 textarea {
   overflow: auto; }
 
-/* Interactive
-       ========================================================================== */
-/*
-     * Add the correct display in Edge, IE, and Firefox.
-     */
+[type="checkbox"],
+[type="radio"] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  padding: 0; }
+
+[type="number"]::-webkit-inner-spin-button,
+[type="number"]::-webkit-outer-spin-button {
+  height: auto; }
+
+[type="search"] {
+  -webkit-appearance: textfield;
+  outline-offset: -2px; }
+
+[type="search"]::-webkit-search-decoration {
+  -webkit-appearance: none; }
+
+::-webkit-file-upload-button {
+  -webkit-appearance: button;
+  font: inherit; }
+
 details {
   display: block; }
 
-/*
-     * Add the correct display in all browsers.
-     */
 summary {
   display: list-item; }
 
-/*
-     * Add the correct display in IE 9-.
-     */
-menu {
-  display: block; }
-
-/* 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; }
 
@@ -511,2140 +239,2168 @@ textarea {
 .is-hidden {
   display: none !important; }
 
-.grid-container {
-  padding-right: 0.625rem;
-  padding-left: 0.625rem;
-  max-width: 75rem;
-  margin: 0 auto; }
-  @media print, screen and (min-width: 40em) {
-    .grid-container {
-      padding-right: 0.9375rem;
-      padding-left: 0.9375rem; } }
-  .grid-container.fluid {
-    padding-right: 0.625rem;
-    padding-left: 0.625rem;
-    max-width: 100%;
-    margin: 0 auto; }
-    @media print, screen and (min-width: 40em) {
-      .grid-container.fluid {
-        padding-right: 0.9375rem;
-        padding-left: 0.9375rem; } }
-  .grid-container.full {
-    padding-right: 0;
-    padding-left: 0;
-    max-width: 100%;
-    margin: 0 auto; }
-
-.grid-x {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-orient: horizontal;
-  -webkit-box-direction: normal;
-  -webkit-flex-flow: row wrap;
-      -ms-flex-flow: row wrap;
-          flex-flow: row wrap; }
-
-.cell {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto;
-  min-height: 0px;
-  min-width: 0px;
-  width: 100%; }
-  .cell.auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-  .cell.shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto; }
+[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],
+textarea {
+  display: block;
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  width: 100%;
+  height: 2.4375rem;
+  margin: 0 0 1rem;
+  padding: 0.5rem;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
+          box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
+  font-family: inherit;
+  font-size: 1rem;
+  font-weight: normal;
+  line-height: 1.5;
+  color: #0a0a0a;
+  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none; }
+  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,
+  textarea:focus {
+    outline: none;
+    border: 1px solid #8a8a8a;
+    background-color: #fefefe;
+    -webkit-box-shadow: 0 0 5px #cacaca;
+            box-shadow: 0 0 5px #cacaca;
+    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
 
-.grid-x > .auto {
-  width: auto; }
+textarea {
+  max-width: 100%; }
+  textarea[rows] {
+    height: auto; }
 
-.grid-x > .shrink {
-  width: auto; }
+input:disabled, input[readonly],
+textarea:disabled,
+textarea[readonly] {
+  background-color: #e6e6e6;
+  cursor: not-allowed; }
 
-.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
-  -webkit-flex-basis: auto;
-      -ms-flex-preferred-size: auto;
-          flex-basis: auto; }
+[type='submit'],
+[type='button'] {
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none;
+  border-radius: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; } }
+input[type='search'] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; } }
+::-webkit-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-1 {
-  width: 8.33333%; }
+:-ms-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-2 {
-  width: 16.66667%; }
+::-ms-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-3 {
-  width: 25%; }
+::placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-4 {
-  width: 33.33333%; }
+[type='file'],
+[type='checkbox'],
+[type='radio'] {
+  margin: 0 0 1rem; }
 
-.grid-x > .small-5 {
-  width: 41.66667%; }
+[type='checkbox'] + label,
+[type='radio'] + label {
+  display: inline-block;
+  vertical-align: baseline;
+  margin-left: 0.5rem;
+  margin-right: 1rem;
+  margin-bottom: 0; }
+  [type='checkbox'] + label[for],
+  [type='radio'] + label[for] {
+    cursor: pointer; }
 
-.grid-x > .small-6 {
-  width: 50%; }
+label > [type='checkbox'],
+label > [type='radio'] {
+  margin-right: 0.5rem; }
 
-.grid-x > .small-7 {
-  width: 58.33333%; }
+[type='file'] {
+  width: 100%; }
 
-.grid-x > .small-8 {
-  width: 66.66667%; }
+label {
+  display: block;
+  margin: 0;
+  font-size: 0.875rem;
+  font-weight: normal;
+  line-height: 1.8;
+  color: #0a0a0a; }
+  label.middle {
+    margin: 0 0 1rem;
+    padding: 0.5625rem 0; }
 
-.grid-x > .small-9 {
-  width: 75%; }
+.help-text {
+  margin-top: -0.5rem;
+  font-size: 0.8125rem;
+  font-style: italic;
+  color: #0a0a0a; }
 
-.grid-x > .small-10 {
-  width: 83.33333%; }
+.input-group {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  width: 100%;
+  margin-bottom: 1rem;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch; }
+  .input-group > :first-child, .input-group > :first-child.input-group-button > * {
+    border-radius: 0 0 0 0; }
+  .input-group > :last-child, .input-group > :last-child.input-group-button > * {
+    border-radius: 0 0 0 0; }
 
-.grid-x > .small-11 {
-  width: 91.66667%; }
+.input-group-label, .input-group-field, .input-group-button, .input-group-button a,
+.input-group-button input,
+.input-group-button button,
+.input-group-button label {
+  margin: 0;
+  white-space: nowrap; }
 
-.grid-x > .small-12 {
-  width: 100%; }
+.input-group-label {
+  padding: 0 1rem;
+  border: 1px solid #cacaca;
+  background: #e6e6e6;
+  color: #0a0a0a;
+  text-align: center;
+  white-space: nowrap;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto;
+  -webkit-box-align: center;
+  -webkit-align-items: center;
+      -ms-flex-align: center;
+          align-items: center; }
+  .input-group-label:first-child {
+    border-right: 0; }
+  .input-group-label:last-child {
+    border-left: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-x > .medium-auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px;
-    width: auto; }
-  .grid-x > .medium-shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto;
-    width: auto; }
-  .grid-x > .medium-1 {
-    width: 8.33333%; }
-  .grid-x > .medium-2 {
-    width: 16.66667%; }
-  .grid-x > .medium-3 {
-    width: 25%; }
-  .grid-x > .medium-4 {
-    width: 33.33333%; }
-  .grid-x > .medium-5 {
-    width: 41.66667%; }
-  .grid-x > .medium-6 {
-    width: 50%; }
-  .grid-x > .medium-7 {
-    width: 58.33333%; }
-  .grid-x > .medium-8 {
-    width: 66.66667%; }
-  .grid-x > .medium-9 {
-    width: 75%; }
-  .grid-x > .medium-10 {
-    width: 83.33333%; }
-  .grid-x > .medium-11 {
-    width: 91.66667%; }
-  .grid-x > .medium-12 {
-    width: 100%; } }
+.input-group-field {
+  border-radius: 0;
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 1 0px;
+      -ms-flex: 1 1 0px;
+          flex: 1 1 0px;
+  min-width: 0; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-x > .large-auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px;
-    width: auto; }
-  .grid-x > .large-shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto;
-    width: auto; }
-  .grid-x > .large-1 {
-    width: 8.33333%; }
-  .grid-x > .large-2 {
-    width: 16.66667%; }
-  .grid-x > .large-3 {
-    width: 25%; }
-  .grid-x > .large-4 {
-    width: 33.33333%; }
-  .grid-x > .large-5 {
-    width: 41.66667%; }
-  .grid-x > .large-6 {
-    width: 50%; }
-  .grid-x > .large-7 {
-    width: 58.33333%; }
-  .grid-x > .large-8 {
-    width: 66.66667%; }
-  .grid-x > .large-9 {
-    width: 75%; }
-  .grid-x > .large-10 {
-    width: 83.33333%; }
-  .grid-x > .large-11 {
-    width: 91.66667%; }
-  .grid-x > .large-12 {
-    width: 100%; } }
+.input-group-button {
+  padding-top: 0;
+  padding-bottom: 0;
+  text-align: center;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto; }
+  .input-group-button a,
+  .input-group-button input,
+  .input-group-button button,
+  .input-group-button label {
+    -webkit-align-self: stretch;
+        -ms-flex-item-align: stretch;
+            align-self: stretch;
+    height: auto;
+    padding-top: 0;
+    padding-bottom: 0;
+    font-size: 1rem; }
 
-.grid-margin-x:not(.grid-x) > .cell {
-  width: auto; }
+fieldset {
+  margin: 0;
+  padding: 0;
+  border: 0; }
 
-.grid-margin-y:not(.grid-y) > .cell {
-  height: auto; }
+legend {
+  max-width: 100%;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x {
-  margin-left: -0.625rem;
-  margin-right: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x {
-      margin-left: -0.9375rem;
-      margin-right: -0.9375rem; } }
-  .grid-margin-x > .cell {
-    width: calc(100% - 1.25rem);
-    margin-left: 0.625rem;
-    margin-right: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x > .cell {
-      width: calc(100% - 1.875rem);
-      margin-left: 0.9375rem;
-      margin-right: 0.9375rem; } }
-  .grid-margin-x > .auto {
-    width: auto; }
-  .grid-margin-x > .shrink {
-    width: auto; }
-  .grid-margin-x > .small-1 {
-    width: calc(8.33333% - 1.25rem); }
-  .grid-margin-x > .small-2 {
-    width: calc(16.66667% - 1.25rem); }
-  .grid-margin-x > .small-3 {
-    width: calc(25% - 1.25rem); }
-  .grid-margin-x > .small-4 {
-    width: calc(33.33333% - 1.25rem); }
-  .grid-margin-x > .small-5 {
-    width: calc(41.66667% - 1.25rem); }
-  .grid-margin-x > .small-6 {
-    width: calc(50% - 1.25rem); }
-  .grid-margin-x > .small-7 {
-    width: calc(58.33333% - 1.25rem); }
-  .grid-margin-x > .small-8 {
-    width: calc(66.66667% - 1.25rem); }
-  .grid-margin-x > .small-9 {
-    width: calc(75% - 1.25rem); }
-  .grid-margin-x > .small-10 {
-    width: calc(83.33333% - 1.25rem); }
-  .grid-margin-x > .small-11 {
-    width: calc(91.66667% - 1.25rem); }
-  .grid-margin-x > .small-12 {
-    width: calc(100% - 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x > .auto {
-      width: auto; }
-    .grid-margin-x > .shrink {
-      width: auto; }
-    .grid-margin-x > .small-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .small-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .small-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .small-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .small-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .small-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .small-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .small-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .small-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .small-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .small-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .small-12 {
-      width: calc(100% - 1.875rem); }
-    .grid-margin-x > .medium-auto {
-      width: auto; }
-    .grid-margin-x > .medium-shrink {
-      width: auto; }
-    .grid-margin-x > .medium-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .medium-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .medium-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .medium-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .medium-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .medium-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .medium-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .medium-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .medium-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .medium-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .medium-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .medium-12 {
-      width: calc(100% - 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-margin-x > .large-auto {
-      width: auto; }
-    .grid-margin-x > .large-shrink {
-      width: auto; }
-    .grid-margin-x > .large-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .large-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .large-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .large-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .large-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .large-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .large-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .large-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .large-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .large-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .large-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .large-12 {
-      width: calc(100% - 1.875rem); } }
+.fieldset {
+  margin: 1.125rem 0;
+  padding: 1.25rem;
+  border: 1px solid #cacaca; }
+  .fieldset legend {
+    margin: 0;
+    margin-left: -0.1875rem;
+    padding: 0 0.1875rem; }
 
-.grid-padding-x .grid-padding-x {
-  margin-right: -0.625rem;
-  margin-left: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-x .grid-padding-x {
-      margin-right: -0.9375rem;
-      margin-left: -0.9375rem; } }
+select {
+  height: 2.4375rem;
+  margin: 0 0 1rem;
+  padding: 0.5rem;
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  font-family: inherit;
+  font-size: 1rem;
+  font-weight: normal;
+  line-height: 1.5;
+  color: #0a0a0a;
+  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");
+  background-origin: content-box;
+  background-position: right -1rem center;
+  background-repeat: no-repeat;
+  background-size: 9px 6px;
+  padding-right: 1.5rem;
+  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+  @media screen and (min-width: 0\0) {
+    select {
+      background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } }
+  select:focus {
+    outline: none;
+    border: 1px solid #8a8a8a;
+    background-color: #fefefe;
+    -webkit-box-shadow: 0 0 5px #cacaca;
+            box-shadow: 0 0 5px #cacaca;
+    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+  select:disabled {
+    background-color: #e6e6e6;
+    cursor: not-allowed; }
+  select::-ms-expand {
+    display: none; }
+  select[multiple] {
+    height: auto;
+    background-image: none; }
 
-.grid-container:not(.full) > .grid-padding-x {
-  margin-right: -0.625rem;
-  margin-left: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-container:not(.full) > .grid-padding-x {
-      margin-right: -0.9375rem;
-      margin-left: -0.9375rem; } }
+.is-invalid-input:not(:focus) {
+  border-color: #cc4b37;
+  background-color: #f9ecea; }
+  .is-invalid-input:not(:focus)::-webkit-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus):-ms-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus)::-ms-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus)::placeholder {
+    color: #cc4b37; }
 
-.grid-padding-x > .cell {
-  padding-right: 0.625rem;
-  padding-left: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-x > .cell {
-      padding-right: 0.9375rem;
-      padding-left: 0.9375rem; } }
+.is-invalid-label {
+  color: #cc4b37; }
 
-.small-up-1 > .cell {
-  width: 100%; }
+.form-error {
+  display: none;
+  margin-top: -0.5rem;
+  margin-bottom: 1rem;
+  font-size: 0.75rem;
+  font-weight: bold;
+  color: #cc4b37; }
+  .form-error.is-visible {
+    display: block; }
 
-.small-up-2 > .cell {
-  width: 50%; }
+div,
+dl,
+dt,
+dd,
+ul,
+ol,
+li,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+pre,
+form,
+p,
+blockquote,
+th,
+td {
+  margin: 0;
+  padding: 0; }
 
-.small-up-3 > .cell {
-  width: 33.33333%; }
+p {
+  margin-bottom: 1rem;
+  font-size: inherit;
+  line-height: 1.6;
+  text-rendering: optimizeLegibility; }
 
-.small-up-4 > .cell {
-  width: 25%; }
+em,
+i {
+  font-style: italic;
+  line-height: inherit; }
 
-.small-up-5 > .cell {
-  width: 20%; }
+strong,
+b {
+  font-weight: bold;
+  line-height: inherit; }
 
-.small-up-6 > .cell {
-  width: 16.66667%; }
+small {
+  font-size: 80%;
+  line-height: inherit; }
 
-.small-up-7 > .cell {
-  width: 14.28571%; }
+h1, .h1,
+h2, .h2,
+h3, .h3,
+h4, .h4,
+h5, .h5,
+h6, .h6 {
+  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
+  font-style: normal;
+  font-weight: normal;
+  color: inherit;
+  text-rendering: optimizeLegibility; }
+  h1 small, .h1 small,
+  h2 small, .h2 small,
+  h3 small, .h3 small,
+  h4 small, .h4 small,
+  h5 small, .h5 small,
+  h6 small, .h6 small {
+    line-height: 0;
+    color: #cacaca; }
 
-.small-up-8 > .cell {
-  width: 12.5%; }
+h1, .h1 {
+  font-size: 1.5rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-up-1 > .cell {
-    width: 100%; }
-  .medium-up-2 > .cell {
-    width: 50%; }
-  .medium-up-3 > .cell {
-    width: 33.33333%; }
-  .medium-up-4 > .cell {
-    width: 25%; }
-  .medium-up-5 > .cell {
-    width: 20%; }
-  .medium-up-6 > .cell {
-    width: 16.66667%; }
-  .medium-up-7 > .cell {
-    width: 14.28571%; }
-  .medium-up-8 > .cell {
-    width: 12.5%; } }
+h2, .h2 {
+  font-size: 1.25rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-@media print, screen and (min-width: 64em) {
-  .large-up-1 > .cell {
-    width: 100%; }
-  .large-up-2 > .cell {
-    width: 50%; }
-  .large-up-3 > .cell {
-    width: 33.33333%; }
-  .large-up-4 > .cell {
-    width: 25%; }
-  .large-up-5 > .cell {
-    width: 20%; }
-  .large-up-6 > .cell {
-    width: 16.66667%; }
-  .large-up-7 > .cell {
-    width: 14.28571%; }
-  .large-up-8 > .cell {
-    width: 12.5%; } }
+h3, .h3 {
+  font-size: 1.1875rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-1 > .cell {
-  width: calc(100% - 1.25rem); }
+h4, .h4 {
+  font-size: 1.125rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-2 > .cell {
-  width: calc(50% - 1.25rem); }
+h5, .h5 {
+  font-size: 1.0625rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-3 > .cell {
-  width: calc(33.33333% - 1.25rem); }
+h6, .h6 {
+  font-size: 1rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-4 > .cell {
-  width: calc(25% - 1.25rem); }
+@media print, screen and (min-width: 40em) {
+  h1, .h1 {
+    font-size: 3rem; }
+  h2, .h2 {
+    font-size: 2.5rem; }
+  h3, .h3 {
+    font-size: 1.9375rem; }
+  h4, .h4 {
+    font-size: 1.5625rem; }
+  h5, .h5 {
+    font-size: 1.25rem; }
+  h6, .h6 {
+    font-size: 1rem; } }
 
-.grid-margin-x.small-up-5 > .cell {
-  width: calc(20% - 1.25rem); }
+a {
+  line-height: inherit;
+  color: #1779ba;
+  text-decoration: none;
+  cursor: pointer; }
+  a:hover, a:focus {
+    color: #1468a0; }
+  a img {
+    border: 0; }
 
-.grid-margin-x.small-up-6 > .cell {
-  width: calc(16.66667% - 1.25rem); }
+hr {
+  clear: both;
+  max-width: 75rem;
+  height: 0;
+  margin: 1.25rem auto;
+  border-top: 0;
+  border-right: 0;
+  border-bottom: 1px solid #cacaca;
+  border-left: 0; }
 
-.grid-margin-x.small-up-7 > .cell {
-  width: calc(14.28571% - 1.25rem); }
+ul,
+ol,
+dl {
+  margin-bottom: 1rem;
+  list-style-position: outside;
+  line-height: 1.6; }
 
-.grid-margin-x.small-up-8 > .cell {
-  width: calc(12.5% - 1.25rem); }
+li {
+  font-size: inherit; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-margin-x.small-up-1 > .cell {
-    width: calc(100% - 1.25rem); }
-  .grid-margin-x.small-up-2 > .cell {
-    width: calc(50% - 1.25rem); }
-  .grid-margin-x.small-up-3 > .cell {
-    width: calc(33.33333% - 1.25rem); }
-  .grid-margin-x.small-up-4 > .cell {
-    width: calc(25% - 1.25rem); }
-  .grid-margin-x.small-up-5 > .cell {
-    width: calc(20% - 1.25rem); }
-  .grid-margin-x.small-up-6 > .cell {
-    width: calc(16.66667% - 1.25rem); }
-  .grid-margin-x.small-up-7 > .cell {
-    width: calc(14.28571% - 1.25rem); }
-  .grid-margin-x.small-up-8 > .cell {
-    width: calc(12.5% - 1.25rem); }
-  .grid-margin-x.medium-up-1 > .cell {
-    width: calc(100% - 1.875rem); }
-  .grid-margin-x.medium-up-2 > .cell {
-    width: calc(50% - 1.875rem); }
-  .grid-margin-x.medium-up-3 > .cell {
-    width: calc(33.33333% - 1.875rem); }
-  .grid-margin-x.medium-up-4 > .cell {
-    width: calc(25% - 1.875rem); }
-  .grid-margin-x.medium-up-5 > .cell {
-    width: calc(20% - 1.875rem); }
-  .grid-margin-x.medium-up-6 > .cell {
-    width: calc(16.66667% - 1.875rem); }
-  .grid-margin-x.medium-up-7 > .cell {
-    width: calc(14.28571% - 1.875rem); }
-  .grid-margin-x.medium-up-8 > .cell {
-    width: calc(12.5% - 1.875rem); } }
+ul {
+  margin-left: 1.25rem;
+  list-style-type: disc; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-margin-x.large-up-1 > .cell {
-    width: calc(100% - 1.875rem); }
-  .grid-margin-x.large-up-2 > .cell {
-    width: calc(50% - 1.875rem); }
-  .grid-margin-x.large-up-3 > .cell {
-    width: calc(33.33333% - 1.875rem); }
-  .grid-margin-x.large-up-4 > .cell {
-    width: calc(25% - 1.875rem); }
-  .grid-margin-x.large-up-5 > .cell {
-    width: calc(20% - 1.875rem); }
-  .grid-margin-x.large-up-6 > .cell {
-    width: calc(16.66667% - 1.875rem); }
-  .grid-margin-x.large-up-7 > .cell {
-    width: calc(14.28571% - 1.875rem); }
-  .grid-margin-x.large-up-8 > .cell {
-    width: calc(12.5% - 1.875rem); } }
+ol {
+  margin-left: 1.25rem; }
 
-.small-margin-collapse {
-  margin-right: 0;
-  margin-left: 0; }
-  .small-margin-collapse > .cell {
-    margin-right: 0;
-    margin-left: 0; }
-  .small-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .small-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .small-margin-collapse > .small-3 {
-    width: 25%; }
-  .small-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .small-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .small-margin-collapse > .small-6 {
-    width: 50%; }
-  .small-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .small-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .small-margin-collapse > .small-9 {
-    width: 75%; }
-  .small-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .small-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .small-margin-collapse > .small-12 {
-    width: 100%; }
-  @media print, screen and (min-width: 40em) {
-    .small-margin-collapse > .medium-1 {
-      width: 8.33333%; }
-    .small-margin-collapse > .medium-2 {
-      width: 16.66667%; }
-    .small-margin-collapse > .medium-3 {
-      width: 25%; }
-    .small-margin-collapse > .medium-4 {
-      width: 33.33333%; }
-    .small-margin-collapse > .medium-5 {
-      width: 41.66667%; }
-    .small-margin-collapse > .medium-6 {
-      width: 50%; }
-    .small-margin-collapse > .medium-7 {
-      width: 58.33333%; }
-    .small-margin-collapse > .medium-8 {
-      width: 66.66667%; }
-    .small-margin-collapse > .medium-9 {
-      width: 75%; }
-    .small-margin-collapse > .medium-10 {
-      width: 83.33333%; }
-    .small-margin-collapse > .medium-11 {
-      width: 91.66667%; }
-    .small-margin-collapse > .medium-12 {
-      width: 100%; } }
-  @media print, screen and (min-width: 64em) {
-    .small-margin-collapse > .large-1 {
-      width: 8.33333%; }
-    .small-margin-collapse > .large-2 {
-      width: 16.66667%; }
-    .small-margin-collapse > .large-3 {
-      width: 25%; }
-    .small-margin-collapse > .large-4 {
-      width: 33.33333%; }
-    .small-margin-collapse > .large-5 {
-      width: 41.66667%; }
-    .small-margin-collapse > .large-6 {
-      width: 50%; }
-    .small-margin-collapse > .large-7 {
-      width: 58.33333%; }
-    .small-margin-collapse > .large-8 {
-      width: 66.66667%; }
-    .small-margin-collapse > .large-9 {
-      width: 75%; }
-    .small-margin-collapse > .large-10 {
-      width: 83.33333%; }
-    .small-margin-collapse > .large-11 {
-      width: 91.66667%; }
-    .small-margin-collapse > .large-12 {
-      width: 100%; } }
+ul ul, ol ul, ul ol, ol ol {
+  margin-left: 1.25rem;
+  margin-bottom: 0; }
 
-.small-padding-collapse {
-  margin-right: 0;
-  margin-left: 0; }
-  .small-padding-collapse > .cell {
-    padding-right: 0;
-    padding-left: 0; }
+dl {
+  margin-bottom: 1rem; }
+  dl dt {
+    margin-bottom: 0.3rem;
+    font-weight: bold; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .medium-margin-collapse > .cell {
-      margin-right: 0;
-      margin-left: 0; } }
-
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .small-3 {
-    width: 25%; }
-  .medium-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .small-6 {
-    width: 50%; }
-  .medium-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .small-9 {
-    width: 75%; }
-  .medium-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .small-12 {
-    width: 100%; } }
-
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse > .medium-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .medium-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .medium-3 {
-    width: 25%; }
-  .medium-margin-collapse > .medium-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .medium-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .medium-6 {
-    width: 50%; }
-  .medium-margin-collapse > .medium-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .medium-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .medium-9 {
-    width: 75%; }
-  .medium-margin-collapse > .medium-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .medium-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .medium-12 {
-    width: 100%; } }
-
-@media print, screen and (min-width: 64em) {
-  .medium-margin-collapse > .large-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .large-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .large-3 {
-    width: 25%; }
-  .medium-margin-collapse > .large-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .large-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .large-6 {
-    width: 50%; }
-  .medium-margin-collapse > .large-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .large-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .large-9 {
-    width: 75%; }
-  .medium-margin-collapse > .large-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .large-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .large-12 {
-    width: 100%; } }
+blockquote {
+  margin: 0 0 1rem;
+  padding: 0.5625rem 1.25rem 0 1.1875rem;
+  border-left: 1px solid #cacaca; }
+  blockquote, blockquote p {
+    line-height: 1.6;
+    color: #8a8a8a; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-padding-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .medium-padding-collapse > .cell {
-      padding-right: 0;
-      padding-left: 0; } }
+cite {
+  display: block;
+  font-size: 0.8125rem;
+  color: #8a8a8a; }
+  cite:before {
+    content: "— "; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .large-margin-collapse > .cell {
-      margin-right: 0;
-      margin-left: 0; } }
+abbr, abbr[title] {
+  border-bottom: 1px dotted #0a0a0a;
+  cursor: help;
+  text-decoration: none; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .small-3 {
-    width: 25%; }
-  .large-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .small-6 {
-    width: 50%; }
-  .large-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .small-9 {
-    width: 75%; }
-  .large-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .small-12 {
-    width: 100%; } }
+figure {
+  margin: 0; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .medium-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .medium-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .medium-3 {
-    width: 25%; }
-  .large-margin-collapse > .medium-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .medium-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .medium-6 {
-    width: 50%; }
-  .large-margin-collapse > .medium-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .medium-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .medium-9 {
-    width: 75%; }
-  .large-margin-collapse > .medium-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .medium-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .medium-12 {
-    width: 100%; } }
+code {
+  padding: 0.125rem 0.3125rem 0.0625rem;
+  border: 1px solid #cacaca;
+  background-color: #e6e6e6;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  font-weight: normal;
+  color: #0a0a0a; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .large-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .large-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .large-3 {
-    width: 25%; }
-  .large-margin-collapse > .large-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .large-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .large-6 {
-    width: 50%; }
-  .large-margin-collapse > .large-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .large-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .large-9 {
-    width: 75%; }
-  .large-margin-collapse > .large-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .large-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .large-12 {
-    width: 100%; } }
+kbd {
+  margin: 0;
+  padding: 0.125rem 0.25rem 0;
+  background-color: #e6e6e6;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  color: #0a0a0a; }
 
-@media print, screen and (min-width: 64em) {
-  .large-padding-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .large-padding-collapse > .cell {
-      padding-right: 0;
-      padding-left: 0; } }
+.subheader {
+  margin-top: 0.2rem;
+  margin-bottom: 0.5rem;
+  font-weight: normal;
+  line-height: 1.4;
+  color: #8a8a8a; }
 
-.small-offset-0 {
-  margin-left: 0%; }
+.lead {
+  font-size: 125%;
+  line-height: 1.6; }
 
-.grid-margin-x > .small-offset-0 {
-  margin-left: calc(0% + 0.625rem); }
+.stat {
+  font-size: 2.5rem;
+  line-height: 1; }
+  p + .stat {
+    margin-top: -1rem; }
 
-.small-offset-1 {
-  margin-left: 8.33333%; }
+ul.no-bullet, ol.no-bullet {
+  margin-left: 0;
+  list-style: none; }
 
-.grid-margin-x > .small-offset-1 {
-  margin-left: calc(8.33333% + 0.625rem); }
+.text-left {
+  text-align: left; }
 
-.small-offset-2 {
-  margin-left: 16.66667%; }
+.text-right {
+  text-align: right; }
 
-.grid-margin-x > .small-offset-2 {
-  margin-left: calc(16.66667% + 0.625rem); }
+.text-center {
+  text-align: center; }
 
-.small-offset-3 {
-  margin-left: 25%; }
+.text-justify {
+  text-align: justify; }
 
-.grid-margin-x > .small-offset-3 {
-  margin-left: calc(25% + 0.625rem); }
+@media print, screen and (min-width: 40em) {
+  .medium-text-left {
+    text-align: left; }
+  .medium-text-right {
+    text-align: right; }
+  .medium-text-center {
+    text-align: center; }
+  .medium-text-justify {
+    text-align: justify; } }
 
-.small-offset-4 {
-  margin-left: 33.33333%; }
+@media print, screen and (min-width: 64em) {
+  .large-text-left {
+    text-align: left; }
+  .large-text-right {
+    text-align: right; }
+  .large-text-center {
+    text-align: center; }
+  .large-text-justify {
+    text-align: justify; } }
 
-.grid-margin-x > .small-offset-4 {
-  margin-left: calc(33.33333% + 0.625rem); }
+.show-for-print {
+  display: none !important; }
 
-.small-offset-5 {
-  margin-left: 41.66667%; }
+@media print {
+  * {
+    background: transparent !important;
+    -webkit-box-shadow: none !important;
+            box-shadow: none !important;
+    color: black !important;
+    text-shadow: none !important; }
+  .show-for-print {
+    display: block !important; }
+  .hide-for-print {
+    display: none !important; }
+  table.show-for-print {
+    display: table !important; }
+  thead.show-for-print {
+    display: table-header-group !important; }
+  tbody.show-for-print {
+    display: table-row-group !important; }
+  tr.show-for-print {
+    display: table-row !important; }
+  td.show-for-print {
+    display: table-cell !important; }
+  th.show-for-print {
+    display: table-cell !important; }
+  a,
+  a:visited {
+    text-decoration: underline; }
+  a[href]:after {
+    content: " (" attr(href) ")"; }
+  .ir a:after,
+  a[href^='javascript:']:after,
+  a[href^='#']:after {
+    content: ''; }
+  abbr[title]:after {
+    content: " (" attr(title) ")"; }
+  pre,
+  blockquote {
+    border: 1px solid #8a8a8a;
+    page-break-inside: avoid; }
+  thead {
+    display: table-header-group; }
+  tr,
+  img {
+    page-break-inside: avoid; }
+  img {
+    max-width: 100% !important; }
+  @page {
+    margin: 0.5cm; }
+  p,
+  h2,
+  h3 {
+    orphans: 3;
+    widows: 3; }
+  h2,
+  h3 {
+    page-break-after: avoid; }
+  .print-break-inside {
+    page-break-inside: auto; } }
 
-.grid-margin-x > .small-offset-5 {
-  margin-left: calc(41.66667% + 0.625rem); }
+.grid-container {
+  padding-right: 0.625rem;
+  padding-left: 0.625rem;
+  max-width: 75rem;
+  margin-left: auto;
+  margin-right: auto; }
+  @media print, screen and (min-width: 40em) {
+    .grid-container {
+      padding-right: 0.9375rem;
+      padding-left: 0.9375rem; } }
+  .grid-container.fluid {
+    padding-right: 0.625rem;
+    padding-left: 0.625rem;
+    max-width: 100%;
+    margin-left: auto;
+    margin-right: auto; }
+    @media print, screen and (min-width: 40em) {
+      .grid-container.fluid {
+        padding-right: 0.9375rem;
+        padding-left: 0.9375rem; } }
+  .grid-container.full {
+    padding-right: 0;
+    padding-left: 0;
+    max-width: 100%;
+    margin-left: auto;
+    margin-right: auto; }
 
-.small-offset-6 {
-  margin-left: 50%; }
+.grid-x {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: horizontal;
+  -webkit-box-direction: normal;
+  -webkit-flex-flow: row wrap;
+      -ms-flex-flow: row wrap;
+          flex-flow: row wrap; }
 
-.grid-margin-x > .small-offset-6 {
-  margin-left: calc(50% + 0.625rem); }
+.cell {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto;
+  min-height: 0px;
+  min-width: 0px;
+  width: 100%; }
+  .cell.auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
+  .cell.shrink {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
 
-.small-offset-7 {
-  margin-left: 58.33333%; }
+.grid-x > .auto {
+  width: auto; }
 
-.grid-margin-x > .small-offset-7 {
-  margin-left: calc(58.33333% + 0.625rem); }
+.grid-x > .shrink {
+  width: auto; }
 
-.small-offset-8 {
-  margin-left: 66.66667%; }
+.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
+  -webkit-flex-basis: auto;
+      -ms-flex-preferred-size: auto;
+          flex-basis: auto; }
 
-.grid-margin-x > .small-offset-8 {
-  margin-left: calc(66.66667% + 0.625rem); }
+@media print, screen and (min-width: 40em) {
+  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; } }
 
-.small-offset-9 {
-  margin-left: 75%; }
+@media print, screen and (min-width: 64em) {
+  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; } }
 
-.grid-margin-x > .small-offset-9 {
-  margin-left: calc(75% + 0.625rem); }
+.grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto; }
 
-.small-offset-10 {
-  margin-left: 83.33333%; }
+.grid-x > .small-1 {
+  width: 8.33333%; }
 
-.grid-margin-x > .small-offset-10 {
-  margin-left: calc(83.33333% + 0.625rem); }
+.grid-x > .small-2 {
+  width: 16.66667%; }
 
-.small-offset-11 {
-  margin-left: 91.66667%; }
+.grid-x > .small-3 {
+  width: 25%; }
 
-.grid-margin-x > .small-offset-11 {
-  margin-left: calc(91.66667% + 0.625rem); }
+.grid-x > .small-4 {
+  width: 33.33333%; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-offset-0 {
-    margin-left: 0%; }
-  .grid-margin-x > .medium-offset-0 {
-    margin-left: calc(0% + 0.9375rem); }
-  .medium-offset-1 {
-    margin-left: 8.33333%; }
-  .grid-margin-x > .medium-offset-1 {
-    margin-left: calc(8.33333% + 0.9375rem); }
-  .medium-offset-2 {
-    margin-left: 16.66667%; }
-  .grid-margin-x > .medium-offset-2 {
-    margin-left: calc(16.66667% + 0.9375rem); }
-  .medium-offset-3 {
-    margin-left: 25%; }
-  .grid-margin-x > .medium-offset-3 {
-    margin-left: calc(25% + 0.9375rem); }
-  .medium-offset-4 {
-    margin-left: 33.33333%; }
-  .grid-margin-x > .medium-offset-4 {
-    margin-left: calc(33.33333% + 0.9375rem); }
-  .medium-offset-5 {
-    margin-left: 41.66667%; }
-  .grid-margin-x > .medium-offset-5 {
-    margin-left: calc(41.66667% + 0.9375rem); }
-  .medium-offset-6 {
-    margin-left: 50%; }
-  .grid-margin-x > .medium-offset-6 {
-    margin-left: calc(50% + 0.9375rem); }
-  .medium-offset-7 {
-    margin-left: 58.33333%; }
-  .grid-margin-x > .medium-offset-7 {
-    margin-left: calc(58.33333% + 0.9375rem); }
-  .medium-offset-8 {
-    margin-left: 66.66667%; }
-  .grid-margin-x > .medium-offset-8 {
-    margin-left: calc(66.66667% + 0.9375rem); }
-  .medium-offset-9 {
-    margin-left: 75%; }
-  .grid-margin-x > .medium-offset-9 {
-    margin-left: calc(75% + 0.9375rem); }
-  .medium-offset-10 {
-    margin-left: 83.33333%; }
-  .grid-margin-x > .medium-offset-10 {
-    margin-left: calc(83.33333% + 0.9375rem); }
-  .medium-offset-11 {
-    margin-left: 91.66667%; }
-  .grid-margin-x > .medium-offset-11 {
-    margin-left: calc(91.66667% + 0.9375rem); } }
+.grid-x > .small-5 {
+  width: 41.66667%; }
 
-@media print, screen and (min-width: 64em) {
-  .large-offset-0 {
-    margin-left: 0%; }
-  .grid-margin-x > .large-offset-0 {
-    margin-left: calc(0% + 0.9375rem); }
-  .large-offset-1 {
-    margin-left: 8.33333%; }
-  .grid-margin-x > .large-offset-1 {
-    margin-left: calc(8.33333% + 0.9375rem); }
-  .large-offset-2 {
-    margin-left: 16.66667%; }
-  .grid-margin-x > .large-offset-2 {
-    margin-left: calc(16.66667% + 0.9375rem); }
-  .large-offset-3 {
-    margin-left: 25%; }
-  .grid-margin-x > .large-offset-3 {
-    margin-left: calc(25% + 0.9375rem); }
-  .large-offset-4 {
-    margin-left: 33.33333%; }
-  .grid-margin-x > .large-offset-4 {
-    margin-left: calc(33.33333% + 0.9375rem); }
-  .large-offset-5 {
-    margin-left: 41.66667%; }
-  .grid-margin-x > .large-offset-5 {
-    margin-left: calc(41.66667% + 0.9375rem); }
-  .large-offset-6 {
-    margin-left: 50%; }
-  .grid-margin-x > .large-offset-6 {
-    margin-left: calc(50% + 0.9375rem); }
-  .large-offset-7 {
-    margin-left: 58.33333%; }
-  .grid-margin-x > .large-offset-7 {
-    margin-left: calc(58.33333% + 0.9375rem); }
-  .large-offset-8 {
-    margin-left: 66.66667%; }
-  .grid-margin-x > .large-offset-8 {
-    margin-left: calc(66.66667% + 0.9375rem); }
-  .large-offset-9 {
-    margin-left: 75%; }
-  .grid-margin-x > .large-offset-9 {
-    margin-left: calc(75% + 0.9375rem); }
-  .large-offset-10 {
-    margin-left: 83.33333%; }
-  .grid-margin-x > .large-offset-10 {
-    margin-left: calc(83.33333% + 0.9375rem); }
-  .large-offset-11 {
-    margin-left: 91.66667%; }
-  .grid-margin-x > .large-offset-11 {
-    margin-left: calc(91.66667% + 0.9375rem); } }
+.grid-x > .small-6 {
+  width: 50%; }
 
-.grid-y {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-orient: vertical;
-  -webkit-box-direction: normal;
-  -webkit-flex-flow: column nowrap;
-      -ms-flex-flow: column nowrap;
-          flex-flow: column nowrap; }
-  .grid-y > .cell {
+.grid-x > .small-7 {
+  width: 58.33333%; }
+
+.grid-x > .small-8 {
+  width: 66.66667%; }
+
+.grid-x > .small-9 {
+  width: 75%; }
+
+.grid-x > .small-10 {
+  width: 83.33333%; }
+
+.grid-x > .small-11 {
+  width: 91.66667%; }
+
+.grid-x > .small-12 {
+  width: 100%; }
+
+@media print, screen and (min-width: 40em) {
+  .grid-x > .medium-auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px;
     width: auto; }
-  .grid-y > .auto {
-    height: auto; }
-  .grid-y > .shrink {
-    height: auto; }
-  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; }
-  @media print, screen and (min-width: 40em) {
-    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
-      -webkit-flex-basis: auto;
-          -ms-flex-preferred-size: auto;
-              flex-basis: auto; } }
-  @media print, screen and (min-width: 64em) {
-    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
-      -webkit-flex-basis: auto;
-          -ms-flex-preferred-size: auto;
-              flex-basis: auto; } }
-  .grid-y > .small-1 {
-    height: 8.33333%; }
-  .grid-y > .small-2 {
-    height: 16.66667%; }
-  .grid-y > .small-3 {
-    height: 25%; }
-  .grid-y > .small-4 {
-    height: 33.33333%; }
-  .grid-y > .small-5 {
-    height: 41.66667%; }
-  .grid-y > .small-6 {
-    height: 50%; }
-  .grid-y > .small-7 {
-    height: 58.33333%; }
-  .grid-y > .small-8 {
-    height: 66.66667%; }
-  .grid-y > .small-9 {
-    height: 75%; }
-  .grid-y > .small-10 {
-    height: 83.33333%; }
-  .grid-y > .small-11 {
-    height: 91.66667%; }
-  .grid-y > .small-12 {
-    height: 100%; }
-  @media print, screen and (min-width: 40em) {
-    .grid-y > .medium-auto {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      height: auto; }
-    .grid-y > .medium-shrink {
-      height: auto; }
-    .grid-y > .medium-1 {
-      height: 8.33333%; }
-    .grid-y > .medium-2 {
-      height: 16.66667%; }
-    .grid-y > .medium-3 {
-      height: 25%; }
-    .grid-y > .medium-4 {
-      height: 33.33333%; }
-    .grid-y > .medium-5 {
-      height: 41.66667%; }
-    .grid-y > .medium-6 {
-      height: 50%; }
-    .grid-y > .medium-7 {
-      height: 58.33333%; }
-    .grid-y > .medium-8 {
-      height: 66.66667%; }
-    .grid-y > .medium-9 {
-      height: 75%; }
-    .grid-y > .medium-10 {
-      height: 83.33333%; }
-    .grid-y > .medium-11 {
-      height: 91.66667%; }
-    .grid-y > .medium-12 {
-      height: 100%; } }
-  @media print, screen and (min-width: 64em) {
-    .grid-y > .large-auto {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      height: auto; }
-    .grid-y > .large-shrink {
-      height: auto; }
-    .grid-y > .large-1 {
-      height: 8.33333%; }
-    .grid-y > .large-2 {
-      height: 16.66667%; }
-    .grid-y > .large-3 {
-      height: 25%; }
-    .grid-y > .large-4 {
-      height: 33.33333%; }
-    .grid-y > .large-5 {
-      height: 41.66667%; }
-    .grid-y > .large-6 {
-      height: 50%; }
-    .grid-y > .large-7 {
-      height: 58.33333%; }
-    .grid-y > .large-8 {
-      height: 66.66667%; }
-    .grid-y > .large-9 {
-      height: 75%; }
-    .grid-y > .large-10 {
-      height: 83.33333%; }
-    .grid-y > .large-11 {
-      height: 91.66667%; }
-    .grid-y > .large-12 {
-      height: 100%; } }
+  .grid-x > .medium-shrink, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-x > .medium-shrink {
+    width: auto; }
+  .grid-x > .medium-1 {
+    width: 8.33333%; }
+  .grid-x > .medium-2 {
+    width: 16.66667%; }
+  .grid-x > .medium-3 {
+    width: 25%; }
+  .grid-x > .medium-4 {
+    width: 33.33333%; }
+  .grid-x > .medium-5 {
+    width: 41.66667%; }
+  .grid-x > .medium-6 {
+    width: 50%; }
+  .grid-x > .medium-7 {
+    width: 58.33333%; }
+  .grid-x > .medium-8 {
+    width: 66.66667%; }
+  .grid-x > .medium-9 {
+    width: 75%; }
+  .grid-x > .medium-10 {
+    width: 83.33333%; }
+  .grid-x > .medium-11 {
+    width: 91.66667%; }
+  .grid-x > .medium-12 {
+    width: 100%; } }
 
-.grid-padding-y .grid-padding-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-y .grid-padding-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
+@media print, screen and (min-width: 64em) {
+  .grid-x > .large-auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px;
+    width: auto; }
+  .grid-x > .large-shrink, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-x > .large-shrink {
+    width: auto; }
+  .grid-x > .large-1 {
+    width: 8.33333%; }
+  .grid-x > .large-2 {
+    width: 16.66667%; }
+  .grid-x > .large-3 {
+    width: 25%; }
+  .grid-x > .large-4 {
+    width: 33.33333%; }
+  .grid-x > .large-5 {
+    width: 41.66667%; }
+  .grid-x > .large-6 {
+    width: 50%; }
+  .grid-x > .large-7 {
+    width: 58.33333%; }
+  .grid-x > .large-8 {
+    width: 66.66667%; }
+  .grid-x > .large-9 {
+    width: 75%; }
+  .grid-x > .large-10 {
+    width: 83.33333%; }
+  .grid-x > .large-11 {
+    width: 91.66667%; }
+  .grid-x > .large-12 {
+    width: 100%; } }
 
-.grid-padding-y > .cell {
-  padding-top: 0.625rem;
-  padding-bottom: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-y > .cell {
-      padding-top: 0.9375rem;
-      padding-bottom: 0.9375rem; } }
+.grid-margin-x:not(.grid-x) > .cell {
+  width: auto; }
 
-.grid-margin-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
-  .grid-margin-y > .cell {
-    height: calc(100% - 1.25rem);
-    margin-top: 0.625rem;
-    margin-bottom: 0.625rem; }
+.grid-margin-y:not(.grid-y) > .cell {
+  height: auto; }
+
+.grid-margin-x {
+  margin-left: -0.625rem;
+  margin-right: -0.625rem; }
   @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .cell {
-      height: calc(100% - 1.875rem);
-      margin-top: 0.9375rem;
-      margin-bottom: 0.9375rem; } }
-  .grid-margin-y > .auto {
-    height: auto; }
-  .grid-margin-y > .shrink {
-    height: auto; }
-  .grid-margin-y > .small-1 {
-    height: calc(8.33333% - 1.25rem); }
-  .grid-margin-y > .small-2 {
-    height: calc(16.66667% - 1.25rem); }
-  .grid-margin-y > .small-3 {
-    height: calc(25% - 1.25rem); }
-  .grid-margin-y > .small-4 {
-    height: calc(33.33333% - 1.25rem); }
-  .grid-margin-y > .small-5 {
-    height: calc(41.66667% - 1.25rem); }
-  .grid-margin-y > .small-6 {
-    height: calc(50% - 1.25rem); }
-  .grid-margin-y > .small-7 {
-    height: calc(58.33333% - 1.25rem); }
-  .grid-margin-y > .small-8 {
-    height: calc(66.66667% - 1.25rem); }
-  .grid-margin-y > .small-9 {
-    height: calc(75% - 1.25rem); }
-  .grid-margin-y > .small-10 {
-    height: calc(83.33333% - 1.25rem); }
-  .grid-margin-y > .small-11 {
-    height: calc(91.66667% - 1.25rem); }
-  .grid-margin-y > .small-12 {
-    height: calc(100% - 1.25rem); }
+    .grid-margin-x {
+      margin-left: -0.9375rem;
+      margin-right: -0.9375rem; } }
+  .grid-margin-x > .cell {
+    width: calc(100% - 1.25rem);
+    margin-left: 0.625rem;
+    margin-right: 0.625rem; }
   @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .auto {
-      height: auto; }
-    .grid-margin-y > .shrink {
-      height: auto; }
-    .grid-margin-y > .small-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .small-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .small-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .small-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .small-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .small-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .small-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .small-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .small-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .small-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .small-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .small-12 {
-      height: calc(100% - 1.875rem); }
-    .grid-margin-y > .medium-auto {
-      height: auto; }
-    .grid-margin-y > .medium-shrink {
-      height: auto; }
-    .grid-margin-y > .medium-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .medium-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .medium-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .medium-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .medium-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .medium-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .medium-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .medium-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .medium-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .medium-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .medium-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .medium-12 {
-      height: calc(100% - 1.875rem); } }
+    .grid-margin-x > .cell {
+      width: calc(100% - 1.875rem);
+      margin-left: 0.9375rem;
+      margin-right: 0.9375rem; } }
+  .grid-margin-x > .auto {
+    width: auto; }
+  .grid-margin-x > .shrink {
+    width: auto; }
+  .grid-margin-x > .small-1 {
+    width: calc(8.33333% - 1.25rem); }
+  .grid-margin-x > .small-2 {
+    width: calc(16.66667% - 1.25rem); }
+  .grid-margin-x > .small-3 {
+    width: calc(25% - 1.25rem); }
+  .grid-margin-x > .small-4 {
+    width: calc(33.33333% - 1.25rem); }
+  .grid-margin-x > .small-5 {
+    width: calc(41.66667% - 1.25rem); }
+  .grid-margin-x > .small-6 {
+    width: calc(50% - 1.25rem); }
+  .grid-margin-x > .small-7 {
+    width: calc(58.33333% - 1.25rem); }
+  .grid-margin-x > .small-8 {
+    width: calc(66.66667% - 1.25rem); }
+  .grid-margin-x > .small-9 {
+    width: calc(75% - 1.25rem); }
+  .grid-margin-x > .small-10 {
+    width: calc(83.33333% - 1.25rem); }
+  .grid-margin-x > .small-11 {
+    width: calc(91.66667% - 1.25rem); }
+  .grid-margin-x > .small-12 {
+    width: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-x > .auto {
+      width: auto; }
+    .grid-margin-x > .shrink {
+      width: auto; }
+    .grid-margin-x > .small-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .small-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .small-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .small-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .small-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .small-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .small-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .small-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .small-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .small-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .small-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .small-12 {
+      width: calc(100% - 1.875rem); }
+    .grid-margin-x > .medium-auto {
+      width: auto; }
+    .grid-margin-x > .medium-shrink {
+      width: auto; }
+    .grid-margin-x > .medium-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .medium-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .medium-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .medium-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .medium-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .medium-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .medium-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .medium-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .medium-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .medium-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .medium-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .medium-12 {
+      width: calc(100% - 1.875rem); } }
   @media print, screen and (min-width: 64em) {
-    .grid-margin-y > .large-auto {
-      height: auto; }
-    .grid-margin-y > .large-shrink {
-      height: auto; }
-    .grid-margin-y > .large-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .large-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .large-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .large-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .large-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .large-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .large-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .large-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .large-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .large-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .large-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .large-12 {
-      height: calc(100% - 1.875rem); } }
-
-.grid-frame {
-  overflow: hidden;
-  position: relative;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch;
-  width: 100vw; }
-
-.cell .grid-frame {
-  width: 100%; }
-
-.cell-block {
-  overflow-x: auto;
-  max-width: 100%;
-  -webkit-overflow-scrolling: touch;
-  -ms-overflow-stype: -ms-autohiding-scrollbar; }
-
-.cell-block-y {
-  overflow-y: auto;
-  max-height: 100%;
-  -webkit-overflow-scrolling: touch;
-  -ms-overflow-stype: -ms-autohiding-scrollbar; }
+    .grid-margin-x > .large-auto {
+      width: auto; }
+    .grid-margin-x > .large-shrink {
+      width: auto; }
+    .grid-margin-x > .large-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .large-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .large-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .large-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .large-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .large-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .large-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .large-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .large-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .large-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .large-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .large-12 {
+      width: calc(100% - 1.875rem); } }
 
-.cell-block-container {
-  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;
-  max-height: 100%; }
-  .cell-block-container > .grid-x {
-    max-height: 100%;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap; }
+.grid-padding-x .grid-padding-x {
+  margin-right: -0.625rem;
+  margin-left: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-x .grid-padding-x {
+      margin-right: -0.9375rem;
+      margin-left: -0.9375rem; } }
 
-@media print, screen and (min-width: 40em) {
-  .medium-grid-frame {
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    width: 100vw; }
-  .cell .medium-grid-frame {
-    width: 100%; }
-  .medium-cell-block {
-    overflow-x: auto;
-    max-width: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; }
-  .medium-cell-block-container {
-    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;
-    max-height: 100%; }
-    .medium-cell-block-container > .grid-x {
-      max-height: 100%;
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap; }
-  .medium-cell-block-y {
-    overflow-y: auto;
-    max-height: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; } }
+.grid-container:not(.full) > .grid-padding-x {
+  margin-right: -0.625rem;
+  margin-left: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-container:not(.full) > .grid-padding-x {
+      margin-right: -0.9375rem;
+      margin-left: -0.9375rem; } }
 
-@media print, screen and (min-width: 64em) {
-  .large-grid-frame {
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    width: 100vw; }
-  .cell .large-grid-frame {
-    width: 100%; }
-  .large-cell-block {
-    overflow-x: auto;
-    max-width: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; }
-  .large-cell-block-container {
-    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;
-    max-height: 100%; }
-    .large-cell-block-container > .grid-x {
-      max-height: 100%;
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap; }
-  .large-cell-block-y {
-    overflow-y: auto;
-    max-height: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; } }
+.grid-padding-x > .cell {
+  padding-right: 0.625rem;
+  padding-left: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-x > .cell {
+      padding-right: 0.9375rem;
+      padding-left: 0.9375rem; } }
 
-.grid-y.grid-frame {
-  width: auto;
-  overflow: hidden;
-  position: relative;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch;
-  height: 100vh; }
+.small-up-1 > .cell {
+  width: 100%; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-y.medium-grid-frame {
-    width: auto;
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    height: 100vh; } }
+.small-up-2 > .cell {
+  width: 50%; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-y.large-grid-frame {
-    width: auto;
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    height: 100vh; } }
+.small-up-3 > .cell {
+  width: 33.33333%; }
 
-.cell .grid-y.grid-frame {
-  height: 100%; }
+.small-up-4 > .cell {
+  width: 25%; }
 
-@media print, screen and (min-width: 40em) {
-  .cell .grid-y.medium-grid-frame {
-    height: 100%; } }
+.small-up-5 > .cell {
+  width: 20%; }
 
-@media print, screen and (min-width: 64em) {
-  .cell .grid-y.large-grid-frame {
-    height: 100%; } }
+.small-up-6 > .cell {
+  width: 16.66667%; }
 
-.grid-margin-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
-  .grid-margin-y > .cell {
-    height: calc(100% - 1.25rem);
-    margin-top: 0.625rem;
-    margin-bottom: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .cell {
-      height: calc(100% - 1.875rem);
-      margin-top: 0.9375rem;
-      margin-bottom: 0.9375rem; } }
-  .grid-margin-y > .auto {
-    height: auto; }
-  .grid-margin-y > .shrink {
-    height: auto; }
-  .grid-margin-y > .small-1 {
-    height: calc(8.33333% - 1.25rem); }
-  .grid-margin-y > .small-2 {
-    height: calc(16.66667% - 1.25rem); }
-  .grid-margin-y > .small-3 {
-    height: calc(25% - 1.25rem); }
-  .grid-margin-y > .small-4 {
-    height: calc(33.33333% - 1.25rem); }
-  .grid-margin-y > .small-5 {
-    height: calc(41.66667% - 1.25rem); }
-  .grid-margin-y > .small-6 {
-    height: calc(50% - 1.25rem); }
-  .grid-margin-y > .small-7 {
-    height: calc(58.33333% - 1.25rem); }
-  .grid-margin-y > .small-8 {
-    height: calc(66.66667% - 1.25rem); }
-  .grid-margin-y > .small-9 {
-    height: calc(75% - 1.25rem); }
-  .grid-margin-y > .small-10 {
-    height: calc(83.33333% - 1.25rem); }
-  .grid-margin-y > .small-11 {
-    height: calc(91.66667% - 1.25rem); }
-  .grid-margin-y > .small-12 {
-    height: calc(100% - 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .auto {
-      height: auto; }
-    .grid-margin-y > .shrink {
-      height: auto; }
-    .grid-margin-y > .small-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .small-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .small-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .small-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .small-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .small-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .small-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .small-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .small-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .small-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .small-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .small-12 {
-      height: calc(100% - 1.875rem); }
-    .grid-margin-y > .medium-auto {
-      height: auto; }
-    .grid-margin-y > .medium-shrink {
-      height: auto; }
-    .grid-margin-y > .medium-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .medium-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .medium-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .medium-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .medium-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .medium-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .medium-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .medium-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .medium-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .medium-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .medium-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .medium-12 {
-      height: calc(100% - 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-margin-y > .large-auto {
-      height: auto; }
-    .grid-margin-y > .large-shrink {
-      height: auto; }
-    .grid-margin-y > .large-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .large-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .large-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .large-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .large-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .large-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .large-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .large-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .large-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .large-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .large-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .large-12 {
-      height: calc(100% - 1.875rem); } }
+.small-up-7 > .cell {
+  width: 14.28571%; }
 
-.grid-frame.grid-margin-y {
-  height: calc(100vh + 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-frame.grid-margin-y {
-      height: calc(100vh + 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-frame.grid-margin-y {
-      height: calc(100vh + 1.875rem); } }
+.small-up-8 > .cell {
+  width: 12.5%; }
 
 @media print, screen and (min-width: 40em) {
-  .grid-margin-y.medium-grid-frame {
-    height: calc(100vh + 1.875rem); } }
+  .medium-up-1 > .cell {
+    width: 100%; }
+  .medium-up-2 > .cell {
+    width: 50%; }
+  .medium-up-3 > .cell {
+    width: 33.33333%; }
+  .medium-up-4 > .cell {
+    width: 25%; }
+  .medium-up-5 > .cell {
+    width: 20%; }
+  .medium-up-6 > .cell {
+    width: 16.66667%; }
+  .medium-up-7 > .cell {
+    width: 14.28571%; }
+  .medium-up-8 > .cell {
+    width: 12.5%; } }
 
 @media print, screen and (min-width: 64em) {
-  .grid-margin-y.large-grid-frame {
-    height: calc(100vh + 1.875rem); } }
+  .large-up-1 > .cell {
+    width: 100%; }
+  .large-up-2 > .cell {
+    width: 50%; }
+  .large-up-3 > .cell {
+    width: 33.33333%; }
+  .large-up-4 > .cell {
+    width: 25%; }
+  .large-up-5 > .cell {
+    width: 20%; }
+  .large-up-6 > .cell {
+    width: 16.66667%; }
+  .large-up-7 > .cell {
+    width: 14.28571%; }
+  .large-up-8 > .cell {
+    width: 12.5%; } }
 
-div,
-dl,
-dt,
-dd,
-ul,
-ol,
-li,
-h1,
-h2,
-h3,
-h4,
-h5,
-h6,
-pre,
-form,
-p,
-blockquote,
-th,
-td {
-  margin: 0;
-  padding: 0; }
+.grid-margin-x.small-up-1 > .cell {
+  width: calc(100% - 1.25rem); }
 
-p {
-  margin-bottom: 1rem;
-  font-size: inherit;
-  line-height: 1.6;
-  text-rendering: optimizeLegibility; }
+.grid-margin-x.small-up-2 > .cell {
+  width: calc(50% - 1.25rem); }
 
-em,
-i {
-  font-style: italic;
-  line-height: inherit; }
+.grid-margin-x.small-up-3 > .cell {
+  width: calc(33.33333% - 1.25rem); }
 
-strong,
-b {
-  font-weight: bold;
-  line-height: inherit; }
+.grid-margin-x.small-up-4 > .cell {
+  width: calc(25% - 1.25rem); }
 
-small {
-  font-size: 80%;
-  line-height: inherit; }
+.grid-margin-x.small-up-5 > .cell {
+  width: calc(20% - 1.25rem); }
 
-h1, .h1,
-h2, .h2,
-h3, .h3,
-h4, .h4,
-h5, .h5,
-h6, .h6 {
-  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
-  font-style: normal;
-  font-weight: normal;
-  color: inherit;
-  text-rendering: optimizeLegibility; }
-  h1 small, .h1 small,
-  h2 small, .h2 small,
-  h3 small, .h3 small,
-  h4 small, .h4 small,
-  h5 small, .h5 small,
-  h6 small, .h6 small {
-    line-height: 0;
-    color: #cacaca; }
+.grid-margin-x.small-up-6 > .cell {
+  width: calc(16.66667% - 1.25rem); }
 
-h1, .h1 {
-  font-size: 1.5rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.grid-margin-x.small-up-7 > .cell {
+  width: calc(14.28571% - 1.25rem); }
 
-h2, .h2 {
-  font-size: 1.25rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.grid-margin-x.small-up-8 > .cell {
+  width: calc(12.5% - 1.25rem); }
 
-h3, .h3 {
-  font-size: 1.1875rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+@media print, screen and (min-width: 40em) {
+  .grid-margin-x.small-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.small-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.small-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.small-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.small-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.small-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.small-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.small-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); }
+  .grid-margin-x.medium-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.medium-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.medium-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.medium-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.medium-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.medium-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.medium-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.medium-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); } }
 
-h4, .h4 {
-  font-size: 1.125rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+@media print, screen and (min-width: 64em) {
+  .grid-margin-x.large-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.large-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.large-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.large-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.large-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.large-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.large-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.large-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); } }
 
-h5, .h5 {
-  font-size: 1.0625rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-margin-collapse {
+  margin-right: 0;
+  margin-left: 0; }
+  .small-margin-collapse > .cell {
+    margin-right: 0;
+    margin-left: 0; }
+  .small-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .small-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .small-margin-collapse > .small-3 {
+    width: 25%; }
+  .small-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .small-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .small-margin-collapse > .small-6 {
+    width: 50%; }
+  .small-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .small-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .small-margin-collapse > .small-9 {
+    width: 75%; }
+  .small-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .small-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .small-margin-collapse > .small-12 {
+    width: 100%; }
+  @media print, screen and (min-width: 40em) {
+    .small-margin-collapse > .medium-1 {
+      width: 8.33333%; }
+    .small-margin-collapse > .medium-2 {
+      width: 16.66667%; }
+    .small-margin-collapse > .medium-3 {
+      width: 25%; }
+    .small-margin-collapse > .medium-4 {
+      width: 33.33333%; }
+    .small-margin-collapse > .medium-5 {
+      width: 41.66667%; }
+    .small-margin-collapse > .medium-6 {
+      width: 50%; }
+    .small-margin-collapse > .medium-7 {
+      width: 58.33333%; }
+    .small-margin-collapse > .medium-8 {
+      width: 66.66667%; }
+    .small-margin-collapse > .medium-9 {
+      width: 75%; }
+    .small-margin-collapse > .medium-10 {
+      width: 83.33333%; }
+    .small-margin-collapse > .medium-11 {
+      width: 91.66667%; }
+    .small-margin-collapse > .medium-12 {
+      width: 100%; } }
+  @media print, screen and (min-width: 64em) {
+    .small-margin-collapse > .large-1 {
+      width: 8.33333%; }
+    .small-margin-collapse > .large-2 {
+      width: 16.66667%; }
+    .small-margin-collapse > .large-3 {
+      width: 25%; }
+    .small-margin-collapse > .large-4 {
+      width: 33.33333%; }
+    .small-margin-collapse > .large-5 {
+      width: 41.66667%; }
+    .small-margin-collapse > .large-6 {
+      width: 50%; }
+    .small-margin-collapse > .large-7 {
+      width: 58.33333%; }
+    .small-margin-collapse > .large-8 {
+      width: 66.66667%; }
+    .small-margin-collapse > .large-9 {
+      width: 75%; }
+    .small-margin-collapse > .large-10 {
+      width: 83.33333%; }
+    .small-margin-collapse > .large-11 {
+      width: 91.66667%; }
+    .small-margin-collapse > .large-12 {
+      width: 100%; } }
 
-h6, .h6 {
-  font-size: 1rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-padding-collapse {
+  margin-right: 0;
+  margin-left: 0; }
+  .small-padding-collapse > .cell {
+    padding-right: 0;
+    padding-left: 0; }
 
 @media print, screen and (min-width: 40em) {
-  h1, .h1 {
-    font-size: 3rem; }
-  h2, .h2 {
-    font-size: 2.5rem; }
-  h3, .h3 {
-    font-size: 1.9375rem; }
-  h4, .h4 {
-    font-size: 1.5625rem; }
-  h5, .h5 {
-    font-size: 1.25rem; }
-  h6, .h6 {
-    font-size: 1rem; } }
+  .medium-margin-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .medium-margin-collapse > .cell {
+      margin-right: 0;
+      margin-left: 0; } }
 
-a {
-  line-height: inherit;
-  color: #1779ba;
-  text-decoration: none;
-  cursor: pointer; }
-  a:hover, a:focus {
-    color: #1468a0; }
-  a img {
-    border: 0; }
+@media print, screen and (min-width: 40em) {
+  .medium-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .small-3 {
+    width: 25%; }
+  .medium-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .small-6 {
+    width: 50%; }
+  .medium-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .small-9 {
+    width: 75%; }
+  .medium-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .small-12 {
+    width: 100%; } }
 
-hr {
-  clear: both;
-  max-width: 75rem;
-  height: 0;
-  margin: 1.25rem auto;
-  border-top: 0;
-  border-right: 0;
-  border-bottom: 1px solid #cacaca;
-  border-left: 0; }
+@media print, screen and (min-width: 40em) {
+  .medium-margin-collapse > .medium-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .medium-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .medium-3 {
+    width: 25%; }
+  .medium-margin-collapse > .medium-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .medium-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .medium-6 {
+    width: 50%; }
+  .medium-margin-collapse > .medium-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .medium-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .medium-9 {
+    width: 75%; }
+  .medium-margin-collapse > .medium-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .medium-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .medium-12 {
+    width: 100%; } }
 
-ul,
-ol,
-dl {
-  margin-bottom: 1rem;
-  list-style-position: outside;
-  line-height: 1.6; }
+@media print, screen and (min-width: 64em) {
+  .medium-margin-collapse > .large-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .large-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .large-3 {
+    width: 25%; }
+  .medium-margin-collapse > .large-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .large-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .large-6 {
+    width: 50%; }
+  .medium-margin-collapse > .large-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .large-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .large-9 {
+    width: 75%; }
+  .medium-margin-collapse > .large-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .large-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .large-12 {
+    width: 100%; } }
 
-li {
-  font-size: inherit; }
+@media print, screen and (min-width: 40em) {
+  .medium-padding-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .medium-padding-collapse > .cell {
+      padding-right: 0;
+      padding-left: 0; } }
 
-ul {
-  margin-left: 1.25rem;
-  list-style-type: disc; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .large-margin-collapse > .cell {
+      margin-right: 0;
+      margin-left: 0; } }
 
-ol {
-  margin-left: 1.25rem; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .small-3 {
+    width: 25%; }
+  .large-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .small-6 {
+    width: 50%; }
+  .large-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .small-9 {
+    width: 75%; }
+  .large-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .small-12 {
+    width: 100%; } }
 
-ul ul, ol ul, ul ol, ol ol {
-  margin-left: 1.25rem;
-  margin-bottom: 0; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .medium-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .medium-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .medium-3 {
+    width: 25%; }
+  .large-margin-collapse > .medium-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .medium-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .medium-6 {
+    width: 50%; }
+  .large-margin-collapse > .medium-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .medium-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .medium-9 {
+    width: 75%; }
+  .large-margin-collapse > .medium-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .medium-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .medium-12 {
+    width: 100%; } }
 
-dl {
-  margin-bottom: 1rem; }
-  dl dt {
-    margin-bottom: 0.3rem;
-    font-weight: bold; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .large-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .large-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .large-3 {
+    width: 25%; }
+  .large-margin-collapse > .large-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .large-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .large-6 {
+    width: 50%; }
+  .large-margin-collapse > .large-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .large-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .large-9 {
+    width: 75%; }
+  .large-margin-collapse > .large-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .large-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .large-12 {
+    width: 100%; } }
 
-blockquote {
-  margin: 0 0 1rem;
-  padding: 0.5625rem 1.25rem 0 1.1875rem;
-  border-left: 1px solid #cacaca; }
-  blockquote, blockquote p {
-    line-height: 1.6;
-    color: #8a8a8a; }
+@media print, screen and (min-width: 64em) {
+  .large-padding-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .large-padding-collapse > .cell {
+      padding-right: 0;
+      padding-left: 0; } }
 
-cite {
-  display: block;
-  font-size: 0.8125rem;
-  color: #8a8a8a; }
-  cite:before {
-    content: "— "; }
+.small-offset-0 {
+  margin-left: 0%; }
+
+.grid-margin-x > .small-offset-0 {
+  margin-left: calc(0% + 0.625rem); }
 
-abbr, abbr[title] {
-  border-bottom: 1px dotted #0a0a0a;
-  cursor: help;
-  text-decoration: none; }
+.small-offset-1 {
+  margin-left: 8.33333%; }
 
-figure {
-  margin: 0; }
+.grid-margin-x > .small-offset-1 {
+  margin-left: calc(8.33333% + 0.625rem); }
 
-code {
-  padding: 0.125rem 0.3125rem 0.0625rem;
-  border: 1px solid #cacaca;
-  background-color: #e6e6e6;
-  font-family: Consolas, "Liberation Mono", Courier, monospace;
-  font-weight: normal;
-  color: #0a0a0a; }
+.small-offset-2 {
+  margin-left: 16.66667%; }
 
-kbd {
-  margin: 0;
-  padding: 0.125rem 0.25rem 0;
-  background-color: #e6e6e6;
-  font-family: Consolas, "Liberation Mono", Courier, monospace;
-  color: #0a0a0a; }
+.grid-margin-x > .small-offset-2 {
+  margin-left: calc(16.66667% + 0.625rem); }
 
-.subheader {
-  margin-top: 0.2rem;
-  margin-bottom: 0.5rem;
-  font-weight: normal;
-  line-height: 1.4;
-  color: #8a8a8a; }
+.small-offset-3 {
+  margin-left: 25%; }
 
-.lead {
-  font-size: 125%;
-  line-height: 1.6; }
+.grid-margin-x > .small-offset-3 {
+  margin-left: calc(25% + 0.625rem); }
 
-.stat {
-  font-size: 2.5rem;
-  line-height: 1; }
-  p + .stat {
-    margin-top: -1rem; }
+.small-offset-4 {
+  margin-left: 33.33333%; }
 
-ul.no-bullet, ol.no-bullet {
-  margin-left: 0;
-  list-style: none; }
+.grid-margin-x > .small-offset-4 {
+  margin-left: calc(33.33333% + 0.625rem); }
 
-.text-left {
-  text-align: left; }
+.small-offset-5 {
+  margin-left: 41.66667%; }
 
-.text-right {
-  text-align: right; }
+.grid-margin-x > .small-offset-5 {
+  margin-left: calc(41.66667% + 0.625rem); }
 
-.text-center {
-  text-align: center; }
+.small-offset-6 {
+  margin-left: 50%; }
 
-.text-justify {
-  text-align: justify; }
+.grid-margin-x > .small-offset-6 {
+  margin-left: calc(50% + 0.625rem); }
 
-@media print, screen and (min-width: 40em) {
-  .medium-text-left {
-    text-align: left; }
-  .medium-text-right {
-    text-align: right; }
-  .medium-text-center {
-    text-align: center; }
-  .medium-text-justify {
-    text-align: justify; } }
+.small-offset-7 {
+  margin-left: 58.33333%; }
 
-@media print, screen and (min-width: 64em) {
-  .large-text-left {
-    text-align: left; }
-  .large-text-right {
-    text-align: right; }
-  .large-text-center {
-    text-align: center; }
-  .large-text-justify {
-    text-align: justify; } }
+.grid-margin-x > .small-offset-7 {
+  margin-left: calc(58.33333% + 0.625rem); }
 
-.show-for-print {
-  display: none !important; }
+.small-offset-8 {
+  margin-left: 66.66667%; }
 
-@media print {
-  * {
-    background: transparent !important;
-    -webkit-box-shadow: none !important;
-            box-shadow: none !important;
-    color: black !important;
-    text-shadow: none !important; }
-  .show-for-print {
-    display: block !important; }
-  .hide-for-print {
-    display: none !important; }
-  table.show-for-print {
-    display: table !important; }
-  thead.show-for-print {
-    display: table-header-group !important; }
-  tbody.show-for-print {
-    display: table-row-group !important; }
-  tr.show-for-print {
-    display: table-row !important; }
-  td.show-for-print {
-    display: table-cell !important; }
-  th.show-for-print {
-    display: table-cell !important; }
-  a,
-  a:visited {
-    text-decoration: underline; }
-  a[href]:after {
-    content: " (" attr(href) ")"; }
-  .ir a:after,
-  a[href^='javascript:']:after,
-  a[href^='#']:after {
-    content: ''; }
-  abbr[title]:after {
-    content: " (" attr(title) ")"; }
-  pre,
-  blockquote {
-    border: 1px solid #8a8a8a;
-    page-break-inside: avoid; }
-  thead {
-    display: table-header-group; }
-  tr,
-  img {
-    page-break-inside: avoid; }
-  img {
-    max-width: 100% !important; }
-  @page {
-    margin: 0.5cm; }
-  p,
-  h2,
-  h3 {
-    orphans: 3;
-    widows: 3; }
-  h2,
-  h3 {
-    page-break-after: avoid; }
-  .print-break-inside {
-    page-break-inside: auto; } }
+.grid-margin-x > .small-offset-8 {
+  margin-left: calc(66.66667% + 0.625rem); }
 
-[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],
-textarea {
-  display: block;
-  -webkit-box-sizing: border-box;
-          box-sizing: border-box;
-  width: 100%;
-  height: 2.4375rem;
-  margin: 0 0 1rem;
-  padding: 0.5rem;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
-          box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
-  font-family: inherit;
-  font-size: 1rem;
-  font-weight: normal;
-  line-height: 1.5;
-  color: #0a0a0a;
-  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none; }
-  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,
-  textarea:focus {
-    outline: none;
-    border: 1px solid #8a8a8a;
-    background-color: #fefefe;
-    -webkit-box-shadow: 0 0 5px #cacaca;
-            box-shadow: 0 0 5px #cacaca;
-    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+.small-offset-9 {
+  margin-left: 75%; }
 
-textarea {
-  max-width: 100%; }
-  textarea[rows] {
-    height: auto; }
+.grid-margin-x > .small-offset-9 {
+  margin-left: calc(75% + 0.625rem); }
 
-input::-webkit-input-placeholder,
-textarea::-webkit-input-placeholder {
-  color: #cacaca; }
+.small-offset-10 {
+  margin-left: 83.33333%; }
 
-input:-ms-input-placeholder,
-textarea:-ms-input-placeholder {
-  color: #cacaca; }
+.grid-margin-x > .small-offset-10 {
+  margin-left: calc(83.33333% + 0.625rem); }
 
-input::placeholder,
-textarea::placeholder {
-  color: #cacaca; }
+.small-offset-11 {
+  margin-left: 91.66667%; }
+
+.grid-margin-x > .small-offset-11 {
+  margin-left: calc(91.66667% + 0.625rem); }
+
+@media print, screen and (min-width: 40em) {
+  .medium-offset-0 {
+    margin-left: 0%; }
+  .grid-margin-x > .medium-offset-0 {
+    margin-left: calc(0% + 0.9375rem); }
+  .medium-offset-1 {
+    margin-left: 8.33333%; }
+  .grid-margin-x > .medium-offset-1 {
+    margin-left: calc(8.33333% + 0.9375rem); }
+  .medium-offset-2 {
+    margin-left: 16.66667%; }
+  .grid-margin-x > .medium-offset-2 {
+    margin-left: calc(16.66667% + 0.9375rem); }
+  .medium-offset-3 {
+    margin-left: 25%; }
+  .grid-margin-x > .medium-offset-3 {
+    margin-left: calc(25% + 0.9375rem); }
+  .medium-offset-4 {
+    margin-left: 33.33333%; }
+  .grid-margin-x > .medium-offset-4 {
+    margin-left: calc(33.33333% + 0.9375rem); }
+  .medium-offset-5 {
+    margin-left: 41.66667%; }
+  .grid-margin-x > .medium-offset-5 {
+    margin-left: calc(41.66667% + 0.9375rem); }
+  .medium-offset-6 {
+    margin-left: 50%; }
+  .grid-margin-x > .medium-offset-6 {
+    margin-left: calc(50% + 0.9375rem); }
+  .medium-offset-7 {
+    margin-left: 58.33333%; }
+  .grid-margin-x > .medium-offset-7 {
+    margin-left: calc(58.33333% + 0.9375rem); }
+  .medium-offset-8 {
+    margin-left: 66.66667%; }
+  .grid-margin-x > .medium-offset-8 {
+    margin-left: calc(66.66667% + 0.9375rem); }
+  .medium-offset-9 {
+    margin-left: 75%; }
+  .grid-margin-x > .medium-offset-9 {
+    margin-left: calc(75% + 0.9375rem); }
+  .medium-offset-10 {
+    margin-left: 83.33333%; }
+  .grid-margin-x > .medium-offset-10 {
+    margin-left: calc(83.33333% + 0.9375rem); }
+  .medium-offset-11 {
+    margin-left: 91.66667%; }
+  .grid-margin-x > .medium-offset-11 {
+    margin-left: calc(91.66667% + 0.9375rem); } }
 
-input:disabled, input[readonly],
-textarea:disabled,
-textarea[readonly] {
-  background-color: #e6e6e6;
-  cursor: not-allowed; }
+@media print, screen and (min-width: 64em) {
+  .large-offset-0 {
+    margin-left: 0%; }
+  .grid-margin-x > .large-offset-0 {
+    margin-left: calc(0% + 0.9375rem); }
+  .large-offset-1 {
+    margin-left: 8.33333%; }
+  .grid-margin-x > .large-offset-1 {
+    margin-left: calc(8.33333% + 0.9375rem); }
+  .large-offset-2 {
+    margin-left: 16.66667%; }
+  .grid-margin-x > .large-offset-2 {
+    margin-left: calc(16.66667% + 0.9375rem); }
+  .large-offset-3 {
+    margin-left: 25%; }
+  .grid-margin-x > .large-offset-3 {
+    margin-left: calc(25% + 0.9375rem); }
+  .large-offset-4 {
+    margin-left: 33.33333%; }
+  .grid-margin-x > .large-offset-4 {
+    margin-left: calc(33.33333% + 0.9375rem); }
+  .large-offset-5 {
+    margin-left: 41.66667%; }
+  .grid-margin-x > .large-offset-5 {
+    margin-left: calc(41.66667% + 0.9375rem); }
+  .large-offset-6 {
+    margin-left: 50%; }
+  .grid-margin-x > .large-offset-6 {
+    margin-left: calc(50% + 0.9375rem); }
+  .large-offset-7 {
+    margin-left: 58.33333%; }
+  .grid-margin-x > .large-offset-7 {
+    margin-left: calc(58.33333% + 0.9375rem); }
+  .large-offset-8 {
+    margin-left: 66.66667%; }
+  .grid-margin-x > .large-offset-8 {
+    margin-left: calc(66.66667% + 0.9375rem); }
+  .large-offset-9 {
+    margin-left: 75%; }
+  .grid-margin-x > .large-offset-9 {
+    margin-left: calc(75% + 0.9375rem); }
+  .large-offset-10 {
+    margin-left: 83.33333%; }
+  .grid-margin-x > .large-offset-10 {
+    margin-left: calc(83.33333% + 0.9375rem); }
+  .large-offset-11 {
+    margin-left: 91.66667%; }
+  .grid-margin-x > .large-offset-11 {
+    margin-left: calc(91.66667% + 0.9375rem); } }
 
-[type='submit'],
-[type='button'] {
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none;
-  border-radius: 0; }
+.grid-y {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-flow: column nowrap;
+      -ms-flex-flow: column nowrap;
+          flex-flow: column nowrap; }
+  .grid-y > .cell {
+    width: auto;
+    max-width: none; }
+  .grid-y > .auto {
+    height: auto; }
+  .grid-y > .shrink {
+    height: auto; }
+  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; }
+  @media print, screen and (min-width: 40em) {
+    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
+      -webkit-flex-basis: auto;
+          -ms-flex-preferred-size: auto;
+              flex-basis: auto; } }
+  @media print, screen and (min-width: 64em) {
+    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
+      -webkit-flex-basis: auto;
+          -ms-flex-preferred-size: auto;
+              flex-basis: auto; } }
+  .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-y > .small-1 {
+    height: 8.33333%; }
+  .grid-y > .small-2 {
+    height: 16.66667%; }
+  .grid-y > .small-3 {
+    height: 25%; }
+  .grid-y > .small-4 {
+    height: 33.33333%; }
+  .grid-y > .small-5 {
+    height: 41.66667%; }
+  .grid-y > .small-6 {
+    height: 50%; }
+  .grid-y > .small-7 {
+    height: 58.33333%; }
+  .grid-y > .small-8 {
+    height: 66.66667%; }
+  .grid-y > .small-9 {
+    height: 75%; }
+  .grid-y > .small-10 {
+    height: 83.33333%; }
+  .grid-y > .small-11 {
+    height: 91.66667%; }
+  .grid-y > .small-12 {
+    height: 100%; }
+  @media print, screen and (min-width: 40em) {
+    .grid-y > .medium-auto {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px;
+      height: auto; }
+    .grid-y > .medium-shrink, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto; }
+    .grid-y > .medium-shrink {
+      height: auto; }
+    .grid-y > .medium-1 {
+      height: 8.33333%; }
+    .grid-y > .medium-2 {
+      height: 16.66667%; }
+    .grid-y > .medium-3 {
+      height: 25%; }
+    .grid-y > .medium-4 {
+      height: 33.33333%; }
+    .grid-y > .medium-5 {
+      height: 41.66667%; }
+    .grid-y > .medium-6 {
+      height: 50%; }
+    .grid-y > .medium-7 {
+      height: 58.33333%; }
+    .grid-y > .medium-8 {
+      height: 66.66667%; }
+    .grid-y > .medium-9 {
+      height: 75%; }
+    .grid-y > .medium-10 {
+      height: 83.33333%; }
+    .grid-y > .medium-11 {
+      height: 91.66667%; }
+    .grid-y > .medium-12 {
+      height: 100%; } }
+  @media print, screen and (min-width: 64em) {
+    .grid-y > .large-auto {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px;
+      height: auto; }
+    .grid-y > .large-shrink, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto; }
+    .grid-y > .large-shrink {
+      height: auto; }
+    .grid-y > .large-1 {
+      height: 8.33333%; }
+    .grid-y > .large-2 {
+      height: 16.66667%; }
+    .grid-y > .large-3 {
+      height: 25%; }
+    .grid-y > .large-4 {
+      height: 33.33333%; }
+    .grid-y > .large-5 {
+      height: 41.66667%; }
+    .grid-y > .large-6 {
+      height: 50%; }
+    .grid-y > .large-7 {
+      height: 58.33333%; }
+    .grid-y > .large-8 {
+      height: 66.66667%; }
+    .grid-y > .large-9 {
+      height: 75%; }
+    .grid-y > .large-10 {
+      height: 83.33333%; }
+    .grid-y > .large-11 {
+      height: 91.66667%; }
+    .grid-y > .large-12 {
+      height: 100%; } }
 
-input[type='search'] {
-  -webkit-box-sizing: border-box;
-          box-sizing: border-box; }
+.grid-padding-y .grid-padding-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-y .grid-padding-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
 
-[type='file'],
-[type='checkbox'],
-[type='radio'] {
-  margin: 0 0 1rem; }
+.grid-padding-y > .cell {
+  padding-top: 0.625rem;
+  padding-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-y > .cell {
+      padding-top: 0.9375rem;
+      padding-bottom: 0.9375rem; } }
 
-[type='checkbox'] + label,
-[type='radio'] + label {
-  display: inline-block;
-  vertical-align: baseline;
-  margin-left: 0.5rem;
-  margin-right: 1rem;
-  margin-bottom: 0; }
-  [type='checkbox'] + label[for],
-  [type='radio'] + label[for] {
-    cursor: pointer; }
+.grid-margin-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
+  .grid-margin-y > .cell {
+    height: calc(100% - 1.25rem);
+    margin-top: 0.625rem;
+    margin-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .cell {
+      height: calc(100% - 1.875rem);
+      margin-top: 0.9375rem;
+      margin-bottom: 0.9375rem; } }
+  .grid-margin-y > .auto {
+    height: auto; }
+  .grid-margin-y > .shrink {
+    height: auto; }
+  .grid-margin-y > .small-1 {
+    height: calc(8.33333% - 1.25rem); }
+  .grid-margin-y > .small-2 {
+    height: calc(16.66667% - 1.25rem); }
+  .grid-margin-y > .small-3 {
+    height: calc(25% - 1.25rem); }
+  .grid-margin-y > .small-4 {
+    height: calc(33.33333% - 1.25rem); }
+  .grid-margin-y > .small-5 {
+    height: calc(41.66667% - 1.25rem); }
+  .grid-margin-y > .small-6 {
+    height: calc(50% - 1.25rem); }
+  .grid-margin-y > .small-7 {
+    height: calc(58.33333% - 1.25rem); }
+  .grid-margin-y > .small-8 {
+    height: calc(66.66667% - 1.25rem); }
+  .grid-margin-y > .small-9 {
+    height: calc(75% - 1.25rem); }
+  .grid-margin-y > .small-10 {
+    height: calc(83.33333% - 1.25rem); }
+  .grid-margin-y > .small-11 {
+    height: calc(91.66667% - 1.25rem); }
+  .grid-margin-y > .small-12 {
+    height: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .auto {
+      height: auto; }
+    .grid-margin-y > .shrink {
+      height: auto; }
+    .grid-margin-y > .small-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .small-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .small-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .small-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .small-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .small-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .small-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .small-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .small-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .small-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .small-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .small-12 {
+      height: calc(100% - 1.875rem); }
+    .grid-margin-y > .medium-auto {
+      height: auto; }
+    .grid-margin-y > .medium-shrink {
+      height: auto; }
+    .grid-margin-y > .medium-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .medium-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .medium-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .medium-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .medium-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .medium-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .medium-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .medium-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .medium-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .medium-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .medium-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .medium-12 {
+      height: calc(100% - 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-margin-y > .large-auto {
+      height: auto; }
+    .grid-margin-y > .large-shrink {
+      height: auto; }
+    .grid-margin-y > .large-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .large-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .large-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .large-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .large-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .large-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .large-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .large-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .large-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .large-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .large-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .large-12 {
+      height: calc(100% - 1.875rem); } }
 
-label > [type='checkbox'],
-label > [type='radio'] {
-  margin-right: 0.5rem; }
+.grid-frame {
+  overflow: hidden;
+  position: relative;
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch;
+  width: 100vw; }
 
-[type='file'] {
+.cell .grid-frame {
   width: 100%; }
 
-label {
-  display: block;
-  margin: 0;
-  font-size: 0.875rem;
-  font-weight: normal;
-  line-height: 1.8;
-  color: #0a0a0a; }
-  label.middle {
-    margin: 0 0 1rem;
-    padding: 0.5625rem 0; }
+.cell-block {
+  overflow-x: auto;
+  max-width: 100%;
+  -webkit-overflow-scrolling: touch;
+  -ms-overflow-style: -ms-autohiding-scrollbar; }
 
-.help-text {
-  margin-top: -0.5rem;
-  font-size: 0.8125rem;
-  font-style: italic;
-  color: #0a0a0a; }
+.cell-block-y {
+  overflow-y: auto;
+  max-height: 100%;
+  min-height: 100%;
+  -webkit-overflow-scrolling: touch;
+  -ms-overflow-style: -ms-autohiding-scrollbar; }
 
-.input-group {
+.cell-block-container {
   display: -webkit-box;
   display: -webkit-flex;
   display: -ms-flexbox;
   display: flex;
-  width: 100%;
-  margin-bottom: 1rem;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch; }
-  .input-group > :first-child {
-    border-radius: 0 0 0 0; }
-  .input-group > :last-child > * {
-    border-radius: 0 0 0 0; }
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-direction: column;
+      -ms-flex-direction: column;
+          flex-direction: column;
+  max-height: 100%; }
+  .cell-block-container > .grid-x {
+    max-height: 100%;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap; }
 
-.input-group-label, .input-group-field, .input-group-button, .input-group-button a,
-.input-group-button input,
-.input-group-button button,
-.input-group-button label {
-  margin: 0;
-  white-space: nowrap; }
+@media print, screen and (min-width: 40em) {
+  .medium-grid-frame {
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    width: 100vw; }
+  .cell .medium-grid-frame {
+    width: 100%; }
+  .medium-cell-block {
+    overflow-x: auto;
+    max-width: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; }
+  .medium-cell-block-container {
+    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;
+    max-height: 100%; }
+    .medium-cell-block-container > .grid-x {
+      max-height: 100%;
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap; }
+  .medium-cell-block-y {
+    overflow-y: auto;
+    max-height: 100%;
+    min-height: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; } }
 
-.input-group-label {
-  padding: 0 1rem;
-  border: 1px solid #cacaca;
-  background: #e6e6e6;
-  color: #0a0a0a;
-  text-align: center;
-  white-space: nowrap;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto;
-  -webkit-box-align: center;
-  -webkit-align-items: center;
-      -ms-flex-align: center;
-          align-items: center; }
-  .input-group-label:first-child {
-    border-right: 0; }
-  .input-group-label:last-child {
-    border-left: 0; }
+@media print, screen and (min-width: 64em) {
+  .large-grid-frame {
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    width: 100vw; }
+  .cell .large-grid-frame {
+    width: 100%; }
+  .large-cell-block {
+    overflow-x: auto;
+    max-width: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; }
+  .large-cell-block-container {
+    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;
+    max-height: 100%; }
+    .large-cell-block-container > .grid-x {
+      max-height: 100%;
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap; }
+  .large-cell-block-y {
+    overflow-y: auto;
+    max-height: 100%;
+    min-height: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; } }
 
-.input-group-field {
-  border-radius: 0;
-  -webkit-box-flex: 1;
-  -webkit-flex: 1 1 0px;
-      -ms-flex: 1 1 0px;
-          flex: 1 1 0px;
-  height: auto;
-  min-width: 0; }
+.grid-y.grid-frame {
+  width: auto;
+  overflow: hidden;
+  position: relative;
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch;
+  height: 100vh; }
 
-.input-group-button {
-  padding-top: 0;
-  padding-bottom: 0;
-  text-align: center;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto; }
-  .input-group-button a,
-  .input-group-button input,
-  .input-group-button button,
-  .input-group-button label {
-    height: auto;
-    -webkit-align-self: stretch;
-        -ms-flex-item-align: stretch;
-                -ms-grid-row-align: stretch;
-            align-self: stretch;
-    padding-top: 0;
-    padding-bottom: 0;
-    font-size: 1rem; }
+@media print, screen and (min-width: 40em) {
+  .grid-y.medium-grid-frame {
+    width: auto;
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    height: 100vh; } }
 
-fieldset {
-  margin: 0;
-  padding: 0;
-  border: 0; }
+@media print, screen and (min-width: 64em) {
+  .grid-y.large-grid-frame {
+    width: auto;
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    height: 100vh; } }
 
-legend {
-  max-width: 100%;
-  margin-bottom: 0.5rem; }
+.cell .grid-y.grid-frame {
+  height: 100%; }
 
-.fieldset {
-  margin: 1.125rem 0;
-  padding: 1.25rem;
-  border: 1px solid #cacaca; }
-  .fieldset legend {
-    margin: 0;
-    margin-left: -0.1875rem;
-    padding: 0 0.1875rem; }
+@media print, screen and (min-width: 40em) {
+  .cell .grid-y.medium-grid-frame {
+    height: 100%; } }
 
-select {
-  height: 2.4375rem;
-  margin: 0 0 1rem;
-  padding: 0.5rem;
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  font-family: inherit;
-  font-size: 1rem;
-  font-weight: normal;
-  line-height: 1.5;
-  color: #0a0a0a;
-  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");
-  -webkit-background-origin: content-box;
-          background-origin: content-box;
-  background-position: right -1rem center;
-  background-repeat: no-repeat;
-  -webkit-background-size: 9px 6px;
-          background-size: 9px 6px;
-  padding-right: 1.5rem;
-  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-  @media screen and (min-width: 0\0) {
-    select {
-      background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } }
-  select:focus {
-    outline: none;
-    border: 1px solid #8a8a8a;
-    background-color: #fefefe;
-    -webkit-box-shadow: 0 0 5px #cacaca;
-            box-shadow: 0 0 5px #cacaca;
-    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-  select:disabled {
-    background-color: #e6e6e6;
-    cursor: not-allowed; }
-  select::-ms-expand {
-    display: none; }
-  select[multiple] {
-    height: auto;
-    background-image: none; }
+@media print, screen and (min-width: 64em) {
+  .cell .grid-y.large-grid-frame {
+    height: 100%; } }
+
+.grid-margin-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
+  .grid-margin-y > .cell {
+    height: calc(100% - 1.25rem);
+    margin-top: 0.625rem;
+    margin-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .cell {
+      height: calc(100% - 1.875rem);
+      margin-top: 0.9375rem;
+      margin-bottom: 0.9375rem; } }
+  .grid-margin-y > .auto {
+    height: auto; }
+  .grid-margin-y > .shrink {
+    height: auto; }
+  .grid-margin-y > .small-1 {
+    height: calc(8.33333% - 1.25rem); }
+  .grid-margin-y > .small-2 {
+    height: calc(16.66667% - 1.25rem); }
+  .grid-margin-y > .small-3 {
+    height: calc(25% - 1.25rem); }
+  .grid-margin-y > .small-4 {
+    height: calc(33.33333% - 1.25rem); }
+  .grid-margin-y > .small-5 {
+    height: calc(41.66667% - 1.25rem); }
+  .grid-margin-y > .small-6 {
+    height: calc(50% - 1.25rem); }
+  .grid-margin-y > .small-7 {
+    height: calc(58.33333% - 1.25rem); }
+  .grid-margin-y > .small-8 {
+    height: calc(66.66667% - 1.25rem); }
+  .grid-margin-y > .small-9 {
+    height: calc(75% - 1.25rem); }
+  .grid-margin-y > .small-10 {
+    height: calc(83.33333% - 1.25rem); }
+  .grid-margin-y > .small-11 {
+    height: calc(91.66667% - 1.25rem); }
+  .grid-margin-y > .small-12 {
+    height: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .auto {
+      height: auto; }
+    .grid-margin-y > .shrink {
+      height: auto; }
+    .grid-margin-y > .small-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .small-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .small-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .small-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .small-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .small-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .small-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .small-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .small-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .small-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .small-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .small-12 {
+      height: calc(100% - 1.875rem); }
+    .grid-margin-y > .medium-auto {
+      height: auto; }
+    .grid-margin-y > .medium-shrink {
+      height: auto; }
+    .grid-margin-y > .medium-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .medium-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .medium-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .medium-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .medium-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .medium-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .medium-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .medium-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .medium-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .medium-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .medium-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .medium-12 {
+      height: calc(100% - 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-margin-y > .large-auto {
+      height: auto; }
+    .grid-margin-y > .large-shrink {
+      height: auto; }
+    .grid-margin-y > .large-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .large-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .large-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .large-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .large-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .large-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .large-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .large-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .large-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .large-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .large-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .large-12 {
+      height: calc(100% - 1.875rem); } }
 
-.is-invalid-input:not(:focus) {
-  border-color: #cc4b37;
-  background-color: #f9ecea; }
-  .is-invalid-input:not(:focus)::-webkit-input-placeholder {
-    color: #cc4b37; }
-  .is-invalid-input:not(:focus):-ms-input-placeholder {
-    color: #cc4b37; }
-  .is-invalid-input:not(:focus)::placeholder {
-    color: #cc4b37; }
+.grid-frame.grid-margin-y {
+  height: calc(100vh + 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-frame.grid-margin-y {
+      height: calc(100vh + 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-frame.grid-margin-y {
+      height: calc(100vh + 1.875rem); } }
 
-.is-invalid-label {
-  color: #cc4b37; }
+@media print, screen and (min-width: 40em) {
+  .grid-margin-y.medium-grid-frame {
+    height: calc(100vh + 1.875rem); } }
 
-.form-error {
-  display: none;
-  margin-top: -0.5rem;
-  margin-bottom: 1rem;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #cc4b37; }
-  .form-error.is-visible {
-    display: block; }
+@media print, screen and (min-width: 64em) {
+  .grid-margin-y.large-grid-frame {
+    height: calc(100vh + 1.875rem); } }
 
 .button {
   display: inline-block;
   vertical-align: middle;
   margin: 0 0 1rem 0;
-  font-family: inherit;
   padding: 0.85em 1em;
-  -webkit-appearance: none;
   border: 1px solid transparent;
   border-radius: 0;
   -webkit-transition: background-color 0.25s ease-out, color 0.25s ease-out;
   transition: background-color 0.25s ease-out, color 0.25s ease-out;
+  font-family: inherit;
   font-size: 0.9rem;
+  -webkit-appearance: none;
   line-height: 1;
   text-align: center;
   cursor: pointer;
@@ -2795,305 +2551,104 @@ select {
     color: #1779ba; }
     .button.clear, .button.clear:hover, .button.clear:focus {
       background-color: transparent; }
-    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {
-      background-color: transparent; }
-    .button.clear:hover, .button.clear:focus {
-      border-color: #0c3d5d;
-      color: #0c3d5d; }
-      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {
-        border: 1px solid #1779ba;
-        color: #1779ba; }
-    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {
-      border-color: transparent; }
-    .button.clear.primary {
-      border: 1px solid #1779ba;
-      color: #1779ba; }
-      .button.clear.primary:hover, .button.clear.primary:focus {
-        border-color: #0c3d5d;
-        color: #0c3d5d; }
-        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
-          border: 1px solid #1779ba;
-          color: #1779ba; }
-      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.secondary {
-      border: 1px solid #767676;
-      color: #767676; }
-      .button.clear.secondary:hover, .button.clear.secondary:focus {
-        border-color: #3b3b3b;
-        color: #3b3b3b; }
-        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
-          border: 1px solid #767676;
-          color: #767676; }
-      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.success {
-      border: 1px solid #3adb76;
-      color: #3adb76; }
-      .button.clear.success:hover, .button.clear.success:focus {
-        border-color: #157539;
-        color: #157539; }
-        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
-          border: 1px solid #3adb76;
-          color: #3adb76; }
-      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.warning {
-      border: 1px solid #ffae00;
-      color: #ffae00; }
-      .button.clear.warning:hover, .button.clear.warning:focus {
-        border-color: #805700;
-        color: #805700; }
-        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
-          border: 1px solid #ffae00;
-          color: #ffae00; }
-      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.alert {
-      border: 1px solid #cc4b37;
-      color: #cc4b37; }
-      .button.clear.alert:hover, .button.clear.alert:focus {
-        border-color: #67251a;
-        color: #67251a; }
-        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
-          border: 1px solid #cc4b37;
-          color: #cc4b37; }
-      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
-        border-color: transparent; }
-  .button.dropdown::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.4em;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #fefefe transparent transparent;
-    position: relative;
-    top: 0.4em;
-    display: inline-block;
-    float: right;
-    margin-left: 1em; }
-  .button.dropdown.hollow::after {
-    border-top-color: #1779ba; }
-  .button.dropdown.hollow.primary::after {
-    border-top-color: #1779ba; }
-  .button.dropdown.hollow.secondary::after {
-    border-top-color: #767676; }
-  .button.dropdown.hollow.success::after {
-    border-top-color: #3adb76; }
-  .button.dropdown.hollow.warning::after {
-    border-top-color: #ffae00; }
-  .button.dropdown.hollow.alert::after {
-    border-top-color: #cc4b37; }
-  .button.arrow-only::after {
-    top: -0.1em;
-    float: none;
-    margin-left: 0; }
-
-a.button:hover, a.button:focus {
-  text-decoration: none; }
-
-.accordion {
-  margin-left: 0;
-  background: #fefefe;
-  list-style-type: none; }
-  .accordion[disabled] .accordion-title {
-    cursor: not-allowed; }
-
-.accordion-item:first-child > :first-child {
-  border-radius: 0 0 0 0; }
-
-.accordion-item:last-child > :last-child {
-  border-radius: 0 0 0 0; }
-
-.accordion-title {
-  position: relative;
-  display: block;
-  padding: 1.25rem 1rem;
-  border: 1px solid #e6e6e6;
-  border-bottom: 0;
-  font-size: 0.75rem;
-  line-height: 1;
-  color: #1779ba; }
-  :last-child:not(.is-active) > .accordion-title {
-    border-bottom: 1px solid #e6e6e6;
-    border-radius: 0 0 0 0; }
-  .accordion-title:hover, .accordion-title:focus {
-    background-color: #e6e6e6; }
-  .accordion-title::before {
-    position: absolute;
-    top: 50%;
-    right: 1rem;
-    margin-top: -0.5rem;
-    content: '+'; }
-  .is-active > .accordion-title::before {
-    content: '\2013'; }
-
-.accordion-content {
-  display: none;
-  padding: 1rem;
-  border: 1px solid #e6e6e6;
-  border-bottom: 0;
-  background-color: #fefefe;
-  color: #0a0a0a; }
-  :last-child > .accordion-content:last-child {
-    border-bottom: 1px solid #e6e6e6; }
-
-.accordion-menu li {
-  width: 100%; }
-
-.accordion-menu a {
-  padding: 0.7rem 1rem; }
-
-.accordion-menu .is-accordion-submenu a {
-  padding: 0.7rem 1rem; }
-
-.accordion-menu .nested.is-accordion-submenu {
-  margin-right: 0;
-  margin-left: 1rem; }
-
-.accordion-menu.align-right .nested.is-accordion-submenu {
-  margin-right: 1rem;
-  margin-left: 0; }
-
-.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {
-  position: relative; }
-  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    position: absolute;
-    top: 50%;
-    margin-top: -3px;
-    right: 1rem; }
-
-.accordion-menu.align-left .is-accordion-submenu-parent > a::after {
-  left: auto;
-  right: 1rem; }
-
-.accordion-menu.align-right .is-accordion-submenu-parent > a::after {
-  right: auto;
-  left: 1rem; }
-
-.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {
-  -webkit-transform: rotate(180deg);
-      -ms-transform: rotate(180deg);
-          transform: rotate(180deg);
-  -webkit-transform-origin: 50% 50%;
-      -ms-transform-origin: 50% 50%;
-          transform-origin: 50% 50%; }
-
-.is-accordion-submenu-parent {
-  position: relative; }
-
-.has-submenu-toggle > a {
-  margin-right: 40px; }
-
-.submenu-toggle {
-  position: absolute;
-  top: 0;
-  right: 0;
-  cursor: pointer;
-  width: 40px;
-  height: 40px; }
-  .submenu-toggle::after {
+    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {
+      background-color: transparent; }
+    .button.clear:hover, .button.clear:focus {
+      border-color: #0c3d5d;
+      color: #0c3d5d; }
+      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {
+        border: 1px solid #1779ba;
+        color: #1779ba; }
+    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {
+      border-color: transparent; }
+    .button.clear.primary {
+      border: 1px solid #1779ba;
+      color: #1779ba; }
+      .button.clear.primary:hover, .button.clear.primary:focus {
+        border-color: #0c3d5d;
+        color: #0c3d5d; }
+        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
+          border: 1px solid #1779ba;
+          color: #1779ba; }
+      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.secondary {
+      border: 1px solid #767676;
+      color: #767676; }
+      .button.clear.secondary:hover, .button.clear.secondary:focus {
+        border-color: #3b3b3b;
+        color: #3b3b3b; }
+        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
+          border: 1px solid #767676;
+          color: #767676; }
+      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.success {
+      border: 1px solid #3adb76;
+      color: #3adb76; }
+      .button.clear.success:hover, .button.clear.success:focus {
+        border-color: #157539;
+        color: #157539; }
+        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
+          border: 1px solid #3adb76;
+          color: #3adb76; }
+      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.warning {
+      border: 1px solid #ffae00;
+      color: #ffae00; }
+      .button.clear.warning:hover, .button.clear.warning:focus {
+        border-color: #805700;
+        color: #805700; }
+        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
+          border: 1px solid #ffae00;
+          color: #ffae00; }
+      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.alert {
+      border: 1px solid #cc4b37;
+      color: #cc4b37; }
+      .button.clear.alert:hover, .button.clear.alert:focus {
+        border-color: #67251a;
+        color: #67251a; }
+        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
+          border: 1px solid #cc4b37;
+          color: #cc4b37; }
+      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
+        border-color: transparent; }
+  .button.dropdown::after {
     display: block;
     width: 0;
     height: 0;
-    border: inset 6px;
+    border: inset 0.4em;
     content: '';
     border-bottom-width: 0;
     border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    top: 0;
-    bottom: 0;
-    margin: auto; }
-
-.submenu-toggle[aria-expanded='true']::after {
-  -webkit-transform: scaleY(-1);
-      -ms-transform: scaleY(-1);
-          transform: scaleY(-1);
-  -webkit-transform-origin: 50% 50%;
-      -ms-transform-origin: 50% 50%;
-          transform-origin: 50% 50%; }
-
-.submenu-toggle-text {
-  position: absolute !important;
-  width: 1px;
-  height: 1px;
-  padding: 0;
-  overflow: hidden;
-  clip: rect(0, 0, 0, 0);
-  white-space: nowrap;
-  -webkit-clip-path: inset(50%);
-          clip-path: inset(50%);
-  border: 0; }
-
-.badge {
-  display: inline-block;
-  min-width: 2.1em;
-  padding: 0.3em;
-  border-radius: 50%;
-  font-size: 0.6rem;
-  text-align: center;
-  background: #1779ba;
-  color: #fefefe; }
-  .badge.primary {
-    background: #1779ba;
-    color: #fefefe; }
-  .badge.secondary {
-    background: #767676;
-    color: #fefefe; }
-  .badge.success {
-    background: #3adb76;
-    color: #0a0a0a; }
-  .badge.warning {
-    background: #ffae00;
-    color: #0a0a0a; }
-  .badge.alert {
-    background: #cc4b37;
-    color: #fefefe; }
+    border-color: #fefefe transparent transparent;
+    position: relative;
+    top: 0.4em;
+    display: inline-block;
+    float: right;
+    margin-left: 1em; }
+  .button.dropdown.hollow::after, .button.dropdown.clear::after {
+    border-top-color: #1779ba; }
+  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {
+    border-top-color: #1779ba; }
+  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {
+    border-top-color: #767676; }
+  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {
+    border-top-color: #3adb76; }
+  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {
+    border-top-color: #ffae00; }
+  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {
+    border-top-color: #cc4b37; }
+  .button.arrow-only::after {
+    top: -0.1em;
+    float: none;
+    margin-left: 0; }
 
-.breadcrumbs {
-  margin: 0 0 1rem 0;
-  list-style: none; }
-  .breadcrumbs::before, .breadcrumbs::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .breadcrumbs::after {
-    clear: both; }
-  .breadcrumbs li {
-    float: left;
-    font-size: 0.6875rem;
-    color: #0a0a0a;
-    cursor: default;
-    text-transform: uppercase; }
-    .breadcrumbs li:not(:last-child)::after {
-      position: relative;
-      margin: 0 0.75rem;
-      opacity: 1;
-      content: "/";
-      color: #cacaca; }
-  .breadcrumbs a {
-    color: #1779ba; }
-    .breadcrumbs a:hover {
-      text-decoration: underline; }
-  .breadcrumbs .disabled {
-    color: #cacaca;
-    cursor: not-allowed; }
+a.button:hover, a.button:focus {
+  text-decoration: none; }
 
 .button-group {
   margin-bottom: 1rem;
@@ -3183,1948 +2738,2249 @@ a.button:hover, a.button:focus {
               flex: 0 0 100%; }
       .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {
         margin-bottom: 0; }
-  @media print, screen and (min-width: 40em) {
-    .button-group.stacked-for-small .button {
+    .button-group.stacked.expanded .button, .button-group.stacked-for-small.expanded .button, .button-group.stacked-for-medium.expanded .button {
       -webkit-box-flex: 1;
       -webkit-flex: 1 1 0px;
           -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
+              flex: 1 1 0px; }
+  @media print, screen and (min-width: 40em) {
+    .button-group.stacked-for-small .button {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto;
       margin-bottom: 0; } }
   @media print, screen and (min-width: 64em) {
     .button-group.stacked-for-medium .button {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto;
       margin-bottom: 0; } }
-  @media screen and (max-width: 39.9375em) {
+  @media screen and (max-width: 39.99875em) {
     .button-group.stacked-for-small.expanded {
       display: block; }
       .button-group.stacked-for-small.expanded .button {
         display: block;
         margin-right: 0; } }
+  @media screen and (max-width: 63.99875em) {
+    .button-group.stacked-for-medium.expanded {
+      display: block; }
+      .button-group.stacked-for-medium.expanded .button {
+        display: block;
+        margin-right: 0; } }
+
+.close-button {
+  position: absolute;
+  color: #8a8a8a;
+  cursor: pointer; }
+  [data-whatinput='mouse'] .close-button {
+    outline: 0; }
+  .close-button:hover, .close-button:focus {
+    color: #0a0a0a; }
+  .close-button.small {
+    right: 0.66rem;
+    top: 0.33em;
+    font-size: 1.5em;
+    line-height: 1; }
+  .close-button, .close-button.medium {
+    right: 1rem;
+    top: 0.5rem;
+    font-size: 2em;
+    line-height: 1; }
+
+.label {
+  display: inline-block;
+  padding: 0.33333rem 0.5rem;
+  border-radius: 0;
+  font-size: 0.8rem;
+  line-height: 1;
+  white-space: nowrap;
+  cursor: default;
+  background: #1779ba;
+  color: #fefefe; }
+  .label.primary {
+    background: #1779ba;
+    color: #fefefe; }
+  .label.secondary {
+    background: #767676;
+    color: #fefefe; }
+  .label.success {
+    background: #3adb76;
+    color: #0a0a0a; }
+  .label.warning {
+    background: #ffae00;
+    color: #0a0a0a; }
+  .label.alert {
+    background: #cc4b37;
+    color: #fefefe; }
+
+.progress {
+  height: 1rem;
+  margin-bottom: 1rem;
+  border-radius: 0;
+  background-color: #cacaca; }
+  .progress.primary .progress-meter {
+    background-color: #1779ba; }
+  .progress.secondary .progress-meter {
+    background-color: #767676; }
+  .progress.success .progress-meter {
+    background-color: #3adb76; }
+  .progress.warning .progress-meter {
+    background-color: #ffae00; }
+  .progress.alert .progress-meter {
+    background-color: #cc4b37; }
+
+.progress-meter {
+  position: relative;
+  display: block;
+  width: 0%;
+  height: 100%;
+  background-color: #1779ba; }
+
+.progress-meter-text {
+  position: absolute;
+  top: 50%;
+  left: 50%;
+  -webkit-transform: translate(-50%, -50%);
+      -ms-transform: translate(-50%, -50%);
+          transform: translate(-50%, -50%);
+  margin: 0;
+  font-size: 0.75rem;
+  font-weight: bold;
+  color: #fefefe;
+  white-space: nowrap; }
 
-.callout {
+.slider {
   position: relative;
-  margin: 0 0 1rem 0;
-  padding: 1rem;
-  border: 1px solid rgba(10, 10, 10, 0.25);
+  height: 0.5rem;
+  margin-top: 1.25rem;
+  margin-bottom: 2.25rem;
+  background-color: #e6e6e6;
+  cursor: pointer;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+  -ms-touch-action: none;
+      touch-action: none; }
+
+.slider-fill {
+  position: absolute;
+  top: 0;
+  left: 0;
+  display: inline-block;
+  max-width: 100%;
+  height: 0.5rem;
+  background-color: #cacaca;
+  -webkit-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out; }
+  .slider-fill.is-dragging {
+    -webkit-transition: all 0s linear;
+    transition: all 0s linear; }
+
+.slider-handle {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%);
+  left: 0;
+  z-index: 1;
+  display: inline-block;
+  width: 1.4rem;
+  height: 1.4rem;
   border-radius: 0;
-  background-color: white;
-  color: #0a0a0a; }
-  .callout > :first-child {
-    margin-top: 0; }
-  .callout > :last-child {
-    margin-bottom: 0; }
-  .callout.primary {
-    background-color: #d7ecfa;
-    color: #0a0a0a; }
-  .callout.secondary {
-    background-color: #eaeaea;
-    color: #0a0a0a; }
-  .callout.success {
-    background-color: #e1faea;
-    color: #0a0a0a; }
-  .callout.warning {
-    background-color: #fff3d9;
-    color: #0a0a0a; }
-  .callout.alert {
-    background-color: #f7e4e1;
-    color: #0a0a0a; }
-  .callout.small {
-    padding-top: 0.5rem;
-    padding-right: 0.5rem;
-    padding-bottom: 0.5rem;
-    padding-left: 0.5rem; }
-  .callout.large {
-    padding-top: 3rem;
-    padding-right: 3rem;
-    padding-bottom: 3rem;
-    padding-left: 3rem; }
+  background-color: #1779ba;
+  -webkit-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out;
+  -ms-touch-action: manipulation;
+      touch-action: manipulation; }
+  [data-whatinput='mouse'] .slider-handle {
+    outline: 0; }
+  .slider-handle:hover {
+    background-color: #14679e; }
+  .slider-handle.is-dragging {
+    -webkit-transition: all 0s linear;
+    transition: all 0s linear; }
 
-.card {
-  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-grow: 1;
-      -ms-flex-positive: 1;
-          flex-grow: 1;
+.slider.disabled,
+.slider[disabled] {
+  opacity: 0.25;
+  cursor: not-allowed; }
+
+.slider.vertical {
+  display: inline-block;
+  width: 0.5rem;
+  height: 12.5rem;
+  margin: 0 1.25rem;
+  -webkit-transform: scale(1, -1);
+      -ms-transform: scale(1, -1);
+          transform: scale(1, -1); }
+  .slider.vertical .slider-fill {
+    top: 0;
+    width: 0.5rem;
+    max-height: 100%; }
+  .slider.vertical .slider-handle {
+    position: absolute;
+    top: 0;
+    left: 50%;
+    width: 1.4rem;
+    height: 1.4rem;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+
+.switch {
+  height: 2rem;
+  position: relative;
   margin-bottom: 1rem;
-  border: 1px solid #e6e6e6;
+  outline: 0;
+  font-size: 0.875rem;
+  font-weight: bold;
+  color: #fefefe;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none; }
+
+.switch-input {
+  position: absolute;
+  margin-bottom: 0;
+  opacity: 0; }
+
+.switch-paddle {
+  position: relative;
+  display: block;
+  width: 4rem;
+  height: 2rem;
   border-radius: 0;
-  background: #fefefe;
-  -webkit-box-shadow: none;
-          box-shadow: none;
-  overflow: hidden;
-  color: #0a0a0a; }
-  .card > :last-child {
-    margin-bottom: 0; }
+  background: #cacaca;
+  -webkit-transition: all 0.25s ease-out;
+  transition: all 0.25s ease-out;
+  font-weight: inherit;
+  color: inherit;
+  cursor: pointer; }
+  input + .switch-paddle {
+    margin: 0; }
+  .switch-paddle::after {
+    position: absolute;
+    top: 0.25rem;
+    left: 0.25rem;
+    display: block;
+    width: 1.5rem;
+    height: 1.5rem;
+    -webkit-transform: translate3d(0, 0, 0);
+            transform: translate3d(0, 0, 0);
+    border-radius: 0;
+    background: #fefefe;
+    -webkit-transition: all 0.25s ease-out;
+    transition: all 0.25s ease-out;
+    content: ''; }
+  input:checked ~ .switch-paddle {
+    background: #1779ba; }
+    input:checked ~ .switch-paddle::after {
+      left: 2.25rem; }
+  [data-whatinput='mouse'] input:focus ~ .switch-paddle {
+    outline: 0; }
 
-.card-divider {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 1 auto;
-      -ms-flex: 0 1 auto;
-          flex: 0 1 auto;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  padding: 1rem;
-  background: #e6e6e6; }
-  .card-divider > :last-child {
-    margin-bottom: 0; }
+.switch-active, .switch-inactive {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%); }
 
-.card-section {
-  -webkit-box-flex: 1;
-  -webkit-flex: 1 0 auto;
-      -ms-flex: 1 0 auto;
-          flex: 1 0 auto;
-  padding: 1rem; }
-  .card-section > :last-child {
-    margin-bottom: 0; }
+.switch-active {
+  left: 8%;
+  display: none; }
+  input:checked + label > .switch-active {
+    display: block; }
+
+.switch-inactive {
+  right: 15%; }
+  input:checked + label > .switch-inactive {
+    display: none; }
+
+.switch.tiny {
+  height: 1.5rem; }
+  .switch.tiny .switch-paddle {
+    width: 3rem;
+    height: 1.5rem;
+    font-size: 0.625rem; }
+  .switch.tiny .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 1rem;
+    height: 1rem; }
+  .switch.tiny input:checked ~ .switch-paddle::after {
+    left: 1.75rem; }
+
+.switch.small {
+  height: 1.75rem; }
+  .switch.small .switch-paddle {
+    width: 3.5rem;
+    height: 1.75rem;
+    font-size: 0.75rem; }
+  .switch.small .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 1.25rem;
+    height: 1.25rem; }
+  .switch.small input:checked ~ .switch-paddle::after {
+    left: 2rem; }
 
-.card-image {
-  min-height: 1px; }
+.switch.large {
+  height: 2.5rem; }
+  .switch.large .switch-paddle {
+    width: 5rem;
+    height: 2.5rem;
+    font-size: 1rem; }
+  .switch.large .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 2rem;
+    height: 2rem; }
+  .switch.large input:checked ~ .switch-paddle::after {
+    left: 2.75rem; }
 
-.close-button {
-  position: absolute;
-  color: #8a8a8a;
-  cursor: pointer; }
-  [data-whatinput='mouse'] .close-button {
-    outline: 0; }
-  .close-button:hover, .close-button:focus {
+table {
+  border-collapse: collapse;
+  width: 100%;
+  margin-bottom: 1rem;
+  border-radius: 0; }
+  thead,
+  tbody,
+  tfoot {
+    border: 1px solid #f1f1f1;
+    background-color: #fefefe; }
+  caption {
+    padding: 0.5rem 0.625rem 0.625rem;
+    font-weight: bold; }
+  thead {
+    background: #f8f8f8;
     color: #0a0a0a; }
-  .close-button.small {
-    right: 0.66rem;
-    top: 0.33em;
-    font-size: 1.5em;
-    line-height: 1; }
-  .close-button, .close-button.medium {
-    right: 1rem;
-    top: 0.5rem;
-    font-size: 2em;
-    line-height: 1; }
+  tfoot {
+    background: #f1f1f1;
+    color: #0a0a0a; }
+  thead tr,
+  tfoot tr {
+    background: transparent; }
+  thead th,
+  thead td,
+  tfoot th,
+  tfoot td {
+    padding: 0.5rem 0.625rem 0.625rem;
+    font-weight: bold;
+    text-align: left; }
+  tbody th,
+  tbody td {
+    padding: 0.5rem 0.625rem 0.625rem; }
+  tbody tr:nth-child(even) {
+    border-bottom: 0;
+    background-color: #f1f1f1; }
+  table.unstriped tbody {
+    background-color: #fefefe; }
+    table.unstriped tbody tr {
+      border-bottom: 0;
+      border-bottom: 1px solid #f1f1f1;
+      background-color: #fefefe; }
 
-.menu {
-  padding: 0;
-  margin: 0;
-  list-style: none;
-  position: relative;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-flex-wrap: wrap;
-      -ms-flex-wrap: wrap;
-          flex-wrap: wrap; }
-  [data-whatinput='mouse'] .menu li {
-    outline: 0; }
-  .menu a,
-  .menu .button {
-    line-height: 1;
-    text-decoration: none;
-    display: block;
-    padding: 0.7rem 1rem; }
-  .menu input,
-  .menu select,
-  .menu a,
-  .menu button {
-    margin-bottom: 0; }
-  .menu input {
-    display: inline-block; }
-  .menu, .menu.horizontal {
-    -webkit-flex-wrap: wrap;
-        -ms-flex-wrap: wrap;
-            flex-wrap: wrap;
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-direction: row;
-        -ms-flex-direction: row;
-            flex-direction: row; }
-  .menu.vertical {
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-orient: vertical;
-    -webkit-box-direction: normal;
-    -webkit-flex-direction: column;
-        -ms-flex-direction: column;
-            flex-direction: column; }
-  .menu.expanded li {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-  .menu.simple {
-    -webkit-box-align: center;
-    -webkit-align-items: center;
-        -ms-flex-align: center;
-            align-items: center; }
-    .menu.simple li + li {
-      margin-left: 1rem; }
-    .menu.simple a {
-      padding: 0; }
-  @media print, screen and (min-width: 40em) {
-    .menu.medium-horizontal {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap;
-      -webkit-box-orient: horizontal;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: row;
-          -ms-flex-direction: row;
-              flex-direction: row; }
-    .menu.medium-vertical {
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap;
-      -webkit-box-orient: vertical;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: column;
-          -ms-flex-direction: column;
-              flex-direction: column; }
-    .menu.medium-expanded li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; }
-    .menu.medium-simple li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; } }
-  @media print, screen and (min-width: 64em) {
-    .menu.large-horizontal {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap;
-      -webkit-box-orient: horizontal;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: row;
-          -ms-flex-direction: row;
-              flex-direction: row; }
-    .menu.large-vertical {
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap;
-      -webkit-box-orient: vertical;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: column;
-          -ms-flex-direction: column;
-              flex-direction: column; }
-    .menu.large-expanded li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; }
-    .menu.large-simple li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; } }
-  .menu.nested {
-    margin-right: 0;
-    margin-left: 1rem; }
-  .menu.icons a {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex; }
-  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex; }
-  .menu.icon-left li a {
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: row nowrap;
-        -ms-flex-flow: row nowrap;
-            flex-flow: row nowrap; }
-    .menu.icon-left li a img,
-    .menu.icon-left li a i,
-    .menu.icon-left li a svg {
-      margin-right: 0.25rem; }
-  .menu.icon-right li a {
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: row nowrap;
-        -ms-flex-flow: row nowrap;
-            flex-flow: row nowrap; }
-    .menu.icon-right li a img,
-    .menu.icon-right li a i,
-    .menu.icon-right li a svg {
-      margin-left: 0.25rem; }
-  .menu.icon-top li a {
-    -webkit-box-orient: vertical;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: column nowrap;
-        -ms-flex-flow: column nowrap;
-            flex-flow: column nowrap; }
-    .menu.icon-top li a img,
-    .menu.icon-top li a i,
-    .menu.icon-top li a svg {
-      -webkit-align-self: stretch;
-          -ms-flex-item-align: stretch;
-                  -ms-grid-row-align: stretch;
-              align-self: stretch;
-      margin-bottom: 0.25rem;
-      text-align: center; }
-  .menu.icon-bottom li a {
-    -webkit-box-orient: vertical;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: column nowrap;
-        -ms-flex-flow: column nowrap;
-            flex-flow: column nowrap; }
-    .menu.icon-bottom li a img,
-    .menu.icon-bottom li a i,
-    .menu.icon-bottom li a svg {
-      -webkit-align-self: stretch;
-          -ms-flex-item-align: stretch;
-                  -ms-grid-row-align: stretch;
-              align-self: stretch;
-      margin-bottom: 0.25rem;
-      text-align: center; }
-  .menu .is-active > a {
+@media screen and (max-width: 63.99875em) {
+  table.stack thead {
+    display: none; }
+  table.stack tfoot {
+    display: none; }
+  table.stack tr,
+  table.stack th,
+  table.stack td {
+    display: block; }
+  table.stack td {
+    border-top: 0; } }
+
+table.scroll {
+  display: block;
+  width: 100%;
+  overflow-x: auto; }
+
+table.hover thead tr:hover {
+  background-color: #f3f3f3; }
+
+table.hover tfoot tr:hover {
+  background-color: #ececec; }
+
+table.hover tbody tr:hover {
+  background-color: #f9f9f9; }
+
+table.hover:not(.unstriped) tr:nth-of-type(even):hover {
+  background-color: #ececec; }
+
+.table-scroll {
+  overflow-x: auto; }
+
+.badge {
+  display: inline-block;
+  min-width: 2.1em;
+  padding: 0.3em;
+  border-radius: 50%;
+  font-size: 0.6rem;
+  text-align: center;
+  background: #1779ba;
+  color: #fefefe; }
+  .badge.primary {
     background: #1779ba;
     color: #fefefe; }
-  .menu .active > a {
-    background: #1779ba;
+  .badge.secondary {
+    background: #767676;
     color: #fefefe; }
-  .menu.align-left {
-    -webkit-box-pack: start;
-    -webkit-justify-content: flex-start;
-        -ms-flex-pack: start;
-            justify-content: flex-start; }
-  .menu.align-right li {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex;
-    -webkit-box-pack: end;
-    -webkit-justify-content: flex-end;
-        -ms-flex-pack: end;
-            justify-content: flex-end; }
-    .menu.align-right li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
-  .menu.align-right.vertical li {
+  .badge.success {
+    background: #3adb76;
+    color: #0a0a0a; }
+  .badge.warning {
+    background: #ffae00;
+    color: #0a0a0a; }
+  .badge.alert {
+    background: #cc4b37;
+    color: #fefefe; }
+
+.breadcrumbs {
+  margin: 0 0 1rem 0;
+  list-style: none; }
+  .breadcrumbs::before, .breadcrumbs::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .breadcrumbs::after {
+    clear: both; }
+  .breadcrumbs li {
+    float: left;
+    font-size: 0.6875rem;
+    color: #0a0a0a;
+    cursor: default;
+    text-transform: uppercase; }
+    .breadcrumbs li:not(:last-child)::after {
+      position: relative;
+      margin: 0 0.75rem;
+      opacity: 1;
+      content: "/";
+      color: #cacaca; }
+  .breadcrumbs a {
+    color: #1779ba; }
+    .breadcrumbs a:hover {
+      text-decoration: underline; }
+  .breadcrumbs .disabled {
+    color: #cacaca;
+    cursor: not-allowed; }
+
+.callout {
+  position: relative;
+  margin: 0 0 1rem 0;
+  padding: 1rem;
+  border: 1px solid rgba(10, 10, 10, 0.25);
+  border-radius: 0;
+  background-color: white;
+  color: #0a0a0a; }
+  .callout > :first-child {
+    margin-top: 0; }
+  .callout > :last-child {
+    margin-bottom: 0; }
+  .callout.primary {
+    background-color: #d7ecfa;
+    color: #0a0a0a; }
+  .callout.secondary {
+    background-color: #eaeaea;
+    color: #0a0a0a; }
+  .callout.success {
+    background-color: #e1faea;
+    color: #0a0a0a; }
+  .callout.warning {
+    background-color: #fff3d9;
+    color: #0a0a0a; }
+  .callout.alert {
+    background-color: #f7e4e1;
+    color: #0a0a0a; }
+  .callout.small {
+    padding-top: 0.5rem;
+    padding-right: 0.5rem;
+    padding-bottom: 0.5rem;
+    padding-left: 0.5rem; }
+  .callout.large {
+    padding-top: 3rem;
+    padding-right: 3rem;
+    padding-bottom: 3rem;
+    padding-left: 3rem; }
+
+.card {
+  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-grow: 1;
+      -ms-flex-positive: 1;
+          flex-grow: 1;
+  margin-bottom: 1rem;
+  border: 1px solid #e6e6e6;
+  border-radius: 0;
+  background: #fefefe;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  overflow: hidden;
+  color: #0a0a0a; }
+  .card > :last-child {
+    margin-bottom: 0; }
+
+.card-divider {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 1 auto;
+      -ms-flex: 0 1 auto;
+          flex: 0 1 auto;
+  padding: 1rem;
+  background: #e6e6e6; }
+  .card-divider > :last-child {
+    margin-bottom: 0; }
+
+.card-section {
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 0 auto;
+      -ms-flex: 1 0 auto;
+          flex: 1 0 auto;
+  padding: 1rem; }
+  .card-section > :last-child {
+    margin-bottom: 0; }
+
+.card-image {
+  min-height: 1px; }
+
+.dropdown-pane {
+  position: absolute;
+  z-index: 10;
+  display: none;
+  width: 300px;
+  padding: 1rem;
+  visibility: hidden;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  font-size: 1rem; }
+  .dropdown-pane.is-opening {
+    display: block; }
+  .dropdown-pane.is-open {
     display: block;
-    text-align: right; }
-    .menu.align-right.vertical li .submenu li {
-      text-align: right; }
-  .menu.align-right .nested {
-    margin-right: 1rem;
-    margin-left: 0; }
-  .menu.align-center li {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex;
-    -webkit-box-pack: center;
-    -webkit-justify-content: center;
-        -ms-flex-pack: center;
-            justify-content: center; }
-    .menu.align-center li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
-  .menu .menu-text {
-    padding: 0.7rem 1rem;
-    font-weight: bold;
-    line-height: 1;
-    color: inherit; }
+    visibility: visible; }
 
-.menu-centered > .menu {
-  -webkit-box-pack: center;
-  -webkit-justify-content: center;
-      -ms-flex-pack: center;
-          justify-content: center; }
-  .menu-centered > .menu li {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex;
-    -webkit-box-pack: center;
-    -webkit-justify-content: center;
-        -ms-flex-pack: center;
-            justify-content: center; }
-    .menu-centered > .menu li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
+.dropdown-pane.tiny {
+  width: 100px; }
+
+.dropdown-pane.small {
+  width: 200px; }
+
+.dropdown-pane.large {
+  width: 400px; }
+
+.pagination {
+  margin-left: 0;
+  margin-bottom: 1rem; }
+  .pagination::before, .pagination::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .pagination::after {
+    clear: both; }
+  .pagination li {
+    margin-right: 0.0625rem;
+    border-radius: 0;
+    font-size: 0.875rem;
+    display: none; }
+    .pagination li:last-child, .pagination li:first-child {
+      display: inline-block; }
+    @media print, screen and (min-width: 40em) {
+      .pagination li {
+        display: inline-block; } }
+  .pagination a,
+  .pagination button {
+    display: block;
+    padding: 0.1875rem 0.625rem;
+    border-radius: 0;
+    color: #0a0a0a; }
+    .pagination a:hover,
+    .pagination button:hover {
+      background: #e6e6e6; }
+  .pagination .current {
+    padding: 0.1875rem 0.625rem;
+    background: #1779ba;
+    color: #fefefe;
+    cursor: default; }
+  .pagination .disabled {
+    padding: 0.1875rem 0.625rem;
+    color: #cacaca;
+    cursor: not-allowed; }
+    .pagination .disabled:hover {
+      background: transparent; }
+  .pagination .ellipsis::after {
+    padding: 0.1875rem 0.625rem;
+    content: '\2026';
+    color: #0a0a0a; }
 
-.no-js [data-responsive-menu] ul {
-  display: none; }
+.pagination-previous a::before,
+.pagination-previous.disabled::before {
+  display: inline-block;
+  margin-right: 0.5rem;
+  content: '\00ab'; }
 
-.menu-icon {
-  position: relative;
+.pagination-next a::after,
+.pagination-next.disabled::after {
   display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer; }
-  .menu-icon::after {
-    position: absolute;
-    top: 0;
-    left: 0;
-    display: block;
-    width: 100%;
-    height: 2px;
-    background: #fefefe;
-    -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
-            box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
-    content: ''; }
-  .menu-icon:hover::after {
-    background: #cacaca;
-    -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
-            box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }
+  margin-left: 0.5rem;
+  content: '\00bb'; }
 
-.menu-icon.dark {
+.has-tip {
   position: relative;
   display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer; }
-  .menu-icon.dark::after {
-    position: absolute;
-    top: 0;
-    left: 0;
+  border-bottom: dotted 1px #8a8a8a;
+  font-weight: bold;
+  cursor: help; }
+
+.tooltip {
+  position: absolute;
+  top: calc(100% + 0.6495rem);
+  z-index: 1200;
+  max-width: 10rem;
+  padding: 0.75rem;
+  border-radius: 0;
+  background-color: #0a0a0a;
+  font-size: 80%;
+  color: #fefefe; }
+  .tooltip::before {
+    position: absolute; }
+  .tooltip.bottom::before {
     display: block;
-    width: 100%;
-    height: 2px;
-    background: #0a0a0a;
-    -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-            box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-    content: ''; }
-  .menu-icon.dark:hover::after {
-    background: #8a8a8a;
-    -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
-            box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-top-width: 0;
+    border-bottom-style: solid;
+    border-color: transparent transparent #0a0a0a;
+    bottom: 100%; }
+  .tooltip.bottom.align-center::before {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+  .tooltip.top::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #0a0a0a transparent transparent;
+    top: 100%;
+    bottom: auto; }
+  .tooltip.top.align-center::before {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+  .tooltip.left::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #0a0a0a;
+    left: 100%; }
+  .tooltip.left.align-center::before {
+    bottom: auto;
+    top: 50%;
+    -webkit-transform: translateY(-50%);
+        -ms-transform: translateY(-50%);
+            transform: translateY(-50%); }
+  .tooltip.right::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #0a0a0a transparent transparent;
+    right: 100%;
+    left: auto; }
+  .tooltip.right.align-center::before {
+    bottom: auto;
+    top: 50%;
+    -webkit-transform: translateY(-50%);
+        -ms-transform: translateY(-50%);
+            transform: translateY(-50%); }
+  .tooltip.align-top::before {
+    bottom: auto;
+    top: 10%; }
+  .tooltip.align-bottom::before {
+    bottom: 10%;
+    top: auto; }
+  .tooltip.align-left::before {
+    left: 10%;
+    right: auto; }
+  .tooltip.align-right::before {
+    left: auto;
+    right: 10%; }
 
-.is-drilldown {
-  position: relative;
-  overflow: hidden; }
-  .is-drilldown li {
-    display: block; }
-  .is-drilldown.animate-height {
-    -webkit-transition: height 0.5s;
-    transition: height 0.5s; }
+.accordion {
+  margin-left: 0;
+  background: #fefefe;
+  list-style-type: none; }
+  .accordion[disabled] .accordion-title {
+    cursor: not-allowed; }
 
-.drilldown a {
-  padding: 0.7rem 1rem;
-  background: #fefefe; }
+.accordion-item:first-child > :first-child {
+  border-radius: 0 0 0 0; }
 
-.drilldown .is-drilldown-submenu {
-  position: absolute;
-  top: 0;
-  left: 100%;
-  z-index: -1;
-  width: 100%;
-  background: #fefefe;
-  -webkit-transition: -webkit-transform 0.15s linear;
-  transition: -webkit-transform 0.15s linear;
-  transition: transform 0.15s linear;
-  transition: transform 0.15s linear, -webkit-transform 0.15s linear; }
-  .drilldown .is-drilldown-submenu.is-active {
-    z-index: 1;
-    display: block;
-    -webkit-transform: translateX(-100%);
-        -ms-transform: translateX(-100%);
-            transform: translateX(-100%); }
-  .drilldown .is-drilldown-submenu.is-closing {
-    -webkit-transform: translateX(100%);
-        -ms-transform: translateX(100%);
-            transform: translateX(100%); }
-  .drilldown .is-drilldown-submenu a {
-    padding: 0.7rem 1rem; }
+.accordion-item:last-child > :last-child {
+  border-radius: 0 0 0 0; }
+
+.accordion-title {
+  position: relative;
+  display: block;
+  padding: 1.25rem 1rem;
+  border: 1px solid #e6e6e6;
+  border-bottom: 0;
+  font-size: 0.75rem;
+  line-height: 1;
+  color: #1779ba; }
+  :last-child:not(.is-active) > .accordion-title {
+    border-bottom: 1px solid #e6e6e6;
+    border-radius: 0 0 0 0; }
+  .accordion-title:hover, .accordion-title:focus {
+    background-color: #e6e6e6; }
+  .accordion-title::before {
+    position: absolute;
+    top: 50%;
+    right: 1rem;
+    margin-top: -0.5rem;
+    content: '+'; }
+  .is-active > .accordion-title::before {
+    content: '\2013'; }
+
+.accordion-content {
+  display: none;
+  padding: 1rem;
+  border: 1px solid #e6e6e6;
+  border-bottom: 0;
+  background-color: #fefefe;
+  color: #0a0a0a; }
+  :last-child > .accordion-content:last-child {
+    border-bottom: 1px solid #e6e6e6; }
 
-.drilldown .nested.is-drilldown-submenu {
-  margin-right: 0;
-  margin-left: 0; }
+.media-object {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  margin-bottom: 1rem;
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap; }
+  .media-object img {
+    max-width: none; }
+  @media screen and (max-width: 39.99875em) {
+    .media-object.stack-for-small {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap; } }
 
-.drilldown .drilldown-submenu-cover-previous {
-  min-height: 100%; }
+.media-object-section {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 1 auto;
+      -ms-flex: 0 1 auto;
+          flex: 0 1 auto; }
+  .media-object-section:first-child {
+    padding-right: 1rem; }
+  .media-object-section:last-child:not(:nth-child(2)) {
+    padding-left: 1rem; }
+  .media-object-section > :last-child {
+    margin-bottom: 0; }
+  @media screen and (max-width: 39.99875em) {
+    .stack-for-small .media-object-section {
+      padding: 0;
+      padding-bottom: 1rem;
+      -webkit-flex-basis: 100%;
+          -ms-flex-preferred-size: 100%;
+              flex-basis: 100%;
+      max-width: 100%; }
+      .stack-for-small .media-object-section img {
+        width: 100%; } }
+  .media-object-section.main-section {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
 
-.drilldown .is-drilldown-submenu-parent > a {
+.orbit {
   position: relative; }
-  .drilldown .is-drilldown-submenu-parent > a::after {
-    position: absolute;
-    top: 50%;
-    margin-top: -6px;
-    right: 1rem;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; }
 
-.drilldown.align-left .is-drilldown-submenu-parent > a::after {
-  left: auto;
-  right: 1rem;
-  display: block;
-  width: 0;
+.orbit-container {
+  position: relative;
   height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba; }
+  margin: 0;
+  list-style: none;
+  overflow: hidden; }
 
-.drilldown.align-right .is-drilldown-submenu-parent > a::after {
-  right: auto;
-  left: 1rem;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent; }
+.orbit-slide {
+  width: 100%;
+  position: absolute; }
+  .orbit-slide.no-motionui.is-active {
+    top: 0;
+    left: 0; }
 
-.drilldown .js-drilldown-back > a::before {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent;
-  border-left-width: 0;
-  display: inline-block;
-  vertical-align: middle;
-  margin-right: 0.75rem;
-  border-left-width: 0; }
+.orbit-figure {
+  margin: 0; }
 
-.dropdown-pane {
+.orbit-image {
+  width: 100%;
+  max-width: 100%;
+  margin: 0; }
+
+.orbit-caption {
   position: absolute;
-  z-index: 10;
-  width: 300px;
+  bottom: 0;
+  width: 100%;
+  margin-bottom: 0;
   padding: 1rem;
-  visibility: hidden;
-  display: none;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  font-size: 1rem; }
-  .dropdown-pane.is-opening {
-    display: block; }
-  .dropdown-pane.is-open {
-    visibility: visible;
-    display: block; }
-
-.dropdown-pane.tiny {
-  width: 100px; }
-
-.dropdown-pane.small {
-  width: 200px; }
-
-.dropdown-pane.large {
-  width: 400px; }
+  background-color: rgba(10, 10, 10, 0.5);
+  color: #fefefe; }
 
-.dropdown.menu > li.opens-left > .is-dropdown-submenu {
-  top: 100%;
-  right: 0;
-  left: auto; }
+.orbit-previous, .orbit-next {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%);
+  z-index: 10;
+  padding: 1rem;
+  color: #fefefe; }
+  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
+    outline: 0; }
+  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {
+    background-color: rgba(10, 10, 10, 0.5); }
 
-.dropdown.menu > li.opens-right > .is-dropdown-submenu {
-  top: 100%;
-  right: auto;
+.orbit-previous {
   left: 0; }
 
-.dropdown.menu > li.is-dropdown-submenu-parent > a {
-  position: relative;
-  padding-right: 1.5rem; }
-
-.dropdown.menu > li.is-dropdown-submenu-parent > a::after {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-bottom-width: 0;
-  border-top-style: solid;
-  border-color: #1779ba transparent transparent;
-  right: 5px;
+.orbit-next {
   left: auto;
-  margin-top: -3px; }
+  right: 0; }
 
-.dropdown.menu a {
-  padding: 0.7rem 1rem; }
-  [data-whatinput='mouse'] .dropdown.menu a {
+.orbit-bullets {
+  position: relative;
+  margin-top: 0.8rem;
+  margin-bottom: 0.8rem;
+  text-align: center; }
+  [data-whatinput='mouse'] .orbit-bullets {
     outline: 0; }
+  .orbit-bullets button {
+    width: 1.2rem;
+    height: 1.2rem;
+    margin: 0.1rem;
+    border-radius: 50%;
+    background-color: #cacaca; }
+    .orbit-bullets button:hover {
+      background-color: #8a8a8a; }
+    .orbit-bullets button.is-active {
+      background-color: #8a8a8a; }
 
-.dropdown.menu .is-active > a {
-  background: transparent;
-  color: #1779ba; }
+.responsive-embed,
+.flex-video {
+  position: relative;
+  height: 0;
+  margin-bottom: 1rem;
+  padding-bottom: 75%;
+  overflow: hidden; }
+  .responsive-embed iframe,
+  .responsive-embed object,
+  .responsive-embed embed,
+  .responsive-embed video,
+  .flex-video iframe,
+  .flex-video object,
+  .flex-video embed,
+  .flex-video video {
+    position: absolute;
+    top: 0;
+    left: 0;
+    width: 100%;
+    height: 100%; }
+  .responsive-embed.widescreen,
+  .flex-video.widescreen {
+    padding-bottom: 56.25%; }
 
-.no-js .dropdown.menu ul {
-  display: none; }
+.tabs {
+  margin: 0;
+  border: 1px solid #e6e6e6;
+  background: #fefefe;
+  list-style-type: none; }
+  .tabs::before, .tabs::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .tabs::after {
+    clear: both; }
 
-.dropdown.menu .nested.is-dropdown-submenu {
-  margin-right: 0;
-  margin-left: 0; }
+.tabs.vertical > li {
+  display: block;
+  float: none;
+  width: auto; }
 
-.dropdown.menu.vertical > li .is-dropdown-submenu {
-  top: 0; }
+.tabs.simple > li > a {
+  padding: 0; }
+  .tabs.simple > li > a:hover {
+    background: transparent; }
+
+.tabs.primary {
+  background: #1779ba; }
+  .tabs.primary > li > a {
+    color: #fefefe; }
+    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
+      background: #1673b1; }
 
-.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {
-  right: 100%;
-  left: auto;
-  top: 0; }
+.tabs-title {
+  float: left; }
+  .tabs-title > a {
+    display: block;
+    padding: 1.25rem 1.5rem;
+    font-size: 0.75rem;
+    line-height: 1;
+    color: #1779ba; }
+    [data-whatinput='mouse'] .tabs-title > a {
+      outline: 0; }
+    .tabs-title > a:hover {
+      background: #fefefe;
+      color: #1468a0; }
+    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {
+      background: #e6e6e6;
+      color: #1779ba; }
 
-.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {
-  right: auto;
-  left: 100%; }
+.tabs-content {
+  border: 1px solid #e6e6e6;
+  border-top: 0;
+  background: #fefefe;
+  color: #0a0a0a;
+  -webkit-transition: all 0.5s ease;
+  transition: all 0.5s ease; }
 
-.dropdown.menu.vertical > li > a::after {
-  right: 14px; }
+.tabs-content.vertical {
+  border: 1px solid #e6e6e6;
+  border-left: 0; }
 
-.dropdown.menu.vertical > li.opens-left > a::after {
-  right: auto;
-  left: 5px;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent; }
+.tabs-panel {
+  display: none;
+  padding: 1rem; }
+  .tabs-panel.is-active {
+    display: block; }
 
-.dropdown.menu.vertical > li.opens-right > a::after {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba; }
+.thumbnail {
+  display: inline-block;
+  max-width: 100%;
+  margin-bottom: 1rem;
+  border: 4px solid #fefefe;
+  border-radius: 0;
+  -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
+          box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
+  line-height: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {
-    top: 100%;
-    right: 0;
-    left: auto; }
-  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
-    top: 100%;
-    right: auto;
-    left: 0; }
-  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {
-    position: relative;
-    padding-right: 1.5rem; }
-  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    right: 5px;
-    left: auto;
-    margin-top: -3px; }
-  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {
-    top: 0; }
-  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto;
-    top: 0; }
-  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
-  .dropdown.menu.medium-vertical > li > a::after {
-    right: 14px; }
-  .dropdown.menu.medium-vertical > li.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .dropdown.menu.medium-vertical > li.opens-right > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; } }
+a.thumbnail {
+  -webkit-transition: -webkit-box-shadow 200ms ease-out;
+  transition: -webkit-box-shadow 200ms ease-out;
+  transition: box-shadow 200ms ease-out;
+  transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; }
+  a.thumbnail:hover, a.thumbnail:focus {
+    -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
+            box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }
+  a.thumbnail image {
+    -webkit-box-shadow: none;
+            box-shadow: none; }
 
-@media print, screen and (min-width: 64em) {
-  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {
-    top: 100%;
-    right: 0;
-    left: auto; }
-  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {
-    top: 100%;
-    right: auto;
-    left: 0; }
-  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {
-    position: relative;
-    padding-right: 1.5rem; }
-  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    right: 5px;
-    left: auto;
-    margin-top: -3px; }
-  .dropdown.menu.large-vertical > li .is-dropdown-submenu {
-    top: 0; }
-  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto;
-    top: 0; }
-  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
-  .dropdown.menu.large-vertical > li > a::after {
-    right: 14px; }
-  .dropdown.menu.large-vertical > li.opens-left > a::after {
-    right: auto;
-    left: 5px;
+.menu {
+  padding: 0;
+  margin: 0;
+  list-style: none;
+  position: relative;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-flex-wrap: wrap;
+      -ms-flex-wrap: wrap;
+          flex-wrap: wrap; }
+  [data-whatinput='mouse'] .menu li {
+    outline: 0; }
+  .menu a,
+  .menu .button {
+    line-height: 1;
+    text-decoration: none;
     display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .dropdown.menu.large-vertical > li.opens-right > a::after {
+    padding: 0.7rem 1rem; }
+  .menu input,
+  .menu select,
+  .menu a,
+  .menu button {
+    margin-bottom: 0; }
+  .menu input {
+    display: inline-block; }
+  .menu, .menu.horizontal {
+    -webkit-flex-wrap: wrap;
+        -ms-flex-wrap: wrap;
+            flex-wrap: wrap;
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: row;
+        -ms-flex-direction: row;
+            flex-direction: row; }
+  .menu.vertical {
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: column;
+        -ms-flex-direction: column;
+            flex-direction: column; }
+  .menu.expanded li {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
+  .menu.simple {
+    -webkit-box-align: center;
+    -webkit-align-items: center;
+        -ms-flex-align: center;
+            align-items: center; }
+    .menu.simple li + li {
+      margin-left: 1rem; }
+    .menu.simple a {
+      padding: 0; }
+  @media print, screen and (min-width: 40em) {
+    .menu.medium-horizontal {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap;
+      -webkit-box-orient: horizontal;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: row;
+          -ms-flex-direction: row;
+              flex-direction: row; }
+    .menu.medium-vertical {
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap;
+      -webkit-box-orient: vertical;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: column;
+          -ms-flex-direction: column;
+              flex-direction: column; }
+    .menu.medium-expanded li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; }
+    .menu.medium-simple li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; } }
+  @media print, screen and (min-width: 64em) {
+    .menu.large-horizontal {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap;
+      -webkit-box-orient: horizontal;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: row;
+          -ms-flex-direction: row;
+              flex-direction: row; }
+    .menu.large-vertical {
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap;
+      -webkit-box-orient: vertical;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: column;
+          -ms-flex-direction: column;
+              flex-direction: column; }
+    .menu.large-expanded li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; }
+    .menu.large-simple li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; } }
+  .menu.nested {
+    margin-right: 0;
+    margin-left: 1rem; }
+  .menu.icons a {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex; }
+  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex; }
+  .menu.icon-left li a {
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: row nowrap;
+        -ms-flex-flow: row nowrap;
+            flex-flow: row nowrap; }
+    .menu.icon-left li a img,
+    .menu.icon-left li a i,
+    .menu.icon-left li a svg {
+      margin-right: 0.25rem; }
+  .menu.icon-right li a {
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: row nowrap;
+        -ms-flex-flow: row nowrap;
+            flex-flow: row nowrap; }
+    .menu.icon-right li a img,
+    .menu.icon-right li a i,
+    .menu.icon-right li a svg {
+      margin-left: 0.25rem; }
+  .menu.icon-top li a {
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: column nowrap;
+        -ms-flex-flow: column nowrap;
+            flex-flow: column nowrap; }
+    .menu.icon-top li a img,
+    .menu.icon-top li a i,
+    .menu.icon-top li a svg {
+      -webkit-align-self: stretch;
+          -ms-flex-item-align: stretch;
+              align-self: stretch;
+      margin-bottom: 0.25rem;
+      text-align: center; }
+  .menu.icon-bottom li a {
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: column nowrap;
+        -ms-flex-flow: column nowrap;
+            flex-flow: column nowrap; }
+    .menu.icon-bottom li a img,
+    .menu.icon-bottom li a i,
+    .menu.icon-bottom li a svg {
+      -webkit-align-self: stretch;
+          -ms-flex-item-align: stretch;
+              align-self: stretch;
+      margin-bottom: 0.25rem;
+      text-align: center; }
+  .menu .is-active > a {
+    background: #1779ba;
+    color: #fefefe; }
+  .menu .active > a {
+    background: #1779ba;
+    color: #fefefe; }
+  .menu.align-left {
+    -webkit-box-pack: start;
+    -webkit-justify-content: flex-start;
+        -ms-flex-pack: start;
+            justify-content: flex-start; }
+  .menu.align-right li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: end;
+    -webkit-justify-content: flex-end;
+        -ms-flex-pack: end;
+            justify-content: flex-end; }
+    .menu.align-right li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
+  .menu.align-right.vertical li {
     display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; } }
-
-.dropdown.menu.align-right .is-dropdown-submenu.first-sub {
-  top: 100%;
-  right: 0;
-  left: auto; }
-
-.is-dropdown-menu.vertical {
-  width: 100px; }
-  .is-dropdown-menu.vertical.align-right {
-    float: right; }
+    text-align: right; }
+    .menu.align-right.vertical li .submenu li {
+      text-align: right; }
+  .menu.align-right .nested {
+    margin-right: 1rem;
+    margin-left: 0; }
+  .menu.align-center li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: center;
+    -webkit-justify-content: center;
+        -ms-flex-pack: center;
+            justify-content: center; }
+    .menu.align-center li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
+  .menu .menu-text {
+    padding: 0.7rem 1rem;
+    font-weight: bold;
+    line-height: 1;
+    color: inherit; }
 
-.is-dropdown-submenu-parent {
-  position: relative; }
-  .is-dropdown-submenu-parent a::after {
-    position: absolute;
-    top: 50%;
-    right: 5px;
-    left: auto;
-    margin-top: -6px; }
-  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {
-    top: 100%;
-    left: auto; }
-  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto; }
-  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
+.menu-centered > .menu {
+  -webkit-box-pack: center;
+  -webkit-justify-content: center;
+      -ms-flex-pack: center;
+          justify-content: center; }
+  .menu-centered > .menu li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: center;
+    -webkit-justify-content: center;
+        -ms-flex-pack: center;
+            justify-content: center; }
+    .menu-centered > .menu li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
 
-.is-dropdown-submenu {
-  position: absolute;
-  top: 0;
-  left: 100%;
-  z-index: 1;
-  display: none;
-  min-width: 200px;
-  border: 1px solid #cacaca;
-  background: #fefefe; }
-  .dropdown .is-dropdown-submenu a {
-    padding: 0.7rem 1rem; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {
-    right: 14px; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; }
-  .is-dropdown-submenu .is-dropdown-submenu {
-    margin-top: -1px; }
-  .is-dropdown-submenu > li {
-    width: 100%; }
-  .is-dropdown-submenu.js-dropdown-active {
-    display: block; }
+.no-js [data-responsive-menu] ul {
+  display: none; }
 
-.responsive-embed,
-.flex-video {
+.menu-icon {
   position: relative;
-  height: 0;
-  margin-bottom: 1rem;
-  padding-bottom: 75%;
-  overflow: hidden; }
-  .responsive-embed iframe,
-  .responsive-embed object,
-  .responsive-embed embed,
-  .responsive-embed video,
-  .flex-video iframe,
-  .flex-video object,
-  .flex-video embed,
-  .flex-video video {
+  display: inline-block;
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
+  cursor: pointer; }
+  .menu-icon::after {
     position: absolute;
     top: 0;
     left: 0;
+    display: block;
     width: 100%;
-    height: 100%; }
-  .responsive-embed.widescreen,
-  .flex-video.widescreen {
-    padding-bottom: 56.25%; }
+    height: 2px;
+    background: #fefefe;
+    -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+            box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+    content: ''; }
+  .menu-icon:hover::after {
+    background: #cacaca;
+    -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
+            box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }
 
-.label {
+.menu-icon.dark {
+  position: relative;
   display: inline-block;
-  padding: 0.33333rem 0.5rem;
-  border-radius: 0;
-  font-size: 0.8rem;
-  line-height: 1;
-  white-space: nowrap;
-  cursor: default;
-  background: #1779ba;
-  color: #fefefe; }
-  .label.primary {
-    background: #1779ba;
-    color: #fefefe; }
-  .label.secondary {
-    background: #767676;
-    color: #fefefe; }
-  .label.success {
-    background: #3adb76;
-    color: #0a0a0a; }
-  .label.warning {
-    background: #ffae00;
-    color: #0a0a0a; }
-  .label.alert {
-    background: #cc4b37;
-    color: #fefefe; }
-
-.media-object {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  margin-bottom: 1rem;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap; }
-  .media-object img {
-    max-width: none; }
-  @media screen and (max-width: 39.9375em) {
-    .media-object.stack-for-small {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap; } }
-  @media screen and (max-width: 39.9375em) {
-    .media-object.stack-for-small .media-object-section {
-      padding: 0;
-      padding-bottom: 1rem;
-      -webkit-flex-basis: 100%;
-          -ms-flex-preferred-size: 100%;
-              flex-basis: 100%;
-      max-width: 100%; }
-      .media-object.stack-for-small .media-object-section img {
-        width: 100%; } }
-
-.media-object-section {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 1 auto;
-      -ms-flex: 0 1 auto;
-          flex: 0 1 auto; }
-  .media-object-section:first-child {
-    padding-right: 1rem; }
-  .media-object-section:last-child:not(:nth-child(2)) {
-    padding-left: 1rem; }
-  .media-object-section > :last-child {
-    margin-bottom: 0; }
-  .media-object-section.main-section {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-
-.is-off-canvas-open {
-  overflow: hidden; }
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
+  cursor: pointer; }
+  .menu-icon.dark::after {
+    position: absolute;
+    top: 0;
+    left: 0;
+    display: block;
+    width: 100%;
+    height: 2px;
+    background: #0a0a0a;
+    -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
+            box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
+    content: ''; }
+  .menu-icon.dark:hover::after {
+    background: #8a8a8a;
+    -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
+            box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }
 
-.js-off-canvas-overlay {
-  position: absolute;
-  top: 0;
-  left: 0;
-  z-index: 11;
-  width: 100%;
-  height: 100%;
-  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
-  transition: opacity 0.5s ease, visibility 0.5s ease;
-  background: rgba(254, 254, 254, 0.25);
-  opacity: 0;
-  visibility: hidden;
-  overflow: hidden; }
-  .js-off-canvas-overlay.is-visible {
-    opacity: 1;
-    visibility: visible; }
-  .js-off-canvas-overlay.is-closable {
-    cursor: pointer; }
-  .js-off-canvas-overlay.is-overlay-absolute {
-    position: absolute; }
-  .js-off-canvas-overlay.is-overlay-fixed {
-    position: fixed; }
+.accordion-menu li {
+  width: 100%; }
 
-.off-canvas-wrapper {
-  position: relative;
-  overflow: hidden; }
+.accordion-menu a {
+  padding: 0.7rem 1rem; }
 
-.off-canvas {
-  position: fixed;
-  z-index: 12;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  background: #e6e6e6; }
-  [data-whatinput='mouse'] .off-canvas {
-    outline: 0; }
-  .off-canvas.is-transition-push {
-    z-index: 12; }
-  .off-canvas.is-closed {
-    visibility: hidden; }
-  .off-canvas.is-transition-overlap {
-    z-index: 13; }
-    .off-canvas.is-transition-overlap.is-open {
-      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
-              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
-  .off-canvas.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
+.accordion-menu .is-accordion-submenu a {
+  padding: 0.7rem 1rem; }
 
-.off-canvas-absolute {
-  position: absolute;
-  z-index: 12;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  background: #e6e6e6; }
-  [data-whatinput='mouse'] .off-canvas-absolute {
-    outline: 0; }
-  .off-canvas-absolute.is-transition-push {
-    z-index: 12; }
-  .off-canvas-absolute.is-closed {
-    visibility: hidden; }
-  .off-canvas-absolute.is-transition-overlap {
-    z-index: 13; }
-    .off-canvas-absolute.is-transition-overlap.is-open {
-      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
-              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
-  .off-canvas-absolute.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
+.accordion-menu .nested.is-accordion-submenu {
+  margin-right: 0;
+  margin-left: 1rem; }
 
-.position-left {
-  top: 0;
-  left: 0;
-  height: 100%;
-  overflow-y: auto;
-  width: 250px;
-  -webkit-transform: translateX(-250px);
-      -ms-transform: translateX(-250px);
-          transform: translateX(-250px); }
-  .off-canvas-content .off-canvas.position-left {
-    -webkit-transform: translateX(-250px);
-        -ms-transform: translateX(-250px);
-            transform: translateX(-250px); }
-    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-left.has-transition-push {
-    -webkit-transform: translateX(250px);
-        -ms-transform: translateX(250px);
-            transform: translateX(250px); }
-  .position-left.is-transition-push {
-    -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }
+.accordion-menu.align-right .nested.is-accordion-submenu {
+  margin-right: 1rem;
+  margin-left: 0; }
 
-.position-right {
-  top: 0;
-  right: 0;
-  height: 100%;
-  overflow-y: auto;
-  width: 250px;
-  -webkit-transform: translateX(250px);
-      -ms-transform: translateX(250px);
-          transform: translateX(250px); }
-  .off-canvas-content .off-canvas.position-right {
-    -webkit-transform: translateX(250px);
-        -ms-transform: translateX(250px);
-            transform: translateX(250px); }
-    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-right.has-transition-push {
-    -webkit-transform: translateX(-250px);
-        -ms-transform: translateX(-250px);
-            transform: translateX(-250px); }
-  .position-right.is-transition-push {
-    -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }
+.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {
+  position: relative; }
+  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    position: absolute;
+    top: 50%;
+    margin-top: -3px;
+    right: 1rem; }
 
-.position-top {
-  top: 0;
-  left: 0;
-  width: 100%;
-  overflow-x: auto;
-  height: 250px;
-  -webkit-transform: translateY(-250px);
-      -ms-transform: translateY(-250px);
-          transform: translateY(-250px); }
-  .off-canvas-content .off-canvas.position-top {
-    -webkit-transform: translateY(-250px);
-        -ms-transform: translateY(-250px);
-            transform: translateY(-250px); }
-    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-top.has-transition-push {
-    -webkit-transform: translateY(250px);
-        -ms-transform: translateY(250px);
-            transform: translateY(250px); }
-  .position-top.is-transition-push {
-    -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }
+.accordion-menu.align-left .is-accordion-submenu-parent > a::after {
+  right: 1rem;
+  left: auto; }
 
-.position-bottom {
-  bottom: 0;
-  left: 0;
-  width: 100%;
-  overflow-x: auto;
-  height: 250px;
-  -webkit-transform: translateY(250px);
-      -ms-transform: translateY(250px);
-          transform: translateY(250px); }
-  .off-canvas-content .off-canvas.position-bottom {
-    -webkit-transform: translateY(250px);
-        -ms-transform: translateY(250px);
-            transform: translateY(250px); }
-    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-bottom.has-transition-push {
-    -webkit-transform: translateY(-250px);
-        -ms-transform: translateY(-250px);
-            transform: translateY(-250px); }
-  .position-bottom.is-transition-push {
-    -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }
+.accordion-menu.align-right .is-accordion-submenu-parent > a::after {
+  right: auto;
+  left: 1rem; }
 
-.off-canvas-content {
-  -webkit-transform: none;
-      -ms-transform: none;
-          transform: none;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden; }
-  .off-canvas-content.has-transition-push {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
-  .off-canvas-content .off-canvas.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
+.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {
+  -webkit-transform: rotate(180deg);
+      -ms-transform: rotate(180deg);
+          transform: rotate(180deg);
+  -webkit-transform-origin: 50% 50%;
+      -ms-transform-origin: 50% 50%;
+          transform-origin: 50% 50%; }
 
-@media print, screen and (min-width: 40em) {
-  .position-left.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-left.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-left.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-left {
-      margin-left: 250px; }
-    .position-left.reveal-for-medium ~ .off-canvas-content {
-      margin-left: 250px; }
-  .position-right.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-right.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-right.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-right {
-      margin-right: 250px; }
-    .position-right.reveal-for-medium ~ .off-canvas-content {
-      margin-right: 250px; }
-  .position-top.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-top.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-top.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-top {
-      margin-top: 250px; }
-    .position-top.reveal-for-medium ~ .off-canvas-content {
-      margin-top: 250px; }
-  .position-bottom.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-bottom.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-bottom.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-bottom {
-      margin-bottom: 250px; }
-    .position-bottom.reveal-for-medium ~ .off-canvas-content {
-      margin-bottom: 250px; } }
+.is-accordion-submenu-parent {
+  position: relative; }
 
-@media print, screen and (min-width: 64em) {
-  .position-left.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-left.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-left.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-left {
-      margin-left: 250px; }
-    .position-left.reveal-for-large ~ .off-canvas-content {
-      margin-left: 250px; }
-  .position-right.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-right.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-right.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-right {
-      margin-right: 250px; }
-    .position-right.reveal-for-large ~ .off-canvas-content {
-      margin-right: 250px; }
-  .position-top.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-top.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-top.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-top {
-      margin-top: 250px; }
-    .position-top.reveal-for-large ~ .off-canvas-content {
-      margin-top: 250px; }
-  .position-bottom.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-bottom.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-bottom.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-bottom {
-      margin-bottom: 250px; }
-    .position-bottom.reveal-for-large ~ .off-canvas-content {
-      margin-bottom: 250px; } }
+.has-submenu-toggle > a {
+  margin-right: 40px; }
 
-@media print, screen and (min-width: 40em) {
-  .off-canvas.in-canvas-for-medium {
-    visibility: visible;
-    height: auto;
-    position: static;
-    background: inherit;
-    width: inherit;
-    overflow: inherit;
-    -webkit-transition: inherit;
-    transition: inherit; }
-    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {
-      -webkit-box-shadow: none;
-              box-shadow: none;
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas.in-canvas-for-medium .close-button {
-      display: none; } }
+.submenu-toggle {
+  position: absolute;
+  top: 0;
+  right: 0;
+  width: 40px;
+  height: 40px;
+  cursor: pointer; }
+  .submenu-toggle::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    top: 0;
+    bottom: 0;
+    margin: auto; }
 
-@media print, screen and (min-width: 64em) {
-  .off-canvas.in-canvas-for-large {
-    visibility: visible;
-    height: auto;
-    position: static;
-    background: inherit;
-    width: inherit;
-    overflow: inherit;
-    -webkit-transition: inherit;
-    transition: inherit; }
-    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {
-      -webkit-box-shadow: none;
-              box-shadow: none;
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas.in-canvas-for-large .close-button {
-      display: none; } }
+.submenu-toggle[aria-expanded='true']::after {
+  -webkit-transform: scaleY(-1);
+      -ms-transform: scaleY(-1);
+          transform: scaleY(-1);
+  -webkit-transform-origin: 50% 50%;
+      -ms-transform-origin: 50% 50%;
+          transform-origin: 50% 50%; }
 
-.orbit {
-  position: relative; }
+.submenu-toggle-text {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  padding: 0;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
+  white-space: nowrap;
+  border: 0; }
 
-.orbit-container {
+.is-drilldown {
   position: relative;
-  height: 0;
-  margin: 0;
-  list-style: none;
   overflow: hidden; }
+  .is-drilldown li {
+    display: block; }
+  .is-drilldown.animate-height {
+    -webkit-transition: height 0.5s;
+    transition: height 0.5s; }
 
-.orbit-slide {
-  width: 100%; }
-  .orbit-slide.no-motionui.is-active {
-    top: 0;
-    left: 0; }
-
-.orbit-figure {
-  margin: 0; }
-
-.orbit-image {
-  width: 100%;
-  max-width: 100%;
-  margin: 0; }
+.drilldown a {
+  padding: 0.7rem 1rem;
+  background: #fefefe; }
 
-.orbit-caption {
+.drilldown .is-drilldown-submenu {
   position: absolute;
-  bottom: 0;
+  top: 0;
+  left: 100%;
+  z-index: -1;
   width: 100%;
-  margin-bottom: 0;
-  padding: 1rem;
-  background-color: rgba(10, 10, 10, 0.5);
-  color: #fefefe; }
+  background: #fefefe;
+  -webkit-transition: -webkit-transform 0.15s linear;
+  transition: -webkit-transform 0.15s linear;
+  transition: transform 0.15s linear;
+  transition: transform 0.15s linear, -webkit-transform 0.15s linear; }
+  .drilldown .is-drilldown-submenu.is-active {
+    z-index: 1;
+    display: block;
+    -webkit-transform: translateX(-100%);
+        -ms-transform: translateX(-100%);
+            transform: translateX(-100%); }
+  .drilldown .is-drilldown-submenu.is-closing {
+    -webkit-transform: translateX(100%);
+        -ms-transform: translateX(100%);
+            transform: translateX(100%); }
+  .drilldown .is-drilldown-submenu a {
+    padding: 0.7rem 1rem; }
 
-.orbit-previous, .orbit-next {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%);
-  z-index: 10;
-  padding: 1rem;
-  color: #fefefe; }
-  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
-    outline: 0; }
-  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {
-    background-color: rgba(10, 10, 10, 0.5); }
+.drilldown .nested.is-drilldown-submenu {
+  margin-right: 0;
+  margin-left: 0; }
 
-.orbit-previous {
-  left: 0; }
+.drilldown .drilldown-submenu-cover-previous {
+  min-height: 100%; }
 
-.orbit-next {
-  left: auto;
-  right: 0; }
+.drilldown .is-drilldown-submenu-parent > a {
+  position: relative; }
+  .drilldown .is-drilldown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba;
+    position: absolute;
+    top: 50%;
+    margin-top: -6px;
+    right: 1rem; }
 
-.orbit-bullets {
-  position: relative;
-  margin-top: 0.8rem;
-  margin-bottom: 0.8rem;
-  text-align: center; }
-  [data-whatinput='mouse'] .orbit-bullets {
-    outline: 0; }
-  .orbit-bullets button {
-    width: 1.2rem;
-    height: 1.2rem;
-    margin: 0.1rem;
-    border-radius: 50%;
-    background-color: #cacaca; }
-    .orbit-bullets button:hover {
-      background-color: #8a8a8a; }
-    .orbit-bullets button.is-active {
-      background-color: #8a8a8a; }
+.drilldown.align-left .is-drilldown-submenu-parent > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba;
+  right: 1rem;
+  left: auto; }
 
-.pagination {
-  margin-left: 0;
-  margin-bottom: 1rem; }
-  .pagination::before, .pagination::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .pagination::after {
-    clear: both; }
-  .pagination li {
-    margin-right: 0.0625rem;
-    border-radius: 0;
-    font-size: 0.875rem;
-    display: none; }
-    .pagination li:last-child, .pagination li:first-child {
-      display: inline-block; }
-    @media print, screen and (min-width: 40em) {
-      .pagination li {
-        display: inline-block; } }
-  .pagination a,
-  .pagination button {
-    display: block;
-    padding: 0.1875rem 0.625rem;
-    border-radius: 0;
-    color: #0a0a0a; }
-    .pagination a:hover,
-    .pagination button:hover {
-      background: #e6e6e6; }
-  .pagination .current {
-    padding: 0.1875rem 0.625rem;
-    background: #1779ba;
-    color: #fefefe;
-    cursor: default; }
-  .pagination .disabled {
-    padding: 0.1875rem 0.625rem;
-    color: #cacaca;
-    cursor: not-allowed; }
-    .pagination .disabled:hover {
-      background: transparent; }
-  .pagination .ellipsis::after {
-    padding: 0.1875rem 0.625rem;
-    content: '\2026';
-    color: #0a0a0a; }
+.drilldown.align-right .is-drilldown-submenu-parent > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  right: auto;
+  left: 1rem; }
 
-.pagination-previous a::before,
-.pagination-previous.disabled::before {
+.drilldown .js-drilldown-back > a::before {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
   display: inline-block;
-  margin-right: 0.5rem;
-  content: '\00ab'; }
+  vertical-align: middle;
+  margin-right: 0.75rem; }
 
-.pagination-next a::after,
-.pagination-next.disabled::after {
-  display: inline-block;
-  margin-left: 0.5rem;
-  content: '\00bb'; }
+.dropdown.menu > li.opens-left > .is-dropdown-submenu {
+  top: 100%;
+  right: 0;
+  left: auto; }
 
-.progress {
-  height: 1rem;
-  margin-bottom: 1rem;
-  border-radius: 0;
-  background-color: #cacaca; }
-  .progress.primary .progress-meter {
-    background-color: #1779ba; }
-  .progress.secondary .progress-meter {
-    background-color: #767676; }
-  .progress.success .progress-meter {
-    background-color: #3adb76; }
-  .progress.warning .progress-meter {
-    background-color: #ffae00; }
-  .progress.alert .progress-meter {
-    background-color: #cc4b37; }
+.dropdown.menu > li.opens-right > .is-dropdown-submenu {
+  top: 100%;
+  right: auto;
+  left: 0; }
 
-.progress-meter {
+.dropdown.menu > li.is-dropdown-submenu-parent > a {
   position: relative;
+  padding-right: 1.5rem; }
+
+.dropdown.menu > li.is-dropdown-submenu-parent > a::after {
   display: block;
-  width: 0%;
-  height: 100%;
-  background-color: #1779ba; }
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-bottom-width: 0;
+  border-top-style: solid;
+  border-color: #1779ba transparent transparent;
+  right: 5px;
+  left: auto;
+  margin-top: -3px; }
 
-.progress-meter-text {
-  position: absolute;
-  top: 50%;
-  left: 50%;
-  -webkit-transform: translate(-50%, -50%);
-      -ms-transform: translate(-50%, -50%);
-          transform: translate(-50%, -50%);
-  position: absolute;
-  margin: 0;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #fefefe;
-  white-space: nowrap; }
+[data-whatinput='mouse'] .dropdown.menu a {
+  outline: 0; }
 
-.slider {
-  position: relative;
-  height: 0.5rem;
-  margin-top: 1.25rem;
-  margin-bottom: 2.25rem;
-  background-color: #e6e6e6;
-  cursor: pointer;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none;
-  -ms-touch-action: none;
-      touch-action: none; }
+.dropdown.menu > li > a {
+  padding: 0.7rem 1rem; }
 
-.slider-fill {
-  position: absolute;
+.dropdown.menu > li.is-active > a {
+  background: transparent;
+  color: #1779ba; }
+
+.no-js .dropdown.menu ul {
+  display: none; }
+
+.dropdown.menu .nested.is-dropdown-submenu {
+  margin-right: 0;
+  margin-left: 0; }
+
+.dropdown.menu.vertical > li .is-dropdown-submenu {
+  top: 0; }
+
+.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {
   top: 0;
-  left: 0;
-  display: inline-block;
-  max-width: 100%;
-  height: 0.5rem;
-  background-color: #cacaca;
-  -webkit-transition: all 0.2s ease-in-out;
-  transition: all 0.2s ease-in-out; }
-  .slider-fill.is-dragging {
-    -webkit-transition: all 0s linear;
-    transition: all 0s linear; }
+  right: 100%;
+  left: auto; }
 
-.slider-handle {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%);
-  left: 0;
-  z-index: 1;
-  display: inline-block;
-  width: 1.4rem;
-  height: 1.4rem;
-  border-radius: 0;
-  background-color: #1779ba;
-  -webkit-transition: all 0.2s ease-in-out;
-  transition: all 0.2s ease-in-out;
-  -ms-touch-action: manipulation;
-      touch-action: manipulation; }
-  [data-whatinput='mouse'] .slider-handle {
-    outline: 0; }
-  .slider-handle:hover {
-    background-color: #14679e; }
-  .slider-handle.is-dragging {
-    -webkit-transition: all 0s linear;
-    transition: all 0s linear; }
+.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {
+  right: auto;
+  left: 100%; }
 
-.slider.disabled,
-.slider[disabled] {
-  opacity: 0.25;
-  cursor: not-allowed; }
+.dropdown.menu.vertical > li > a::after {
+  right: 14px; }
 
-.slider.vertical {
-  display: inline-block;
-  width: 0.5rem;
-  height: 12.5rem;
-  margin: 0 1.25rem;
-  -webkit-transform: scale(1, -1);
-      -ms-transform: scale(1, -1);
-          transform: scale(1, -1); }
-  .slider.vertical .slider-fill {
-    top: 0;
-    width: 0.5rem;
-    max-height: 100%; }
-  .slider.vertical .slider-handle {
-    position: absolute;
-    top: 0;
-    left: 50%;
-    width: 1.4rem;
-    height: 1.4rem;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
+.dropdown.menu.vertical > li.opens-left > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  right: auto;
+  left: 5px; }
 
-.sticky-container {
-  position: relative; }
+.dropdown.menu.vertical > li.opens-right > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba; }
 
-.sticky {
-  position: relative;
-  z-index: 0;
-  -webkit-transform: translate3d(0, 0, 0);
-          transform: translate3d(0, 0, 0); }
+@media print, screen and (min-width: 40em) {
+  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {
+    top: 100%;
+    right: 0;
+    left: auto; }
+  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
+    top: 100%;
+    right: auto;
+    left: 0; }
+  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {
+    position: relative;
+    padding-right: 1.5rem; }
+  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    right: 5px;
+    left: auto;
+    margin-top: -3px; }
+  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {
+    top: 0; }
+  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {
+    top: 0;
+    right: 100%;
+    left: auto; }
+  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
+  .dropdown.menu.medium-vertical > li > a::after {
+    right: 14px; }
+  .dropdown.menu.medium-vertical > li.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .dropdown.menu.medium-vertical > li.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; } }
 
-.sticky.is-stuck {
-  position: fixed;
-  z-index: 5;
-  width: 100%; }
-  .sticky.is-stuck.is-at-top {
+@media print, screen and (min-width: 64em) {
+  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {
+    top: 100%;
+    right: 0;
+    left: auto; }
+  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {
+    top: 100%;
+    right: auto;
+    left: 0; }
+  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {
+    position: relative;
+    padding-right: 1.5rem; }
+  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    right: 5px;
+    left: auto;
+    margin-top: -3px; }
+  .dropdown.menu.large-vertical > li .is-dropdown-submenu {
     top: 0; }
-  .sticky.is-stuck.is-at-bottom {
-    bottom: 0; }
+  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {
+    top: 0;
+    right: 100%;
+    left: auto; }
+  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
+  .dropdown.menu.large-vertical > li > a::after {
+    right: 14px; }
+  .dropdown.menu.large-vertical > li.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .dropdown.menu.large-vertical > li.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; } }
 
-.sticky.is-anchored {
-  position: relative;
-  right: auto;
+.dropdown.menu.align-right .is-dropdown-submenu.first-sub {
+  top: 100%;
+  right: 0;
   left: auto; }
-  .sticky.is-anchored.is-at-bottom {
-    bottom: 0; }
 
-body.is-reveal-open {
-  overflow: hidden; }
+.is-dropdown-menu.vertical {
+  width: 100px; }
+  .is-dropdown-menu.vertical.align-right {
+    float: right; }
 
-html.is-reveal-open,
-html.is-reveal-open body {
-  min-height: 100%;
-  overflow: hidden;
-  position: fixed;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none; }
+.is-dropdown-submenu-parent {
+  position: relative; }
+  .is-dropdown-submenu-parent a::after {
+    position: absolute;
+    top: 50%;
+    right: 5px;
+    left: auto;
+    margin-top: -6px; }
+  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {
+    top: 100%;
+    left: auto; }
+  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {
+    right: 100%;
+    left: auto; }
+  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
 
-.reveal-overlay {
-  position: fixed;
+.is-dropdown-submenu {
+  position: absolute;
   top: 0;
-  right: 0;
-  bottom: 0;
-  left: 0;
-  z-index: 1005;
-  display: none;
-  background-color: rgba(10, 10, 10, 0.45);
-  overflow-y: scroll; }
-
-.reveal {
-  z-index: 1006;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
+  left: 100%;
+  z-index: 1;
   display: none;
-  padding: 1rem;
+  min-width: 200px;
   border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  position: relative;
-  top: 100px;
-  margin-right: auto;
-  margin-left: auto;
-  overflow-y: auto; }
-  [data-whatinput='mouse'] .reveal {
-    outline: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal {
-      min-height: 0; } }
-  .reveal .column {
-    min-width: 0; }
-  .reveal > :last-child {
-    margin-bottom: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal {
-      width: 600px;
-      max-width: 75rem; } }
-  .reveal.collapse {
-    padding: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal.tiny {
-      width: 30%;
-      max-width: 75rem; } }
-  @media print, screen and (min-width: 40em) {
-    .reveal.small {
-      width: 50%;
-      max-width: 75rem; } }
-  @media print, screen and (min-width: 40em) {
-    .reveal.large {
-      width: 90%;
-      max-width: 75rem; } }
-  .reveal.full {
-    top: 0;
-    left: 0;
-    width: 100%;
-    max-width: none;
-    height: 100%;
-    height: 100vh;
-    min-height: 100vh;
-    margin-left: 0;
-    border: 0;
-    border-radius: 0; }
-  @media screen and (max-width: 39.9375em) {
-    .reveal {
-      top: 0;
-      left: 0;
-      width: 100%;
-      max-width: none;
-      height: 100%;
-      height: 100vh;
-      min-height: 100vh;
-      margin-left: 0;
-      border: 0;
-      border-radius: 0; } }
-  .reveal.without-overlay {
-    position: fixed; }
-
-.switch {
-  height: 2rem;
-  position: relative;
-  margin-bottom: 1rem;
-  outline: 0;
-  font-size: 0.875rem;
-  font-weight: bold;
-  color: #fefefe;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none; }
-
-.switch-input {
-  position: absolute;
-  margin-bottom: 0;
-  opacity: 0; }
-
-.switch-paddle {
-  position: relative;
-  display: block;
-  width: 4rem;
-  height: 2rem;
-  border-radius: 0;
-  background: #cacaca;
-  -webkit-transition: all 0.25s ease-out;
-  transition: all 0.25s ease-out;
-  font-weight: inherit;
-  color: inherit;
-  cursor: pointer; }
-  input + .switch-paddle {
-    margin: 0; }
-  .switch-paddle::after {
-    position: absolute;
-    top: 0.25rem;
-    left: 0.25rem;
+  background: #fefefe; }
+  .dropdown .is-dropdown-submenu a {
+    padding: 0.7rem 1rem; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {
+    right: 14px; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {
     display: block;
-    width: 1.5rem;
-    height: 1.5rem;
-    -webkit-transform: translate3d(0, 0, 0);
-            transform: translate3d(0, 0, 0);
-    border-radius: 0;
-    background: #fefefe;
-    -webkit-transition: all 0.25s ease-out;
-    transition: all 0.25s ease-out;
-    content: ''; }
-  input:checked ~ .switch-paddle {
-    background: #1779ba; }
-    input:checked ~ .switch-paddle::after {
-      left: 2.25rem; }
-  [data-whatinput='mouse'] input:focus ~ .switch-paddle {
-    outline: 0; }
-
-.switch-active, .switch-inactive {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%); }
-
-.switch-active {
-  left: 8%;
-  display: none; }
-  input:checked + label > .switch-active {
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; }
+  .is-dropdown-submenu .is-dropdown-submenu {
+    margin-top: -1px; }
+  .is-dropdown-submenu > li {
+    width: 100%; }
+  .is-dropdown-submenu.js-dropdown-active {
     display: block; }
 
-.switch-inactive {
-  right: 15%; }
-  input:checked + label > .switch-inactive {
-    display: none; }
-
-.switch.tiny {
-  height: 1.5rem; }
-  .switch.tiny .switch-paddle {
-    width: 3rem;
-    height: 1.5rem;
-    font-size: 0.625rem; }
-  .switch.tiny .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 1rem;
-    height: 1rem; }
-  .switch.tiny input:checked ~ .switch-paddle::after {
-    left: 1.75rem; }
+.is-off-canvas-open {
+  overflow: hidden; }
 
-.switch.small {
-  height: 1.75rem; }
-  .switch.small .switch-paddle {
-    width: 3.5rem;
-    height: 1.75rem;
-    font-size: 0.75rem; }
-  .switch.small .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 1.25rem;
-    height: 1.25rem; }
-  .switch.small input:checked ~ .switch-paddle::after {
-    left: 2rem; }
+.js-off-canvas-overlay {
+  position: absolute;
+  top: 0;
+  left: 0;
+  z-index: 11;
+  width: 100%;
+  height: 100%;
+  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
+  transition: opacity 0.5s ease, visibility 0.5s ease;
+  background: rgba(254, 254, 254, 0.25);
+  opacity: 0;
+  visibility: hidden;
+  overflow: hidden; }
+  .js-off-canvas-overlay.is-visible {
+    opacity: 1;
+    visibility: visible; }
+  .js-off-canvas-overlay.is-closable {
+    cursor: pointer; }
+  .js-off-canvas-overlay.is-overlay-absolute {
+    position: absolute; }
+  .js-off-canvas-overlay.is-overlay-fixed {
+    position: fixed; }
 
-.switch.large {
-  height: 2.5rem; }
-  .switch.large .switch-paddle {
-    width: 5rem;
-    height: 2.5rem;
-    font-size: 1rem; }
-  .switch.large .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 2rem;
-    height: 2rem; }
-  .switch.large input:checked ~ .switch-paddle::after {
-    left: 2.75rem; }
+.off-canvas-wrapper {
+  position: relative;
+  overflow: hidden; }
 
-table {
-  border-collapse: collapse;
-  width: 100%;
-  margin-bottom: 1rem;
-  border-radius: 0; }
-  table thead,
-  table tbody,
-  table tfoot {
-    border: 1px solid #f1f1f1;
-    background-color: #fefefe; }
-  table caption {
-    padding: 0.5rem 0.625rem 0.625rem;
-    font-weight: bold; }
-  table thead {
-    background: #f8f8f8;
-    color: #0a0a0a; }
-  table tfoot {
-    background: #f1f1f1;
-    color: #0a0a0a; }
-  table thead tr,
-  table tfoot tr {
-    background: transparent; }
-  table thead th,
-  table thead td,
-  table tfoot th,
-  table tfoot td {
-    padding: 0.5rem 0.625rem 0.625rem;
-    font-weight: bold;
-    text-align: left; }
-  table tbody th,
-  table tbody td {
-    padding: 0.5rem 0.625rem 0.625rem; }
-  table tbody tr:nth-child(even) {
-    border-bottom: 0;
-    background-color: #f1f1f1; }
-  table.unstriped tbody {
-    background-color: #fefefe; }
-    table.unstriped tbody tr {
-      border-bottom: 0;
-      border-bottom: 1px solid #f1f1f1;
-      background-color: #fefefe; }
+.off-canvas {
+  position: fixed;
+  z-index: 12;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  background: #e6e6e6; }
+  [data-whatinput='mouse'] .off-canvas {
+    outline: 0; }
+  .off-canvas.is-transition-push {
+    z-index: 12; }
+  .off-canvas.is-closed {
+    visibility: hidden; }
+  .off-canvas.is-transition-overlap {
+    z-index: 13; }
+    .off-canvas.is-transition-overlap.is-open {
+      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
+              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
+  .off-canvas.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-@media screen and (max-width: 63.9375em) {
-  table.stack thead {
-    display: none; }
-  table.stack tfoot {
-    display: none; }
-  table.stack tr,
-  table.stack th,
-  table.stack td {
-    display: block; }
-  table.stack td {
-    border-top: 0; } }
+.off-canvas-absolute {
+  position: absolute;
+  z-index: 12;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  background: #e6e6e6; }
+  [data-whatinput='mouse'] .off-canvas-absolute {
+    outline: 0; }
+  .off-canvas-absolute.is-transition-push {
+    z-index: 12; }
+  .off-canvas-absolute.is-closed {
+    visibility: hidden; }
+  .off-canvas-absolute.is-transition-overlap {
+    z-index: 13; }
+    .off-canvas-absolute.is-transition-overlap.is-open {
+      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
+              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
+  .off-canvas-absolute.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-table.scroll {
-  display: block;
-  width: 100%;
-  overflow-x: auto; }
+.position-left {
+  top: 0;
+  left: 0;
+  height: 100%;
+  overflow-y: auto;
+  width: 250px;
+  -webkit-transform: translateX(-250px);
+      -ms-transform: translateX(-250px);
+          transform: translateX(-250px); }
+  .off-canvas-content .off-canvas.position-left {
+    -webkit-transform: translateX(-250px);
+        -ms-transform: translateX(-250px);
+            transform: translateX(-250px); }
+    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-left.has-transition-push {
+    -webkit-transform: translateX(250px);
+        -ms-transform: translateX(250px);
+            transform: translateX(250px); }
+  .position-left.is-transition-push {
+    -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }
 
-table.hover thead tr:hover {
-  background-color: #f3f3f3; }
+.position-right {
+  top: 0;
+  right: 0;
+  height: 100%;
+  overflow-y: auto;
+  width: 250px;
+  -webkit-transform: translateX(250px);
+      -ms-transform: translateX(250px);
+          transform: translateX(250px); }
+  .off-canvas-content .off-canvas.position-right {
+    -webkit-transform: translateX(250px);
+        -ms-transform: translateX(250px);
+            transform: translateX(250px); }
+    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-right.has-transition-push {
+    -webkit-transform: translateX(-250px);
+        -ms-transform: translateX(-250px);
+            transform: translateX(-250px); }
+  .position-right.is-transition-push {
+    -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }
 
-table.hover tfoot tr:hover {
-  background-color: #ececec; }
+.position-top {
+  top: 0;
+  left: 0;
+  width: 100%;
+  overflow-x: auto;
+  height: 250px;
+  -webkit-transform: translateY(-250px);
+      -ms-transform: translateY(-250px);
+          transform: translateY(-250px); }
+  .off-canvas-content .off-canvas.position-top {
+    -webkit-transform: translateY(-250px);
+        -ms-transform: translateY(-250px);
+            transform: translateY(-250px); }
+    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-top.has-transition-push {
+    -webkit-transform: translateY(250px);
+        -ms-transform: translateY(250px);
+            transform: translateY(250px); }
+  .position-top.is-transition-push {
+    -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }
 
-table.hover tbody tr:hover {
-  background-color: #f9f9f9; }
+.position-bottom {
+  bottom: 0;
+  left: 0;
+  width: 100%;
+  overflow-x: auto;
+  height: 250px;
+  -webkit-transform: translateY(250px);
+      -ms-transform: translateY(250px);
+          transform: translateY(250px); }
+  .off-canvas-content .off-canvas.position-bottom {
+    -webkit-transform: translateY(250px);
+        -ms-transform: translateY(250px);
+            transform: translateY(250px); }
+    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-bottom.has-transition-push {
+    -webkit-transform: translateY(-250px);
+        -ms-transform: translateY(-250px);
+            transform: translateY(-250px); }
+  .position-bottom.is-transition-push {
+    -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }
 
-table.hover:not(.unstriped) tr:nth-of-type(even):hover {
-  background-color: #ececec; }
+.off-canvas-content {
+  -webkit-transform: none;
+      -ms-transform: none;
+          transform: none;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden; }
+  .off-canvas-content.has-transition-push {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
+  .off-canvas-content .off-canvas.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-.table-scroll {
-  overflow-x: auto; }
-  .table-scroll table {
-    width: auto; }
+@media print, screen and (min-width: 40em) {
+  .position-left.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-left.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-left.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-left {
+      margin-left: 250px; }
+    .position-left.reveal-for-medium ~ .off-canvas-content {
+      margin-left: 250px; }
+  .position-right.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-right.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-right.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-right {
+      margin-right: 250px; }
+    .position-right.reveal-for-medium ~ .off-canvas-content {
+      margin-right: 250px; }
+  .position-top.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-top.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-top.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-top {
+      margin-top: 250px; }
+    .position-top.reveal-for-medium ~ .off-canvas-content {
+      margin-top: 250px; }
+  .position-bottom.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-bottom.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-bottom.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-bottom {
+      margin-bottom: 250px; }
+    .position-bottom.reveal-for-medium ~ .off-canvas-content {
+      margin-bottom: 250px; } }
 
-.tabs {
-  margin: 0;
-  border: 1px solid #e6e6e6;
-  background: #fefefe;
-  list-style-type: none; }
-  .tabs::before, .tabs::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .tabs::after {
-    clear: both; }
+@media print, screen and (min-width: 64em) {
+  .position-left.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-left.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-left.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-left {
+      margin-left: 250px; }
+    .position-left.reveal-for-large ~ .off-canvas-content {
+      margin-left: 250px; }
+  .position-right.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-right.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-right.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-right {
+      margin-right: 250px; }
+    .position-right.reveal-for-large ~ .off-canvas-content {
+      margin-right: 250px; }
+  .position-top.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-top.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-top.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-top {
+      margin-top: 250px; }
+    .position-top.reveal-for-large ~ .off-canvas-content {
+      margin-top: 250px; }
+  .position-bottom.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-bottom.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-bottom.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-bottom {
+      margin-bottom: 250px; }
+    .position-bottom.reveal-for-large ~ .off-canvas-content {
+      margin-bottom: 250px; } }
 
-.tabs.vertical > li {
-  display: block;
-  float: none;
-  width: auto; }
+@media print, screen and (min-width: 40em) {
+  .off-canvas.in-canvas-for-medium {
+    visibility: visible;
+    height: auto;
+    position: static;
+    background: none;
+    width: auto;
+    overflow: visible;
+    -webkit-transition: none;
+    transition: none; }
+    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {
+      -webkit-box-shadow: none;
+              box-shadow: none;
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas.in-canvas-for-medium .close-button {
+      display: none; } }
 
-.tabs.simple > li > a {
-  padding: 0; }
-  .tabs.simple > li > a:hover {
-    background: transparent; }
+@media print, screen and (min-width: 64em) {
+  .off-canvas.in-canvas-for-large {
+    visibility: visible;
+    height: auto;
+    position: static;
+    background: none;
+    width: auto;
+    overflow: visible;
+    -webkit-transition: none;
+    transition: none; }
+    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {
+      -webkit-box-shadow: none;
+              box-shadow: none;
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas.in-canvas-for-large .close-button {
+      display: none; } }
 
-.tabs.primary {
-  background: #1779ba; }
-  .tabs.primary > li > a {
-    color: #fefefe; }
-    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
-      background: #1673b1; }
+html.is-reveal-open {
+  position: fixed;
+  width: 100%;
+  overflow-y: hidden; }
+  html.is-reveal-open.zf-has-scroll {
+    overflow-y: scroll; }
+  html.is-reveal-open body {
+    overflow-y: hidden; }
 
-.tabs-title {
-  float: left; }
-  .tabs-title > a {
-    display: block;
-    padding: 1.25rem 1.5rem;
-    font-size: 0.75rem;
-    line-height: 1;
-    color: #1779ba; }
-    .tabs-title > a:hover {
-      background: #fefefe;
-      color: #1468a0; }
-    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {
-      background: #e6e6e6;
-      color: #1779ba; }
+.reveal-overlay {
+  position: fixed;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  z-index: 1005;
+  display: none;
+  background-color: rgba(10, 10, 10, 0.45);
+  overflow-y: auto; }
 
-.tabs-content {
-  border: 1px solid #e6e6e6;
-  border-top: 0;
-  background: #fefefe;
-  color: #0a0a0a;
-  -webkit-transition: all 0.5s ease;
-  transition: all 0.5s ease; }
+.reveal {
+  z-index: 1006;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  display: none;
+  padding: 1rem;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  position: relative;
+  top: 100px;
+  margin-right: auto;
+  margin-left: auto;
+  overflow-y: auto; }
+  [data-whatinput='mouse'] .reveal {
+    outline: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal {
+      min-height: 0; } }
+  .reveal .column {
+    min-width: 0; }
+  .reveal > :last-child {
+    margin-bottom: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal {
+      width: 600px;
+      max-width: 75rem; } }
+  .reveal.collapse {
+    padding: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal.tiny {
+      width: 30%;
+      max-width: 75rem; } }
+  @media print, screen and (min-width: 40em) {
+    .reveal.small {
+      width: 50%;
+      max-width: 75rem; } }
+  @media print, screen and (min-width: 40em) {
+    .reveal.large {
+      width: 90%;
+      max-width: 75rem; } }
+  .reveal.full {
+    top: 0;
+    right: 0;
+    bottom: 0;
+    left: 0;
+    width: 100%;
+    max-width: none;
+    height: 100%;
+    min-height: 100%;
+    margin-left: 0;
+    border: 0;
+    border-radius: 0; }
+  @media screen and (max-width: 39.99875em) {
+    .reveal {
+      top: 0;
+      right: 0;
+      bottom: 0;
+      left: 0;
+      width: 100%;
+      max-width: none;
+      height: 100%;
+      min-height: 100%;
+      margin-left: 0;
+      border: 0;
+      border-radius: 0; } }
+  .reveal.without-overlay {
+    position: fixed; }
 
-.tabs-content.vertical {
-  border: 1px solid #e6e6e6;
-  border-left: 0; }
+.sticky-container {
+  position: relative; }
 
-.tabs-panel {
-  display: none;
-  padding: 1rem; }
-  .tabs-panel.is-active {
-    display: block; }
+.sticky {
+  position: relative;
+  z-index: 0;
+  -webkit-transform: translate3d(0, 0, 0);
+          transform: translate3d(0, 0, 0); }
 
-.thumbnail {
-  display: inline-block;
-  max-width: 100%;
-  margin-bottom: 1rem;
-  border: solid 4px #fefefe;
-  border-radius: 0;
-  -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-          box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-  line-height: 0; }
+.sticky.is-stuck {
+  position: fixed;
+  z-index: 5;
+  width: 100%; }
+  .sticky.is-stuck.is-at-top {
+    top: 0; }
+  .sticky.is-stuck.is-at-bottom {
+    bottom: 0; }
 
-a.thumbnail {
-  -webkit-transition: -webkit-box-shadow 200ms ease-out;
-  transition: -webkit-box-shadow 200ms ease-out;
-  transition: box-shadow 200ms ease-out;
-  transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; }
-  a.thumbnail:hover, a.thumbnail:focus {
-    -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
-            box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }
-  a.thumbnail image {
-    -webkit-box-shadow: none;
-            box-shadow: none; }
+.sticky.is-anchored {
+  position: relative;
+  right: auto;
+  left: auto; }
+  .sticky.is-anchored.is-at-bottom {
+    bottom: 0; }
 
 .title-bar {
   padding: 0.5rem;
@@ -5161,102 +5017,6 @@ a.thumbnail {
   vertical-align: middle;
   font-weight: bold; }
 
-.has-tip {
-  position: relative;
-  display: inline-block;
-  border-bottom: dotted 1px #8a8a8a;
-  font-weight: bold;
-  cursor: help; }
-
-.tooltip {
-  position: absolute;
-  top: calc(100% + 0.6495rem);
-  z-index: 1200;
-  max-width: 10rem;
-  padding: 0.75rem;
-  border-radius: 0;
-  background-color: #0a0a0a;
-  font-size: 80%;
-  color: #fefefe; }
-  .tooltip::before {
-    position: absolute; }
-  .tooltip.bottom::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-top-width: 0;
-    border-bottom-style: solid;
-    border-color: transparent transparent #0a0a0a;
-    bottom: 100%; }
-  .tooltip.bottom.align-center::before {
-    left: 50%;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
-  .tooltip.top::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #0a0a0a transparent transparent;
-    top: 100%;
-    bottom: auto; }
-  .tooltip.top.align-center::before {
-    left: 50%;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
-  .tooltip.left::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #0a0a0a;
-    left: 100%; }
-  .tooltip.left.align-center::before {
-    bottom: auto;
-    top: 50%;
-    -webkit-transform: translateY(-50%);
-        -ms-transform: translateY(-50%);
-            transform: translateY(-50%); }
-  .tooltip.right::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #0a0a0a transparent transparent;
-    right: 100%;
-    left: auto; }
-  .tooltip.right.align-center::before {
-    bottom: auto;
-    top: 50%;
-    -webkit-transform: translateY(-50%);
-        -ms-transform: translateY(-50%);
-            transform: translateY(-50%); }
-  .tooltip.align-top::before {
-    bottom: auto;
-    top: 10%; }
-  .tooltip.align-bottom::before {
-    bottom: 10%;
-    top: auto; }
-  .tooltip.align-left::before {
-    left: 10%;
-    right: auto; }
-  .tooltip.align-right::before {
-    left: auto;
-    right: 10%; }
-
 .top-bar {
   display: -webkit-box;
   display: -webkit-flex;
@@ -5312,7 +5072,7 @@ a.thumbnail {
             -ms-flex: 0 1 auto;
                 flex: 0 1 auto;
         margin-left: auto; } }
-  @media screen and (max-width: 63.9375em) {
+  @media screen and (max-width: 63.99875em) {
     .top-bar.stacked-for-medium {
       -webkit-flex-wrap: wrap;
           -ms-flex-wrap: wrap;
@@ -5324,7 +5084,7 @@ a.thumbnail {
             -ms-flex: 0 0 100%;
                 flex: 0 0 100%;
         max-width: 100%; } }
-  @media screen and (max-width: 74.9375em) {
+  @media screen and (max-width: 74.99875em) {
     .top-bar.stacked-for-large {
       -webkit-flex-wrap: wrap;
           -ms-flex-wrap: wrap;
@@ -5351,99 +5111,6 @@ a.thumbnail {
       -ms-flex: 0 0 auto;
           flex: 0 0 auto; }
 
-.hide {
-  display: none !important; }
-
-.invisible {
-  visibility: hidden; }
-
-@media screen and (max-width: 39.9375em) {
-  .hide-for-small-only {
-    display: none !important; } }
-
-@media screen and (max-width: 0em), screen and (min-width: 40em) {
-  .show-for-small-only {
-    display: none !important; } }
-
-@media print, screen and (min-width: 40em) {
-  .hide-for-medium {
-    display: none !important; } }
-
-@media screen and (max-width: 39.9375em) {
-  .show-for-medium {
-    display: none !important; } }
-
-@media screen and (min-width: 40em) and (max-width: 63.9375em) {
-  .hide-for-medium-only {
-    display: none !important; } }
-
-@media screen and (max-width: 39.9375em), screen and (min-width: 64em) {
-  .show-for-medium-only {
-    display: none !important; } }
-
-@media print, screen and (min-width: 64em) {
-  .hide-for-large {
-    display: none !important; } }
-
-@media screen and (max-width: 63.9375em) {
-  .show-for-large {
-    display: none !important; } }
-
-@media screen and (min-width: 64em) and (max-width: 74.9375em) {
-  .hide-for-large-only {
-    display: none !important; } }
-
-@media screen and (max-width: 63.9375em), screen and (min-width: 75em) {
-  .show-for-large-only {
-    display: none !important; } }
-
-.show-for-sr,
-.show-on-focus {
-  position: absolute !important;
-  width: 1px;
-  height: 1px;
-  padding: 0;
-  overflow: hidden;
-  clip: rect(0, 0, 0, 0);
-  white-space: nowrap;
-  -webkit-clip-path: inset(50%);
-          clip-path: inset(50%);
-  border: 0; }
-
-.show-on-focus:active, .show-on-focus:focus {
-  position: static !important;
-  width: auto;
-  height: auto;
-  overflow: visible;
-  clip: auto;
-  white-space: normal;
-  -webkit-clip-path: none;
-          clip-path: none; }
-
-.show-for-landscape,
-.hide-for-portrait {
-  display: block !important; }
-  @media screen and (orientation: landscape) {
-    .show-for-landscape,
-    .hide-for-portrait {
-      display: block !important; } }
-  @media screen and (orientation: portrait) {
-    .show-for-landscape,
-    .hide-for-portrait {
-      display: none !important; } }
-
-.hide-for-landscape,
-.show-for-portrait {
-  display: none !important; }
-  @media screen and (orientation: landscape) {
-    .hide-for-landscape,
-    .show-for-portrait {
-      display: none !important; } }
-  @media screen and (orientation: portrait) {
-    .hide-for-landscape,
-    .show-for-portrait {
-      display: block !important; } }
-
 .float-left {
   float: left !important; }
 
@@ -5469,6 +5136,12 @@ a.thumbnail {
 .clearfix::after {
   clear: both; }
 
+.align-left {
+  -webkit-box-pack: start;
+  -webkit-justify-content: flex-start;
+      -ms-flex-pack: start;
+          justify-content: flex-start; }
+
 .align-right {
   -webkit-box-pack: end;
   -webkit-justify-content: flex-end;
@@ -5492,6 +5165,12 @@ a.thumbnail {
       -ms-flex-pack: distribute;
           justify-content: space-around; }
 
+.align-left.vertical.menu > li > a {
+  -webkit-box-pack: start;
+  -webkit-justify-content: flex-start;
+      -ms-flex-pack: start;
+          justify-content: flex-start; }
+
 .align-right.vertical.menu > li > a {
   -webkit-box-pack: end;
   -webkit-justify-content: flex-end;
@@ -5535,7 +5214,6 @@ a.thumbnail {
 .align-self-middle {
   -webkit-align-self: center;
       -ms-flex-item-align: center;
-              -ms-grid-row-align: center;
           align-self: center; }
 
 .align-stretch {
@@ -5547,7 +5225,6 @@ a.thumbnail {
 .align-self-stretch {
   -webkit-align-self: stretch;
       -ms-flex-item-align: stretch;
-              -ms-grid-row-align: stretch;
           align-self: stretch; }
 
 .align-center-middle {
@@ -5807,6 +5484,95 @@ a.thumbnail {
         -ms-flex-direction: column-reverse;
             flex-direction: column-reverse; } }
 
+.hide {
+  display: none !important; }
+
+.invisible {
+  visibility: hidden; }
+
+@media screen and (max-width: 39.99875em) {
+  .hide-for-small-only {
+    display: none !important; } }
+
+@media screen and (max-width: 0em), screen and (min-width: 40em) {
+  .show-for-small-only {
+    display: none !important; } }
+
+@media print, screen and (min-width: 40em) {
+  .hide-for-medium {
+    display: none !important; } }
+
+@media screen and (max-width: 39.99875em) {
+  .show-for-medium {
+    display: none !important; } }
+
+@media screen and (min-width: 40em) and (max-width: 63.99875em) {
+  .hide-for-medium-only {
+    display: none !important; } }
+
+@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {
+  .show-for-medium-only {
+    display: none !important; } }
+
+@media print, screen and (min-width: 64em) {
+  .hide-for-large {
+    display: none !important; } }
+
+@media screen and (max-width: 63.99875em) {
+  .show-for-large {
+    display: none !important; } }
+
+@media screen and (min-width: 64em) and (max-width: 74.99875em) {
+  .hide-for-large-only {
+    display: none !important; } }
+
+@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {
+  .show-for-large-only {
+    display: none !important; } }
+
+.show-for-sr,
+.show-on-focus {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  padding: 0;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
+  white-space: nowrap;
+  border: 0; }
+
+.show-on-focus:active, .show-on-focus:focus {
+  position: static !important;
+  width: auto;
+  height: auto;
+  overflow: visible;
+  clip: auto;
+  white-space: normal; }
+
+.show-for-landscape,
+.hide-for-portrait {
+  display: block !important; }
+  @media screen and (orientation: landscape) {
+    .show-for-landscape,
+    .hide-for-portrait {
+      display: block !important; } }
+  @media screen and (orientation: portrait) {
+    .show-for-landscape,
+    .hide-for-portrait {
+      display: none !important; } }
+
+.hide-for-landscape,
+.show-for-portrait {
+  display: none !important; }
+  @media screen and (orientation: landscape) {
+    .hide-for-landscape,
+    .show-for-portrait {
+      display: none !important; } }
+  @media screen and (orientation: portrait) {
+    .hide-for-landscape,
+    .show-for-portrait {
+      display: block !important; } }
+
 .text-hide {
   font: 0/0 a !important;
   color: transparent !important;
@@ -5888,6 +5654,8 @@ ol.list-upper-roman {
 
 .rounded {
   border-radius: 5000px !important; }
+  .rounded:after {
+    border-radius: 50%; }
 
 .radius {
   border-radius: 0.1875rem; }
@@ -6107,209 +5875,185 @@ ol.list-upper-roman {
   max-height: 100% !important; }
 
 .margin-0 {
-  margin-top: 0rem !important;
-  margin-right: 0rem !important;
-  margin-bottom: 0rem !important;
-  margin-left: 0rem !important; }
-
-.padding-0 {
-  padding-top: 0rem !important;
-  padding-right: 0rem !important;
-  padding-bottom: 0rem !important;
-  padding-left: 0rem !important; }
+  margin: 0rem; }
 
 .margin-top-0 {
   margin-top: 0rem !important; }
 
-.padding-top-0 {
-  padding-top: 0rem !important; }
-
 .margin-right-0 {
   margin-right: 0rem !important; }
 
-.padding-right-0 {
-  padding-right: 0rem !important; }
-
 .margin-bottom-0 {
   margin-bottom: 0rem !important; }
 
-.padding-bottom-0 {
-  padding-bottom: 0rem !important; }
-
 .margin-left-0 {
   margin-left: 0rem !important; }
 
-.padding-left-0 {
-  padding-left: 0rem !important; }
-
 .margin-horizontal-0 {
   margin-right: 0rem !important;
   margin-left: 0rem !important; }
 
-.padding-horizontal-0 {
-  padding-right: 0rem !important;
-  padding-left: 0rem !important; }
-
 .margin-vertical-0 {
   margin-top: 0rem !important;
   margin-bottom: 0rem !important; }
 
+.padding-0 {
+  padding: 0rem; }
+
+.padding-top-0 {
+  padding-top: 0rem !important; }
+
+.padding-right-0 {
+  padding-right: 0rem !important; }
+
+.padding-bottom-0 {
+  padding-bottom: 0rem !important; }
+
+.padding-left-0 {
+  padding-left: 0rem !important; }
+
+.padding-horizontal-0 {
+  padding-right: 0rem !important;
+  padding-left: 0rem !important; }
+
 .padding-vertical-0 {
   padding-top: 0rem !important;
   padding-bottom: 0rem !important; }
 
 .margin-1 {
-  margin-top: 1rem !important;
-  margin-right: 1rem !important;
-  margin-bottom: 1rem !important;
-  margin-left: 1rem !important; }
-
-.padding-1 {
-  padding-top: 1rem !important;
-  padding-right: 1rem !important;
-  padding-bottom: 1rem !important;
-  padding-left: 1rem !important; }
+  margin: 1rem; }
 
 .margin-top-1 {
   margin-top: 1rem !important; }
 
-.padding-top-1 {
-  padding-top: 1rem !important; }
-
 .margin-right-1 {
   margin-right: 1rem !important; }
 
-.padding-right-1 {
-  padding-right: 1rem !important; }
-
 .margin-bottom-1 {
   margin-bottom: 1rem !important; }
 
-.padding-bottom-1 {
-  padding-bottom: 1rem !important; }
-
 .margin-left-1 {
   margin-left: 1rem !important; }
 
-.padding-left-1 {
-  padding-left: 1rem !important; }
-
 .margin-horizontal-1 {
   margin-right: 1rem !important;
   margin-left: 1rem !important; }
 
-.padding-horizontal-1 {
-  padding-right: 1rem !important;
-  padding-left: 1rem !important; }
-
 .margin-vertical-1 {
   margin-top: 1rem !important;
   margin-bottom: 1rem !important; }
 
+.padding-1 {
+  padding: 1rem; }
+
+.padding-top-1 {
+  padding-top: 1rem !important; }
+
+.padding-right-1 {
+  padding-right: 1rem !important; }
+
+.padding-bottom-1 {
+  padding-bottom: 1rem !important; }
+
+.padding-left-1 {
+  padding-left: 1rem !important; }
+
+.padding-horizontal-1 {
+  padding-right: 1rem !important;
+  padding-left: 1rem !important; }
+
 .padding-vertical-1 {
   padding-top: 1rem !important;
   padding-bottom: 1rem !important; }
 
 .margin-2 {
-  margin-top: 2rem !important;
-  margin-right: 2rem !important;
-  margin-bottom: 2rem !important;
-  margin-left: 2rem !important; }
-
-.padding-2 {
-  padding-top: 2rem !important;
-  padding-right: 2rem !important;
-  padding-bottom: 2rem !important;
-  padding-left: 2rem !important; }
+  margin: 2rem; }
 
 .margin-top-2 {
   margin-top: 2rem !important; }
 
-.padding-top-2 {
-  padding-top: 2rem !important; }
-
 .margin-right-2 {
   margin-right: 2rem !important; }
 
-.padding-right-2 {
-  padding-right: 2rem !important; }
-
 .margin-bottom-2 {
   margin-bottom: 2rem !important; }
 
-.padding-bottom-2 {
-  padding-bottom: 2rem !important; }
-
 .margin-left-2 {
   margin-left: 2rem !important; }
 
-.padding-left-2 {
-  padding-left: 2rem !important; }
-
 .margin-horizontal-2 {
   margin-right: 2rem !important;
   margin-left: 2rem !important; }
 
-.padding-horizontal-2 {
-  padding-right: 2rem !important;
-  padding-left: 2rem !important; }
-
 .margin-vertical-2 {
   margin-top: 2rem !important;
   margin-bottom: 2rem !important; }
 
+.padding-2 {
+  padding: 2rem; }
+
+.padding-top-2 {
+  padding-top: 2rem !important; }
+
+.padding-right-2 {
+  padding-right: 2rem !important; }
+
+.padding-bottom-2 {
+  padding-bottom: 2rem !important; }
+
+.padding-left-2 {
+  padding-left: 2rem !important; }
+
+.padding-horizontal-2 {
+  padding-right: 2rem !important;
+  padding-left: 2rem !important; }
+
 .padding-vertical-2 {
   padding-top: 2rem !important;
   padding-bottom: 2rem !important; }
 
 .margin-3 {
-  margin-top: 3rem !important;
-  margin-right: 3rem !important;
-  margin-bottom: 3rem !important;
-  margin-left: 3rem !important; }
-
-.padding-3 {
-  padding-top: 3rem !important;
-  padding-right: 3rem !important;
-  padding-bottom: 3rem !important;
-  padding-left: 3rem !important; }
+  margin: 3rem; }
 
 .margin-top-3 {
   margin-top: 3rem !important; }
 
-.padding-top-3 {
-  padding-top: 3rem !important; }
-
 .margin-right-3 {
   margin-right: 3rem !important; }
 
-.padding-right-3 {
-  padding-right: 3rem !important; }
-
 .margin-bottom-3 {
   margin-bottom: 3rem !important; }
 
-.padding-bottom-3 {
-  padding-bottom: 3rem !important; }
-
 .margin-left-3 {
   margin-left: 3rem !important; }
 
-.padding-left-3 {
-  padding-left: 3rem !important; }
-
 .margin-horizontal-3 {
   margin-right: 3rem !important;
   margin-left: 3rem !important; }
 
-.padding-horizontal-3 {
-  padding-right: 3rem !important;
-  padding-left: 3rem !important; }
-
 .margin-vertical-3 {
   margin-top: 3rem !important;
   margin-bottom: 3rem !important; }
 
+.padding-3 {
+  padding: 3rem; }
+
+.padding-top-3 {
+  padding-top: 3rem !important; }
+
+.padding-right-3 {
+  padding-right: 3rem !important; }
+
+.padding-bottom-3 {
+  padding-bottom: 3rem !important; }
+
+.padding-left-3 {
+  padding-left: 3rem !important; }
+
+.padding-horizontal-3 {
+  padding-right: 3rem !important;
+  padding-left: 3rem !important; }
+
 .padding-vertical-3 {
   padding-top: 3rem !important;
   padding-bottom: 3rem !important; }
diff --git a/dist/css/foundation-prototype.css.map b/dist/css/foundation-prototype.css.map
new file mode 100644 (file)
index 0000000..0544565
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation-prototype.css","../scss/foundation.scss","../scss/util/_breakpoint.scss","../scss/components/_reveal.scss","../scss/vendor/normalize.scss","../scss/_global.scss","../scss/util/_unit.scss","../scss/util/_mixins.scss","../scss/forms/_text.scss","../scss/forms/_checkbox.scss","../scss/forms/_label.scss","../scss/forms/_help-text.scss","../scss/forms/_input-group.scss","../scss/forms/_fieldset.scss","../scss/forms/_select.scss","../scss/forms/_error.scss","../scss/typography/_base.scss","../scss/typography/_helpers.scss","../scss/typography/_alignment.scss","../scss/typography/_print.scss","../scss/xy-grid/_classes.scss","../scss/xy-grid/_gutters.scss","../scss/xy-grid/_grid.scss","../scss/xy-grid/_cell.scss","../scss/xy-grid/_layout.scss","../scss/xy-grid/_collapse.scss","../scss/xy-grid/_position.scss","../scss/xy-grid/_frame.scss","../scss/components/_button.scss","../scss/components/_button-group.scss","../scss/components/_close-button.scss","../scss/components/_label.scss","../scss/components/_progress-bar.scss","../scss/forms/_progress.scss","../scss/components/_slider.scss","../scss/forms/_range.scss","../scss/components/_switch.scss","../scss/components/_table.scss","../scss/util/_color.scss","../scss/components/_badge.scss","../scss/components/_breadcrumbs.scss","../scss/components/_callout.scss","../scss/components/_card.scss","../scss/components/_dropdown.scss","../scss/components/_pagination.scss","../scss/components/_tooltip.scss","../scss/components/_accordion.scss","../scss/components/_media-object.scss","../scss/components/_orbit.scss","../scss/components/_responsive-embed.scss","../scss/util/_math.scss","../scss/components/_tabs.scss","../scss/components/_thumbnail.scss","../scss/components/_menu.scss","../scss/components/_menu-icon.scss","../scss/components/_accordion-menu.scss","../scss/components/_drilldown.scss","../scss/components/_dropdown-menu.scss","../scss/components/_off-canvas.scss","../scss/components/_sticky.scss","../scss/components/_title-bar.scss","../scss/components/_top-bar.scss","../scss/components/_float.scss","../scss/components/_flex.scss","../scss/util/_flex.scss","../scss/components/_visibility.scss","../scss/prototype/_text-utilities.scss","../scss/prototype/_text-transformation.scss","../scss/prototype/_text-decoration.scss","../scss/prototype/_font-styling.scss","../scss/prototype/_list-style-type.scss","../scss/prototype/_rounded.scss","../scss/prototype/_bordered.scss","../scss/prototype/_shadow.scss","../scss/prototype/_arrow.scss","../scss/prototype/_separator.scss","../scss/prototype/_position.scss","../scss/prototype/_overflow.scss","../scss/prototype/_display.scss","../scss/prototype/_border-box.scss","../scss/prototype/_border-none.scss","../scss/prototype/_sizing.scss","../scss/prototype/_spacing.scss"],"names":[],"mappings":"AAAA,gBAAgB;ACAhB;;;;;EDME;AEgKI;ECzHJ;IACE,WAAW;IACX,UAAU;IACV,cAAc,EAAA,EACf;;AChDD,2EAAA;AAQA;EACE,iBAAiB;EACjB,8BAA8B,EAAA;;AAQhC;EACE,SAAS,EAAA;;AAMX;EACE,cAAc;EACd,gBAAgB,EAAA;;AASlB;EACE,+BAAuB;UAAvB,uBAAuB;EACvB,SAAS;EACT,iBAAiB,EAAA;;AAMnB;EACE,iCAAiC;EACjC,cAAc,EAAA;;AAQhB;EACE,6BAA6B,EAAA;;AAM/B;EACE,mBAAmB;EACnB,0BAA0B;EAC1B,yCAAiC;UAAjC,iCAAiC,EAAA;;AAKnC;;EAEE,mBAAmB,EAAA;;AAMrB;;;EAGE,iCAAiC;EACjC,cAAc,EAAA;;AAKhB;EACE,cAAc,EAAA;;AAMhB;;EAEE,cAAc;EACd,cAAc;EACd,kBAAkB;EAClB,wBAAwB,EAAA;;AAG1B;EACE,eAAe,EAAA;;AAGjB;EACE,WAAW,EAAA;;AAQb;EACE,kBAAkB,EAAA;;AASpB;;;;;EAKE,oBAAoB;EACpB,eAAe;EACf,iBAAiB;EACjB,SAAS,EAAA;;AAMX;;EAEE,iBAAiB,EAAA;;AAMnB;;EAEE,oBAAoB,EAAA;;AAKtB;;;;EAIE,0BAA0B,EAAA;;AAK5B;;;;EAIE,kBAAkB;EAClB,UAAU,EAAA;;AAKZ;;;;EAIE,8BAA8B,EAAA;;AAKhC;EACE,8BAA8B,EAAA;;AAQhC;EACE,8BAAsB;UAAtB,sBAAsB;EACtB,cAAc;EACd,cAAc;EACd,eAAe;EACf,UAAU;EACV,mBAAmB,EAAA;;AAKrB;EACE,wBAAwB,EAAA;;AAK1B;EACE,cAAc,EAAA;;AJrFlB;;EI6FI,8BAAsB;UAAtB,sBAAsB;EACtB,UAAU,EAAA;;AJzFd;;EIgGI,YAAY,EAAA;;AJ5FhB;EImGI,6BAA6B;EAC7B,oBAAoB,EAAA;;AJhGxB;EIsGI,wBAAwB,EAAA;;AAM1B;EACE,0BAA0B;EAC1B,aAAa,EAAA;;AAQf;EACE,cAAc,EAAA;;AAKhB;EACE,kBAAkB,EAAA;;AAQpB;EACE,aAAa,EAAA;;AJtHjB;EI4HI,aAAa,EAAA;;AC3If;EACE,wEAAgD,EAAA;;ADnIlD;ECuIE,8BAAsB;UAAtB,sBAAsB;EACtB,eCzImB,EAAA;;AD6IrB;;;EAGE,2BAAmB;UAAnB,mBAAmB,EAAA;;ADrIrB;EC0IE,SAAS;EACT,UAAU;EAEV,mBA5GW;EA8GX,mEAlGqE;EAmGrE,mBA/EyB;EAgFzB,gBA9ImB;EA+InB,cArHW;EAwHT,mCAAmC;EACnC,kCAAkC,EAAA;;ADrDtC;EC2DE,qBAAqB;EACrB,sBAAsB;EAGtB,eAAe;EACf,YAAY;EACZ,+BAA+B,EAAA;;AD4BjC;ECvBE,YAAY;EACZ,gBAAgB;EAChB,gBAhGa,EAAA;;AAoGf;EACE,8BAAsB;UAAtB,sBAAsB;EACtB,WAAW;EACX,gBAvGa,EAAA;;AA4Gf;;;;;;EAKI,0BAA0B,EAAA;;AAK9B;EAEE,UAAU;EACV,wBAAgB;KAAhB,qBAAgB;UAAhB,gBAAgB;EAChB,SAAS;EACT,gBA3Ha;EA4Hb,uBAAuB;EACvB,cAAc;EACd,YAvGuB,EAAA;ELkGzB;IOXE,UAAU,EAAA;;AH5JZ;ECiLE,cAAc,EAAA;;ADjGhB;;;;;EC0GE,oBAAoB,EAAA;;AAItB;EACE,yBAAyB,EAAA;;AAG3B;EACE,wBAAwB,EAAA;;ALT5B;;EQjJE,cAAc;EACd,8BAAsB;UAAtB,sBAAsB;EACtB,WAAW;EACX,iBALsJ;EAMtJ,gBFHuD;EEIvD,eAtC+B;EAwC/B,yBHtDmB;EGuDnB,gBHHe;EGIf,yBH5Ca;EG6Cb,yDHjDa;UGiDb,iDHjDa;EGmDb,oBAjFyB;EAkFzB,eFZuD;EEavD,mBHjB2B;EGkB3B,gBHhFqB;EGiFrB,cHvDa;EG0DX,2EApC8D;EAoC9D,mEApC8D;EAoC9D,2DApC8D;EAoC9D,oFApC8D;EAyD9D,wBAAgB;KAAhB,qBAAgB;UAAhB,gBAAgB,EAAA;ER4HlB;;IQ5IE,aAAa;IACb,yBHpEe;IGqEf,yBH7DW;IG8DX,mCH1EiB;YG0EjB,2BH1EiB;IG6Ef,2EA/C4D;IA+C5D,mEA/C4D;IA+C5D,2DA/C4D;IA+C5D,oFA/C4D,EAAA;;AJ2IhE;EI7EE,eAAe,EAAA;EADjB;IAII,YAAY,EAAA;;AAIhB;;;EAKI,yBH5Gc;EG6Gd,mBA/E6B,EAAA;;AR4MnC;;EQtHI,wBAAgB;KAAhB,qBAAgB;UAAhB,gBAAgB;EAChB,gBH7Da,EAAA;;AGiEf;EACE,8BAAsB;UAAtB,sBAAsB,EAAA;;AAiBxB;EACE,cHxIiB,EAAA;;AGuInB;EACE,cHxIiB,EAAA;;AGuInB;EACE,cHxIiB,EAAA;;AGuInB;EACE,cHxIiB,EAAA;;ALiPrB;;;ES7QI,gBH4EqD,EAAA;;ANsMzD;;ES5QI,qBAAqB;EACrB,wBAAwB;EAExB,mBAAkD;EAClD,kBHkEqD;EGjErD,gBAAgB,EAAA;ET8QlB;;IS3QI,eAAe,EAAA;;AAKnB;;EAEE,oBAAmD,EAAA;;AT4QvD;ESvQI,WAAW,EAAA;;ACIb;EAjBA,cAAc;EACd,SAAS;EAET,mBJ4DuD;EI3DvD,mBLuD2B;EKtD3B,gBAR0B;EAS1B,cLiBa,EAAA;EKNb;IALA,gBJmDuD;IIlDvD,oBAA8D,EAAA;;ACjB9D;EAGE,mBAFuC;EAGvC,oBL+DqD;EK9DrD,kBARwB;EASxB,cNqBW,EAAA;;AOtBb;EACE,oBAAiC;EAAjC,qBAAiC;EAAjC,oBAAiC;EAAjC,aAAiC;EACjC,WAAW;EACX,mBN2DqD;EMxDnD,0BAAoB;EAApB,4BAAoB;MAApB,uBAAoB;UAApB,oBAAoB,EAAA;EANxB;IAWM,sBPuDS,EAAA;EOlEf;IAiBM,sBAAiH,EAAA;;AAKvH;;;;EACE,SAAS;EACT,mBAAmB,EAAA;;AAQrB;EAEE,eAvCuB;EAwCvB,yBPrBiB;EOsBjB,mBP1BgB;EO4BhB,cPhBW;EOiBX,kBAAkB;EAClB,mBAAmB;EAGjB,oBAAa;EAAb,qBAAa;EAAb,oBAAa;EAAb,aAAa;EACb,mBAAc;EAAd,sBAAc;MAAd,kBAAc;UAAd,cAAc;EACd,yBAAmB;EAAnB,2BAAmB;MAAnB,sBAAmB;UAAnB,mBAAmB,EAAA;EAbvB;IAsBM,eAAiC,EAAA;EAtBvC;IA0BM,cAAgC,EAAA;;AAKtC;EAEE,gBAAgB;EAGd,mBAAa;EAAb,qBAAa;MAAb,iBAAa;UAAb,aAAa;EACb,YAAY,EAAA;;AAIhB;EAEE,cAAc;EACd,iBAAiB;EACjB,kBAAkB;EAGhB,oBAAa;EAAb,qBAAa;EAAb,oBAAa;EAAb,aAAa;EACb,mBAAc;EAAd,sBAAc;MAAd,kBAAc;UAAd,cAAc,EAAA;EARlB;;;;IAsBM,2BAAmB;QAAnB,4BAAmB;YAAnB,mBAAmB;IACnB,YAAY;IAKd,cAAc;IACd,iBAAiB;IACjB,eNzCmD,EAAA;;AF+FvD;EShJE,SAAS;EACT,UAAU;EACV,SAAS,EAAA;;ATuJX;ESnJE,eAAe;EACf,qBAAkC,EAAA;;AAGpC;EAxBA,kBPoEW;EOnEX,gBP8DuD;EO7DvD,yBRamB,EAAA;EQXnB;IAEE,SAAS;IACT,uBPwDqD;IOvDrD,oBPuDqD,EAAA;;ADwGvD;ESzKA,iBAFsJ;EAGtJ,gBRgEuD;EQ/DvD,eN6B+B;EM3B/B,wBAAgB;KAAhB,qBAAgB;UAAhB,gBAAgB;EAChB,yBTYmB;ESXnB,gBT+De;ES9Df,yBTsBa;ESpBb,oBNdyB;EMezB,eRuDuD;EQtDvD,mBTkD2B;ESjD3B,gBTbqB;EScrB,cTYa;EEsGb,wOAAyN;EO9GvN,8BAA8B;EAC9B,uCAA0D;EAC1D,4BAA4B;EAC5B,wBAAwB;EAExB,qBAAuD;EAIvD,2ENqB8D;EMrB9D,mENqB8D;EMrB9D,2DNqB8D;EMrB9D,oFNqB8D,EAAA;EDkFhE;IFwCA;MErCI,uWAAuW,EAAA,EOvE1W;EA/BD;IACE,aAAa;IACb,yBTXe;ISYf,yBTJW;ISKX,mCTjBiB;YSiBjB,2BTjBiB;ISoBf,2ENU4D;IMV5D,mENU4D;IMV5D,2DNU4D;IMV5D,oFNU4D,EAAA;EMLhE;IACE,yBT9BgB;IS+BhB,mBND+B,EAAA;EMKjC;IACE,aAAa,EAAA;EAGf;IACE,YAAY;IACZ,sBAAsB,EAAA;;ACjCxB;EACE,qBVdY;EUeZ,yBAA+D,EAAA;EAE/D;IACE,cVlBU,EAAA;EUiBZ;IACE,cVlBU,EAAA;EUiBZ;IACE,cVlBU,EAAA;EUiBZ;IACE,cVlBU,EAAA;;AU4CZ;EACE,cV7CU,EAAA;;AUkDd;EAzBA,aAAa;EACb,mBAAgC;EAChC,mBT8BuD;ES5BvD,kBT4BuD;ES3BvD,iBV2BuB;EU1BvB,cV/Bc,EAAA;EUkDd;IAII,cAAc,EAAA;;AC0KlB;;;;;;;;;;;;;;;;;;;EAmBE,SAAS;EACT,UAAU,EAAA;;AAIZ;EACE,mBAzK0B;EA2K1B,kBAAkB;EAClB,gBAhLsB;EAiLtB,kCAzKyC,EAAA;;AA6K3C;;EAEE,kBAAkB;EAClB,oBAAoB,EAAA;;AAItB;;EAEE,iBXjNqB;EWkNrB,oBAAoB,EAAA;;AZlNtB;EYuNE,cA5MiB;EA6MjB,oBAAoB,EAAA;;AAItB;;;;;;EAME,mEX1PqE;EW2PrE,kBAzRsB;EA0RtB,mBXxOyB;EWyOzB,cAnRkB;EAoRlB,kCA/NsC,EAAA;EAqNxC;;;;;;IAaI,cAAc;IACd,cX1Re,EAAA;;AWmSb;EAII,iBVvP6C;EUmQ7C,gBA7SW;EAqTX,aAAa;EAOb,qBAxTiB,EAAA;;AAyRrB;EAII,kBVvP6C;EUmQ7C,gBA7SW;EAqTX,aAAa;EAOb,qBAxTiB,EAAA;;AAyRrB;EAII,oBVvP6C;EUmQ7C,gBA7SW;EAqTX,aAAa;EAOb,qBAxTiB,EAAA;;AAyRrB;EAII,mBVvP6C;EUmQ7C,gBA7SW;EAqTX,aAAa;EAOb,qBAxTiB,EAAA;;AAyRrB;EAII,oBVvP6C;EUmQ7C,gBA7SW;EAqTX,aAAa;EAOb,qBAxTiB,EAAA;;AAyRrB;EAII,eVvP6C;EUmQ7C,gBA7SW;EAqTX,aAAa;EAOb,qBAxTiB,EAAA;;AdoHvB;EcqKE;IAII,eVvP6C,EAAA;EUmPjD;IAII,iBVvP6C,EAAA;EUmPjD;IAII,oBVvP6C,EAAA;EUmPjD;IAII,oBVvP6C,EAAA;EUmPjD;IAII,kBVvP6C,EAAA;EUmPjD;IAII,eVvP6C,EAAA,EUoRhD;;AZpTP;EY2TE,oBAAoB;EACpB,cXzVc;EW0Vd,qBA9NyB;EAgOzB,eAAe,EAAA;EALjB;IASI,cAxO2D,EAAA;EA+N/D;IAgBI,SAAS,EAAA;;AZ7Vb;EYmWE,WAAW;EAEX,gBVlTqD;EUmTrD,SAAS;EACT,oBArOyB;EAuOzB,aAAa;EACb,eAAe;EACf,gCXxWiB;EWyWjB,cAAc,EAAA;;AAIhB;;;EAGE,mBAzS0B;EA0S1B,4BAlOyB;EAmOzB,gBA/SsB,EAAA;;AAmTxB;EACE,kBAAkB,EAAA;;AAIpB;EACE,oBAzOsB;EA0OtB,qBAlPkB,EAAA;;AAsPpB;EACE,oBA/OsB,EAAA;;AAmPxB;EAEI,oBAjP2B;EAkP3B,gBAAgB,EAAA;;AAKpB;EACE,mBApPyB,EAAA;EAmP3B;IAII,qBA/O8B;IAgP9B,iBXnWmB,EAAA;;AWwWvB;EACE,gBAlV0B;EAmV1B,sCV1WqD;EU2WrD,8BX3ZiB,EAAA;EWwZnB;IAMI,gBA3VoB;IA4VpB,cX3Za,EAAA;;AWgajB;EACE,cAAc;EACd,oBVtXqD;EUuXrD,cXnae,EAAA;EWgajB;IAMI,aA/OgB,EAAa;;AAoPjC;EACE,iCXxaW;EWyaX,YAAY;EACZ,qBAAqB,EAAA;;AAIvB;EACE,SAAS,EAAA;;AAIX;EACE,qCV5YqD;EU8YrD,yBX9biB;EW+bjB,yBXncgB;EWqchB,4DAncmE;EAocnE,mBXtZyB;EWuZzB,cX3bW,EAAA;;AW+bb;EACE,SAAS;EACT,2BVpZS;EUsZT,yBX/cgB;EWidhB,4DA/cmE;EAgdnE,cXtcW,EAAA;;AYDb;EACE,kBAlByB;EAmBzB,qBAf4B;EAiB5B,mBZiCyB;EYhCzB,gBAlCsB;EAmCtB,cZTe,EAAA;;AYajB;EACE,eAhDqC;EAiDrC,gBA7CiB,EAAA;;AAiDnB;EACE,iBA1BmB;EA2BnB,cAAc,EAAA;EAEd;IACE,iBAAiB,EAAA;;AAIrB;EAGI,cAAgC;EAChC,gBAAgB,EAAA;;AC9DZ;EACE,gBARe,EAAA;;AAOjB;EACE,iBARsB,EAAA;;AAOxB;EACE,kBAR8B,EAAA;;AAOhC;EACE,mBARuC,EAAA;;AhB+J7C;EgB7JI;IACE,gBAHe,EAAA;EAEjB;IACE,iBAHsB,EAAA;EAExB;IACE,kBAH8B,EAAA;EAEhC;IACE,mBAHuC,EAAA,EAIxC;;AhB2JL;EgB7JI;IACE,gBAHe,EAAA;EAEjB;IACE,iBAHsB,EAAA;EAExB;IACE,kBAH8B,EAAA;EAEhC;IACE,mBAHuC,EAAA,EAIxC;;ACMT;EAAkB,wBAAwB,EAAA;;AAE1C;EACE;IAEI,kCAAkC;IAGpC,mCAA2B;YAA3B,2BAA2B;IAE3B,uBAAuB;IACvB,4BAA4B,EAAA;EAXhC;IAcoB,yBAAyB,EAAA;EAC3C;IAAkB,wBAAwB,EAAA;EAE1C;IAAuB,yBAAyB,EAAA;EAChD;IAAuB,sCAAsC,EAAA;EAC7D;IAAuB,mCAAmC,EAAA;EAC1D;IAAoB,6BAA6B,EAAA;EACjD;IAAoB,8BAA8B,EAAA;EAClD;IAAoB,8BAA8B,EAAA;EAGlD;;IACY,0BAA0B,EAAA;EAEpC;IAAgB,4BAA4B,EAAA;EAI9C;;;IAEqB,WAAW,EAAA;EAGhC;IAAoB,6BAA6B,EAAA;EAGjD;;IAEE,yBdfa;IcgBb,wBAAwB,EAAA;EAI1B;IAAQ,2BAA2B,EAAA;EAEnC;;IACM,wBAAwB,EAAA;EfiDhC;Ie/CQ,0BAA0B,EAAA;EAEhC;IAAQ,aAAa,EAAA;EAErB;;;IAGE,UAAU;IACV,SAAS,EAAA;EAIX;;IACK,uBAAuB,EAAA;EAG5B;IACE,uBAAuB,EAAA,EACxB;;AC3EH;ECoBM,uBAA6D;EAA7D,sBAA6D;ECdnE,gBhBsEuD;EgBrEvD,iBAAiB;EACjB,kBAAkB,EAAA;EpBkJd;IkB1JJ;MCoBM,wBAA6D;MAA7D,uBAA6D,EAAA,EDVlE;EAVD;ICoBM,uBAA6D;IAA7D,sBAA6D;ICdnE,eFFmC;IEGnC,iBAAiB;IACjB,kBAAkB,EAAA;IpBkJd;MkB1JJ;QCoBM,wBAA6D;QAA7D,uBAA6D,EAAA,EDfhE;EALH;IC6BI,gBAA6D;IAA7D,eAA6D;ICvBjE,eFEmC;IEDnC,iBAAiB;IACjB,kBAAkB,EAAA;;AFKlB;EESA,oBAAa;EAAb,qBAAa;EAAb,oBAAa;EAAb,aAAa;EACb,8BAHqB;EAGrB,6BAHqB;EAGrB,2BAHqB;MAGrB,uBAHqB;UAGrB,mBAHqB,EAAA;;AFHrB;EGqBE,mBAAc;EAAd,sBAAc;MAAd,kBAAc;UAAd,cAAc;EACd,eAAe;EACf,cAAc;EAsCd,WADoD,EAAA;EH5DtD;IG0BE,mBAAa;IAAb,qBAAa;QAAb,iBAAa;YAAb,aAAa,EAAA;EH1Bf;IG6BE,mBAAc;IAAd,sBAAc;QAAd,kBAAc;YAAd,cAAc,EAAA;;AHhBhB;EGwCE,WAAmB,EAAA;;AHxCrB;EG4CE,WAAmB,EAAA;;AH5BnB;EAMI,wBAAgB;MAAhB,6BAAgB;UAAhB,gBAAgB,EAAA;;AlBsGlB;EkB5GF;IAMI,wBAAgB;QAAhB,6BAAgB;YAAhB,gBAAgB,EAAA,EACjB;;AlBqGD;EkB5GF;IAMI,wBAAgB;QAAhB,6BAAgB;YAAhB,gBAAgB,EAAA,EACjB;;AAaH;EGpBA,mBAAc;EAAd,sBAAc;MAAd,kBAAc;UAAd,cAAc,EAAA;;AHmCZ;EGHF,eADoD,EAAA;;AHIlD;EGHF,gBADoD,EAAA;;AHIlD;EGHF,UADoD,EAAA;;AHIlD;EGHF,gBADoD,EAAA;;AHIlD;EGHF,gBADoD,EAAA;;AHIlD;EGHF,UADoD,EAAA;;AHIlD;EGHF,gBADoD,EAAA;;AHIlD;EGHF,gBADoD,EAAA;;AHIlD;EGHF,UADoD,EAAA;;AHIlD;EGHF,gBADoD,EAAA;;AHIlD;EGHF,gBADoD,EAAA;;AHIlD;EGHF,WADoD,EAAA;;ArB6ElD;EkB9FA;IGjBF,mBAAa;IAAb,qBAAa;QAAb,iBAAa;YAAb,aAAa;IA2Bb,WAAmB,EAAA;EHJnB;IGpBA,mBAAc;IAAd,sBAAc;QAAd,kBAAc;YAAd,cAAc,EAAA;EH0BZ;IGEF,WAAmB,EAAA;EHOjB;IGHF,eADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,UADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,UADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,UADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,WADoD,EAAA,EHOjD;;AlBsED;EkB9FA;IGjBF,mBAAa;IAAb,qBAAa;QAAb,iBAAa;YAAb,aAAa;IA2Bb,WAAmB,EAAA;EHJnB;IGpBA,mBAAc;IAAd,sBAAc;QAAd,kBAAc;YAAd,cAAc,EAAA;EH0BZ;IGEF,WAAmB,EAAA;EHOjB;IGHF,eADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,UADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,UADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,UADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,gBADoD,EAAA;EHIlD;IGHF,WADoD,EAAA,EHOjD;;AAKL;EACE,WAAW,EAAA;;AAIb;EACE,YAAY,EAAA;;AA8Bd;ECzGM,sBAA6D;EAA7D,uBAA6D,EAAA;EnBsI/D;IkB7BJ;MCzGM,uBAA6D;MAA7D,wBAA6D,EAAA,EDwIlE;EA/BD;IG1DE,2BAD4E;IFrC1E,qBAA6D;IAA7D,sBAA6D,EAAA;EnB6H7D;IkB7BJ;MG1DE,4BAD4E;MFrC1E,sBAA6D;MAA7D,uBAA6D,EAAA,ED6G1D;EArCP;IG/BE,WAAmB,EAAA;EHmCrB;IG/BE,WAAmB,EAAA;EHuCnB;IGnCA,+BADgH,EAAA;EHoChH;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,0BADgH,EAAA;EHoChH;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,0BADgH,EAAA;EHoChH;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,0BADgH,EAAA;EHoChH;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;ErB6E9G;IkBrDJ;MG/BE,WAAmB,EAAA;IHmCrB;MG/BE,WAAmB,EAAA;IHuCnB;MGnCA,gCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHwBlH;MG/BE,WAAmB,EAAA;IHmCrB;MG/BE,WAAmB,EAAA;IHuCnB;MGnCA,gCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA,EHsC/G;ElBuCC;IkBrDJ;MG/BE,WAAmB,EAAA;IHmCrB;MG/BE,WAAmB,EAAA;IHuCnB;MGnCA,gCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,2BADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA,EHsC/G;;AA8CH;EC7IM,uBAA6D;EAA7D,sBAA6D,EAAA;EnBsI/D;IkBOJ;MC7IM,wBAA6D;MAA7D,uBAA6D,EAAA,EDkJhE;;AAID;ECtJI,uBAA6D;EAA7D,sBAA6D,EAAA;EnBsI/D;IkBgBF;MCtJI,wBAA6D;MAA7D,uBAA6D,EAAA,EDwJhE;;AAXH;EC7IM,uBAA6D;EAA7D,sBAA6D,EAAA;EnBsI/D;IkBOJ;MC7IM,wBAA6D;MAA7D,uBAA6D,EAAA,ED6JhE;;AI/JH;ED4DE,WADoD,EAAA;;AC3DtD;ED4DE,UADoD,EAAA;;AC3DtD;ED4DE,gBADoD,EAAA;;AC3DtD;ED4DE,UADoD,EAAA;;AC3DtD;ED4DE,UADoD,EAAA;;AC3DtD;ED4DE,gBADoD,EAAA;;AC3DtD;ED4DE,gBADoD,EAAA;;AC3DtD;ED4DE,YADoD,EAAA;;ArB6ElD;EsBxIJ;ID4DE,WADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,YADoD,EAAA,ECzDrD;;AtBsIG;EsBxIJ;ID4DE,WADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,YADoD,EAAA,ECzDrD;;AAFD;ED4DE,2BADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,4BADgH,EAAA;;ArB6E9G;EsBxIJ;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,6BADgH,EAAA;EC3DlH;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,6BADgH,EAAA,ECzDjH;;AtBsIG;EsBxIJ;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADg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A;;ANoO3B;EMpOF,uCAA6B,EAAA;;ANgO3B;EMhOF,gBAA6B,EAAA;;ANoO3B;EMpOF,iCAA6B,EAAA;;ANgO3B;EMhOF,sBAA6B,EAAA;;ANoO3B;EMpOF,uCAA6B,EAAA;;ANgO3B;EMhOF,sBAA6B,EAAA;;ANoO3B;EMpOF,uCAA6B,EAAA;;ANgO3B;EMhOF,gBAA6B,EAAA;;ANoO3B;EMpOF,iCAA6B,EAAA;;ANgO3B;EMhOF,sBAA6B,EAAA;;ANoO3B;EMpOF,uCAA6B,EAAA;;ANgO3B;EMhOF,sBAA6B,EAAA;;ANoO3B;EMpOF,uCAA6B,EAAA;;AxByI3B;EkBuFA;IMhOF,eAA6B,EAAA;ENoO3B;IMpOF,iCAA6B,EAAA;ENgO3B;IMhOF,qBAA6B,EAAA;ENoO3B;IMpOF,uCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA,ENsO1B;;AlB7FD;EkBuFA;IMhOF,eAA6B,EAAA;ENoO3B;IMpOF,iCAA6B,EAAA;ENgO3B;IMhOF,qBAA6B,EAAA;ENoO3B;IMpOF,uCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,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AA,ED6G1D;EArCP;IG/BE,YAAmB,EAAA;EHmCrB;IG/BE,YAAmB,EAAA;EHuCnB;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,4BADgH,EAAA;ErB6E9G;IkBrDJ;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,6BADgH,EAAA;IHwBlH;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,6BADgH,EAAA,EHsC/G;ElBuCC;IkBrDJ;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IH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DkB;MAyDlB,wBAzDkB;UAyDlB,oBAzDkB,EAAA;;AD6EhB;ECpCF,yBAxCgB;EAwChB,2BAxCgB;MAwChB,sBAxCgB;UAwChB,mBAxCgB,EAAA;;ADgFd;ECxBF,0BAxDgB;MAwDhB,2BAxDgB;UAwDhB,kBAxDgB,EAAA;;AD4Ed;ECpCF,0BAvCkB;EAuClB,4BAvCkB;MAuClB,uBAvCkB;UAuClB,oBAvCkB,EAAA;;AD+EhB;ECxBF,2BAvDkB;MAuDlB,4BAvDkB;UAuDlB,mBAvDkB,EAAA;;ADqFlB;EC/CA,wBAnDkB;EAmDlB,+BAnDkB;MAmDlB,qBAnDkB;UAmDlB,uBAnDkB;EAoDlB,yBAxCgB;EAwChB,2BAxCgB;MAwChB,sBAxCgB;UAwChB,mBAxCgB;EDwFd,6BAAqB;MAArB,0BAAqB;UAArB,qBAAqB,EAAA;;AAMnB;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;A7DyDZ;E6DxDA;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/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","file":"foundation-prototype.css","sourcesContent":["@charset \"UTF-8\";\n/**\n * Foundation for Sites by ZURB\n * Version 6.5.3\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n@media print, screen and (min-width: 40em) {\n  .reveal, .reveal.tiny, .reveal.small, .reveal.large {\n    right: auto;\n    left: auto;\n    margin: 0 auto; } }\n\n/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  line-height: 1.15;\n  -webkit-text-size-adjust: 100%; }\n\nbody {\n  margin: 0; }\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0; }\n\nhr {\n  box-sizing: content-box;\n  height: 0;\n  overflow: visible; }\n\npre {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\na {\n  background-color: transparent; }\n\nabbr[title] {\n  border-bottom: none;\n  text-decoration: underline;\n  text-decoration: underline dotted; }\n\nb,\nstrong {\n  font-weight: bolder; }\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\nsmall {\n  font-size: 80%; }\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline; }\n\nsub {\n  bottom: -0.25em; }\n\nsup {\n  top: -0.5em; }\n\nimg {\n  border-style: none; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: 100%;\n  line-height: 1.15;\n  margin: 0; }\n\nbutton,\ninput {\n  overflow: visible; }\n\nbutton,\nselect {\n  text-transform: none; }\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button; }\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0; }\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText; }\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em; }\n\nlegend {\n  box-sizing: border-box;\n  color: inherit;\n  display: table;\n  max-width: 100%;\n  padding: 0;\n  white-space: normal; }\n\nprogress {\n  vertical-align: baseline; }\n\ntextarea {\n  overflow: auto; }\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  padding: 0; }\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto; }\n\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  outline-offset: -2px; }\n\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none; }\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  font: inherit; }\n\ndetails {\n  display: block; }\n\nsummary {\n  display: list-item; }\n\ntemplate {\n  display: none; }\n\n[hidden] {\n  display: none; }\n\n.foundation-mq {\n  font-family: \"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em\"; }\n\nhtml {\n  box-sizing: border-box;\n  font-size: 100%; }\n\n*,\n*::before,\n*::after {\n  box-sizing: inherit; }\n\nbody {\n  margin: 0;\n  padding: 0;\n  background: #fefefe;\n  font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale; }\n\nimg {\n  display: inline-block;\n  vertical-align: middle;\n  max-width: 100%;\n  height: auto;\n  -ms-interpolation-mode: bicubic; }\n\ntextarea {\n  height: auto;\n  min-height: 50px;\n  border-radius: 0; }\n\nselect {\n  box-sizing: border-box;\n  width: 100%;\n  border-radius: 0; }\n\n.map_canvas img,\n.map_canvas embed,\n.map_canvas object,\n.mqa-display img,\n.mqa-display embed,\n.mqa-display object {\n  max-width: none !important; }\n\nbutton {\n  padding: 0;\n  appearance: none;\n  border: 0;\n  border-radius: 0;\n  background: transparent;\n  line-height: 1;\n  cursor: auto; }\n  [data-whatinput='mouse'] button {\n    outline: 0; }\n\npre {\n  overflow: auto; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit; }\n\n.is-visible {\n  display: block !important; }\n\n.is-hidden {\n  display: none !important; }\n\n[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],\ntextarea {\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n  appearance: none; }\n  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,\n  textarea:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n\ntextarea {\n  max-width: 100%; }\n  textarea[rows] {\n    height: auto; }\n\ninput:disabled, input[readonly],\ntextarea:disabled,\ntextarea[readonly] {\n  background-color: #e6e6e6;\n  cursor: not-allowed; }\n\n[type='submit'],\n[type='button'] {\n  appearance: none;\n  border-radius: 0; }\n\ninput[type='search'] {\n  box-sizing: border-box; }\n\n::placeholder {\n  color: #cacaca; }\n\n[type='file'],\n[type='checkbox'],\n[type='radio'] {\n  margin: 0 0 1rem; }\n\n[type='checkbox'] + label,\n[type='radio'] + label {\n  display: inline-block;\n  vertical-align: baseline;\n  margin-left: 0.5rem;\n  margin-right: 1rem;\n  margin-bottom: 0; }\n  [type='checkbox'] + label[for],\n  [type='radio'] + label[for] {\n    cursor: pointer; }\n\nlabel > [type='checkbox'],\nlabel > [type='radio'] {\n  margin-right: 0.5rem; }\n\n[type='file'] {\n  width: 100%; }\n\nlabel {\n  display: block;\n  margin: 0;\n  font-size: 0.875rem;\n  font-weight: normal;\n  line-height: 1.8;\n  color: #0a0a0a; }\n  label.middle {\n    margin: 0 0 1rem;\n    padding: 0.5625rem 0; }\n\n.help-text {\n  margin-top: -0.5rem;\n  font-size: 0.8125rem;\n  font-style: italic;\n  color: #0a0a0a; }\n\n.input-group {\n  display: flex;\n  width: 100%;\n  margin-bottom: 1rem;\n  align-items: stretch; }\n  .input-group > :first-child, .input-group > :first-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n  .input-group > :last-child, .input-group > :last-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n\n.input-group-label, .input-group-field, .input-group-button, .input-group-button a,\n.input-group-button input,\n.input-group-button button,\n.input-group-button label {\n  margin: 0;\n  white-space: nowrap; }\n\n.input-group-label {\n  padding: 0 1rem;\n  border: 1px solid #cacaca;\n  background: #e6e6e6;\n  color: #0a0a0a;\n  text-align: center;\n  white-space: nowrap;\n  display: flex;\n  flex: 0 0 auto;\n  align-items: center; }\n  .input-group-label:first-child {\n    border-right: 0; }\n  .input-group-label:last-child {\n    border-left: 0; }\n\n.input-group-field {\n  border-radius: 0;\n  flex: 1 1 0px;\n  min-width: 0; }\n\n.input-group-button {\n  padding-top: 0;\n  padding-bottom: 0;\n  text-align: center;\n  display: flex;\n  flex: 0 0 auto; }\n  .input-group-button a,\n  .input-group-button input,\n  .input-group-button button,\n  .input-group-button label {\n    align-self: stretch;\n    height: auto;\n    padding-top: 0;\n    padding-bottom: 0;\n    font-size: 1rem; }\n\nfieldset {\n  margin: 0;\n  padding: 0;\n  border: 0; }\n\nlegend {\n  max-width: 100%;\n  margin-bottom: 0.5rem; }\n\n.fieldset {\n  margin: 1.125rem 0;\n  padding: 1.25rem;\n  border: 1px solid #cacaca; }\n  .fieldset legend {\n    margin: 0;\n    margin-left: -0.1875rem;\n    padding: 0 0.1875rem; }\n\nselect {\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  appearance: none;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>\");\n  background-origin: content-box;\n  background-position: right -1rem center;\n  background-repeat: no-repeat;\n  background-size: 9px 6px;\n  padding-right: 1.5rem;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  @media screen and (min-width: 0\\0) {\n    select {\n      background-image: url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==\"); } }\n  select:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  select:disabled {\n    background-color: #e6e6e6;\n    cursor: not-allowed; }\n  select::-ms-expand {\n    display: none; }\n  select[multiple] {\n    height: auto;\n    background-image: none; }\n\n.is-invalid-input:not(:focus) {\n  border-color: #cc4b37;\n  background-color: #f9ecea; }\n  .is-invalid-input:not(:focus)::placeholder {\n    color: #cc4b37; }\n\n.is-invalid-label {\n  color: #cc4b37; }\n\n.form-error {\n  display: none;\n  margin-top: -0.5rem;\n  margin-bottom: 1rem;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #cc4b37; }\n  .form-error.is-visible {\n    display: block; }\n\ndiv,\ndl,\ndt,\ndd,\nul,\nol,\nli,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\npre,\nform,\np,\nblockquote,\nth,\ntd {\n  margin: 0;\n  padding: 0; }\n\np {\n  margin-bottom: 1rem;\n  font-size: inherit;\n  line-height: 1.6;\n  text-rendering: optimizeLegibility; }\n\nem,\ni {\n  font-style: italic;\n  line-height: inherit; }\n\nstrong,\nb {\n  font-weight: bold;\n  line-height: inherit; }\n\nsmall {\n  font-size: 80%;\n  line-height: inherit; }\n\nh1, .h1,\nh2, .h2,\nh3, .h3,\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n  font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  color: inherit;\n  text-rendering: optimizeLegibility; }\n  h1 small, .h1 small,\n  h2 small, .h2 small,\n  h3 small, .h3 small,\n  h4 small, .h4 small,\n  h5 small, .h5 small,\n  h6 small, .h6 small {\n    line-height: 0;\n    color: #cacaca; }\n\nh1, .h1 {\n  font-size: 1.5rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh2, .h2 {\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh3, .h3 {\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh4, .h4 {\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh5, .h5 {\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh6, .h6 {\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n  h1, .h1 {\n    font-size: 3rem; }\n  h2, .h2 {\n    font-size: 2.5rem; }\n  h3, .h3 {\n    font-size: 1.9375rem; }\n  h4, .h4 {\n    font-size: 1.5625rem; }\n  h5, .h5 {\n    font-size: 1.25rem; }\n  h6, .h6 {\n    font-size: 1rem; } }\n\na {\n  line-height: inherit;\n  color: #1779ba;\n  text-decoration: none;\n  cursor: pointer; }\n  a:hover, a:focus {\n    color: #1468a0; }\n  a img {\n    border: 0; }\n\nhr {\n  clear: both;\n  max-width: 75rem;\n  height: 0;\n  margin: 1.25rem auto;\n  border-top: 0;\n  border-right: 0;\n  border-bottom: 1px solid #cacaca;\n  border-left: 0; }\n\nul,\nol,\ndl {\n  margin-bottom: 1rem;\n  list-style-position: outside;\n  line-height: 1.6; }\n\nli {\n  font-size: inherit; }\n\nul {\n  margin-left: 1.25rem;\n  list-style-type: disc; }\n\nol {\n  margin-left: 1.25rem; }\n\nul ul, ol ul, ul ol, ol ol {\n  margin-left: 1.25rem;\n  margin-bottom: 0; }\n\ndl {\n  margin-bottom: 1rem; }\n  dl dt {\n    margin-bottom: 0.3rem;\n    font-weight: bold; }\n\nblockquote {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 1.25rem 0 1.1875rem;\n  border-left: 1px solid #cacaca; }\n  blockquote, blockquote p {\n    line-height: 1.6;\n    color: #8a8a8a; }\n\ncite {\n  display: block;\n  font-size: 0.8125rem;\n  color: #8a8a8a; }\n  cite:before {\n    content: \"— \"; }\n\nabbr, abbr[title] {\n  border-bottom: 1px dotted #0a0a0a;\n  cursor: help;\n  text-decoration: none; }\n\nfigure {\n  margin: 0; }\n\ncode {\n  padding: 0.125rem 0.3125rem 0.0625rem;\n  border: 1px solid #cacaca;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  font-weight: normal;\n  color: #0a0a0a; }\n\nkbd {\n  margin: 0;\n  padding: 0.125rem 0.25rem 0;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  color: #0a0a0a; }\n\n.subheader {\n  margin-top: 0.2rem;\n  margin-bottom: 0.5rem;\n  font-weight: normal;\n  line-height: 1.4;\n  color: #8a8a8a; }\n\n.lead {\n  font-size: 125%;\n  line-height: 1.6; }\n\n.stat {\n  font-size: 2.5rem;\n  line-height: 1; }\n  p + .stat {\n    margin-top: -1rem; }\n\nul.no-bullet, ol.no-bullet {\n  margin-left: 0;\n  list-style: none; }\n\n.text-left {\n  text-align: left; }\n\n.text-right {\n  text-align: right; }\n\n.text-center {\n  text-align: center; }\n\n.text-justify {\n  text-align: justify; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-text-left {\n    text-align: left; }\n  .medium-text-right {\n    text-align: right; }\n  .medium-text-center {\n    text-align: center; }\n  .medium-text-justify {\n    text-align: justify; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-text-left {\n    text-align: left; }\n  .large-text-right {\n    text-align: right; }\n  .large-text-center {\n    text-align: center; }\n  .large-text-justify {\n    text-align: justify; } }\n\n.show-for-print {\n  display: none !important; }\n\n@media print {\n  * {\n    background: transparent !important;\n    box-shadow: none !important;\n    color: black !important;\n    text-shadow: none !important; }\n  .show-for-print {\n    display: block !important; }\n  .hide-for-print {\n    display: none !important; }\n  table.show-for-print {\n    display: table !important; }\n  thead.show-for-print {\n    display: table-header-group !important; }\n  tbody.show-for-print {\n    display: table-row-group !important; }\n  tr.show-for-print {\n    display: table-row !important; }\n  td.show-for-print {\n    display: table-cell !important; }\n  th.show-for-print {\n    display: table-cell !important; }\n  a,\n  a:visited {\n    text-decoration: underline; }\n  a[href]:after {\n    content: \" (\" attr(href) \")\"; }\n  .ir a:after,\n  a[href^='javascript:']:after,\n  a[href^='#']:after {\n    content: ''; }\n  abbr[title]:after {\n    content: \" (\" attr(title) \")\"; }\n  pre,\n  blockquote {\n    border: 1px solid #8a8a8a;\n    page-break-inside: avoid; }\n  thead {\n    display: table-header-group; }\n  tr,\n  img {\n    page-break-inside: avoid; }\n  img {\n    max-width: 100% !important; }\n  @page {\n    margin: 0.5cm; }\n  p,\n  h2,\n  h3 {\n    orphans: 3;\n    widows: 3; }\n  h2,\n  h3 {\n    page-break-after: avoid; }\n  .print-break-inside {\n    page-break-inside: auto; } }\n\n.grid-container {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n  max-width: 75rem;\n  margin-left: auto;\n  margin-right: auto; }\n  @media print, screen and (min-width: 40em) {\n    .grid-container {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n  .grid-container.fluid {\n    padding-right: 0.625rem;\n    padding-left: 0.625rem;\n    max-width: 100%;\n    margin-left: auto;\n    margin-right: auto; }\n    @media print, screen and (min-width: 40em) {\n      .grid-container.fluid {\n        padding-right: 0.9375rem;\n        padding-left: 0.9375rem; } }\n  .grid-container.full {\n    padding-right: 0;\n    padding-left: 0;\n    max-width: 100%;\n    margin-left: auto;\n    margin-right: auto; }\n\n.grid-x {\n  display: flex;\n  flex-flow: row wrap; }\n\n.cell {\n  flex: 0 0 auto;\n  min-height: 0px;\n  min-width: 0px;\n  width: 100%; }\n  .cell.auto {\n    flex: 1 1 0px; }\n  .cell.shrink {\n    flex: 0 0 auto; }\n\n.grid-x > .auto {\n  width: auto; }\n\n.grid-x > .shrink {\n  width: auto; }\n\n.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {\n  flex-basis: auto; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {\n    flex-basis: auto; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {\n    flex-basis: auto; } }\n\n.grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {\n  flex: 0 0 auto; }\n\n.grid-x > .small-1 {\n  width: 8.33333%; }\n\n.grid-x > .small-2 {\n  width: 16.66667%; }\n\n.grid-x > .small-3 {\n  width: 25%; }\n\n.grid-x > .small-4 {\n  width: 33.33333%; }\n\n.grid-x > .small-5 {\n  width: 41.66667%; }\n\n.grid-x > .small-6 {\n  width: 50%; }\n\n.grid-x > .small-7 {\n  width: 58.33333%; }\n\n.grid-x > .small-8 {\n  width: 66.66667%; }\n\n.grid-x > .small-9 {\n  width: 75%; }\n\n.grid-x > .small-10 {\n  width: 83.33333%; }\n\n.grid-x > .small-11 {\n  width: 91.66667%; }\n\n.grid-x > .small-12 {\n  width: 100%; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-x > .medium-auto {\n    flex: 1 1 0px;\n    width: auto; }\n  .grid-x > .medium-shrink, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {\n    flex: 0 0 auto; }\n  .grid-x > .medium-shrink {\n    width: auto; }\n  .grid-x > .medium-1 {\n    width: 8.33333%; }\n  .grid-x > .medium-2 {\n    width: 16.66667%; }\n  .grid-x > .medium-3 {\n    width: 25%; }\n  .grid-x > .medium-4 {\n    width: 33.33333%; }\n  .grid-x > .medium-5 {\n    width: 41.66667%; }\n  .grid-x > .medium-6 {\n    width: 50%; }\n  .grid-x > .medium-7 {\n    width: 58.33333%; }\n  .grid-x > .medium-8 {\n    width: 66.66667%; }\n  .grid-x > .medium-9 {\n    width: 75%; }\n  .grid-x > .medium-10 {\n    width: 83.33333%; }\n  .grid-x > .medium-11 {\n    width: 91.66667%; }\n  .grid-x > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-x > .large-auto {\n    flex: 1 1 0px;\n    width: auto; }\n  .grid-x > .large-shrink, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {\n    flex: 0 0 auto; }\n  .grid-x > .large-shrink {\n    width: auto; }\n  .grid-x > .large-1 {\n    width: 8.33333%; }\n  .grid-x > .large-2 {\n    width: 16.66667%; }\n  .grid-x > .large-3 {\n    width: 25%; }\n  .grid-x > .large-4 {\n    width: 33.33333%; }\n  .grid-x > .large-5 {\n    width: 41.66667%; }\n  .grid-x > .large-6 {\n    width: 50%; }\n  .grid-x > .large-7 {\n    width: 58.33333%; }\n  .grid-x > .large-8 {\n    width: 66.66667%; }\n  .grid-x > .large-9 {\n    width: 75%; }\n  .grid-x > .large-10 {\n    width: 83.33333%; }\n  .grid-x > .large-11 {\n    width: 91.66667%; }\n  .grid-x > .large-12 {\n    width: 100%; } }\n\n.grid-margin-x:not(.grid-x) > .cell {\n  width: auto; }\n\n.grid-margin-y:not(.grid-y) > .cell {\n  height: auto; }\n\n.grid-margin-x {\n  margin-left: -0.625rem;\n  margin-right: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x {\n      margin-left: -0.9375rem;\n      margin-right: -0.9375rem; } }\n  .grid-margin-x > .cell {\n    width: calc(100% - 1.25rem);\n    margin-left: 0.625rem;\n    margin-right: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x > .cell {\n      width: calc(100% - 1.875rem);\n      margin-left: 0.9375rem;\n      margin-right: 0.9375rem; } }\n  .grid-margin-x > .auto {\n    width: auto; }\n  .grid-margin-x > .shrink {\n    width: auto; }\n  .grid-margin-x > .small-1 {\n    width: calc(8.33333% - 1.25rem); }\n  .grid-margin-x > .small-2 {\n    width: calc(16.66667% - 1.25rem); }\n  .grid-margin-x > .small-3 {\n    width: calc(25% - 1.25rem); }\n  .grid-margin-x > .small-4 {\n    width: calc(33.33333% - 1.25rem); }\n  .grid-margin-x > .small-5 {\n    width: calc(41.66667% - 1.25rem); }\n  .grid-margin-x > .small-6 {\n    width: calc(50% - 1.25rem); }\n  .grid-margin-x > .small-7 {\n    width: calc(58.33333% - 1.25rem); }\n  .grid-margin-x > .small-8 {\n    width: calc(66.66667% - 1.25rem); }\n  .grid-margin-x > .small-9 {\n    width: calc(75% - 1.25rem); }\n  .grid-margin-x > .small-10 {\n    width: calc(83.33333% - 1.25rem); }\n  .grid-margin-x > .small-11 {\n    width: calc(91.66667% - 1.25rem); }\n  .grid-margin-x > .small-12 {\n    width: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x > .auto {\n      width: auto; }\n    .grid-margin-x > .shrink {\n      width: auto; }\n    .grid-margin-x > .small-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .small-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .small-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .small-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .small-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .small-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .small-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .small-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .small-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .small-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .small-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .small-12 {\n      width: calc(100% - 1.875rem); }\n    .grid-margin-x > .medium-auto {\n      width: auto; }\n    .grid-margin-x > .medium-shrink {\n      width: auto; }\n    .grid-margin-x > .medium-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .medium-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .medium-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .medium-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .medium-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .medium-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .medium-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .medium-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .medium-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .medium-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .medium-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .medium-12 {\n      width: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-x > .large-auto {\n      width: auto; }\n    .grid-margin-x > .large-shrink {\n      width: auto; }\n    .grid-margin-x > .large-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .large-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .large-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .large-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .large-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .large-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .large-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .large-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .large-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .large-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .large-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .large-12 {\n      width: calc(100% - 1.875rem); } }\n\n.grid-padding-x .grid-padding-x {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-x .grid-padding-x {\n      margin-right: -0.9375rem;\n      margin-left: -0.9375rem; } }\n\n.grid-container:not(.full) > .grid-padding-x {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-container:not(.full) > .grid-padding-x {\n      margin-right: -0.9375rem;\n      margin-left: -0.9375rem; } }\n\n.grid-padding-x > .cell {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-x > .cell {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n\n.small-up-1 > .cell {\n  width: 100%; }\n\n.small-up-2 > .cell {\n  width: 50%; }\n\n.small-up-3 > .cell {\n  width: 33.33333%; }\n\n.small-up-4 > .cell {\n  width: 25%; }\n\n.small-up-5 > .cell {\n  width: 20%; }\n\n.small-up-6 > .cell {\n  width: 16.66667%; }\n\n.small-up-7 > .cell {\n  width: 14.28571%; }\n\n.small-up-8 > .cell {\n  width: 12.5%; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-up-1 > .cell {\n    width: 100%; }\n  .medium-up-2 > .cell {\n    width: 50%; }\n  .medium-up-3 > .cell {\n    width: 33.33333%; }\n  .medium-up-4 > .cell {\n    width: 25%; }\n  .medium-up-5 > .cell {\n    width: 20%; }\n  .medium-up-6 > .cell {\n    width: 16.66667%; }\n  .medium-up-7 > .cell {\n    width: 14.28571%; }\n  .medium-up-8 > .cell {\n    width: 12.5%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-up-1 > .cell {\n    width: 100%; }\n  .large-up-2 > .cell {\n    width: 50%; }\n  .large-up-3 > .cell {\n    width: 33.33333%; }\n  .large-up-4 > .cell {\n    width: 25%; }\n  .large-up-5 > .cell {\n    width: 20%; }\n  .large-up-6 > .cell {\n    width: 16.66667%; }\n  .large-up-7 > .cell {\n    width: 14.28571%; }\n  .large-up-8 > .cell {\n    width: 12.5%; } }\n\n.grid-margin-x.small-up-1 > .cell {\n  width: calc(100% - 1.25rem); }\n\n.grid-margin-x.small-up-2 > .cell {\n  width: calc(50% - 1.25rem); }\n\n.grid-margin-x.small-up-3 > .cell {\n  width: calc(33.33333% - 1.25rem); }\n\n.grid-margin-x.small-up-4 > .cell {\n  width: calc(25% - 1.25rem); }\n\n.grid-margin-x.small-up-5 > .cell {\n  width: calc(20% - 1.25rem); }\n\n.grid-margin-x.small-up-6 > .cell {\n  width: calc(16.66667% - 1.25rem); }\n\n.grid-margin-x.small-up-7 > .cell {\n  width: calc(14.28571% - 1.25rem); }\n\n.grid-margin-x.small-up-8 > .cell {\n  width: calc(12.5% - 1.25rem); }\n\n@media print, screen and (min-width: 40em) {\n  .grid-margin-x.small-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.small-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.small-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.small-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.small-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.small-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.small-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.small-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); }\n  .grid-margin-x.medium-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.medium-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.medium-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.medium-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.medium-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.medium-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.medium-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.medium-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-margin-x.large-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.large-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.large-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.large-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.large-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.large-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.large-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.large-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); } }\n\n.small-margin-collapse {\n  margin-right: 0;\n  margin-left: 0; }\n  .small-margin-collapse > .cell {\n    margin-right: 0;\n    margin-left: 0; }\n  .small-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .small-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .small-margin-collapse > .small-3 {\n    width: 25%; }\n  .small-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .small-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .small-margin-collapse > .small-6 {\n    width: 50%; }\n  .small-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .small-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .small-margin-collapse > .small-9 {\n    width: 75%; }\n  .small-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .small-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .small-margin-collapse > .small-12 {\n    width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .small-margin-collapse > .medium-1 {\n      width: 8.33333%; }\n    .small-margin-collapse > .medium-2 {\n      width: 16.66667%; }\n    .small-margin-collapse > .medium-3 {\n      width: 25%; }\n    .small-margin-collapse > .medium-4 {\n      width: 33.33333%; }\n    .small-margin-collapse > .medium-5 {\n      width: 41.66667%; }\n    .small-margin-collapse > .medium-6 {\n      width: 50%; }\n    .small-margin-collapse > .medium-7 {\n      width: 58.33333%; }\n    .small-margin-collapse > .medium-8 {\n      width: 66.66667%; }\n    .small-margin-collapse > .medium-9 {\n      width: 75%; }\n    .small-margin-collapse > .medium-10 {\n      width: 83.33333%; }\n    .small-margin-collapse > .medium-11 {\n      width: 91.66667%; }\n    .small-margin-collapse > .medium-12 {\n      width: 100%; } }\n  @media print, screen and (min-width: 64em) {\n    .small-margin-collapse > .large-1 {\n      width: 8.33333%; }\n    .small-margin-collapse > .large-2 {\n      width: 16.66667%; }\n    .small-margin-collapse > .large-3 {\n      width: 25%; }\n    .small-margin-collapse > .large-4 {\n      width: 33.33333%; }\n    .small-margin-collapse > .large-5 {\n      width: 41.66667%; }\n    .small-margin-collapse > .large-6 {\n      width: 50%; }\n    .small-margin-collapse > .large-7 {\n      width: 58.33333%; }\n    .small-margin-collapse > .large-8 {\n      width: 66.66667%; }\n    .small-margin-collapse > .large-9 {\n      width: 75%; }\n    .small-margin-collapse > .large-10 {\n      width: 83.33333%; }\n    .small-margin-collapse > .large-11 {\n      width: 91.66667%; }\n    .small-margin-collapse > .large-12 {\n      width: 100%; } }\n\n.small-padding-collapse {\n  margin-right: 0;\n  margin-left: 0; }\n  .small-padding-collapse > .cell {\n    padding-right: 0;\n    padding-left: 0; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-margin-collapse > .cell {\n      margin-right: 0;\n      margin-left: 0; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .small-3 {\n    width: 25%; }\n  .medium-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .small-6 {\n    width: 50%; }\n  .medium-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .small-9 {\n    width: 75%; }\n  .medium-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .small-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse > .medium-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .medium-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .medium-3 {\n    width: 25%; }\n  .medium-margin-collapse > .medium-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .medium-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .medium-6 {\n    width: 50%; }\n  .medium-margin-collapse > .medium-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .medium-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .medium-9 {\n    width: 75%; }\n  .medium-margin-collapse > .medium-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .medium-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .medium-margin-collapse > .large-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .large-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .large-3 {\n    width: 25%; }\n  .medium-margin-collapse > .large-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .large-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .large-6 {\n    width: 50%; }\n  .medium-margin-collapse > .large-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .large-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .large-9 {\n    width: 75%; }\n  .medium-margin-collapse > .large-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .large-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .large-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-padding-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-padding-collapse > .cell {\n      padding-right: 0;\n      padding-left: 0; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .large-margin-collapse > .cell {\n      margin-right: 0;\n      margin-left: 0; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .small-3 {\n    width: 25%; }\n  .large-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .small-6 {\n    width: 50%; }\n  .large-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .small-9 {\n    width: 75%; }\n  .large-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .small-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .medium-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .medium-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .medium-3 {\n    width: 25%; }\n  .large-margin-collapse > .medium-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .medium-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .medium-6 {\n    width: 50%; }\n  .large-margin-collapse > .medium-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .medium-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .medium-9 {\n    width: 75%; }\n  .large-margin-collapse > .medium-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .medium-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .large-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .large-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .large-3 {\n    width: 25%; }\n  .large-margin-collapse > .large-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .large-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .large-6 {\n    width: 50%; }\n  .large-margin-collapse > .large-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .large-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .large-9 {\n    width: 75%; }\n  .large-margin-collapse > .large-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .large-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .large-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-padding-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .large-padding-collapse > .cell {\n      padding-right: 0;\n      padding-left: 0; } }\n\n.small-offset-0 {\n  margin-left: 0%; }\n\n.grid-margin-x > .small-offset-0 {\n  margin-left: calc(0% + 0.625rem); }\n\n.small-offset-1 {\n  margin-left: 8.33333%; }\n\n.grid-margin-x > .small-offset-1 {\n  margin-left: calc(8.33333% + 0.625rem); }\n\n.small-offset-2 {\n  margin-left: 16.66667%; }\n\n.grid-margin-x > .small-offset-2 {\n  margin-left: calc(16.66667% + 0.625rem); }\n\n.small-offset-3 {\n  margin-left: 25%; }\n\n.grid-margin-x > .small-offset-3 {\n  margin-left: calc(25% + 0.625rem); }\n\n.small-offset-4 {\n  margin-left: 33.33333%; }\n\n.grid-margin-x > .small-offset-4 {\n  margin-left: calc(33.33333% + 0.625rem); }\n\n.small-offset-5 {\n  margin-left: 41.66667%; }\n\n.grid-margin-x > .small-offset-5 {\n  margin-left: calc(41.66667% + 0.625rem); }\n\n.small-offset-6 {\n  margin-left: 50%; }\n\n.grid-margin-x > .small-offset-6 {\n  margin-left: calc(50% + 0.625rem); }\n\n.small-offset-7 {\n  margin-left: 58.33333%; }\n\n.grid-margin-x > .small-offset-7 {\n  margin-left: calc(58.33333% + 0.625rem); }\n\n.small-offset-8 {\n  margin-left: 66.66667%; }\n\n.grid-margin-x > .small-offset-8 {\n  margin-left: calc(66.66667% + 0.625rem); }\n\n.small-offset-9 {\n  margin-left: 75%; }\n\n.grid-margin-x > .small-offset-9 {\n  margin-left: calc(75% + 0.625rem); }\n\n.small-offset-10 {\n  margin-left: 83.33333%; }\n\n.grid-margin-x > .small-offset-10 {\n  margin-left: calc(83.33333% + 0.625rem); }\n\n.small-offset-11 {\n  margin-left: 91.66667%; }\n\n.grid-margin-x > .small-offset-11 {\n  margin-left: calc(91.66667% + 0.625rem); }\n\n@media print, screen and (min-width: 40em) {\n  .medium-offset-0 {\n    margin-left: 0%; }\n  .grid-margin-x > .medium-offset-0 {\n    margin-left: calc(0% + 0.9375rem); }\n  .medium-offset-1 {\n    margin-left: 8.33333%; }\n  .grid-margin-x > .medium-offset-1 {\n    margin-left: calc(8.33333% + 0.9375rem); }\n  .medium-offset-2 {\n    margin-left: 16.66667%; }\n  .grid-margin-x > .medium-offset-2 {\n    margin-left: calc(16.66667% + 0.9375rem); }\n  .medium-offset-3 {\n    margin-left: 25%; }\n  .grid-margin-x > .medium-offset-3 {\n    margin-left: calc(25% + 0.9375rem); }\n  .medium-offset-4 {\n    margin-left: 33.33333%; }\n  .grid-margin-x > .medium-offset-4 {\n    margin-left: calc(33.33333% + 0.9375rem); }\n  .medium-offset-5 {\n    margin-left: 41.66667%; }\n  .grid-margin-x > .medium-offset-5 {\n    margin-left: calc(41.66667% + 0.9375rem); }\n  .medium-offset-6 {\n    margin-left: 50%; }\n  .grid-margin-x > .medium-offset-6 {\n    margin-left: calc(50% + 0.9375rem); }\n  .medium-offset-7 {\n    margin-left: 58.33333%; }\n  .grid-margin-x > .medium-offset-7 {\n    margin-left: calc(58.33333% + 0.9375rem); }\n  .medium-offset-8 {\n    margin-left: 66.66667%; }\n  .grid-margin-x > .medium-offset-8 {\n    margin-left: calc(66.66667% + 0.9375rem); }\n  .medium-offset-9 {\n    margin-left: 75%; }\n  .grid-margin-x > .medium-offset-9 {\n    margin-left: calc(75% + 0.9375rem); }\n  .medium-offset-10 {\n    margin-left: 83.33333%; }\n  .grid-margin-x > .medium-offset-10 {\n    margin-left: calc(83.33333% + 0.9375rem); }\n  .medium-offset-11 {\n    margin-left: 91.66667%; }\n  .grid-margin-x > .medium-offset-11 {\n    margin-left: calc(91.66667% + 0.9375rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .large-offset-0 {\n    margin-left: 0%; }\n  .grid-margin-x > .large-offset-0 {\n    margin-left: calc(0% + 0.9375rem); }\n  .large-offset-1 {\n    margin-left: 8.33333%; }\n  .grid-margin-x > .large-offset-1 {\n    margin-left: calc(8.33333% + 0.9375rem); }\n  .large-offset-2 {\n    margin-left: 16.66667%; }\n  .grid-margin-x > .large-offset-2 {\n    margin-left: calc(16.66667% + 0.9375rem); }\n  .large-offset-3 {\n    margin-left: 25%; }\n  .grid-margin-x > .large-offset-3 {\n    margin-left: calc(25% + 0.9375rem); }\n  .large-offset-4 {\n    margin-left: 33.33333%; }\n  .grid-margin-x > .large-offset-4 {\n    margin-left: calc(33.33333% + 0.9375rem); }\n  .large-offset-5 {\n    margin-left: 41.66667%; }\n  .grid-margin-x > .large-offset-5 {\n    margin-left: calc(41.66667% + 0.9375rem); }\n  .large-offset-6 {\n    margin-left: 50%; }\n  .grid-margin-x > .large-offset-6 {\n    margin-left: calc(50% + 0.9375rem); }\n  .large-offset-7 {\n    margin-left: 58.33333%; }\n  .grid-margin-x > .large-offset-7 {\n    margin-left: calc(58.33333% + 0.9375rem); }\n  .large-offset-8 {\n    margin-left: 66.66667%; }\n  .grid-margin-x > .large-offset-8 {\n    margin-left: calc(66.66667% + 0.9375rem); }\n  .large-offset-9 {\n    margin-left: 75%; }\n  .grid-margin-x > .large-offset-9 {\n    margin-left: calc(75% + 0.9375rem); }\n  .large-offset-10 {\n    margin-left: 83.33333%; }\n  .grid-margin-x > .large-offset-10 {\n    margin-left: calc(83.33333% + 0.9375rem); }\n  .large-offset-11 {\n    margin-left: 91.66667%; }\n  .grid-margin-x > .large-offset-11 {\n    margin-left: calc(91.66667% + 0.9375rem); } }\n\n.grid-y {\n  display: flex;\n  flex-flow: column nowrap; }\n  .grid-y > .cell {\n    width: auto;\n    max-width: none; }\n  .grid-y > .auto {\n    height: auto; }\n  .grid-y > .shrink {\n    height: auto; }\n  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {\n    flex-basis: auto; }\n  @media print, screen and (min-width: 40em) {\n    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {\n      flex-basis: auto; } }\n  @media print, screen and (min-width: 64em) {\n    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {\n      flex-basis: auto; } }\n  .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {\n    flex: 0 0 auto; }\n  .grid-y > .small-1 {\n    height: 8.33333%; }\n  .grid-y > .small-2 {\n    height: 16.66667%; }\n  .grid-y > .small-3 {\n    height: 25%; }\n  .grid-y > .small-4 {\n    height: 33.33333%; }\n  .grid-y > .small-5 {\n    height: 41.66667%; }\n  .grid-y > .small-6 {\n    height: 50%; }\n  .grid-y > .small-7 {\n    height: 58.33333%; }\n  .grid-y > .small-8 {\n    height: 66.66667%; }\n  .grid-y > .small-9 {\n    height: 75%; }\n  .grid-y > .small-10 {\n    height: 83.33333%; }\n  .grid-y > .small-11 {\n    height: 91.66667%; }\n  .grid-y > .small-12 {\n    height: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .grid-y > .medium-auto {\n      flex: 1 1 0px;\n      height: auto; }\n    .grid-y > .medium-shrink, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {\n      flex: 0 0 auto; }\n    .grid-y > .medium-shrink {\n      height: auto; }\n    .grid-y > .medium-1 {\n      height: 8.33333%; }\n    .grid-y > .medium-2 {\n      height: 16.66667%; }\n    .grid-y > .medium-3 {\n      height: 25%; }\n    .grid-y > .medium-4 {\n      height: 33.33333%; }\n    .grid-y > .medium-5 {\n      height: 41.66667%; }\n    .grid-y > .medium-6 {\n      height: 50%; }\n    .grid-y > .medium-7 {\n      height: 58.33333%; }\n    .grid-y > .medium-8 {\n      height: 66.66667%; }\n    .grid-y > .medium-9 {\n      height: 75%; }\n    .grid-y > .medium-10 {\n      height: 83.33333%; }\n    .grid-y > .medium-11 {\n      height: 91.66667%; }\n    .grid-y > .medium-12 {\n      height: 100%; } }\n  @media print, screen and (min-width: 64em) {\n    .grid-y > .large-auto {\n      flex: 1 1 0px;\n      height: auto; }\n    .grid-y > .large-shrink, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {\n      flex: 0 0 auto; }\n    .grid-y > .large-shrink {\n      height: auto; }\n    .grid-y > .large-1 {\n      height: 8.33333%; }\n    .grid-y > .large-2 {\n      height: 16.66667%; }\n    .grid-y > .large-3 {\n      height: 25%; }\n    .grid-y > .large-4 {\n      height: 33.33333%; }\n    .grid-y > .large-5 {\n      height: 41.66667%; }\n    .grid-y > .large-6 {\n      height: 50%; }\n    .grid-y > .large-7 {\n      height: 58.33333%; }\n    .grid-y > .large-8 {\n      height: 66.66667%; }\n    .grid-y > .large-9 {\n      height: 75%; }\n    .grid-y > .large-10 {\n      height: 83.33333%; }\n    .grid-y > .large-11 {\n      height: 91.66667%; }\n    .grid-y > .large-12 {\n      height: 100%; } }\n\n.grid-padding-y .grid-padding-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-y .grid-padding-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n\n.grid-padding-y > .cell {\n  padding-top: 0.625rem;\n  padding-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-y > .cell {\n      padding-top: 0.9375rem;\n      padding-bottom: 0.9375rem; } }\n\n.grid-margin-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n  .grid-margin-y > .cell {\n    height: calc(100% - 1.25rem);\n    margin-top: 0.625rem;\n    margin-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .cell {\n      height: calc(100% - 1.875rem);\n      margin-top: 0.9375rem;\n      margin-bottom: 0.9375rem; } }\n  .grid-margin-y > .auto {\n    height: auto; }\n  .grid-margin-y > .shrink {\n    height: auto; }\n  .grid-margin-y > .small-1 {\n    height: calc(8.33333% - 1.25rem); }\n  .grid-margin-y > .small-2 {\n    height: calc(16.66667% - 1.25rem); }\n  .grid-margin-y > .small-3 {\n    height: calc(25% - 1.25rem); }\n  .grid-margin-y > .small-4 {\n    height: calc(33.33333% - 1.25rem); }\n  .grid-margin-y > .small-5 {\n    height: calc(41.66667% - 1.25rem); }\n  .grid-margin-y > .small-6 {\n    height: calc(50% - 1.25rem); }\n  .grid-margin-y > .small-7 {\n    height: calc(58.33333% - 1.25rem); }\n  .grid-margin-y > .small-8 {\n    height: calc(66.66667% - 1.25rem); }\n  .grid-margin-y > .small-9 {\n    height: calc(75% - 1.25rem); }\n  .grid-margin-y > .small-10 {\n    height: calc(83.33333% - 1.25rem); }\n  .grid-margin-y > .small-11 {\n    height: calc(91.66667% - 1.25rem); }\n  .grid-margin-y > .small-12 {\n    height: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .auto {\n      height: auto; }\n    .grid-margin-y > .shrink {\n      height: auto; }\n    .grid-margin-y > .small-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .small-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .small-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .small-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .small-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .small-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .small-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .small-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .small-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .small-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .small-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .small-12 {\n      height: calc(100% - 1.875rem); }\n    .grid-margin-y > .medium-auto {\n      height: auto; }\n    .grid-margin-y > .medium-shrink {\n      height: auto; }\n    .grid-margin-y > .medium-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .medium-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .medium-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .medium-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .medium-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .medium-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .medium-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .medium-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .medium-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .medium-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .medium-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .medium-12 {\n      height: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-y > .large-auto {\n      height: auto; }\n    .grid-margin-y > .large-shrink {\n      height: auto; }\n    .grid-margin-y > .large-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .large-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .large-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .large-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .large-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .large-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .large-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .large-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .large-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .large-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .large-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .large-12 {\n      height: calc(100% - 1.875rem); } }\n\n.grid-frame {\n  overflow: hidden;\n  position: relative;\n  flex-wrap: nowrap;\n  align-items: stretch;\n  width: 100vw; }\n\n.cell .grid-frame {\n  width: 100%; }\n\n.cell-block {\n  overflow-x: auto;\n  max-width: 100%;\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar; }\n\n.cell-block-y {\n  overflow-y: auto;\n  max-height: 100%;\n  min-height: 100%;\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar; }\n\n.cell-block-container {\n  display: flex;\n  flex-direction: column;\n  max-height: 100%; }\n  .cell-block-container > .grid-x {\n    max-height: 100%;\n    flex-wrap: nowrap; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-grid-frame {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    width: 100vw; }\n  .cell .medium-grid-frame {\n    width: 100%; }\n  .medium-cell-block {\n    overflow-x: auto;\n    max-width: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; }\n  .medium-cell-block-container {\n    display: flex;\n    flex-direction: column;\n    max-height: 100%; }\n    .medium-cell-block-container > .grid-x {\n      max-height: 100%;\n      flex-wrap: nowrap; }\n  .medium-cell-block-y {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-grid-frame {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    width: 100vw; }\n  .cell .large-grid-frame {\n    width: 100%; }\n  .large-cell-block {\n    overflow-x: auto;\n    max-width: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; }\n  .large-cell-block-container {\n    display: flex;\n    flex-direction: column;\n    max-height: 100%; }\n    .large-cell-block-container > .grid-x {\n      max-height: 100%;\n      flex-wrap: nowrap; }\n  .large-cell-block-y {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; } }\n\n.grid-y.grid-frame {\n  width: auto;\n  overflow: hidden;\n  position: relative;\n  flex-wrap: nowrap;\n  align-items: stretch;\n  height: 100vh; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-y.medium-grid-frame {\n    width: auto;\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    height: 100vh; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-y.large-grid-frame {\n    width: auto;\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    height: 100vh; } }\n\n.cell .grid-y.grid-frame {\n  height: 100%; }\n\n@media print, screen and (min-width: 40em) {\n  .cell .grid-y.medium-grid-frame {\n    height: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .cell .grid-y.large-grid-frame {\n    height: 100%; } }\n\n.grid-margin-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n  .grid-margin-y > .cell {\n    height: calc(100% - 1.25rem);\n    margin-top: 0.625rem;\n    margin-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .cell {\n      height: calc(100% - 1.875rem);\n      margin-top: 0.9375rem;\n      margin-bottom: 0.9375rem; } }\n  .grid-margin-y > .auto {\n    height: auto; }\n  .grid-margin-y > .shrink {\n    height: auto; }\n  .grid-margin-y > .small-1 {\n    height: calc(8.33333% - 1.25rem); }\n  .grid-margin-y > .small-2 {\n    height: calc(16.66667% - 1.25rem); }\n  .grid-margin-y > .small-3 {\n    height: calc(25% - 1.25rem); }\n  .grid-margin-y > .small-4 {\n    height: calc(33.33333% - 1.25rem); }\n  .grid-margin-y > .small-5 {\n    height: calc(41.66667% - 1.25rem); }\n  .grid-margin-y > .small-6 {\n    height: calc(50% - 1.25rem); }\n  .grid-margin-y > .small-7 {\n    height: calc(58.33333% - 1.25rem); }\n  .grid-margin-y > .small-8 {\n    height: calc(66.66667% - 1.25rem); }\n  .grid-margin-y > .small-9 {\n    height: calc(75% - 1.25rem); }\n  .grid-margin-y > .small-10 {\n    height: calc(83.33333% - 1.25rem); }\n  .grid-margin-y > .small-11 {\n    height: calc(91.66667% - 1.25rem); }\n  .grid-margin-y > .small-12 {\n    height: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .auto {\n      height: auto; }\n    .grid-margin-y > .shrink {\n      height: auto; }\n    .grid-margin-y > .small-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .small-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .small-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .small-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .small-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .small-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .small-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .small-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .small-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .small-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .small-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .small-12 {\n      height: calc(100% - 1.875rem); }\n    .grid-margin-y > .medium-auto {\n      height: auto; }\n    .grid-margin-y > .medium-shrink {\n      height: auto; }\n    .grid-margin-y > .medium-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .medium-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .medium-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .medium-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .medium-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .medium-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .medium-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .medium-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .medium-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .medium-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .medium-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .medium-12 {\n      height: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-y > .large-auto {\n      height: auto; }\n    .grid-margin-y > .large-shrink {\n      height: auto; }\n    .grid-margin-y > .large-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .large-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .large-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .large-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .large-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .large-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .large-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .large-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .large-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .large-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .large-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .large-12 {\n      height: calc(100% - 1.875rem); } }\n\n.grid-frame.grid-margin-y {\n  height: calc(100vh + 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-frame.grid-margin-y {\n      height: calc(100vh + 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-frame.grid-margin-y {\n      height: calc(100vh + 1.875rem); } }\n\n@media print, screen and (min-width: 40em) {\n  .grid-margin-y.medium-grid-frame {\n    height: calc(100vh + 1.875rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-margin-y.large-grid-frame {\n    height: calc(100vh + 1.875rem); } }\n\n.button {\n  display: inline-block;\n  vertical-align: middle;\n  margin: 0 0 1rem 0;\n  padding: 0.85em 1em;\n  border: 1px solid transparent;\n  border-radius: 0;\n  transition: background-color 0.25s ease-out, color 0.25s ease-out;\n  font-family: inherit;\n  font-size: 0.9rem;\n  -webkit-appearance: none;\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n  background-color: #1779ba;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .button {\n    outline: 0; }\n  .button:hover, .button:focus {\n    background-color: #14679e;\n    color: #fefefe; }\n  .button.tiny {\n    font-size: 0.6rem; }\n  .button.small {\n    font-size: 0.75rem; }\n  .button.large {\n    font-size: 1.25rem; }\n  .button.expanded {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0; }\n  .button.primary {\n    background-color: #1779ba;\n    color: #fefefe; }\n    .button.primary:hover, .button.primary:focus {\n      background-color: #126195;\n      color: #fefefe; }\n  .button.secondary {\n    background-color: #767676;\n    color: #fefefe; }\n    .button.secondary:hover, .button.secondary:focus {\n      background-color: #5e5e5e;\n      color: #fefefe; }\n  .button.success {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n    .button.success:hover, .button.success:focus {\n      background-color: #22bb5b;\n      color: #0a0a0a; }\n  .button.warning {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n    .button.warning:hover, .button.warning:focus {\n      background-color: #cc8b00;\n      color: #0a0a0a; }\n  .button.alert {\n    background-color: #cc4b37;\n    color: #fefefe; }\n    .button.alert:hover, .button.alert:focus {\n      background-color: #a53b2a;\n      color: #fefefe; }\n  .button.disabled, .button[disabled] {\n    opacity: 0.25;\n    cursor: not-allowed; }\n    .button.disabled, .button.disabled:hover, .button.disabled:focus, .button[disabled], .button[disabled]:hover, .button[disabled]:focus {\n      background-color: #1779ba;\n      color: #fefefe; }\n    .button.disabled.primary, .button[disabled].primary {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.primary, .button.disabled.primary:hover, .button.disabled.primary:focus, .button[disabled].primary, .button[disabled].primary:hover, .button[disabled].primary:focus {\n        background-color: #1779ba;\n        color: #fefefe; }\n    .button.disabled.secondary, .button[disabled].secondary {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.secondary, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary, .button[disabled].secondary:hover, .button[disabled].secondary:focus {\n        background-color: #767676;\n        color: #fefefe; }\n    .button.disabled.success, .button[disabled].success {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.success, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success, .button[disabled].success:hover, .button[disabled].success:focus {\n        background-color: #3adb76;\n        color: #0a0a0a; }\n    .button.disabled.warning, .button[disabled].warning {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.warning, .button.disabled.warning:hover, .button.disabled.warning:focus, .button[disabled].warning, .button[disabled].warning:hover, .button[disabled].warning:focus {\n        background-color: #ffae00;\n        color: #0a0a0a; }\n    .button.disabled.alert, .button[disabled].alert {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.alert, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert, .button[disabled].alert:hover, .button[disabled].alert:focus {\n        background-color: #cc4b37;\n        color: #fefefe; }\n  .button.hollow {\n    border: 1px solid #1779ba;\n    color: #1779ba; }\n    .button.hollow, .button.hollow:hover, .button.hollow:focus {\n      background-color: transparent; }\n    .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {\n      background-color: transparent; }\n    .button.hollow:hover, .button.hollow:focus {\n      border-color: #0c3d5d;\n      color: #0c3d5d; }\n      .button.hollow:hover.disabled, .button.hollow:hover[disabled], .button.hollow:focus.disabled, .button.hollow:focus[disabled] {\n        border: 1px solid #1779ba;\n        color: #1779ba; }\n    .button.hollow.primary {\n      border: 1px solid #1779ba;\n      color: #1779ba; }\n      .button.hollow.primary:hover, .button.hollow.primary:focus {\n        border-color: #0c3d5d;\n        color: #0c3d5d; }\n        .button.hollow.primary:hover.disabled, .button.hollow.primary:hover[disabled], .button.hollow.primary:focus.disabled, .button.hollow.primary:focus[disabled] {\n          border: 1px solid #1779ba;\n          color: #1779ba; }\n    .button.hollow.secondary {\n      border: 1px solid #767676;\n      color: #767676; }\n      .button.hollow.secondary:hover, .button.hollow.secondary:focus {\n        border-color: #3b3b3b;\n        color: #3b3b3b; }\n        .button.hollow.secondary:hover.disabled, .button.hollow.secondary:hover[disabled], .button.hollow.secondary:focus.disabled, .button.hollow.secondary:focus[disabled] {\n          border: 1px solid #767676;\n          color: #767676; }\n    .button.hollow.success {\n      border: 1px solid #3adb76;\n      color: #3adb76; }\n      .button.hollow.success:hover, .button.hollow.success:focus {\n        border-color: #157539;\n        color: #157539; }\n        .button.hollow.success:hover.disabled, .button.hollow.success:hover[disabled], .button.hollow.success:focus.disabled, .button.hollow.success:focus[disabled] {\n          border: 1px solid #3adb76;\n          color: #3adb76; }\n    .button.hollow.warning {\n      border: 1px solid #ffae00;\n      color: #ffae00; }\n      .button.hollow.warning:hover, .button.hollow.warning:focus {\n        border-color: #805700;\n        color: #805700; }\n        .button.hollow.warning:hover.disabled, .button.hollow.warning:hover[disabled], .button.hollow.warning:focus.disabled, .button.hollow.warning:focus[disabled] {\n          border: 1px solid #ffae00;\n          color: #ffae00; }\n    .button.hollow.alert {\n      border: 1px solid #cc4b37;\n      color: #cc4b37; }\n      .button.hollow.alert:hover, .button.hollow.alert:focus {\n        border-color: #67251a;\n        color: #67251a; }\n        .button.hollow.alert:hover.disabled, .button.hollow.alert:hover[disabled], .button.hollow.alert:focus.disabled, .button.hollow.alert:focus[disabled] {\n          border: 1px solid #cc4b37;\n          color: #cc4b37; }\n  .button.clear {\n    border: 1px solid #1779ba;\n    color: #1779ba; }\n    .button.clear, .button.clear:hover, .button.clear:focus {\n      background-color: transparent; }\n    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {\n      background-color: transparent; }\n    .button.clear:hover, .button.clear:focus {\n      border-color: #0c3d5d;\n      color: #0c3d5d; }\n      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {\n        border: 1px solid #1779ba;\n        color: #1779ba; }\n    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {\n      border-color: transparent; }\n    .button.clear.primary {\n      border: 1px solid #1779ba;\n      color: #1779ba; }\n      .button.clear.primary:hover, .button.clear.primary:focus {\n        border-color: #0c3d5d;\n        color: #0c3d5d; }\n        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {\n          border: 1px solid #1779ba;\n          color: #1779ba; }\n      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.secondary {\n      border: 1px solid #767676;\n      color: #767676; }\n      .button.clear.secondary:hover, .button.clear.secondary:focus {\n        border-color: #3b3b3b;\n        color: #3b3b3b; }\n        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {\n          border: 1px solid #767676;\n          color: #767676; }\n      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.success {\n      border: 1px solid #3adb76;\n      color: #3adb76; }\n      .button.clear.success:hover, .button.clear.success:focus {\n        border-color: #157539;\n        color: #157539; }\n        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {\n          border: 1px solid #3adb76;\n          color: #3adb76; }\n      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.warning {\n      border: 1px solid #ffae00;\n      color: #ffae00; }\n      .button.clear.warning:hover, .button.clear.warning:focus {\n        border-color: #805700;\n        color: #805700; }\n        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {\n          border: 1px solid #ffae00;\n          color: #ffae00; }\n      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.alert {\n      border: 1px solid #cc4b37;\n      color: #cc4b37; }\n      .button.clear.alert:hover, .button.clear.alert:focus {\n        border-color: #67251a;\n        color: #67251a; }\n        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {\n          border: 1px solid #cc4b37;\n          color: #cc4b37; }\n      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {\n        border-color: transparent; }\n  .button.dropdown::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.4em;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #fefefe transparent transparent;\n    position: relative;\n    top: 0.4em;\n    display: inline-block;\n    float: right;\n    margin-left: 1em; }\n  .button.dropdown.hollow::after, .button.dropdown.clear::after {\n    border-top-color: #1779ba; }\n  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {\n    border-top-color: #1779ba; }\n  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {\n    border-top-color: #767676; }\n  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {\n    border-top-color: #3adb76; }\n  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {\n    border-top-color: #ffae00; }\n  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {\n    border-top-color: #cc4b37; }\n  .button.arrow-only::after {\n    top: -0.1em;\n    float: none;\n    margin-left: 0; }\n\na.button:hover, a.button:focus {\n  text-decoration: none; }\n\n.button-group {\n  margin-bottom: 1rem;\n  display: flex;\n  flex-wrap: nowrap;\n  align-items: stretch; }\n  .button-group::before, .button-group::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .button-group::after {\n    clear: both; }\n  .button-group .button {\n    margin: 0;\n    margin-right: 1px;\n    margin-bottom: 1px;\n    font-size: 0.9rem;\n    flex: 0 0 auto; }\n    .button-group .button:last-child {\n      margin-right: 0; }\n  .button-group.tiny .button {\n    font-size: 0.6rem; }\n  .button-group.small .button {\n    font-size: 0.75rem; }\n  .button-group.large .button {\n    font-size: 1.25rem; }\n  .button-group.expanded .button {\n    flex: 1 1 0px; }\n  .button-group.primary .button {\n    background-color: #1779ba;\n    color: #fefefe; }\n    .button-group.primary .button:hover, .button-group.primary .button:focus {\n      background-color: #126195;\n      color: #fefefe; }\n  .button-group.secondary .button {\n    background-color: #767676;\n    color: #fefefe; }\n    .button-group.secondary .button:hover, .button-group.secondary .button:focus {\n      background-color: #5e5e5e;\n      color: #fefefe; }\n  .button-group.success .button {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n    .button-group.success .button:hover, .button-group.success .button:focus {\n      background-color: #22bb5b;\n      color: #0a0a0a; }\n  .button-group.warning .button {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n    .button-group.warning .button:hover, .button-group.warning .button:focus {\n      background-color: #cc8b00;\n      color: #0a0a0a; }\n  .button-group.alert .button {\n    background-color: #cc4b37;\n    color: #fefefe; }\n    .button-group.alert .button:hover, .button-group.alert .button:focus {\n      background-color: #a53b2a;\n      color: #fefefe; }\n  .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium {\n    flex-wrap: wrap; }\n    .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {\n      flex: 0 0 100%; }\n      .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {\n        margin-bottom: 0; }\n    .button-group.stacked.expanded .button, .button-group.stacked-for-small.expanded .button, .button-group.stacked-for-medium.expanded .button {\n      flex: 1 1 0px; }\n  @media print, screen and (min-width: 40em) {\n    .button-group.stacked-for-small .button {\n      flex: 0 0 auto;\n      margin-bottom: 0; } }\n  @media print, screen and (min-width: 64em) {\n    .button-group.stacked-for-medium .button {\n      flex: 0 0 auto;\n      margin-bottom: 0; } }\n  @media screen and (max-width: 39.99875em) {\n    .button-group.stacked-for-small.expanded {\n      display: block; }\n      .button-group.stacked-for-small.expanded .button {\n        display: block;\n        margin-right: 0; } }\n  @media screen and (max-width: 63.99875em) {\n    .button-group.stacked-for-medium.expanded {\n      display: block; }\n      .button-group.stacked-for-medium.expanded .button {\n        display: block;\n        margin-right: 0; } }\n\n.close-button {\n  position: absolute;\n  color: #8a8a8a;\n  cursor: pointer; }\n  [data-whatinput='mouse'] .close-button {\n    outline: 0; }\n  .close-button:hover, .close-button:focus {\n    color: #0a0a0a; }\n  .close-button.small {\n    right: 0.66rem;\n    top: 0.33em;\n    font-size: 1.5em;\n    line-height: 1; }\n  .close-button, .close-button.medium {\n    right: 1rem;\n    top: 0.5rem;\n    font-size: 2em;\n    line-height: 1; }\n\n.label {\n  display: inline-block;\n  padding: 0.33333rem 0.5rem;\n  border-radius: 0;\n  font-size: 0.8rem;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n  background: #1779ba;\n  color: #fefefe; }\n  .label.primary {\n    background: #1779ba;\n    color: #fefefe; }\n  .label.secondary {\n    background: #767676;\n    color: #fefefe; }\n  .label.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .label.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .label.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.progress {\n  height: 1rem;\n  margin-bottom: 1rem;\n  border-radius: 0;\n  background-color: #cacaca; }\n  .progress.primary .progress-meter {\n    background-color: #1779ba; }\n  .progress.secondary .progress-meter {\n    background-color: #767676; }\n  .progress.success .progress-meter {\n    background-color: #3adb76; }\n  .progress.warning .progress-meter {\n    background-color: #ffae00; }\n  .progress.alert .progress-meter {\n    background-color: #cc4b37; }\n\n.progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: #1779ba; }\n\n.progress-meter-text {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #fefefe;\n  white-space: nowrap; }\n\n.slider {\n  position: relative;\n  height: 0.5rem;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n  background-color: #e6e6e6;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none; }\n\n.slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: inline-block;\n  max-width: 100%;\n  height: 0.5rem;\n  background-color: #cacaca;\n  transition: all 0.2s ease-in-out; }\n  .slider-fill.is-dragging {\n    transition: all 0s linear; }\n\n.slider-handle {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  left: 0;\n  z-index: 1;\n  display: inline-block;\n  width: 1.4rem;\n  height: 1.4rem;\n  border-radius: 0;\n  background-color: #1779ba;\n  transition: all 0.2s ease-in-out;\n  touch-action: manipulation; }\n  [data-whatinput='mouse'] .slider-handle {\n    outline: 0; }\n  .slider-handle:hover {\n    background-color: #14679e; }\n  .slider-handle.is-dragging {\n    transition: all 0s linear; }\n\n.slider.disabled,\n.slider[disabled] {\n  opacity: 0.25;\n  cursor: not-allowed; }\n\n.slider.vertical {\n  display: inline-block;\n  width: 0.5rem;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1); }\n  .slider.vertical .slider-fill {\n    top: 0;\n    width: 0.5rem;\n    max-height: 100%; }\n  .slider.vertical .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: 1.4rem;\n    height: 1.4rem;\n    transform: translateX(-50%); }\n\n.switch {\n  height: 2rem;\n  position: relative;\n  margin-bottom: 1rem;\n  outline: 0;\n  font-size: 0.875rem;\n  font-weight: bold;\n  color: #fefefe;\n  user-select: none; }\n\n.switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0; }\n\n.switch-paddle {\n  position: relative;\n  display: block;\n  width: 4rem;\n  height: 2rem;\n  border-radius: 0;\n  background: #cacaca;\n  transition: all 0.25s ease-out;\n  font-weight: inherit;\n  color: inherit;\n  cursor: pointer; }\n  input + .switch-paddle {\n    margin: 0; }\n  .switch-paddle::after {\n    position: absolute;\n    top: 0.25rem;\n    left: 0.25rem;\n    display: block;\n    width: 1.5rem;\n    height: 1.5rem;\n    transform: translate3d(0, 0, 0);\n    border-radius: 0;\n    background: #fefefe;\n    transition: all 0.25s ease-out;\n    content: ''; }\n  input:checked ~ .switch-paddle {\n    background: #1779ba; }\n    input:checked ~ .switch-paddle::after {\n      left: 2.25rem; }\n  [data-whatinput='mouse'] input:focus ~ .switch-paddle {\n    outline: 0; }\n\n.switch-active, .switch-inactive {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%); }\n\n.switch-active {\n  left: 8%;\n  display: none; }\n  input:checked + label > .switch-active {\n    display: block; }\n\n.switch-inactive {\n  right: 15%; }\n  input:checked + label > .switch-inactive {\n    display: none; }\n\n.switch.tiny {\n  height: 1.5rem; }\n  .switch.tiny .switch-paddle {\n    width: 3rem;\n    height: 1.5rem;\n    font-size: 0.625rem; }\n  .switch.tiny .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 1rem;\n    height: 1rem; }\n  .switch.tiny input:checked ~ .switch-paddle::after {\n    left: 1.75rem; }\n\n.switch.small {\n  height: 1.75rem; }\n  .switch.small .switch-paddle {\n    width: 3.5rem;\n    height: 1.75rem;\n    font-size: 0.75rem; }\n  .switch.small .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 1.25rem;\n    height: 1.25rem; }\n  .switch.small input:checked ~ .switch-paddle::after {\n    left: 2rem; }\n\n.switch.large {\n  height: 2.5rem; }\n  .switch.large .switch-paddle {\n    width: 5rem;\n    height: 2.5rem;\n    font-size: 1rem; }\n  .switch.large .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 2rem;\n    height: 2rem; }\n  .switch.large input:checked ~ .switch-paddle::after {\n    left: 2.75rem; }\n\ntable {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: 1rem;\n  border-radius: 0; }\n  thead,\n  tbody,\n  tfoot {\n    border: 1px solid #f1f1f1;\n    background-color: #fefefe; }\n  caption {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold; }\n  thead {\n    background: #f8f8f8;\n    color: #0a0a0a; }\n  tfoot {\n    background: #f1f1f1;\n    color: #0a0a0a; }\n  thead tr,\n  tfoot tr {\n    background: transparent; }\n  thead th,\n  thead td,\n  tfoot th,\n  tfoot td {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold;\n    text-align: left; }\n  tbody th,\n  tbody td {\n    padding: 0.5rem 0.625rem 0.625rem; }\n  tbody tr:nth-child(even) {\n    border-bottom: 0;\n    background-color: #f1f1f1; }\n  table.unstriped tbody {\n    background-color: #fefefe; }\n    table.unstriped tbody tr {\n      border-bottom: 0;\n      border-bottom: 1px solid #f1f1f1;\n      background-color: #fefefe; }\n\n@media screen and (max-width: 63.99875em) {\n  table.stack thead {\n    display: none; }\n  table.stack tfoot {\n    display: none; }\n  table.stack tr,\n  table.stack th,\n  table.stack td {\n    display: block; }\n  table.stack td {\n    border-top: 0; } }\n\ntable.scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto; }\n\ntable.hover thead tr:hover {\n  background-color: #f3f3f3; }\n\ntable.hover tfoot tr:hover {\n  background-color: #ececec; }\n\ntable.hover tbody tr:hover {\n  background-color: #f9f9f9; }\n\ntable.hover:not(.unstriped) tr:nth-of-type(even):hover {\n  background-color: #ececec; }\n\n.table-scroll {\n  overflow-x: auto; }\n\n.badge {\n  display: inline-block;\n  min-width: 2.1em;\n  padding: 0.3em;\n  border-radius: 50%;\n  font-size: 0.6rem;\n  text-align: center;\n  background: #1779ba;\n  color: #fefefe; }\n  .badge.primary {\n    background: #1779ba;\n    color: #fefefe; }\n  .badge.secondary {\n    background: #767676;\n    color: #fefefe; }\n  .badge.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .badge.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .badge.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.breadcrumbs {\n  margin: 0 0 1rem 0;\n  list-style: none; }\n  .breadcrumbs::before, .breadcrumbs::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .breadcrumbs::after {\n    clear: both; }\n  .breadcrumbs li {\n    float: left;\n    font-size: 0.6875rem;\n    color: #0a0a0a;\n    cursor: default;\n    text-transform: uppercase; }\n    .breadcrumbs li:not(:last-child)::after {\n      position: relative;\n      margin: 0 0.75rem;\n      opacity: 1;\n      content: \"/\";\n      color: #cacaca; }\n  .breadcrumbs a {\n    color: #1779ba; }\n    .breadcrumbs a:hover {\n      text-decoration: underline; }\n  .breadcrumbs .disabled {\n    color: #cacaca;\n    cursor: not-allowed; }\n\n.callout {\n  position: relative;\n  margin: 0 0 1rem 0;\n  padding: 1rem;\n  border: 1px solid rgba(10, 10, 10, 0.25);\n  border-radius: 0;\n  background-color: white;\n  color: #0a0a0a; }\n  .callout > :first-child {\n    margin-top: 0; }\n  .callout > :last-child {\n    margin-bottom: 0; }\n  .callout.primary {\n    background-color: #d7ecfa;\n    color: #0a0a0a; }\n  .callout.secondary {\n    background-color: #eaeaea;\n    color: #0a0a0a; }\n  .callout.success {\n    background-color: #e1faea;\n    color: #0a0a0a; }\n  .callout.warning {\n    background-color: #fff3d9;\n    color: #0a0a0a; }\n  .callout.alert {\n    background-color: #f7e4e1;\n    color: #0a0a0a; }\n  .callout.small {\n    padding-top: 0.5rem;\n    padding-right: 0.5rem;\n    padding-bottom: 0.5rem;\n    padding-left: 0.5rem; }\n  .callout.large {\n    padding-top: 3rem;\n    padding-right: 3rem;\n    padding-bottom: 3rem;\n    padding-left: 3rem; }\n\n.card {\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n  margin-bottom: 1rem;\n  border: 1px solid #e6e6e6;\n  border-radius: 0;\n  background: #fefefe;\n  box-shadow: none;\n  overflow: hidden;\n  color: #0a0a0a; }\n  .card > :last-child {\n    margin-bottom: 0; }\n\n.card-divider {\n  display: flex;\n  flex: 0 1 auto;\n  padding: 1rem;\n  background: #e6e6e6; }\n  .card-divider > :last-child {\n    margin-bottom: 0; }\n\n.card-section {\n  flex: 1 0 auto;\n  padding: 1rem; }\n  .card-section > :last-child {\n    margin-bottom: 0; }\n\n.card-image {\n  min-height: 1px; }\n\n.dropdown-pane {\n  position: absolute;\n  z-index: 10;\n  display: none;\n  width: 300px;\n  padding: 1rem;\n  visibility: hidden;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-size: 1rem; }\n  .dropdown-pane.is-opening {\n    display: block; }\n  .dropdown-pane.is-open {\n    display: block;\n    visibility: visible; }\n\n.dropdown-pane.tiny {\n  width: 100px; }\n\n.dropdown-pane.small {\n  width: 200px; }\n\n.dropdown-pane.large {\n  width: 400px; }\n\n.pagination {\n  margin-left: 0;\n  margin-bottom: 1rem; }\n  .pagination::before, .pagination::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .pagination::after {\n    clear: both; }\n  .pagination li {\n    margin-right: 0.0625rem;\n    border-radius: 0;\n    font-size: 0.875rem;\n    display: none; }\n    .pagination li:last-child, .pagination li:first-child {\n      display: inline-block; }\n    @media print, screen and (min-width: 40em) {\n      .pagination li {\n        display: inline-block; } }\n  .pagination a,\n  .pagination button {\n    display: block;\n    padding: 0.1875rem 0.625rem;\n    border-radius: 0;\n    color: #0a0a0a; }\n    .pagination a:hover,\n    .pagination button:hover {\n      background: #e6e6e6; }\n  .pagination .current {\n    padding: 0.1875rem 0.625rem;\n    background: #1779ba;\n    color: #fefefe;\n    cursor: default; }\n  .pagination .disabled {\n    padding: 0.1875rem 0.625rem;\n    color: #cacaca;\n    cursor: not-allowed; }\n    .pagination .disabled:hover {\n      background: transparent; }\n  .pagination .ellipsis::after {\n    padding: 0.1875rem 0.625rem;\n    content: '\\2026';\n    color: #0a0a0a; }\n\n.pagination-previous a::before,\n.pagination-previous.disabled::before {\n  display: inline-block;\n  margin-right: 0.5rem;\n  content: '\\00ab'; }\n\n.pagination-next a::after,\n.pagination-next.disabled::after {\n  display: inline-block;\n  margin-left: 0.5rem;\n  content: '\\00bb'; }\n\n.has-tip {\n  position: relative;\n  display: inline-block;\n  border-bottom: dotted 1px #8a8a8a;\n  font-weight: bold;\n  cursor: help; }\n\n.tooltip {\n  position: absolute;\n  top: calc(100% + 0.6495rem);\n  z-index: 1200;\n  max-width: 10rem;\n  padding: 0.75rem;\n  border-radius: 0;\n  background-color: #0a0a0a;\n  font-size: 80%;\n  color: #fefefe; }\n  .tooltip::before {\n    position: absolute; }\n  .tooltip.bottom::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent #0a0a0a;\n    bottom: 100%; }\n  .tooltip.bottom.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.top::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #0a0a0a transparent transparent;\n    top: 100%;\n    bottom: auto; }\n  .tooltip.top.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.left::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #0a0a0a;\n    left: 100%; }\n  .tooltip.left.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.right::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #0a0a0a transparent transparent;\n    right: 100%;\n    left: auto; }\n  .tooltip.right.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.align-top::before {\n    bottom: auto;\n    top: 10%; }\n  .tooltip.align-bottom::before {\n    bottom: 10%;\n    top: auto; }\n  .tooltip.align-left::before {\n    left: 10%;\n    right: auto; }\n  .tooltip.align-right::before {\n    left: auto;\n    right: 10%; }\n\n.accordion {\n  margin-left: 0;\n  background: #fefefe;\n  list-style-type: none; }\n  .accordion[disabled] .accordion-title {\n    cursor: not-allowed; }\n\n.accordion-item:first-child > :first-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-item:last-child > :last-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-title {\n  position: relative;\n  display: block;\n  padding: 1.25rem 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  font-size: 0.75rem;\n  line-height: 1;\n  color: #1779ba; }\n  :last-child:not(.is-active) > .accordion-title {\n    border-bottom: 1px solid #e6e6e6;\n    border-radius: 0 0 0 0; }\n  .accordion-title:hover, .accordion-title:focus {\n    background-color: #e6e6e6; }\n  .accordion-title::before {\n    position: absolute;\n    top: 50%;\n    right: 1rem;\n    margin-top: -0.5rem;\n    content: '+'; }\n  .is-active > .accordion-title::before {\n    content: '\\2013'; }\n\n.accordion-content {\n  display: none;\n  padding: 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  background-color: #fefefe;\n  color: #0a0a0a; }\n  :last-child > .accordion-content:last-child {\n    border-bottom: 1px solid #e6e6e6; }\n\n.media-object {\n  display: flex;\n  margin-bottom: 1rem;\n  flex-wrap: nowrap; }\n  .media-object img {\n    max-width: none; }\n  @media screen and (max-width: 39.99875em) {\n    .media-object.stack-for-small {\n      flex-wrap: wrap; } }\n\n.media-object-section {\n  flex: 0 1 auto; }\n  .media-object-section:first-child {\n    padding-right: 1rem; }\n  .media-object-section:last-child:not(:nth-child(2)) {\n    padding-left: 1rem; }\n  .media-object-section > :last-child {\n    margin-bottom: 0; }\n  @media screen and (max-width: 39.99875em) {\n    .stack-for-small .media-object-section {\n      padding: 0;\n      padding-bottom: 1rem;\n      flex-basis: 100%;\n      max-width: 100%; }\n      .stack-for-small .media-object-section img {\n        width: 100%; } }\n  .media-object-section.main-section {\n    flex: 1 1 0px; }\n\n.orbit {\n  position: relative; }\n\n.orbit-container {\n  position: relative;\n  height: 0;\n  margin: 0;\n  list-style: none;\n  overflow: hidden; }\n\n.orbit-slide {\n  width: 100%;\n  position: absolute; }\n  .orbit-slide.no-motionui.is-active {\n    top: 0;\n    left: 0; }\n\n.orbit-figure {\n  margin: 0; }\n\n.orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0; }\n\n.orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: 1rem;\n  background-color: rgba(10, 10, 10, 0.5);\n  color: #fefefe; }\n\n.orbit-previous, .orbit-next {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  z-index: 10;\n  padding: 1rem;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {\n    outline: 0; }\n  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {\n    background-color: rgba(10, 10, 10, 0.5); }\n\n.orbit-previous {\n  left: 0; }\n\n.orbit-next {\n  left: auto;\n  right: 0; }\n\n.orbit-bullets {\n  position: relative;\n  margin-top: 0.8rem;\n  margin-bottom: 0.8rem;\n  text-align: center; }\n  [data-whatinput='mouse'] .orbit-bullets {\n    outline: 0; }\n  .orbit-bullets button {\n    width: 1.2rem;\n    height: 1.2rem;\n    margin: 0.1rem;\n    border-radius: 50%;\n    background-color: #cacaca; }\n    .orbit-bullets button:hover {\n      background-color: #8a8a8a; }\n    .orbit-bullets button.is-active {\n      background-color: #8a8a8a; }\n\n.responsive-embed,\n.flex-video {\n  position: relative;\n  height: 0;\n  margin-bottom: 1rem;\n  padding-bottom: 75%;\n  overflow: hidden; }\n  .responsive-embed iframe,\n  .responsive-embed object,\n  .responsive-embed embed,\n  .responsive-embed video,\n  .flex-video iframe,\n  .flex-video object,\n  .flex-video embed,\n  .flex-video video {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%; }\n  .responsive-embed.widescreen,\n  .flex-video.widescreen {\n    padding-bottom: 56.25%; }\n\n.tabs {\n  margin: 0;\n  border: 1px solid #e6e6e6;\n  background: #fefefe;\n  list-style-type: none; }\n  .tabs::before, .tabs::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .tabs::after {\n    clear: both; }\n\n.tabs.vertical > li {\n  display: block;\n  float: none;\n  width: auto; }\n\n.tabs.simple > li > a {\n  padding: 0; }\n  .tabs.simple > li > a:hover {\n    background: transparent; }\n\n.tabs.primary {\n  background: #1779ba; }\n  .tabs.primary > li > a {\n    color: #fefefe; }\n    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {\n      background: #1673b1; }\n\n.tabs-title {\n  float: left; }\n  .tabs-title > a {\n    display: block;\n    padding: 1.25rem 1.5rem;\n    font-size: 0.75rem;\n    line-height: 1;\n    color: #1779ba; }\n    [data-whatinput='mouse'] .tabs-title > a {\n      outline: 0; }\n    .tabs-title > a:hover {\n      background: #fefefe;\n      color: #1468a0; }\n    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {\n      background: #e6e6e6;\n      color: #1779ba; }\n\n.tabs-content {\n  border: 1px solid #e6e6e6;\n  border-top: 0;\n  background: #fefefe;\n  color: #0a0a0a;\n  transition: all 0.5s ease; }\n\n.tabs-content.vertical {\n  border: 1px solid #e6e6e6;\n  border-left: 0; }\n\n.tabs-panel {\n  display: none;\n  padding: 1rem; }\n  .tabs-panel.is-active {\n    display: block; }\n\n.thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: 1rem;\n  border: 4px solid #fefefe;\n  border-radius: 0;\n  box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);\n  line-height: 0; }\n\na.thumbnail {\n  transition: box-shadow 200ms ease-out; }\n  a.thumbnail:hover, a.thumbnail:focus {\n    box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }\n  a.thumbnail image {\n    box-shadow: none; }\n\n.menu {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n  display: flex;\n  flex-wrap: wrap; }\n  [data-whatinput='mouse'] .menu li {\n    outline: 0; }\n  .menu a,\n  .menu .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: 0.7rem 1rem; }\n  .menu input,\n  .menu select,\n  .menu a,\n  .menu button {\n    margin-bottom: 0; }\n  .menu input {\n    display: inline-block; }\n  .menu, .menu.horizontal {\n    flex-wrap: wrap;\n    flex-direction: row; }\n  .menu.vertical {\n    flex-wrap: nowrap;\n    flex-direction: column; }\n  .menu.expanded li {\n    flex: 1 1 0px; }\n  .menu.simple {\n    align-items: center; }\n    .menu.simple li + li {\n      margin-left: 1rem; }\n    .menu.simple a {\n      padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .menu.medium-horizontal {\n      flex-wrap: wrap;\n      flex-direction: row; }\n    .menu.medium-vertical {\n      flex-wrap: nowrap;\n      flex-direction: column; }\n    .menu.medium-expanded li {\n      flex: 1 1 0px; }\n    .menu.medium-simple li {\n      flex: 1 1 0px; } }\n  @media print, screen and (min-width: 64em) {\n    .menu.large-horizontal {\n      flex-wrap: wrap;\n      flex-direction: row; }\n    .menu.large-vertical {\n      flex-wrap: nowrap;\n      flex-direction: column; }\n    .menu.large-expanded li {\n      flex: 1 1 0px; }\n    .menu.large-simple li {\n      flex: 1 1 0px; } }\n  .menu.nested {\n    margin-right: 0;\n    margin-left: 1rem; }\n  .menu.icons a {\n    display: flex; }\n  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {\n    display: flex; }\n  .menu.icon-left li a {\n    flex-flow: row nowrap; }\n    .menu.icon-left li a img,\n    .menu.icon-left li a i,\n    .menu.icon-left li a svg {\n      margin-right: 0.25rem; }\n  .menu.icon-right li a {\n    flex-flow: row nowrap; }\n    .menu.icon-right li a img,\n    .menu.icon-right li a i,\n    .menu.icon-right li a svg {\n      margin-left: 0.25rem; }\n  .menu.icon-top li a {\n    flex-flow: column nowrap; }\n    .menu.icon-top li a img,\n    .menu.icon-top li a i,\n    .menu.icon-top li a svg {\n      align-self: stretch;\n      margin-bottom: 0.25rem;\n      text-align: center; }\n  .menu.icon-bottom li a {\n    flex-flow: column nowrap; }\n    .menu.icon-bottom li a img,\n    .menu.icon-bottom li a i,\n    .menu.icon-bottom li a svg {\n      align-self: stretch;\n      margin-bottom: 0.25rem;\n      text-align: center; }\n  .menu .is-active > a {\n    background: #1779ba;\n    color: #fefefe; }\n  .menu .active > a {\n    background: #1779ba;\n    color: #fefefe; }\n  .menu.align-left {\n    justify-content: flex-start; }\n  .menu.align-right li {\n    display: flex;\n    justify-content: flex-end; }\n    .menu.align-right li .submenu li {\n      justify-content: flex-start; }\n  .menu.align-right.vertical li {\n    display: block;\n    text-align: right; }\n    .menu.align-right.vertical li .submenu li {\n      text-align: right; }\n  .menu.align-right .nested {\n    margin-right: 1rem;\n    margin-left: 0; }\n  .menu.align-center li {\n    display: flex;\n    justify-content: center; }\n    .menu.align-center li .submenu li {\n      justify-content: flex-start; }\n  .menu .menu-text {\n    padding: 0.7rem 1rem;\n    font-weight: bold;\n    line-height: 1;\n    color: inherit; }\n\n.menu-centered > .menu {\n  justify-content: center; }\n  .menu-centered > .menu li {\n    display: flex;\n    justify-content: center; }\n    .menu-centered > .menu li .submenu li {\n      justify-content: flex-start; }\n\n.no-js [data-responsive-menu] ul {\n  display: none; }\n\n.menu-icon {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #fefefe;\n    box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;\n    content: ''; }\n  .menu-icon:hover::after {\n    background: #cacaca;\n    box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }\n\n.menu-icon.dark {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon.dark::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #0a0a0a;\n    box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;\n    content: ''; }\n  .menu-icon.dark:hover::after {\n    background: #8a8a8a;\n    box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }\n\n.accordion-menu li {\n  width: 100%; }\n\n.accordion-menu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .is-accordion-submenu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .nested.is-accordion-submenu {\n  margin-right: 0;\n  margin-left: 1rem; }\n\n.accordion-menu.align-right .nested.is-accordion-submenu {\n  margin-right: 1rem;\n  margin-left: 0; }\n\n.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n  position: relative; }\n  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    position: absolute;\n    top: 50%;\n    margin-top: -3px;\n    right: 1rem; }\n\n.accordion-menu.align-left .is-accordion-submenu-parent > a::after {\n  right: 1rem;\n  left: auto; }\n\n.accordion-menu.align-right .is-accordion-submenu-parent > a::after {\n  right: auto;\n  left: 1rem; }\n\n.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n  transform: rotate(180deg);\n  transform-origin: 50% 50%; }\n\n.is-accordion-submenu-parent {\n  position: relative; }\n\n.has-submenu-toggle > a {\n  margin-right: 40px; }\n\n.submenu-toggle {\n  position: absolute;\n  top: 0;\n  right: 0;\n  width: 40px;\n  height: 40px;\n  cursor: pointer; }\n  .submenu-toggle::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    top: 0;\n    bottom: 0;\n    margin: auto; }\n\n.submenu-toggle[aria-expanded='true']::after {\n  transform: scaleY(-1);\n  transform-origin: 50% 50%; }\n\n.submenu-toggle-text {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  white-space: nowrap;\n  border: 0; }\n\n.is-drilldown {\n  position: relative;\n  overflow: hidden; }\n  .is-drilldown li {\n    display: block; }\n  .is-drilldown.animate-height {\n    transition: height 0.5s; }\n\n.drilldown a {\n  padding: 0.7rem 1rem;\n  background: #fefefe; }\n\n.drilldown .is-drilldown-submenu {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  z-index: -1;\n  width: 100%;\n  background: #fefefe;\n  transition: transform 0.15s linear; }\n  .drilldown .is-drilldown-submenu.is-active {\n    z-index: 1;\n    display: block;\n    transform: translateX(-100%); }\n  .drilldown .is-drilldown-submenu.is-closing {\n    transform: translateX(100%); }\n  .drilldown .is-drilldown-submenu a {\n    padding: 0.7rem 1rem; }\n\n.drilldown .nested.is-drilldown-submenu {\n  margin-right: 0;\n  margin-left: 0; }\n\n.drilldown .drilldown-submenu-cover-previous {\n  min-height: 100%; }\n\n.drilldown .is-drilldown-submenu-parent > a {\n  position: relative; }\n  .drilldown .is-drilldown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba;\n    position: absolute;\n    top: 50%;\n    margin-top: -6px;\n    right: 1rem; }\n\n.drilldown.align-left .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba;\n  right: 1rem;\n  left: auto; }\n\n.drilldown.align-right .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  right: auto;\n  left: 1rem; }\n\n.drilldown .js-drilldown-back > a::before {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: 0.75rem; }\n\n.dropdown.menu > li.opens-left > .is-dropdown-submenu {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.dropdown.menu > li.opens-right > .is-dropdown-submenu {\n  top: 100%;\n  right: auto;\n  left: 0; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a {\n  position: relative;\n  padding-right: 1.5rem; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-bottom-width: 0;\n  border-top-style: solid;\n  border-color: #1779ba transparent transparent;\n  right: 5px;\n  left: auto;\n  margin-top: -3px; }\n\n[data-whatinput='mouse'] .dropdown.menu a {\n  outline: 0; }\n\n.dropdown.menu > li > a {\n  padding: 0.7rem 1rem; }\n\n.dropdown.menu > li.is-active > a {\n  background: transparent;\n  color: #1779ba; }\n\n.no-js .dropdown.menu ul {\n  display: none; }\n\n.dropdown.menu .nested.is-dropdown-submenu {\n  margin-right: 0;\n  margin-left: 0; }\n\n.dropdown.menu.vertical > li .is-dropdown-submenu {\n  top: 0; }\n\n.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {\n  top: 0;\n  right: 100%;\n  left: auto; }\n\n.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%; }\n\n.dropdown.menu.vertical > li > a::after {\n  right: 14px; }\n\n.dropdown.menu.vertical > li.opens-left > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  right: auto;\n  left: 5px; }\n\n.dropdown.menu.vertical > li.opens-right > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba; }\n\n@media print, screen and (min-width: 40em) {\n  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    right: 5px;\n    left: auto;\n    margin-top: -3px; }\n  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.medium-vertical > li > a::after {\n    right: 14px; }\n  .dropdown.menu.medium-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.medium-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; } }\n\n@media print, screen and (min-width: 64em) {\n  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    right: 5px;\n    left: auto;\n    margin-top: -3px; }\n  .dropdown.menu.large-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.large-vertical > li > a::after {\n    right: 14px; }\n  .dropdown.menu.large-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.large-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; } }\n\n.dropdown.menu.align-right .is-dropdown-submenu.first-sub {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.is-dropdown-menu.vertical {\n  width: 100px; }\n  .is-dropdown-menu.vertical.align-right {\n    float: right; }\n\n.is-dropdown-submenu-parent {\n  position: relative; }\n  .is-dropdown-submenu-parent a::after {\n    position: absolute;\n    top: 50%;\n    right: 5px;\n    left: auto;\n    margin-top: -6px; }\n  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {\n    top: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n\n.is-dropdown-submenu {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  z-index: 1;\n  display: none;\n  min-width: 200px;\n  border: 1px solid #cacaca;\n  background: #fefefe; }\n  .dropdown .is-dropdown-submenu a {\n    padding: 0.7rem 1rem; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {\n    right: 14px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; }\n  .is-dropdown-submenu .is-dropdown-submenu {\n    margin-top: -1px; }\n  .is-dropdown-submenu > li {\n    width: 100%; }\n  .is-dropdown-submenu.js-dropdown-active {\n    display: block; }\n\n.is-off-canvas-open {\n  overflow: hidden; }\n\n.js-off-canvas-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 11;\n  width: 100%;\n  height: 100%;\n  transition: opacity 0.5s ease, visibility 0.5s ease;\n  background: rgba(254, 254, 254, 0.25);\n  opacity: 0;\n  visibility: hidden;\n  overflow: hidden; }\n  .js-off-canvas-overlay.is-visible {\n    opacity: 1;\n    visibility: visible; }\n  .js-off-canvas-overlay.is-closable {\n    cursor: pointer; }\n  .js-off-canvas-overlay.is-overlay-absolute {\n    position: absolute; }\n  .js-off-canvas-overlay.is-overlay-fixed {\n    position: fixed; }\n\n.off-canvas-wrapper {\n  position: relative;\n  overflow: hidden; }\n\n.off-canvas {\n  position: fixed;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas {\n    outline: 0; }\n  .off-canvas.is-transition-push {\n    z-index: 12; }\n  .off-canvas.is-closed {\n    visibility: hidden; }\n  .off-canvas.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n.off-canvas-absolute {\n  position: absolute;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas-absolute {\n    outline: 0; }\n  .off-canvas-absolute.is-transition-push {\n    z-index: 12; }\n  .off-canvas-absolute.is-closed {\n    visibility: hidden; }\n  .off-canvas-absolute.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas-absolute.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas-absolute.is-open {\n    transform: translate(0, 0); }\n\n.position-left {\n  top: 0;\n  left: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(-250px); }\n  .off-canvas-content .off-canvas.position-left {\n    transform: translateX(-250px); }\n    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-left.has-transition-push {\n    transform: translateX(250px); }\n  .position-left.is-transition-push {\n    box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-right {\n  top: 0;\n  right: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(250px); }\n  .off-canvas-content .off-canvas.position-right {\n    transform: translateX(250px); }\n    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-right.has-transition-push {\n    transform: translateX(-250px); }\n  .position-right.is-transition-push {\n    box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-top {\n  top: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(-250px); }\n  .off-canvas-content .off-canvas.position-top {\n    transform: translateY(-250px); }\n    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-top.has-transition-push {\n    transform: translateY(250px); }\n  .position-top.is-transition-push {\n    box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-bottom {\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(250px); }\n  .off-canvas-content .off-canvas.position-bottom {\n    transform: translateY(250px); }\n    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-bottom.has-transition-push {\n    transform: translateY(-250px); }\n  .position-bottom.is-transition-push {\n    box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.off-canvas-content {\n  transform: none;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden; }\n  .off-canvas-content.has-transition-push {\n    transform: translate(0, 0); }\n  .off-canvas-content .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n@media print, screen and (min-width: 40em) {\n  .position-left.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-medium ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-medium ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-medium ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-medium ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 64em) {\n  .position-left.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-large ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-large ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-large ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-large ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 40em) {\n  .off-canvas.in-canvas-for-medium {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-medium .close-button {\n      display: none; } }\n\n@media print, screen and (min-width: 64em) {\n  .off-canvas.in-canvas-for-large {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-large .close-button {\n      display: none; } }\n\nhtml.is-reveal-open {\n  position: fixed;\n  width: 100%;\n  overflow-y: hidden; }\n  html.is-reveal-open.zf-has-scroll {\n    overflow-y: scroll; }\n  html.is-reveal-open body {\n    overflow-y: hidden; }\n\n.reveal-overlay {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1005;\n  display: none;\n  background-color: rgba(10, 10, 10, 0.45);\n  overflow-y: auto; }\n\n.reveal {\n  z-index: 1006;\n  backface-visibility: hidden;\n  display: none;\n  padding: 1rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  position: relative;\n  top: 100px;\n  margin-right: auto;\n  margin-left: auto;\n  overflow-y: auto; }\n  [data-whatinput='mouse'] .reveal {\n    outline: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      min-height: 0; } }\n  .reveal .column {\n    min-width: 0; }\n  .reveal > :last-child {\n    margin-bottom: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      width: 600px;\n      max-width: 75rem; } }\n  .reveal.collapse {\n    padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal.tiny {\n      width: 30%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.small {\n      width: 50%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.large {\n      width: 90%;\n      max-width: 75rem; } }\n  .reveal.full {\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    max-width: none;\n    height: 100%;\n    min-height: 100%;\n    margin-left: 0;\n    border: 0;\n    border-radius: 0; }\n  @media screen and (max-width: 39.99875em) {\n    .reveal {\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      width: 100%;\n      max-width: none;\n      height: 100%;\n      min-height: 100%;\n      margin-left: 0;\n      border: 0;\n      border-radius: 0; } }\n  .reveal.without-overlay {\n    position: fixed; }\n\n.sticky-container {\n  position: relative; }\n\n.sticky {\n  position: relative;\n  z-index: 0;\n  transform: translate3d(0, 0, 0); }\n\n.sticky.is-stuck {\n  position: fixed;\n  z-index: 5;\n  width: 100%; }\n  .sticky.is-stuck.is-at-top {\n    top: 0; }\n  .sticky.is-stuck.is-at-bottom {\n    bottom: 0; }\n\n.sticky.is-anchored {\n  position: relative;\n  right: auto;\n  left: auto; }\n  .sticky.is-anchored.is-at-bottom {\n    bottom: 0; }\n\n.title-bar {\n  padding: 0.5rem;\n  background: #0a0a0a;\n  color: #fefefe;\n  display: flex;\n  justify-content: flex-start;\n  align-items: center; }\n  .title-bar .menu-icon {\n    margin-left: 0.25rem;\n    margin-right: 0.25rem; }\n\n.title-bar-left,\n.title-bar-right {\n  flex: 1 1 0px; }\n\n.title-bar-right {\n  text-align: right; }\n\n.title-bar-title {\n  display: inline-block;\n  vertical-align: middle;\n  font-weight: bold; }\n\n.top-bar {\n  display: flex;\n  flex-wrap: nowrap;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0.5rem;\n  flex-wrap: wrap; }\n  .top-bar,\n  .top-bar ul {\n    background-color: #e6e6e6; }\n  .top-bar input {\n    max-width: 200px;\n    margin-right: 1rem; }\n  .top-bar .input-group-field {\n    width: 100%;\n    margin-right: 0; }\n  .top-bar input.button {\n    width: auto; }\n  .top-bar .top-bar-left,\n  .top-bar .top-bar-right {\n    flex: 0 0 100%;\n    max-width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .top-bar {\n      flex-wrap: nowrap; }\n      .top-bar .top-bar-left {\n        flex: 1 1 auto;\n        margin-right: auto; }\n      .top-bar .top-bar-right {\n        flex: 0 1 auto;\n        margin-left: auto; } }\n  @media screen and (max-width: 63.99875em) {\n    .top-bar.stacked-for-medium {\n      flex-wrap: wrap; }\n      .top-bar.stacked-for-medium .top-bar-left,\n      .top-bar.stacked-for-medium .top-bar-right {\n        flex: 0 0 100%;\n        max-width: 100%; } }\n  @media screen and (max-width: 74.99875em) {\n    .top-bar.stacked-for-large {\n      flex-wrap: wrap; }\n      .top-bar.stacked-for-large .top-bar-left,\n      .top-bar.stacked-for-large .top-bar-right {\n        flex: 0 0 100%;\n        max-width: 100%; } }\n\n.top-bar-title {\n  flex: 0 0 auto;\n  margin: 0.5rem 1rem 0.5rem 0; }\n\n.top-bar-left,\n.top-bar-right {\n  flex: 0 0 auto; }\n\n.float-left {\n  float: left !important; }\n\n.float-right {\n  float: right !important; }\n\n.float-center {\n  display: block;\n  margin-right: auto;\n  margin-left: auto; }\n\n.clearfix::before, .clearfix::after {\n  display: table;\n  content: ' ';\n  flex-basis: 0;\n  order: 1; }\n\n.clearfix::after {\n  clear: both; }\n\n.align-left {\n  justify-content: flex-start; }\n\n.align-right {\n  justify-content: flex-end; }\n\n.align-center {\n  justify-content: center; }\n\n.align-justify {\n  justify-content: space-between; }\n\n.align-spaced {\n  justify-content: space-around; }\n\n.align-left.vertical.menu > li > a {\n  justify-content: flex-start; }\n\n.align-right.vertical.menu > li > a {\n  justify-content: flex-end; }\n\n.align-center.vertical.menu > li > a {\n  justify-content: center; }\n\n.align-top {\n  align-items: flex-start; }\n\n.align-self-top {\n  align-self: flex-start; }\n\n.align-bottom {\n  align-items: flex-end; }\n\n.align-self-bottom {\n  align-self: flex-end; }\n\n.align-middle {\n  align-items: center; }\n\n.align-self-middle {\n  align-self: center; }\n\n.align-stretch {\n  align-items: stretch; }\n\n.align-self-stretch {\n  align-self: stretch; }\n\n.align-center-middle {\n  justify-content: center;\n  align-items: center;\n  align-content: center; }\n\n.small-order-1 {\n  order: 1; }\n\n.small-order-2 {\n  order: 2; }\n\n.small-order-3 {\n  order: 3; }\n\n.small-order-4 {\n  order: 4; }\n\n.small-order-5 {\n  order: 5; }\n\n.small-order-6 {\n  order: 6; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-order-1 {\n    order: 1; }\n  .medium-order-2 {\n    order: 2; }\n  .medium-order-3 {\n    order: 3; }\n  .medium-order-4 {\n    order: 4; }\n  .medium-order-5 {\n    order: 5; }\n  .medium-order-6 {\n    order: 6; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-order-1 {\n    order: 1; }\n  .large-order-2 {\n    order: 2; }\n  .large-order-3 {\n    order: 3; }\n  .large-order-4 {\n    order: 4; }\n  .large-order-5 {\n    order: 5; }\n  .large-order-6 {\n    order: 6; } }\n\n.flex-container {\n  display: flex; }\n\n.flex-child-auto {\n  flex: 1 1 auto; }\n\n.flex-child-grow {\n  flex: 1 0 auto; }\n\n.flex-child-shrink {\n  flex: 0 1 auto; }\n\n.flex-dir-row {\n  flex-direction: row; }\n\n.flex-dir-row-reverse {\n  flex-direction: row-reverse; }\n\n.flex-dir-column {\n  flex-direction: column; }\n\n.flex-dir-column-reverse {\n  flex-direction: column-reverse; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-flex-container {\n    display: flex; }\n  .medium-flex-child-auto {\n    flex: 1 1 auto; }\n  .medium-flex-child-grow {\n    flex: 1 0 auto; }\n  .medium-flex-child-shrink {\n    flex: 0 1 auto; }\n  .medium-flex-dir-row {\n    flex-direction: row; }\n  .medium-flex-dir-row-reverse {\n    flex-direction: row-reverse; }\n  .medium-flex-dir-column {\n    flex-direction: column; }\n  .medium-flex-dir-column-reverse {\n    flex-direction: column-reverse; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-flex-container {\n    display: flex; }\n  .large-flex-child-auto {\n    flex: 1 1 auto; }\n  .large-flex-child-grow {\n    flex: 1 0 auto; }\n  .large-flex-child-shrink {\n    flex: 0 1 auto; }\n  .large-flex-dir-row {\n    flex-direction: row; }\n  .large-flex-dir-row-reverse {\n    flex-direction: row-reverse; }\n  .large-flex-dir-column {\n    flex-direction: column; }\n  .large-flex-dir-column-reverse {\n    flex-direction: column-reverse; } }\n\n.hide {\n  display: none !important; }\n\n.invisible {\n  visibility: hidden; }\n\n@media screen and (max-width: 39.99875em) {\n  .hide-for-small-only {\n    display: none !important; } }\n\n@media screen and (max-width: 0em), screen and (min-width: 40em) {\n  .show-for-small-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 40em) {\n  .hide-for-medium {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em) {\n  .show-for-medium {\n    display: none !important; } }\n\n@media screen and (min-width: 40em) and (max-width: 63.99875em) {\n  .hide-for-medium-only {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {\n  .show-for-medium-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 64em) {\n  .hide-for-large {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em) {\n  .show-for-large {\n    display: none !important; } }\n\n@media screen and (min-width: 64em) and (max-width: 74.99875em) {\n  .hide-for-large-only {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {\n  .show-for-large-only {\n    display: none !important; } }\n\n.show-for-sr,\n.show-on-focus {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  white-space: nowrap;\n  border: 0; }\n\n.show-on-focus:active, .show-on-focus:focus {\n  position: static !important;\n  width: auto;\n  height: auto;\n  overflow: visible;\n  clip: auto;\n  white-space: normal; }\n\n.show-for-landscape,\n.hide-for-portrait {\n  display: block !important; }\n  @media screen and (orientation: landscape) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: block !important; } }\n  @media screen and (orientation: portrait) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: none !important; } }\n\n.hide-for-landscape,\n.show-for-portrait {\n  display: none !important; }\n  @media screen and (orientation: landscape) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: none !important; } }\n  @media screen and (orientation: portrait) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: block !important; } }\n\n.text-hide {\n  font: 0/0 a !important;\n  color: transparent !important;\n  text-shadow: none !important;\n  background-color: transparent !important;\n  border: 0 !important; }\n\n.text-truncate {\n  max-width: 100% !important;\n  overflow: hidden !important;\n  text-overflow: ellipsis;\n  white-space: nowrap !important; }\n\n.text-nowrap {\n  white-space: nowrap !important; }\n\n.text-wrap {\n  word-wrap: break-word !important; }\n\n.text-lowercase {\n  text-transform: lowercase !important; }\n\n.text-uppercase {\n  text-transform: uppercase !important; }\n\n.text-capitalize {\n  text-transform: capitalize !important; }\n\n.text-overline {\n  text-decoration: overline !important; }\n\n.text-underline {\n  text-decoration: underline !important; }\n\n.text-line-through {\n  text-decoration: line-through !important; }\n\n.font-wide {\n  letter-spacing: 0.25rem; }\n\n.font-normal {\n  font-weight: normal; }\n\n.font-bold {\n  font-weight: bold; }\n\n.font-italic {\n  font-style: italic !important; }\n\nul.list-disc {\n  list-style-type: disc !important; }\n\nul.list-circle {\n  list-style-type: circle !important; }\n\nul.list-square {\n  list-style-type: square !important; }\n\nol.list-decimal {\n  list-style-type: decimal !important; }\n\nol.list-lower-alpha {\n  list-style-type: lower-alpha !important; }\n\nol.list-lower-latin {\n  list-style-type: lower-latin !important; }\n\nol.list-lower-roman {\n  list-style-type: lower-roman !important; }\n\nol.list-upper-alpha {\n  list-style-type: upper-alpha !important; }\n\nol.list-upper-latin {\n  list-style-type: upper-latin !important; }\n\nol.list-upper-roman {\n  list-style-type: upper-roman !important; }\n\n.rounded {\n  border-radius: 5000px !important; }\n  .rounded:after {\n    border-radius: 50%; }\n\n.radius {\n  border-radius: 0.1875rem; }\n\n.bordered {\n  border: 0.0625rem solid #cacaca; }\n\n.shadow {\n  box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.16), 0 2px 10px 0 rgba(0, 0, 0, 0.12); }\n\n.arrow-down {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 0.4375rem;\n  content: '';\n  border-bottom-width: 0;\n  border-top-style: solid;\n  border-color: #0a0a0a transparent transparent; }\n\n.arrow-up {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 0.4375rem;\n  content: '';\n  border-top-width: 0;\n  border-bottom-style: solid;\n  border-color: transparent transparent #0a0a0a; }\n\n.arrow-right {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 0.4375rem;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #0a0a0a; }\n\n.arrow-left {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 0.4375rem;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #0a0a0a transparent transparent; }\n\n.separator-center {\n  text-align: center !important; }\n  .separator-center::before, .separator-center::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .separator-center::after {\n    clear: both; }\n  .separator-center::after {\n    position: relative !important;\n    width: 3rem;\n    border-bottom: 0.125rem solid #1779ba;\n    margin: 1rem auto 0; }\n\n.separator-left {\n  text-align: left !important; }\n  .separator-left::before, .separator-left::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .separator-left::after {\n    clear: both; }\n  .separator-left::after {\n    position: relative !important;\n    width: 3rem;\n    border-bottom: 0.125rem solid #1779ba;\n    margin: 1rem auto 0;\n    margin-left: 0 !important; }\n\n.separator-right {\n  text-align: right !important; }\n  .separator-right::before, .separator-right::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .separator-right::after {\n    clear: both; }\n  .separator-right::after {\n    position: relative !important;\n    width: 3rem;\n    border-bottom: 0.125rem solid #1779ba;\n    margin: 1rem auto 0;\n    margin-right: 0 !important; }\n\n.overflow-visible {\n  overflow: visible !important; }\n\n.overflow-x-visible {\n  overflow-x: visible !important; }\n\n.overflow-y-visible {\n  overflow-y: visible !important; }\n\n.overflow-hidden {\n  overflow: hidden !important; }\n\n.overflow-x-hidden {\n  overflow-x: hidden !important; }\n\n.overflow-y-hidden {\n  overflow-y: hidden !important; }\n\n.overflow-scroll {\n  overflow: scroll !important; }\n\n.overflow-x-scroll {\n  overflow-x: scroll !important; }\n\n.overflow-y-scroll {\n  overflow-y: scroll !important; }\n\n.display-inline {\n  display: inline !important; }\n\n.display-inline-block {\n  display: inline-block !important; }\n\n.display-block {\n  display: block !important; }\n\n.display-table {\n  display: table !important; }\n\n.display-table-cell {\n  display: table-cell !important; }\n\n.position-static {\n  position: static !important; }\n\n.position-relative {\n  position: relative !important; }\n\n.position-absolute {\n  position: absolute !important; }\n\n.position-fixed {\n  position: fixed !important; }\n\n.position-fixed-top {\n  position: fixed !important;\n  top: 0rem !important;\n  right: 0rem !important;\n  left: 0rem !important;\n  z-index: 975; }\n\n.position-fixed-bottom {\n  position: fixed !important;\n  right: 0rem !important;\n  bottom: 0rem !important;\n  left: 0rem !important;\n  z-index: 975; }\n\n.border-box {\n  box-sizing: border-box !important; }\n\n.border-none {\n  border: none !important; }\n\n.width-25 {\n  width: 25% !important; }\n\n.width-50 {\n  width: 50% !important; }\n\n.width-75 {\n  width: 75% !important; }\n\n.width-100 {\n  width: 100% !important; }\n\n.height-25 {\n  height: 25% !important; }\n\n.height-50 {\n  height: 50% !important; }\n\n.height-75 {\n  height: 75% !important; }\n\n.height-100 {\n  height: 100% !important; }\n\n.max-width-100 {\n  max-width: 100% !important; }\n\n.max-height-100 {\n  max-height: 100% !important; }\n\n.margin-0 {\n  margin: 0rem; }\n\n.margin-top-0 {\n  margin-top: 0rem !important; }\n\n.margin-right-0 {\n  margin-right: 0rem !important; }\n\n.margin-bottom-0 {\n  margin-bottom: 0rem !important; }\n\n.margin-left-0 {\n  margin-left: 0rem !important; }\n\n.margin-horizontal-0 {\n  margin-right: 0rem !important;\n  margin-left: 0rem !important; }\n\n.margin-vertical-0 {\n  margin-top: 0rem !important;\n  margin-bottom: 0rem !important; }\n\n.padding-0 {\n  padding: 0rem; }\n\n.padding-top-0 {\n  padding-top: 0rem !important; }\n\n.padding-right-0 {\n  padding-right: 0rem !important; }\n\n.padding-bottom-0 {\n  padding-bottom: 0rem !important; }\n\n.padding-left-0 {\n  padding-left: 0rem !important; }\n\n.padding-horizontal-0 {\n  padding-right: 0rem !important;\n  padding-left: 0rem !important; }\n\n.padding-vertical-0 {\n  padding-top: 0rem !important;\n  padding-bottom: 0rem !important; }\n\n.margin-1 {\n  margin: 1rem; }\n\n.margin-top-1 {\n  margin-top: 1rem !important; }\n\n.margin-right-1 {\n  margin-right: 1rem !important; }\n\n.margin-bottom-1 {\n  margin-bottom: 1rem !important; }\n\n.margin-left-1 {\n  margin-left: 1rem !important; }\n\n.margin-horizontal-1 {\n  margin-right: 1rem !important;\n  margin-left: 1rem !important; }\n\n.margin-vertical-1 {\n  margin-top: 1rem !important;\n  margin-bottom: 1rem !important; }\n\n.padding-1 {\n  padding: 1rem; }\n\n.padding-top-1 {\n  padding-top: 1rem !important; }\n\n.padding-right-1 {\n  padding-right: 1rem !important; }\n\n.padding-bottom-1 {\n  padding-bottom: 1rem !important; }\n\n.padding-left-1 {\n  padding-left: 1rem !important; }\n\n.padding-horizontal-1 {\n  padding-right: 1rem !important;\n  padding-left: 1rem !important; }\n\n.padding-vertical-1 {\n  padding-top: 1rem !important;\n  padding-bottom: 1rem !important; }\n\n.margin-2 {\n  margin: 2rem; }\n\n.margin-top-2 {\n  margin-top: 2rem !important; }\n\n.margin-right-2 {\n  margin-right: 2rem !important; }\n\n.margin-bottom-2 {\n  margin-bottom: 2rem !important; }\n\n.margin-left-2 {\n  margin-left: 2rem !important; }\n\n.margin-horizontal-2 {\n  margin-right: 2rem !important;\n  margin-left: 2rem !important; }\n\n.margin-vertical-2 {\n  margin-top: 2rem !important;\n  margin-bottom: 2rem !important; }\n\n.padding-2 {\n  padding: 2rem; }\n\n.padding-top-2 {\n  padding-top: 2rem !important; }\n\n.padding-right-2 {\n  padding-right: 2rem !important; }\n\n.padding-bottom-2 {\n  padding-bottom: 2rem !important; }\n\n.padding-left-2 {\n  padding-left: 2rem !important; }\n\n.padding-horizontal-2 {\n  padding-right: 2rem !important;\n  padding-left: 2rem !important; }\n\n.padding-vertical-2 {\n  padding-top: 2rem !important;\n  padding-bottom: 2rem !important; }\n\n.margin-3 {\n  margin: 3rem; }\n\n.margin-top-3 {\n  margin-top: 3rem !important; }\n\n.margin-right-3 {\n  margin-right: 3rem !important; }\n\n.margin-bottom-3 {\n  margin-bottom: 3rem !important; }\n\n.margin-left-3 {\n  margin-left: 3rem !important; }\n\n.margin-horizontal-3 {\n  margin-right: 3rem !important;\n  margin-left: 3rem !important; }\n\n.margin-vertical-3 {\n  margin-top: 3rem !important;\n  margin-bottom: 3rem !important; }\n\n.padding-3 {\n  padding: 3rem; }\n\n.padding-top-3 {\n  padding-top: 3rem !important; }\n\n.padding-right-3 {\n  padding-right: 3rem !important; }\n\n.padding-bottom-3 {\n  padding-bottom: 3rem !important; }\n\n.padding-left-3 {\n  padding-left: 3rem !important; }\n\n.padding-horizontal-3 {\n  padding-right: 3rem !important;\n  padding-left: 3rem !important; }\n\n.padding-vertical-3 {\n  padding-top: 3rem !important;\n  padding-bottom: 3rem !important; }\n","/**\n * Foundation for Sites by ZURB\n * Version 6.5.3\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n\n// Dependencies\n@import 'vendor/normalize';\n@import '../_vendor/sassy-lists/stylesheets/helpers/missing-dependencies';\n@import '../_vendor/sassy-lists/stylesheets/helpers/true';\n@import '../_vendor/sassy-lists/stylesheets/functions/contain';\n@import '../_vendor/sassy-lists/stylesheets/functions/purge';\n@import '../_vendor/sassy-lists/stylesheets/functions/remove';\n@import '../_vendor/sassy-lists/stylesheets/functions/replace';\n@import '../_vendor/sassy-lists/stylesheets/functions/to-list';\n\n// --- Settings ---\n// import your own `settings` here or\n// import and modify the default settings through\n// @import 'settings/settings';\n\n// --- Components ---\n// Utilities\n@import 'util/util';\n// Global styles\n@import 'global';\n@import 'forms/forms';\n@import 'typography/typography';\n\n// Grids\n@import 'grid/grid';\n@import 'xy-grid/xy-grid';\n// Generic components\n@import 'components/button';\n@import 'components/button-group';\n@import 'components/close-button';\n@import 'components/label';\n@import 'components/progress-bar';\n@import 'components/slider';\n@import 'components/switch';\n@import 'components/table';\n// Basic components\n@import 'components/badge';\n@import 'components/breadcrumbs';\n@import 'components/callout';\n@import 'components/card';\n@import 'components/dropdown';\n@import 'components/pagination';\n@import 'components/tooltip';\n\n// Containers\n@import 'components/accordion';\n@import 'components/media-object';\n@import 'components/orbit';\n@import 'components/responsive-embed';\n@import 'components/tabs';\n@import 'components/thumbnail';\n// Menu-based containers\n@import 'components/menu';\n@import 'components/menu-icon';\n@import 'components/accordion-menu';\n@import 'components/drilldown';\n@import 'components/dropdown-menu';\n\n// Layout components\n@import 'components/off-canvas';\n@import 'components/reveal';\n@import 'components/sticky';\n@import 'components/title-bar';\n@import 'components/top-bar';\n\n// Helpers\n@import 'components/float';\n@import 'components/flex';\n@import 'components/visibility';\n@import 'prototype/prototype';\n\n\n@mixin foundation-everything(\n  $flex: true,\n  $prototype: false\n) {\n  @if $flex {\n    $global-flexbox: true !global;\n  }\n\n  // Global styles\n  @include foundation-global-styles;\n  @include foundation-forms;\n  @include foundation-typography;\n\n  // Grids\n  @if not $flex {\n    @include foundation-grid;\n  }\n  @else {\n    @if $xy-grid {\n      @include foundation-xy-grid-classes;\n    }\n    @else {\n      @include foundation-flex-grid;\n    }\n  }\n\n  // Generic components\n  @include foundation-button;\n  @include foundation-button-group;\n  @include foundation-close-button;\n  @include foundation-label;\n  @include foundation-progress-bar;\n  @include foundation-slider;\n  @include foundation-switch;\n  @include foundation-table;\n  // Basic components\n  @include foundation-badge;\n  @include foundation-breadcrumbs;\n  @include foundation-callout;\n  @include foundation-card;\n  @include foundation-dropdown;\n  @include foundation-pagination;\n  @include foundation-tooltip;\n\n  // Containers\n  @include foundation-accordion;\n  @include foundation-media-object;\n  @include foundation-orbit;\n  @include foundation-responsive-embed;\n  @include foundation-tabs;\n  @include foundation-thumbnail;\n  // Menu-based containers\n  @include foundation-menu;\n  @include foundation-menu-icon;\n  @include foundation-accordion-menu;\n  @include foundation-drilldown-menu;\n  @include foundation-dropdown-menu;\n\n  // Layout components\n  @include foundation-off-canvas;\n  @include foundation-reveal;\n  @include foundation-sticky;\n  @include foundation-title-bar;\n  @include foundation-top-bar;\n\n  // Helpers\n  @include foundation-float-classes;\n  @if $flex { @include foundation-flex-classes; }\n  @include foundation-visibility-classes;\n  @if $prototype { @include foundation-prototype-classes; }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group breakpoints\n////\n\n/// A list of named breakpoints. You can use these with the `breakpoint()` mixin to quickly create media queries.\n/// @type Map\n$breakpoints: (\n  small: 0,\n  medium: 640px,\n  large: 1024px,\n  xlarge: 1200px,\n  xxlarge: 1440px,\n) !default;\n\n/// The largest named breakpoint in which to include print as a media type\n/// @type Keyword\n$print-breakpoint: large !default;\n\n$-zf-zero-breakpoint: small !default;\n\n$-zf-breakpoints-keys: map-to-list($breakpoints, 'keys');\n\n@if nth(map-values($breakpoints), 1) != 0 {\n  @error 'The first key in the $breakpoints map must have a value of \"0\".';\n}\n@else {\n  $-zf-zero-breakpoint: nth(map-keys($breakpoints), 1);\n}\n\n/// All of the names in this list will be output as classes in your CSS, like `.small-12`, `.medium-6`, and so on. Each value in this list must also be in the `$breakpoints` map.\n/// @type List\n$breakpoint-classes: (small medium large) !default;\n\n/// Generates a media query string matching the input value. Refer to the documentation for the `breakpoint()` mixin to see what the possible inputs are.\n///\n/// @param {Keyword|Number} $val [small] - Breakpoint name, or px, rem, or em value to process.\n@function breakpoint($val: $-zf-zero-breakpoint) {\n  // Size or keyword\n  $bp: nth($val, 1);\n  // Value for max-width media queries\n  $bp-max: 0;\n  // Direction of media query (up, down, or only)\n  $dir: if(length($val) > 1, nth($val, 2), up);\n  // Eventual output\n  $str: '';\n  // Is it a named media query?\n  $named: false;\n\n  // Orientation media queries have a unique syntax\n  @if $bp == 'landscape' or $bp == 'portrait' {\n    @return '(orientation: #{$bp})';\n  }\n  @else if $bp == 'retina' {\n    @return '(-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi)';\n  }\n\n  // Try to pull a named breakpoint out of the $breakpoints map\n  @if type-of($bp) == 'string' {\n    @if map-has-key($breakpoints, $bp) {\n      @if $dir == 'only' or $dir == 'down' {\n        $bp-max: -zf-map-next($breakpoints, $bp);\n      }\n\n      $bp: map-get($breakpoints, $bp);\n      $named: true;\n    }\n    @else {\n      $bp: 0;\n      @warn 'breakpoint(): \"#{$val}\" is not defined in your $breakpoints setting.';\n    }\n  }\n\n  // Convert any pixel, rem, or unitless value to em\n  $bp: -zf-bp-to-em($bp);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/zurb/foundation-sites/issues/11313\n  @if $bp-max {\n    $bp-max: -zf-bp-to-em($bp-max) - .00125;\n  }\n\n  // Conditions to skip media query creation\n  // - It's a named breakpoint that resolved to \"0 down\" or \"0 up\"\n  // - It's a numeric breakpoint that resolved to \"0 \" + anything\n  @if $bp > 0em or $dir == 'only' or $dir == 'down' {\n    // `only` ranges use the format `(min-width: n) and (max-width: n)`\n    @if $dir == 'only' {\n      // Only named media queries can have an \"only\" range\n      @if $named == true {\n        // Only use \"min-width\" if the floor is greater than 0\n        @if $bp > 0em {\n          $str: $str + '(min-width: #{$bp})';\n\n          // Only add \"and\" to the media query if there's a ceiling\n          @if $bp-max != null {\n            $str: $str + ' and ';\n          }\n        }\n\n        // Only use \"max-width\" if there's a ceiling\n        @if $bp-max != null {\n          $str: $str + '(max-width: #{$bp-max})';\n        }\n      }\n      @else {\n        @warn 'breakpoint(): Only named media queries can have an `only` range.';\n      }\n    }\n\n    // `down` ranges use the format `(max-width: n)`\n    @else if $dir == 'down' {\n      $max: if($named, $bp-max, $bp);\n\n      // Skip media query creation if input value is exactly \"0 down\",\n      // unless the function was called as \"small down\", in which case it's just \"small only\"\n      @if $named or $bp > 0em {\n        @if $max != null {\n          $str: $str + '(max-width: #{$max})';\n        }\n      }\n    }\n\n    // `up` ranges use the format `(min-width: n)`\n    @else if $bp > 0em {\n      $str: $str + '(min-width: #{$bp})';\n    }\n  }\n\n  @return $str;\n}\n\n/// Wraps a media query around the content you put inside the mixin. This mixin accepts a number of values:\n///  - If a string is passed, the mixin will look for it in the `$breakpoints` map, and use a media query there.\n///  - If a pixel value is passed, it will be converted to an em value using `$global-font-size` as the base.\n///  - If a rem value is passed, the unit will be changed to em.\n///  - If an em value is passed, the value will be used as-is.\n///\n/// @param {Keyword|Number} $value - Breakpoint name, or px, rem, or em value to process.\n///\n/// @output If the breakpoint is \"0px and larger\", outputs the content as-is. Otherwise, outputs the content wrapped in a media query.\n@mixin breakpoint($value) {\n  $str: breakpoint($value);\n  $bp: index($-zf-breakpoints-keys, $value);\n  $pbp: index($-zf-breakpoints-keys, $print-breakpoint);\n\n  $old-zf-size: null;\n\n  // Make breakpoint size available as a variable\n  @if global-variable-exists(-zf-size) {\n    $old-zf-size: $-zf-size;\n  }\n  $-zf-size: nth($value, 1) !global; // get the first value to account for `only` and `down` keywords\n\n  // If $str is still an empty string, no media query is needed\n  @if $str == '' {\n    @content;\n  }\n\n  // Otherwise, wrap the content in a media query\n  @else {\n    // For named breakpoints less than or equal to $print-breakpoint, add print to the media types\n    @if $bp != null and $bp <= $pbp {\n      @media print, screen and #{$str} {\n        @content;\n       }\n    }\n    @else {\n      @media screen and #{$str} {\n        @content;\n      }\n    }\n  }\n\n  $-zf-size: $old-zf-size !global;\n}\n\n/// Converts the breakpoints map to a URL-encoded string, like this: `key1=value1&key2=value2`. The value is then dropped into the CSS for a special `<meta>` tag, which is read by the Foundation JavaScript. This is how we transfer values from Sass to JavaScript, so they can be defined in one place.\n/// @access private\n///\n/// @param {Map} $map - Map to convert.\n///\n/// @returns {String} A string containing the map's contents.\n@function -zf-bp-serialize($map) {\n  $str: '';\n  @each $key, $value in $map {\n    $str: $str + $key + '=' + -zf-bp-to-em($value) + '&';\n  }\n  $str: str-slice($str, 1, -2);\n\n  @return $str;\n}\n\n/// Find the next key in a map.\n/// @access private\n///\n/// @param {Map} $map - Map to traverse.\n/// @param {Mixed} $key - Key to use as a starting point.\n///\n/// @returns {Mixed} The value for the key after `$key`, if `$key` was found. If `$key` was not found, or `$key` was the last value in the map, returns `null`.\n@function -zf-map-next($map, $key) {\n\n  // Store the keys of the map as a list\n  $values: map-keys($map);\n\n  $i: 0;\n\n  // If the Key Exists, Get the index of the key within the map and add 1 to it for the next breakpoint in the map\n  @if (map-has-key($map, $key)) {\n    $i: index($values, $key) + 1;\n  }\n\n  // If the key doesn't exist, or it's the last key in the map, return null\n  @if ($i > length($map) or $i == 0) {\n    @return null;\n  }\n  // Otherwise, return the value\n  @else {\n    @return map-get($map, nth($values, $i));\n  }\n\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $key - Key to use as last breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-breakpoints-less-than($key) {\n  $list: ();\n  $found_key: false;\n\n  @each $name in $-zf-breakpoints-keys {\n    @if ($name == $key) {\n      $found_key: true;\n    }\n    @if not $found_key {\n      $list: append($list, $name);\n    }\n  }\n  @return $list;\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $breakpoint - a named or non-named breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-closest-named-breakpoint($breakpoint) {\n  $last: $-zf-zero-breakpoint;\n  $found: false;\n\n  $value: unitless-calc($breakpoint, 1px);\n  @each $key, $val in $breakpoints {\n    @if not $found {\n      @if unitless-calc($val) > $value {\n        $found: true;\n      } @else {\n        $last: $key;\n      }\n    }\n  }\n\n  @return $last;\n}\n\n/// Get a value for a breakpoint from a responsive config map or single value.\n/// - If the config is a single value, return it regardless of `$value`.\n/// - If the config is a map and has the key `$value`, the exact breakpoint value is returned.\n/// - If the config is a map and does *not* have the breakpoint, the value matching the next lowest breakpoint in the config map is returned.\n/// @access private\n///\n/// @param {Number|Map} $map - Responsive config map or single value.\n/// @param {Keyword} $value - Breakpoint name to use.\n///\n/// @return {Mixed} The corresponding breakpoint value.\n@function -zf-get-bp-val($map, $value) {\n  // If the given map is a single value, return it\n  @if type-of($map) == 'number' {\n    @return $map;\n  }\n\n\n  // Check if the breakpoint name exists globally\n  @if not map-has-key($breakpoints, $value) {\n    @if type-of($value) == 'number' {\n      $value: -zf-closest-named-breakpoint($value);\n    } @else {\n      @return null;\n    }\n  }\n  // Check if the breakpoint name exists in the local config map\n  @else if map-has-key($map, $value) {\n    // If it does, just return the value\n    @return map-get($map, $value);\n  }\n  // Otherwise, find the next lowest breakpoint and return that value\n  @else {\n    $anchor: null;\n    $found: false;\n\n    @each $key, $val in $breakpoints {\n      @if not $found {\n        @if map-has-key($map, $key) {\n          $anchor: $key;\n        }\n        @if $key == $value {\n          $found: true;\n        }\n      }\n    }\n\n    @return map-get($map, $anchor);\n  }\n}\n\n$small-up: '';\n$small-only: '';\n\n@if map-has-key($breakpoints, small) {\n  $small-up: screen;\n  $small-only: unquote('screen and #{breakpoint(small only)}');\n}\n\n$medium-up: '';\n$medium-only: '';\n\n@if map-has-key($breakpoints, medium) {\n  $medium-up: unquote('screen and #{breakpoint(medium)}');\n  $medium-only: unquote('screen and #{breakpoint(medium only)}');\n}\n\n$large-up: '';\n$large-only: '';\n\n@if map-has-key($breakpoints, large) {\n  $large-up: unquote('screen and #{breakpoint(large)}');\n  $large-only: unquote('screen and #{breakpoint(large only)}');\n}\n\n$xlarge-up: '';\n$xlarge-only: '';\n\n@if map-has-key($breakpoints, xlarge) {\n  $xlarge-up: unquote('screen and #{breakpoint(xlarge)}');\n  $xlarge-only: unquote('screen and #{breakpoint(xlarge only)}');\n}\n\n$xxlarge-up: '';\n\n@if map-has-key($breakpoints, xxlarge) {\n  $xxlarge-up: unquote('screen and #{breakpoint(xxlarge)}');\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group reveal\n////\n\n/// Default background color of a modal.\n/// @type Color\n$reveal-background: $white !default;\n\n/// Default width of a modal, with no class applied.\n/// @type Number\n$reveal-width: 600px !default;\n\n/// Default maximum width of a modal.\n/// @type Number\n$reveal-max-width: $global-width !default;\n\n/// Default padding inside a modal.\n/// @type Number\n$reveal-padding: $global-padding !default;\n\n/// Default border around a modal.\n/// @type Number\n$reveal-border: 1px solid $medium-gray !default;\n\n/// Default radius for modal.\n/// @type Number\n$reveal-radius: $global-radius !default;\n\n/// z-index for modals. The overlay uses this value, while the modal itself uses this value plus one.\n/// @type Number\n$reveal-zindex: 1005 !default;\n\n/// Background color of modal overlays.\n/// @type Color\n$reveal-overlay-background: rgba($black, 0.45) !default;\n\n\n// Placeholder selector for medium-and-up modals\n// Prevents duplicate CSS when defining multiple Reveal sizes\n// This should be in the same breakpoint then `@mixin reveal-modal-width`\n@include breakpoint(medium) {\n  %reveal-centered {\n    right: auto;\n    left: auto;\n    margin: 0 auto;\n  }\n}\n\n\n/// Adds styles for a modal overlay.\n/// @param {Color} $background [$reveal-overlay-background] - Background color of the overlay.\n@mixin reveal-overlay($background: $reveal-overlay-background) {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: $reveal-zindex;\n\n  display: none;\n  background-color: $background;\n  overflow-y: auto;\n}\n\n/// Adds base styles for a modal.\n@mixin reveal-modal-base {\n  @include disable-mouse-outline;\n  z-index: $reveal-zindex + 1;\n  // Workaround android browser z-index bug\n  backface-visibility: hidden;\n\n  display: none;\n  padding: $reveal-padding;\n\n  border: $reveal-border;\n  border-radius: $reveal-radius;\n  background-color: $reveal-background;\n\n  @include breakpoint(medium) {\n    min-height: 0;\n  }\n\n  // Make sure rows don't have a min-width on them\n  .column {\n    min-width: 0;\n  }\n\n  // Strip margins from the last item in the modal\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adjusts the width of a modal.\n/// @param {Number} $width - Width of the modal. Generally a percentage.\n/// @param {Number} $max-width [$reveal-max-width] - Maximum width of the modal.\n@mixin reveal-modal-width(\n  $width: $reveal-width,\n  $max-width: $reveal-max-width\n) {\n  // Extends must be made outside of breakpoints for compatibility with newer Sass versions (libsass v3.5)\n  @extend %reveal-centered;\n  @include breakpoint(medium) {\n    width: $width;\n    max-width: $max-width;\n  }\n}\n\n/// Creates a full-screen modal, which stretches the full width and height of the window.\n@mixin reveal-modal-fullscreen {\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n\n  width: 100%;\n  max-width: none;\n  height: 100%;\n  min-height: 100%;\n  margin-left: 0;\n\n  border: 0;\n  border-radius: 0;\n}\n\n@mixin foundation-reveal {\n\n  /// Disables the scroll when Reveal is shown to prevent the background from shifting\n  html.is-reveal-open {\n    position: fixed;\n    width: 100%;\n    overflow-y: hidden;\n\n    &.zf-has-scroll {\n      overflow-y: scroll;\n    }\n\n    body { // sass-lint:disable-line no-qualifying-elements\n      overflow-y: hidden;\n    }\n  }\n\n  // Overlay\n  .reveal-overlay {\n    @include reveal-overlay;\n  }\n\n  // Modal container\n  .reveal {\n    @include reveal-modal-base;\n    @include reveal-modal-width($reveal-width);\n    position: relative;\n    top: 100px;\n    margin-right: auto;\n    margin-left: auto;\n    overflow-y: auto;\n\n    // Remove padding\n    &.collapse {\n      padding: 0;\n    }\n\n    // Sizing classes\n    &.tiny  { @include reveal-modal-width(30%); }\n    &.small { @include reveal-modal-width(50%); }\n    &.large { @include reveal-modal-width(90%); }\n\n    // Full-screen mode\n    &.full {\n      @include reveal-modal-fullscreen;\n    }\n\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include reveal-modal-fullscreen;\n    }\n\n    &.without-overlay {\n      position: fixed;\n    }\n  }\n}\n","@mixin foundation-normalize() {\n  /*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\n\n  // Document\n  // ==========================================================================\n\n  // 1. Correct the line height in all browsers.\n  // 2. Prevent adjustments of font size after orientation changes in iOS.\n\n  html {\n    line-height: 1.15; // 1\n    -webkit-text-size-adjust: 100%; // 2\n  }\n\n  // Sections\n  // ==========================================================================\n\n  // Remove the margin in all browsers.\n\n  body {\n    margin: 0;\n  }\n\n  // Correct the font size and margin on `h1` elements within `section` and\n  // `article` contexts in Chrome, Firefox, and Safari.\n\n  h1 {\n    font-size: 2em;\n    margin: 0.67em 0;\n  }\n\n  // Grouping content\n  // ==========================================================================\n\n  // 1. Add the correct box sizing in Firefox.\n  // 2. Show the overflow in Edge and IE.\n\n  hr {\n    box-sizing: content-box; // 1\n    height: 0; // 1\n    overflow: visible; // 2\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  pre {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Text-level semantics\n  // ==========================================================================\n\n  // Remove the gray background on active links in IE 10.\n\n  a {\n    background-color: transparent;\n  }\n\n  // 1. Remove the bottom border in Chrome 57-\n  // 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n\n  abbr[title] {\n    border-bottom: none; // 1\n    text-decoration: underline; // 2\n    text-decoration: underline dotted; // 2\n  }\n\n  // Add the correct font weight in Chrome, Edge, and Safari.\n\n  b,\n  strong {\n    font-weight: bolder;\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  code,\n  kbd,\n  samp {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Add the correct font size in all browsers.\n\n  small {\n    font-size: 80%;\n  }\n\n  // Prevent `sub` and `sup` elements from affecting the line height in\n  // all browsers.\n\n  sub,\n  sup {\n    font-size: 75%;\n    line-height: 0;\n    position: relative;\n    vertical-align: baseline;\n  }\n\n  sub {\n    bottom: -0.25em;\n  }\n\n  sup {\n    top: -0.5em;\n  }\n\n  // Embedded content\n  // ==========================================================================\n\n  // Remove the border on images inside links in IE 10.\n\n  img {\n    border-style: none;\n  }\n\n  // Forms\n  // ==========================================================================\n\n  // 1. Change the font styles in all browsers.\n  // 2. Remove the margin in Firefox and Safari.\n\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit; // 1\n    font-size: 100%; // 1\n    line-height: 1.15; // 1\n    margin: 0; // 2\n  }\n\n  // Show the overflow in IE.\n  // 1. Show the overflow in Edge.\n\n  button,\n  input { // 1\n    overflow: visible;\n  }\n\n  // Remove the inheritance of text transform in Edge, Firefox, and IE.\n  // 1. Remove the inheritance of text transform in Firefox.\n\n  button,\n  select { // 1\n    text-transform: none;\n  }\n\n  // Correct the inability to style clickable types in iOS and Safari.\n\n  button,\n  [type=\"button\"],\n  [type=\"reset\"],\n  [type=\"submit\"] {\n    -webkit-appearance: button;\n  }\n\n  // Remove the inner border and padding in Firefox.\n\n  button::-moz-focus-inner,\n  [type=\"button\"]::-moz-focus-inner,\n  [type=\"reset\"]::-moz-focus-inner,\n  [type=\"submit\"]::-moz-focus-inner {\n    border-style: none;\n    padding: 0;\n  }\n\n  // Restore the focus styles unset by the previous rule.\n\n  button:-moz-focusring,\n  [type=\"button\"]:-moz-focusring,\n  [type=\"reset\"]:-moz-focusring,\n  [type=\"submit\"]:-moz-focusring {\n    outline: 1px dotted ButtonText;\n  }\n\n  // Correct the padding in Firefox.\n\n  fieldset {\n    padding: 0.35em 0.75em 0.625em;\n  }\n\n  // 1. Correct the text wrapping in Edge and IE.\n  // 2. Correct the color inheritance from `fieldset` elements in IE.\n  // 3. Remove the padding so developers are not caught out when they zero out\n  //    `fieldset` elements in all browsers.\n\n  legend {\n    box-sizing: border-box; // 1\n    color: inherit; // 2\n    display: table; // 1\n    max-width: 100%; // 1\n    padding: 0; // 3\n    white-space: normal; // 1\n  }\n\n  // Add the correct vertical alignment in Chrome, Firefox, and Opera.\n\n  progress {\n    vertical-align: baseline;\n  }\n\n  // Remove the default vertical scrollbar in IE 10+.\n\n  textarea {\n    overflow: auto;\n  }\n\n  // 1. Add the correct box sizing in IE 10.\n  // 2. Remove the padding in IE 10.\n\n  [type=\"checkbox\"],\n  [type=\"radio\"] {\n    box-sizing: border-box; // 1\n    padding: 0; // 2\n  }\n\n  // Correct the cursor style of increment and decrement buttons in Chrome.\n\n  [type=\"number\"]::-webkit-inner-spin-button,\n  [type=\"number\"]::-webkit-outer-spin-button {\n    height: auto;\n  }\n\n  // 1. Correct the odd appearance in Chrome and Safari.\n  // 2. Correct the outline style in Safari.\n\n  [type=\"search\"] {\n    -webkit-appearance: textfield; // 1\n    outline-offset: -2px; // 2\n  }\n\n  // Remove the inner padding in Chrome and Safari on macOS.\n\n  [type=\"search\"]::-webkit-search-decoration {\n    -webkit-appearance: none;\n  }\n\n  // 1. Correct the inability to style clickable types in iOS and Safari.\n  // 2. Change font properties to `inherit` in Safari.\n\n  ::-webkit-file-upload-button {\n    -webkit-appearance: button; // 1\n    font: inherit; // 2\n  }\n\n  // Interactive\n  // ==========================================================================\n\n  // Add the correct display in Edge, IE 10+, and Firefox.\n\n  details {\n    display: block;\n  }\n\n  // Add the correct display in all browsers.\n\n  summary {\n    display: list-item;\n  }\n\n  // Misc\n  // ==========================================================================\n\n  // Add the correct display in IE 10+.\n\n  template {\n    display: none;\n  }\n\n  // Add the correct display in IE 10.\n\n  [hidden] {\n    display: none;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-color-literals, no-qualifying-elements\n\n////\n/// @group global\n////\n\n@import 'util/util';\n\n/// Font size attribute applied to `<html>` and `<body>`. We use 100% by default so the value is inherited from the user's browser settings.\n/// @type Number\n$global-font-size: 100% !default;\n\n/// Global width of your site. Used by the grid to determine row width.\n/// @type Number\n$global-width: rem-calc(1200) !default;\n\n/// Default line height for all type. `$global-lineheight` is 24px while `$global-font-size` is 16px\n/// @type Number\n$global-lineheight: 1.5 !default;\n\n/// Colors used for buttons, callouts, links, etc. There must always be a color called `primary`.\n/// @type Map\n$foundation-palette: (\n  primary: #1779ba,\n  secondary: #767676,\n  success: #3adb76,\n  warning: #ffae00,\n  alert: #cc4b37,\n) !default;\n\n/// Color used for light gray UI items.\n/// @type Color\n$light-gray: #e6e6e6 !default;\n\n/// Color used for medium gray UI items.\n/// @type Color\n$medium-gray: #cacaca !default;\n\n/// Color used for dark gray UI items.\n/// @type Color\n$dark-gray: #8a8a8a !default;\n\n/// Color used for black ui items.\n/// @type Color\n$black: #0a0a0a !default;\n\n/// Color used for white ui items.\n/// @type Color\n$white: #fefefe !default;\n\n/// Background color of the body.\n/// @type Color\n$body-background: $white !default;\n\n/// Text color of the body.\n/// @type Color\n$body-font-color: $black !default;\n\n/// Font stack of the body.\n/// @type List\n$body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif !default;\n\n/// Set to `true` to enable antialiased type, using the `-webkit-font-smoothing` and `-moz-osx-font-smoothing` CSS properties.\n/// @type Boolean\n$body-antialiased: true !default;\n\n/// Global value used for margin on components.\n/// @type Number\n$global-margin: 1rem !default;\n\n/// Global value used for padding on components.\n/// @type Number\n$global-padding: 1rem !default;\n\n/// Global value used for positioning on components.\n/// @type Number\n$global-position: 1rem !default;\n\n/// Global font weight used for normal type.\n/// @type Keyword | Number\n$global-weight-normal: normal !default;\n\n/// Global font weight used for bold type.\n/// @type Keyword | Number\n$global-weight-bold: bold !default;\n\n/// Global value used for all elements that have a border radius.\n/// @type Number\n$global-radius: 0 !default;\n\n/// Global value used for all menu styles. Can be overwritten at individual menu component level.\n/// @type Number\n$global-menu-padding: 0.7rem 1rem !default;\n\n/// Global value used for all menu styles. Nested margin for submenu.\n$global-menu-nested-margin: 1rem !default;\n\n/// Sets the text direction of the CSS. Can be either `ltr` or `rtl`.\n/// @type Keyword\n$global-text-direction: ltr !default;\n\n/// Enables flexbox for components that support it.\n/// @type Boolean\n$global-flexbox: true !default;\n\n/// Enabled responsive breakpoints for prototypes if applicable\n/// @type Boolean\n$global-prototype-breakpoints: false !default;\n\n/// Button cursor's value, `auto` by default\n/// @type Keyword\n$global-button-cursor: auto !default;\n\n@if not map-has-key($foundation-palette, primary) {\n  @error 'In $foundation-palette, you must have a color named \"primary\".';\n}\n\n// Internal variables used for text direction\n$global-left: if($global-text-direction == rtl, right, left);\n$global-right: if($global-text-direction == rtl, left, right);\n\n// Internal variable that contains the flex justifying options\n$-zf-flex-justify: -zf-flex-justify($global-text-direction);\n\n/// Global tolerance for color pick contrast.\n/// @type Number\n$global-color-pick-contrast-tolerance: 0 !default;\n\n// Internal variables used for colors\n@include add-foundation-colors;\n\n@mixin foundation-global-styles {\n  @include foundation-normalize;\n\n  // These styles are applied to a <meta> tag, which is read by the Foundation JavaScript\n  .foundation-mq {\n    font-family: '#{-zf-bp-serialize($breakpoints)}';\n  }\n\n  html {\n    box-sizing: border-box;\n    font-size: $global-font-size;\n  }\n\n  // Set box-sizing globally to handle padding and border widths\n  *,\n  *::before,\n  *::after {\n    box-sizing: inherit;\n  }\n\n  // Default body styles\n  body {\n    margin: 0;\n    padding: 0;\n\n    background: $body-background;\n\n    font-family: $body-font-family;\n    font-weight: $global-weight-normal;\n    line-height: $global-lineheight;\n    color: $body-font-color;\n\n    @if ($body-antialiased) {\n      -webkit-font-smoothing: antialiased; // sass-lint:disable-line no-vendor-prefixes\n      -moz-osx-font-smoothing: grayscale; // sass-lint:disable-line no-vendor-prefixes\n    }\n  }\n\n  img {\n    // Get rid of gap under images by making them display: inline-block; by default\n    display: inline-block;\n    vertical-align: middle;\n\n    // Grid defaults to get images and embeds to work properly\n    max-width: 100%;\n    height: auto;\n    -ms-interpolation-mode: bicubic;\n  }\n\n  // Make sure textarea takes on height automatically\n  textarea {\n    height: auto;\n    min-height: 50px;\n    border-radius: $global-radius;\n  }\n\n  // Make select elements are 100% width by default\n  select {\n    box-sizing: border-box;\n    width: 100%;\n    border-radius: $global-radius;\n  }\n\n  // Styles Google Maps and MapQuest embeds properly\n  // sass-lint:disable-line no-ids\n  .map_canvas,\n  .mqa-display {\n    img,\n    embed,\n    object {\n      max-width: none !important;\n    }\n  }\n\n  // Reset <button> styles created by most browsers\n  button {\n    @include disable-mouse-outline;\n    padding: 0;\n    appearance: none;\n    border: 0;\n    border-radius: $global-radius;\n    background: transparent;\n    line-height: 1;\n    cursor: $global-button-cursor;\n  }\n\n  // Prevent text overflow on pre\n  pre {\n    overflow: auto;\n  }\n\n  // Make reset inherit font-family instead of settings sans-serif\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit;\n  }\n\n  // Internal classes to show/hide elements in JavaScript\n  .is-visible {\n    display: block !important;\n  }\n\n  .is-hidden {\n    display: none !important;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n$global-font-size: 100% !default;\n\n/// Removes the unit (e.g. px, em, rem) from a value, returning the number only.\n///\n/// @param {Number} $num - Number to strip unit from.\n///\n/// @returns {Number} The same number, sans unit.\n@function strip-unit($num) {\n  @return $num / ($num * 0 + 1);\n}\n\n/// Converts one or more pixel values into matching rem values.\n///\n/// @param {Number|List} $values - One or more values to convert. Be sure to separate them with spaces and not commas. If you need to convert a comma-separated list, wrap the list in parentheses.\n/// @param {Number} $base [null] - The base value to use when calculating the `rem`. If you're using Foundation out of the box, this is 16px. If this parameter is `null`, the function will reference the `$global-font-size` variable as the base.\n///\n/// @returns {List} A list of converted values.\n@function rem-calc($values, $base: null) {\n  $rem-values: ();\n  $count: length($values);\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // If the base font size is a %, then multiply it by 16px\n  // This is because 100% font size = 16px in most all browsers\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  // Using rem as base allows correct scaling\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if $count == 1 {\n    @return -zf-to-rem($values, $base);\n  }\n\n  @for $i from 1 through $count {\n    $rem-values: append($rem-values, -zf-to-rem(nth($values, $i), $base));\n  }\n\n  @return $rem-values;\n}\n\n// Converts a unitless, pixel, or rem value to em, for use in breakpoints.\n@function -zf-bp-to-em($value) {\n  // Pixel and unitless values are converted to rems\n  @if unit($value) == 'px' or unitless($value) {\n    $value: rem-calc($value, $base: 16px);\n  }\n\n  // Then the value is converted to ems\n  @return strip-unit($value) * 1em;\n}\n\n/// Converts a pixel value to matching rem value. *Any* value passed, regardless of unit, is assumed to be a pixel value. By default, the base pixel value used to calculate the rem value is taken from the `$global-font-size` variable.\n/// @access private\n///\n/// @param {Number} $value - Pixel value to convert.\n/// @param {Number} $base [null] - Base for pixel conversion.\n///\n/// @returns {Number} A number in rems, calculated based on the given value and the base pixel value. rem values are passed through as is.\n@function -zf-to-rem($value, $base: null) {\n  // Check if the value is a number\n  @if type-of($value) != 'number' {\n    @warn inspect($value) + ' was passed to rem-calc(), which is not a number.';\n    @return $value;\n  }\n\n  // Transform em into rem if someone hands over 'em's\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * 1rem;\n  }\n\n  // Calculate rem if units for $value is not rem or em\n  @if unit($value) != 'rem' {\n    $value: strip-unit($value) / strip-unit($base) * 1rem;\n  }\n\n  // Turn 0rem into 0\n  @if $value == 0rem {\n    $value: 0;\n  }\n\n  @return $value;\n}\n\n/// Converts a pixel, percentage, rem or em value to a unitless value based on a given font size. Ideal for working out unitless line heights.\n///\n/// @param {Number} $value - Value to convert to a unitless line height\n/// @param {Number} $base - The font size to use to work out the line height - defaults to $global-font-size\n///\n/// @return {Number} - Unitless number\n@function unitless-calc($value, $base: null) {\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // First, lets convert our $base to pixels\n\n  // If the base font size is a %, then multiply it by 16px\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if unit($base) == 'em' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  // Now let's convert our value to pixels too\n  @if unit($value) == '%' {\n    $value: ($value / 100%) * $base;\n  }\n\n  @if unit($value) == 'rem' {\n    $value: strip-unit($value) * $base;\n  }\n\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * $base;\n  }\n\n  // 'px'\n  @if unit($value) == 'px' {\n    @return strip-unit($value) / strip-unit($base);\n  }\n\n  // assume that line-heights greater than 10 are meant to be absolute in 'px'\n  @if unitless($value) and ($value > 10) {\n    @return $value / strip-unit($base);\n  }\n\n  @return $value;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Creates an inner box-shadow for only one side\n///\n/// @param {Keyword} $side - Side the shadow is supposed to appear. Can be `top`, `left`, `right` or `bottom`.\n/// @param {Number} $size - Width for the target side.\n/// @param {Color} $color - Color of the shadow.\n@mixin inner-side-shadow(\n  $side: bottom,\n  $size: 20px,\n  $color: rgba($black, 0.25)\n) {\n\n  $helper: round($size * 0.65);\n\n  @if ($side == top) {\n    box-shadow: inset 0 $helper $size (-1)*$helper $color;\n  } @else if ($side == left) {\n    box-shadow: inset $helper 0 $size (-1)*$helper $color;\n  } @else if ($side == right) {\n    box-shadow: inset (-1)*$helper 0 $size (-1)*$helper $color;\n  } @else if ($side == bottom) {\n    box-shadow: inset 0 (-1)*$helper $size (-1)*$helper $color;\n  }\n}\n\n/// Creates a CSS triangle, which can be used for dropdown arrows, dropdown pips, and more. Use this mixin inside a `&::before` or `&::after` selector, to attach the triangle to an existing element.\n///\n/// @param {Number} $triangle-size - Width of the triangle.\n/// @param {Color} $triangle-color - Color of the triangle.\n/// @param {Keyword} $triangle-direction - Direction the triangle points. Can be `up`, `right`, `down`, or `left`.\n@mixin css-triangle(\n  $triangle-size,\n  $triangle-color,\n  $triangle-direction\n) {\n  display: block;\n  width: 0;\n  height: 0;\n\n  border: inset $triangle-size;\n\n  content: '';\n\n  @if ($triangle-direction == down) {\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: $triangle-color transparent transparent;\n  }\n  @if ($triangle-direction == up) {\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == right) {\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == left) {\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent $triangle-color transparent transparent;\n  }\n}\n\n/// Creates a menu icon with a set width, height, number of bars, and colors. The mixin uses the height of the icon and the weight of the bars to determine spacing. <div class=\"docs-example-burger\"></div>\n///\n/// @param {Color} $color [$black] - Color to use for the icon.\n/// @param {Color} $color-hover [$dark-gray] - Color to use when the icon is hovered over.\n/// @param {Number} $width [20px] - Width of the icon.\n/// @param {Number} $height [16px] - Height of the icon.\n/// @param {Number} $weight [2px] - Height of individual bars in the icon.\n/// @param {Number} $bars [3] - Number of bars in the icon.\n@mixin hamburger(\n  $color: $black,\n  $color-hover: $dark-gray,\n  $width: 20px,\n  $height: 16px,\n  $weight: 2px,\n  $bars: 3\n) {\n  // box-shadow CSS output\n  $shadow: ();\n  $hover-shadow: ();\n\n  // Spacing between bars is calculated based on the total height of the icon and the weight of each bar\n  $spacing: ($height - ($weight * $bars)) / ($bars - 1);\n\n  @if unit($spacing) == 'px' {\n    $spacing: floor($spacing);\n  }\n\n  @for $i from 2 through $bars {\n    $offset: ($weight + $spacing) * ($i - 1);\n    $shadow: append($shadow, 0 $offset 0 $color, comma);\n  }\n\n  // Icon container\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: $width;\n  height: $height;\n  cursor: pointer;\n\n  // Icon bars\n  &::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n\n    display: block;\n    width: 100%;\n    height: $weight;\n\n    background: $color;\n    box-shadow: $shadow;\n\n    content: '';\n  }\n\n  // Hover state\n  @if $color-hover {\n    // Generate CSS\n    @for $i from 2 through $bars {\n      $offset: ($weight + $spacing) * ($i - 1);\n      $hover-shadow: append($hover-shadow, 0 $offset 0 $color-hover, comma);\n    }\n\n    &:hover::after {\n      background: $color-hover;\n      box-shadow: $hover-shadow;\n    }\n  }\n}\n\n/// Adds a downward-facing triangle as a background image to an element. The image is formatted as an SVG, making it easy to change the color. Because Internet Explorer doesn't support encoded SVGs as background images, a PNG fallback is also included.\n/// There are two PNG fallbacks: a black triangle and a white triangle. The one used depends on the lightness of the input color.\n///\n/// @param {Color} $color [$black] - Color to use for the triangle.\n@mixin background-triangle($color: $black) {\n  $rgb: 'rgb%28#{round(red($color))}, #{round(green($color))}, #{round(blue($color))}%29';\n\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: #{$rgb}'></polygon></svg>\");\n\n  @media screen and (min-width:0\\0) {\n    @if lightness($color) < 60% {\n      // White triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==');\n    }\n    @else {\n      // Black triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAMBJREFUeNrEllsOhCAMRVszC9IlzU7KCmVHTJsoMWYMUtpyv9BgbuXQB5ZSdgBYYY4ycgBivk8KYFsQMfMiTTBP4o3nUzCKzOabLJbLy2/g31evGkAginR4/ZegKH5qX3bJCscA3t0x3kgO5tQFyhhFf50xRqFLbyMUNJQzgyjGS/wgCpvKqkRBpuWrE4V9d+1E4dPUXqIg107SQOE/2DRQxMwTDygIInVDET9T3lCoj/6j/VCmGjZOl2lKpZ8AAwDQP7zIimDGFQAAAABJRU5ErkJggg==');\n    }\n  }\n}\n\n/// Applies the micro clearfix hack popularized by Nicolas Gallagher. Include this mixin on a container if its children are all floated, to give the container a proper height.\n/// The clearfix is augmented with specific styles to prevent borders in flexbox environments\n/// @link http://nicolasgallagher.com/micro-clearfix-hack/ Micro Clearfix Hack\n/// @link http://danisadesigner.com/blog/flexbox-clear-fix-pseudo-elements/ Flexbox fix\n@mixin clearfix {\n  &::before,\n  &::after {\n    display: table;\n    content: ' ';\n\n    @if $global-flexbox {\n      flex-basis: 0;\n      order: 1;\n    }\n  }\n\n  &::after {\n    clear: both;\n  }\n}\n\n/// Adds CSS for a \"quantity query\" selector that automatically sizes elements based on how many there are inside a container.\n/// @link http://alistapart.com/article/quantity-queries-for-css Quantity Queries for CSS\n///\n/// @param {Number} $max - Maximum number of items to detect. The higher this number is, the more CSS that's required to cover each number of items.\n/// @param {Keyword} $elem [li] - Tag to use for sibling selectors.\n@mixin auto-width($max, $elem: li) {\n  @for $i from 2 through $max {\n    &:nth-last-child(#{$i}):first-child,\n    &:nth-last-child(#{$i}):first-child ~ #{$elem} {\n      width: percentage(1 / $i);\n    }\n  }\n}\n\n/// Removes the focus ring around an element when a mouse input is detected.\n@mixin disable-mouse-outline {\n  [data-whatinput='mouse'] & {\n    outline: 0;\n  }\n}\n\n/// Makes an element visually hidden, but still accessible to keyboards and assistive devices.\n/// @link http://snook.ca/archives/html_and_css/hiding-content-for-accessibility Hiding Content for Accessibility\n/// @link http://hugogiraudel.com/2016/10/13/css-hide-and-seek/\n@mixin element-invisible {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0,0,0,0);\n  white-space: nowrap;\n  border: 0;\n}\n\n/// Reverses the CSS output created by the `element-invisible()` mixin.\n@mixin element-invisible-off {\n  position: static !important;\n  width: auto;\n  height: auto;\n  overflow: visible;\n  clip: auto;\n  white-space: normal;\n}\n\n/// Vertically centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin vertical-center {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Horizontally centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin horizontal-center {\n  position: absolute;\n  left: 50%;\n  transform: translateX(-50%);\n}\n\n/// Absolutely centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin absolute-center {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n}\n\n/// Iterates through breakpoints defined in `$breakpoint-classes` and prints the CSS inside the mixin at each breakpoint's media query. Use this with the grid, or any other component that has responsive classes.\n///\n/// @param {Boolean} $small [true] - If `false`, the mixin will skip the `small` breakpoint. Use this with components that don't prefix classes with `small-`, only `medium-` and up.\n/// @param {Boolean} $auto-insert-breakpoints [true] - If `false`, the mixin will iterate over breakpoints without doing the media query itself. Useful for more complex media query generation as in the margin grid.\n@mixin -zf-each-breakpoint($small: true, $auto-insert-breakpoints: true) {\n  $list: $breakpoint-classes;\n\n  @if not $small {\n    $list: sl-remove($list, $-zf-zero-breakpoint);\n  }\n\n  @each $name in $list {\n    $old-zf-size: null;\n    @if global-variable-exists(-zf-size) {\n      $old-zf-size: $-zf-size;\n    }\n    $-zf-size: $name !global;\n\n    @if $auto-insert-breakpoints {\n      @include breakpoint($name) {\n        @content;\n      }\n    }\n    @else {\n      @content;\n    }\n\n    $-zf-size: $old-zf-size !global;\n  }\n}\n\n/// Generate the `@content` passed to the mixin with a value `$-zf-bp-value` related to a breakpoint, depending on the `$name` parameter:\n/// - For a single value, `$-zf-bp-value` is this value.\n/// - For a breakpoint name, `$-zf-bp-value` is the corresponding breakpoint value in `$map`.\n/// - For \"auto\", `$-zf-bp-value` is the corresponding breakpoint value in `$map` and is passed to `@content`, which is made responsive for each breakpoint of `$map`.\n/// @param {Number|Array|Keyword} $name [auto] - Single value, breakpoint name, or list of breakpoint names to use. \"auto\" by default.\n/// @param {Number|Map} $map - Map of breakpoints and values or single value to use.\n@mixin -zf-breakpoint-value(\n  $name: auto,\n  $map: null\n) {\n  @if $name == auto and type-of($map) == 'map' {\n    // \"auto\"\n    @each $k, $v in $map {\n      @include breakpoint($k) {\n        @include -zf-breakpoint-value($v, $map) {\n          @content;\n        }\n      }\n    }\n  }\n  @else {\n    // breakpoint name\n    @if type-of($name) == 'string' {\n      $name: -zf-get-bp-val($map, $name);\n    }\n\n    // breakpoint value\n    $-zf-bp-value: $name !global;\n    @content;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Font color of text inputs.\n/// @type Color\n$input-color: $black !default;\n\n/// Font color of placeholder text within text inputs.\n/// @type Color\n$input-placeholder-color: $medium-gray !default;\n\n/// Font family of text inputs.\n/// @type Font\n$input-font-family: inherit !default;\n\n/// Font size of text inputs.\n/// @type Number\n$input-font-size: rem-calc(16) !default;\n\n/// Font weight of text inputs.\n/// @type Keyword\n$input-font-weight: $global-weight-normal !default;\n\n/// Line height of text inputs.\n/// @type Keyword\n$input-line-height: $global-lineheight !default;\n\n/// Background color of text inputs.\n/// @type Color\n$input-background: $white !default;\n\n/// Background color of focused of text inputs.\n/// @type Color\n$input-background-focus: $white !default;\n\n/// Background color of disabled text inputs.\n/// @type Color\n$input-background-disabled: $light-gray !default;\n\n/// Border around text inputs.\n/// @type Border\n$input-border: 1px solid $medium-gray !default;\n\n/// Border around focused text inputs.\n/// @type Color\n$input-border-focus: 1px solid $dark-gray !default;\n\n/// Padding of text inputs.\n/// @type Color\n$input-padding: $form-spacing / 2 !default;\n\n/// Box shadow inside text inputs when not focused.\n/// @type Shadow\n$input-shadow: inset 0 1px 2px rgba($black, 0.1) !default;\n\n/// Box shadow outside text inputs when focused.\n/// @type Shadow\n$input-shadow-focus: 0 0 5px $medium-gray !default;\n\n/// Cursor to use when hovering over a disabled text input.\n/// @type Cursor\n$input-cursor-disabled: not-allowed !default;\n\n/// Properties to transition on text inputs.\n/// @type Transition\n$input-transition: box-shadow 0.5s, border-color 0.25s ease-in-out !default;\n\n/// Enables the up/down buttons that Chrome and Firefox add to `<input type='number'>` elements.\n/// @type Boolean\n$input-number-spinners: true !default;\n\n/// Radius for text inputs.\n/// @type Border\n$input-radius: $global-radius !default;\n\n/// Border radius for form buttons, defaulted to global-radius.\n/// @type Number\n$form-button-radius: $global-radius !default;\n\n@mixin form-element {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  border: $input-border;\n  border-radius: $input-radius;\n  background-color: $input-background;\n  box-shadow: $input-shadow;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n}\n\n@mixin foundation-form-text {\n  // Text inputs\n  #{text-inputs()},\n  textarea {\n    @include form-element;\n    appearance: none;\n  }\n\n  // Text areas\n  textarea {\n    max-width: 100%;\n\n    &[rows] {\n      height: auto;\n    }\n  }\n\n  input,\n  textarea {\n    // Disabled/readonly state\n    &:disabled,\n    &[readonly] {\n      background-color: $input-background-disabled;\n      cursor: $input-cursor-disabled;\n    }\n  }\n\n  // Reset styles on button-like inputs\n  [type='submit'],\n  [type='button'] {\n    appearance: none;\n    border-radius: $form-button-radius;\n  }\n\n  // Reset Normalize setting content-box to search elements\n  input[type='search'] { // sass-lint:disable-line no-qualifying-elements\n    box-sizing: border-box;\n  }\n\n  // Number input styles\n  [type='number'] {\n    @if not $input-number-spinners {\n      -moz-appearance: textfield; // sass-lint:disable-line no-vendor-prefixes\n\n      &::-webkit-inner-spin-button,\n      &::-webkit-outer-spin-button {\n        -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n        margin: 0;\n      }\n    }\n  }\n\n  // Placeholder text\n  ::placeholder {\n    color: $input-placeholder-color;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n@mixin foundation-form-checkbox {\n  [type='file'],\n  [type='checkbox'],\n  [type='radio'] {\n    margin: 0 0 $form-spacing;\n  }\n\n  // Styles for input/label siblings\n  [type='checkbox'] + label,\n  [type='radio'] + label {\n    display: inline-block;\n    vertical-align: baseline;\n\n    margin-#{$global-left}: $form-spacing * 0.5;\n    margin-#{$global-right}: $form-spacing;\n    margin-bottom: 0;\n\n    &[for] {\n      cursor: pointer;\n    }\n  }\n\n  // Styles for inputs inside labels\n  label > [type='checkbox'],\n  label > [type='radio'] {\n    margin-#{$global-right}: $form-spacing * 0.5;\n  }\n\n  // Normalize file input width\n  [type='file'] {\n    width: 100%;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color for form labels.\n/// @type Color\n$form-label-color: $black !default;\n\n/// Font size for form labels.\n/// @type Number\n$form-label-font-size: rem-calc(14) !default;\n\n/// Font weight for form labels.\n/// @type Keyword\n$form-label-font-weight: $global-weight-normal !default;\n\n/// Line height for form labels. The higher the number, the more space between the label and its input field.\n/// @type Number\n$form-label-line-height: 1.8 !default;\n\n@mixin form-label {\n  display: block;\n  margin: 0;\n\n  font-size: $form-label-font-size;\n  font-weight: $form-label-font-weight;\n  line-height: $form-label-line-height;\n  color: $form-label-color;\n}\n\n@mixin form-label-middle {\n  $input-border-width: get-border-value($input-border, width);\n\n  margin: 0 0 $form-spacing;\n  padding: ($form-spacing / 2 + rem-calc($input-border-width)) 0;\n}\n\n@mixin foundation-form-label {\n  label {\n    @include form-label;\n\n    &.middle {\n      @include form-label-middle;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default color for help text.\n/// @type Color\n$helptext-color: $black !default;\n\n/// Default font size for help text.\n/// @type Number\n$helptext-font-size: rem-calc(13) !default;\n\n/// Default font style for help text.\n/// @type Keyword\n$helptext-font-style: italic !default;\n\n@mixin foundation-form-helptext {\n  .help-text {\n    $margin-top: ($form-spacing * 0.5) * -1;\n\n    margin-top: $margin-top;\n    font-size: $helptext-font-size;\n    font-style: $helptext-font-style;\n    color: $helptext-color;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color of labels prefixed to an input.\n/// @type Color\n$input-prefix-color: $black !default;\n\n/// Background color of labels prefixed to an input.\n/// @type Color\n$input-prefix-background: $light-gray !default;\n\n/// Border around labels prefixed to an input.\n/// @type Border\n$input-prefix-border: 1px solid $medium-gray !default;\n\n/// Left/right padding of an pre/postfixed input label\n$input-prefix-padding: 1rem !default;\n\n@mixin foundation-form-prepostfix {\n  $height: ($input-font-size * $input-line-height) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  .input-group {\n    display: if($global-flexbox, flex, table);\n    width: 100%;\n    margin-bottom: $form-spacing;\n\n    @if $global-flexbox {\n      align-items: stretch;\n    }\n\n    > :first-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, 0 $input-radius $input-radius 0, $input-radius 0 0 $input-radius);\n      }\n    }\n\n    > :last-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, $input-radius 0 0 $input-radius, 0 $input-radius $input-radius 0);\n      }\n    }\n  }\n\n  %input-group-child {\n    margin: 0;\n    white-space: nowrap;\n\n    @if not $global-flexbox {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n\n  .input-group-label {\n    @extend %input-group-child;\n    padding: 0 $input-prefix-padding;\n    border: $input-prefix-border;\n    background: $input-prefix-background;\n\n    color: $input-prefix-color;\n    text-align: center;\n    white-space: nowrap;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n      align-items: center;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    @if has-value($input-prefix-border) {\n      &:first-child {\n        border-#{$global-right}: 0;\n      }\n\n      &:last-child {\n        border-#{$global-left}: 0;\n      }\n    }\n  }\n\n  .input-group-field {\n    @extend %input-group-child;\n    border-radius: 0;\n\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n      min-width: 0;\n    }\n  }\n\n  .input-group-button {\n    @extend %input-group-child;\n    padding-top: 0;\n    padding-bottom: 0;\n    text-align: center;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    a,\n    input,\n    button,\n    label {\n      @extend %input-group-child;\n\n      @if $global-flexbox {\n        align-self: stretch;\n        height: auto;\n      }\n      @else {\n        height: $height;\n      }\n      padding-top: 0;\n      padding-bottom: 0;\n      font-size: $input-font-size;\n    }\n  }\n\n  // Specificity bump needed to prevent override by buttons\n  @if not $global-flexbox {\n    .input-group {\n      .input-group-button {\n        display: table-cell;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default border around custom fieldsets.\n/// @type Border\n$fieldset-border: 1px solid $medium-gray !default;\n\n/// Default padding inside custom fieldsets.\n/// @type Number\n$fieldset-padding: rem-calc(20) !default;\n\n/// Default margin around custom fieldsets.\n/// @type Number\n$fieldset-margin: rem-calc(18 0) !default;\n\n/// Default padding between the legend text and fieldset border.\n/// @type Number\n$legend-padding: rem-calc(0 3) !default;\n\n@mixin fieldset {\n  margin: $fieldset-margin;\n  padding: $fieldset-padding;\n  border: $fieldset-border;\n\n  legend {\n    // Covers up the fieldset's border to create artificial padding\n    margin: 0;\n    margin-#{$global-left}: rem-calc(-3);\n    padding: $legend-padding;\n  }\n}\n\n@mixin foundation-form-fieldset {\n  fieldset {\n    margin: 0;\n    padding: 0;\n    border: 0;\n  }\n\n  legend {\n    max-width: 100%;\n    margin-bottom: $form-spacing * 0.5;\n  }\n\n  .fieldset {\n    @include fieldset;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Background color for select menus.\n/// @type Color\n$select-background: $white !default;\n\n/// Color of the dropdown triangle inside select menus. Set to `transparent` to remove it entirely.\n/// @type Color\n$select-triangle-color: $dark-gray !default;\n\n/// Default radius for select menus.\n/// @type Color\n$select-radius: $global-radius !default;\n\n@mixin form-select {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  appearance: none;\n  border: $input-border;\n  border-radius: $select-radius;\n  background-color: $select-background;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if $select-triangle-color != transparent {\n    @include background-triangle($select-triangle-color);\n    background-origin: content-box;\n    background-position: $global-right (-$form-spacing) center;\n    background-repeat: no-repeat;\n    background-size: 9px 6px;\n\n    padding-#{$global-right}: ($form-spacing * 1.5);\n  }\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n\n  // Disabled state\n  &:disabled {\n    background-color: $input-background-disabled;\n    cursor: $input-cursor-disabled;\n  }\n\n  // Hide the dropdown arrow shown in newer IE versions\n  &::-ms-expand {\n    display: none;\n  }\n\n  &[multiple] {\n    height: auto;\n    background-image: none;\n  }\n}\n\n@mixin foundation-form-select {\n  select {\n    @include form-select;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group abide\n////\n\n/// Sets if error styles should be added to inputs.\n/// @type Boolean\n$abide-inputs: true !default;\n\n/// Sets if error styles should be added to labels.\n/// @type Boolean\n$abide-labels: true !default;\n\n/// Background color to use for invalid text inputs.\n/// @type Color\n$input-background-invalid: get-color(alert) !default;\n\n/// Color to use for labels of invalid inputs.\n/// @type Color\n$form-label-color-invalid: get-color(alert) !default;\n\n/// Default font color for form error text.\n/// @type Color\n$input-error-color: get-color(alert) !default;\n\n/// Default font size for form error text.\n/// @type Number\n$input-error-font-size: rem-calc(12) !default;\n\n/// Default font weight for form error text.\n/// @type Keyword\n$input-error-font-weight: $global-weight-bold !default;\n\n/// Styles the background and border of an input field to have an error state.\n///\n/// @param {Color} $background [$alert-color] - Color to use for the background and border.\n/// @param {Number} $background-lighten [10%] - Lightness level of the background color.\n@mixin form-input-error(\n  $background: $input-background-invalid,\n  $background-lighten: 10%\n) {\n  &:not(:focus) {\n    border-color: $background;\n    background-color: mix($background, $white, $background-lighten);\n\n    &::placeholder {\n      color: $background;\n    }\n  }\n}\n\n/// Adds error styles to a form element, using the values in the settings file.\n@mixin form-error {\n  display: none;\n  margin-top: $form-spacing * -0.5;\n  margin-bottom: $form-spacing;\n\n  font-size: $input-error-font-size;\n  font-weight: $input-error-font-weight;\n  color: $input-error-color;\n}\n\n@mixin foundation-form-error {\n  @if $abide-inputs {\n    // Error class for invalid inputs\n    .is-invalid-input {\n      @include form-input-error;\n    }\n  }\n\n  @if $abide-labels {\n    // Error class for labels of invalid outputs\n    .is-invalid-label {\n      color: $form-label-color-invalid;\n    }\n  }\n\n  // Form error element\n  .form-error {\n    @include form-error;\n\n    &.is-visible {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group typography-base\n////\n\n// Base Typography\n// - - - - - - - - - - - - - - -\n// These are styles applied to basic HTML tags, including:\n//   - Paragraphs <p>\n//   - Bold/italics <b> <strong> <i> <em>\n//   - Small text <small>\n//   - Headings <h1>-<h6>\n//   - Anchors <a>\n//   - Dividers <hr>\n//   - Lists <ul> <ol> <dl>\n//   - Blockquotes <blockquote>\n//   - Code blocks <code>\n//   - Abbreviations <abbr>\n//   - Citations <cite>\n//   - Keystrokes <kbd>\n\n/// Font family for header elements.\n/// @type String | List\n$header-font-family: $body-font-family !default;\n\n/// Font weight of headers.\n/// @type String\n$header-font-weight: $global-weight-normal !default;\n\n/// Font style (e.g. italicized) of headers.\n/// @type String\n$header-font-style: normal !default;\n\n/// Font stack used for elements that use monospaced type, such as code samples\n/// @type String | List\n$font-family-monospace: Consolas, 'Liberation Mono', Courier, monospace !default;\n\n/// Color of headers.\n/// @type Color\n$header-color: inherit !default;\n\n/// Line height of headers.\n/// @type Number\n$header-lineheight: 1.4 !default;\n\n/// Bottom margin of headers.\n/// @type Number\n$header-margin-bottom: 0.5rem !default;\n\n/// Styles for headings at various screen sizes. Each key is a breakpoint, and each value is a map of heading styles.\n/// @type Map\n$header-styles: (\n  small: (\n    'h1': ('font-size': 24),\n    'h2': ('font-size': 20),\n    'h3': ('font-size': 19),\n    'h4': ('font-size': 18),\n    'h5': ('font-size': 17),\n    'h6': ('font-size': 16),\n  ),\n  medium: (\n    'h1': ('font-size': 48),\n    'h2': ('font-size': 40),\n    'h3': ('font-size': 31),\n    'h4': ('font-size': 25),\n    'h5': ('font-size': 20),\n    'h6': ('font-size': 16),\n  ),\n) !default;\n\n// $header-styles map is built from $header-sizes in order to ensure downward compatibility\n// when $header-sizes is depreciated, $header-styles needs to get !default values like settings.scss\n@function build_from_header-sizes($header-sizes) {\n  @warn 'Note, that $header-sizes has been replaced with $header-styles. $header-sizes still works, but it is going to be depreciated.';\n  $header-styles: ();\n  @each $size, $headers in $header-sizes {\n    $header-map: ();\n    @each $header, $font-size in $headers {\n      $header-map: map-merge($header-map, ($header: ('font-size': $font-size)));\n    }\n    $header-styles: map-merge($header-styles, ($size: $header-map));\n  }\n  @return $header-styles;\n}\n\n// If it exists $headers-sizes is used to build $header-styles. See the documentation.\n@if variable-exists(header-sizes) {\n  $header-styles: build_from_header-sizes($header-sizes);\n}\n\n/// Text rendering method of headers.\n/// @type String\n$header-text-rendering: optimizeLegibility !default;\n\n/// Font size of `<small>` elements.\n/// @type Number\n$small-font-size: 80% !default;\n\n/// Color of `<small>` elements when placed inside headers.\n/// @type Color\n$header-small-font-color: $medium-gray !default;\n\n/// Line height of text inside `<p>` elements.\n/// @type Number\n$paragraph-lineheight: 1.6 !default;\n\n/// Bottom margin of paragraphs.\n/// @type Number\n$paragraph-margin-bottom: 1rem !default;\n\n/// Text rendering method for paragraph text.\n/// @type String\n$paragraph-text-rendering: optimizeLegibility !default;\n\n/// Text color of code samples.\n/// @type Color\n$code-color: $black !default;\n\n/// Font family of code samples.\n/// @type String | List\n$code-font-family: $font-family-monospace !default;\n\n/// Font weight of text in code samples.\n/// @type String\n$code-font-weight: $global-weight-normal !default;\n\n/// Background color of code samples.\n/// @type Color\n$code-background: $light-gray !default;\n\n/// Border around code samples.\n/// @type List\n$code-border: 1px solid $medium-gray !default;\n\n/// Padding around text of code samples.\n/// @type Number | List\n$code-padding: rem-calc(2 5 1) !default;\n\n/// Default color for links.\n/// @type Color\n$anchor-color: $primary-color !default;\n\n/// Default color for links on hover.\n/// @type Color\n$anchor-color-hover: scale-color($anchor-color, $lightness: -14%) !default;\n\n/// Default text decoration for links.\n/// @type String\n$anchor-text-decoration: none !default;\n\n/// Default text decoration for links on hover.\n/// @type String\n$anchor-text-decoration-hover: none !default;\n\n/// Maximum width of a divider.\n/// @type Number\n$hr-width: $global-width !default;\n\n/// Default border for a divider.\n/// @type List\n$hr-border: 1px solid $medium-gray !default;\n\n/// Default margin for a divider.\n/// @type Number | List\n$hr-margin: rem-calc(20) auto !default;\n\n/// Line height for items in a list.\n/// @type Number\n$list-lineheight: $paragraph-lineheight !default;\n\n/// Bottom margin for items in a list.\n/// @type Number\n$list-margin-bottom: $paragraph-margin-bottom !default;\n\n/// Bullet type to use for unordered lists (e.g., `square`, `circle`, `disc`).\n/// @type String\n$list-style-type: disc !default;\n\n/// Positioning for bullets on unordered list items.\n/// @type String\n$list-style-position: outside !default;\n\n/// Left (or right) margin for lists.\n/// @type Number\n$list-side-margin: 1.25rem !default;\n\n/// Left (or right) margin for a list inside a list.\n/// @type Number\n$list-nested-side-margin: 1.25rem !default;\n\n/// Bottom margin for `<dl>` elements.\n/// @type Number\n$defnlist-margin-bottom: 1rem !default;\n\n/// Font weight for `<dt>` elements.\n/// @type String\n$defnlist-term-weight: $global-weight-bold !default;\n\n/// Spacing between `<dt>` and `<dd>` elements.\n/// @type Number\n$defnlist-term-margin-bottom: 0.3rem !default;\n\n/// Text color of `<blockquote>` elements.\n/// @type Color\n$blockquote-color: $dark-gray !default;\n\n/// Padding inside a `<blockquote>` element.\n/// @type Number | List\n$blockquote-padding: rem-calc(9 20 0 19) !default;\n\n/// Side border for `<blockquote>` elements.\n/// @type List\n$blockquote-border: 1px solid $medium-gray !default;\n\n/// Font size for `<cite>` elements.\n/// @type Number\n$cite-font-size: rem-calc(13) !default;\n\n/// Text color for `<cite>` elements.\n/// @type Color\n$cite-color: $dark-gray !default;\n\n/// Pseudo content for `<cite>` elements.\n/// @type String\n$cite-pseudo-content: '\\2014 \\0020' !default;\n\n/// Font family for `<kbd>` elements.\n/// @type String | List\n$keystroke-font: $font-family-monospace !default;\n\n/// Text color for `<kbd>` elements.\n/// @type Color\n$keystroke-color: $black !default;\n\n/// Background color for `<kbd>` elements.\n/// @type Color\n$keystroke-background: $light-gray !default;\n\n/// Padding for `<kbd>` elements.\n/// @type Number | List\n$keystroke-padding: rem-calc(2 4 0) !default;\n\n/// Border radius for `<kbd>` elements.\n/// @type Number | List\n$keystroke-radius: $global-radius !default;\n\n/// Bottom border style for `<abbr>` elements.\n/// @type List\n$abbr-underline: 1px dotted $black !default;\n\n@mixin foundation-typography-base {\n  // Typography resets\n  div,\n  dl,\n  dt,\n  dd,\n  ul,\n  ol,\n  li,\n  h1,\n  h2,\n  h3,\n  h4,\n  h5,\n  h6,\n  pre,\n  form,\n  p,\n  blockquote,\n  th,\n  td {\n    margin: 0;\n    padding: 0;\n  }\n\n  // Paragraphs\n  p {\n    margin-bottom: $paragraph-margin-bottom;\n\n    font-size: inherit;\n    line-height: $paragraph-lineheight;\n    text-rendering: $paragraph-text-rendering;\n  }\n\n  // Emphasized text\n  em,\n  i {\n    font-style: italic;\n    line-height: inherit;\n  }\n\n  // Strong text\n  strong,\n  b {\n    font-weight: $global-weight-bold;\n    line-height: inherit;\n  }\n\n  // Small text\n  small {\n    font-size: $small-font-size;\n    line-height: inherit;\n  }\n\n  // Headings\n  h1, .h1,\n  h2, .h2,\n  h3, .h3,\n  h4, .h4,\n  h5, .h5,\n  h6, .h6 {\n    font-family: $header-font-family;\n    font-style: $header-font-style;\n    font-weight: $header-font-weight;\n    color: $header-color;\n    text-rendering: $header-text-rendering;\n\n    small {\n      line-height: 0;\n      color: $header-small-font-color;\n    }\n  }\n\n  // Heading styles\n  @each $size, $headers in $header-styles {\n    @include breakpoint($size) {\n      @each $header, $header-defs in $headers {\n        $font-size-temp: 1rem;\n        #{$header}, .#{$header} {\n\n          @if map-has-key($header-defs, font-size) {\n            $font-size-temp: rem-calc(map-get($header-defs, font-size));\n            font-size: $font-size-temp;\n          } @else if map-has-key($header-defs, fs) {\n            $font-size-temp: rem-calc(map-get($header-defs, fs));\n            font-size: $font-size-temp;\n          } @else if $size == $-zf-zero-breakpoint {\n            font-size: $font-size-temp;\n          }\n          @if map-has-key($header-defs, line-height) {\n            line-height: unitless-calc(map-get($header-defs, line-height), $font-size-temp);\n          } @else if map-has-key($header-defs, lh) {\n            line-height: unitless-calc(map-get($header-defs, lh), $font-size-temp);\n          } @else if $size == $-zf-zero-breakpoint {\n            line-height: unitless-calc($header-lineheight, $font-size-temp);\n          }\n\n          @if map-has-key($header-defs, margin-top) {\n            margin-top: rem-calc(map-get($header-defs, margin-top));\n          } @else if map-has-key($header-defs, mt) {\n            margin-top: rem-calc(map-get($header-defs, mt));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-top: 0;\n          }\n          @if map-has-key($header-defs, margin-bottom) {\n            margin-bottom: rem-calc(map-get($header-defs, margin-bottom));\n          } @else if map-has-key($header-defs, mb) {\n            margin-bottom: rem-calc(map-get($header-defs, mb));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-bottom: rem-calc($header-margin-bottom);\n          }\n        }\n      }\n    }\n  }\n\n  // Links\n  a {\n    line-height: inherit;\n    color: $anchor-color;\n    text-decoration: $anchor-text-decoration;\n\n    cursor: pointer;\n\n    &:hover,\n    &:focus {\n      color: $anchor-color-hover;\n      @if $anchor-text-decoration-hover != $anchor-text-decoration {\n        text-decoration: $anchor-text-decoration-hover;\n      }\n    }\n\n    img {\n      border: 0;\n    }\n  }\n\n  // Horizontal rule\n  hr {\n    clear: both;\n\n    max-width: $hr-width;\n    height: 0;\n    margin: $hr-margin;\n\n    border-top: 0;\n    border-right: 0;\n    border-bottom: $hr-border;\n    border-left: 0;\n  }\n\n  // Lists\n  ul,\n  ol,\n  dl {\n    margin-bottom: $list-margin-bottom;\n    list-style-position: $list-style-position;\n    line-height: $list-lineheight;\n  }\n\n  // List items\n  li {\n    font-size: inherit;\n  }\n\n  // Unordered lists\n  ul {\n    margin-#{$global-left}: $list-side-margin;\n    list-style-type: $list-style-type;\n  }\n\n  // Ordered lists\n  ol {\n    margin-#{$global-left}: $list-side-margin;\n  }\n\n  // Nested unordered/ordered lists\n  ul, ol {\n    & & {\n      margin-#{$global-left}: $list-nested-side-margin;\n      margin-bottom: 0;\n    }\n  }\n\n  // Definition lists\n  dl {\n    margin-bottom: $defnlist-margin-bottom;\n\n    dt {\n      margin-bottom: $defnlist-term-margin-bottom;\n      font-weight: $defnlist-term-weight;\n    }\n  }\n\n  // Blockquotes\n  blockquote {\n    margin: 0 0 $paragraph-margin-bottom;\n    padding: $blockquote-padding;\n    border-#{$global-left}: $blockquote-border;\n\n    &, p {\n      line-height: $paragraph-lineheight;\n      color: $blockquote-color;\n    }\n  }\n\n  // Citations\n  cite {\n    display: block;\n    font-size: $cite-font-size;\n    color: $cite-color;\n\n    &:before {\n      content: $cite-pseudo-content;\n    }\n  }\n\n  // Abbreviations\n  abbr, abbr[title] {\n    border-bottom: $abbr-underline;\n    cursor: help;\n    text-decoration: none;\n  }\n\n  // Figures\n  figure {\n    margin: 0;\n  }\n\n  // Code\n  code {\n    padding: $code-padding;\n\n    border: $code-border;\n    background-color: $code-background;\n\n    font-family: $code-font-family;\n    font-weight: $code-font-weight;\n    color: $code-color;\n  }\n\n  // Keystrokes\n  kbd {\n    margin: 0;\n    padding: $keystroke-padding;\n\n    background-color: $keystroke-background;\n\n    font-family: $keystroke-font;\n    color: $keystroke-color;\n\n    @if has-value($keystroke-radius) {\n      border-radius: $keystroke-radius;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group typography-helpers\n////\n\n/// Default font size for lead paragraphs.\n/// @type Number\n$lead-font-size: $global-font-size * 1.25 !default;\n\n/// Default line height for lead paragraphs.\n/// @type String\n$lead-lineheight: 1.6 !default;\n\n/// Default line height for subheaders.\n/// @type Number\n$subheader-lineheight: 1.4 !default;\n\n/// Default font color for subheaders.\n/// @type Color\n$subheader-color: $dark-gray !default;\n\n/// Default font weight for subheaders.\n/// @type String\n$subheader-font-weight: $global-weight-normal !default;\n\n/// Default top margin for subheaders.\n/// @type Number\n$subheader-margin-top: 0.2rem !default;\n\n/// Default bottom margin for subheaders.\n/// @type Number\n$subheader-margin-bottom: 0.5rem !default;\n\n/// Default font size for statistic numbers.\n/// @type Number\n$stat-font-size: 2.5rem !default;\n\n@mixin foundation-typography-helpers {\n  // Use to create a subheading under a main header\n  // Make sure you pair the two elements in a <header> element, like this:\n  // <header>\n  //   <h1>Heading</h1>\n  //   <h2>Subheading</h2>\n  // </header>\n  .subheader {\n    margin-top: $subheader-margin-top;\n    margin-bottom: $subheader-margin-bottom;\n\n    font-weight: $subheader-font-weight;\n    line-height: $subheader-lineheight;\n    color: $subheader-color;\n  }\n\n  // Use to style an introductory lead, deck, blurb, etc.\n  .lead {\n    font-size: $lead-font-size;\n    line-height: $lead-lineheight;\n  }\n\n  // Use to style a large number to display a statistic\n  .stat {\n    font-size: $stat-font-size;\n    line-height: 1;\n\n    p + & {\n      margin-top: -1rem;\n    }\n  }\n\n  ul, ol {\n    // Use to remove numbers from ordered list & bullets from unordered list\n    &.no-bullet {\n      margin-#{$global-left}: 0;\n      list-style: none;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@mixin foundation-text-alignment {\n  @each $size in $breakpoint-classes {\n    @include breakpoint($size) {\n      @each $align in (left, right, center, justify) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-text-#{$align} {\n            text-align: $align;\n          }\n        }\n        @else {\n          .text-#{$align} {\n            text-align: $align;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// If `true`, all elements will have transparent backgrounds when printed, to save on ink.\n/// @type Boolean\n/// @group global\n$print-transparent-backgrounds: true !default;\n\n/// If `true`, displays next to all links their \"href\" when printed.\n/// @type Boolean\n/// @group global\n$print-hrefs: true !default;\n\n// sass-lint:disable-all\n\n@mixin foundation-print-styles {\n  .show-for-print { display: none !important; }\n\n  @media print {\n    * {\n      @if $print-transparent-backgrounds {\n        background: transparent !important;\n      }\n\n      box-shadow: none !important;\n\n      color: black !important; // Black prints faster: h5bp.com/s\n      text-shadow: none !important;\n    }\n\n    .show-for-print { display: block !important; }\n    .hide-for-print { display: none !important; }\n\n    table.show-for-print { display: table !important; }\n    thead.show-for-print { display: table-header-group !important; }\n    tbody.show-for-print { display: table-row-group !important; }\n    tr.show-for-print { display: table-row !important; }\n    td.show-for-print { display: table-cell !important; }\n    th.show-for-print { display: table-cell !important; }\n\n    // Display the URL of a link after the text\n    a,\n    a:visited { text-decoration: underline;}\n    @if $print-hrefs {\n      a[href]:after { content: ' (' attr(href) ')'; }\n    }\n\n    // Don't display the URL for images or JavaScript/internal links\n    .ir a:after,\n    a[href^='javascript:']:after,\n    a[href^='#']:after { content: ''; }\n\n    // Display what an abbreviation stands for after the text\n    abbr[title]:after { content: ' (' attr(title) ')'; }\n\n    // Prevent page breaks in the middle of a blockquote or preformatted text block\n    pre,\n    blockquote {\n      border: 1px solid $dark-gray;\n      page-break-inside: avoid;\n    }\n\n    // h5bp.com/t\n    thead { display: table-header-group; }\n\n    tr,\n    img { page-break-inside: avoid; }\n\n    img { max-width: 100% !important; }\n\n    @page { margin: 0.5cm; }\n\n    p,\n    h2,\n    h3 {\n      orphans: 3;\n      widows: 3;\n    }\n\n    // Avoid page breaks after a heading\n    h2,\n    h3 { page-break-after: avoid; }\n\n    // Helper to re-allow page breaks in the middle of certain elements (e.g. pre, blockquote, tr)\n    .print-break-inside {\n      page-break-inside: auto;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n// Margin Grid classes\n@mixin xy-base-grid-classes {\n\n  // Grid Container\n  .grid-container {\n    @include xy-grid-container;\n\n    &.fluid {\n      @include xy-grid-container(100%);\n    }\n\n    &.full {\n      @include xy-grid-container(100%, 0);\n    }\n  }\n\n  // Base grid styles\n  .grid-x {\n    @include xy-grid;\n  }\n\n  .cell {\n    @include xy-cell-base();\n    @include xy-cell-static($grid-columns, false, $gutter-type: padding);\n\n    &.auto {\n      @include xy-cell-base(auto);\n    }\n\n    &.shrink {\n      @include xy-cell-base(shrink);\n    }\n\n  }\n  .grid-x {\n    > .auto {\n      @include xy-cell-static(auto, false);\n    }\n\n    > .shrink {\n      @include xy-cell-static(shrink, false);\n    }\n  }\n\n  // Auto width\n  @include -zf-each-breakpoint() {\n    // This is a bit of a hack/workaround, see these issues & PRs for the backstory:\n    // https://github.com/zurb/foundation-sites/issues/10244\n    // https://github.com/zurb/foundation-sites/pull/10222 and\n    // https://github.com/zurb/foundation-sites/pull/10164\n    .grid-x {\n      $str: \"> .#{$-zf-size}-shrink, > .#{$-zf-size}-full\";\n      @for $i from 1 through $grid-columns {\n        $str: $str + \", > .#{$-zf-size}-#{$i}\"\n      }\n      #{$str} {\n        flex-basis: auto;\n      }\n    }\n  }\n\n  @include -zf-each-breakpoint() {\n    // Responsive \"auto\" modifier\n    @if not($-zf-size == small) {\n      .grid-x > .#{$-zf-size}-auto {\n        @include xy-cell-base(auto);\n        @include xy-cell-static(auto, false);\n      }\n    }\n\n    %-xy-cell-base-shrink-horizontal-#{$-zf-size} {\n      @include xy-cell-base(shrink);\n    }\n\n    // Responsive \"shrink\" modifier\n    @if not($-zf-size == small) {\n      .grid-x > .#{$-zf-size}-shrink {\n        @extend %-xy-cell-base-shrink-horizontal-#{$-zf-size};\n        @include xy-cell-static(shrink, false);\n      }\n    }\n\n    // Responsive width modifiers\n    @for $i from 1 through $grid-columns {\n      // Sizing (percentage)\n      .grid-x > .#{$-zf-size}-#{$i} {\n        @extend %-xy-cell-base-shrink-horizontal-#{$-zf-size};\n        @include xy-cell-static($i, false, $gutter-type: padding);\n      }\n    }\n  }\n\n  // Reset width when using `.grid-margin-x` not on `.grid-x`\n  .grid-margin-x:not(.grid-x) > .cell {\n    width: auto;\n  }\n\n  // Reset height when using `.grid-margin-y` not on `.grid-y`\n  .grid-margin-y:not(.grid-y) > .cell {\n    height: auto;\n  }\n}\n\n@mixin -xy-breakpoint-cell-classes($class-breakpoint, $gutter-breakpoint, $vertical) {\n  $prefix: if($class-breakpoint == $-zf-zero-breakpoint, '', '#{$class-breakpoint}-');\n  > .#{$prefix}auto {\n    @include xy-cell-static(auto, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n  }\n\n  > .#{$prefix}shrink {\n    @include xy-cell-static(shrink, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n  }\n\n  @for $i from 1 through $grid-columns {\n    // Sizing (percentage)\n    $classname: if($vertical, '.#{$class-breakpoint}-#{$i}', '.#{$class-breakpoint}-#{$i}');\n\n    > #{$classname} {\n      @include xy-cell-static($i, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n    }\n  }\n}\n\n// Margin Grid classes\n@mixin xy-margin-grid-classes(\n  $gutter-position: left right,\n  $vertical: false,\n  $wrapping-selector: '.grid-margin-x'\n){\n  #{$wrapping-selector} {\n    @include xy-gutters($negative: true, $gutter-position: $gutter-position);\n\n    // Base cell styles\n    > .cell {\n      @include xy-cell-static($vertical: $vertical);\n    }\n\n    // base styles need to all be before the auto and shrink styles\n    @include -zf-each-breakpoint() {\n      @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size) and $-zf-size != $-zf-zero-breakpoint) {\n        > .cell {\n          @include xy-cell-static($breakpoint: $-zf-size, $vertical: $vertical);\n        }\n      }\n    }\n\n    @include -zf-each-breakpoint() {\n\n      // This is purely for responsive gutters - the margin grid has to go back and adjust widths (or heights)\n      // for all prior breakpoints.\n      // As their gutter is defined with their width/height, even breakpoint without a new margin must be\n      // generated to not having their width/height overrided by re-adjusted smaller breakpoints.\n      @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size)) {\n        @each $bp in -zf-breakpoints-less-than($-zf-size) {\n          @include -xy-breakpoint-cell-classes($bp, $-zf-size, $vertical);\n        }\n      }\n\n      @include -xy-breakpoint-cell-classes($-zf-size, $-zf-size, $vertical);\n    }\n  }\n}\n\n// Padding Grid classes\n@mixin xy-padding-grid-classes {\n  .grid-padding-x {\n\n    // Negative margin for nested grids\n    .grid-padding-x {\n      @include xy-gutters($negative: true);\n    }\n\n    // Negative margin for grids within `grid-container/grid-container.fluid`\n    // This allows margin and padding grids to line up with eachother\n    .grid-container:not(.full) > & {\n      @include xy-gutters($negative: true);\n    }\n\n    // Base cell styles\n    > .cell {\n      @include xy-gutters($gutters: $grid-padding-gutters, $gutter-type: padding);\n    }\n  }\n}\n\n// Block Grid classes\n@mixin xy-block-grid-classes($margin-grid: true, $padding-grid: true) {\n  @if $padding-grid {\n    @include -zf-each-breakpoint {\n      @for $i from 1 through $xy-block-grid-max {\n        .#{$-zf-size}-up-#{$i} {\n          @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: padding, $breakpoint: $-zf-size);\n        }\n      }\n    }\n  }\n\n  @if $margin-grid {\n    @include -zf-each-breakpoint {\n      @for $i from 1 through $xy-block-grid-max {\n        // This is purely for responsive gutters - the margin grid has to go back and adjust widths (or heights)\n        // for prior breakpoints based on the responsive gutter.\n        @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size)) {\n          @each $bp in -zf-breakpoints-less-than($-zf-size) {\n            @if(map-has-key($grid-margin-gutters, $bp)) {\n              .grid-margin-x.#{$bp}-up-#{$i} {\n                @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: margin, $breakpoint: $-zf-size);\n              }\n            }\n          }\n        }\n      }\n      @for $i from 1 through $xy-block-grid-max {\n        .grid-margin-x.#{$-zf-size}-up-#{$i} {\n          @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: margin, $breakpoint: $-zf-size);\n        }\n      }\n    }\n  }\n}\n\n// Collapse classes\n@mixin xy-collapse-grid-classes($margin-grid: true, $padding-grid: true) {\n  @each $bp in $breakpoint-classes {\n    @if $margin-grid {\n      .#{$bp}-margin-collapse {\n        @include xy-grid-collapse($gutter-type: margin, $min-breakpoint: $bp);\n      }\n    }\n\n    @if $padding-grid {\n      .#{$bp}-padding-collapse {\n        @include xy-grid-collapse($gutter-type: padding, $min-breakpoint: $bp);\n      }\n    }\n  }\n}\n\n// Offset classes\n@mixin xy-offset-cell-classes {\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $grid-columns {\n      // Offsets\n      $o: $i - 1;\n\n      .#{$-zf-size}-offset-#{$o} {\n        @include xy-cell-offset($o, $gutters: $grid-padding-gutters, $gutter-type: padding, $breakpoint: $-zf-size);\n      }\n\n      .grid-margin-x > .#{$-zf-size}-offset-#{$o} {\n        @include xy-cell-offset($o, $breakpoint: $-zf-size);\n      }\n    }\n  }\n}\n\n// Vertical Grid classes\n@mixin xy-vertical-grid-classes(\n  $margin-grid: true,\n  $padding-grid: true\n) {\n\n  @include -zf-each-breakpoint() {\n    @if not($-zf-size == small) {\n    }\n  }\n\n  .grid-y {\n    @include xy-grid(vertical, false);\n\n\n    > .cell {\n      @include xy-cell-reset();\n    }\n\n    > .auto {\n      @include xy-cell-static(auto, false, $vertical: true);\n    }\n\n    > .shrink {\n      @include xy-cell-static(shrink, false, $vertical: true);\n    }\n\n\n    @include -zf-each-breakpoint() {\n      // This is a bit of a hack/workaround, see these issues and PRs for the backstory:\n      // https://github.com/zurb/foundation-sites/issues/10244\n      // https://github.com/zurb/foundation-sites/pull/10222 and\n      // https://github.com/zurb/foundation-sites/pull/10164\n      $str: \"> .#{$-zf-size}-shrink, > .#{$-zf-size}-full\";\n      @for $i from 1 through $grid-columns {\n        $str: $str + \", > .#{$-zf-size}-#{$i}\"\n      }\n      #{$str} {\n        flex-basis: auto;\n      }\n    }\n\n    @include -zf-each-breakpoint() {\n      // Responsive \"auto\" modifier\n      @if not($-zf-size == small) {\n        > .#{$-zf-size}-auto {\n          @include xy-cell-base(auto);\n          @include xy-cell-static(auto, false, $breakpoint: $-zf-size, $vertical: true);\n        }\n      }\n\n      %-xy-cell-base-shrink-vertical-#{$-zf-size} {\n        @include xy-cell-base(shrink);\n      }\n\n      // Responsive \"shrink\" modifier\n      @if not($-zf-size == small) {\n        > .#{$-zf-size}-shrink {\n          @extend %-xy-cell-base-shrink-vertical-#{$-zf-size};\n          @include xy-cell-static(shrink, false, $breakpoint: $-zf-size, $vertical: true);\n        }\n      }\n\n      // Responsive width modifiers\n      @for $i from 1 through $grid-columns {\n        // Sizing (percentage)\n        > .#{$-zf-size}-#{$i} {\n          @extend %-xy-cell-base-shrink-vertical-#{$-zf-size};\n          @include xy-cell-static($i, false, $vertical: true, $gutter-type: padding);\n        }\n      }\n\n    }\n  }\n\n  @if $padding-grid {\n    .grid-padding-y {\n      // Negative margin for nested grids\n      .grid-padding-y {\n        @include xy-gutters($negative: true, $gutter-position: top bottom);\n      }\n\n      // Base cell styles\n      > .cell {\n        @include xy-gutters($gutters: $grid-padding-gutters, $gutter-type: padding, $gutter-position: top bottom);\n      }\n    }\n  }\n\n  @if $margin-grid {\n    @include xy-margin-grid-classes(top bottom, true, '.grid-margin-y');\n  }\n\n}\n\n@mixin xy-frame-grid-classes($vertical-grid: true, $margin-grid: true) {\n  // Framed grid styles\n  .grid-frame {\n    @include xy-grid-frame;\n  }\n\n  .cell .grid-frame {\n    width: 100%; // Same as include with $nested, but with less css\n  }\n\n  .cell-block {\n    @include xy-cell-block();\n  }\n\n  .cell-block-y {\n    @include xy-cell-block(true);\n  }\n\n\n  .cell-block-container {\n    @include xy-cell-block-container();\n  }\n\n\n  @include -zf-each-breakpoint(false) {\n\n    .#{$-zf-size}-grid-frame {\n      @include xy-grid-frame;\n    }\n\n    .cell .#{$-zf-size}-grid-frame {\n      width: 100%; // Same as include with $nested, but with less css\n    }\n\n    .#{$-zf-size}-cell-block {\n      @include xy-cell-block();\n    }\n\n    .#{$-zf-size}-cell-block-container {\n      @include xy-cell-block-container();\n    }\n\n    .#{$-zf-size}-cell-block-y {\n      @include xy-cell-block(true);\n    }\n  }\n\n  @if $vertical-grid {\n    .grid-y {\n      &.grid-frame {\n        width: auto;\n        @include xy-grid-frame(true);\n      }\n\n      @include -zf-each-breakpoint(false) {\n        &.#{$-zf-size}-grid-frame {\n          width: auto;\n          @include xy-grid-frame(true);\n        }\n\n      }\n    }\n    .cell {\n      .grid-y.grid-frame {\n        height: 100%; // Same as include with $nested, but with less css\n      }\n      @include -zf-each-breakpoint(false) {\n        .grid-y.#{$-zf-size}-grid-frame {\n          height: 100%; // Same as include with $nested, but with less css\n        }\n      }\n    }\n  }\n  @if $margin-grid {\n    @include xy-margin-grid-classes(top bottom, true, '.grid-margin-y');\n    .grid-frame.grid-margin-y {\n      @include xy-grid-frame(true, false, $grid-margin-gutters, $include-base: false);\n    }\n    @include -zf-each-breakpoint(false) {\n      .grid-margin-y.#{$-zf-size}-grid-frame {\n        @include xy-grid-frame(true, false, $grid-margin-gutters, $-zf-size, false);\n      }\n    }\n  }\n}\n\n// Final classes\n@mixin foundation-xy-grid-classes(\n  $base-grid: true,\n  $margin-grid: true,\n  $padding-grid: true,\n  $block-grid: true,\n  $collapse: true,\n  $offset: true,\n  $vertical-grid: true,\n  $frame-grid: true\n) {\n\n  // Base grid styles\n  @if($base-grid) {\n    @include xy-base-grid-classes();\n  }\n\n  // Margin grid\n  @if($margin-grid) {\n    @include xy-margin-grid-classes();\n  }\n\n  // Padding grid\n  @if($padding-grid) {\n    @include xy-padding-grid-classes();\n  }\n\n  // Block grid\n  @if($block-grid) {\n    @include xy-block-grid-classes($margin-grid, $padding-grid);\n  }\n\n  // Collapse gutters\n  @if($collapse) {\n    @include xy-collapse-grid-classes($margin-grid, $padding-grid);\n  }\n\n  // Offset gutters\n  @if($offset) {\n    @include xy-offset-cell-classes();\n  }\n\n  // Vertical grid\n  @if($vertical-grid) {\n    @include xy-vertical-grid-classes($margin-grid, $padding-grid);\n  }\n\n  @if ($frame-grid) {\n    @include xy-frame-grid-classes($vertical-grid, $margin-grid)\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Create gutters for a cell/container.\n///\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts either margin or padding.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {Boolean} $negative [false] - Whether to apply the gutter as a negative value. Commonly used for nested grids.\n@mixin xy-gutters(\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $negative: false\n) {\n  $operator: if($negative, '-', '');\n\n  // If we have declared negative gutters, force type to `margin.\n  $gutter-type: if($negative, 'margin', $gutter-type);\n\n  // Output our margin gutters.\n  @if (type-of($gutters) == 'map') {\n    @include -zf-breakpoint-value(auto, $gutters) {\n      $gutter: rem-calc($-zf-bp-value) / 2;\n\n      // Loop through each gutter position\n      @each $value in $gutter-position {\n        #{$gutter-type}-#{$value}: unquote(\"#{$operator}#{$gutter}\");\n      }\n    }\n  }\n  @else if (type-of($gutters) == 'number') {\n    $gutter: rem-calc($gutters) / 2;\n\n    // Loop through each gutter position\n    @each $value in $gutter-position {\n      #{$gutter-type}-#{$value}: unquote(\"#{$operator}#{$gutter}\");\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Creates a max width container, designed to house your grid content.\n///\n/// @param {Number} $width [$grid-container] - a width to limit the container to.\n/// @param {Number} $padding [$grid-container-padding] - paddings of the container.\n@mixin xy-grid-container(\n  $width: $grid-container,\n  $padding: $grid-container-padding\n) {\n  @include xy-gutters($gutters: $padding, $gutter-type: padding);\n\n  max-width: $width;\n  margin-left: auto;\n  margin-right: auto;\n}\n\n/// Creates a container for your flex cells.\n///\n/// @param {Keyword} $direction [horizontal] - Either horizontal or vertical direction of cells within.\n/// @param {Boolean} $wrap [true] - If the cells within should wrap or not.\n@mixin xy-grid(\n  $direction: horizontal,\n  $wrap: true\n) {\n  $direction: if($direction == 'horizontal', row, column);\n  $wrap: if($wrap, wrap, nowrap);\n\n  display: flex;\n  flex-flow: $direction $wrap;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Calculate the percentage size of a cell.\n///\n/// @param {Number|List} $size [$grid-columns] - Size to make the cell. You can pass a value in multiple formats, such as `6`, `50%`, `1 of 2` or `1/3`.\n@function xy-cell-size(\n  $size: $grid-columns\n) {\n  // Parsing percents, decimals, n of n and number counts\n  @if type-of($size) == 'number' {\n    @if unit($size) == '%' {\n      $size: $size;\n    }\n    @else if $size < 1 {\n      $size: percentage($size);\n    }\n    @else {\n      $size: percentage($size / $grid-columns);\n    }\n  }\n\n  // Parsing \"n of n\" or \"n/n\" expressions\n  @else if type-of($size) == 'list' {\n    @if length($size) != 3 {\n      @error 'Wrong syntax for xy-cell-size(). Use the format \"n of n\" or \"n/n\".';\n    }\n    @else {\n      $size: percentage(nth($size, 1) / nth($size, 3));\n    }\n  }\n  // Anything else is incorrect\n  @else {\n    @error 'Wrong syntax for xy-cell-size(). Use a number, decimal, percentage, or \"n of n\" / \"n/n\".';\n  }\n\n  @return $size;\n}\n\n/// Sets base flex properties for cells.\n///\n/// @param {Keyword} $size [full] - The size of your cell. Accepts `full`, `auto`, `shrink` or `grow`.\n@mixin xy-cell-base($size: full) {\n  @if($size == 'full') {\n    // This is the base style, all others inherit from it\n    flex: 0 0 auto;\n    min-height: 0px;\n    min-width: 0px;\n  }\n  @else if ($size == 'auto') {\n    flex: 1 1 0px; // sass-lint:disable-line zero-unit\n  }\n  @else if ($size == 'shrink') {\n    flex: 0 0 auto;\n  }\n  @else if ($size == 'grow') {\n    flex: 1 0 auto;\n  }\n}\n\n/// Resets a cells width (or height if vertical is true) as well as strips its gutters.\n///\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-reset($vertical: true) {\n  $direction: if($vertical == true, width, height);\n  #{$direction}: auto;\n  max-#{$direction}: none;\n}\n\n// Sets our cell widths or heights depending on gutter type.\n@mixin -xy-cell-properties($size, $margin-gutter, $vertical) {\n  $direction: if($vertical == true, height, width);\n  @if($size == 'full') {\n    $val: if($margin-gutter == 0, 100%, calc(100% - #{rem-calc($margin-gutter)}));\n    #{$direction}: $val;\n  }\n  @else if ($size == 'auto') {\n    #{$direction}: auto;\n    $val: if($margin-gutter == 0, 100%, calc(100% - #{rem-calc($margin-gutter)}));\n  }\n  @else if ($size == 'shrink') {\n    #{$direction}: auto;\n  }\n  @else {\n    $val: if($margin-gutter == 0, #{xy-cell-size($size)}, calc(#{xy-cell-size($size)} - #{rem-calc($margin-gutter)}));\n    #{$direction}: $val;\n  }\n}\n\n/// Creates a cell for your grid.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (default) for 100% width, `auto` to use up available space and `shrink` to use up only required space.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Map or single value for gutters.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell(\n  $size: full,\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $breakpoint: null,\n  $vertical: false\n) {\n  $bp-is-fallback: false;\n\n  @if($breakpoint == null) {\n    // If `$bp-size` is available then use this, otherwise revert to the smallest bp.\n    @if(variable-exists(-zf-size) and type-of($-zf-size) != 'number') and $-zf-size != null {\n      $breakpoint: $-zf-size;\n    }\n    @else {\n      $breakpoint: $-zf-zero-breakpoint;\n      $bp-is-fallback: true;\n    }\n  }\n\n  // Get the gutter for the given breakpoint/value.\n  $gutter: -zf-get-bp-val($gutters, $breakpoint);\n  // If the breakpoint is a fallback, use a fallback gutter as well\n  @if ($bp-is-fallback == true and $gutter == null) {\n    $gutter: 0;\n  }\n\n  @if($gutter != null) {\n    // Base flex properties\n    @include xy-cell-base($size);\n\n    @if($gutter-type == 'margin') {\n      @include -xy-cell-properties($size, $gutter, $vertical);\n    }\n    @else {\n      @include -xy-cell-properties($size, 0, $vertical);\n    }\n\n    @if $gutter-output {\n      @include xy-gutters($gutter, $gutter-type, $gutter-position);\n    }\n  }\n  @else {\n    @warn 'xy-cell: no gutters were found in `$gutters` for \"$breakpoint: #{$breakpoint}\", cell was not generated`'\n  }\n}\n\n/// Creates a single breakpoint sized grid. Used to generate our grid classes.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (default) for 100% width, `auto` to use up available space and `shrink` to use up only required space.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-static(\n  $size: full,\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $breakpoint: $-zf-zero-breakpoint,\n  $vertical: false\n) {\n\n  $gutter: -zf-get-bp-val($gutters, $breakpoint);\n  $gutter-position: if($vertical == true, top bottom, left right);\n\n  @if($gutter-type == 'margin') {\n    @include -xy-cell-properties($size, $gutter, $vertical);\n  }\n  @else {\n    @include -xy-cell-properties($size, 0, $vertical);\n  }\n\n  // If we want to output the gutters\n  @if($gutter-output) {\n    // TODO: Figure out if we need to pass breakpoint in here too.\n    @include xy-gutters($gutter, $gutter-type, $gutter-position);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Sizes child elements so that `$n` number of items appear on each row.\n///\n/// @param {Number} $n - Number of elements to display per row.\n/// @param {String} $selector ['.cell'] - Selector(s) to use for child elements.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts `margin` or `padding`.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {String} $breakpoint [null] - The breakpoint to use for the cell generation.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-grid-layout(\n  $n,\n  $selector: '.cell',\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $breakpoint: null,\n  $vertical: false\n) {\n  $size: percentage(1/$n);\n\n  & > #{$selector} {\n    @include xy-cell($size, $gutter-output, $gutters, $gutter-type, $gutter-position, $breakpoint, $vertical);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Collapses the grid a cells within it.\n///\n/// @param {String} $selector [.cell] - The child element to remove the gutter from.\n/// @param {Keyword} $gutter-type [margin] - The type of gutter to remove.\n/// @param {List} $gutter-position [right left] - The positions to remove gutters from. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {Keyword} $min-breakpoint [$-zf-zero-breakpoint] - Minimum breakpoint in `$breakpoint-classes` for which to collapse the gutter.\n@mixin xy-grid-collapse(\n  $selector: '.cell',\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $min-breakpoint: $-zf-zero-breakpoint\n) {\n  // First, lets negate any margins on the top level\n  @if ($gutter-type == 'margin') {\n\n    @include breakpoint($min-breakpoint) {\n      @each $value in $gutter-position {\n        margin-#{$value}: 0;\n      }\n\n      > #{$selector} {\n        @each $value in $gutter-position {\n          margin-#{$value}: 0;\n        }\n      }\n    }\n\n    $excluded-bps: -zf-breakpoints-less-than($min-breakpoint);\n\n    // Output new widths to not include gutters\n    @each $bp in $breakpoint-classes {\n      @if(sl-contain($excluded-bps, $bp)) {\n        @include breakpoint($min-breakpoint) {\n          @for $i from 1 through $grid-columns {\n            // Sizing (percentage)\n            > .#{$bp}-#{$i} {\n              @include xy-cell-static($i, $gutter-output: false, $gutter-type: padding);\n            }\n          }\n        }\n      } @else {\n        @include breakpoint($bp) {\n          @for $i from 1 through $grid-columns {\n            // Sizing (percentage)\n            > .#{$bp}-#{$i} {\n              @include xy-cell-static($i, $gutter-output: false, $gutter-type: padding);\n            }\n          }\n        }\n      }\n    }\n  }\n  @else {\n\n    @include breakpoint($min-breakpoint) {\n      @each $value in $gutter-position {\n        margin-#{$value}: 0;\n      }\n\n      > #{$selector} {\n        @each $value in $gutter-position {\n          padding-#{$value}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Offsets a column to the right/bottom by `$n` columns.\n///\n/// @param {Number|List} $n - Size to offset by. You can pass in any value accepted by the `zf-cell()` mixin, such as `6`, `50%`, or `1 of 2`.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] Map of gutters or single value to use for responsive gutters.\n/// @param {Keyword} $gutter-type [margin] The type of gutter to use. Can be `margin` or `padding`\n/// @param {Number|Array|Keyword} $breakpoint [$-zf-zero-breakpoint] - Single value, breakpoint name, or list of breakpoint names to use for `$gutters`. See `-zf-breakpoint-value()`.\n/// @param {Boolean} $vertical [false] Sets the direction of the offset. If set to true will apply margin-top instead.\n@mixin xy-cell-offset(\n $n,\n $gutters: $grid-margin-gutters,\n $gutter-type: margin,\n $breakpoint: $-zf-zero-breakpoint,\n $vertical: false\n) {\n  $direction: if($vertical, 'top', $global-left);\n\n  @include -zf-breakpoint-value($breakpoint, $gutters) {\n    $gutter: rem-calc($-zf-bp-value) / 2;\n    $gutter-margin: if($gutter-type == 'margin', $gutter, 0);\n    $size: if($gutter-margin == 0, #{xy-cell-size($n)}, calc(#{xy-cell-size($n)} + #{$gutter-margin}));\n\n    margin-#{$direction}: #{$size};\n  }\n}\n","/// Modifies a grid to give it \"frame\" behavior (no overflow, no wrap, stretch behavior)\n///\n/// @param {Boolean} $vertical [false] - Is grid vertical or horizontal. Should match grid.\n/// @param {Boolean} $nested [false] - Is grid nested or not. If nested is true this sets the frame to 100% height, otherwise will be 100vh.\n/// @param {Number|Map} $gutters [null] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from.\n/// @param {Boolean} $include-base [true] - Include the base styles that don't vary per breakpoint.\n@mixin xy-grid-frame(\n  $vertical: false,\n  $nested: false,\n  $gutters: null,\n  $breakpoint: null,\n  $include-base: true\n) {\n\n  @if $include-base {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n  }\n\n  @if $breakpoint == null and type-of($gutters) == 'map' {\n    @include -zf-each-breakpoint() {\n      @include xy-grid-frame($vertical, $nested, $gutters, $-zf-size, false);\n    }\n  } @else {\n    // Get our gutters if applicable\n    $gutter: -zf-get-bp-val($gutters, $breakpoint);\n\n    // If we have a gutter, add it to the width/height\n    @if $gutter {\n      @if $vertical == true {\n        $unit: if($nested == true, 100%, 100vh);\n        $gutter: rem-calc($gutter);\n        height: calc(#{$unit} + #{$gutter});\n      } @else {\n        $unit: if($nested == true, 100%, 100vw);\n        $gutter: rem-calc($gutter);\n        width: calc(#{$unit} + #{$gutter});\n      }\n    }\n    @else {\n      @if $vertical == true {\n        height: if($nested == true, 100%, 100vh);\n      } @else {\n        width: if($nested == true, 100%, 100vw);\n      }\n    }\n  }\n}\n\n/// Modifies a cell to give it \"block\" behavior (overflow auto, inertial scrolling)\n///\n/// @param {Boolean} $vertical [false] - Is grid vertical or horizontal. Should match grid.\n@mixin xy-cell-block(\n  $vertical: false\n) {\n  $property: if($vertical == true, 'overflow-y', 'overflow-x');\n\n  @if $vertical == true {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n  } @else {\n    overflow-x: auto;\n    max-width: 100%;\n  }\n\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar;\n}\n\n/// Container for inside a grid frame containing multiple blocks. Typically used\n/// as a modifier for a `.cell` to allow the cell to pass along flex sizing\n/// constraints / from parents to children.\n@mixin xy-cell-block-container() {\n  display: flex;\n  flex-direction: column;\n  max-height: 100%;\n\n  > .grid-x {\n    max-height: 100%;\n    flex-wrap: nowrap;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group button\n////\n\n/// Font family for button elements.\n/// @type Font\n$button-font-family: inherit !default;\n\n/// Padding inside buttons.\n/// @type List\n$button-padding: 0.85em 1em !default;\n\n/// Margin around buttons.\n/// @type List\n$button-margin: 0 0 $global-margin 0 !default;\n\n/// Default fill for buttons. Can either be `solid` or `hollow`.\n/// @type Keyword\n$button-fill: solid !default;\n\n/// Default background color for buttons.\n/// @type Color\n$button-background: $primary-color !default;\n\n/// Background color on hover for buttons.\n/// @type Color\n$button-background-hover: scale-color($button-background, $lightness: -15%) !default;\n\n/// Font color for buttons.\n/// @type List\n$button-color: $white !default;\n\n/// Alternative font color for buttons.\n/// @type List\n$button-color-alt: $black !default;\n\n/// Border radius for buttons, defaulted to global-radius.\n/// @type Number\n$button-radius: $global-radius !default;\n\n/// Border width for hollow outline buttons\n/// @type Number\n$button-hollow-border-width: 1px !default;\n\n/// Sizes for buttons.\n/// @type Map\n$button-sizes: (\n  tiny: 0.6rem,\n  small: 0.75rem,\n  default: 0.9rem,\n  large: 1.25rem,\n) !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$button-palette: $foundation-palette !default;\n\n/// opacity for a disabled button.\n/// @type List\n$button-opacity-disabled: 0.25 !default;\n\n/// Background color lightness on hover for buttons.\n/// @type Number\n$button-background-hover-lightness: -20% !default;\n\n/// Color lightness on hover for hollow buttons.\n/// @type Number\n$button-hollow-hover-lightness: -50% !default;\n\n// Internal: flip from margin-right to margin-left for defaults\n@if $global-text-direction == 'rtl' {\n  $button-margin: 0 0 $global-margin $global-margin !default;\n}\n\n/// transitions for buttons.\n/// @type List\n$button-transition: background-color 0.25s ease-out, color 0.25s ease-out !default;\n\n/// Additional responsive classes for .expanded\n/// @type Boolean\n$button-responsive-expanded: false !default;\n\n// TODO: Document button-base() mixin\n@mixin button-base {\n  @include disable-mouse-outline;\n  display: inline-block;\n  vertical-align: middle;\n  margin: $button-margin;\n\n  @if (type-of($button-padding) == 'map') {\n    @each $size, $padding in $button-padding {\n      @include breakpoint($size) {\n        padding: $padding;\n      }\n    }\n  }\n  @else {\n    padding: $button-padding;\n  }\n\n  border: 1px solid transparent;\n  border-radius: $button-radius;\n  transition: $button-transition;\n  font-family: $button-font-family;\n  font-size: map-get($button-sizes, default);\n  -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n}\n\n/// Expands a button to make it full-width.\n/// @param {Boolean} $expand [true] - Set to `true` to enable the expand behavior. Set to `false` to reverse this behavior.\n@mixin button-expand($expand: true) {\n  @if $expand {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0;\n  }\n  @else {\n    display: inline-block;\n    width: auto;\n    margin: $button-margin;\n  }\n}\n\n/// Sets the visual style of a button.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n@mixin button-style(\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $background-hover-lightness: $button-background-hover-lightness\n) {\n  @if $color == auto {\n    $color: color-pick-contrast($background, ($button-color, $button-color-alt));\n  }\n\n  @if $background-hover == auto {\n    $background-hover: scale-color($background, $lightness: $background-hover-lightness);\n  }\n\n  background-color: $background;\n  color: $color;\n\n  &:hover, &:focus {\n    background-color: $background-hover;\n    color: $color;\n  }\n}\n\n/// Removes background fill on hover and focus for hollow buttons.\n@mixin button-hollow {\n  &,\n  &:hover,\n  &:focus {\n    background-color: transparent;\n  }\n\n  &.disabled,\n  &[disabled] {\n    &,\n    &:hover, &:focus {\n      background-color: transparent;\n    }\n  }\n}\n\n@mixin button-hollow-style(\n  $color: $button-background,\n  $hover-lightness: $button-hollow-hover-lightness,\n  $border-width: $button-hollow-border-width\n) {\n  $color-hover: scale-color($color, $lightness: $hover-lightness);\n\n  border: $border-width solid $color;\n  color: $color;\n\n  &:hover, &:focus {\n    border-color: $color-hover;\n    color: $color-hover;\n    &.disabled,\n    &[disabled] {\n      border: $border-width solid $color;\n      color: $color;\n    }\n  }\n}\n\n/// Adds disabled styles to a button by fading the element, reseting the cursor, and disabling pointer events.\n/// @param {Color} $background [$button-background] - Background color of the disabled button.\n/// @param {Color} $color [$button-color] - Text color of the disabled button. Set to `auto` to have the mixin automatically generate a color based on the background color.\n@mixin button-disabled(\n  $background: $button-background,\n  $color: $button-color\n) {\n  @if $color == auto {\n    $color: color-pick-contrast($background, ($button-color, $button-color-alt));\n  }\n\n  opacity: $button-opacity-disabled;\n  cursor: not-allowed;\n\n  &, &:hover, &:focus {\n    background-color: $background;\n    color: $color;\n  }\n}\n\n/// Adds a dropdown arrow to a button.\n/// @param {Number} $size [0.4em] - Size of the arrow. We recommend using an `em` value so the triangle scales when used inside different sizes of buttons.\n/// @param {Color} $color [white] - Color of the arrow.\n/// @param {Number} $offset [$button-padding] - Distance between the arrow and the text of the button. Defaults to whatever the right padding of a button is.\n@mixin button-dropdown(\n  $size: 0.4em,\n  $color: $white,\n  $offset: get-side($button-padding, right)\n) {\n  &::after {\n    @include css-triangle($size, $color, down);\n    position: relative;\n    top: 0.4em; // Aligns the arrow with the text of the button\n\n    display: inline-block;\n    float: #{$global-right};\n    margin-#{$global-left}: $offset;\n  }\n}\n\n/// Adds all styles for a button. For more granular control over styles, use the individual button mixins.\n/// @param {Boolean} $expand [false] - Set to `true` to make the button full-width.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n/// @param {Keyword} $style [solid] - Set to `hollow` to create a hollow button. The color defined in `$background` will be used as the primary color of the button.\n@mixin button(\n  $expand: false,\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $style: $button-fill\n) {\n  @include button-base;\n\n  @if $style == solid {\n    @include button-style($background, $background-hover, $color);\n  }\n  @else if $style == hollow {\n    @include button-hollow;\n    @include button-hollow-style($background);\n  }\n\n  @if $expand {\n    @include button-expand;\n  }\n}\n\n@mixin foundation-button {\n  .button {\n    @include button;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} {\n        font-size: $value;\n      }\n    }\n\n    &.expanded { @include button-expand; }\n\n    @if $button-responsive-expanded {\n      @each $size in $breakpoint-classes {\n        @include breakpoint(#{$size} only) {\n          &.#{$size}-only-expanded {\n            @include button-expand;\n          }\n        }\n        @if $size != $-zf-zero-breakpoint {\n          @include breakpoint(#{$size} down) {\n            &.#{$size}-down-expanded {\n              @include button-expand;\n            }\n          }\n\n          @include breakpoint(#{$size}) {\n            &.#{$size}-expanded {\n              @include button-expand;\n            }\n          }\n        }\n      }\n    }\n\n    // Colors\n    @each $name, $color in $button-palette {\n      @if $button-fill != hollow {\n        &.#{$name} {\n          @include button-style($color, auto, auto);\n        }\n      }\n      @else {\n        &.#{$name} {\n          @include button-hollow-style($color);\n        }\n\n        &.#{$name}.dropdown::after {\n          border-top-color: $color;\n        }\n      }\n    }\n\n    // Disabled style\n    &.disabled,\n    &[disabled] {\n      @include button-disabled;\n\n      @each $name, $color in $button-palette {\n        &.#{$name} {\n          @include button-disabled($color, auto);\n        }\n      }\n    }\n\n    // Hollow style\n    @if $button-fill != hollow {\n      &.hollow {\n        @include button-hollow;\n        @include button-hollow-style;\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-hollow-style($color);\n          }\n        }\n      }\n    }\n\n    // Clear style\n    @if $button-fill != clear {\n      &.clear {\n        @include button-hollow;\n        @include button-hollow-style;\n\n        &, &:hover, &:focus {\n          &, &.disabled, &[disabled] {\n            border-color: transparent;\n          }\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-hollow-style($color);\n\n            &, &:hover,\n            &:focus {\n              &,\n              &.disabled,\n              &[disabled] {\n                border-color: transparent;\n              }\n            }\n          }\n        }\n      }\n    }\n\n    // Dropdown arrow\n    &.dropdown {\n      @include button-dropdown;\n\n      @if $button-fill == hollow {\n        &::after {\n          border-top-color: $button-background;\n        }\n      }\n\n      &.hollow, &.clear {\n        &::after {\n          border-top-color: $button-background;\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            &::after {\n              border-top-color: $color;\n            }\n          }\n        }\n      }\n    }\n\n    // Button with dropdown arrow only\n    &.arrow-only::after {\n      top: -0.1em;\n      float: none;\n      margin-#{$global-left}: 0;\n    }\n  }\n\n  a.button { // sass-lint:disable-line no-qualifying-elements\n    &:hover,\n    &:focus {\n      text-decoration: none;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group button-group\n////\n\n/// Margin for button groups.\n/// @type Number\n$buttongroup-margin: 1rem !default;\n\n/// Margin between buttons in a button group.\n/// @type Number\n$buttongroup-spacing: 1px !default;\n\n/// Selector for the buttons inside a button group.\n/// @type String\n$buttongroup-child-selector: '.button' !default;\n\n/// Maximum number of buttons that can be in an even-width button group. (Only needed when $global-flexbox: false;)\n/// @type Number\n$buttongroup-expand-max: 6 !default;\n\n/// Determines if $button-radius is applied to each button or the button group as a whole. Use $global-radius in _settings.scss to change radius.\n/// @type Boolean\n$buttongroup-radius-on-each: true !default;\n\n/// Add styles for a button group container.\n/// @param {String} $child-selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group(\n  $child-selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing\n) {\n  @include clearfix;\n  margin-bottom: $buttongroup-margin;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    align-items: stretch;\n  }\n  @else {\n    font-size: 0;\n  }\n\n  #{$child-selector} {\n    margin: 0;\n    margin-#{$global-right}: $spacing;\n    margin-bottom: $spacing;\n    font-size: map-get($button-sizes, default);\n\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n\n    &:last-child {\n      margin-#{$global-right}: 0;\n    }\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $button-radius;\n        border-bottom-#{$global-left}-radius: $button-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $button-radius;\n        border-bottom-#{$global-right}-radius: $button-radius;\n      }\n    }\n\n  }\n}\n\n/// Creates a full-width button group, making each button equal width.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group-expand(\n  $selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing,\n  $count: null\n) {\n  @if not $global-flexbox {\n    margin-#{$global-right}: -$spacing;\n\n    &::before,\n    &::after {\n      display: none;\n    }\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n    @else {\n      // One child\n      &:first-child {\n        &:last-child {\n          width: calc(100% - #{$spacing});\n        }\n      }\n\n      // Two or more childreen\n      @for $i from 2 through $buttongroup-expand-max {\n        &:first-child:nth-last-child(#{$i}) {\n          &, &:first-child:nth-last-child(#{$i}) ~ #{$selector} {\n            display: inline-block;\n            width: calc(#{percentage(1 / $i)} - #{$spacing});\n            margin-#{$global-right}: $spacing;\n\n            &:last-child {\n              margin-#{$global-right}: $spacing * -$buttongroup-expand-max;\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n/// Stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-stack(\n  $selector: $buttongroup-child-selector\n) {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 100%;\n    }\n    @else {\n      width: 100%;\n    }\n\n    &:last-child {\n      margin-bottom: 0;\n    }\n\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: $global-radius;\n      }\n\n      &:last-child {\n        margin-bottom: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n      }\n    }\n\n  }\n}\n\n/// Un-stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-unstack(\n  $selector: $buttongroup-child-selector\n) {\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n    @else {\n      width: auto;\n    }\n    margin-bottom: 0;\n\n    @if not $buttongroup-radius-on-each {\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-left}-radius: 0;\n      }\n    }\n\n  }\n}\n\n@mixin foundation-button-group {\n  .button-group {\n    @include button-group;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} #{$buttongroup-child-selector} {\n        font-size: $value;\n      }\n    }\n\n    // Even-width Group\n    &.expanded {\n      @include button-group-expand;\n    }\n\n    // Colors\n    @each $name, $color in $button-palette {\n      @if $button-fill != hollow {\n        &.#{$name} #{$buttongroup-child-selector} {\n          @include button-style($color, auto, auto);\n        }\n      }\n      @else {\n        &.#{$name} #{$buttongroup-child-selector} {\n          @include button-hollow;\n          @include button-hollow-style($color);\n        }\n      }\n    }\n\n    &.stacked,\n    &.stacked-for-small,\n    &.stacked-for-medium {\n      @include button-group-stack;\n\n      &.expanded {\n        @include button-group-expand;\n      }\n    }\n\n    &.stacked-for-small {\n      @include breakpoint(medium) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-medium {\n      @include breakpoint(large) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-small.expanded {\n      @include breakpoint(small only) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n\n    &.stacked-for-medium.expanded {\n      @include breakpoint(medium down) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group close-button\n////\n\n/// Default position of the close button. The first value should be `right` or `left`, and the second value should be `top` or `bottom`.\n/// @type List\n$closebutton-position: right top !default;\n\n/// Right (or left) offset(s) for a close button.\n/// @type Number|Map\n$closebutton-offset-horizontal: (\n  small: 0.66rem,\n  medium: 1rem,\n) !default;\n\n/// Top (or bottom) offset(s) for a close button.\n/// @type Number|Map\n$closebutton-offset-vertical: (\n  small: 0.33em,\n  medium: 0.5rem,\n) !default;\n\n/// Default font size(s) of the close button.\n/// @type Number|Map\n$closebutton-size: (\n  small: 1.5em,\n  medium: 2em,\n) !default;\n\n/// The line-height of the close button. It affects the spacing of the element.\n/// @type Number\n$closebutton-lineheight: 1 !default;\n\n/// Default color of the close button.\n/// @type Color\n$closebutton-color: $dark-gray !default;\n\n/// Default color of the close button when being hovered on.\n/// @type Color\n$closebutton-color-hover: $black !default;\n\n\n/// Get the size and position for a close button. If the input value is a number, the number is returned. If the input value is a config map and the map has the key `$size`, the value is returned.\n///\n/// @param {Number|Map} $value - A number or map that represents the size or position value(s) of the close button.\n/// @param {Keyword} $size - The size of the close button to use.\n///\n/// @return {Number} The given number or the value found in the map.\n@function -zf-get-size-val($value, $size) {\n  // Check if the value is a number\n  @if type-of($value) == 'number' {\n    // If it is, just return the number\n    @return $value;\n  }\n\n  // Check if the size name exists in the value map\n  @else if map-has-key($value, $size) {\n    // If it does, return the value\n    @return map-get($value, $size);\n  }\n}\n\n/// Sets the size and position of a close button.\n/// @param {Keyword} $size [medium] - The size to use. Set to `small` to create a small close button. The 'medium' values defined in `$closebutton-*` variables will be used as the default size and position of the close button.\n@mixin close-button-size($size) {\n  $x: nth($closebutton-position, 1);\n  $y: nth($closebutton-position, 2);\n\n  #{$x}: -zf-get-size-val($closebutton-offset-horizontal, $size);\n  #{$y}: -zf-get-size-val($closebutton-offset-vertical, $size);\n  font-size: -zf-get-size-val($closebutton-size, $size);\n  line-height: -zf-get-size-val($closebutton-lineheight, $size);\n}\n\n/// Adds styles for a close button, using the styles in the settings variables.\n@mixin close-button {\n  $x: nth($closebutton-position, 1);\n  $y: nth($closebutton-position, 2);\n\n  @include disable-mouse-outline;\n  position: absolute;\n  color: $closebutton-color;\n  cursor: pointer;\n\n  &:hover,\n  &:focus {\n    color: $closebutton-color-hover;\n  }\n}\n\n@mixin foundation-close-button {\n  .close-button {\n    @include close-button;\n\n    &.small { @include close-button-size(small) }\n    &, &.medium { @include close-button-size(medium) }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group label\n////\n\n/// Default background color for labels.\n/// @type Color\n$label-background: $primary-color !default;\n\n/// Default text color for labels.\n/// @type Color\n$label-color: $white !default;\n\n/// Alternate text color for labels.\n/// @type Color\n$label-color-alt: $black !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$label-palette: $foundation-palette !default;\n\n/// Default font size for labels.\n/// @type Number\n$label-font-size: 0.8rem !default;\n\n/// Default padding inside labels.\n/// @type Number\n$label-padding: 0.33333rem 0.5rem !default;\n\n/// Default radius of labels.\n/// @type Number\n$label-radius: $global-radius !default;\n\n/// Generates base styles for a label.\n@mixin label {\n  display: inline-block;\n  padding: $label-padding;\n\n  border-radius: $label-radius;\n\n  font-size: $label-font-size;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n}\n\n@mixin foundation-label {\n  .label {\n    @include label;\n\n    background: $label-background;\n    color: $label-color;\n\n    @each $name, $color in $label-palette {\n      &.#{$name} {\n        background: $color;\n        color: color-pick-contrast($color, ($label-color, $label-color-alt));\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// Adds styles for a progress bar container.\n@mixin progress-container {\n  height: $progress-height;\n  margin-bottom: $progress-margin-bottom;\n  border-radius: $progress-radius;\n  background-color: $progress-background;\n}\n\n/// Adds styles for the inner meter of a progress bar.\n@mixin progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: $progress-meter-background;\n\n  @if has-value($progress-radius) {\n    border-radius: $global-radius;\n  }\n}\n\n/// Adds styles for text in the progress meter.\n@mixin progress-meter-text {\n  @include absolute-center;\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: $white;\n  white-space: nowrap;\n\n  @if has-value($progress-radius) {\n    border-radius: $progress-radius;\n  }\n}\n\n@mixin foundation-progress-bar {\n  // Progress bar\n  .progress {\n    @include progress-container;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        .progress-meter {\n          background-color: $color;\n        }\n      }\n    }\n  }\n\n  // Inner meter\n  .progress-meter {\n    @include progress-meter;\n  }\n\n  // Inner meter text\n  .progress-meter-text {\n    @include progress-meter-text;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group progress-bar\n////\n\n/// Height of a progress bar.\n/// @type Number\n$progress-height: 1rem !default;\n\n/// Background color of a progress bar.\n/// @type Color\n$progress-background: $medium-gray !default;\n\n/// Bottom margin of a progress bar.\n/// @type Number\n$progress-margin-bottom: $global-margin !default;\n\n/// Default color of a progress bar's meter.\n/// @type Color\n$progress-meter-background: $primary-color !default;\n\n/// Default radius of a progress bar.\n/// @type Number\n$progress-radius: $global-radius !default;\n\n@mixin foundation-progress-element {\n  progress {\n    display: block;\n    width: 100%;\n    height: $progress-height;\n    margin-bottom: $progress-margin-bottom;\n\n    appearance: none;\n\n    @if has-value($progress-radius) {\n      border-radius: $progress-radius;\n    }\n\n    // For Firefox\n    border: 0;\n    background: $progress-background;\n\n    &::-webkit-progress-bar {\n      background: $progress-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    &::-webkit-progress-value {\n      background: $progress-meter-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    &::-moz-progress-bar {\n      background: $progress-meter-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        // Internet Explorer sets the fill with color\n        color: $color;\n\n        &::-webkit-progress-value {\n          background: $color;\n        }\n\n        &::-moz-progress-bar {\n          background: $color;\n        }\n      }\n    }\n\n    // For IE and Edge\n    &::-ms-fill { // sass-lint:disable-line no-vendor-prefixes\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n\n      border: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// [TODO] Check how plugin confirms disabled or vertical status\n// [TODO] Check if transition: all; is necessary\n\n////\n/// @group slider\n////\n\n/// Default slider width of a vertical slider. (Doesn't apply to the native slider.)\n/// @type Number\n$slider-width-vertical: 0.5rem !default;\n\n/// Transition properties to apply to the slider handle and fill. (Doesn't apply to the native slider.)\n/// @type Transition\n$slider-transition: all 0.2s ease-in-out !default;\n\n/// Adds the general styles for sliders.\n@mixin slider-container {\n  position: relative;\n  height: $slider-height;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n\n  background-color: $slider-background;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none;\n}\n\n/// Adds the general styles for active fill for sliders.\n@mixin slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n\n  display: inline-block;\n  max-width: 100%;\n  height: $slider-height;\n\n  background-color: $slider-fill-background;\n  transition: $slider-transition;\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n/// Adds the general styles for the slider handles.\n@mixin slider-handle {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  left: 0;\n  z-index: 1;\n\n  display: inline-block;\n  width: $slider-handle-width;\n  height: $slider-handle-height;\n\n  border-radius: $slider-radius;\n  background-color: $slider-handle-background;\n  transition: $slider-transition;\n  touch-action: manipulation;\n\n  &:hover {\n    background-color: scale-color($slider-handle-background, $lightness: -15%);\n  }\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n@mixin slider-disabled {\n  opacity: $slider-opacity-disabled;\n  cursor: not-allowed;\n}\n\n@mixin slider-vertical {\n  display: inline-block;\n  width: $slider-width-vertical;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1);\n\n  .slider-fill {\n    top: 0;\n    width: $slider-width-vertical;\n    max-height: 100%;\n  }\n\n  .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: $slider-handle-height;\n    height: $slider-handle-width;\n    transform: translateX(-50%);\n  }\n}\n\n@mixin foundation-slider {\n  // Container\n  .slider {\n    @include slider-container;\n  }\n\n  // Fill area\n  .slider-fill {\n    @include slider-fill;\n  }\n\n  // Draggable handle\n  .slider-handle {\n    @include slider-handle;\n  }\n\n  // Disabled state\n  .slider.disabled,\n  .slider[disabled] {\n    @include slider-disabled;\n  }\n\n  // Vertical slider\n  .slider.vertical {\n    @include slider-vertical;\n  }\n\n  // RTL support\n  @if $global-text-direction == rtl {\n    .slider:not(.vertical) {\n      transform: scale(-1, 1);\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group slider\n////\n\n/// Default height of the slider.\n/// @type Number\n$slider-height: 0.5rem !default;\n\n/// Default background color of the slider's track.\n/// @type Color\n$slider-background: $light-gray !default;\n\n/// Default color of the active fill color of the slider.\n/// @type Color\n$slider-fill-background: $medium-gray !default;\n\n/// Default height of the handle of the slider.\n/// @type Number\n$slider-handle-height: 1.4rem !default;\n\n/// Default width of the handle of the slider.\n/// @type Number\n$slider-handle-width: 1.4rem !default;\n\n/// Default color of the handle for the slider.\n/// @type Color\n$slider-handle-background: $primary-color !default;\n\n/// Default fade amount of a disabled slider.\n/// @type Number\n$slider-opacity-disabled: 0.25 !default;\n\n/// Default radius for slider.\n/// @type Number\n$slider-radius: $global-radius !default;\n\n@mixin foundation-range-input {\n  input[type='range'] {  // sass-lint:disable-line no-qualifying-elements\n    $margin: ($slider-handle-height - $slider-height) / 2;\n\n    display: block;\n    width: 100%;\n    height: auto;\n    margin-top: $margin;\n    margin-bottom: $margin;\n\n    appearance: none;\n    border: 0;\n    line-height: 1;\n    cursor: pointer;\n\n    @if has-value($slider-radius) {\n      border-radius: $slider-radius;\n    }\n\n    &:focus {\n      outline: 0;\n    }\n\n    &[disabled] {\n      opacity: $slider-opacity-disabled;\n    }\n\n    // sass-lint:disable no-vendor-prefix\n\n    // Chrome/Safari\n    &::-webkit-slider-runnable-track {\n      height: $slider-height;\n      background: $slider-background;\n    }\n\n    &::-webkit-slider-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      margin-top: -$margin;\n\n      -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    // Firefox\n    &::-moz-range-track {\n      height: $slider-height;\n      -moz-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-background;\n    }\n\n    &::-moz-range-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      margin-top: -$margin;\n\n      -moz-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    // Internet Explorer\n    &::-ms-track {\n      height: $slider-height;\n\n      border: 0;\n      border-top: $margin solid $body-background;\n      border-bottom: $margin solid $body-background;\n      background: $slider-background;\n\n      overflow: visible;\n      color: transparent;\n    }\n\n    &::-ms-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      border: 0;\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    &::-ms-fill-lower {\n      background: $slider-fill-background;\n    }\n\n    &::-ms-fill-upper {\n      background: $slider-background;\n    }\n\n    @at-root {\n      output {\n        vertical-align: middle;\n        margin-left: 0.5em;\n        line-height: $slider-handle-height;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group switch\n////\n\n/// Background color of a switch.\n/// @type Color\n$switch-background: $medium-gray !default;\n\n/// Background active color of a switch.\n/// @type Color\n$switch-background-active: $primary-color !default;\n\n/// Height of a switch, with no class applied.\n/// @type Number\n$switch-height: 2rem !default;\n\n/// Height of a switch with .tiny class.\n/// @type Number\n$switch-height-tiny: 1.5rem !default;\n\n/// Height of a switch with .small class.\n/// @type Number\n$switch-height-small: 1.75rem !default;\n\n/// Height of a switch with .large class.\n/// @type Number\n$switch-height-large: 2.5rem !default;\n\n/// Border radius of the switch\n/// @type Number\n$switch-radius: $global-radius !default;\n\n/// border around a modal.\n/// @type Number\n$switch-margin: $global-margin !default;\n\n/// Background color for the switch container and paddle.\n/// @type Color\n$switch-paddle-background: $white !default;\n\n/// Spacing between a switch paddle and the edge of the body.\n/// @type Number\n$switch-paddle-offset: 0.25rem !default;\n\n/// border radius of the switch paddle\n/// @type Number\n$switch-paddle-radius: $global-radius !default;\n\n/// switch transition.\n/// @type Number\n$switch-paddle-transition: all 0.25s ease-out !default;\n\n// make them variables\n// ask about accessibility on label\n// change class name for text\n\n/// Adds styles for a switch container. Apply this to a container class.\n@mixin switch-container {\n  position: relative;\n  margin-bottom: $switch-margin;\n  outline: 0;\n\n  // These properties cascade down to the switch text\n  font-size: rem-calc(14);\n  font-weight: bold;\n  color: $white;\n\n  user-select: none;\n}\n\n/// Adds styles for a switch input. Apply this to an `<input>` within a switch.\n@mixin switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0;\n}\n\n/// Adds styles for the background and paddle of a switch. Apply this to a `<label>` within a switch.\n@mixin switch-paddle {\n  $switch-width: $switch-height * 2;\n  $paddle-height: $switch-height - ($switch-paddle-offset * 2);\n  $paddle-width: $switch-height - ($switch-paddle-offset * 2);\n  $paddle-active-offest: $switch-width - $paddle-width - $switch-paddle-offset;\n\n  position: relative;\n  display: block;\n  width: $switch-width;\n  height: $switch-height;\n\n  border-radius: $switch-radius;\n  background: $switch-background;\n  transition: $switch-paddle-transition;\n\n  // Resetting these <label> presets so type styles cascade down\n  font-weight: inherit;\n  color: inherit;\n\n  cursor: pointer;\n\n  // Needed to override specificity\n  input + & {\n    margin: 0;\n  }\n\n  // The paddle itself\n  &::after {\n    position: absolute;\n    top: $switch-paddle-offset;\n    #{$global-left}: $switch-paddle-offset;\n\n    display: block;\n    width: $paddle-width;\n    height: $paddle-height;\n\n    transform: translate3d(0, 0, 0);\n    border-radius: $switch-paddle-radius;\n    background: $switch-paddle-background;\n    transition: $switch-paddle-transition;\n    content: '';\n  }\n\n  // Change the visual style when the switch is active\n  input:checked ~ & {\n    background: $switch-background-active;\n\n    &::after {\n      #{$global-left}: $paddle-active-offest;\n    }\n  }\n\n  input:focus ~ & {\n    @include disable-mouse-outline;\n  }\n}\n\n/// Adds base styles for active/inactive text inside a switch. Apply this to text elements inside the switch `<label>`.\n@mixin switch-text {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Adds styles for the active state text within a switch.\n@mixin switch-text-active {\n  #{$global-left}: 8%;\n  display: none;\n\n  input:checked + label > & {\n    display: block;\n  }\n}\n\n/// Adds styles for the inactive state text within a switch.\n@mixin switch-text-inactive {\n  #{$global-right}: 15%;\n\n  input:checked + label > & {\n    display: none;\n  }\n}\n\n/// Changes the size of a switch by modifying the size of the body and paddle. Apply this to a switch container.\n/// @param {Number} $font-size [1rem] - Font size of label text within the switch.\n/// @param {Number} $switch-height [2rem] - Height of the switch body.\n/// @param {Number} $paddle-offset [0.25rem] - Spacing between the switch paddle and the edge of the switch body.\n@mixin switch-size(\n  $font-size: 1rem,\n  $switch-height: 2rem,\n  $paddle-offset: 0.25rem\n) {\n\n  $switch-width: $switch-height * 2;\n  $paddle-width: $switch-height - ($paddle-offset * 2);\n  $paddle-height: $switch-height - ($paddle-offset * 2);\n  $paddle-active-offest: $switch-width - $paddle-width - $paddle-offset;\n\n  height: $switch-height;\n\n  .switch-paddle {\n    width: $switch-width;\n    height: $switch-height;\n    font-size: $font-size;\n  }\n\n  .switch-paddle::after {\n    top: $paddle-offset;\n    #{$global-left}: $paddle-offset;\n    width: $paddle-width;\n    height: $paddle-height;\n  }\n\n  input:checked ~ .switch-paddle::after {\n    #{$global-left}: $paddle-active-offest;\n  }\n}\n\n@mixin foundation-switch {\n  // Container class\n  .switch {\n    height: $switch-height;\n    @include switch-container;\n  }\n\n  // <input> element\n  .switch-input {\n    @include switch-input;\n  }\n\n  // <label> element\n  .switch-paddle {\n    @include switch-paddle;\n  }\n\n  // Base label text styles\n  %switch-text {\n    @include switch-text;\n  }\n\n  // Active label text styles\n  .switch-active {\n    @extend %switch-text;\n    @include switch-text-active;\n  }\n\n  // Inactive label text styles\n  .switch-inactive {\n    @extend %switch-text;\n    @include switch-text-inactive;\n  }\n\n  // Switch sizes\n  .switch.tiny {\n    @include switch-size(rem-calc(10), $switch-height-tiny, $switch-paddle-offset);\n  }\n\n  .switch.small {\n    @include switch-size(rem-calc(12), $switch-height-small, $switch-paddle-offset);\n  }\n\n  .switch.large {\n    @include switch-size(rem-calc(16), $switch-height-large, $switch-paddle-offset);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-qualifying-elements\n\n////\n/// @group table\n////\n\n/// Default color for table background.\n/// @type Color\n$table-background: $white  !default;\n\n/// Default scale for darkening the striped table rows and the table border.\n/// @type Number\n$table-color-scale: 5% !default;\n\n/// Default style for table border.\n/// @type List\n$table-border: 1px solid smart-scale($table-background, $table-color-scale) !default;\n\n/// Default padding for table.\n/// @type Number\n$table-padding: rem-calc(8 10 10) !default;\n\n/// Default scale for darkening the table rows on hover.\n/// @type Number\n$table-hover-scale: 2% !default;\n\n/// Default color of standard rows on hover.\n/// @type List\n$table-row-hover: darken($table-background, $table-hover-scale) !default;\n\n/// Default color of striped rows on hover.\n/// @type List\n$table-row-stripe-hover: darken($table-background, $table-color-scale + $table-hover-scale) !default;\n\n/// If `true`, tables are striped by default and an .unstriped class is created. If `false`, a .striped class is created.\n/// @type Boolean\n$table-is-striped: true !default;\n\n/// Default background color for striped rows.\n/// @type Color\n$table-striped-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default value for showing the stripe on rows of the tables, excluding the header and footer. If even, the even rows will have a background color. If odd, the odd rows will have a background color. If empty, or any other value, the table rows will have no striping.\n/// @type Keyword\n$table-stripe: even !default;\n\n/// Default color for header background.\n/// @type Color\n$table-head-background: smart-scale($table-background, $table-color-scale / 2) !default;\n\n/// Default color of header rows on hover.\n/// @type List\n$table-head-row-hover: darken($table-head-background, $table-hover-scale) !default;\n\n/// Default color for footer background.\n/// @type Color\n$table-foot-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default color of footer rows on hover.\n/// @type List\n$table-foot-row-hover: darken($table-foot-background, $table-hover-scale) !default;\n\n/// Default font color for header.\n/// @type Color\n$table-head-font-color: $body-font-color !default;\n\n/// Default font color for footer.\n/// @type Color\n$table-foot-font-color: $body-font-color !default;\n\n/// Default value for showing the header when using stacked tables.\n/// @type Boolean\n$show-header-for-stacked: false !default;\n\n/// Breakpoint at which stacked table switches from mobile to desktop view.\n/// @type Breakpoint\n$table-stack-breakpoint: medium !default;\n\n@mixin -zf-table-stripe($stripe: $table-stripe) {\n  tr {\n    // If stripe is set to even, darken the even rows.\n    @if $stripe == even {\n      &:nth-child(even) {\n        border-bottom: 0;\n        background-color: $table-striped-background;\n      }\n    }\n\n    // If stripe is set to odd, darken the odd rows.\n    @else if $stripe == odd {\n      &:nth-child(odd) {\n        background-color: $table-striped-background;\n      }\n    }\n  }\n}\n\n@mixin -zf-table-unstripe() {\n  tr {\n    border-bottom: 0;\n    border-bottom: $table-border;\n    background-color: $table-background;\n  }\n}\n\n@mixin -zf-table-children-styles($stripe: $table-stripe, $is-striped: $table-is-striped) {\n  thead,\n  tbody,\n  tfoot {\n    border: $table-border;\n    background-color: $table-background;\n  }\n\n  // Caption\n  caption {\n    padding: $table-padding;\n    font-weight: $global-weight-bold;\n  }\n\n  // Table head\n  thead {\n    background: $table-head-background;\n    color: $table-head-font-color;\n  }\n\n  // Table foot\n  tfoot {\n    background: $table-foot-background;\n    color: $table-foot-font-color;\n  }\n\n  // Table head and foot\n  thead,\n  tfoot {\n    // Rows within head and foot\n    tr {\n      background: transparent;\n    }\n\n    // Cells within head and foot\n    th,\n    td {\n      padding: $table-padding;\n      font-weight: $global-weight-bold;\n      text-align: #{$global-left};\n    }\n  }\n\n  // Table rows\n  tbody {\n    th,\n    td {\n      padding: $table-padding;\n    }\n  }\n\n  // If tables are striped\n  @if $is-striped == true {\n    tbody {\n      @include -zf-table-stripe($stripe);\n    }\n\n    &.unstriped {\n      tbody {\n        @include -zf-table-unstripe();\n        background-color: $table-background;\n      }\n    }\n  }\n\n  // If tables are not striped\n  @else if $is-striped == false {\n    tbody {\n      @include -zf-table-unstripe();\n    }\n\n    &.striped {\n      tbody {\n        @include -zf-table-stripe($stripe);\n      }\n    }\n  }\n}\n\n/// Adds the general styles for tables.\n/// @param {Keyword} $stripe [$table-stripe] - Uses keywords even, odd, or none to darken rows of the table. The default value is even.\n@mixin table(\n  $stripe: $table-stripe,\n  $nest: false\n) {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: $global-margin;\n  border-radius: $global-radius;\n\n  @if $nest {\n    @include -zf-table-children-styles($stripe);\n  }\n  @else {\n    @at-root {\n      @include -zf-table-children-styles($stripe);\n    }\n  }\n}\n\n/// Adds the ability to horizontally scroll the table when the content overflows horizontally.\n@mixin table-scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto;\n}\n\n/// Slightly darkens the table rows on hover.\n@mixin table-hover {\n  thead tr {\n    //Darkens the table header rows on hover.\n    &:hover {\n      background-color: $table-head-row-hover;\n    }\n  }\n\n  tfoot tr {\n    //Darkens the table footer rows on hover.\n    &:hover {\n      background-color: $table-foot-row-hover;\n    }\n  }\n\n  tbody tr {\n    //Darkens the non-striped table rows on hover.\n    &:hover {\n      background-color: $table-row-hover;\n    }\n  }\n\n  @if $table-is-striped == true {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &:not(.unstriped) tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &:not(.unstriped) tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n\n  @else if $table-is-striped == false {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &.striped tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &.striped tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n}\n\n/// Adds styles for a stacked table. Useful for small-screen layouts.\n/// @param {Boolean} $header [$show-header-for-stacked] - Show the first th of header when stacked.\n@mixin table-stack($header: $show-header-for-stacked) {\n  @if $header {\n    thead {\n      th {\n        display: block;\n      }\n    }\n  }\n  @else {\n    thead {\n      display: none;\n    }\n  }\n\n  tfoot {\n    display: none;\n  }\n\n  tr,\n  th,\n  td {\n    display: block;\n  }\n\n  td {\n    border-top: 0;\n  }\n}\n\n@mixin foundation-table($nest: false) {\n  table {\n    @include table($nest: $nest);\n  }\n\n  table.stack {\n    @include breakpoint($table-stack-breakpoint down) {\n      @include table-stack;\n    }\n  }\n\n  table.scroll {\n    @include table-scroll;\n  }\n\n  table.hover {\n    @include table-hover;\n  }\n\n  .table-scroll {\n    overflow-x: auto;\n\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@import 'math';\n\n$contrast-warnings: true !default;\n\n////\n/// @group functions\n////\n\n/// Checks the luminance of `$color`.\n///\n/// @param {Color} $color - Color to check the luminance of.\n///\n/// @returns {Number} The luminance of `$color`.\n@function color-luminance($color) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n  $rgba: red($color), green($color), blue($color);\n  $rgba2: ();\n\n  @for $i from 1 through 3 {\n    $rgb: nth($rgba, $i);\n    $rgb: $rgb / 255;\n\n    $rgb: if($rgb < 0.03928, $rgb / 12.92, pow(($rgb + 0.055) / 1.055, 2.4));\n\n    $rgba2: append($rgba2, $rgb);\n  }\n\n  @return 0.2126 * nth($rgba2, 1) + 0.7152 * nth($rgba2, 2) + 0.0722 * nth($rgba2, 3);\n}\n\n/// Checks the contrast ratio of two colors.\n///\n/// @param {Color} $color1 - First color to compare.\n/// @param {Color} $color2 - Second color to compare.\n///\n/// @returns {Number} The contrast ratio of the compared colors.\n@function color-contrast($color1, $color2) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef\n  $luminance1: color-luminance($color1) + 0.05;\n  $luminance2: color-luminance($color2) + 0.05;\n  $ratio: $luminance1 / $luminance2;\n\n  @if $luminance2 > $luminance1 {\n    $ratio: 1 / $ratio;\n  }\n\n  $ratio: round($ratio * 10) / 10;\n\n  @return $ratio;\n}\n\n/// Checks the luminance of `$base`, and returns the color from `$colors` (list of colors) that has the most contrast.\n///\n/// @param {Color} $base - Color to check luminance.\n/// @param {List} $colors [($white, $black)] - Colors to compare.\n/// @param {Number} $tolerance [$global-color-pick-contrast-tolerance] - Contrast tolerance.\n///\n/// @returns {Color} the color from `$colors` (list of colors) that has the most contrast.\n@function color-pick-contrast($base, $colors: ($white, $black), $tolerance: $global-color-pick-contrast-tolerance) {\n  $contrast: color-contrast($base, nth($colors, 1));\n  $best: nth($colors, 1);\n\n  @for $i from 2 through length($colors) {\n    $current-contrast: color-contrast($base, nth($colors, $i));\n    @if ($current-contrast - $contrast > $tolerance) {\n      $contrast: color-contrast($base, nth($colors, $i));\n      $best: nth($colors, $i);\n    }\n  }\n\n  @if ($contrast-warnings and $contrast < 3) {\n    @warn \"Contrast ratio of #{$best} on #{$base} is pretty bad, just #{$contrast}\";\n  }\n\n  @return $best;\n}\n\n/// Scales a color to be darker if it's light, or lighter if it's dark. Use this function to tint a color appropriate to its lightness.\n///\n/// @param {Color} $color - Color to scale.\n/// @param {Percentage} $scale [5%] - Amount to scale up or down.\n/// @param {Percentage} $threshold [40%] - Threshold of lightness to check against.\n///\n/// @returns {Color} A scaled color.\n@function smart-scale($color, $scale: 5%, $threshold: 40%) {\n  @if lightness($color) > $threshold {\n    $scale: -$scale;\n  }\n  @return scale-color($color, $lightness: $scale);\n}\n\n/// Get color from foundation-palette\n///\n/// @param {key} color key from foundation-palette\n///\n/// @returns {Color} color from foundation-palette\n@function get-color($key) {\n  @if map-has-key($foundation-palette, $key) {\n    @return map-get($foundation-palette, $key);\n  }\n  @else {\n    @error 'given $key is not available in $foundation-palette';\n  }\n}\n\n/// Transfers the colors in the `$foundation-palette` map into variables, such as `$primary-color` and `$secondary-color`. Call this mixin below the Global section of your settings file to properly migrate your codebase.\n@mixin add-foundation-colors() {\n  @if map-has-key($foundation-palette, primary) {\n    $primary-color: map-get($foundation-palette, primary) !global;\n  } @else {\n    $primary-color: #1779ba !global;\n  }\n  @if map-has-key($foundation-palette, secondary) {\n    $secondary-color: map-get($foundation-palette, secondary) !global;\n  } @else {\n    $secondary-color: #767676 !global;\n  }\n  @if map-has-key($foundation-palette, success) {\n    $success-color: map-get($foundation-palette, success) !global;\n  } @else {\n    $success-color: #3adb76 !global;\n  }\n  @if map-has-key($foundation-palette, warning) {\n    $warning-color: map-get($foundation-palette, warning) !global;\n  } @else {\n    $warning-color: #ffae00 !global;\n  }\n  @if map-has-key($foundation-palette, alert) {\n    $alert-color: map-get($foundation-palette, alert) !global;\n  } @else {\n    $alert-color: #cc4b37 !global;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group badge\n////\n\n/// Default background color for badges.\n/// @type Color\n$badge-background: $primary-color !default;\n\n/// Default text color for badges.\n/// @type Color\n$badge-color: $white !default;\n\n/// Alternate text color for badges.\n/// @type Color\n$badge-color-alt: $black !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$badge-palette: $foundation-palette !default;\n\n/// Default padding inside badges.\n/// @type Number\n$badge-padding: 0.3em !default;\n\n/// Minimum width of a badge.\n/// @type Number\n$badge-minwidth: 2.1em !default;\n\n/// Default font size for badges.\n/// @type Number\n$badge-font-size: 0.6rem !default;\n\n/// Generates the base styles for a badge.\n@mixin badge {\n  display: inline-block;\n  min-width: $badge-minwidth;\n  padding: $badge-padding;\n\n  border-radius: 50%;\n\n  font-size: $badge-font-size;\n  text-align: center;\n}\n\n@mixin foundation-badge {\n  .badge {\n    @include badge;\n\n    background: $badge-background;\n    color: $badge-color;\n\n    @each $name, $color in $badge-palette {\n      &.#{$name} {\n        background: $color;\n        color: color-pick-contrast($color, ($badge-color, $badge-color-alt));\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group breadcrumbs\n////\n\n/// Margin around a breadcrumbs container.\n/// @type Number\n$breadcrumbs-margin: 0 0 $global-margin 0 !default;\n\n/// Font size of breadcrumb links.\n/// @type Number\n$breadcrumbs-item-font-size: rem-calc(11) !default;\n\n/// Color of breadcrumb links.\n/// @type Color\n$breadcrumbs-item-color: $primary-color !default;\n\n/// Color of the active breadcrumb link.\n/// @type Color\n$breadcrumbs-item-color-current: $black !default;\n\n/// Opacity of disabled breadcrumb links.\n/// @type Number\n$breadcrumbs-item-color-disabled: $medium-gray !default;\n\n/// Margin between breadcrumb items.\n/// @type Number\n$breadcrumbs-item-margin: 0.75rem !default;\n\n/// If `true`, makes breadcrumb links uppercase.\n/// @type Boolean\n$breadcrumbs-item-uppercase: true !default;\n\n/// If `true`, adds a seperator between breadcrumb links.\n/// @type Boolean\n$breadcrumbs-item-separator: true !default;\n\n// If it exists $breadcrumbs-item-slash is used to build $breadcrumbs-item-separator. See the documentation.\n@if variable-exists(breadcrumbs-item-slash) {\n  $breadcrumbs-item-separator: $breadcrumbs-item-slash;\n}\n\n/// Used character for the breadcrumb separator.\n/// @type Content\n$breadcrumbs-item-separator-item: '/' !default;\n\n/// Used character for the breadcrumb separator in rtl mode.\n/// @type Content\n$breadcrumbs-item-separator-item-rtl: '\\\\' !default;\n\n/// Color of breadcrumb item.\n/// @type Color\n$breadcrumbs-item-separator-color: $medium-gray !default;\n\n// If it exists $breadcrumbs-item-slash-color is used to build $breadcrumbs-item-separator-color. See the documentation.\n@if variable-exists(breadcrumbs-item-slash-color) {\n  $breadcrumbs-item-separator-color: $breadcrumbs-item-slash-color;\n}\n\n/// Adds styles for a breadcrumbs container, along with the styles for the `<li>` and `<a>` elements inside of it.\n@mixin breadcrumbs-container {\n  @include clearfix;\n  margin: $breadcrumbs-margin;\n  list-style: none;\n\n  // Item wrapper\n  li {\n    float: #{$global-left};\n\n    font-size: $breadcrumbs-item-font-size;\n    color: $breadcrumbs-item-color-current;\n    cursor: default;\n\n    @if $breadcrumbs-item-uppercase {\n      text-transform: uppercase;\n    }\n\n    @if $breadcrumbs-item-separator {\n      // Need to escape the backslash\n      $separator: if($global-text-direction == 'ltr', $breadcrumbs-item-separator-item, $breadcrumbs-item-separator-item-rtl);\n\n      &:not(:last-child) {\n        &::after {\n          position: relative;\n          margin: 0 $breadcrumbs-item-margin;\n          opacity: 1;\n          content: $separator;\n          color: $breadcrumbs-item-separator-color;\n        }\n      }\n    }\n    @else {\n      margin-#{$global-right}: $breadcrumbs-item-margin;\n    }\n  }\n\n  // Page links\n  a {\n    color: $breadcrumbs-item-color;\n\n    &:hover {\n      text-decoration: underline;\n    }\n  }\n}\n\n@mixin foundation-breadcrumbs {\n  .breadcrumbs {\n    @include breadcrumbs-container;\n\n    .disabled {\n      color: $breadcrumbs-item-color-disabled;\n      cursor: not-allowed;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group callout\n////\n\n/// Default background color.\n/// @type Color\n$callout-background: $white !default;\n\n/// Default fade value for callout backgrounds.\n/// @type Number\n$callout-background-fade: 85% !default;\n\n/// Default border style for callouts.\n/// @type List\n$callout-border: 1px solid rgba($black, 0.25) !default;\n\n/// Default bottom margin for callouts.\n/// @type Number\n$callout-margin: 0 0 1rem 0 !default;\n\n/// Default inner padding for callouts.\n/// @type Number\n$callout-padding: 1rem !default;\n\n/// Default font color for callouts.\n/// @type Color\n$callout-font-color: $body-font-color !default;\n\n/// Default font color for callouts, if the callout has a dark background.\n/// @type Color\n$callout-font-color-alt: $body-background !default;\n\n/// Default border radius for callouts.\n/// @type Color\n$callout-radius: $global-radius !default;\n\n/// Amount to tint links used within colored panels. Set to `false` to disable this feature.\n/// @type Number | Boolean\n$callout-link-tint: 30% !default;\n\n/// Adds basic styles for a callout, including padding and margin.\n@mixin callout-base() {\n  position: relative;\n  margin: $callout-margin;\n  padding: $callout-padding;\n\n  border: $callout-border;\n  border-radius: $callout-radius;\n\n  // Respect the padding, fool.\n  > :first-child {\n    margin-top: 0;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Generate quick styles for a callout using a single color as a baseline.\n/// @param {Color} $color [$callout-background] - Color to use.\n@mixin callout-style($color: $callout-background) {\n  $background: scale-color($color, $lightness: $callout-background-fade);\n\n  background-color: $background;\n  color: color-pick-contrast($background, ($callout-font-color, $callout-font-color-alt));\n}\n\n@mixin callout-size($padding) {\n  padding-top: $padding;\n  padding-right: $padding;\n  padding-bottom: $padding;\n  padding-left: $padding;\n}\n\n\n/// Adds styles for a callout.\n/// @param {Color} $color [$callout-background] - Color to use.\n@mixin callout($color: $callout-background) {\n  @include callout-base;\n  @include callout-style($color);\n}\n\n@mixin foundation-callout {\n  .callout {\n    @include callout;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        @include callout-style($color);\n      }\n    }\n\n    &.small {\n      @include callout-size(0.5rem);\n    }\n\n    &.large {\n      @include callout-size(3rem);\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group card\n////\n\n/// Default background color.\n/// @type Color\n$card-background: $white !default;\n\n/// Default font color for cards.\n/// @type Color\n$card-font-color: $body-font-color !default;\n\n/// Default background.\n/// @type Color\n$card-divider-background: $light-gray !default;\n\n/// Default border style.\n/// @type List\n$card-border: 1px solid $light-gray !default;\n\n/// Default card shadow.\n/// @type List\n$card-shadow: none !default;\n\n/// Default border radius.\n/// @type List\n$card-border-radius: $global-radius !default;\n\n/// Default padding.\n/// @type Number\n$card-padding: $global-padding !default;\n\n/// Default bottom margin.\n/// @type number\n$card-margin-bottom: $global-margin !default;\n\n/// Adds styles for a card container.\n/// @param {Color} $background - Background color of the card.\n/// @param {Color} $color - font color of the card.\n/// @param {Number} $margin - Bottom margin of the card.\n/// @param {List} $border - Border around the card.\n/// @param {List} $radius - border radius of the card.\n/// @param {List} $shadow - box shadow of the card.\n@mixin card-container(\n  $background: $card-background,\n  $color: $card-font-color,\n  $margin: $card-margin-bottom,\n  $border: $card-border,\n  $radius: $card-border-radius,\n  $shadow: $card-shadow\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex-direction: column;\n    flex-grow: 1;\n  }\n\n  margin-bottom: $margin;\n\n  border: $border;\n  border-radius: $radius;\n\n  background: $background;\n  box-shadow: $shadow;\n\n  overflow: hidden;\n  color: $color;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card divider.\n@mixin card-divider(\n  $background: $card-divider-background,\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex: 0 1 auto;\n  }\n\n  padding: $padding;\n  background: $background;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card section.\n@mixin card-section(\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    flex: 1 0 auto;\n  }\n\n  padding: $padding;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n@mixin foundation-card {\n  .card {\n    @include card-container;\n  }\n\n  .card-divider {\n    @include card-divider;\n  }\n\n  .card-section {\n    @include card-section;\n  }\n\n  // For IE 11 - Flexbug\n  // https://github.com/philipwalton/flexbugs/issues/75\n  .card-image {\n    min-height: 1px;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown\n////\n\n/// Padding for dropdown panes.\n/// @type List\n$dropdown-padding: 1rem !default;\n\n/// Background for dropdown panes.\n/// @type Color\n$dropdown-background: $body-background !default;\n\n/// Border for dropdown panes.\n/// @type List\n$dropdown-border: 1px solid $medium-gray !default;\n\n/// Font size for dropdown panes.\n/// @type List\n$dropdown-font-size: 1rem !default;\n\n/// Width for dropdown panes.\n/// @type Number\n$dropdown-width: 300px !default;\n\n/// Border radius dropdown panes.\n/// @type Number\n$dropdown-radius: $global-radius !default;\n\n/// Sizes for dropdown panes. Each size is a CSS class you can apply.\n/// @type Map\n$dropdown-sizes: (\n  tiny: 100px,\n  small: 200px,\n  large: 400px,\n) !default;\n\n/// Applies styles for a basic dropdown.\n@mixin dropdown-container {\n  position: absolute;\n  z-index: 10;\n\n  display: none;\n\n  width: $dropdown-width;\n  padding: $dropdown-padding;\n\n  visibility: hidden;\n  border: $dropdown-border;\n  border-radius: $dropdown-radius;\n  background-color: $dropdown-background;\n\n  font-size: $dropdown-font-size;\n\n\n  // Allow an intermittent state to do positioning before making visible.\n  &.is-opening {\n    display: block;\n  }\n\n  &.is-open {\n    display: block;\n    visibility: visible;\n  }\n}\n\n@mixin foundation-dropdown {\n  .dropdown-pane {\n    @include dropdown-container;\n  }\n\n  @each $name, $size in $dropdown-sizes {\n    .dropdown-pane {\n      &.#{$name} {\n        width: $size;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group pagination\n////\n\n/// Font size of pagination items.\n/// @type Number\n$pagination-font-size: rem-calc(14) !default;\n\n/// Default bottom margin of the pagination object.\n/// @type Number\n$pagination-margin-bottom: $global-margin !default;\n\n/// Text color of pagination items.\n/// @type Color\n$pagination-item-color: $black !default;\n\n/// Padding inside of pagination items.\n/// @type Number\n$pagination-item-padding: rem-calc(3 10) !default;\n\n/// Right margin to separate pagination items.\n/// @type Number\n$pagination-item-spacing: rem-calc(1) !default;\n\n/// Default radius for pagination items.\n/// @type Number\n$pagination-radius: $global-radius !default;\n\n/// Background color of pagination items on hover.\n/// @type Color\n$pagination-item-background-hover: $light-gray !default;\n\n/// Background color of pagination item for the current page.\n/// @type Color\n$pagination-item-background-current: $primary-color !default;\n\n/// Text color of the pagination item for the current page.\n/// @type Color\n$pagination-item-color-current: $white !default;\n\n/// Text color of a disabled pagination item.\n/// @type Color\n$pagination-item-color-disabled: $medium-gray !default;\n\n/// Color of the ellipsis in a pagination menu.\n/// @type Color\n$pagination-ellipsis-color: $black !default;\n\n/// If `false`, don't display page number links on mobile, only next/previous links\n/// and optionally current page number.\n/// @type Boolean\n$pagination-mobile-items: false !default;\n\n/// If `true`, display the current page number on mobile even if `$pagination-mobile-items` is set to `false`.\n/// This parameter will only override the visibility setting of the current item for `$pagination-mobile-items: false;`,\n/// it will not affect the current page number visibility when `$pagination-mobile-items` is set to `true`.\n/// @type Boolean\n$pagination-mobile-current-item: false !default;\n\n/// If `true`, arrows are added to the next and previous links of pagination.\n/// @type Boolean\n$pagination-arrows: true !default;\n\n/// Adds styles for a pagination container. Apply this to a `<ul>`.\n@mixin pagination-container (\n  $margin-bottom: $pagination-margin-bottom,\n  $font-size: $pagination-font-size,\n  $spacing: $pagination-item-spacing,\n  $radius: $pagination-radius,\n  $color: $pagination-item-color,\n  $padding: $pagination-item-padding,\n  $background-hover: $pagination-item-background-hover\n) {\n  @include clearfix;\n  margin-#{$global-left}: 0;\n  margin-bottom: $margin-bottom;\n\n  // List item\n  li {\n    margin-#{$global-right}: $spacing;\n    border-radius: $radius;\n    font-size: $font-size;\n\n    @if $pagination-mobile-items {\n      display: inline-block;\n    }\n    @else {\n      display: none;\n\n      &:last-child,\n      &:first-child {\n        display: inline-block;\n      }\n\n      @if $pagination-mobile-current-item {\n        &.current {\n          display: inline-block;\n        }\n      }\n\n      @include breakpoint(medium) {\n        display: inline-block;\n      }\n    }\n  }\n\n  // Page links\n  a,\n  button {\n    display: block;\n    padding: $padding;\n    border-radius: $radius;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n    }\n  }\n}\n\n/// Adds styles for the current pagination item. Apply this to an `<a>`.\n@mixin pagination-item-current (\n  $padding: $pagination-item-padding,\n  $background-current: $pagination-item-background-current,\n  $color-current: $pagination-item-color-current\n) {\n  padding: $padding;\n  background: $background-current;\n  color: $color-current;\n  cursor: default;\n}\n\n/// Adds styles for a disabled pagination item. Apply this to an `<a>`.\n@mixin pagination-item-disabled (\n  $padding: $pagination-item-padding,\n  $color: $pagination-item-color-disabled\n) {\n  padding: $padding;\n  color: $color;\n  cursor: not-allowed;\n\n  &:hover {\n    background: transparent;\n  }\n}\n\n/// Adds styles for an ellipsis for use in a pagination list.\n@mixin pagination-ellipsis (\n  $padding: $pagination-item-padding,\n  $color: $pagination-ellipsis-color\n) {\n  padding: $padding;\n  content: '\\2026';\n  color: $color;\n}\n\n@mixin foundation-pagination {\n  .pagination {\n    @include pagination-container;\n\n    .current {\n      @include pagination-item-current;\n    }\n\n    .disabled {\n      @include pagination-item-disabled;\n    }\n\n    .ellipsis::after {\n      @include pagination-ellipsis;\n    }\n  }\n\n  @if $pagination-arrows {\n    .pagination-previous a::before,\n    .pagination-previous.disabled::before {\n      display: inline-block;\n      margin-#{$global-right}: 0.5rem;\n      content: '\\00ab';\n    }\n\n    .pagination-next a::after,\n    .pagination-next.disabled::after {\n      display: inline-block;\n      margin-#{$global-left}: 0.5rem;\n      content: '\\00bb';\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group tooltip\n////\n\n/// Default cursor of the defined term.\n/// @type Keyword\n$has-tip-cursor: help !default;\n\n/// Default font weight of the defined term.\n/// @type Keyword | Number\n$has-tip-font-weight: $global-weight-bold !default;\n\n/// Default border bottom of the defined term.\n/// @type List\n$has-tip-border-bottom: dotted 1px $dark-gray !default;\n\n/// Default color of the tooltip background.\n/// @type Color\n$tooltip-background-color: $black !default;\n\n/// Default color of the tooltip font.\n/// @type Color\n$tooltip-color: $white !default;\n\n/// Default padding of the tooltip background.\n/// @type Number\n$tooltip-padding: 0.75rem !default;\n\n/// Default max width for tooltips.\n/// @type Number\n$tooltip-max-width: 10rem !default;\n\n/// Default font size of the tooltip text. By default, we recommend a smaller font size than the body copy.\n/// @type Number\n$tooltip-font-size: $small-font-size !default;\n\n/// Default pip width for tooltips.\n/// @type Number\n$tooltip-pip-width: 0.75rem !default;\n\n/// Default pip height for tooltips. This is helpful for calculating the distance of the tooltip from the tooltip word.\n/// @type Number\n$tooltip-pip-height: $tooltip-pip-width * 0.866 !default;\n\n/// Default radius for tooltips.\n/// @type Number\n$tooltip-radius: $global-radius !default;\n\n@mixin has-tip {\n  position: relative;\n  display: inline-block;\n\n  border-bottom: $has-tip-border-bottom;\n  font-weight: $has-tip-font-weight;\n  cursor: $has-tip-cursor;\n}\n\n@mixin tooltip {\n  position: absolute;\n  top: calc(100% + #{$tooltip-pip-height});\n  z-index: 1200;\n\n  max-width: $tooltip-max-width;\n  padding: $tooltip-padding;\n\n  border-radius: $tooltip-radius;\n  background-color: $tooltip-background-color;\n  font-size: $tooltip-font-size;\n  color: $tooltip-color;\n\n  &::before {\n    position: absolute;\n  }\n\n  &.bottom {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, up);\n      bottom: 100%;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.top {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, down);\n      top: 100%;\n      bottom: auto;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.left {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, right);\n      left: 100%;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.right {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, left);\n      right: 100%;\n      left: auto;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.align-top::before {\n    bottom: auto;\n    top: 10%;\n  }\n\n  &.align-bottom::before {\n    bottom: 10%;\n    top: auto;\n  }\n\n  &.align-left::before {\n    left: 10%;\n    right: auto;\n  }\n\n  &.align-right::before {\n    left: auto;\n    right: 10%;\n  }\n}\n\n@mixin foundation-tooltip {\n  .has-tip {\n    @include has-tip;\n  }\n\n  .tooltip {\n    @include tooltip;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group accordion\n////\n\n/// Default background color of an accordion group.\n/// @type Color\n$accordion-background: $white !default;\n\n/// If `true`, adds plus and minus icons to the side of each accordion title.\n/// @type Boolean\n$accordion-plusminus: true !default;\n\n/// Font size of accordion titles.\n/// @type Number\n$accordion-title-font-size: rem-calc(12) !default;\n\n/// Default text color for items in a Menu.\n/// @type Color\n$accordion-item-color: $primary-color !default;\n\n/// Default background color on hover for items in a Menu.\n/// @type Color\n$accordion-item-background-hover: $light-gray !default;\n\n/// Default padding of an accordion item.\n/// @type Number | List\n$accordion-item-padding: 1.25rem 1rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$accordion-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$accordion-content-border: 1px solid $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$accordion-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$accordion-content-padding: 1rem !default;\n\n/// Adds styles for an accordion container. Apply this to the same element that gets `data-accordion`.\n@mixin accordion-container (\n  $background: $accordion-background\n) {\n  margin-#{$global-left}: 0;\n  background: $background;\n  list-style-type: none;\n\n  &[disabled] {\n    .accordion-title {\n      cursor: not-allowed;\n    }\n  }\n}\n\n/// Adds styles for the accordion item. Apply this to the list item within an accordion ul.\n@mixin accordion-item {\n  &:first-child > :first-child {\n    border-radius: $global-radius $global-radius 0 0;\n  }\n\n  &:last-child > :last-child {\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n}\n\n/// Adds styles for the title of an accordion item. Apply this to the link within an accordion item.\n@mixin accordion-title (\n  $padding: $accordion-item-padding,\n  $font-size: $accordion-title-font-size,\n  $color: $accordion-item-color,\n  $border: $accordion-content-border,\n  $background-hover: $accordion-item-background-hover\n) {\n  position: relative;\n  display: block;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n\n  font-size: $font-size;\n  line-height: 1;\n  color: $color;\n\n  :last-child:not(.is-active) > & {\n    border-bottom: $border;\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n\n  &:hover,\n  &:focus {\n    background-color: $background-hover;\n  }\n\n  @if $accordion-plusminus {\n    &::before {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 1rem;\n      margin-top: -0.5rem;\n      content: '+';\n    }\n\n    .is-active > &::before {\n      content: '\\2013';\n    }\n  }\n}\n\n/// Adds styles for accordion content. Apply this to the content pane below an accordion item's title.\n@mixin accordion-content (\n  $padding: $accordion-content-padding,\n  $border: $accordion-content-border,\n  $background: $accordion-content-background,\n  $color: $accordion-content-color\n) {\n  display: none;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n  background-color: $background;\n\n  color: $color;\n\n  :last-child > &:last-child {\n    border-bottom: $border;\n  }\n}\n\n@mixin foundation-accordion {\n  .accordion {\n    @include accordion-container;\n  }\n\n  .accordion-item {\n    @include accordion-item;\n  }\n\n  .accordion-title {\n    @include accordion-title;\n  }\n\n  .accordion-content {\n    @include accordion-content;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group media-object\n////\n\n/// Bottom margin of a media object.\n/// @type Number\n$mediaobject-margin-bottom: $global-margin !default;\n\n/// Left and right padding on sections within a media object.\n/// @type Number\n$mediaobject-section-padding: $global-padding !default;\n\n/// Width of images within a media object, when the object is stacked vertically. Set to 'auto' to use the image's natural width.\n/// @type Number\n$mediaobject-image-width-stacked: 100% !default;\n\n/// Adds styles for a media object container.\n@mixin media-object-container {\n  display: if($global-flexbox, flex, block);\n  margin-bottom: $mediaobject-margin-bottom;\n\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n  }\n\n  img {\n    max-width: none;\n  }\n\n  @if $global-flexbox {\n    &.stack-for-#{$-zf-zero-breakpoint} {\n      @include breakpoint($-zf-zero-breakpoint only) {\n        flex-wrap: wrap;\n      }\n    }\n  }\n}\n\n/// Adds styles for sections within a media object.\n/// @param {Number} $padding [$mediaobject-section-padding] - Padding between sections.\n@mixin media-object-section($padding: $mediaobject-section-padding) {\n  @if $global-flexbox {\n    flex: 0 1 auto;\n  }\n  @else {\n    display: table-cell;\n    vertical-align: top;\n  }\n\n  &:first-child {\n    padding-#{$global-right}: $padding;\n  }\n\n  &:last-child:not(:nth-child(2)) {\n    padding-#{$global-left}: $padding;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n\n  .stack-for-#{$-zf-zero-breakpoint} & {\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include media-object-stack;\n    }\n  }\n\n  @if $global-flexbox {\n    &.main-section {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    &.middle {\n      vertical-align: middle;\n    }\n\n    &.bottom {\n      vertical-align: bottom;\n    }\n  }\n}\n\n/// Adds styles to stack sections of a media object. Apply this to the section elements, not the container.\n@mixin media-object-stack {\n  padding: 0;\n  padding-bottom: $mediaobject-section-padding;\n\n  @if $global-flexbox {\n    flex-basis: 100%;\n    max-width: 100%;\n  }\n  @else {\n    display: block;\n  }\n\n  img {\n    width: $mediaobject-image-width-stacked;\n  }\n}\n\n@mixin foundation-media-object {\n  .media-object {\n    @include media-object-container;\n  }\n\n  .media-object-section {\n    @include media-object-section;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group orbit\n////\n\n/// Default color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background: $medium-gray !default;\n\n/// Default active color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background-active: $dark-gray !default;\n\n/// Default diameter for Orbit's bullets.\n/// @type Number\n$orbit-bullet-diameter: 1.2rem !default;\n\n/// Default margin between Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin: 0.1rem !default;\n\n/// Default distance from slide region for Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin-top: 0.8rem !default;\n\n/// Default bottom margin from Orbit's bullets to whatever content may lurk below it.\n/// @type Number\n$orbit-bullet-margin-bottom: 0.8rem !default;\n\n/// Default background color for Orbit's caption.\n/// @type Color\n$orbit-caption-background: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's caption.\n/// @type Number\n$orbit-caption-padding: 1rem !default;\n\n/// Default background color for Orbit's controls when hovered.\n/// @type Color\n$orbit-control-background-hover: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's controls.\n/// @type Number\n$orbit-control-padding: 1rem !default;\n\n/// Default z-index for Orbit's controls.\n/// @type Number\n$orbit-control-zindex: 10 !default;\n\n/// Adds styles for the outer Orbit wrapper. These styles are used on the `.orbit` class.\n@mixin orbit-wrapper {\n  position: relative;\n}\n\n/// Adds styles for the inner Orbit slide container. These styles are used on the `.orbit-container` class.\n@mixin orbit-container {\n  position: relative;\n  height: 0; // Prevent FOUC by not showing until JS sets height\n  margin: 0;\n  list-style: none;\n  overflow: hidden;\n}\n\n/// Adds styles for the individual slides of an Orbit slider. These styles are used on the `.orbit-slide` class.\n@mixin orbit-slide {\n  width: 100%;\n  position: absolute;\n\n  &.no-motionui {\n    &.is-active {\n      top: 0;\n      left: 0;\n    }\n  }\n}\n\n@mixin orbit-figure {\n  margin: 0;\n}\n\n/// Adds styles for a slide containing an image. These styles are used on the `.orbit-image` class.\n@mixin orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0;\n}\n\n/// Adds styles for an orbit slide caption. These styles are used on the `.orbit-caption` class.\n@mixin orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: $orbit-caption-padding;\n\n  background-color: $orbit-caption-background;\n  color: color-pick-contrast($orbit-caption-background);\n}\n\n/// Adds base styles for the next/previous buttons in an Orbit slider. These styles are shared between the `.orbit-next` and `.orbit-previous` classes in the default CSS.\n@mixin orbit-control {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  z-index: $orbit-control-zindex;\n  padding: $orbit-control-padding;\n  color: $white;\n\n  &:hover,\n  &:active,\n  &:focus {\n    background-color: $orbit-control-background-hover;\n  }\n}\n\n/// Adds styles for the Orbit previous button. These styles are used on the `.orbit-previous` class.\n@mixin orbit-previous {\n  #{$global-left}: 0;\n}\n\n/// Adds styles for the Orbit next button. These styles are used on the `.orbit-next` class.\n@mixin orbit-next {\n  #{$global-left}: auto;\n  #{$global-right}: 0;\n}\n\n/// Adds styles for a container of Orbit bullets. /// Adds styles for the Orbit previous button. These styles are used on the `.orbit-bullets` class.\n@mixin orbit-bullets {\n  @include disable-mouse-outline;\n  position: relative;\n  margin-top: $orbit-bullet-margin-top;\n  margin-bottom: $orbit-bullet-margin-bottom;\n  text-align: center;\n\n  button {\n    width: $orbit-bullet-diameter;\n    height: $orbit-bullet-diameter;\n    margin: $orbit-bullet-margin;\n\n    border-radius: 50%;\n    background-color: $orbit-bullet-background;\n\n    &:hover {\n      background-color: $orbit-bullet-background-active;\n    }\n\n    &.is-active {\n      background-color: $orbit-bullet-background-active;\n    }\n  }\n}\n\n@mixin foundation-orbit {\n  .orbit {\n    @include orbit-wrapper;\n  }\n\n  .orbit-container {\n    @include orbit-container;\n  }\n\n  .orbit-slide {\n    @include orbit-slide;\n  }\n\n  .orbit-figure {\n    @include orbit-figure;\n  }\n\n  .orbit-image {\n    @include orbit-image;\n  }\n\n  .orbit-caption {\n    @include orbit-caption;\n  }\n\n  %orbit-control {\n    @include orbit-control;\n  }\n\n  .orbit-previous {\n    @extend %orbit-control;\n    @include orbit-previous;\n  }\n\n  .orbit-next {\n    @extend %orbit-control;\n    @include orbit-next;\n  }\n\n  .orbit-bullets {\n    @include orbit-bullets;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group responsive-embed\n////\n\n/// Margin below a responsive embed container.\n/// @type Number\n$responsive-embed-margin-bottom: rem-calc(16) !default;\n\n/// Aspect ratios used to determine padding-bottom of responsive embed containers.\n/// @type Map\n$responsive-embed-ratios: (\n  default: 4 by 3,\n  widescreen: 16 by 9,\n) !default;\n\n/// Creates a responsive embed container.\n/// @param {String|List} $ratio [default] - Ratio of the container. Can be a key from the `$responsive-embed-ratios` map or a list formatted as `x by y`.\n@mixin responsive-embed($ratio: default) {\n  @if type-of($ratio) == 'string' {\n    $ratio: map-get($responsive-embed-ratios, $ratio);\n  }\n  position: relative;\n  height: 0;\n  margin-bottom: $responsive-embed-margin-bottom;\n  padding-bottom: ratio-to-percentage($ratio);\n  overflow: hidden;\n\n  iframe,\n  object,\n  embed,\n  video {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 0;\n    width: 100%;\n    height: 100%;\n  }\n}\n\n@mixin foundation-responsive-embed {\n  .responsive-embed,\n  .flex-video {\n    @include responsive-embed($ratio: default);\n\n    $ratios: map-remove($responsive-embed-ratios,default);\n\n    @each $name, $ratio in $ratios {\n      &.#{$name} {\n        padding-bottom: ratio-to-percentage($ratio);\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Finds the greatest common divisor of two integers.\n///\n/// @param {Number} $a - First number to compare.\n/// @param {Number} $b - Second number to compare.\n///\n/// @returns {Number} The greatest common divisor.\n@function gcd($a, $b) {\n  // From: http://rosettacode.org/wiki/Greatest_common_divisor#JavaScript\n  @if ($b != 0) {\n    @return gcd($b, $a % $b);\n  }\n  @else {\n    @return abs($a);\n  }\n}\n\n/// Handles decimal exponents by trying to convert them into a fraction and then use a nth-root-algorithm for parts of the calculation\n///\n/// @param {Number} $base - The base number.\n/// @param {Number} $exponent - The exponent.\n///\n/// @returns {Number} The product of the exponentiation.\n@function pow($base, $exponent, $prec: 16) {\n  @if (floor($exponent) != $exponent) {\n    $prec2 : pow(10, $prec);\n    $exponent: round($exponent * $prec2);\n    $denominator: gcd($exponent, $prec2);\n    @return nth-root(pow($base, $exponent / $denominator), $prec2 / $denominator, $prec);\n  }\n\n  $value: $base;\n  @if $exponent > 1 {\n    @for $i from 2 through $exponent {\n      $value: $value * $base;\n    }\n  }\n  @else if $exponent < 1 {\n    @for $i from 0 through -$exponent {\n      $value: $value / $base;\n    }\n  }\n\n  @return $value;\n}\n\n@function nth-root($num, $n: 2, $prec: 12) {\n  // From: http://rosettacode.org/wiki/Nth_root#JavaScript\n  $x: 1;\n\n  @for $i from 0 through $prec {\n    $x: 1 / $n * (($n - 1) * $x + ($num / pow($x, $n - 1)));\n  }\n\n  @return $x;\n}\n\n/// Calculates the height as a percentage of the width for a given ratio.\n/// @param {List} $ratio - Ratio to use to calculate the height, formatted as `x by y`.\n/// @return {Number} A percentage value for the height relative to the width of a responsive container.\n@function ratio-to-percentage($ratio) {\n  $w: nth($ratio, 1);\n  $h: nth($ratio, 3);\n  @return $h / $w * 100%;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group tabs\n////\n\n/// Default margin of the tab bar.\n/// @type Number\n$tab-margin: 0 !default;\n\n/// Default background color of a tab bar.\n/// @type Color\n$tab-background: $white !default;\n\n/// Font color of tab item.\n/// @type Color\n$tab-color: $primary-color !default;\n\n/// Active background color of a tab bar.\n/// @type Color\n$tab-background-active: $light-gray !default;\n\n/// Active font color of tab item.\n/// @type Color\n$tab-active-color: $primary-color !default;\n\n/// Font size of tab items.\n/// @type Number\n$tab-item-font-size: rem-calc(12) !default;\n\n/// Default background color on hover for items in a Menu.\n$tab-item-background-hover: $white !default;\n\n/// Default padding of a tab item.\n/// @type Number\n$tab-item-padding: 1.25rem 1.5rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$tab-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$tab-content-border: $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$tab-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$tab-content-padding: 1rem !default;\n\n/// Adds styles for a tab container. Apply this to a `<ul>`.\n@mixin tabs-container (\n  $margin: $tab-margin,\n  $background: $tab-background,\n  $border-color: $tab-content-border\n) {\n  @include clearfix;\n  margin: $margin;\n  border: 1px solid $border-color;\n  background: $background;\n  list-style-type: none;\n}\n\n/// Augments a tab container to have vertical tabs. Use this in conjunction with `tabs-container()`.\n@mixin tabs-container-vertical {\n  > li {\n    display: block;\n    float: none;\n    width: auto;\n  }\n}\n\n/// Adds styles for the links within a tab container. Apply this to the `<li>` elements inside a tab container.\n@mixin tabs-title (\n  $padding: $tab-item-padding,\n  $font-size: $tab-item-font-size,\n  $color: $tab-color,\n  $color-active: $tab-active-color,\n  $background-hover: $tab-item-background-hover,\n  $background-active: $tab-background-active\n) {\n  float: #{$global-left};\n\n  > a {\n    @include disable-mouse-outline;\n    display: block;\n    padding: $padding;\n    font-size: $font-size;\n    line-height: 1;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n      color: scale-color($color, $lightness: -14%);\n    }\n\n    &:focus,\n    &[aria-selected='true'] {\n      background: $background-active;\n      color: $color-active;\n    }\n  }\n}\n\n/// Adds styles for the wrapper that surrounds a tab group's content panes.\n@mixin tabs-content (\n  $background: $tab-content-background,\n  $color: $tab-content-color,\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-top: 0;\n  background: $background;\n  color: $color;\n  transition: all 0.5s ease;\n}\n\n/// Augments a tab content container to have a vertical style, by shifting the border around. Use this in conjunction with `tabs-content()`.\n@mixin tabs-content-vertical (\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-#{$global-left}: 0;\n}\n\n/// Adds styles for an individual tab content panel within the tab content container.\n@mixin tabs-panel (\n  $padding: $tab-content-padding\n) {\n  display: none;\n  padding: $padding;\n\n  &.is-active {\n    display: block;\n  }\n}\n\n@mixin foundation-tabs {\n  .tabs {\n    @include tabs-container;\n  }\n\n  // Vertical\n  .tabs.vertical {\n    @include tabs-container-vertical;\n  }\n\n  // Simple\n  .tabs.simple {\n    > li > a {\n      padding: 0;\n\n      &:hover {\n        background: transparent;\n      }\n    }\n  }\n\n  // Primary color\n  .tabs.primary {\n    background: $primary-color;\n\n    > li > a {\n      color: color-pick-contrast($primary-color);\n\n      &:hover,\n      &:focus {\n        background: smart-scale($primary-color);\n      }\n    }\n  }\n\n  .tabs-title {\n    @include tabs-title;\n  }\n\n  .tabs-content {\n    @include tabs-content;\n  }\n\n  .tabs-content.vertical {\n    @include tabs-content-vertical;\n  }\n\n  .tabs-panel {\n    @include tabs-panel;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group thumbnail\n////\n\n/// Border around thumbnail images.\n/// @type Border\n$thumbnail-border: 4px solid $white !default;\n\n/// Bottom margin for thumbnail images.\n/// @type Length\n$thumbnail-margin-bottom: $global-margin !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow: 0 0 0 1px rgba($black, 0.2) !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow-hover: 0 0 6px 1px rgba($primary-color, 0.5) !default;\n\n/// Transition proprties for thumbnail images.\n/// @type Transition\n$thumbnail-transition: box-shadow 200ms ease-out !default;\n\n/// Default radius for thumbnail images.\n/// @type Number\n$thumbnail-radius: $global-radius !default;\n\n/// Adds thumbnail styles to an element.\n@mixin thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: $thumbnail-margin-bottom;\n\n  border: $thumbnail-border;\n  border-radius: $thumbnail-radius;\n  box-shadow: $thumbnail-shadow;\n\n  line-height: 0;\n}\n\n@mixin thumbnail-link {\n  transition: $thumbnail-transition;\n\n  &:hover,\n  &:focus {\n    box-shadow: $thumbnail-shadow-hover;\n  }\n\n  image {\n    box-shadow: none;\n  }\n}\n\n@mixin foundation-thumbnail {\n  .thumbnail {\n    @include thumbnail;\n  }\n\n  a.thumbnail {\n    @include thumbnail-link;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group menu\n////\n\n/// Margin of a menu.\n/// @type Number\n$menu-margin: 0 !default;\n\n/// Left-hand margin of a nested menu.\n/// @type Number\n$menu-nested-margin: $global-menu-nested-margin !default;\n\n/// Padding for items in a pill menu.\n/// @type Number\n$menu-items-padding: $global-menu-padding !default;\n\n/// margin for items in a simple menu.\n/// @type Number\n$menu-simple-margin: 1rem !default;\n\n/// Text color of an active menu item.\n/// @type Color\n$menu-item-color-active: $white !default;\n\n/// Background color of an active menu item.\n/// @type Color\n$menu-item-background-active: get-color(primary) !default;\n\n/// Spacing between an icon and text in a menu item.\n/// @type Number\n$menu-icon-spacing: 0.25rem !default;\n\n/// Backward compatibility for menu state. If true, this duplicate `active` with `is-active`. \n/// But please note that `active` will be removed in upcoming versions.\n/// @type Boolean\n$menu-state-back-compat: true !default;\n\n/// Backward compatibility for menu centered. If true, this duplicate `.menu-centered > .menu` with `.menu.align-center`. \n/// But please note that `menu-centered` will be removed in upcoming versions.\n/// @type Boolean\n$menu-centered-back-compat: true !default;\n\n/// Backward compatibility for using `icon-*` classes without `.icons` classes\n/// But please note that this backward compatibility will be removed in upcoming versions.\n/// @type Boolean\n$menu-icons-back-compat: true !default;\n\n/// Creates the base styles for a Menu.\n@mixin menu-base {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: wrap;\n  }\n\n  li {\n    @include disable-mouse-outline;\n  }\n\n  a,\n  .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: $menu-items-padding;\n  }\n\n  // Reset styles of inner elements\n  input,\n  select,\n  a,\n  button {\n    margin-bottom: 0;\n  }\n\n  input {\n    display: inline-block;\n  }\n}\n\n/// Expands the items of a Menu, so each item is the same width.\n@mixin menu-expand {\n  @if $global-flexbox {\n    li {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    display: table;\n    width: 100%;\n\n    > li {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n}\n\n/// Align menu items.\n@mixin menu-align($alignment) {\n  @if $alignment == left {\n    @if $global-flexbox {\n      justify-content: flex-start;\n    }\n    @else {\n      text-align: $global-left;\n    }\n  }\n  @else if $alignment == right {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: flex-end;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n\n      &.vertical li {\n        display: block;\n        text-align: $global-right;\n\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n    @else {\n      text-align: $global-right;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n\n      &.vertical {\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n  }\n  @else if $alignment == center {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: center;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n    }\n    @else {\n      text-align: center;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n    }\n  }\n}\n\n/// Sets the direction of a Menu.\n/// @param {Keyword} $dir [horizontal] - Direction of the Menu. Can be `horizontal` or `vertical`.\n@mixin menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    @if $global-flexbox {\n      flex-wrap: wrap;\n      flex-direction: row;\n    }\n    @else {\n      li {\n        display: inline-block;\n      }\n    }\n  }\n  @else if $dir == vertical {\n    @if $global-flexbox {\n      flex-wrap: nowrap;\n      flex-direction: column;\n    }\n    @else {\n      li {\n        display: block;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for menu-direction() must be horizontal or vertical.';\n  }\n}\n\n/// Creates a simple Menu, which has no padding or hover state.\n/// @param {Keyword} $dir [$global-left] - Direction of the menu. This effects the side of the `<li>` that receives the margin.\n/// @param {Number} $margin [$menu-simple-margin] - The margin to apply to each `<li>`.\n@mixin menu-simple($dir: $global-left, $margin: $menu-simple-margin) {\n  @if $global-flexbox {\n    align-items: center;\n  }\n\n  li + li {\n    margin-#{$dir}: $margin;\n  }\n\n  a {\n    padding: 0;\n  }\n}\n\n/// Adds styles for a nested Menu, by adding `margin-left` to the menu.\n/// @param {Keyword|Number} $margin [$menu-nested-margin] - Length of the margin.\n/// @param {Keyword} $nested-alignment [left] - Alignment of the nested class\n@mixin menu-nested(\n  $margin: $menu-nested-margin,\n  $nested-alignment: left\n) {\n  @if $nested-alignment == right {\n    margin-#{$global-right}: $margin;\n    margin-#{$global-left}: 0;\n  }\n  @else {\n    margin-#{$global-right}: 0;\n    margin-#{$global-left}: $margin;\n  }\n\n}\n\n/// Adds basic styles for icons in menus.\n@mixin menu-icons() {\n  @if $global-flexbox {\n    a {\n      display: flex;\n    }\n  }\n  @else {\n    img,\n    i,\n    svg {\n      vertical-align: middle;\n\n      + span {\n        vertical-align: middle;\n      }\n    }\n  }\n}\n\n/// Adds position classes for icons within a menu.\n@mixin menu-icon-position($position: left, $spacing: $menu-icon-spacing) {\n  @if $position == left {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-right}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-left}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: 0 auto $spacing;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: $spacing auto 0;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n}\n\n@mixin menu-text {\n  padding: $global-menu-padding;\n\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n@mixin menu-state-active {\n  background: $menu-item-background-active;\n  color: $menu-item-color-active;\n}\n\n@mixin foundation-menu {\n  .menu {\n    @include menu-base;\n\n    // Default orientation: horizontal\n    &, &.horizontal {\n      @include menu-direction(horizontal);\n    }\n\n    // Vertical orientation modifier\n    &.vertical {\n      @include menu-direction(vertical);\n    }\n\n    // Even-width modifier for horizontal orientation\n    &.expanded {\n      @include menu-expand;\n    }\n\n    // Simple\n    &.simple {\n      @include menu-simple;\n    }\n\n    // Breakpoint specific versions\n    @include -zf-each-breakpoint($small: false) {\n      &.#{$-zf-size}-horizontal {\n        @include menu-direction(horizontal);\n      }\n\n      &.#{$-zf-size}-vertical {\n        @include menu-direction(vertical);\n      }\n\n      &.#{$-zf-size}-expanded {\n        @include menu-expand;\n      }\n\n      &.#{$-zf-size}-simple {\n        @include menu-expand;\n      }\n    }\n\n    // Nesting\n    &.nested {\n      @include menu-nested;\n    }\n\n    // Icon Base Styles\n    &.icons {\n      @include menu-icons;\n    }\n\n    // Backward Compatibility for active state\n    @if $menu-icons-back-compat {\n      &.icon-top,\n      &.icon-right,\n      &.icon-bottom,\n      &.icon-left {\n        @include menu-icons;\n      }\n    }\n\n    // Icon Left\n    &.icon-left {\n      @include menu-icon-position(left);\n    }\n\n    // Icon Right\n    &.icon-right {\n      @include menu-icon-position(right);\n    }\n\n    // Icon Top\n    &.icon-top {\n      @include menu-icon-position(top);\n    }\n\n    // Icon Bottom\n    &.icon-bottom {\n      @include menu-icon-position(bottom);\n    }\n\n    // Active state\n    .is-active > a {\n      @include menu-state-active;\n    }\n    \n    // Backward Compatibility for active state\n    @if $menu-state-back-compat {\n      .active > a {\n        @include menu-state-active;\n      }\n    }\n\n    // Align left\n    &.align-#{$global-left} {\n      @include menu-align(left);\n    }\n\n    // Align right\n    &.align-#{$global-right} {\n      @include menu-align(right);\n\n      .nested {\n        @include menu-nested($nested-alignment: right);\n      }\n    }\n\n    // Align center\n    &.align-center {\n      @include menu-align(center);\n    }\n\n    .menu-text {\n      @include menu-text;\n    }\n  }\n\n  @if $menu-centered-back-compat {\n    .menu-centered {\n      > .menu {\n        @if $global-flexbox {\n          justify-content: center;\n        }\n        \n        @include menu-align(center);\n      }\n    }\n  }\n\n  // Prevent FOUC when using the Responsive Menu plugin\n  .no-js [data-responsive-menu] ul {\n    display: none;\n  }\n}\n","@mixin foundation-menu-icon {\n  .menu-icon {\n    @include hamburger($color: $titlebar-icon-color, $color-hover: $titlebar-icon-color-hover);\n  }\n\n  .menu-icon.dark {\n    @include hamburger;\n  }\n}\n","////\n/// @group accordion-menu\n////\n\n/// Sets accordion menu padding.\n/// @type Number\n$accordionmenu-padding: $global-menu-padding !default;\n\n/// Sets accordion menu nested margin\n/// @type Number\n$accordionmenu-nested-margin: $global-menu-nested-margin !default;\n\n/// Sets accordion menu submenu padding.\n/// @type Number\n$accordionmenu-submenu-padding: $accordionmenu-padding !default;\n\n/// Sets if accordion menus have the default arrow styles.\n/// @type Boolean\n$accordionmenu-arrows: true !default;\n\n/// Sets accordion menu arrow color if arrow is used.\n/// @type Color\n$accordionmenu-arrow-color: $primary-color !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-item-background: null !default;\n\n/// Sets accordion menu item border.\n/// @type Color\n$accordionmenu-border: null !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-submenu-toggle-background: null !default;\n\n/// Sets accordion menu item padding.\n/// @type List\n$accordion-submenu-toggle-border: $accordionmenu-border !default;\n\n/// Sets accordion menu submenu toggle background width.\n/// @type Number\n$accordionmenu-submenu-toggle-width: 40px !default;\n\n/// Sets accordion menu submenu toggle background height.\n/// @type Number\n$accordionmenu-submenu-toggle-height: $accordionmenu-submenu-toggle-width !default;\n\n/// Sets accordion menu arrow size if arrow is used.\n/// @type Length\n$accordionmenu-arrow-size: 6px !default;\n\n@mixin zf-accordion-menu-left-right-arrows {\n  .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($accordionmenu-arrow-size, $accordionmenu-arrow-color, down);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * ($accordionmenu-arrow-size / 2);\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-accordion-submenu-parent > a::after {\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-accordion-submenu-parent > a::after {\n    right: auto;\n    left: 1rem;\n  }\n}\n@mixin foundation-accordion-menu {\n\n  .accordion-menu {\n    @if $accordionmenu-border {\n      border-bottom: $accordionmenu-border;\n    }\n\n    li {\n      @if $accordionmenu-border {\n        border-top: $accordionmenu-border;\n        border-right: $accordionmenu-border;\n        border-left: $accordionmenu-border;\n      }\n      width: 100%;\n    }\n\n    a {\n      @if $accordionmenu-item-background {\n        background: $accordionmenu-item-background;\n      }\n      padding: $accordionmenu-padding;\n    }\n\n    .is-accordion-submenu a {\n      padding: $accordionmenu-submenu-padding;\n    }\n\n    .nested.is-accordion-submenu {\n      @include menu-nested($accordionmenu-nested-margin);\n    }\n\n    &.align-#{$global-right} {\n      .nested.is-accordion-submenu {\n        @include menu-nested($accordionmenu-nested-margin, right);\n      }\n    }\n\n    @if $accordionmenu-arrows {\n      @include zf-accordion-menu-left-right-arrows;\n\n      .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n        transform: rotate(180deg);\n        transform-origin: 50% 50%;\n      }\n    }\n  }\n\n  .is-accordion-submenu li {\n    @if $accordionmenu-border {\n      border-right: 0;\n      border-left: 0;\n    }\n  }\n\n  .is-accordion-submenu-parent {\n    position: relative;\n  }\n\n  .has-submenu-toggle > a {\n    margin-#{$global-right}: $accordionmenu-submenu-toggle-width;\n  }\n\n  // Submenu toggle\n  .submenu-toggle {\n    position: absolute;\n    top: 0;\n    #{$global-right}: 0;\n\n    width: $accordionmenu-submenu-toggle-width;\n    height: $accordionmenu-submenu-toggle-height;\n\n    cursor: pointer;\n\n    border-#{$global-left}: $accordion-submenu-toggle-border;\n\n    @if $accordionmenu-submenu-toggle-background {\n      background: $accordionmenu-submenu-toggle-background;\n    }\n\n    // Add the arrow to the toggle\n    &::after {\n      @include css-triangle(6px, $accordionmenu-arrow-color, down);\n\n      top: 0;\n      bottom: 0;\n      margin: auto;\n    }\n  }\n\n  // Rotate the arrow when menu is open\n  .submenu-toggle[aria-expanded='true']::after {\n    transform: scaleY(-1);\n    transform-origin: 50% 50%;\n  }\n\n  .submenu-toggle-text {\n    @include element-invisible;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group drilldown\n////\n\n/// Transition property to use for animating menus.\n/// @type Transition\n$drilldown-transition: transform 0.15s linear !default;\n\n/// Adds arrows to drilldown items with submenus, as well as the back button.\n/// @type Boolean\n$drilldown-arrows: true !default;\n\n/// Sets drilldown menu item padding.\n/// @type Number\n$drilldown-padding: $global-menu-padding !default;\n\n/// Sets drilldown menu nested margin\n/// @type Number\n$drilldown-nested-margin: 0 !default;\n\n/// Background color for drilldown top level items.\n/// @type Color\n$drilldown-background: $white !default;\n\n/// Sets drilldown menu item padding in the submenu.\n/// @type Number\n$drilldown-submenu-padding: $drilldown-padding !default;\n\n/// Background color for drilldown submenus.\n/// @type Color\n$drilldown-submenu-background: $white !default;\n\n/// Sets drilldown arrow color if arrow is used.\n/// @type Color\n$drilldown-arrow-color: $primary-color !default;\n\n/// Sets drilldown arrow size if arrow is used.\n/// @type Length\n$drilldown-arrow-size: 6px !default;\n\n@mixin zf-drilldown-left-right-arrows {\n  .is-drilldown-submenu-parent > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-right);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * $drilldown-arrow-size;\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 1rem;\n  }\n\n}\n\n@mixin foundation-drilldown-menu {\n  // Applied to the Menu container\n  .is-drilldown {\n    position: relative;\n    overflow: hidden;\n\n    li {\n      display: block;\n    }\n\n    &.animate-height {\n      transition: height 0.5s;\n    }\n  }\n\n  // The top level <ul>\n  .drilldown {\n    a {\n      padding: $drilldown-padding;\n      background: $drilldown-background;\n    }\n\n    // Applied to submenu <ul>s\n    .is-drilldown-submenu {\n      position: absolute;\n      top: 0;\n      #{$global-left}: 100%;\n      z-index: -1;\n\n      width: 100%;\n      background: $drilldown-submenu-background;\n      transition: $drilldown-transition;\n\n      &.is-active {\n        z-index: 1;\n        display: block;\n        transform: translateX(if($global-text-direction == ltr, -100%, 100%));\n      }\n\n      &.is-closing {\n        transform: translateX(if($global-text-direction == ltr, 100%, -100%));\n      }\n\n      // Submenu item padding\n      a {\n        padding: $drilldown-submenu-padding;\n      }\n    }\n\n    .nested.is-drilldown-submenu {\n      @include menu-nested($drilldown-nested-margin);\n    }\n\n    .drilldown-submenu-cover-previous {\n      min-height: 100%;\n    }\n\n    @if $drilldown-arrows {\n      @include zf-drilldown-left-right-arrows;\n\n      .js-drilldown-back > a::before {\n        @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-left);\n        display: inline-block;\n        vertical-align: middle;\n        margin-#{$global-right}: 0.75rem; // Creates space between the arrow and the text\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown-menu\n////\n\n/// Enables arrows for items with dropdown menus.\n/// @type Boolean\n$dropdownmenu-arrows: true !default;\n\n/// Sets dropdown menu arrow color if arrow is used.\n/// @type Color\n$dropdownmenu-arrow-color: $anchor-color !default;\n\n/// Sets dropdown menu arrow size if arrow is used.\n/// @type Length\n$dropdownmenu-arrow-size: 6px !default;\n\n/// Sets dropdown menu arrow padding for aligning the arrow correctly.\n/// @type Length\n$dropdownmenu-arrow-padding: 1.5rem !default;\n\n/// Minimum width of dropdown sub-menus.\n/// @type Length\n$dropdownmenu-min-width: 200px !default;\n\n/// Background color for top level items.\n/// @type Color\n$dropdownmenu-background: null !default;\n\n/// Background color for dropdowns.\n/// @type Color\n$dropdownmenu-submenu-background: $white !default;\n\n/// Padding for top level items.\n/// @type Number\n$dropdownmenu-padding: $global-menu-padding !default;\n\n/// Sets dropdown menu nested margin\n/// @type Number\n$dropdownmenu-nested-margin: 0 !default;\n\n/// Padding for sub-menu items.\n/// @type Number\n$dropdownmenu-submenu-padding: $dropdownmenu-padding !default;\n\n/// Border for dropdown sub-menus.\n/// @type List\n$dropdownmenu-border: 1px solid $medium-gray !default;\n\n// Border width for dropdown sub-menus.\n// Used to adjust top margin of a sub-menu if a border is used.\n// @type Length\n$dropdownmenu-border-width: nth($dropdownmenu-border, 1);\n\n/// Text color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-color-active: get-color(primary) !default;\n\n/// Background color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-background-active: transparent !default;\n\n@mixin zf-dropdown-left-right-arrows {\n  > a::after {\n    #{$global-right}: 14px;\n  }\n\n  &.opens-left > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 5px;\n  }\n\n  &.opens-right > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n  }\n}\n\n@mixin dropdown-menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    > li.opens-left { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n\n    > li.opens-right { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: auto;\n        left: 0;\n      }\n    }\n\n    @if $dropdownmenu-arrows {\n      > li.is-dropdown-submenu-parent > a { // sass-lint:disable-line no-qualifying-elements\n        position: relative;\n        padding-#{$global-right}: $dropdownmenu-arrow-padding;\n      }\n\n      > li.is-dropdown-submenu-parent > a::after { // sass-lint:disable-line no-qualifying-elements\n        @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, down);\n        #{$global-right}: 5px;\n        #{$global-left}: auto;\n        margin-top: -1 * ($dropdownmenu-arrow-size / 2);\n      }\n    }\n  }\n  @else if $dir == vertical {\n    > li {\n      .is-dropdown-submenu {\n        top: 0;\n      }\n\n      &.opens-left {\n        > .is-dropdown-submenu {\n          top: 0;\n          right: 100%;\n          left: auto;\n        }\n      }\n\n      &.opens-right {\n        > .is-dropdown-submenu {\n          right: auto;\n          left: 100%;\n        }\n      }\n\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for dropdown-menu-direction() must be horizontal or vertical.';\n  }\n}\n\n@mixin foundation-dropdown-menu {\n  .dropdown.menu {\n    @include dropdown-menu-direction(horizontal);\n\n    a {\n      @include disable-mouse-outline;\n    }\n\n    // Top-level item\n    > li > a {\n      background: $dropdownmenu-background;\n      padding: $dropdownmenu-padding;\n    }\n\n    // Top-level item active state\n    > li.is-active > a {\n      background: $dropdown-menu-item-background-active;\n      color: $dropdown-menu-item-color-active;\n    }\n\n    .no-js & ul {\n      display: none;\n    }\n\n    .nested.is-dropdown-submenu {\n      @include menu-nested($dropdownmenu-nested-margin);\n    }\n\n    &.vertical {\n      @include dropdown-menu-direction(vertical);\n    }\n\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        @include breakpoint($size) {\n          &.#{$size}-horizontal {\n            @include dropdown-menu-direction(horizontal);\n          }\n\n          &.#{$size}-vertical {\n            @include dropdown-menu-direction(vertical);\n          }\n        }\n      }\n    }\n\n    &.align-right {\n      .is-dropdown-submenu.first-sub {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n  }\n\n  .is-dropdown-menu.vertical {\n    width: 100px;\n\n    &.align-right {\n      float: right;\n    }\n  }\n\n  .is-dropdown-submenu-parent {\n    position: relative;\n\n    a::after {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 5px;\n      #{$global-left}: auto;\n      margin-top: -1 * $dropdownmenu-arrow-size;\n    }\n\n    &.opens-inner > .is-dropdown-submenu {\n\n      top: 100%;\n      @if $global-text-direction == 'rtl' {\n        right: auto;\n      }\n      @else {\n        left: auto;\n      }\n    }\n\n    &.opens-left > .is-dropdown-submenu {\n      right: 100%;\n      left: auto;\n    }\n\n    &.opens-right > .is-dropdown-submenu {\n      right: auto;\n      left: 100%;\n    }\n  }\n\n  .is-dropdown-submenu {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 100%;\n    z-index: 1;\n\n    display: none;\n    min-width: $dropdownmenu-min-width;\n\n    border: $dropdownmenu-border;\n    background: $dropdownmenu-submenu-background;\n\n    .dropdown & a {\n      padding: $dropdownmenu-submenu-padding;\n    }\n\n    .is-dropdown-submenu-parent {\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n\n    @if (type-of($dropdownmenu-border-width) == 'number') {\n      .is-dropdown-submenu {\n        margin-top: (-$dropdownmenu-border-width);\n      }\n    }\n\n    > li {\n      width: 100%;\n    }\n\n    // [TODO] Cut back specificity\n    //&:not(.js-dropdown-nohover) > .is-dropdown-submenu-parent:hover > &, // why is this line needed? Opening is handled by JS and this causes some ugly flickering when the sub is re-positioned automatically...\n    &.js-dropdown-active {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group off-canvas\n////\n\n/// Width map of a left/right off-canvas panel.\n/// @type Map\n$offcanvas-sizes: (\n  small: 250px,\n) !default;\n\n/// Height map of a top/bottom off-canvas panel.\n/// @type Map\n$offcanvas-vertical-sizes: (\n  small: 250px,\n) !default;\n\n/// Background color of an off-canvas panel.\n/// @type Color\n$offcanvas-background: $light-gray !default;\n\n/// Box shadow for the off-canvas overlap panel.\n/// @type Shadow\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7) !default;\n\n/// Inner box shadow size for the off-canvas push panel.\n/// @type Number\n$offcanvas-inner-shadow-size: 20px !default;\n\n/// Inner box shadow color for the off-canvas push panel.\n/// @type Color\n$offcanvas-inner-shadow-color: rgba($black, 0.25) !default;\n\n/// Z-index of an off-canvas content overlay.\n/// @type Number\n$offcanvas-overlay-zindex: 11 !default;\n\n/// Z-index of an off-canvas panel with the `push` transition.\n/// @type Number\n$offcanvas-push-zindex: 12 !default;\n\n/// Z-index of an off-canvas panel with the `overlap` transition.\n/// @type Number\n$offcanvas-overlap-zindex: 13 !default;\n\n/// Z-index of an off-canvas panel using the `reveal-for-*` classes or mixin.\n/// @type Number\n$offcanvas-reveal-zindex: 12 !default;\n\n/// Length of the animation on an off-canvas panel.\n/// @type Number\n$offcanvas-transition-length: 0.5s !default;\n\n/// Timing function of the animation on an off-canvas panel.\n/// @type Keyword\n$offcanvas-transition-timing: ease !default;\n\n/// If `true`, a revealed off-canvas will be fixed-position, and scroll with the screen.\n/// @type Bool\n$offcanvas-fixed-reveal: true !default;\n\n/// Background color for the overlay that appears when an off-canvas panel is open.\n/// @type Color\n$offcanvas-exit-background: rgba($white, 0.25) !default;\n\n/// CSS class used for the main content area. The off-canvas mixins use this to target the page content.\n$maincontent-class: 'off-canvas-content' !default;\n\n/// Adds baseline styles for off-canvas. This CSS is required to make the other pieces work.\n@mixin off-canvas-basics {\n\n  /// Transform deprecated size settings into map & show warning\n  @if variable-exists(offcanvas-size) {\n    $offcanvas-sizes: (small: $offcanvas-size, medium: $offcanvas-size) !global;\n    @warn '$offcanvas-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-sizes instead';\n  }\n  @if variable-exists(offcanvas-vertical-size) {\n    $offcanvas-vertical-sizes: (small: $offcanvas-vertical-size, medium: $offcanvas-vertical-size) !global;\n    @warn '$offcanvas-vertical-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-vertical-sizes instead';\n  }\n\n  // Checks the z-indexes and increase them due to backwards compatibility.\n  // This is necessary because the overlay's z-index is new since v6.4 and may be identical to the user custom settings of the push z-index.\n  @if $offcanvas-push-zindex <= $offcanvas-overlay-zindex { $offcanvas-push-zindex: $offcanvas-overlay-zindex + 1 !global; }\n  @if $offcanvas-overlap-zindex <= $offcanvas-push-zindex { $offcanvas-overlap-zindex: $offcanvas-push-zindex + 1 !global; }\n  @if $offcanvas-reveal-zindex <= $offcanvas-overlay-zindex { $offcanvas-reveal-zindex: $offcanvas-overlay-zindex + 1 !global; }\n\n  // Hides overflow on body when an off-canvas panel is open.\n  .is-off-canvas-open {\n    overflow: hidden;\n  }\n\n  // Off-canvas overlay (generated by JavaScript)\n  .js-off-canvas-overlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    z-index: $offcanvas-overlay-zindex;\n\n    width: 100%;\n    height: 100%;\n\n    transition: opacity $offcanvas-transition-length $offcanvas-transition-timing, visibility $offcanvas-transition-length $offcanvas-transition-timing;\n\n    background: $offcanvas-exit-background;\n\n    opacity: 0;\n    visibility: hidden;\n\n    overflow: hidden;\n\n    &.is-visible {\n      opacity: 1;\n      visibility: visible;\n    }\n\n    &.is-closable {\n      cursor: pointer;\n    }\n\n    &.is-overlay-absolute {\n      position: absolute;\n    }\n\n    &.is-overlay-fixed {\n      position: fixed;\n    }\n  }\n}\n\n// Adds basic styles for an off-canvas wrapper.\n@mixin off-canvas-wrapper() {\n  position: relative;\n  overflow: hidden;\n}\n\n/// Adds basic styles for an off-canvas panel.\n@mixin off-canvas-base(\n  $background: $offcanvas-background,\n  $transition: $offcanvas-transition-length $offcanvas-transition-timing,\n  $fixed: true\n) {\n  @include disable-mouse-outline;\n\n  @if $fixed == true {\n    position: fixed;\n  }\n  @else {\n    position: absolute;\n  }\n\n  // Set the off-canvas z-index.\n  z-index: $offcanvas-push-zindex;\n\n  // Increase CSS specificity\n  &.is-transition-push {\n    z-index: $offcanvas-push-zindex;\n  }\n\n  transition: transform $transition;\n  backface-visibility: hidden;\n\n  background: $background;\n\n  // Hide inactive off-canvas within the content that have the same position\n  &.is-closed {\n    visibility: hidden;\n  }\n\n  // Overlap only styles.\n  &.is-transition-overlap {\n    z-index: $offcanvas-overlap-zindex;\n\n    &.is-open {\n      box-shadow: $offcanvas-shadow;\n    }\n  }\n\n  // Sets transform to 0 to show an off-canvas panel.\n  &.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles to position an off-canvas panel to the left/right/top/bottom.\n@mixin off-canvas-position(\n  $position: left,\n  $orientation: horizontal,\n  $sizes: if($orientation == horizontal, $offcanvas-sizes, $offcanvas-vertical-sizes)\n) {\n  @if $position == left {\n    top: 0;\n    left: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    top: 0;\n    right: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX(-$size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    top: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY(-$size);\n          }\n        }\n      }\n    }\n  }\n\n  // If $offcanvas-inner-shadow-size is set, add inner box-shadow.\n  // This mimics the off-canvas panel having a lower z-index, without having to have one.\n  @if $offcanvas-inner-shadow-size {\n    &.is-transition-push {\n      @if $position == left {\n        @include inner-side-shadow(right, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == right {\n        @include inner-side-shadow(left, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == top {\n        @include inner-side-shadow(bottom, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == bottom {\n        @include inner-side-shadow(top, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n    }\n  }\n\n}\n\n/// Sets the styles for the content container.\n@mixin off-canvas-content() {\n  transform: none;\n  transition: transform $offcanvas-transition-length $offcanvas-transition-timing;\n  backface-visibility: hidden;\n\n  // Transform scope until the element is closed (makes sure transitionend gets triggered)\n  &.has-transition-push {\n    transform: translate(0, 0);\n  }\n\n  // Consider element & content, nested in another content\n  .off-canvas.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles that reveal an off-canvas panel.\n@mixin off-canvas-reveal(\n$position: left,\n$zindex: $offcanvas-reveal-zindex,\n$content: $maincontent-class,\n$breakpoint: small\n) {\n  transform: none;\n  z-index: $zindex;\n  transition: none;\n  visibility: visible;\n\n  @if not $offcanvas-fixed-reveal {\n    position: absolute;\n  }\n\n  .close-button {\n    display: none;\n  }\n\n  // Consider revealed element is nested in content\n  .#{$maincontent-class} & {\n    transform: none;\n  }\n\n  @at-root .#{$content}.has-reveal-#{$position} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n\n  // backwards compatibility (prior to v6.4)\n  & ~ .#{$content} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n}\n\n/// Overrides the off-canvas styles\n@mixin in-canvas() {\n  visibility: visible;\n  height: auto;\n  position: static;\n  background: none;\n  width: auto;\n  overflow: visible;\n  transition: none;\n\n  // Increase CSS specificity\n  &.position-left,\n  &.position-right,\n  &.position-top,\n  &.position-bottom {\n    box-shadow: none;\n    transform: none;\n  }\n\n  .close-button {\n    display: none;\n  }\n}\n\n@mixin foundation-off-canvas {\n  @include off-canvas-basics;\n\n  // Off-canvas wrapper\n  .off-canvas-wrapper {\n    @include off-canvas-wrapper;\n  }\n\n  // Off-canvas container\n  .off-canvas {\n    @include off-canvas-base;\n\n    // Force position absolute for nested off-canvas because fixed doesn't work for push transition within the transform scope.\n    @at-root .#{$maincontent-class} & {\n      // NOTE: since overlap transition is currently forced if nested, there's no need to force position absolute until nested push transition is supported.\n      // position: absolute;\n    }\n  }\n\n  // Off-canvas container with absolute position\n  .off-canvas-absolute {\n    @include off-canvas-base($fixed: false);\n  }\n\n  // Off-canvas position classes\n  .position-left    { @include off-canvas-position(left,   horizontal); }\n  .position-right   { @include off-canvas-position(right,  horizontal); }\n  .position-top     { @include off-canvas-position(top,    vertical); }\n  .position-bottom  { @include off-canvas-position(bottom, vertical); }\n\n  .off-canvas-content {\n    @include off-canvas-content;\n  }\n\n  // Reveal off-canvas panel on larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .position-left.reveal-for-#{$name} {\n          @include off-canvas-reveal(left, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-right.reveal-for-#{$name} {\n          @include off-canvas-reveal(right, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-top.reveal-for-#{$name} {\n          @include off-canvas-reveal(top, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-bottom.reveal-for-#{$name} {\n          @include off-canvas-reveal(bottom, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n      }\n    }\n  }\n\n  // Move in-canvas for larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .off-canvas.in-canvas-for-#{$name} {\n          @include in-canvas;\n        }\n      }\n    }\n  }\n}\n\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@mixin foundation-sticky {\n  .sticky-container {\n    position: relative;\n  }\n\n  .sticky {\n    position: relative;\n    z-index: 0;\n    transform: translate3d(0, 0, 0);\n  }\n\n  .sticky.is-stuck {\n    position: fixed;\n    z-index: 5;\n    width: 100%;\n\n    &.is-at-top {\n      top: 0;\n    }\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n\n  .sticky.is-anchored {\n    position: relative;\n    right: auto;\n    left: auto;\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group title-bar\n////\n\n/// Background color of a title bar.\n/// @type Color\n$titlebar-background: $black !default;\n\n/// Color of text inside a title bar.\n/// @type Color\n$titlebar-color: $white !default;\n\n/// Padding inside a title bar.\n/// @type Length\n$titlebar-padding: 0.5rem !default;\n\n/// Font weight of text inside a title bar.\n/// @type Weight\n$titlebar-text-font-weight: bold !default;\n\n/// Color of menu icons inside a title bar.\n/// @type Color\n$titlebar-icon-color: $white !default;\n\n/// Color of menu icons inside a title bar on hover.\n/// @type Color\n$titlebar-icon-color-hover: $medium-gray !default;\n\n/// Spacing between the menu icon and text inside a title bar.\n/// @type Length\n$titlebar-icon-spacing: 0.25rem !default;\n\n@mixin foundation-title-bar {\n  .title-bar {\n    padding: $titlebar-padding;\n    background: $titlebar-background;\n    color: $titlebar-color;\n\n    @if $global-flexbox {\n      display: flex;\n      justify-content: flex-start;\n      align-items: center;\n    }\n    @else {\n      @include clearfix;\n    }\n\n    .menu-icon {\n      margin-#{$global-left}: $titlebar-icon-spacing;\n      margin-#{$global-right}: $titlebar-icon-spacing;\n    }\n  }\n\n  @if $global-flexbox {\n    .title-bar-left,\n    .title-bar-right {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n\n    .title-bar-right {\n      text-align: right;\n    }\n  }\n  @else {\n    .title-bar-left {\n      float: left;\n    }\n\n    .title-bar-right {\n      float: right;\n      text-align: right;\n    }\n  }\n\n  .title-bar-title {\n    display: inline-block;\n    vertical-align: middle;\n    font-weight: $titlebar-text-font-weight;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group top-bar\n////\n\n/// Padding for the top bar.\n/// @type Number\n$topbar-padding: 0.5rem !default;\n\n/// Background color for the top bar. This color also cascades to menus within the top bar.\n/// @type Color\n$topbar-background: $light-gray !default;\n\n/// Background color submenus within the top bar. Usefull if $topbar-background is transparent.\n/// @type Color\n$topbar-submenu-background: $topbar-background !default;\n\n/// Spacing for the top bar title.\n/// @type Number\n$topbar-title-spacing: 0.5rem 1rem 0.5rem 0 !default;\n\n/// Maximum width of `<input>` elements inside the top bar.\n/// @type Number\n$topbar-input-width: 200px !default;\n\n/// Breakpoint at which top bar switches from mobile to desktop view.\n/// @type Breakpoint\n$topbar-unstack-breakpoint: medium !default;\n\n/// Adds styles for a top bar container.\n@mixin top-bar-container {\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    justify-content: space-between;\n    align-items: center;\n  }\n  @else {\n    @include clearfix;\n  }\n\n  padding: $topbar-padding;\n\n  &,\n  ul {\n    background-color: $topbar-background;\n  }\n\n  // Check if $topbar-background is differnt from $topbar-background-submenu\n  @if ($topbar-background != $topbar-submenu-background) {\n    ul ul {\n      background-color: $topbar-submenu-background;\n    }\n  }\n\n  // Restrain width of inputs by default to make them easier to arrange\n  input {\n    max-width: $topbar-input-width;\n    margin-#{$global-right}: 1rem;\n  }\n\n  // The above styles shouldn't apply to input group fields\n  .input-group-field {\n    width: 100%;\n    margin-#{$global-right}: 0;\n  }\n\n  input.button { // sass-lint:disable-line no-qualifying-elements\n    width: auto;\n  }\n}\n\n/// Makes sections of a top bar stack on top of each other.\n@mixin top-bar-stacked {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 100%;\n      max-width: 100%;\n    }\n  }\n  @else {\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      width: 100%;\n    }\n  }\n}\n\n/// Undoes the CSS applied by the `top-bar-stacked()` mixin.\n@mixin top-bar-unstack {\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n\n    .top-bar-left {\n      flex: 1 1 auto;\n      margin-right: auto;\n    }\n\n    .top-bar-right {\n      flex: 0 1 auto;\n      margin-left: auto;\n    }\n  }\n  @else {\n    .top-bar-left,\n    .top-bar-right {\n      width: auto;\n    }\n  }\n}\n\n@mixin foundation-top-bar {\n  // Top bar container\n  .top-bar {\n    @include top-bar-container;\n\n    // Stack on small screens by default\n    @include top-bar-stacked;\n\n    @include breakpoint($topbar-unstack-breakpoint) {\n      @include top-bar-unstack;\n    }\n\n    // Generate classes for stacking on each screen size (defined in $breakpoint-classes)\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        &.stacked-for-#{$size} {\n          @include breakpoint($size down) {\n            @include top-bar-stacked;\n          }\n        }\n      }\n    }\n  }\n\n  // Sub-sections\n  @if $global-flexbox {\n    .top-bar-title {\n      flex: 0 0 auto;\n      margin: $topbar-title-spacing;\n    }\n\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 auto;\n    }\n  }\n  @else {\n    .top-bar-title {\n      display: inline-block;\n      float: left;\n      padding: $topbar-title-spacing;\n\n      .menu-icon {\n        bottom: 2px;\n      }\n    }\n\n    .top-bar-left {\n      float: left;\n    }\n\n    .top-bar-right {\n      float: right;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group float\n////\n\n@mixin foundation-float-classes {\n  .float-left {\n    float: left !important;\n  }\n\n  .float-right {\n    float: right !important;\n  }\n\n  .float-center {\n    display: block;\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  .clearfix {\n    @include clearfix;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group Flexbox Utilities\n////\n//\n/// Default value for the count of source ordering`\n/// @type Number\n$flex-source-ordering-count: 6 !default;\n\n/// Quickly disable/enable Responsive breakpoints for Vanilla Flex Helpers.\n/// @type Boolean\n$flexbox-responsive-breakpoints: true !default;\n\n@mixin flex-helpers {\n  .flex-container {\n    @include flex;\n  }\n\n  .flex-child-auto {\n    flex: 1 1 auto;\n  }\n\n  .flex-child-grow {\n    flex: 1 0 auto;\n  }\n\n  .flex-child-shrink {\n    flex: 0 1 auto;\n  }\n\n  @each $dir, $prop in $-zf-flex-direction {\n    .flex-dir-#{$dir} {\n      @include flex-direction($prop);\n    }\n  }\n\n  @if ($flexbox-responsive-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-flex-container {\n            @include flex;\n          }\n\n          .#{$size}-flex-child-auto {\n            flex: 1 1 auto;\n          }\n\n          .#{$size}-flex-child-grow {\n            flex: 1 0 auto;\n          }\n\n          .#{$size}-flex-child-shrink {\n            flex: 0 1 auto;\n          }\n\n          @each $dir, $prop in $-zf-flex-direction {\n            .#{$size}-flex-dir-#{$dir} {\n              @include flex-direction($prop);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n@mixin foundation-flex-classes {\n  // Horizontal alignment using justify-content\n  @each $hdir, $prop in $-zf-flex-justify {\n    .align-#{$hdir} {\n      @include flex-align($x: $hdir);\n    }\n  }\n  \n  // Horizontal alignment Specifically for Vertical Menu\n  @each $hdir, $prop in map-remove($-zf-flex-justify, 'justify', 'spaced') {\n    .align-#{$hdir} {\n      &.vertical {\n        &.menu > li > a {\n          @include flex-align($x: $hdir);\n        }\n      }\n    }\n  }\n\n  // Vertical alignment using align-items and align-self\n  @each $vdir, $prop in $-zf-flex-align {\n    .align-#{$vdir} {\n      @include flex-align($y: $vdir);\n    }\n\n    .align-self-#{$vdir} {\n      @include flex-align-self($y: $vdir);\n    }\n  }\n\n  // Central alignment of content\n  .align-center-middle {\n    @include flex-align($x: center, $y: middle);\n    align-content: center;\n  }\n\n  // Source ordering\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $flex-source-ordering-count {\n      .#{$-zf-size}-order-#{$i} {\n        @include flex-order($i);\n      }\n    }\n  }\n\n  // Vanilla Flexbox Helpers\n  @include flex-helpers;\n}\n","@function -zf-flex-justify($text-direction){\n  $-zf-flex-justify: (\n    'left': if($text-direction == rtl, flex-end, flex-start),\n    'right': if($text-direction == rtl, flex-start, flex-end),\n    'center': center,\n    'justify': space-between,\n    'spaced': space-around,\n  );\n\n  @return $-zf-flex-justify;\n}\n\n\n$-zf-flex-align: (\n  'top': flex-start,\n  'bottom': flex-end,\n  'middle': center,\n  'stretch': stretch,\n);\n\n$-zf-flex-direction: (\n  'row': row,\n  'row-reverse': row-reverse,\n  'column': column,\n  'column-reverse': column-reverse,\n);\n\n/// Enables flexbox by adding `display: flex` to the element.\n@mixin flex {\n  display: flex;\n}\n\n/// Horizontally or vertically aligns the items within a flex container.\n///\n/// @param {Keyword} $x [null] - Horizontal alignment to use. Can be `left`, `right`, `center`, `justify`, or `spaced`. Or, set it to `null` (the default) to not set horizontal alignment.\n/// @param {Keyword} $y [null] - Vertical alignment to use. Can be `top`, `bottom`, `middle`, or `stretch`. Or, set it to `null` (the default) to not set vertical alignment.\n@mixin flex-align($x: null, $y: null) {\n  @if $x {\n    @if map-has-key($-zf-flex-justify, $x) {\n      $x: map-get($-zf-flex-justify, $x);\n    }\n    @else {\n      @warn 'flex-grid-row-align(): #{$x} is not a valid value for horizontal alignment. Use left, right, center, justify, or spaced.';\n    }\n  }\n\n  @if $y {\n    @if map-has-key($-zf-flex-align, $y) {\n      $y: map-get($-zf-flex-align, $y);\n    }\n    @else {\n      @warn 'flex-grid-row-align(): #{$y} is not a valid value for vertical alignment. Use top, bottom, middle, or stretch.';\n    }\n  }\n\n  justify-content: $x;\n  align-items: $y;\n}\n\n/// Vertically align a single column within a flex row. Apply this mixin to a flex column.\n///\n/// @param {Keyword} $y [null] - Vertical alignment to use. Can be `top`, `bottom`, `middle`, or `stretch`. Or, set it to `null` (the default) to not set vertical alignment.\n@mixin flex-align-self($y: null) {\n  @if $y {\n    @if map-has-key($-zf-flex-align, $y) {\n      $y: map-get($-zf-flex-align, $y);\n    }\n    @else {\n      @warn 'flex-grid-column-align(): #{$y} is not a valid value for alignment. Use top, bottom, middle, or stretch.';\n    }\n  }\n\n  align-self: $y;\n}\n\n/// Changes the source order of a flex child. Children with lower numbers appear first in the layout.\n/// @param {Number} $order [0] - Order number to apply.\n@mixin flex-order($order: 0) {\n  order: $order;\n}\n\n/// Change flex-direction\n/// @param {Keyword} $direction [row] - Flex direction to use. Can be\n///   - row (default): same as text direction\n///   - row-reverse: opposite to text direction\n///   - column: same as row but top to bottom\n///   - column-reverse: same as row-reverse top to bottom\n@mixin flex-direction($direction: row) {\n  flex-direction: $direction;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// Hide an element by default, only displaying it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for($size) {\n  $size: map-get($breakpoints, $size);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/zurb/foundation-sites/issues/11313\n  $size: -zf-bp-to-em($size) - .00125;\n\n  @include breakpoint($size down) {\n    display: none !important;\n  }\n}\n\n/// Hide an element by default, only displaying it within a certain breakpoint.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for-only($size) {\n  $lower-bound-size: map-get($breakpoints, $size);\n  $upper-bound-size: -zf-map-next($breakpoints, $size);\n\n  // more often than not this will be correct, just one time round the loop it won't so set in scope here\n  $lower-bound: -zf-bp-to-em($lower-bound-size) - .00125;\n  // test actual lower-bound-size, if 0 set it to 0em\n  @if strip-unit($lower-bound-size) == 0 {\n    $lower-bound: -zf-bp-to-em($lower-bound-size);\n  }\n\n  @if $upper-bound-size == null {\n    @media screen and (max-width: $lower-bound) {\n      display: none !important;\n    }\n  }\n  @else {\n    $upper-bound: -zf-bp-to-em($upper-bound-size);\n\n    @media screen and (max-width: $lower-bound), screen and (min-width: $upper-bound) {\n      display: none !important;\n    }\n  }\n}\n\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for($size) {\n  @include breakpoint($size) {\n    display: none !important;\n  }\n}\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for-only($size) {\n  @include breakpoint($size only) {\n    display: none !important;\n  }\n}\n\n@mixin foundation-visibility-classes {\n  // Basic hiding classes\n  .hide {\n    display: none !important;\n  }\n\n  .invisible {\n    visibility: hidden;\n  }\n\n  // Responsive visibility classes\n  @each $size in $breakpoint-classes {\n    @if $size != $-zf-zero-breakpoint {\n      .hide-for-#{$size} {\n        @include hide-for($size);\n      }\n\n      .show-for-#{$size} {\n        @include show-for($size);\n      }\n    }\n\n    .hide-for-#{$size}-only {\n      @include hide-for-only($size);\n    }\n\n    .show-for-#{$size}-only {\n      @include show-for-only($size);\n    }\n  }\n\n  // Screen reader visibility classes\n  // Need a \"hide-for-sr\" class? Add aria-hidden='true' to the element\n  .show-for-sr,\n  .show-on-focus {\n    @include element-invisible;\n  }\n\n  // Only display the element when it's focused\n  .show-on-focus {\n    &:active,\n    &:focus {\n      @include element-invisible-off;\n    }\n  }\n\n  // Landscape and portrait visibility\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: block !important;\n\n    @include breakpoint(landscape) {\n      display: block !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: none !important;\n    }\n  }\n\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: none !important;\n\n    @include breakpoint(landscape) {\n      display: none !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: block !important;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-text-utilities\n////\n\n/// Responsive breakpoints for text utilities\n/// @type Boolean\n$prototype-utilities-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default Value for `text-overflow` variable\n/// @type String\n$prototype-text-overflow: ellipsis !default;\n\n/// Image Replacement utility. `text-hide`\n@mixin text-hide {\n  font: 0/0 a !important;\n  color: transparent !important;\n  text-shadow: none !important;\n  background-color: transparent !important;\n  border: 0 !important;\n}\n\n/// Truncating the text, elipsis by default.\n/// @param {String} $overflow [$prototype-text-overflow] Text Truncate\n@mixin text-truncate(\n  $overflow: $prototype-text-overflow\n) {\n  max-width: 100% !important;\n  overflow: hidden !important;\n  text-overflow: $overflow; \n  white-space: nowrap !important;\n}\n\n/// No wrapping of the text. `text-nowrap`\n@mixin text-nowrap {\n  white-space: nowrap !important;\n}\n\n/// Wrapping of the text. `text-wrap`\n@mixin text-wrap {\n  word-wrap: break-word !important;\n}\n\n@mixin foundation-prototype-text-utilities {\n  .text-hide {\n    @include text-hide;\n  }\n\n  .text-truncate {\n    @include text-truncate;\n  }\n\n  .text-nowrap {\n    @include text-nowrap;\n  }\n\n  .text-wrap {\n    @include text-wrap;\n  }\n\n  @if ($prototype-utilities-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-text-hide {\n            @include text-hide;\n          }\n\n          .#{$size}-text-truncate {\n            @include text-truncate;\n          }\n\n          .#{$size}-text-nowrap {\n            @include text-nowrap;\n          }\n\n          .#{$size}-text-wrap {\n            @include text-wrap;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-text-transformation\n////\n\n/// Responsive breakpoints for text transformation classes\n/// @type Boolean\n$prototype-transformation-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `text-transformation` classes\n/// @type Map\n$prototype-text-transformation: (\n  lowercase,\n  uppercase,\n  capitalize\n) !default;\n\n/// Text Transformation, by default coming through a map `$prototype-text-transformation`\n/// @param {String} $transformation [] Text Transformation\n@mixin text-transform($transformation) {\n  text-transform: $transformation !important;\n}\n\n@mixin foundation-prototype-text-transformation {\n  @each $transformation in $prototype-text-transformation {\n    .text-#{$transformation} {\n      @include text-transform($transformation);\n    }\n  }\n\n  @if ($prototype-transformation-breakpoints) {\n    // Loop through Responsive Breakpoints\n  \t@each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $transformation in $prototype-text-transformation {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-text-#{$transformation} {\n  \t\t\t      @include text-transform($transformation);\n  \t\t\t    }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-text-decoration\n////\n\n/// Responsive breakpoints for text decoration classes\n/// @type Boolean\n$prototype-decoration-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `text-decoration` classes\n/// @type Map\n$prototype-text-decoration: (\n  overline,\n  underline,\n  line-through,\n) !default;\n\n/// Text Decoration, by default coming through a map `$prototype-text-decoration`\n/// @param {String} $decoration [] Text Decoration\n@mixin text-decoration($decoration) {\n  text-decoration: $decoration !important;\n}\n\n@mixin foundation-prototype-text-decoration {\n  @each $decoration in $prototype-text-decoration {\n    .text-#{$decoration} {\n      @include text-decoration($decoration);\n    }\n  }\n\n  @if ($prototype-decoration-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $decoration in $prototype-text-decoration {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-text-#{$decoration} {\n              @include text-decoration($decoration);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-font-styling\n////\n\n/// Responsive breakpoints for font styling types\n/// @type Boolean\n$prototype-font-breakpoints: $global-prototype-breakpoints !default;\n\n/// Letter spacing for `.font-wide`\n/// @type Number\n$prototype-wide-letter-spacing: rem-calc(4) !default;\n\n/// Default weight for `.font-normal`, defaulted to `global-weight-normal`\n/// @type Number\n$prototype-font-normal: $global-weight-normal !default;\n\n/// Default weight for `.font-bold`, defaulted to `global-weight-bold`\n/// @type Number\n$prototype-font-bold: $global-weight-bold !default;\n\n/// Font wide letter spacing!\n/// @param {Number} $letter-spacing [$prototype-wide-letter-spacing] Wide letter spacing for the font\n@mixin font-wide(\n  $letter-spacing: $prototype-wide-letter-spacing\n) {\n  letter-spacing: $letter-spacing;\n}\n\n/// Font Weight Normal, default value coming through `global-weight-normal`\n/// @param {Number} $weight [$prototype-font-normal] Weight of the font (normal)\n@mixin font-normal(\n  $weight: $prototype-font-normal\n) {\n  font-weight: $weight;\n}\n\n/// Font Weight Bold, default value coming through `global-weight-bold`\n/// @param {Number} $weight [$prototype-font-bold] Weight of the font (bold)\n@mixin font-bold(\n  $weight: $prototype-font-bold\n) {\n  font-weight: $weight;\n}\n\n/// Font Style Italic\n@mixin font-italic {\n  font-style: italic !important;\n}\n\n@mixin foundation-prototype-font-styling {\n  .font-wide{\n    @include font-wide;\n  }\n\n  .font-normal {\n    @include font-normal;\n  }\n\n  .font-bold {\n    @include font-bold;\n  }\n\n  .font-italic {\n    @include font-italic;\n  }\n\n  @if ($prototype-font-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-font-wide{\n            @include font-wide;\n          }\n\n          .#{$size}-font-normal {\n            @include font-normal;\n          }\n\n          .#{$size}-font-bold {\n            @include font-bold;\n          }\n\n          .#{$size}-font-italic {\n            @include font-italic;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-list-style-type\n////\n\n/// Responsive breakpoints for list styling types\n/// @type Boolean\n$prototype-list-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `style-type-unordered` classes\n/// @type Map\n$prototype-style-type-unordered: (\n  disc,\n  circle,\n  square\n) !default;\n\n/// Map containing all the `style-type-ordered` classes\n/// @type Map\n$prototype-style-type-ordered: (\n  decimal,\n  lower-alpha,\n  lower-latin,\n  lower-roman,\n  upper-alpha,\n  upper-latin,\n  upper-roman\n) !default;\n\n\n/// Style type for unordered Lists, by default coming through a map `$prototype-style-type-unordered`\n/// @param {String} $style-type-unordered [] Style type for unordered Lists\n@mixin style-type-unordered($style-type-unordered) {\n  list-style-type: $style-type-unordered !important;\n}\n\n/// Style type for ordered Lists, by default coming through a map `$prototype-style-type-ordered`\n/// @param {String} $style-type-ordered [] Style type for ordered Lists\n@mixin style-type-ordered($style-type-ordered) {\n  list-style-type: $style-type-ordered !important;\n}\n\n@mixin list-unordered {\n  @each $style-type-unordered in $prototype-style-type-unordered {\n    ul.list-#{$style-type-unordered} {\n      @include style-type-unordered($style-type-unordered);\n    }\n  }\n\n  @if ($prototype-list-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $style-type-unordered in $prototype-style-type-unordered {\n          @if $size != $-zf-zero-breakpoint {\n            ul.#{$size}-list-#{$style-type-unordered} {\n              @include style-type-unordered($style-type-unordered);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n@mixin list-ordered {\n  @each $style-type-ordered in $prototype-style-type-ordered {\n    ol.list-#{$style-type-ordered} {\n      @include style-type-ordered($style-type-ordered);\n    }\n  }\n\n  @if ($prototype-list-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $style-type-ordered in $prototype-style-type-ordered {\n          @if $size != $-zf-zero-breakpoint {\n            ol.#{$size}-list-#{$style-type-ordered} {\n              @include style-type-ordered($style-type-ordered);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n@mixin foundation-prototype-list-style-type {\n  @include list-unordered;\n  @include list-ordered;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-rounded\n////\n\n/// Responsive breakpoints for rounded utility.\n/// @type Boolean\n$prototype-rounded-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default value for `prototype-border-radius`\n/// @type Number\n$prototype-border-radius: rem-calc(3) !default;\n\n/// Rounded utility (all corners): Adds radius corners (all corners) to an element by default.\n/// @param {Number} $radius [$prototype-border-radius] Border radius (all corners)\n@mixin border-radius(\n  $radius: $prototype-border-radius\n) {\n  border-radius: $radius;\n}\n\n/// Rounded square utility or rectangle utility (all corners): Rounds all corners to an element by default to make a pill shape.\n@mixin border-rounded {\n  border-radius: 5000px !important;\n}\n\n@mixin foundation-prototype-rounded {\n  .rounded {\n    @include border-rounded;\n    &:after {\n      border-radius: 50%; // For switches\n    }\n  }\n\n  .radius {\n    @include border-radius;\n  }\n\n  @if ($prototype-rounded-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-rounded {\n            @include border-rounded;\n          }\n          .#{$size}-radius {\n            @include border-radius;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-bordered\n////\n\n/// Responsive breakpoints for bordered utility.\n/// @type Boolean\n$prototype-bordered-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default value for `prototype-border-width`\n/// @type Number\n$prototype-border-width: rem-calc(1) !default;\n\n/// Default value for `prototype-border-type`\n/// @type String\n$prototype-border-type: solid !default;\n\n/// Default value for `prototype-border-color` defaulted to `medium-gray`\n/// @type Color\n$prototype-border-color: $medium-gray !default;\n\n/// Bordered Utility: Adds a light border to an element by default.\n/// @param {Number} $width [$prototype-border-width] Width of the border\n/// @param {String} $type [$prototype-border-type] Type of the border\n/// @param {Color} $color [$prototype-border-color] Color of the border\n@mixin bordered(\n  $width: $prototype-border-width,\n  $type: $prototype-border-type,\n  $color: $prototype-border-color\n) {\n  border: $width $type $color;\n}\n\n@mixin foundation-prototype-bordered {\n  .bordered {\n    @include bordered;\n  }\n\n  @if ($prototype-bordered-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-bordered {\n            @include bordered;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-shadow\n////\n\n/// Responsive breakpoints for shadow utility.\n/// @type Boolean\n$prototype-shadow-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default value for `prototype-box-shadow`\n/// @type Number\n$prototype-box-shadow: 0 2px 5px 0 rgba(0,0,0,.16),\n                       0 2px 10px 0 rgba(0,0,0,.12) !default;\n\n/// Shadow Utility: Adds a light box shadow to an element by default.\n/// @param {Number} $shadow [$prototype-box-shadow] Box Shadow of a component\n@mixin shadow(\n  $shadow: $prototype-box-shadow\n) {\n  box-shadow: $shadow;\n}\n\n@mixin foundation-prototype-shadow {\n  .shadow {\n    @include shadow;\n  }\n\n  @if ($prototype-shadow-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-shadow {\n            @include shadow;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-arrow\n////\n\n/// Map containing all the `arrow` direction\n/// @type Map\n$prototype-arrow-directions: (\n  down,\n  up,\n  right,\n  left\n) !default;\n\n/// Width of the Arrow, `0.4375rem` by default.\n/// @type Number\n$prototype-arrow-size: 0.4375rem;\n\n/// Color of the Arrow, `$black` by default.\n/// @type Color\n$prototype-arrow-color: $black;\n\n@mixin foundation-prototype-arrow {\n  @each $prototype-arrow-direction in $prototype-arrow-directions {\n    .arrow-#{$prototype-arrow-direction} {\n      @include css-triangle(\n        $prototype-arrow-size, \n        $prototype-arrow-color, \n        $prototype-arrow-direction\n      );\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-separator\n////\n\n/// Responsive breakpoints for separator.\n/// @type Boolean\n$prototype-separator-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default alignment of a separator.\n/// @type String\n$prototype-separator-align: center !default;\n\n/// Height of a separator.\n/// @type Number\n$prototype-separator-height: rem-calc(2) !default;\n\n/// Width of a separator.\n/// @type Number\n$prototype-separator-width: 3rem !default;\n\n/// Default color of a separator.\n/// @type Color\n$prototype-separator-background: $primary-color !default;\n\n/// Top Margin of a separator.\n/// @type Number\n$prototype-separator-margin-top: $global-margin !default;\n\n/// Title separator Utility, mostly used to style the main heading of a section\n/// @param {String} $align [$prototype-separator-align] - separator Alignment\n/// @param {Number} $height [$prototype-separator-height] - Width\n/// @param {Number} $width [$prototype-separator-width] - Height\n/// @param {Color} $background [$prototype-separator-background] - Background\n/// @param {Number} $top [$prototype-separator-margin-top] - Margin Top\n@mixin separator (\n  $align: $prototype-separator-align,\n  $height: $prototype-separator-height,\n  $width: $prototype-separator-width,\n  $background: $prototype-separator-background,\n  $top: $prototype-separator-margin-top\n) {\n  text-align: $align !important;\n\t@include clearfix;\n\n  &::after {\n    @include position(relative);\n    width: $width;\n    border-bottom: $height solid $background;\n    margin: $top auto 0;\n\n    @if $align == left {\n      margin-left: 0 !important;\n    }\n\n    @if $align == right {\n      margin-right: 0 !important;\n    }\n  }\n}\n\n@mixin foundation-prototype-separator {\n\t.separator-center {\n\t\t@include separator(center);\n\t}\n\n  .separator-left {\n    @include separator(left);\n  }\n\n  .separator-right {\n    @include separator(right);\n  }\n\n\t@if ($prototype-separator-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-separator-center {\n            @include separator(center);\n          }\n          .#{$size}-separator-left {\n            @include separator(left);\n          }\n          .#{$size}-separator-right {\n            @include separator(right);\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-position\n////\n\n/// Responsive breakpoints for position helpers\n/// @type Boolean\n$prototype-position-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `position` classes\n/// @type Map\n$prototype-position: (\n  static,\n  relative,\n  absolute,\n  fixed\n) !default;\n\n/// z-index for fixed positioning\n/// @type Number\n$prototype-position-z-index: 975 !default;\n\n/// Position classes, by default coming through a map `$prototype-position`, whereas all the offset values are multiplied by `$global-position` which by default is equal to `1rem`.\n/// @param {String} $position [] Position classes, Either `static`, `relative`, `absolute` or `fixed`\n/// @param {Number} $top [null] - Top offset\n/// @param {Number} $right [null] - Right offset\n/// @param {Number} $bottom [null] - Bottom offset\n/// @param {Number} $left [null] - Left offset\n@mixin position(\n  $position,\n  $top: null,\n  $right: null,\n  $bottom: null,\n  $left: null\n) {\n  position: $position !important;\n  @if $top != null {\n    top: $top * $global-position !important;\n  }\n  @if $right != null {\n    right: $right * $global-position !important;\n  }\n  @if $bottom != null {\n    bottom: $bottom * $global-position !important;\n  }\n  @if $left != null {\n    left: $left * $global-position !important;\n  }\n}\n\n/// Position Fixed on top corners\n/// @param {Number} $z-index [$prototype-position-z-index] z-index for `position-fixed-top`\n@mixin position-fixed-top(\n  $z-index: $prototype-position-z-index\n) {\n  @include position(fixed, 0, 0, null, 0);\n  z-index: $z-index;\n}\n\n/// Position Fixed on bottom corners\n/// @param {Number} $z-index [$prototype-position-z-index] z-index for `position-fixed-bottom`\n@mixin position-fixed-bottom(\n  $z-index: $prototype-position-z-index\n) {\n  @include position(fixed, null, 0, 0, 0);\n  z-index: $z-index;\n}\n\n@mixin foundation-prototype-position {\n  // Position: Static, Relative, Fixed, Absolute\n  @each $position in $prototype-position {\n    .position-#{$position} {\n      @include position($position);\n    }\n  }\n\n  // Position: Fixed Top, Fixed Bottom\n  .position-fixed-top {\n    @include position-fixed-top;\n  }\n  .position-fixed-bottom {\n    @include position-fixed-bottom;\n  }\n\n  @if ($prototype-position-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        // Position: Static, Relative, Fixed, Absolute\n        @each $position in $prototype-position {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-position-#{$position} {\n              @include position($position);\n            }\n          }\n        }\n\n        // Position: Fixed Top, Fixed Bottom\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-position-fixed-top {\n            @include position-fixed-top;\n          }\n\n          .#{$size}-position-fixed-bottom {\n            @include position-fixed-bottom;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-overflow\n////\n\n/// Responsive breakpoints for overflow helper classes\n/// @type Boolean\n$prototype-overflow-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `overflow` classes\n/// @type Map\n$prototype-overflow: (\n  visible,\n  hidden,\n  scroll\n) !default;\n\n/// Overflow classes, by default coming through a map `$prototype-overflow`\n/// @param {String} $overflow [] Overflow classes\n@mixin overflow($overflow) {\n  overflow: $overflow !important;\n}\n\n/// Overflow classes on horizontal axis, by default coming through a map `$prototype-overflow`\n/// @param {String} $overflow [] Overflow classes (horizontal axis)\n@mixin overflow-x($overflow) {\n  overflow-x: $overflow !important;\n}\n\n/// Overflow classes on vertical axis, by default coming through a map `$prototype-overflow`\n/// @param {String} $overflow [] Overflow classes (vertical axis)\n@mixin overflow-y($overflow) {\n  overflow-y: $overflow !important;\n}\n\n@mixin foundation-prototype-overflow {\n  @each $overflow in $prototype-overflow {\n    .overflow-#{$overflow} {\n      @include overflow($overflow);\n    }\n    .overflow-x-#{$overflow} {\n      @include overflow-x($overflow);\n    }\n    .overflow-y-#{$overflow} {\n      @include overflow-y($overflow);\n    }\n  }\n\n  @if ($prototype-overflow-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $overflow in $prototype-overflow {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-overflow-#{$overflow} {\n              @include overflow($overflow);\n            }\n            .#{$size}-overflow-x-#{$overflow} {\n              @include overflow-x($overflow);\n            }\n            .#{$size}-overflow-y-#{$overflow} {\n              @include overflow-y($overflow);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-display\n////\n\n/// Responsive breakpoints for display classes\n/// @type Boolean\n$prototype-display-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `display` classes\n/// @type Map\n$prototype-display: (\n  inline,\n  inline-block,\n  block,\n  table,\n  table-cell\n) !default;\n\n/// Display classes, by default coming through a map `$prototype-display`\n/// @param {String} $display [] Display classes\n@mixin display($display) {\n  display: $display !important;\n}\n\n@mixin foundation-prototype-display {\n  @each $display in $prototype-display {\n    .display-#{$display} {\n      @include display($display);\n    }\n  }\n\n  @if ($prototype-display-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @each $display in $prototype-display {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size}-display-#{$display} {\n              @include display($display);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-border-box\n////\n\n/// Responsive breakpoints for border box.\n/// @type Boolean\n$prototype-border-box-breakpoints: $global-prototype-breakpoints !default;\n\n/// Border box utility\n@mixin border-box {\n  box-sizing: border-box !important;\n}\n\n@mixin foundation-prototype-border-box {\n  .border-box {\n    @include border-box;\n  }\n\n  @if ($prototype-border-box-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-border-box {\n            @include border-box;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-border-none\n////\n\n/// Responsive breakpoints for border none.\n/// @type Boolean\n$prototype-border-none-breakpoints: $global-prototype-breakpoints !default;\n\n/// Border none utility\n@mixin border-none {\n  border: none !important;\n}\n\n@mixin foundation-prototype-border-none {\n  .border-none {\n    @include border-none;\n  }\n\n  @if ($prototype-border-none-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-border-none {\n            @include border-none;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-sizing\n////\n\n/// Responsive breakpoints for spacing classes (margin and padding)\n/// @type Boolean\n$prototype-sizing-breakpoints: $global-prototype-breakpoints !default;\n\n/// Map containing all the `sizing` classes\n/// @type Map\n$prototype-sizing: (\n  width,\n  height\n) !default;\n\n/// Map containing all the sizes.\n/// @type Map\n$prototype-sizes: (\n  25: 25%,\n  50: 50%,\n  75: 75%,\n  100: 100%\n) !default;\n\n/// Max Width 100 utility.\n@mixin max-width-100 {\n  max-width: 100% !important;\n}\n\n/// Max Height 100 utility.\n@mixin max-height-100 {\n  max-height: 100% !important;\n}\n\n@mixin foundation-prototype-sizing {\n  // Element Sizing\n  @each $sizing in $prototype-sizing {\n    @each $length, $percentage in $prototype-sizes {\n      .#{$sizing}-#{$length} {\n        #{$sizing}: $percentage !important;\n      }\n    }\n  }\n\n  // Max width & height\n  .max-width-100 {\n    @include max-width-100;\n  }\n  .max-height-100 {\n    @include max-height-100;\n  }\n\n  @if ($prototype-sizing-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          @each $sizing in $prototype-sizing {\n            @each $length, $percentage in $prototype-sizes {\n              .#{$size}-#{$sizing}-#{$length} {\n                #{$sizing}: $percentage !important;\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group prototype-spacing\n////\n\n/// Responsive breakpoints for spacing classes (margin and padding)\n/// @type Boolean\n$prototype-spacing-breakpoints: $global-prototype-breakpoints !default;\n\n/// Default number of spacers count (margin and padding)\n/// @type Number\n$prototype-spacers-count: 3 !default;\n\n/// Margin helper mixin, all the values are multiplied by `$global-margin` which by default is equal to `1rem`\n/// @param {Number} $top [null] - Margin Top\n/// @param {Number} $right [null] - Margin Right\n/// @param {Number} $bottom [null] - Margin Bottom\n/// @param {Number} $left [null] - Margin Left\n@mixin margin(\n  $top: null,\n  $right: null,\n  $bottom: null,\n  $left: null\n) {\n  @if $top != null {\n    margin-top: $top * $global-margin !important;\n  }\n  @if $right != null {\n    margin-right: $right * $global-margin !important;\n  }\n  @if $bottom != null {\n    margin-bottom: $bottom * $global-margin !important;\n  }\n  @if $left != null {\n    margin-left: $left * $global-margin !important;\n  }\n}\n\n/// Padding helper mixin, all the values are multiplied by `$global-padding` which by default is equal to `1rem`\n/// @param {Number} $top [null] - Padding Top\n/// @param {Number} $right [null] - Padding Right\n/// @param {Number} $bottom [null] - Padding Bottom\n/// @param {Number} $left [null] - Padding Left\n@mixin padding(\n  $top: null,\n  $right: null,\n  $bottom: null,\n  $left: null\n) {\n  @if $top != null {\n    padding-top: $top * $global-padding !important;\n  }\n  @if $right != null {\n    padding-right: $right * $global-padding !important;\n  }\n  @if $bottom != null {\n    padding-bottom: $bottom * $global-padding !important;\n  }\n  @if $left != null {\n    padding-left: $left * $global-padding !important;\n  }\n}\n\n/// Margin classes for specific direction properties\n/// @param {String} $dir [] Direction\n/// @param {Number} $spacer [] Spacer\n@mixin margin-direction($dir, $spacer) {\n  @if ($dir == top) { \n    @include margin($top: $spacer); \n  }\n  @else if ($dir == right) { \n    @include margin($right: $spacer); \n  }\n  @else if ($dir == bottom) { \n    @include margin($bottom: $spacer); \n  }\n  @else if ($dir == left) { \n    @include margin($left: $spacer); \n  }\n  @else if ($dir == horizontal) { \n    @include margin($right: $spacer, $left: $spacer); \n  }\n  @else if ($dir == vertical) { \n    @include margin($top: $spacer, $bottom: $spacer); \n  }\n}\n\n/// Padding classes for specific direction properties\n/// @param {String} $dir [] Direction\n/// @param {Number} $spacer [] Spacer\n@mixin padding-direction($dir, $spacer) {\n  @if ($dir == top) { \n    @include padding($top: $spacer); \n  }\n  @else if ($dir == right) { \n    @include padding($right: $spacer); \n  }\n  @else if ($dir == bottom) { \n    @include padding($bottom: $spacer); \n  }\n  @else if ($dir == left) { \n    @include padding($left: $spacer); \n  }\n  @else if ($dir == horizontal) { \n    @include padding($right: $spacer, $left: $spacer); \n  }\n  @else if ($dir == vertical) { \n    @include padding($top: $spacer, $bottom: $spacer); \n  }\n}\n\n@mixin foundation-prototype-spacing {\n  @for $spacer from 0 through $prototype-spacers-count {\n    \n    @each $prop in (margin, padding) {\n      // All Sides\n      .#{$prop}-#{$spacer} {\n        @if ($prop == margin) { \n          margin: $spacer * $global-margin; \n        }\n        @else if ($prop == padding) { \n          padding: $spacer * $global-padding; \n        }\n      }\n\n      @each $dir in (top, right, bottom, left, horizontal, vertical) {\n        // Top Side\n        .#{$prop}-#{$dir}-#{$spacer} {\n          @if ($prop == margin) { \n            @include margin-direction($dir, $spacer);\n          }\n          @else if ($prop == padding) {\n            @include padding-direction($dir, $spacer);\n          }\n        }\n      }\n    }\n\n    @if ($prototype-spacing-breakpoints) {\n    // Loop through Responsive Breakpoints\n      @each $size in $breakpoint-classes {\n        @include breakpoint($size) {\n          @if $size != $-zf-zero-breakpoint {\n            .#{$size} {\n              @each $prop in (margin, padding) {\n                // All Sides\n                &-#{$prop}-#{$spacer} {\n                  @if ($prop == margin) { \n                    margin: $spacer * $global-margin; \n                  }\n                  @else if ($prop == padding) { \n                    padding: $spacer * $global-padding; \n                  }\n                }\n\n                @each $dir in (top, right, bottom, left, horizontal, vertical) {\n                  // Top Side\n                  &-#{$prop}-#{$dir}-#{$spacer} {\n                    @if ($prop == margin) { \n                      @include margin-direction($dir, $spacer);\n                    }\n                    @else if ($prop == padding) { \n                      @include padding-direction($dir, $spacer);\n                    }\n                  }\n                }\n              }\n            }\n          }\n        }\n      }\n    }\n  }\n}\n"]}
\ No newline at end of file
index 8a6ee5ff5dbc669380797e8c8b7d494409f2e170..49caa6f57232564812bbe209778c76676c3720cf 100644 (file)
@@ -1 +1,2 @@
-@charset "UTF-8";@media print,screen and (min-width:40em){.reveal,.reveal.large,.reveal.small,.reveal.tiny{right:auto;left:auto;margin:0 auto}}/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */html{font-family:sans-serif;line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure{display:block}figure{margin:1em 40px}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}main{display:block}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}a:active,a:hover{outline-width:0}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}input{overflow:visible}[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{-webkit-box-sizing:border-box;box-sizing:border-box;display:table;max-width:100%;padding:0;color:inherit;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}details{display:block}summary{display:list-item}menu{display:block}canvas{display:inline-block}template{display:none}[hidden]{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{-webkit-box-sizing:border-box;box-sizing:border-box;font-size:100%}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;padding:0;background:#fefefe;font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle;max-width:100%;height:auto;-ms-interpolation-mode:bicubic}textarea{height:auto;min-height:50px;border-radius:0}select{-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;border-radius:0}.map_canvas embed,.map_canvas img,.map_canvas object,.mqa-display embed,.mqa-display img,.mqa-display object{max-width:none!important}button{padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:0;background:0 0;line-height:1;cursor:auto}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}button,input,optgroup,select,textarea{font-family:inherit}.is-visible{display:block!important}.is-hidden{display:none!important}.grid-container{padding-right:.625rem;padding-left:.625rem;max-width:75rem;margin:0 auto}@media print,screen and (min-width:40em){.grid-container{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.fluid{padding-right:.625rem;padding-left:.625rem;max-width:100%;margin:0 auto}@media print,screen and (min-width:40em){.grid-container.fluid{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.full{padding-right:0;padding-left:0;max-width:100%;margin:0 auto}.grid-x{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row wrap;-ms-flex-flow:row wrap;flex-flow:row wrap}.cell{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;min-height:0;min-width:0;width:100%}.cell.auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.cell.shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.auto{width:auto}.grid-x>.shrink{width:auto}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9,.grid-x>.small-full,.grid-x>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-full,.grid-x>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-full,.grid-x>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-x>.small-1{width:8.33333%}.grid-x>.small-2{width:16.66667%}.grid-x>.small-3{width:25%}.grid-x>.small-4{width:33.33333%}.grid-x>.small-5{width:41.66667%}.grid-x>.small-6{width:50%}.grid-x>.small-7{width:58.33333%}.grid-x>.small-8{width:66.66667%}.grid-x>.small-9{width:75%}.grid-x>.small-10{width:83.33333%}.grid-x>.small-11{width:91.66667%}.grid-x>.small-12{width:100%}@media print,screen and (min-width:40em){.grid-x>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;width:auto}.grid-x>.medium-1{width:8.33333%}.grid-x>.medium-2{width:16.66667%}.grid-x>.medium-3{width:25%}.grid-x>.medium-4{width:33.33333%}.grid-x>.medium-5{width:41.66667%}.grid-x>.medium-6{width:50%}.grid-x>.medium-7{width:58.33333%}.grid-x>.medium-8{width:66.66667%}.grid-x>.medium-9{width:75%}.grid-x>.medium-10{width:83.33333%}.grid-x>.medium-11{width:91.66667%}.grid-x>.medium-12{width:100%}}@media print,screen and (min-width:64em){.grid-x>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;width:auto}.grid-x>.large-1{width:8.33333%}.grid-x>.large-2{width:16.66667%}.grid-x>.large-3{width:25%}.grid-x>.large-4{width:33.33333%}.grid-x>.large-5{width:41.66667%}.grid-x>.large-6{width:50%}.grid-x>.large-7{width:58.33333%}.grid-x>.large-8{width:66.66667%}.grid-x>.large-9{width:75%}.grid-x>.large-10{width:83.33333%}.grid-x>.large-11{width:91.66667%}.grid-x>.large-12{width:100%}}.grid-margin-x:not(.grid-x)>.cell{width:auto}.grid-margin-y:not(.grid-y)>.cell{height:auto}.grid-margin-x{margin-left:-.625rem;margin-right:-.625rem}@media print,screen and (min-width:40em){.grid-margin-x{margin-left:-.9375rem;margin-right:-.9375rem}}.grid-margin-x>.cell{width:calc(100% - 1.25rem);margin-left:.625rem;margin-right:.625rem}@media print,screen and (min-width:40em){.grid-margin-x>.cell{width:calc(100% - 1.875rem);margin-left:.9375rem;margin-right:.9375rem}}.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.25rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.25rem)}.grid-margin-x>.small-3{width:calc(25% - 1.25rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.25rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.25rem)}.grid-margin-x>.small-6{width:calc(50% - 1.25rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.25rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.25rem)}.grid-margin-x>.small-9{width:calc(75% - 1.25rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.25rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.25rem)}.grid-margin-x>.small-12{width:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.small-3{width:calc(25% - 1.875rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.small-6{width:calc(50% - 1.875rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.small-9{width:calc(75% - 1.875rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.small-12{width:calc(100% - 1.875rem)}.grid-margin-x>.medium-auto{width:auto}.grid-margin-x>.medium-shrink{width:auto}.grid-margin-x>.medium-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.medium-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.medium-3{width:calc(25% - 1.875rem)}.grid-margin-x>.medium-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.medium-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.medium-6{width:calc(50% - 1.875rem)}.grid-margin-x>.medium-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.medium-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.medium-9{width:calc(75% - 1.875rem)}.grid-margin-x>.medium-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.medium-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.medium-12{width:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x>.large-auto{width:auto}.grid-margin-x>.large-shrink{width:auto}.grid-margin-x>.large-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.large-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.large-3{width:calc(25% - 1.875rem)}.grid-margin-x>.large-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.large-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.large-6{width:calc(50% - 1.875rem)}.grid-margin-x>.large-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.large-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.large-9{width:calc(75% - 1.875rem)}.grid-margin-x>.large-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.large-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.large-12{width:calc(100% - 1.875rem)}}.grid-padding-x .grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-padding-x .grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-container:not(.full)>.grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-container:not(.full)>.grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-padding-x>.cell{padding-right:.625rem;padding-left:.625rem}@media print,screen and (min-width:40em){.grid-padding-x>.cell{padding-right:.9375rem;padding-left:.9375rem}}.small-up-1>.cell{width:100%}.small-up-2>.cell{width:50%}.small-up-3>.cell{width:33.33333%}.small-up-4>.cell{width:25%}.small-up-5>.cell{width:20%}.small-up-6>.cell{width:16.66667%}.small-up-7>.cell{width:14.28571%}.small-up-8>.cell{width:12.5%}@media print,screen and (min-width:40em){.medium-up-1>.cell{width:100%}.medium-up-2>.cell{width:50%}.medium-up-3>.cell{width:33.33333%}.medium-up-4>.cell{width:25%}.medium-up-5>.cell{width:20%}.medium-up-6>.cell{width:16.66667%}.medium-up-7>.cell{width:14.28571%}.medium-up-8>.cell{width:12.5%}}@media print,screen and (min-width:64em){.large-up-1>.cell{width:100%}.large-up-2>.cell{width:50%}.large-up-3>.cell{width:33.33333%}.large-up-4>.cell{width:25%}.large-up-5>.cell{width:20%}.large-up-6>.cell{width:16.66667%}.large-up-7>.cell{width:14.28571%}.large-up-8>.cell{width:12.5%}}.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}.grid-margin-x.medium-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.medium-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.medium-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.medium-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.medium-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.medium-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.medium-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.medium-up-8>.cell{width:calc(12.5% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x.large-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.large-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.large-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.large-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.large-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.large-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.large-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.large-up-8>.cell{width:calc(12.5% - 1.875rem)}}.small-margin-collapse{margin-right:0;margin-left:0}.small-margin-collapse>.cell{margin-right:0;margin-left:0}.small-margin-collapse>.small-1{width:8.33333%}.small-margin-collapse>.small-2{width:16.66667%}.small-margin-collapse>.small-3{width:25%}.small-margin-collapse>.small-4{width:33.33333%}.small-margin-collapse>.small-5{width:41.66667%}.small-margin-collapse>.small-6{width:50%}.small-margin-collapse>.small-7{width:58.33333%}.small-margin-collapse>.small-8{width:66.66667%}.small-margin-collapse>.small-9{width:75%}.small-margin-collapse>.small-10{width:83.33333%}.small-margin-collapse>.small-11{width:91.66667%}.small-margin-collapse>.small-12{width:100%}@media print,screen and (min-width:40em){.small-margin-collapse>.medium-1{width:8.33333%}.small-margin-collapse>.medium-2{width:16.66667%}.small-margin-collapse>.medium-3{width:25%}.small-margin-collapse>.medium-4{width:33.33333%}.small-margin-collapse>.medium-5{width:41.66667%}.small-margin-collapse>.medium-6{width:50%}.small-margin-collapse>.medium-7{width:58.33333%}.small-margin-collapse>.medium-8{width:66.66667%}.small-margin-collapse>.medium-9{width:75%}.small-margin-collapse>.medium-10{width:83.33333%}.small-margin-collapse>.medium-11{width:91.66667%}.small-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.small-margin-collapse>.large-1{width:8.33333%}.small-margin-collapse>.large-2{width:16.66667%}.small-margin-collapse>.large-3{width:25%}.small-margin-collapse>.large-4{width:33.33333%}.small-margin-collapse>.large-5{width:41.66667%}.small-margin-collapse>.large-6{width:50%}.small-margin-collapse>.large-7{width:58.33333%}.small-margin-collapse>.large-8{width:66.66667%}.small-margin-collapse>.large-9{width:75%}.small-margin-collapse>.large-10{width:83.33333%}.small-margin-collapse>.large-11{width:91.66667%}.small-margin-collapse>.large-12{width:100%}}.small-padding-collapse{margin-right:0;margin-left:0}.small-padding-collapse>.cell{padding-right:0;padding-left:0}@media print,screen and (min-width:40em){.medium-margin-collapse{margin-right:0;margin-left:0}.medium-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:40em){.medium-margin-collapse>.small-1{width:8.33333%}.medium-margin-collapse>.small-2{width:16.66667%}.medium-margin-collapse>.small-3{width:25%}.medium-margin-collapse>.small-4{width:33.33333%}.medium-margin-collapse>.small-5{width:41.66667%}.medium-margin-collapse>.small-6{width:50%}.medium-margin-collapse>.small-7{width:58.33333%}.medium-margin-collapse>.small-8{width:66.66667%}.medium-margin-collapse>.small-9{width:75%}.medium-margin-collapse>.small-10{width:83.33333%}.medium-margin-collapse>.small-11{width:91.66667%}.medium-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:40em){.medium-margin-collapse>.medium-1{width:8.33333%}.medium-margin-collapse>.medium-2{width:16.66667%}.medium-margin-collapse>.medium-3{width:25%}.medium-margin-collapse>.medium-4{width:33.33333%}.medium-margin-collapse>.medium-5{width:41.66667%}.medium-margin-collapse>.medium-6{width:50%}.medium-margin-collapse>.medium-7{width:58.33333%}.medium-margin-collapse>.medium-8{width:66.66667%}.medium-margin-collapse>.medium-9{width:75%}.medium-margin-collapse>.medium-10{width:83.33333%}.medium-margin-collapse>.medium-11{width:91.66667%}.medium-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.medium-margin-collapse>.large-1{width:8.33333%}.medium-margin-collapse>.large-2{width:16.66667%}.medium-margin-collapse>.large-3{width:25%}.medium-margin-collapse>.large-4{width:33.33333%}.medium-margin-collapse>.large-5{width:41.66667%}.medium-margin-collapse>.large-6{width:50%}.medium-margin-collapse>.large-7{width:58.33333%}.medium-margin-collapse>.large-8{width:66.66667%}.medium-margin-collapse>.large-9{width:75%}.medium-margin-collapse>.large-10{width:83.33333%}.medium-margin-collapse>.large-11{width:91.66667%}.medium-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:40em){.medium-padding-collapse{margin-right:0;margin-left:0}.medium-padding-collapse>.cell{padding-right:0;padding-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse{margin-right:0;margin-left:0}.large-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse>.small-1{width:8.33333%}.large-margin-collapse>.small-2{width:16.66667%}.large-margin-collapse>.small-3{width:25%}.large-margin-collapse>.small-4{width:33.33333%}.large-margin-collapse>.small-5{width:41.66667%}.large-margin-collapse>.small-6{width:50%}.large-margin-collapse>.small-7{width:58.33333%}.large-margin-collapse>.small-8{width:66.66667%}.large-margin-collapse>.small-9{width:75%}.large-margin-collapse>.small-10{width:83.33333%}.large-margin-collapse>.small-11{width:91.66667%}.large-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.medium-1{width:8.33333%}.large-margin-collapse>.medium-2{width:16.66667%}.large-margin-collapse>.medium-3{width:25%}.large-margin-collapse>.medium-4{width:33.33333%}.large-margin-collapse>.medium-5{width:41.66667%}.large-margin-collapse>.medium-6{width:50%}.large-margin-collapse>.medium-7{width:58.33333%}.large-margin-collapse>.medium-8{width:66.66667%}.large-margin-collapse>.medium-9{width:75%}.large-margin-collapse>.medium-10{width:83.33333%}.large-margin-collapse>.medium-11{width:91.66667%}.large-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.large-1{width:8.33333%}.large-margin-collapse>.large-2{width:16.66667%}.large-margin-collapse>.large-3{width:25%}.large-margin-collapse>.large-4{width:33.33333%}.large-margin-collapse>.large-5{width:41.66667%}.large-margin-collapse>.large-6{width:50%}.large-margin-collapse>.large-7{width:58.33333%}.large-margin-collapse>.large-8{width:66.66667%}.large-margin-collapse>.large-9{width:75%}.large-margin-collapse>.large-10{width:83.33333%}.large-margin-collapse>.large-11{width:91.66667%}.large-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:64em){.large-padding-collapse{margin-right:0;margin-left:0}.large-padding-collapse>.cell{padding-right:0;padding-left:0}}.small-offset-0{margin-left:0}.grid-margin-x>.small-offset-0{margin-left:calc(0% + .625rem)}.small-offset-1{margin-left:8.33333%}.grid-margin-x>.small-offset-1{margin-left:calc(8.33333% + .625rem)}.small-offset-2{margin-left:16.66667%}.grid-margin-x>.small-offset-2{margin-left:calc(16.66667% + .625rem)}.small-offset-3{margin-left:25%}.grid-margin-x>.small-offset-3{margin-left:calc(25% + .625rem)}.small-offset-4{margin-left:33.33333%}.grid-margin-x>.small-offset-4{margin-left:calc(33.33333% + .625rem)}.small-offset-5{margin-left:41.66667%}.grid-margin-x>.small-offset-5{margin-left:calc(41.66667% + .625rem)}.small-offset-6{margin-left:50%}.grid-margin-x>.small-offset-6{margin-left:calc(50% + .625rem)}.small-offset-7{margin-left:58.33333%}.grid-margin-x>.small-offset-7{margin-left:calc(58.33333% + .625rem)}.small-offset-8{margin-left:66.66667%}.grid-margin-x>.small-offset-8{margin-left:calc(66.66667% + .625rem)}.small-offset-9{margin-left:75%}.grid-margin-x>.small-offset-9{margin-left:calc(75% + .625rem)}.small-offset-10{margin-left:83.33333%}.grid-margin-x>.small-offset-10{margin-left:calc(83.33333% + .625rem)}.small-offset-11{margin-left:91.66667%}.grid-margin-x>.small-offset-11{margin-left:calc(91.66667% + .625rem)}@media print,screen and (min-width:40em){.medium-offset-0{margin-left:0}.grid-margin-x>.medium-offset-0{margin-left:calc(0% + .9375rem)}.medium-offset-1{margin-left:8.33333%}.grid-margin-x>.medium-offset-1{margin-left:calc(8.33333% + .9375rem)}.medium-offset-2{margin-left:16.66667%}.grid-margin-x>.medium-offset-2{margin-left:calc(16.66667% + .9375rem)}.medium-offset-3{margin-left:25%}.grid-margin-x>.medium-offset-3{margin-left:calc(25% + .9375rem)}.medium-offset-4{margin-left:33.33333%}.grid-margin-x>.medium-offset-4{margin-left:calc(33.33333% + .9375rem)}.medium-offset-5{margin-left:41.66667%}.grid-margin-x>.medium-offset-5{margin-left:calc(41.66667% + .9375rem)}.medium-offset-6{margin-left:50%}.grid-margin-x>.medium-offset-6{margin-left:calc(50% + .9375rem)}.medium-offset-7{margin-left:58.33333%}.grid-margin-x>.medium-offset-7{margin-left:calc(58.33333% + .9375rem)}.medium-offset-8{margin-left:66.66667%}.grid-margin-x>.medium-offset-8{margin-left:calc(66.66667% + .9375rem)}.medium-offset-9{margin-left:75%}.grid-margin-x>.medium-offset-9{margin-left:calc(75% + .9375rem)}.medium-offset-10{margin-left:83.33333%}.grid-margin-x>.medium-offset-10{margin-left:calc(83.33333% + .9375rem)}.medium-offset-11{margin-left:91.66667%}.grid-margin-x>.medium-offset-11{margin-left:calc(91.66667% + .9375rem)}}@media print,screen and (min-width:64em){.large-offset-0{margin-left:0}.grid-margin-x>.large-offset-0{margin-left:calc(0% + .9375rem)}.large-offset-1{margin-left:8.33333%}.grid-margin-x>.large-offset-1{margin-left:calc(8.33333% + .9375rem)}.large-offset-2{margin-left:16.66667%}.grid-margin-x>.large-offset-2{margin-left:calc(16.66667% + .9375rem)}.large-offset-3{margin-left:25%}.grid-margin-x>.large-offset-3{margin-left:calc(25% + .9375rem)}.large-offset-4{margin-left:33.33333%}.grid-margin-x>.large-offset-4{margin-left:calc(33.33333% + .9375rem)}.large-offset-5{margin-left:41.66667%}.grid-margin-x>.large-offset-5{margin-left:calc(41.66667% + .9375rem)}.large-offset-6{margin-left:50%}.grid-margin-x>.large-offset-6{margin-left:calc(50% + .9375rem)}.large-offset-7{margin-left:58.33333%}.grid-margin-x>.large-offset-7{margin-left:calc(58.33333% + .9375rem)}.large-offset-8{margin-left:66.66667%}.grid-margin-x>.large-offset-8{margin-left:calc(66.66667% + .9375rem)}.large-offset-9{margin-left:75%}.grid-margin-x>.large-offset-9{margin-left:calc(75% + .9375rem)}.large-offset-10{margin-left:83.33333%}.grid-margin-x>.large-offset-10{margin-left:calc(83.33333% + .9375rem)}.large-offset-11{margin-left:91.66667%}.grid-margin-x>.large-offset-11{margin-left:calc(91.66667% + .9375rem)}}.grid-y{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.grid-y>.cell{width:auto}.grid-y>.auto{height:auto}.grid-y>.shrink{height:auto}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9,.grid-y>.small-full,.grid-y>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-full,.grid-y>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-full,.grid-y>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-y>.small-1{height:8.33333%}.grid-y>.small-2{height:16.66667%}.grid-y>.small-3{height:25%}.grid-y>.small-4{height:33.33333%}.grid-y>.small-5{height:41.66667%}.grid-y>.small-6{height:50%}.grid-y>.small-7{height:58.33333%}.grid-y>.small-8{height:66.66667%}.grid-y>.small-9{height:75%}.grid-y>.small-10{height:83.33333%}.grid-y>.small-11{height:91.66667%}.grid-y>.small-12{height:100%}@media print,screen and (min-width:40em){.grid-y>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.medium-shrink{height:auto}.grid-y>.medium-1{height:8.33333%}.grid-y>.medium-2{height:16.66667%}.grid-y>.medium-3{height:25%}.grid-y>.medium-4{height:33.33333%}.grid-y>.medium-5{height:41.66667%}.grid-y>.medium-6{height:50%}.grid-y>.medium-7{height:58.33333%}.grid-y>.medium-8{height:66.66667%}.grid-y>.medium-9{height:75%}.grid-y>.medium-10{height:83.33333%}.grid-y>.medium-11{height:91.66667%}.grid-y>.medium-12{height:100%}}@media print,screen and (min-width:64em){.grid-y>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.large-shrink{height:auto}.grid-y>.large-1{height:8.33333%}.grid-y>.large-2{height:16.66667%}.grid-y>.large-3{height:25%}.grid-y>.large-4{height:33.33333%}.grid-y>.large-5{height:41.66667%}.grid-y>.large-6{height:50%}.grid-y>.large-7{height:58.33333%}.grid-y>.large-8{height:66.66667%}.grid-y>.large-9{height:75%}.grid-y>.large-10{height:83.33333%}.grid-y>.large-11{height:91.66667%}.grid-y>.large-12{height:100%}}.grid-padding-y .grid-padding-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-padding-y .grid-padding-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-padding-y>.cell{padding-top:.625rem;padding-bottom:.625rem}@media print,screen and (min-width:40em){.grid-padding-y>.cell{padding-top:.9375rem;padding-bottom:.9375rem}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .grid-frame{width:100%}.cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.cell-block-container{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;max-height:100%}.cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}@media print,screen and (min-width:40em){.medium-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .medium-grid-frame{width:100%}.medium-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.medium-cell-block-container{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;max-height:100%}.medium-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.medium-cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}}@media print,screen and (min-width:64em){.large-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .large-grid-frame{width:100%}.large-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.large-cell-block-container{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;max-height:100%}.large-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.large-cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}}.grid-y.grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}@media print,screen and (min-width:40em){.grid-y.medium-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}@media print,screen and (min-width:64em){.grid-y.large-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}.cell .grid-y.grid-frame{height:100%}@media print,screen and (min-width:40em){.cell .grid-y.medium-grid-frame{height:100%}}@media print,screen and (min-width:64em){.cell .grid-y.large-grid-frame{height:100%}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame.grid-margin-y{height:calc(100vh + 1.25rem)}@media print,screen and (min-width:40em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:40em){.grid-margin-y.medium-grid-frame{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y.large-grid-frame{height:calc(100vh + 1.875rem)}}blockquote,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,li,ol,p,pre,td,th,ul{margin:0;padding:0}p{margin-bottom:1rem;font-size:inherit;line-height:1.6;text-rendering:optimizeLegibility}em,i{font-style:italic;line-height:inherit}b,strong{font-weight:700;line-height:inherit}small{font-size:80%;line-height:inherit}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-style:normal;font-weight:400;color:inherit;text-rendering:optimizeLegibility}.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small,h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{line-height:0;color:#cacaca}.h1,h1{font-size:1.5rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h2,h2{font-size:1.25rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h3,h3{font-size:1.1875rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h4,h4{font-size:1.125rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h5,h5{font-size:1.0625rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h6,h6{font-size:1rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}@media print,screen and (min-width:40em){.h1,h1{font-size:3rem}.h2,h2{font-size:2.5rem}.h3,h3{font-size:1.9375rem}.h4,h4{font-size:1.5625rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}}a{line-height:inherit;color:#1779ba;text-decoration:none;cursor:pointer}a:focus,a:hover{color:#1468a0}a img{border:0}hr{clear:both;max-width:75rem;height:0;margin:1.25rem auto;border-top:0;border-right:0;border-bottom:1px solid #cacaca;border-left:0}dl,ol,ul{margin-bottom:1rem;list-style-position:outside;line-height:1.6}li{font-size:inherit}ul{margin-left:1.25rem;list-style-type:disc}ol{margin-left:1.25rem}ol ol,ol ul,ul ol,ul ul{margin-left:1.25rem;margin-bottom:0}dl{margin-bottom:1rem}dl dt{margin-bottom:.3rem;font-weight:700}blockquote{margin:0 0 1rem;padding:.5625rem 1.25rem 0 1.1875rem;border-left:1px solid #cacaca}blockquote,blockquote p{line-height:1.6;color:#8a8a8a}cite{display:block;font-size:.8125rem;color:#8a8a8a}cite:before{content:"— "}abbr,abbr[title]{border-bottom:1px dotted #0a0a0a;cursor:help;text-decoration:none}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:400;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;color:#0a0a0a}.subheader{margin-top:.2rem;margin-bottom:.5rem;font-weight:400;line-height:1.4;color:#8a8a8a}.lead{font-size:125%;line-height:1.6}.stat{font-size:2.5rem;line-height:1}p+.stat{margin-top:-1rem}ol.no-bullet,ul.no-bullet{margin-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}@media print,screen and (min-width:40em){.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}}@media print,screen and (min-width:64em){.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}}.show-for-print{display:none!important}@media print{*{background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}.show-for-print{display:block!important}.hide-for-print{display:none!important}table.show-for-print{display:table!important}thead.show-for-print{display:table-header-group!important}tbody.show-for-print{display:table-row-group!important}tr.show-for-print{display:table-row!important}td.show-for-print{display:table-cell!important}th.show-for-print{display:table-cell!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}.ir a:after,a[href^='#']:after,a[href^='javascript:']:after{content:''}abbr[title]:after{content:" (" attr(title) ")"}blockquote,pre{border:1px solid #8a8a8a;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.print-break-inside{page-break-inside:auto}}[type=color],[type=date],[type=datetime-local],[type=datetime],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],textarea{display:block;-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;height:2.4375rem;margin:0 0 1rem;padding:.5rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;-webkit-box-shadow:inset 0 1px 2px rgba(10,10,10,.1);box-shadow:inset 0 1px 2px rgba(10,10,10,.1);font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s;-webkit-appearance:none;-moz-appearance:none;appearance:none}[type=color]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=datetime]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,textarea:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}textarea{max-width:100%}textarea[rows]{height:auto}input::-webkit-input-placeholder,textarea::-webkit-input-placeholder{color:#cacaca}input:-ms-input-placeholder,textarea:-ms-input-placeholder{color:#cacaca}input::placeholder,textarea::placeholder{color:#cacaca}input:disabled,input[readonly],textarea:disabled,textarea[readonly]{background-color:#e6e6e6;cursor:not-allowed}[type=button],[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}input[type=search]{-webkit-box-sizing:border-box;box-sizing:border-box}[type=checkbox],[type=file],[type=radio]{margin:0 0 1rem}[type=checkbox]+label,[type=radio]+label{display:inline-block;vertical-align:baseline;margin-left:.5rem;margin-right:1rem;margin-bottom:0}[type=checkbox]+label[for],[type=radio]+label[for]{cursor:pointer}label>[type=checkbox],label>[type=radio]{margin-right:.5rem}[type=file]{width:100%}label{display:block;margin:0;font-size:.875rem;font-weight:400;line-height:1.8;color:#0a0a0a}label.middle{margin:0 0 1rem;padding:.5625rem 0}.help-text{margin-top:-.5rem;font-size:.8125rem;font-style:italic;color:#0a0a0a}.input-group{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;width:100%;margin-bottom:1rem;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.input-group>:first-child{border-radius:0}.input-group>:last-child>*{border-radius:0}.input-group-button,.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label,.input-group-field,.input-group-label{margin:0;white-space:nowrap}.input-group-label{padding:0 1rem;border:1px solid #cacaca;background:#e6e6e6;color:#0a0a0a;text-align:center;white-space:nowrap;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.input-group-label:first-child{border-right:0}.input-group-label:last-child{border-left:0}.input-group-field{border-radius:0;-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto;min-width:0}.input-group-button{padding-top:0;padding-bottom:0;text-align:center;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label{height:auto;-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;padding-top:0;padding-bottom:0;font-size:1rem}fieldset{margin:0;padding:0;border:0}legend{max-width:100%;margin-bottom:.5rem}.fieldset{margin:1.125rem 0;padding:1.25rem;border:1px solid #cacaca}.fieldset legend{margin:0;margin-left:-.1875rem;padding:0 .1875rem}select{height:2.4375rem;margin:0 0 1rem;padding:.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");-webkit-background-origin:content-box;background-origin:content-box;background-position:right -1rem center;background-repeat:no-repeat;-webkit-background-size:9px 6px;background-size:9px 6px;padding-right:1.5rem;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}@media screen and (min-width:0\0){select{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==)}}select:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}select:disabled{background-color:#e6e6e6;cursor:not-allowed}select::-ms-expand{display:none}select[multiple]{height:auto;background-image:none}.is-invalid-input:not(:focus){border-color:#cc4b37;background-color:#f9ecea}.is-invalid-input:not(:focus)::-webkit-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus):-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::placeholder{color:#cc4b37}.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700;color:#cc4b37}.form-error.is-visible{display:block}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem 0;font-family:inherit;padding:.85em 1em;-webkit-appearance:none;border:1px solid transparent;border-radius:0;-webkit-transition:background-color .25s ease-out,color .25s ease-out;transition:background-color .25s ease-out,color .25s ease-out;font-size:.9rem;line-height:1;text-align:center;cursor:pointer;background-color:#1779ba;color:#fefefe}[data-whatinput=mouse] .button{outline:0}.button:focus,.button:hover{background-color:#14679e;color:#fefefe}.button.tiny{font-size:.6rem}.button.small{font-size:.75rem}.button.large{font-size:1.25rem}.button.expanded{display:block;width:100%;margin-right:0;margin-left:0}.button.primary{background-color:#1779ba;color:#fefefe}.button.primary:focus,.button.primary:hover{background-color:#126195;color:#fefefe}.button.secondary{background-color:#767676;color:#fefefe}.button.secondary:focus,.button.secondary:hover{background-color:#5e5e5e;color:#fefefe}.button.success{background-color:#3adb76;color:#0a0a0a}.button.success:focus,.button.success:hover{background-color:#22bb5b;color:#0a0a0a}.button.warning{background-color:#ffae00;color:#0a0a0a}.button.warning:focus,.button.warning:hover{background-color:#cc8b00;color:#0a0a0a}.button.alert{background-color:#cc4b37;color:#fefefe}.button.alert:focus,.button.alert:hover{background-color:#a53b2a;color:#fefefe}.button.disabled,.button[disabled]{opacity:.25;cursor:not-allowed}.button.disabled,.button.disabled:focus,.button.disabled:hover,.button[disabled],.button[disabled]:focus,.button[disabled]:hover{background-color:#1779ba;color:#fefefe}.button.disabled.primary,.button[disabled].primary{opacity:.25;cursor:not-allowed}.button.disabled.primary,.button.disabled.primary:focus,.button.disabled.primary:hover,.button[disabled].primary,.button[disabled].primary:focus,.button[disabled].primary:hover{background-color:#1779ba;color:#fefefe}.button.disabled.secondary,.button[disabled].secondary{opacity:.25;cursor:not-allowed}.button.disabled.secondary,.button.disabled.secondary:focus,.button.disabled.secondary:hover,.button[disabled].secondary,.button[disabled].secondary:focus,.button[disabled].secondary:hover{background-color:#767676;color:#fefefe}.button.disabled.success,.button[disabled].success{opacity:.25;cursor:not-allowed}.button.disabled.success,.button.disabled.success:focus,.button.disabled.success:hover,.button[disabled].success,.button[disabled].success:focus,.button[disabled].success:hover{background-color:#3adb76;color:#0a0a0a}.button.disabled.warning,.button[disabled].warning{opacity:.25;cursor:not-allowed}.button.disabled.warning,.button.disabled.warning:focus,.button.disabled.warning:hover,.button[disabled].warning,.button[disabled].warning:focus,.button[disabled].warning:hover{background-color:#ffae00;color:#0a0a0a}.button.disabled.alert,.button[disabled].alert{opacity:.25;cursor:not-allowed}.button.disabled.alert,.button.disabled.alert:focus,.button.disabled.alert:hover,.button[disabled].alert,.button[disabled].alert:focus,.button[disabled].alert:hover{background-color:#cc4b37;color:#fefefe}.button.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow.disabled,.button.hollow.disabled:focus,.button.hollow.disabled:hover,.button.hollow[disabled],.button.hollow[disabled]:focus,.button.hollow[disabled]:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow:focus.disabled,.button.hollow:focus[disabled],.button.hollow:hover.disabled,.button.hollow:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary:focus.disabled,.button.hollow.primary:focus[disabled],.button.hollow.primary:hover.disabled,.button.hollow.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.secondary:focus.disabled,.button.hollow.secondary:focus[disabled],.button.hollow.secondary:hover.disabled,.button.hollow.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.success:focus.disabled,.button.hollow.success:focus[disabled],.button.hollow.success:hover.disabled,.button.hollow.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.warning:focus.disabled,.button.hollow.warning:focus[disabled],.button.hollow.warning:hover.disabled,.button.hollow.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.button.hollow.alert:focus.disabled,.button.hollow.alert:focus[disabled],.button.hollow.alert:hover.disabled,.button.hollow.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear:focus,.button.clear:hover{background-color:transparent}.button.clear.disabled,.button.clear.disabled:focus,.button.clear.disabled:hover,.button.clear[disabled],.button.clear[disabled]:focus,.button.clear[disabled]:hover{background-color:transparent}.button.clear:focus,.button.clear:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover.disabled,.button.clear:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear.disabled,.button.clear:focus,.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover,.button.clear:hover.disabled,.button.clear:hover[disabled],.button.clear[disabled]{border-color:transparent}.button.clear.primary{border:1px solid #1779ba;color:#1779ba}.button.clear.primary:focus,.button.clear.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear.primary,.button.clear.primary.disabled,.button.clear.primary:focus,.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover,.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled],.button.clear.primary[disabled]{border-color:transparent}.button.clear.secondary{border:1px solid #767676;color:#767676}.button.clear.secondary:focus,.button.clear.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.clear.secondary,.button.clear.secondary.disabled,.button.clear.secondary:focus,.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover,.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled],.button.clear.secondary[disabled]{border-color:transparent}.button.clear.success{border:1px solid #3adb76;color:#3adb76}.button.clear.success:focus,.button.clear.success:hover{border-color:#157539;color:#157539}.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover.disabled,.button.clear.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.clear.success,.button.clear.success.disabled,.button.clear.success:focus,.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover,.button.clear.success:hover.disabled,.button.clear.success:hover[disabled],.button.clear.success[disabled]{border-color:transparent}.button.clear.warning{border:1px solid #ffae00;color:#ffae00}.button.clear.warning:focus,.button.clear.warning:hover{border-color:#805700;color:#805700}.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.clear.warning,.button.clear.warning.disabled,.button.clear.warning:focus,.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover,.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled],.button.clear.warning[disabled]{border-color:transparent}.button.clear.alert{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert:focus,.button.clear.alert:hover{border-color:#67251a;color:#67251a}.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert,.button.clear.alert.disabled,.button.clear.alert:focus,.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover,.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled],.button.clear.alert[disabled]{border-color:transparent}.button.dropdown::after{display:block;width:0;height:0;border:inset .4em;content:'';border-bottom-width:0;border-top-style:solid;border-color:#fefefe transparent transparent;position:relative;top:.4em;display:inline-block;float:right;margin-left:1em}.button.dropdown.hollow::after{border-top-color:#1779ba}.button.dropdown.hollow.primary::after{border-top-color:#1779ba}.button.dropdown.hollow.secondary::after{border-top-color:#767676}.button.dropdown.hollow.success::after{border-top-color:#3adb76}.button.dropdown.hollow.warning::after{border-top-color:#ffae00}.button.dropdown.hollow.alert::after{border-top-color:#cc4b37}.button.arrow-only::after{top:-.1em;float:none;margin-left:0}a.button:focus,a.button:hover{text-decoration:none}.accordion{margin-left:0;background:#fefefe;list-style-type:none}.accordion[disabled] .accordion-title{cursor:not-allowed}.accordion-item:first-child>:first-child{border-radius:0}.accordion-item:last-child>:last-child{border-radius:0}.accordion-title{position:relative;display:block;padding:1.25rem 1rem;border:1px solid #e6e6e6;border-bottom:0;font-size:.75rem;line-height:1;color:#1779ba}:last-child:not(.is-active)>.accordion-title{border-bottom:1px solid #e6e6e6;border-radius:0}.accordion-title:focus,.accordion-title:hover{background-color:#e6e6e6}.accordion-title::before{position:absolute;top:50%;right:1rem;margin-top:-.5rem;content:'+'}.is-active>.accordion-title::before{content:'\2013'}.accordion-content{display:none;padding:1rem;border:1px solid #e6e6e6;border-bottom:0;background-color:#fefefe;color:#0a0a0a}:last-child>.accordion-content:last-child{border-bottom:1px solid #e6e6e6}.accordion-menu li{width:100%}.accordion-menu a{padding:.7rem 1rem}.accordion-menu .is-accordion-submenu a{padding:.7rem 1rem}.accordion-menu .nested.is-accordion-submenu{margin-right:0;margin-left:1rem}.accordion-menu.align-right .nested.is-accordion-submenu{margin-right:1rem;margin-left:0}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a{position:relative}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;right:1rem}.accordion-menu.align-left .is-accordion-submenu-parent>a::after{left:auto;right:1rem}.accordion-menu.align-right .is-accordion-submenu-parent>a::after{right:auto;left:1rem}.accordion-menu .is-accordion-submenu-parent[aria-expanded=true]>a::after{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.is-accordion-submenu-parent{position:relative}.has-submenu-toggle>a{margin-right:40px}.submenu-toggle{position:absolute;top:0;right:0;cursor:pointer;width:40px;height:40px}.submenu-toggle::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;top:0;bottom:0;margin:auto}.submenu-toggle[aria-expanded=true]::after{-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.submenu-toggle-text{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center;background:#1779ba;color:#fefefe}.badge.primary{background:#1779ba;color:#fefefe}.badge.secondary{background:#767676;color:#fefefe}.badge.success{background:#3adb76;color:#0a0a0a}.badge.warning{background:#ffae00;color:#0a0a0a}.badge.alert{background:#cc4b37;color:#fefefe}.breadcrumbs{margin:0 0 1rem 0;list-style:none}.breadcrumbs::after,.breadcrumbs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.breadcrumbs::after{clear:both}.breadcrumbs li{float:left;font-size:.6875rem;color:#0a0a0a;cursor:default;text-transform:uppercase}.breadcrumbs li:not(:last-child)::after{position:relative;margin:0 .75rem;opacity:1;content:"/";color:#cacaca}.breadcrumbs a{color:#1779ba}.breadcrumbs a:hover{text-decoration:underline}.breadcrumbs .disabled{color:#cacaca;cursor:not-allowed}.button-group{margin-bottom:1rem;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.button-group::after,.button-group::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.button-group::after{clear:both}.button-group .button{margin:0;margin-right:1px;margin-bottom:1px;font-size:.9rem;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.button-group .button:last-child{margin-right:0}.button-group.tiny .button{font-size:.6rem}.button-group.small .button{font-size:.75rem}.button-group.large .button{font-size:1.25rem}.button-group.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.button-group.primary .button{background-color:#1779ba;color:#fefefe}.button-group.primary .button:focus,.button-group.primary .button:hover{background-color:#126195;color:#fefefe}.button-group.secondary .button{background-color:#767676;color:#fefefe}.button-group.secondary .button:focus,.button-group.secondary .button:hover{background-color:#5e5e5e;color:#fefefe}.button-group.success .button{background-color:#3adb76;color:#0a0a0a}.button-group.success .button:focus,.button-group.success .button:hover{background-color:#22bb5b;color:#0a0a0a}.button-group.warning .button{background-color:#ffae00;color:#0a0a0a}.button-group.warning .button:focus,.button-group.warning .button:hover{background-color:#cc8b00;color:#0a0a0a}.button-group.alert .button{background-color:#cc4b37;color:#fefefe}.button-group.alert .button:focus,.button-group.alert .button:hover{background-color:#a53b2a;color:#fefefe}.button-group.stacked,.button-group.stacked-for-medium,.button-group.stacked-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.button-group.stacked .button,.button-group.stacked-for-medium .button,.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%}.button-group.stacked .button:last-child,.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.button-group.stacked-for-small .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;margin-bottom:0}}@media print,screen and (min-width:64em){.button-group.stacked-for-medium .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;margin-bottom:0}}@media screen and (max-width:39.9375em){.button-group.stacked-for-small.expanded{display:block}.button-group.stacked-for-small.expanded .button{display:block;margin-right:0}}.callout{position:relative;margin:0 0 1rem 0;padding:1rem;border:1px solid rgba(10,10,10,.25);border-radius:0;background-color:#fff;color:#0a0a0a}.callout>:first-child{margin-top:0}.callout>:last-child{margin-bottom:0}.callout.primary{background-color:#d7ecfa;color:#0a0a0a}.callout.secondary{background-color:#eaeaea;color:#0a0a0a}.callout.success{background-color:#e1faea;color:#0a0a0a}.callout.warning{background-color:#fff3d9;color:#0a0a0a}.callout.alert{background-color:#f7e4e1;color:#0a0a0a}.callout.small{padding-top:.5rem;padding-right:.5rem;padding-bottom:.5rem;padding-left:.5rem}.callout.large{padding-top:3rem;padding-right:3rem;padding-bottom:3rem;padding-left:3rem}.card{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-grow:1;-ms-flex-positive:1;flex-grow:1;margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;color:#0a0a0a}.card>:last-child{margin-bottom:0}.card-divider{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;padding:1rem;background:#e6e6e6}.card-divider>:last-child{margin-bottom:0}.card-section{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto;padding:1rem}.card-section>:last-child{margin-bottom:0}.card-image{min-height:1px}.close-button{position:absolute;color:#8a8a8a;cursor:pointer}[data-whatinput=mouse] .close-button{outline:0}.close-button:focus,.close-button:hover{color:#0a0a0a}.close-button.small{right:.66rem;top:.33em;font-size:1.5em;line-height:1}.close-button,.close-button.medium{right:1rem;top:.5rem;font-size:2em;line-height:1}.menu{padding:0;margin:0;list-style:none;position:relative;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}[data-whatinput=mouse] .menu li{outline:0}.menu .button,.menu a{line-height:1;text-decoration:none;display:block;padding:.7rem 1rem}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu input{display:inline-block}.menu,.menu.horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.simple{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.menu.simple li+li{margin-left:1rem}.menu.simple a{padding:0}@media print,screen and (min-width:40em){.menu.medium-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.medium-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.medium-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.medium-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}@media print,screen and (min-width:64em){.menu.large-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.large-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.large-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.large-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}.menu.nested{margin-right:0;margin-left:1rem}.menu.icons a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-bottom a,.menu.icon-left a,.menu.icon-right a,.menu.icon-top a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-left li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-left li a i,.menu.icon-left li a img,.menu.icon-left li a svg{margin-right:.25rem}.menu.icon-right li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-right li a i,.menu.icon-right li a img,.menu.icon-right li a svg{margin-left:.25rem}.menu.icon-top li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-top li a i,.menu.icon-top li a img,.menu.icon-top li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu.icon-bottom li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-bottom li a i,.menu.icon-bottom li a img,.menu.icon-bottom li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu .is-active>a{background:#1779ba;color:#fefefe}.menu .active>a{background:#1779ba;color:#fefefe}.menu.align-left{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-right li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.menu.align-right li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-right.vertical li{display:block;text-align:right}.menu.align-right.vertical li .submenu li{text-align:right}.menu.align-right .nested{margin-right:1rem;margin-left:0}.menu.align-center li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu.align-center li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu .menu-text{padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered>.menu{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.no-js [data-responsive-menu] ul{display:none}.menu-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#fefefe;-webkit-box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:''}.menu-icon:hover::after{background:#cacaca;-webkit-box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.menu-icon.dark{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon.dark::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;-webkit-box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:''}.menu-icon.dark:hover::after{background:#8a8a8a;-webkit-box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a;box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a}.is-drilldown{position:relative;overflow:hidden}.is-drilldown li{display:block}.is-drilldown.animate-height{-webkit-transition:height .5s;transition:height .5s}.drilldown a{padding:.7rem 1rem;background:#fefefe}.drilldown .is-drilldown-submenu{position:absolute;top:0;left:100%;z-index:-1;width:100%;background:#fefefe;-webkit-transition:-webkit-transform .15s linear;transition:-webkit-transform .15s linear;transition:transform .15s linear;transition:transform .15s linear,-webkit-transform .15s linear}.drilldown .is-drilldown-submenu.is-active{z-index:1;display:block;-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%)}.drilldown .is-drilldown-submenu.is-closing{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%)}.drilldown .is-drilldown-submenu a{padding:.7rem 1rem}.drilldown .nested.is-drilldown-submenu{margin-right:0;margin-left:0}.drilldown .drilldown-submenu-cover-previous{min-height:100%}.drilldown .is-drilldown-submenu-parent>a{position:relative}.drilldown .is-drilldown-submenu-parent>a::after{position:absolute;top:50%;margin-top:-6px;right:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.drilldown.align-left .is-drilldown-submenu-parent>a::after{left:auto;right:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.drilldown.align-right .is-drilldown-submenu-parent>a::after{right:auto;left:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.drilldown .js-drilldown-back>a::before{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;border-left-width:0;display:inline-block;vertical-align:middle;margin-right:.75rem;border-left-width:0}.dropdown-pane{position:absolute;z-index:10;width:300px;padding:1rem;visibility:hidden;display:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-opening{display:block}.dropdown-pane.is-open{visibility:visible;display:block}.dropdown-pane.tiny{width:100px}.dropdown-pane.small{width:200px}.dropdown-pane.large{width:400px}.dropdown.menu>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu a{padding:.7rem 1rem}[data-whatinput=mouse] .dropdown.menu a{outline:0}.dropdown.menu .is-active>a{background:0 0;color:#1779ba}.no-js .dropdown.menu ul{display:none}.dropdown.menu .nested.is-dropdown-submenu{margin-right:0;margin-left:0}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.vertical>li>a::after{right:14px}.dropdown.menu.vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}@media print,screen and (min-width:40em){.dropdown.menu.medium-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.medium-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.medium-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.medium-vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.medium-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.medium-vertical>li>a::after{right:14px}.dropdown.menu.medium-vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.medium-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}@media print,screen and (min-width:64em){.dropdown.menu.large-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.large-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.large-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.large-vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.large-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.large-vertical>li>a::after{right:14px}.dropdown.menu.large-vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.large-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}.dropdown.menu.align-right .is-dropdown-submenu.first-sub{top:100%;right:0;left:auto}.is-dropdown-menu.vertical{width:100px}.is-dropdown-menu.vertical.align-right{float:right}.is-dropdown-submenu-parent{position:relative}.is-dropdown-submenu-parent a::after{position:absolute;top:50%;right:5px;left:auto;margin-top:-6px}.is-dropdown-submenu-parent.opens-inner>.is-dropdown-submenu{top:100%;left:auto}.is-dropdown-submenu-parent.opens-left>.is-dropdown-submenu{right:100%;left:auto}.is-dropdown-submenu-parent.opens-right>.is-dropdown-submenu{right:auto;left:100%}.is-dropdown-submenu{position:absolute;top:0;left:100%;z-index:1;display:none;min-width:200px;border:1px solid #cacaca;background:#fefefe}.dropdown .is-dropdown-submenu a{padding:.7rem 1rem}.is-dropdown-submenu .is-dropdown-submenu-parent>a::after{right:14px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.is-dropdown-submenu .is-dropdown-submenu{margin-top:-1px}.is-dropdown-submenu>li{width:100%}.is-dropdown-submenu.js-dropdown-active{display:block}.flex-video,.responsive-embed{position:relative;height:0;margin-bottom:1rem;padding-bottom:75%;overflow:hidden}.flex-video embed,.flex-video iframe,.flex-video object,.flex-video video,.responsive-embed embed,.responsive-embed iframe,.responsive-embed object,.responsive-embed video{position:absolute;top:0;left:0;width:100%;height:100%}.flex-video.widescreen,.responsive-embed.widescreen{padding-bottom:56.25%}.label{display:inline-block;padding:.33333rem .5rem;border-radius:0;font-size:.8rem;line-height:1;white-space:nowrap;cursor:default;background:#1779ba;color:#fefefe}.label.primary{background:#1779ba;color:#fefefe}.label.secondary{background:#767676;color:#fefefe}.label.success{background:#3adb76;color:#0a0a0a}.label.warning{background:#ffae00;color:#0a0a0a}.label.alert{background:#cc4b37;color:#fefefe}.media-object{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;margin-bottom:1rem;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.media-object img{max-width:none}@media screen and (max-width:39.9375em){.media-object.stack-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}}@media screen and (max-width:39.9375em){.media-object.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;-webkit-flex-basis:100%;-ms-flex-preferred-size:100%;flex-basis:100%;max-width:100%}.media-object.stack-for-small .media-object-section img{width:100%}}.media-object-section{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.media-object-section:first-child{padding-right:1rem}.media-object-section:last-child:not(:nth-child(2)){padding-left:1rem}.media-object-section>:last-child{margin-bottom:0}.media-object-section.main-section{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.is-off-canvas-open{overflow:hidden}.js-off-canvas-overlay{position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;-webkit-transition:opacity .5s ease,visibility .5s ease;transition:opacity .5s ease,visibility .5s ease;background:rgba(254,254,254,.25);opacity:0;visibility:hidden;overflow:hidden}.js-off-canvas-overlay.is-visible{opacity:1;visibility:visible}.js-off-canvas-overlay.is-closable{cursor:pointer}.js-off-canvas-overlay.is-overlay-absolute{position:absolute}.js-off-canvas-overlay.is-overlay-fixed{position:fixed}.off-canvas-wrapper{position:relative;overflow:hidden}.off-canvas{position:fixed;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-push{z-index:12}.off-canvas.is-closed{visibility:hidden}.off-canvas.is-transition-overlap{z-index:13}.off-canvas.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-absolute{position:absolute;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas-absolute{outline:0}.off-canvas-absolute.is-transition-push{z-index:12}.off-canvas-absolute.is-closed{visibility:hidden}.off-canvas-absolute.is-transition-overlap{z-index:13}.off-canvas-absolute.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas-absolute.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.position-left{top:0;left:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-left.has-transition-push{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.position-left.is-transition-push{-webkit-box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25)}.position-right{top:0;right:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-right.has-transition-push{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.position-right.is-transition-push{-webkit-box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25)}.position-top{top:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-top.has-transition-push{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.position-top.is-transition-push{-webkit-box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25)}.position-bottom{bottom:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-bottom.has-transition-push{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.position-bottom.is-transition-push{-webkit-box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25)}.off-canvas-content{-webkit-transform:none;-ms-transform:none;transform:none;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.off-canvas-content.has-transition-push{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content .off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}@media print,screen and (min-width:40em){.position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-medium .close-button{display:none}.off-canvas-content .position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-medium .close-button{display:none}.off-canvas-content .position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-medium .close-button{display:none}.off-canvas-content .position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-medium .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:64em){.position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-large .close-button{display:none}.off-canvas-content .position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-large .close-button{display:none}.off-canvas-content .position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-large .close-button{display:none}.off-canvas-content .position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-large .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:40em){.off-canvas.in-canvas-for-medium{visibility:visible;height:auto;position:static;background:inherit;width:inherit;overflow:inherit;-webkit-transition:inherit;transition:inherit}.off-canvas.in-canvas-for-medium.position-bottom,.off-canvas.in-canvas-for-medium.position-left,.off-canvas.in-canvas-for-medium.position-right,.off-canvas.in-canvas-for-medium.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-medium .close-button{display:none}}@media print,screen and (min-width:64em){.off-canvas.in-canvas-for-large{visibility:visible;height:auto;position:static;background:inherit;width:inherit;overflow:inherit;-webkit-transition:inherit;transition:inherit}.off-canvas.in-canvas-for-large.position-bottom,.off-canvas.in-canvas-for-large.position-left,.off-canvas.in-canvas-for-large.position-right,.off-canvas.in-canvas-for-large.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-large .close-button{display:none}}.orbit{position:relative}.orbit-container{position:relative;height:0;margin:0;list-style:none;overflow:hidden}.orbit-slide{width:100%}.orbit-slide.no-motionui.is-active{top:0;left:0}.orbit-figure{margin:0}.orbit-image{width:100%;max-width:100%;margin:0}.orbit-caption{position:absolute;bottom:0;width:100%;margin-bottom:0;padding:1rem;background-color:rgba(10,10,10,.5);color:#fefefe}.orbit-next,.orbit-previous{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);z-index:10;padding:1rem;color:#fefefe}[data-whatinput=mouse] .orbit-next,[data-whatinput=mouse] .orbit-previous{outline:0}.orbit-next:active,.orbit-next:focus,.orbit-next:hover,.orbit-previous:active,.orbit-previous:focus,.orbit-previous:hover{background-color:rgba(10,10,10,.5)}.orbit-previous{left:0}.orbit-next{left:auto;right:0}.orbit-bullets{position:relative;margin-top:.8rem;margin-bottom:.8rem;text-align:center}[data-whatinput=mouse] .orbit-bullets{outline:0}.orbit-bullets button{width:1.2rem;height:1.2rem;margin:.1rem;border-radius:50%;background-color:#cacaca}.orbit-bullets button:hover{background-color:#8a8a8a}.orbit-bullets button.is-active{background-color:#8a8a8a}.pagination{margin-left:0;margin-bottom:1rem}.pagination::after,.pagination::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.pagination::after{clear:both}.pagination li{margin-right:.0625rem;border-radius:0;font-size:.875rem;display:none}.pagination li:first-child,.pagination li:last-child{display:inline-block}@media print,screen and (min-width:40em){.pagination li{display:inline-block}}.pagination a,.pagination button{display:block;padding:.1875rem .625rem;border-radius:0;color:#0a0a0a}.pagination a:hover,.pagination button:hover{background:#e6e6e6}.pagination .current{padding:.1875rem .625rem;background:#1779ba;color:#fefefe;cursor:default}.pagination .disabled{padding:.1875rem .625rem;color:#cacaca;cursor:not-allowed}.pagination .disabled:hover{background:0 0}.pagination .ellipsis::after{padding:.1875rem .625rem;content:'\2026';color:#0a0a0a}.pagination-previous a::before,.pagination-previous.disabled::before{display:inline-block;margin-right:.5rem;content:'\00ab'}.pagination-next a::after,.pagination-next.disabled::after{display:inline-block;margin-left:.5rem;content:'\00bb'}.progress{height:1rem;margin-bottom:1rem;border-radius:0;background-color:#cacaca}.progress.primary .progress-meter{background-color:#1779ba}.progress.secondary .progress-meter{background-color:#767676}.progress.success .progress-meter{background-color:#3adb76}.progress.warning .progress-meter{background-color:#ffae00}.progress.alert .progress-meter{background-color:#cc4b37}.progress-meter{position:relative;display:block;width:0%;height:100%;background-color:#1779ba}.progress-meter-text{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);transform:translate(-50%,-50%);position:absolute;margin:0;font-size:.75rem;font-weight:700;color:#fefefe;white-space:nowrap}.slider{position:relative;height:.5rem;margin-top:1.25rem;margin-bottom:2.25rem;background-color:#e6e6e6;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none}.slider-fill{position:absolute;top:0;left:0;display:inline-block;max-width:100%;height:.5rem;background-color:#cacaca;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.slider-fill.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider-handle{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;-ms-touch-action:manipulation;touch-action:manipulation}[data-whatinput=mouse] .slider-handle{outline:0}.slider-handle:hover{background-color:#14679e}.slider-handle.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider.disabled,.slider[disabled]{opacity:.25;cursor:not-allowed}.slider.vertical{display:inline-block;width:.5rem;height:12.5rem;margin:0 1.25rem;-webkit-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scale(1,-1)}.slider.vertical .slider-fill{top:0;width:.5rem;max-height:100%}.slider.vertical .slider-handle{position:absolute;top:0;left:50%;width:1.4rem;height:1.4rem;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.sticky-container{position:relative}.sticky{position:relative;z-index:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.sticky.is-stuck{position:fixed;z-index:5;width:100%}.sticky.is-stuck.is-at-top{top:0}.sticky.is-stuck.is-at-bottom{bottom:0}.sticky.is-anchored{position:relative;right:auto;left:auto}.sticky.is-anchored.is-at-bottom{bottom:0}body.is-reveal-open{overflow:hidden}html.is-reveal-open,html.is-reveal-open body{min-height:100%;overflow:hidden;position:fixed;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;display:none;background-color:rgba(10,10,10,.45);overflow-y:scroll}.reveal{z-index:1006;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:none;padding:1rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;position:relative;top:100px;margin-right:auto;margin-left:auto;overflow-y:auto}[data-whatinput=mouse] .reveal{outline:0}@media print,screen and (min-width:40em){.reveal{min-height:0}}.reveal .column{min-width:0}.reveal>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.reveal{width:600px;max-width:75rem}}.reveal.collapse{padding:0}@media print,screen and (min-width:40em){.reveal.tiny{width:30%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.small{width:50%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.large{width:90%;max-width:75rem}}.reveal.full{top:0;left:0;width:100%;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}@media screen and (max-width:39.9375em){.reveal{top:0;left:0;width:100%;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}}.reveal.without-overlay{position:fixed}.switch{height:2rem;position:relative;margin-bottom:1rem;outline:0;font-size:.875rem;font-weight:700;color:#fefefe;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.switch-input{position:absolute;margin-bottom:0;opacity:0}.switch-paddle{position:relative;display:block;width:4rem;height:2rem;border-radius:0;background:#cacaca;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;font-weight:inherit;color:inherit;cursor:pointer}input+.switch-paddle{margin:0}.switch-paddle::after{position:absolute;top:.25rem;left:.25rem;display:block;width:1.5rem;height:1.5rem;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);border-radius:0;background:#fefefe;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;content:''}input:checked~.switch-paddle{background:#1779ba}input:checked~.switch-paddle::after{left:2.25rem}[data-whatinput=mouse] input:focus~.switch-paddle{outline:0}.switch-active,.switch-inactive{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.switch-active{left:8%;display:none}input:checked+label>.switch-active{display:block}.switch-inactive{right:15%}input:checked+label>.switch-inactive{display:none}.switch.tiny{height:1.5rem}.switch.tiny .switch-paddle{width:3rem;height:1.5rem;font-size:.625rem}.switch.tiny .switch-paddle::after{top:.25rem;left:.25rem;width:1rem;height:1rem}.switch.tiny input:checked~.switch-paddle::after{left:1.75rem}.switch.small{height:1.75rem}.switch.small .switch-paddle{width:3.5rem;height:1.75rem;font-size:.75rem}.switch.small .switch-paddle::after{top:.25rem;left:.25rem;width:1.25rem;height:1.25rem}.switch.small input:checked~.switch-paddle::after{left:2rem}.switch.large{height:2.5rem}.switch.large .switch-paddle{width:5rem;height:2.5rem;font-size:1rem}.switch.large .switch-paddle::after{top:.25rem;left:.25rem;width:2rem;height:2rem}.switch.large input:checked~.switch-paddle::after{left:2.75rem}table{border-collapse:collapse;width:100%;margin-bottom:1rem;border-radius:0}table tbody,table tfoot,table thead{border:1px solid #f1f1f1;background-color:#fefefe}table caption{padding:.5rem .625rem .625rem;font-weight:700}table thead{background:#f8f8f8;color:#0a0a0a}table tfoot{background:#f1f1f1;color:#0a0a0a}table tfoot tr,table thead tr{background:0 0}table tfoot td,table tfoot th,table thead td,table thead th{padding:.5rem .625rem .625rem;font-weight:700;text-align:left}table tbody td,table tbody th{padding:.5rem .625rem .625rem}table tbody tr:nth-child(even){border-bottom:0;background-color:#f1f1f1}table.unstriped tbody{background-color:#fefefe}table.unstriped tbody tr{border-bottom:0;border-bottom:1px solid #f1f1f1;background-color:#fefefe}@media screen and (max-width:63.9375em){table.stack thead{display:none}table.stack tfoot{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}}table.scroll{display:block;width:100%;overflow-x:auto}table.hover thead tr:hover{background-color:#f3f3f3}table.hover tfoot tr:hover{background-color:#ececec}table.hover tbody tr:hover{background-color:#f9f9f9}table.hover:not(.unstriped) tr:nth-of-type(even):hover{background-color:#ececec}.table-scroll{overflow-x:auto}.table-scroll table{width:auto}.tabs{margin:0;border:1px solid #e6e6e6;background:#fefefe;list-style-type:none}.tabs::after,.tabs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.tabs::after{clear:both}.tabs.vertical>li{display:block;float:none;width:auto}.tabs.simple>li>a{padding:0}.tabs.simple>li>a:hover{background:0 0}.tabs.primary{background:#1779ba}.tabs.primary>li>a{color:#fefefe}.tabs.primary>li>a:focus,.tabs.primary>li>a:hover{background:#1673b1}.tabs-title{float:left}.tabs-title>a{display:block;padding:1.25rem 1.5rem;font-size:.75rem;line-height:1;color:#1779ba}.tabs-title>a:hover{background:#fefefe;color:#1468a0}.tabs-title>a:focus,.tabs-title>a[aria-selected=true]{background:#e6e6e6;color:#1779ba}.tabs-content{border:1px solid #e6e6e6;border-top:0;background:#fefefe;color:#0a0a0a;-webkit-transition:all .5s ease;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-left:0}.tabs-panel{display:none;padding:1rem}.tabs-panel.is-active{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:solid 4px #fefefe;border-radius:0;-webkit-box-shadow:0 0 0 1px rgba(10,10,10,.2);box-shadow:0 0 0 1px rgba(10,10,10,.2);line-height:0}a.thumbnail{-webkit-transition:-webkit-box-shadow .2s ease-out;transition:-webkit-box-shadow .2s ease-out;transition:box-shadow .2s ease-out;transition:box-shadow .2s ease-out,-webkit-box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{-webkit-box-shadow:0 0 6px 1px rgba(23,121,186,.5);box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{-webkit-box-shadow:none;box-shadow:none}.title-bar{padding:.5rem;background:#0a0a0a;color:#fefefe;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.title-bar .menu-icon{margin-left:.25rem;margin-right:.25rem}.title-bar-left,.title-bar-right{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.title-bar-right{text-align:right}.title-bar-title{display:inline-block;vertical-align:middle;font-weight:700}.has-tip{position:relative;display:inline-block;border-bottom:dotted 1px #8a8a8a;font-weight:700;cursor:help}.tooltip{position:absolute;top:calc(100% + .6495rem);z-index:1200;max-width:10rem;padding:.75rem;border-radius:0;background-color:#0a0a0a;font-size:80%;color:#fefefe}.tooltip::before{position:absolute}.tooltip.bottom::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;bottom:100%}.tooltip.bottom.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.top::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.top.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.left::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.right::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.tooltip.right.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.align-top::before{bottom:auto;top:10%}.tooltip.align-bottom::before{bottom:10%;top:auto}.tooltip.align-left::before{left:10%;right:auto}.tooltip.align-right::before{left:auto;right:10%}.top-bar{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;padding:.5rem;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar,.top-bar ul{background-color:#e6e6e6}.top-bar input{max-width:200px;margin-right:1rem}.top-bar .input-group-field{width:100%;margin-right:0}.top-bar input.button{width:auto}.top-bar .top-bar-left,.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}@media print,screen and (min-width:40em){.top-bar{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.top-bar .top-bar-left{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;margin-right:auto}.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;margin-left:auto}}@media screen and (max-width:63.9375em){.top-bar.stacked-for-medium{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}@media screen and (max-width:74.9375em){.top-bar.stacked-for-large{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-large .top-bar-left,.top-bar.stacked-for-large .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}.top-bar-title{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin:.5rem 1rem .5rem 0}.top-bar-left,.top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.hide{display:none!important}.invisible{visibility:hidden}@media screen and (max-width:39.9375em){.hide-for-small-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media print,screen and (min-width:40em){.hide-for-medium{display:none!important}}@media screen and (max-width:39.9375em){.show-for-medium{display:none!important}}@media screen and (min-width:40em) and (max-width:63.9375em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:39.9375em),screen and (min-width:64em){.show-for-medium-only{display:none!important}}@media print,screen and (min-width:64em){.hide-for-large{display:none!important}}@media screen and (max-width:63.9375em){.show-for-large{display:none!important}}@media screen and (min-width:64em) and (max-width:74.9375em){.hide-for-large-only{display:none!important}}@media screen and (max-width:63.9375em),screen and (min-width:75em){.show-for-large-only{display:none!important}}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal;-webkit-clip-path:none;clip-path:none}.hide-for-portrait,.show-for-landscape{display:block!important}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}}.hide-for-landscape,.show-for-portrait{display:none!important}@media screen and (orientation:landscape){.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-landscape,.show-for-portrait{display:block!important}}.float-left{float:left!important}.float-right{float:right!important}.float-center{display:block;margin-right:auto;margin-left:auto}.clearfix::after,.clearfix::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.clearfix::after{clear:both}.align-right{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-justify{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between}.align-spaced{-webkit-justify-content:space-around;-ms-flex-pack:distribute;justify-content:space-around}.align-right.vertical.menu>li>a{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center.vertical.menu>li>a{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-top{-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start}.align-self-top{-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start}.align-bottom{-webkit-box-align:end;-webkit-align-items:flex-end;-ms-flex-align:end;align-items:flex-end}.align-self-bottom{-webkit-align-self:flex-end;-ms-flex-item-align:end;align-self:flex-end}.align-middle{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.align-self-middle{-webkit-align-self:center;-ms-flex-item-align:center;-ms-grid-row-align:center;align-self:center}.align-stretch{-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.align-self-stretch{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch}.align-center-middle{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-align-content:center;-ms-flex-line-pack:center;align-content:center}.small-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.small-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.small-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.small-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.small-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.small-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}@media print,screen and (min-width:40em){.medium-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.medium-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.medium-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.medium-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.medium-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.medium-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}@media print,screen and (min-width:64em){.large-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.large-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.large-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.large-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.large-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.large-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}.flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}@media print,screen and (min-width:40em){.medium-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.medium-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.medium-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.medium-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.medium-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.medium-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.medium-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.medium-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}@media print,screen and (min-width:64em){.large-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.large-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.large-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.large-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.large-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.large-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.large-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.large-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}.text-hide{font:0/0 a!important;color:transparent!important;text-shadow:none!important;background-color:transparent!important;border:0!important}.text-truncate{max-width:100%!important;overflow:hidden!important;text-overflow:ellipsis;white-space:nowrap!important}.text-nowrap{white-space:nowrap!important}.text-wrap{word-wrap:break-word!important}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.text-overline{text-decoration:overline!important}.text-underline{text-decoration:underline!important}.text-line-through{text-decoration:line-through!important}.font-wide{letter-spacing:.25rem}.font-normal{font-weight:400}.font-bold{font-weight:700}.font-italic{font-style:italic!important}ul.list-disc{list-style-type:disc!important}ul.list-circle{list-style-type:circle!important}ul.list-square{list-style-type:square!important}ol.list-decimal{list-style-type:decimal!important}ol.list-lower-alpha{list-style-type:lower-alpha!important}ol.list-lower-latin{list-style-type:lower-latin!important}ol.list-lower-roman{list-style-type:lower-roman!important}ol.list-upper-alpha{list-style-type:upper-alpha!important}ol.list-upper-latin{list-style-type:upper-latin!important}ol.list-upper-roman{list-style-type:upper-roman!important}.rounded{border-radius:5000px!important}.radius{border-radius:.1875rem}.bordered{border:.0625rem solid #cacaca}.shadow{-webkit-box-shadow:0 2px 5px 0 rgba(0,0,0,.16),0 2px 10px 0 rgba(0,0,0,.12);box-shadow:0 2px 5px 0 rgba(0,0,0,.16),0 2px 10px 0 rgba(0,0,0,.12)}.arrow-down{display:block;width:0;height:0;border:inset .4375rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent}.arrow-up{display:block;width:0;height:0;border:inset .4375rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a}.arrow-right{display:block;width:0;height:0;border:inset .4375rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a}.arrow-left{display:block;width:0;height:0;border:inset .4375rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent}.separator-center{text-align:center!important}.separator-center::after,.separator-center::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.separator-center::after{clear:both}.separator-center::after{position:relative!important;width:3rem;border-bottom:.125rem solid #1779ba;margin:1rem auto 0}.separator-left{text-align:left!important}.separator-left::after,.separator-left::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.separator-left::after{clear:both}.separator-left::after{position:relative!important;width:3rem;border-bottom:.125rem solid #1779ba;margin:1rem auto 0;margin-left:0!important}.separator-right{text-align:right!important}.separator-right::after,.separator-right::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.separator-right::after{clear:both}.separator-right::after{position:relative!important;width:3rem;border-bottom:.125rem solid #1779ba;margin:1rem auto 0;margin-right:0!important}.overflow-visible{overflow:visible!important}.overflow-x-visible{overflow-x:visible!important}.overflow-y-visible{overflow-y:visible!important}.overflow-hidden{overflow:hidden!important}.overflow-x-hidden{overflow-x:hidden!important}.overflow-y-hidden{overflow-y:hidden!important}.overflow-scroll{overflow:scroll!important}.overflow-x-scroll{overflow-x:scroll!important}.overflow-y-scroll{overflow-y:scroll!important}.display-inline{display:inline!important}.display-inline-block{display:inline-block!important}.display-block{display:block!important}.display-table{display:table!important}.display-table-cell{display:table-cell!important}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-fixed-top{position:fixed!important;top:0!important;right:0!important;left:0!important;z-index:975}.position-fixed-bottom{position:fixed!important;right:0!important;bottom:0!important;left:0!important;z-index:975}.border-box{-webkit-box-sizing:border-box!important;box-sizing:border-box!important}.border-none{border:none!important}.width-25{width:25%!important}.width-50{width:50%!important}.width-75{width:75%!important}.width-100{width:100%!important}.height-25{height:25%!important}.height-50{height:50%!important}.height-75{height:75%!important}.height-100{height:100%!important}.max-width-100{max-width:100%!important}.max-height-100{max-height:100%!important}.margin-0{margin-top:0!important;margin-right:0!important;margin-bottom:0!important;margin-left:0!important}.padding-0{padding-top:0!important;padding-right:0!important;padding-bottom:0!important;padding-left:0!important}.margin-top-0{margin-top:0!important}.padding-top-0{padding-top:0!important}.margin-right-0{margin-right:0!important}.padding-right-0{padding-right:0!important}.margin-bottom-0{margin-bottom:0!important}.padding-bottom-0{padding-bottom:0!important}.margin-left-0{margin-left:0!important}.padding-left-0{padding-left:0!important}.margin-horizontal-0{margin-right:0!important;margin-left:0!important}.padding-horizontal-0{padding-right:0!important;padding-left:0!important}.margin-vertical-0{margin-top:0!important;margin-bottom:0!important}.padding-vertical-0{padding-top:0!important;padding-bottom:0!important}.margin-1{margin-top:1rem!important;margin-right:1rem!important;margin-bottom:1rem!important;margin-left:1rem!important}.padding-1{padding-top:1rem!important;padding-right:1rem!important;padding-bottom:1rem!important;padding-left:1rem!important}.margin-top-1{margin-top:1rem!important}.padding-top-1{padding-top:1rem!important}.margin-right-1{margin-right:1rem!important}.padding-right-1{padding-right:1rem!important}.margin-bottom-1{margin-bottom:1rem!important}.padding-bottom-1{padding-bottom:1rem!important}.margin-left-1{margin-left:1rem!important}.padding-left-1{padding-left:1rem!important}.margin-horizontal-1{margin-right:1rem!important;margin-left:1rem!important}.padding-horizontal-1{padding-right:1rem!important;padding-left:1rem!important}.margin-vertical-1{margin-top:1rem!important;margin-bottom:1rem!important}.padding-vertical-1{padding-top:1rem!important;padding-bottom:1rem!important}.margin-2{margin-top:2rem!important;margin-right:2rem!important;margin-bottom:2rem!important;margin-left:2rem!important}.padding-2{padding-top:2rem!important;padding-right:2rem!important;padding-bottom:2rem!important;padding-left:2rem!important}.margin-top-2{margin-top:2rem!important}.padding-top-2{padding-top:2rem!important}.margin-right-2{margin-right:2rem!important}.padding-right-2{padding-right:2rem!important}.margin-bottom-2{margin-bottom:2rem!important}.padding-bottom-2{padding-bottom:2rem!important}.margin-left-2{margin-left:2rem!important}.padding-left-2{padding-left:2rem!important}.margin-horizontal-2{margin-right:2rem!important;margin-left:2rem!important}.padding-horizontal-2{padding-right:2rem!important;padding-left:2rem!important}.margin-vertical-2{margin-top:2rem!important;margin-bottom:2rem!important}.padding-vertical-2{padding-top:2rem!important;padding-bottom:2rem!important}.margin-3{margin-top:3rem!important;margin-right:3rem!important;margin-bottom:3rem!important;margin-left:3rem!important}.padding-3{padding-top:3rem!important;padding-right:3rem!important;padding-bottom:3rem!important;padding-left:3rem!important}.margin-top-3{margin-top:3rem!important}.padding-top-3{padding-top:3rem!important}.margin-right-3{margin-right:3rem!important}.padding-right-3{padding-right:3rem!important}.margin-bottom-3{margin-bottom:3rem!important}.padding-bottom-3{padding-bottom:3rem!important}.margin-left-3{margin-left:3rem!important}.padding-left-3{padding-left:3rem!important}.margin-horizontal-3{margin-right:3rem!important;margin-left:3rem!important}.padding-horizontal-3{padding-right:3rem!important;padding-left:3rem!important}.margin-vertical-3{margin-top:3rem!important;margin-bottom:3rem!important}.padding-vertical-3{padding-top:3rem!important;padding-bottom:3rem!important}
\ No newline at end of file
+@charset "UTF-8";@media print,screen and (min-width:40em){.reveal,.reveal.large,.reveal.small,.reveal.tiny{right:auto;left:auto;margin:0 auto}}/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}h1{font-size:2em;margin:.67em 0}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{-webkit-box-sizing:border-box;box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{-webkit-box-sizing:border-box;box-sizing:border-box;font-size:100%}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;padding:0;background:#fefefe;font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle;max-width:100%;height:auto;-ms-interpolation-mode:bicubic}textarea{height:auto;min-height:50px;border-radius:0}select{-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;border-radius:0}.map_canvas embed,.map_canvas img,.map_canvas object,.mqa-display embed,.mqa-display img,.mqa-display object{max-width:none!important}button{padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:0;background:0 0;line-height:1;cursor:auto}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}button,input,optgroup,select,textarea{font-family:inherit}.is-visible{display:block!important}.is-hidden{display:none!important}[type=color],[type=date],[type=datetime-local],[type=datetime],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],textarea{display:block;-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;height:2.4375rem;margin:0 0 1rem;padding:.5rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;-webkit-box-shadow:inset 0 1px 2px rgba(10,10,10,.1);box-shadow:inset 0 1px 2px rgba(10,10,10,.1);font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s;-webkit-appearance:none;-moz-appearance:none;appearance:none}[type=color]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=datetime]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,textarea:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}textarea{max-width:100%}textarea[rows]{height:auto}input:disabled,input[readonly],textarea:disabled,textarea[readonly]{background-color:#e6e6e6;cursor:not-allowed}[type=button],[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}input[type=search]{-webkit-box-sizing:border-box;box-sizing:border-box}::-webkit-input-placeholder{color:#cacaca}:-ms-input-placeholder{color:#cacaca}::-ms-input-placeholder{color:#cacaca}::placeholder{color:#cacaca}[type=checkbox],[type=file],[type=radio]{margin:0 0 1rem}[type=checkbox]+label,[type=radio]+label{display:inline-block;vertical-align:baseline;margin-left:.5rem;margin-right:1rem;margin-bottom:0}[type=checkbox]+label[for],[type=radio]+label[for]{cursor:pointer}label>[type=checkbox],label>[type=radio]{margin-right:.5rem}[type=file]{width:100%}label{display:block;margin:0;font-size:.875rem;font-weight:400;line-height:1.8;color:#0a0a0a}label.middle{margin:0 0 1rem;padding:.5625rem 0}.help-text{margin-top:-.5rem;font-size:.8125rem;font-style:italic;color:#0a0a0a}.input-group{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;width:100%;margin-bottom:1rem;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.input-group>:first-child,.input-group>:first-child.input-group-button>*{border-radius:0}.input-group>:last-child,.input-group>:last-child.input-group-button>*{border-radius:0}.input-group-button,.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label,.input-group-field,.input-group-label{margin:0;white-space:nowrap}.input-group-label{padding:0 1rem;border:1px solid #cacaca;background:#e6e6e6;color:#0a0a0a;text-align:center;white-space:nowrap;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.input-group-label:first-child{border-right:0}.input-group-label:last-child{border-left:0}.input-group-field{border-radius:0;-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;min-width:0}.input-group-button{padding-top:0;padding-bottom:0;text-align:center;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;height:auto;padding-top:0;padding-bottom:0;font-size:1rem}fieldset{margin:0;padding:0;border:0}legend{max-width:100%;margin-bottom:.5rem}.fieldset{margin:1.125rem 0;padding:1.25rem;border:1px solid #cacaca}.fieldset legend{margin:0;margin-left:-.1875rem;padding:0 .1875rem}select{height:2.4375rem;margin:0 0 1rem;padding:.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");background-origin:content-box;background-position:right -1rem center;background-repeat:no-repeat;background-size:9px 6px;padding-right:1.5rem;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}@media screen and (min-width:0\0){select{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==)}}select:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}select:disabled{background-color:#e6e6e6;cursor:not-allowed}select::-ms-expand{display:none}select[multiple]{height:auto;background-image:none}.is-invalid-input:not(:focus){border-color:#cc4b37;background-color:#f9ecea}.is-invalid-input:not(:focus)::-webkit-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus):-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::placeholder{color:#cc4b37}.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700;color:#cc4b37}.form-error.is-visible{display:block}blockquote,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,li,ol,p,pre,td,th,ul{margin:0;padding:0}p{margin-bottom:1rem;font-size:inherit;line-height:1.6;text-rendering:optimizeLegibility}em,i{font-style:italic;line-height:inherit}b,strong{font-weight:700;line-height:inherit}small{font-size:80%;line-height:inherit}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-style:normal;font-weight:400;color:inherit;text-rendering:optimizeLegibility}.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small,h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{line-height:0;color:#cacaca}.h1,h1{font-size:1.5rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h2,h2{font-size:1.25rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h3,h3{font-size:1.1875rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h4,h4{font-size:1.125rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h5,h5{font-size:1.0625rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h6,h6{font-size:1rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}@media print,screen and (min-width:40em){.h1,h1{font-size:3rem}.h2,h2{font-size:2.5rem}.h3,h3{font-size:1.9375rem}.h4,h4{font-size:1.5625rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}}a{line-height:inherit;color:#1779ba;text-decoration:none;cursor:pointer}a:focus,a:hover{color:#1468a0}a img{border:0}hr{clear:both;max-width:75rem;height:0;margin:1.25rem auto;border-top:0;border-right:0;border-bottom:1px solid #cacaca;border-left:0}dl,ol,ul{margin-bottom:1rem;list-style-position:outside;line-height:1.6}li{font-size:inherit}ul{margin-left:1.25rem;list-style-type:disc}ol{margin-left:1.25rem}ol ol,ol ul,ul ol,ul ul{margin-left:1.25rem;margin-bottom:0}dl{margin-bottom:1rem}dl dt{margin-bottom:.3rem;font-weight:700}blockquote{margin:0 0 1rem;padding:.5625rem 1.25rem 0 1.1875rem;border-left:1px solid #cacaca}blockquote,blockquote p{line-height:1.6;color:#8a8a8a}cite{display:block;font-size:.8125rem;color:#8a8a8a}cite:before{content:"— "}abbr,abbr[title]{border-bottom:1px dotted #0a0a0a;cursor:help;text-decoration:none}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:400;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;color:#0a0a0a}.subheader{margin-top:.2rem;margin-bottom:.5rem;font-weight:400;line-height:1.4;color:#8a8a8a}.lead{font-size:125%;line-height:1.6}.stat{font-size:2.5rem;line-height:1}p+.stat{margin-top:-1rem}ol.no-bullet,ul.no-bullet{margin-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}@media print,screen and (min-width:40em){.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}}@media print,screen and (min-width:64em){.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}}.show-for-print{display:none!important}@media print{*{background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}.show-for-print{display:block!important}.hide-for-print{display:none!important}table.show-for-print{display:table!important}thead.show-for-print{display:table-header-group!important}tbody.show-for-print{display:table-row-group!important}tr.show-for-print{display:table-row!important}td.show-for-print{display:table-cell!important}th.show-for-print{display:table-cell!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}.ir a:after,a[href^='#']:after,a[href^='javascript:']:after{content:''}abbr[title]:after{content:" (" attr(title) ")"}blockquote,pre{border:1px solid #8a8a8a;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.print-break-inside{page-break-inside:auto}}.grid-container{padding-right:.625rem;padding-left:.625rem;max-width:75rem;margin-left:auto;margin-right:auto}@media print,screen and (min-width:40em){.grid-container{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.fluid{padding-right:.625rem;padding-left:.625rem;max-width:100%;margin-left:auto;margin-right:auto}@media print,screen and (min-width:40em){.grid-container.fluid{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.full{padding-right:0;padding-left:0;max-width:100%;margin-left:auto;margin-right:auto}.grid-x{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row wrap;-ms-flex-flow:row wrap;flex-flow:row wrap}.cell{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;min-height:0;min-width:0;width:100%}.cell.auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.cell.shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.auto{width:auto}.grid-x>.shrink{width:auto}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9,.grid-x>.small-full,.grid-x>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-full,.grid-x>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-full,.grid-x>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.small-1{width:8.33333%}.grid-x>.small-2{width:16.66667%}.grid-x>.small-3{width:25%}.grid-x>.small-4{width:33.33333%}.grid-x>.small-5{width:41.66667%}.grid-x>.small-6{width:50%}.grid-x>.small-7{width:58.33333%}.grid-x>.small-8{width:66.66667%}.grid-x>.small-9{width:75%}.grid-x>.small-10{width:83.33333%}.grid-x>.small-11{width:91.66667%}.grid-x>.small-12{width:100%}@media print,screen and (min-width:40em){.grid-x>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.medium-shrink{width:auto}.grid-x>.medium-1{width:8.33333%}.grid-x>.medium-2{width:16.66667%}.grid-x>.medium-3{width:25%}.grid-x>.medium-4{width:33.33333%}.grid-x>.medium-5{width:41.66667%}.grid-x>.medium-6{width:50%}.grid-x>.medium-7{width:58.33333%}.grid-x>.medium-8{width:66.66667%}.grid-x>.medium-9{width:75%}.grid-x>.medium-10{width:83.33333%}.grid-x>.medium-11{width:91.66667%}.grid-x>.medium-12{width:100%}}@media print,screen and (min-width:64em){.grid-x>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.large-shrink{width:auto}.grid-x>.large-1{width:8.33333%}.grid-x>.large-2{width:16.66667%}.grid-x>.large-3{width:25%}.grid-x>.large-4{width:33.33333%}.grid-x>.large-5{width:41.66667%}.grid-x>.large-6{width:50%}.grid-x>.large-7{width:58.33333%}.grid-x>.large-8{width:66.66667%}.grid-x>.large-9{width:75%}.grid-x>.large-10{width:83.33333%}.grid-x>.large-11{width:91.66667%}.grid-x>.large-12{width:100%}}.grid-margin-x:not(.grid-x)>.cell{width:auto}.grid-margin-y:not(.grid-y)>.cell{height:auto}.grid-margin-x{margin-left:-.625rem;margin-right:-.625rem}@media print,screen and (min-width:40em){.grid-margin-x{margin-left:-.9375rem;margin-right:-.9375rem}}.grid-margin-x>.cell{width:calc(100% - 1.25rem);margin-left:.625rem;margin-right:.625rem}@media print,screen and (min-width:40em){.grid-margin-x>.cell{width:calc(100% - 1.875rem);margin-left:.9375rem;margin-right:.9375rem}}.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.25rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.25rem)}.grid-margin-x>.small-3{width:calc(25% - 1.25rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.25rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.25rem)}.grid-margin-x>.small-6{width:calc(50% - 1.25rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.25rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.25rem)}.grid-margin-x>.small-9{width:calc(75% - 1.25rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.25rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.25rem)}.grid-margin-x>.small-12{width:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.small-3{width:calc(25% - 1.875rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.small-6{width:calc(50% - 1.875rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.small-9{width:calc(75% - 1.875rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.small-12{width:calc(100% - 1.875rem)}.grid-margin-x>.medium-auto{width:auto}.grid-margin-x>.medium-shrink{width:auto}.grid-margin-x>.medium-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.medium-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.medium-3{width:calc(25% - 1.875rem)}.grid-margin-x>.medium-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.medium-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.medium-6{width:calc(50% - 1.875rem)}.grid-margin-x>.medium-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.medium-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.medium-9{width:calc(75% - 1.875rem)}.grid-margin-x>.medium-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.medium-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.medium-12{width:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x>.large-auto{width:auto}.grid-margin-x>.large-shrink{width:auto}.grid-margin-x>.large-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.large-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.large-3{width:calc(25% - 1.875rem)}.grid-margin-x>.large-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.large-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.large-6{width:calc(50% - 1.875rem)}.grid-margin-x>.large-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.large-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.large-9{width:calc(75% - 1.875rem)}.grid-margin-x>.large-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.large-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.large-12{width:calc(100% - 1.875rem)}}.grid-padding-x .grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-padding-x .grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-container:not(.full)>.grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-container:not(.full)>.grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-padding-x>.cell{padding-right:.625rem;padding-left:.625rem}@media print,screen and (min-width:40em){.grid-padding-x>.cell{padding-right:.9375rem;padding-left:.9375rem}}.small-up-1>.cell{width:100%}.small-up-2>.cell{width:50%}.small-up-3>.cell{width:33.33333%}.small-up-4>.cell{width:25%}.small-up-5>.cell{width:20%}.small-up-6>.cell{width:16.66667%}.small-up-7>.cell{width:14.28571%}.small-up-8>.cell{width:12.5%}@media print,screen and (min-width:40em){.medium-up-1>.cell{width:100%}.medium-up-2>.cell{width:50%}.medium-up-3>.cell{width:33.33333%}.medium-up-4>.cell{width:25%}.medium-up-5>.cell{width:20%}.medium-up-6>.cell{width:16.66667%}.medium-up-7>.cell{width:14.28571%}.medium-up-8>.cell{width:12.5%}}@media print,screen and (min-width:64em){.large-up-1>.cell{width:100%}.large-up-2>.cell{width:50%}.large-up-3>.cell{width:33.33333%}.large-up-4>.cell{width:25%}.large-up-5>.cell{width:20%}.large-up-6>.cell{width:16.66667%}.large-up-7>.cell{width:14.28571%}.large-up-8>.cell{width:12.5%}}.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.875rem)}.grid-margin-x.medium-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.medium-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.medium-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.medium-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.medium-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.medium-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.medium-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.medium-up-8>.cell{width:calc(12.5% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x.large-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.large-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.large-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.large-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.large-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.large-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.large-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.large-up-8>.cell{width:calc(12.5% - 1.875rem)}}.small-margin-collapse{margin-right:0;margin-left:0}.small-margin-collapse>.cell{margin-right:0;margin-left:0}.small-margin-collapse>.small-1{width:8.33333%}.small-margin-collapse>.small-2{width:16.66667%}.small-margin-collapse>.small-3{width:25%}.small-margin-collapse>.small-4{width:33.33333%}.small-margin-collapse>.small-5{width:41.66667%}.small-margin-collapse>.small-6{width:50%}.small-margin-collapse>.small-7{width:58.33333%}.small-margin-collapse>.small-8{width:66.66667%}.small-margin-collapse>.small-9{width:75%}.small-margin-collapse>.small-10{width:83.33333%}.small-margin-collapse>.small-11{width:91.66667%}.small-margin-collapse>.small-12{width:100%}@media print,screen and (min-width:40em){.small-margin-collapse>.medium-1{width:8.33333%}.small-margin-collapse>.medium-2{width:16.66667%}.small-margin-collapse>.medium-3{width:25%}.small-margin-collapse>.medium-4{width:33.33333%}.small-margin-collapse>.medium-5{width:41.66667%}.small-margin-collapse>.medium-6{width:50%}.small-margin-collapse>.medium-7{width:58.33333%}.small-margin-collapse>.medium-8{width:66.66667%}.small-margin-collapse>.medium-9{width:75%}.small-margin-collapse>.medium-10{width:83.33333%}.small-margin-collapse>.medium-11{width:91.66667%}.small-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.small-margin-collapse>.large-1{width:8.33333%}.small-margin-collapse>.large-2{width:16.66667%}.small-margin-collapse>.large-3{width:25%}.small-margin-collapse>.large-4{width:33.33333%}.small-margin-collapse>.large-5{width:41.66667%}.small-margin-collapse>.large-6{width:50%}.small-margin-collapse>.large-7{width:58.33333%}.small-margin-collapse>.large-8{width:66.66667%}.small-margin-collapse>.large-9{width:75%}.small-margin-collapse>.large-10{width:83.33333%}.small-margin-collapse>.large-11{width:91.66667%}.small-margin-collapse>.large-12{width:100%}}.small-padding-collapse{margin-right:0;margin-left:0}.small-padding-collapse>.cell{padding-right:0;padding-left:0}@media print,screen and (min-width:40em){.medium-margin-collapse{margin-right:0;margin-left:0}.medium-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:40em){.medium-margin-collapse>.small-1{width:8.33333%}.medium-margin-collapse>.small-2{width:16.66667%}.medium-margin-collapse>.small-3{width:25%}.medium-margin-collapse>.small-4{width:33.33333%}.medium-margin-collapse>.small-5{width:41.66667%}.medium-margin-collapse>.small-6{width:50%}.medium-margin-collapse>.small-7{width:58.33333%}.medium-margin-collapse>.small-8{width:66.66667%}.medium-margin-collapse>.small-9{width:75%}.medium-margin-collapse>.small-10{width:83.33333%}.medium-margin-collapse>.small-11{width:91.66667%}.medium-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:40em){.medium-margin-collapse>.medium-1{width:8.33333%}.medium-margin-collapse>.medium-2{width:16.66667%}.medium-margin-collapse>.medium-3{width:25%}.medium-margin-collapse>.medium-4{width:33.33333%}.medium-margin-collapse>.medium-5{width:41.66667%}.medium-margin-collapse>.medium-6{width:50%}.medium-margin-collapse>.medium-7{width:58.33333%}.medium-margin-collapse>.medium-8{width:66.66667%}.medium-margin-collapse>.medium-9{width:75%}.medium-margin-collapse>.medium-10{width:83.33333%}.medium-margin-collapse>.medium-11{width:91.66667%}.medium-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.medium-margin-collapse>.large-1{width:8.33333%}.medium-margin-collapse>.large-2{width:16.66667%}.medium-margin-collapse>.large-3{width:25%}.medium-margin-collapse>.large-4{width:33.33333%}.medium-margin-collapse>.large-5{width:41.66667%}.medium-margin-collapse>.large-6{width:50%}.medium-margin-collapse>.large-7{width:58.33333%}.medium-margin-collapse>.large-8{width:66.66667%}.medium-margin-collapse>.large-9{width:75%}.medium-margin-collapse>.large-10{width:83.33333%}.medium-margin-collapse>.large-11{width:91.66667%}.medium-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:40em){.medium-padding-collapse{margin-right:0;margin-left:0}.medium-padding-collapse>.cell{padding-right:0;padding-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse{margin-right:0;margin-left:0}.large-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse>.small-1{width:8.33333%}.large-margin-collapse>.small-2{width:16.66667%}.large-margin-collapse>.small-3{width:25%}.large-margin-collapse>.small-4{width:33.33333%}.large-margin-collapse>.small-5{width:41.66667%}.large-margin-collapse>.small-6{width:50%}.large-margin-collapse>.small-7{width:58.33333%}.large-margin-collapse>.small-8{width:66.66667%}.large-margin-collapse>.small-9{width:75%}.large-margin-collapse>.small-10{width:83.33333%}.large-margin-collapse>.small-11{width:91.66667%}.large-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.medium-1{width:8.33333%}.large-margin-collapse>.medium-2{width:16.66667%}.large-margin-collapse>.medium-3{width:25%}.large-margin-collapse>.medium-4{width:33.33333%}.large-margin-collapse>.medium-5{width:41.66667%}.large-margin-collapse>.medium-6{width:50%}.large-margin-collapse>.medium-7{width:58.33333%}.large-margin-collapse>.medium-8{width:66.66667%}.large-margin-collapse>.medium-9{width:75%}.large-margin-collapse>.medium-10{width:83.33333%}.large-margin-collapse>.medium-11{width:91.66667%}.large-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.large-1{width:8.33333%}.large-margin-collapse>.large-2{width:16.66667%}.large-margin-collapse>.large-3{width:25%}.large-margin-collapse>.large-4{width:33.33333%}.large-margin-collapse>.large-5{width:41.66667%}.large-margin-collapse>.large-6{width:50%}.large-margin-collapse>.large-7{width:58.33333%}.large-margin-collapse>.large-8{width:66.66667%}.large-margin-collapse>.large-9{width:75%}.large-margin-collapse>.large-10{width:83.33333%}.large-margin-collapse>.large-11{width:91.66667%}.large-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:64em){.large-padding-collapse{margin-right:0;margin-left:0}.large-padding-collapse>.cell{padding-right:0;padding-left:0}}.small-offset-0{margin-left:0}.grid-margin-x>.small-offset-0{margin-left:calc(0% + .625rem)}.small-offset-1{margin-left:8.33333%}.grid-margin-x>.small-offset-1{margin-left:calc(8.33333% + .625rem)}.small-offset-2{margin-left:16.66667%}.grid-margin-x>.small-offset-2{margin-left:calc(16.66667% + .625rem)}.small-offset-3{margin-left:25%}.grid-margin-x>.small-offset-3{margin-left:calc(25% + .625rem)}.small-offset-4{margin-left:33.33333%}.grid-margin-x>.small-offset-4{margin-left:calc(33.33333% + .625rem)}.small-offset-5{margin-left:41.66667%}.grid-margin-x>.small-offset-5{margin-left:calc(41.66667% + .625rem)}.small-offset-6{margin-left:50%}.grid-margin-x>.small-offset-6{margin-left:calc(50% + .625rem)}.small-offset-7{margin-left:58.33333%}.grid-margin-x>.small-offset-7{margin-left:calc(58.33333% + .625rem)}.small-offset-8{margin-left:66.66667%}.grid-margin-x>.small-offset-8{margin-left:calc(66.66667% + .625rem)}.small-offset-9{margin-left:75%}.grid-margin-x>.small-offset-9{margin-left:calc(75% + .625rem)}.small-offset-10{margin-left:83.33333%}.grid-margin-x>.small-offset-10{margin-left:calc(83.33333% + .625rem)}.small-offset-11{margin-left:91.66667%}.grid-margin-x>.small-offset-11{margin-left:calc(91.66667% + .625rem)}@media print,screen and (min-width:40em){.medium-offset-0{margin-left:0}.grid-margin-x>.medium-offset-0{margin-left:calc(0% + .9375rem)}.medium-offset-1{margin-left:8.33333%}.grid-margin-x>.medium-offset-1{margin-left:calc(8.33333% + .9375rem)}.medium-offset-2{margin-left:16.66667%}.grid-margin-x>.medium-offset-2{margin-left:calc(16.66667% + .9375rem)}.medium-offset-3{margin-left:25%}.grid-margin-x>.medium-offset-3{margin-left:calc(25% + .9375rem)}.medium-offset-4{margin-left:33.33333%}.grid-margin-x>.medium-offset-4{margin-left:calc(33.33333% + .9375rem)}.medium-offset-5{margin-left:41.66667%}.grid-margin-x>.medium-offset-5{margin-left:calc(41.66667% + .9375rem)}.medium-offset-6{margin-left:50%}.grid-margin-x>.medium-offset-6{margin-left:calc(50% + .9375rem)}.medium-offset-7{margin-left:58.33333%}.grid-margin-x>.medium-offset-7{margin-left:calc(58.33333% + .9375rem)}.medium-offset-8{margin-left:66.66667%}.grid-margin-x>.medium-offset-8{margin-left:calc(66.66667% + .9375rem)}.medium-offset-9{margin-left:75%}.grid-margin-x>.medium-offset-9{margin-left:calc(75% + .9375rem)}.medium-offset-10{margin-left:83.33333%}.grid-margin-x>.medium-offset-10{margin-left:calc(83.33333% + .9375rem)}.medium-offset-11{margin-left:91.66667%}.grid-margin-x>.medium-offset-11{margin-left:calc(91.66667% + .9375rem)}}@media print,screen and (min-width:64em){.large-offset-0{margin-left:0}.grid-margin-x>.large-offset-0{margin-left:calc(0% + .9375rem)}.large-offset-1{margin-left:8.33333%}.grid-margin-x>.large-offset-1{margin-left:calc(8.33333% + .9375rem)}.large-offset-2{margin-left:16.66667%}.grid-margin-x>.large-offset-2{margin-left:calc(16.66667% + .9375rem)}.large-offset-3{margin-left:25%}.grid-margin-x>.large-offset-3{margin-left:calc(25% + .9375rem)}.large-offset-4{margin-left:33.33333%}.grid-margin-x>.large-offset-4{margin-left:calc(33.33333% + .9375rem)}.large-offset-5{margin-left:41.66667%}.grid-margin-x>.large-offset-5{margin-left:calc(41.66667% + .9375rem)}.large-offset-6{margin-left:50%}.grid-margin-x>.large-offset-6{margin-left:calc(50% + .9375rem)}.large-offset-7{margin-left:58.33333%}.grid-margin-x>.large-offset-7{margin-left:calc(58.33333% + .9375rem)}.large-offset-8{margin-left:66.66667%}.grid-margin-x>.large-offset-8{margin-left:calc(66.66667% + .9375rem)}.large-offset-9{margin-left:75%}.grid-margin-x>.large-offset-9{margin-left:calc(75% + .9375rem)}.large-offset-10{margin-left:83.33333%}.grid-margin-x>.large-offset-10{margin-left:calc(83.33333% + .9375rem)}.large-offset-11{margin-left:91.66667%}.grid-margin-x>.large-offset-11{margin-left:calc(91.66667% + .9375rem)}}.grid-y{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.grid-y>.cell{width:auto;max-width:none}.grid-y>.auto{height:auto}.grid-y>.shrink{height:auto}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9,.grid-y>.small-full,.grid-y>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-full,.grid-y>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-full,.grid-y>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.small-1{height:8.33333%}.grid-y>.small-2{height:16.66667%}.grid-y>.small-3{height:25%}.grid-y>.small-4{height:33.33333%}.grid-y>.small-5{height:41.66667%}.grid-y>.small-6{height:50%}.grid-y>.small-7{height:58.33333%}.grid-y>.small-8{height:66.66667%}.grid-y>.small-9{height:75%}.grid-y>.small-10{height:83.33333%}.grid-y>.small-11{height:91.66667%}.grid-y>.small-12{height:100%}@media print,screen and (min-width:40em){.grid-y>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.medium-shrink{height:auto}.grid-y>.medium-1{height:8.33333%}.grid-y>.medium-2{height:16.66667%}.grid-y>.medium-3{height:25%}.grid-y>.medium-4{height:33.33333%}.grid-y>.medium-5{height:41.66667%}.grid-y>.medium-6{height:50%}.grid-y>.medium-7{height:58.33333%}.grid-y>.medium-8{height:66.66667%}.grid-y>.medium-9{height:75%}.grid-y>.medium-10{height:83.33333%}.grid-y>.medium-11{height:91.66667%}.grid-y>.medium-12{height:100%}}@media print,screen and (min-width:64em){.grid-y>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.large-shrink{height:auto}.grid-y>.large-1{height:8.33333%}.grid-y>.large-2{height:16.66667%}.grid-y>.large-3{height:25%}.grid-y>.large-4{height:33.33333%}.grid-y>.large-5{height:41.66667%}.grid-y>.large-6{height:50%}.grid-y>.large-7{height:58.33333%}.grid-y>.large-8{height:66.66667%}.grid-y>.large-9{height:75%}.grid-y>.large-10{height:83.33333%}.grid-y>.large-11{height:91.66667%}.grid-y>.large-12{height:100%}}.grid-padding-y .grid-padding-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-padding-y .grid-padding-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-padding-y>.cell{padding-top:.625rem;padding-bottom:.625rem}@media print,screen and (min-width:40em){.grid-padding-y>.cell{padding-top:.9375rem;padding-bottom:.9375rem}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .grid-frame{width:100%}.cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.cell-block-container{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;max-height:100%}.cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}@media print,screen and (min-width:40em){.medium-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .medium-grid-frame{width:100%}.medium-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.medium-cell-block-container{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;max-height:100%}.medium-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.medium-cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}}@media print,screen and (min-width:64em){.large-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .large-grid-frame{width:100%}.large-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.large-cell-block-container{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;max-height:100%}.large-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.large-cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}}.grid-y.grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}@media print,screen and (min-width:40em){.grid-y.medium-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}@media print,screen and (min-width:64em){.grid-y.large-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}.cell .grid-y.grid-frame{height:100%}@media print,screen and (min-width:40em){.cell .grid-y.medium-grid-frame{height:100%}}@media print,screen and (min-width:64em){.cell .grid-y.large-grid-frame{height:100%}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame.grid-margin-y{height:calc(100vh + 1.25rem)}@media print,screen and (min-width:40em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:40em){.grid-margin-y.medium-grid-frame{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y.large-grid-frame{height:calc(100vh + 1.875rem)}}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem 0;padding:.85em 1em;border:1px solid transparent;border-radius:0;-webkit-transition:background-color .25s ease-out,color .25s ease-out;transition:background-color .25s ease-out,color .25s ease-out;font-family:inherit;font-size:.9rem;-webkit-appearance:none;line-height:1;text-align:center;cursor:pointer;background-color:#1779ba;color:#fefefe}[data-whatinput=mouse] .button{outline:0}.button:focus,.button:hover{background-color:#14679e;color:#fefefe}.button.tiny{font-size:.6rem}.button.small{font-size:.75rem}.button.large{font-size:1.25rem}.button.expanded{display:block;width:100%;margin-right:0;margin-left:0}.button.primary{background-color:#1779ba;color:#fefefe}.button.primary:focus,.button.primary:hover{background-color:#126195;color:#fefefe}.button.secondary{background-color:#767676;color:#fefefe}.button.secondary:focus,.button.secondary:hover{background-color:#5e5e5e;color:#fefefe}.button.success{background-color:#3adb76;color:#0a0a0a}.button.success:focus,.button.success:hover{background-color:#22bb5b;color:#0a0a0a}.button.warning{background-color:#ffae00;color:#0a0a0a}.button.warning:focus,.button.warning:hover{background-color:#cc8b00;color:#0a0a0a}.button.alert{background-color:#cc4b37;color:#fefefe}.button.alert:focus,.button.alert:hover{background-color:#a53b2a;color:#fefefe}.button.disabled,.button[disabled]{opacity:.25;cursor:not-allowed}.button.disabled,.button.disabled:focus,.button.disabled:hover,.button[disabled],.button[disabled]:focus,.button[disabled]:hover{background-color:#1779ba;color:#fefefe}.button.disabled.primary,.button[disabled].primary{opacity:.25;cursor:not-allowed}.button.disabled.primary,.button.disabled.primary:focus,.button.disabled.primary:hover,.button[disabled].primary,.button[disabled].primary:focus,.button[disabled].primary:hover{background-color:#1779ba;color:#fefefe}.button.disabled.secondary,.button[disabled].secondary{opacity:.25;cursor:not-allowed}.button.disabled.secondary,.button.disabled.secondary:focus,.button.disabled.secondary:hover,.button[disabled].secondary,.button[disabled].secondary:focus,.button[disabled].secondary:hover{background-color:#767676;color:#fefefe}.button.disabled.success,.button[disabled].success{opacity:.25;cursor:not-allowed}.button.disabled.success,.button.disabled.success:focus,.button.disabled.success:hover,.button[disabled].success,.button[disabled].success:focus,.button[disabled].success:hover{background-color:#3adb76;color:#0a0a0a}.button.disabled.warning,.button[disabled].warning{opacity:.25;cursor:not-allowed}.button.disabled.warning,.button.disabled.warning:focus,.button.disabled.warning:hover,.button[disabled].warning,.button[disabled].warning:focus,.button[disabled].warning:hover{background-color:#ffae00;color:#0a0a0a}.button.disabled.alert,.button[disabled].alert{opacity:.25;cursor:not-allowed}.button.disabled.alert,.button.disabled.alert:focus,.button.disabled.alert:hover,.button[disabled].alert,.button[disabled].alert:focus,.button[disabled].alert:hover{background-color:#cc4b37;color:#fefefe}.button.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow.disabled,.button.hollow.disabled:focus,.button.hollow.disabled:hover,.button.hollow[disabled],.button.hollow[disabled]:focus,.button.hollow[disabled]:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow:focus.disabled,.button.hollow:focus[disabled],.button.hollow:hover.disabled,.button.hollow:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary:focus.disabled,.button.hollow.primary:focus[disabled],.button.hollow.primary:hover.disabled,.button.hollow.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.secondary:focus.disabled,.button.hollow.secondary:focus[disabled],.button.hollow.secondary:hover.disabled,.button.hollow.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.success:focus.disabled,.button.hollow.success:focus[disabled],.button.hollow.success:hover.disabled,.button.hollow.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.warning:focus.disabled,.button.hollow.warning:focus[disabled],.button.hollow.warning:hover.disabled,.button.hollow.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.button.hollow.alert:focus.disabled,.button.hollow.alert:focus[disabled],.button.hollow.alert:hover.disabled,.button.hollow.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear:focus,.button.clear:hover{background-color:transparent}.button.clear.disabled,.button.clear.disabled:focus,.button.clear.disabled:hover,.button.clear[disabled],.button.clear[disabled]:focus,.button.clear[disabled]:hover{background-color:transparent}.button.clear:focus,.button.clear:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover.disabled,.button.clear:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear.disabled,.button.clear:focus,.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover,.button.clear:hover.disabled,.button.clear:hover[disabled],.button.clear[disabled]{border-color:transparent}.button.clear.primary{border:1px solid #1779ba;color:#1779ba}.button.clear.primary:focus,.button.clear.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear.primary,.button.clear.primary.disabled,.button.clear.primary:focus,.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover,.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled],.button.clear.primary[disabled]{border-color:transparent}.button.clear.secondary{border:1px solid #767676;color:#767676}.button.clear.secondary:focus,.button.clear.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.clear.secondary,.button.clear.secondary.disabled,.button.clear.secondary:focus,.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover,.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled],.button.clear.secondary[disabled]{border-color:transparent}.button.clear.success{border:1px solid #3adb76;color:#3adb76}.button.clear.success:focus,.button.clear.success:hover{border-color:#157539;color:#157539}.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover.disabled,.button.clear.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.clear.success,.button.clear.success.disabled,.button.clear.success:focus,.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover,.button.clear.success:hover.disabled,.button.clear.success:hover[disabled],.button.clear.success[disabled]{border-color:transparent}.button.clear.warning{border:1px solid #ffae00;color:#ffae00}.button.clear.warning:focus,.button.clear.warning:hover{border-color:#805700;color:#805700}.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.clear.warning,.button.clear.warning.disabled,.button.clear.warning:focus,.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover,.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled],.button.clear.warning[disabled]{border-color:transparent}.button.clear.alert{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert:focus,.button.clear.alert:hover{border-color:#67251a;color:#67251a}.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert,.button.clear.alert.disabled,.button.clear.alert:focus,.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover,.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled],.button.clear.alert[disabled]{border-color:transparent}.button.dropdown::after{display:block;width:0;height:0;border:inset .4em;content:'';border-bottom-width:0;border-top-style:solid;border-color:#fefefe transparent transparent;position:relative;top:.4em;display:inline-block;float:right;margin-left:1em}.button.dropdown.clear::after,.button.dropdown.hollow::after{border-top-color:#1779ba}.button.dropdown.clear.primary::after,.button.dropdown.hollow.primary::after{border-top-color:#1779ba}.button.dropdown.clear.secondary::after,.button.dropdown.hollow.secondary::after{border-top-color:#767676}.button.dropdown.clear.success::after,.button.dropdown.hollow.success::after{border-top-color:#3adb76}.button.dropdown.clear.warning::after,.button.dropdown.hollow.warning::after{border-top-color:#ffae00}.button.dropdown.clear.alert::after,.button.dropdown.hollow.alert::after{border-top-color:#cc4b37}.button.arrow-only::after{top:-.1em;float:none;margin-left:0}a.button:focus,a.button:hover{text-decoration:none}.button-group{margin-bottom:1rem;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.button-group::after,.button-group::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.button-group::after{clear:both}.button-group .button{margin:0;margin-right:1px;margin-bottom:1px;font-size:.9rem;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.button-group .button:last-child{margin-right:0}.button-group.tiny .button{font-size:.6rem}.button-group.small .button{font-size:.75rem}.button-group.large .button{font-size:1.25rem}.button-group.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.button-group.primary .button{background-color:#1779ba;color:#fefefe}.button-group.primary .button:focus,.button-group.primary .button:hover{background-color:#126195;color:#fefefe}.button-group.secondary .button{background-color:#767676;color:#fefefe}.button-group.secondary .button:focus,.button-group.secondary .button:hover{background-color:#5e5e5e;color:#fefefe}.button-group.success .button{background-color:#3adb76;color:#0a0a0a}.button-group.success .button:focus,.button-group.success .button:hover{background-color:#22bb5b;color:#0a0a0a}.button-group.warning .button{background-color:#ffae00;color:#0a0a0a}.button-group.warning .button:focus,.button-group.warning .button:hover{background-color:#cc8b00;color:#0a0a0a}.button-group.alert .button{background-color:#cc4b37;color:#fefefe}.button-group.alert .button:focus,.button-group.alert .button:hover{background-color:#a53b2a;color:#fefefe}.button-group.stacked,.button-group.stacked-for-medium,.button-group.stacked-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.button-group.stacked .button,.button-group.stacked-for-medium .button,.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%}.button-group.stacked .button:last-child,.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child{margin-bottom:0}.button-group.stacked-for-medium.expanded .button,.button-group.stacked-for-small.expanded .button,.button-group.stacked.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}@media print,screen and (min-width:40em){.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin-bottom:0}}@media print,screen and (min-width:64em){.button-group.stacked-for-medium .button{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin-bottom:0}}@media screen and (max-width:39.99875em){.button-group.stacked-for-small.expanded{display:block}.button-group.stacked-for-small.expanded .button{display:block;margin-right:0}}@media screen and (max-width:63.99875em){.button-group.stacked-for-medium.expanded{display:block}.button-group.stacked-for-medium.expanded .button{display:block;margin-right:0}}.close-button{position:absolute;color:#8a8a8a;cursor:pointer}[data-whatinput=mouse] .close-button{outline:0}.close-button:focus,.close-button:hover{color:#0a0a0a}.close-button.small{right:.66rem;top:.33em;font-size:1.5em;line-height:1}.close-button,.close-button.medium{right:1rem;top:.5rem;font-size:2em;line-height:1}.label{display:inline-block;padding:.33333rem .5rem;border-radius:0;font-size:.8rem;line-height:1;white-space:nowrap;cursor:default;background:#1779ba;color:#fefefe}.label.primary{background:#1779ba;color:#fefefe}.label.secondary{background:#767676;color:#fefefe}.label.success{background:#3adb76;color:#0a0a0a}.label.warning{background:#ffae00;color:#0a0a0a}.label.alert{background:#cc4b37;color:#fefefe}.progress{height:1rem;margin-bottom:1rem;border-radius:0;background-color:#cacaca}.progress.primary .progress-meter{background-color:#1779ba}.progress.secondary .progress-meter{background-color:#767676}.progress.success .progress-meter{background-color:#3adb76}.progress.warning .progress-meter{background-color:#ffae00}.progress.alert .progress-meter{background-color:#cc4b37}.progress-meter{position:relative;display:block;width:0%;height:100%;background-color:#1779ba}.progress-meter-text{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);transform:translate(-50%,-50%);margin:0;font-size:.75rem;font-weight:700;color:#fefefe;white-space:nowrap}.slider{position:relative;height:.5rem;margin-top:1.25rem;margin-bottom:2.25rem;background-color:#e6e6e6;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none}.slider-fill{position:absolute;top:0;left:0;display:inline-block;max-width:100%;height:.5rem;background-color:#cacaca;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.slider-fill.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider-handle{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;-ms-touch-action:manipulation;touch-action:manipulation}[data-whatinput=mouse] .slider-handle{outline:0}.slider-handle:hover{background-color:#14679e}.slider-handle.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider.disabled,.slider[disabled]{opacity:.25;cursor:not-allowed}.slider.vertical{display:inline-block;width:.5rem;height:12.5rem;margin:0 1.25rem;-webkit-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scale(1,-1)}.slider.vertical .slider-fill{top:0;width:.5rem;max-height:100%}.slider.vertical .slider-handle{position:absolute;top:0;left:50%;width:1.4rem;height:1.4rem;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.switch{height:2rem;position:relative;margin-bottom:1rem;outline:0;font-size:.875rem;font-weight:700;color:#fefefe;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.switch-input{position:absolute;margin-bottom:0;opacity:0}.switch-paddle{position:relative;display:block;width:4rem;height:2rem;border-radius:0;background:#cacaca;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;font-weight:inherit;color:inherit;cursor:pointer}input+.switch-paddle{margin:0}.switch-paddle::after{position:absolute;top:.25rem;left:.25rem;display:block;width:1.5rem;height:1.5rem;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);border-radius:0;background:#fefefe;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;content:''}input:checked~.switch-paddle{background:#1779ba}input:checked~.switch-paddle::after{left:2.25rem}[data-whatinput=mouse] input:focus~.switch-paddle{outline:0}.switch-active,.switch-inactive{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.switch-active{left:8%;display:none}input:checked+label>.switch-active{display:block}.switch-inactive{right:15%}input:checked+label>.switch-inactive{display:none}.switch.tiny{height:1.5rem}.switch.tiny .switch-paddle{width:3rem;height:1.5rem;font-size:.625rem}.switch.tiny .switch-paddle::after{top:.25rem;left:.25rem;width:1rem;height:1rem}.switch.tiny input:checked~.switch-paddle::after{left:1.75rem}.switch.small{height:1.75rem}.switch.small .switch-paddle{width:3.5rem;height:1.75rem;font-size:.75rem}.switch.small .switch-paddle::after{top:.25rem;left:.25rem;width:1.25rem;height:1.25rem}.switch.small input:checked~.switch-paddle::after{left:2rem}.switch.large{height:2.5rem}.switch.large .switch-paddle{width:5rem;height:2.5rem;font-size:1rem}.switch.large .switch-paddle::after{top:.25rem;left:.25rem;width:2rem;height:2rem}.switch.large input:checked~.switch-paddle::after{left:2.75rem}table{border-collapse:collapse;width:100%;margin-bottom:1rem;border-radius:0}tbody,tfoot,thead{border:1px solid #f1f1f1;background-color:#fefefe}caption{padding:.5rem .625rem .625rem;font-weight:700}thead{background:#f8f8f8;color:#0a0a0a}tfoot{background:#f1f1f1;color:#0a0a0a}tfoot tr,thead tr{background:0 0}tfoot td,tfoot th,thead td,thead th{padding:.5rem .625rem .625rem;font-weight:700;text-align:left}tbody td,tbody th{padding:.5rem .625rem .625rem}tbody tr:nth-child(even){border-bottom:0;background-color:#f1f1f1}table.unstriped tbody{background-color:#fefefe}table.unstriped tbody tr{border-bottom:0;border-bottom:1px solid #f1f1f1;background-color:#fefefe}@media screen and (max-width:63.99875em){table.stack thead{display:none}table.stack tfoot{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}}table.scroll{display:block;width:100%;overflow-x:auto}table.hover thead tr:hover{background-color:#f3f3f3}table.hover tfoot tr:hover{background-color:#ececec}table.hover tbody tr:hover{background-color:#f9f9f9}table.hover:not(.unstriped) tr:nth-of-type(even):hover{background-color:#ececec}.table-scroll{overflow-x:auto}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center;background:#1779ba;color:#fefefe}.badge.primary{background:#1779ba;color:#fefefe}.badge.secondary{background:#767676;color:#fefefe}.badge.success{background:#3adb76;color:#0a0a0a}.badge.warning{background:#ffae00;color:#0a0a0a}.badge.alert{background:#cc4b37;color:#fefefe}.breadcrumbs{margin:0 0 1rem 0;list-style:none}.breadcrumbs::after,.breadcrumbs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.breadcrumbs::after{clear:both}.breadcrumbs li{float:left;font-size:.6875rem;color:#0a0a0a;cursor:default;text-transform:uppercase}.breadcrumbs li:not(:last-child)::after{position:relative;margin:0 .75rem;opacity:1;content:"/";color:#cacaca}.breadcrumbs a{color:#1779ba}.breadcrumbs a:hover{text-decoration:underline}.breadcrumbs .disabled{color:#cacaca;cursor:not-allowed}.callout{position:relative;margin:0 0 1rem 0;padding:1rem;border:1px solid rgba(10,10,10,.25);border-radius:0;background-color:#fff;color:#0a0a0a}.callout>:first-child{margin-top:0}.callout>:last-child{margin-bottom:0}.callout.primary{background-color:#d7ecfa;color:#0a0a0a}.callout.secondary{background-color:#eaeaea;color:#0a0a0a}.callout.success{background-color:#e1faea;color:#0a0a0a}.callout.warning{background-color:#fff3d9;color:#0a0a0a}.callout.alert{background-color:#f7e4e1;color:#0a0a0a}.callout.small{padding-top:.5rem;padding-right:.5rem;padding-bottom:.5rem;padding-left:.5rem}.callout.large{padding-top:3rem;padding-right:3rem;padding-bottom:3rem;padding-left:3rem}.card{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-grow:1;-ms-flex-positive:1;flex-grow:1;margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;color:#0a0a0a}.card>:last-child{margin-bottom:0}.card-divider{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;padding:1rem;background:#e6e6e6}.card-divider>:last-child{margin-bottom:0}.card-section{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto;padding:1rem}.card-section>:last-child{margin-bottom:0}.card-image{min-height:1px}.dropdown-pane{position:absolute;z-index:10;display:none;width:300px;padding:1rem;visibility:hidden;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-opening{display:block}.dropdown-pane.is-open{display:block;visibility:visible}.dropdown-pane.tiny{width:100px}.dropdown-pane.small{width:200px}.dropdown-pane.large{width:400px}.pagination{margin-left:0;margin-bottom:1rem}.pagination::after,.pagination::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.pagination::after{clear:both}.pagination li{margin-right:.0625rem;border-radius:0;font-size:.875rem;display:none}.pagination li:first-child,.pagination li:last-child{display:inline-block}@media print,screen and (min-width:40em){.pagination li{display:inline-block}}.pagination a,.pagination button{display:block;padding:.1875rem .625rem;border-radius:0;color:#0a0a0a}.pagination a:hover,.pagination button:hover{background:#e6e6e6}.pagination .current{padding:.1875rem .625rem;background:#1779ba;color:#fefefe;cursor:default}.pagination .disabled{padding:.1875rem .625rem;color:#cacaca;cursor:not-allowed}.pagination .disabled:hover{background:0 0}.pagination .ellipsis::after{padding:.1875rem .625rem;content:'\2026';color:#0a0a0a}.pagination-previous a::before,.pagination-previous.disabled::before{display:inline-block;margin-right:.5rem;content:'\00ab'}.pagination-next a::after,.pagination-next.disabled::after{display:inline-block;margin-left:.5rem;content:'\00bb'}.has-tip{position:relative;display:inline-block;border-bottom:dotted 1px #8a8a8a;font-weight:700;cursor:help}.tooltip{position:absolute;top:calc(100% + .6495rem);z-index:1200;max-width:10rem;padding:.75rem;border-radius:0;background-color:#0a0a0a;font-size:80%;color:#fefefe}.tooltip::before{position:absolute}.tooltip.bottom::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;bottom:100%}.tooltip.bottom.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.top::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.top.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.left::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.right::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.tooltip.right.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.align-top::before{bottom:auto;top:10%}.tooltip.align-bottom::before{bottom:10%;top:auto}.tooltip.align-left::before{left:10%;right:auto}.tooltip.align-right::before{left:auto;right:10%}.accordion{margin-left:0;background:#fefefe;list-style-type:none}.accordion[disabled] .accordion-title{cursor:not-allowed}.accordion-item:first-child>:first-child{border-radius:0}.accordion-item:last-child>:last-child{border-radius:0}.accordion-title{position:relative;display:block;padding:1.25rem 1rem;border:1px solid #e6e6e6;border-bottom:0;font-size:.75rem;line-height:1;color:#1779ba}:last-child:not(.is-active)>.accordion-title{border-bottom:1px solid #e6e6e6;border-radius:0}.accordion-title:focus,.accordion-title:hover{background-color:#e6e6e6}.accordion-title::before{position:absolute;top:50%;right:1rem;margin-top:-.5rem;content:'+'}.is-active>.accordion-title::before{content:'\2013'}.accordion-content{display:none;padding:1rem;border:1px solid #e6e6e6;border-bottom:0;background-color:#fefefe;color:#0a0a0a}:last-child>.accordion-content:last-child{border-bottom:1px solid #e6e6e6}.media-object{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;margin-bottom:1rem;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.media-object img{max-width:none}@media screen and (max-width:39.99875em){.media-object.stack-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}}.media-object-section{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.media-object-section:first-child{padding-right:1rem}.media-object-section:last-child:not(:nth-child(2)){padding-left:1rem}.media-object-section>:last-child{margin-bottom:0}@media screen and (max-width:39.99875em){.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;-webkit-flex-basis:100%;-ms-flex-preferred-size:100%;flex-basis:100%;max-width:100%}.stack-for-small .media-object-section img{width:100%}}.media-object-section.main-section{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.orbit{position:relative}.orbit-container{position:relative;height:0;margin:0;list-style:none;overflow:hidden}.orbit-slide{width:100%;position:absolute}.orbit-slide.no-motionui.is-active{top:0;left:0}.orbit-figure{margin:0}.orbit-image{width:100%;max-width:100%;margin:0}.orbit-caption{position:absolute;bottom:0;width:100%;margin-bottom:0;padding:1rem;background-color:rgba(10,10,10,.5);color:#fefefe}.orbit-next,.orbit-previous{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);z-index:10;padding:1rem;color:#fefefe}[data-whatinput=mouse] .orbit-next,[data-whatinput=mouse] .orbit-previous{outline:0}.orbit-next:active,.orbit-next:focus,.orbit-next:hover,.orbit-previous:active,.orbit-previous:focus,.orbit-previous:hover{background-color:rgba(10,10,10,.5)}.orbit-previous{left:0}.orbit-next{left:auto;right:0}.orbit-bullets{position:relative;margin-top:.8rem;margin-bottom:.8rem;text-align:center}[data-whatinput=mouse] .orbit-bullets{outline:0}.orbit-bullets button{width:1.2rem;height:1.2rem;margin:.1rem;border-radius:50%;background-color:#cacaca}.orbit-bullets button:hover{background-color:#8a8a8a}.orbit-bullets button.is-active{background-color:#8a8a8a}.flex-video,.responsive-embed{position:relative;height:0;margin-bottom:1rem;padding-bottom:75%;overflow:hidden}.flex-video embed,.flex-video iframe,.flex-video object,.flex-video video,.responsive-embed embed,.responsive-embed iframe,.responsive-embed object,.responsive-embed video{position:absolute;top:0;left:0;width:100%;height:100%}.flex-video.widescreen,.responsive-embed.widescreen{padding-bottom:56.25%}.tabs{margin:0;border:1px solid #e6e6e6;background:#fefefe;list-style-type:none}.tabs::after,.tabs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.tabs::after{clear:both}.tabs.vertical>li{display:block;float:none;width:auto}.tabs.simple>li>a{padding:0}.tabs.simple>li>a:hover{background:0 0}.tabs.primary{background:#1779ba}.tabs.primary>li>a{color:#fefefe}.tabs.primary>li>a:focus,.tabs.primary>li>a:hover{background:#1673b1}.tabs-title{float:left}.tabs-title>a{display:block;padding:1.25rem 1.5rem;font-size:.75rem;line-height:1;color:#1779ba}[data-whatinput=mouse] .tabs-title>a{outline:0}.tabs-title>a:hover{background:#fefefe;color:#1468a0}.tabs-title>a:focus,.tabs-title>a[aria-selected=true]{background:#e6e6e6;color:#1779ba}.tabs-content{border:1px solid #e6e6e6;border-top:0;background:#fefefe;color:#0a0a0a;-webkit-transition:all .5s ease;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-left:0}.tabs-panel{display:none;padding:1rem}.tabs-panel.is-active{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:4px solid #fefefe;border-radius:0;-webkit-box-shadow:0 0 0 1px rgba(10,10,10,.2);box-shadow:0 0 0 1px rgba(10,10,10,.2);line-height:0}a.thumbnail{-webkit-transition:-webkit-box-shadow .2s ease-out;transition:-webkit-box-shadow .2s ease-out;transition:box-shadow .2s ease-out;transition:box-shadow .2s ease-out,-webkit-box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{-webkit-box-shadow:0 0 6px 1px rgba(23,121,186,.5);box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{-webkit-box-shadow:none;box-shadow:none}.menu{padding:0;margin:0;list-style:none;position:relative;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}[data-whatinput=mouse] .menu li{outline:0}.menu .button,.menu a{line-height:1;text-decoration:none;display:block;padding:.7rem 1rem}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu input{display:inline-block}.menu,.menu.horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.simple{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.menu.simple li+li{margin-left:1rem}.menu.simple a{padding:0}@media print,screen and (min-width:40em){.menu.medium-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.medium-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.medium-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.medium-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}@media print,screen and (min-width:64em){.menu.large-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.large-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.large-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.large-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}.menu.nested{margin-right:0;margin-left:1rem}.menu.icons a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-bottom a,.menu.icon-left a,.menu.icon-right a,.menu.icon-top a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-left li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-left li a i,.menu.icon-left li a img,.menu.icon-left li a svg{margin-right:.25rem}.menu.icon-right li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-right li a i,.menu.icon-right li a img,.menu.icon-right li a svg{margin-left:.25rem}.menu.icon-top li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-top li a i,.menu.icon-top li a img,.menu.icon-top li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu.icon-bottom li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-bottom li a i,.menu.icon-bottom li a img,.menu.icon-bottom li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu .is-active>a{background:#1779ba;color:#fefefe}.menu .active>a{background:#1779ba;color:#fefefe}.menu.align-left{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-right li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.menu.align-right li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-right.vertical li{display:block;text-align:right}.menu.align-right.vertical li .submenu li{text-align:right}.menu.align-right .nested{margin-right:1rem;margin-left:0}.menu.align-center li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu.align-center li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu .menu-text{padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered>.menu{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.no-js [data-responsive-menu] ul{display:none}.menu-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#fefefe;-webkit-box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:''}.menu-icon:hover::after{background:#cacaca;-webkit-box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.menu-icon.dark{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon.dark::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;-webkit-box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:''}.menu-icon.dark:hover::after{background:#8a8a8a;-webkit-box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a;box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a}.accordion-menu li{width:100%}.accordion-menu a{padding:.7rem 1rem}.accordion-menu .is-accordion-submenu a{padding:.7rem 1rem}.accordion-menu .nested.is-accordion-submenu{margin-right:0;margin-left:1rem}.accordion-menu.align-right .nested.is-accordion-submenu{margin-right:1rem;margin-left:0}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a{position:relative}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;right:1rem}.accordion-menu.align-left .is-accordion-submenu-parent>a::after{right:1rem;left:auto}.accordion-menu.align-right .is-accordion-submenu-parent>a::after{right:auto;left:1rem}.accordion-menu .is-accordion-submenu-parent[aria-expanded=true]>a::after{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.is-accordion-submenu-parent{position:relative}.has-submenu-toggle>a{margin-right:40px}.submenu-toggle{position:absolute;top:0;right:0;width:40px;height:40px;cursor:pointer}.submenu-toggle::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;top:0;bottom:0;margin:auto}.submenu-toggle[aria-expanded=true]::after{-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.submenu-toggle-text{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.is-drilldown{position:relative;overflow:hidden}.is-drilldown li{display:block}.is-drilldown.animate-height{-webkit-transition:height .5s;transition:height .5s}.drilldown a{padding:.7rem 1rem;background:#fefefe}.drilldown .is-drilldown-submenu{position:absolute;top:0;left:100%;z-index:-1;width:100%;background:#fefefe;-webkit-transition:-webkit-transform .15s linear;transition:-webkit-transform .15s linear;transition:transform .15s linear;transition:transform .15s linear,-webkit-transform .15s linear}.drilldown .is-drilldown-submenu.is-active{z-index:1;display:block;-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%)}.drilldown .is-drilldown-submenu.is-closing{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%)}.drilldown .is-drilldown-submenu a{padding:.7rem 1rem}.drilldown .nested.is-drilldown-submenu{margin-right:0;margin-left:0}.drilldown .drilldown-submenu-cover-previous{min-height:100%}.drilldown .is-drilldown-submenu-parent>a{position:relative}.drilldown .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;position:absolute;top:50%;margin-top:-6px;right:1rem}.drilldown.align-left .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;right:1rem;left:auto}.drilldown.align-right .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:1rem}.drilldown .js-drilldown-back>a::before{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;display:inline-block;vertical-align:middle;margin-right:.75rem}.dropdown.menu>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}[data-whatinput=mouse] .dropdown.menu a{outline:0}.dropdown.menu>li>a{padding:.7rem 1rem}.dropdown.menu>li.is-active>a{background:0 0;color:#1779ba}.no-js .dropdown.menu ul{display:none}.dropdown.menu .nested.is-dropdown-submenu{margin-right:0;margin-left:0}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.vertical>li>a::after{right:14px}.dropdown.menu.vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}@media print,screen and (min-width:40em){.dropdown.menu.medium-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.medium-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.medium-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.medium-vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.medium-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.medium-vertical>li>a::after{right:14px}.dropdown.menu.medium-vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.medium-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}@media print,screen and (min-width:64em){.dropdown.menu.large-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.large-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.large-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.large-vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.large-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.large-vertical>li>a::after{right:14px}.dropdown.menu.large-vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.large-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}.dropdown.menu.align-right .is-dropdown-submenu.first-sub{top:100%;right:0;left:auto}.is-dropdown-menu.vertical{width:100px}.is-dropdown-menu.vertical.align-right{float:right}.is-dropdown-submenu-parent{position:relative}.is-dropdown-submenu-parent a::after{position:absolute;top:50%;right:5px;left:auto;margin-top:-6px}.is-dropdown-submenu-parent.opens-inner>.is-dropdown-submenu{top:100%;left:auto}.is-dropdown-submenu-parent.opens-left>.is-dropdown-submenu{right:100%;left:auto}.is-dropdown-submenu-parent.opens-right>.is-dropdown-submenu{right:auto;left:100%}.is-dropdown-submenu{position:absolute;top:0;left:100%;z-index:1;display:none;min-width:200px;border:1px solid #cacaca;background:#fefefe}.dropdown .is-dropdown-submenu a{padding:.7rem 1rem}.is-dropdown-submenu .is-dropdown-submenu-parent>a::after{right:14px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.is-dropdown-submenu .is-dropdown-submenu{margin-top:-1px}.is-dropdown-submenu>li{width:100%}.is-dropdown-submenu.js-dropdown-active{display:block}.is-off-canvas-open{overflow:hidden}.js-off-canvas-overlay{position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;-webkit-transition:opacity .5s ease,visibility .5s ease;transition:opacity .5s ease,visibility .5s ease;background:rgba(254,254,254,.25);opacity:0;visibility:hidden;overflow:hidden}.js-off-canvas-overlay.is-visible{opacity:1;visibility:visible}.js-off-canvas-overlay.is-closable{cursor:pointer}.js-off-canvas-overlay.is-overlay-absolute{position:absolute}.js-off-canvas-overlay.is-overlay-fixed{position:fixed}.off-canvas-wrapper{position:relative;overflow:hidden}.off-canvas{position:fixed;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-push{z-index:12}.off-canvas.is-closed{visibility:hidden}.off-canvas.is-transition-overlap{z-index:13}.off-canvas.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-absolute{position:absolute;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas-absolute{outline:0}.off-canvas-absolute.is-transition-push{z-index:12}.off-canvas-absolute.is-closed{visibility:hidden}.off-canvas-absolute.is-transition-overlap{z-index:13}.off-canvas-absolute.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas-absolute.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.position-left{top:0;left:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-left.has-transition-push{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.position-left.is-transition-push{-webkit-box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25)}.position-right{top:0;right:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-right.has-transition-push{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.position-right.is-transition-push{-webkit-box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25)}.position-top{top:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-top.has-transition-push{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.position-top.is-transition-push{-webkit-box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25)}.position-bottom{bottom:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-bottom.has-transition-push{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.position-bottom.is-transition-push{-webkit-box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25)}.off-canvas-content{-webkit-transform:none;-ms-transform:none;transform:none;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.off-canvas-content.has-transition-push{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content .off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}@media print,screen and (min-width:40em){.position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-medium .close-button{display:none}.off-canvas-content .position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-medium .close-button{display:none}.off-canvas-content .position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-medium .close-button{display:none}.off-canvas-content .position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-medium .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:64em){.position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-large .close-button{display:none}.off-canvas-content .position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-large .close-button{display:none}.off-canvas-content .position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-large .close-button{display:none}.off-canvas-content .position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-large .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:40em){.off-canvas.in-canvas-for-medium{visibility:visible;height:auto;position:static;background:0 0;width:auto;overflow:visible;-webkit-transition:none;transition:none}.off-canvas.in-canvas-for-medium.position-bottom,.off-canvas.in-canvas-for-medium.position-left,.off-canvas.in-canvas-for-medium.position-right,.off-canvas.in-canvas-for-medium.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-medium .close-button{display:none}}@media print,screen and (min-width:64em){.off-canvas.in-canvas-for-large{visibility:visible;height:auto;position:static;background:0 0;width:auto;overflow:visible;-webkit-transition:none;transition:none}.off-canvas.in-canvas-for-large.position-bottom,.off-canvas.in-canvas-for-large.position-left,.off-canvas.in-canvas-for-large.position-right,.off-canvas.in-canvas-for-large.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-large .close-button{display:none}}html.is-reveal-open{position:fixed;width:100%;overflow-y:hidden}html.is-reveal-open.zf-has-scroll{overflow-y:scroll}html.is-reveal-open body{overflow-y:hidden}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;display:none;background-color:rgba(10,10,10,.45);overflow-y:auto}.reveal{z-index:1006;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:none;padding:1rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;position:relative;top:100px;margin-right:auto;margin-left:auto;overflow-y:auto}[data-whatinput=mouse] .reveal{outline:0}@media print,screen and (min-width:40em){.reveal{min-height:0}}.reveal .column{min-width:0}.reveal>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.reveal{width:600px;max-width:75rem}}.reveal.collapse{padding:0}@media print,screen and (min-width:40em){.reveal.tiny{width:30%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.small{width:50%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.large{width:90%;max-width:75rem}}.reveal.full{top:0;right:0;bottom:0;left:0;width:100%;max-width:none;height:100%;min-height:100%;margin-left:0;border:0;border-radius:0}@media screen and (max-width:39.99875em){.reveal{top:0;right:0;bottom:0;left:0;width:100%;max-width:none;height:100%;min-height:100%;margin-left:0;border:0;border-radius:0}}.reveal.without-overlay{position:fixed}.sticky-container{position:relative}.sticky{position:relative;z-index:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.sticky.is-stuck{position:fixed;z-index:5;width:100%}.sticky.is-stuck.is-at-top{top:0}.sticky.is-stuck.is-at-bottom{bottom:0}.sticky.is-anchored{position:relative;right:auto;left:auto}.sticky.is-anchored.is-at-bottom{bottom:0}.title-bar{padding:.5rem;background:#0a0a0a;color:#fefefe;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.title-bar .menu-icon{margin-left:.25rem;margin-right:.25rem}.title-bar-left,.title-bar-right{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.title-bar-right{text-align:right}.title-bar-title{display:inline-block;vertical-align:middle;font-weight:700}.top-bar{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;padding:.5rem;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar,.top-bar ul{background-color:#e6e6e6}.top-bar input{max-width:200px;margin-right:1rem}.top-bar .input-group-field{width:100%;margin-right:0}.top-bar input.button{width:auto}.top-bar .top-bar-left,.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}@media print,screen and (min-width:40em){.top-bar{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.top-bar .top-bar-left{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;margin-right:auto}.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;margin-left:auto}}@media screen and (max-width:63.99875em){.top-bar.stacked-for-medium{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}@media screen and (max-width:74.99875em){.top-bar.stacked-for-large{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-large .top-bar-left,.top-bar.stacked-for-large .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}.top-bar-title{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin:.5rem 1rem .5rem 0}.top-bar-left,.top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.float-left{float:left!important}.float-right{float:right!important}.float-center{display:block;margin-right:auto;margin-left:auto}.clearfix::after,.clearfix::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.clearfix::after{clear:both}.align-left{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.align-right{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-justify{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between}.align-spaced{-webkit-justify-content:space-around;-ms-flex-pack:distribute;justify-content:space-around}.align-left.vertical.menu>li>a{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.align-right.vertical.menu>li>a{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center.vertical.menu>li>a{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-top{-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start}.align-self-top{-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start}.align-bottom{-webkit-box-align:end;-webkit-align-items:flex-end;-ms-flex-align:end;align-items:flex-end}.align-self-bottom{-webkit-align-self:flex-end;-ms-flex-item-align:end;align-self:flex-end}.align-middle{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.align-self-middle{-webkit-align-self:center;-ms-flex-item-align:center;align-self:center}.align-stretch{-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.align-self-stretch{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch}.align-center-middle{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-align-content:center;-ms-flex-line-pack:center;align-content:center}.small-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.small-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.small-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.small-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.small-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.small-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}@media print,screen and (min-width:40em){.medium-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.medium-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.medium-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.medium-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.medium-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.medium-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}@media print,screen and (min-width:64em){.large-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.large-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.large-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.large-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.large-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.large-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}.flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}@media print,screen and (min-width:40em){.medium-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.medium-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.medium-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.medium-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.medium-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.medium-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.medium-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.medium-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}@media print,screen and (min-width:64em){.large-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.large-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.large-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.large-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.large-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.large-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.large-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.large-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}.hide{display:none!important}.invisible{visibility:hidden}@media screen and (max-width:39.99875em){.hide-for-small-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media print,screen and (min-width:40em){.hide-for-medium{display:none!important}}@media screen and (max-width:39.99875em){.show-for-medium{display:none!important}}@media screen and (min-width:40em) and (max-width:63.99875em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:39.99875em),screen and (min-width:64em){.show-for-medium-only{display:none!important}}@media print,screen and (min-width:64em){.hide-for-large{display:none!important}}@media screen and (max-width:63.99875em){.show-for-large{display:none!important}}@media screen and (min-width:64em) and (max-width:74.99875em){.hide-for-large-only{display:none!important}}@media screen and (max-width:63.99875em),screen and (min-width:75em){.show-for-large-only{display:none!important}}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}.hide-for-portrait,.show-for-landscape{display:block!important}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}}.hide-for-landscape,.show-for-portrait{display:none!important}@media screen and (orientation:landscape){.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-landscape,.show-for-portrait{display:block!important}}.text-hide{font:0/0 a!important;color:transparent!important;text-shadow:none!important;background-color:transparent!important;border:0!important}.text-truncate{max-width:100%!important;overflow:hidden!important;text-overflow:ellipsis;white-space:nowrap!important}.text-nowrap{white-space:nowrap!important}.text-wrap{word-wrap:break-word!important}.text-lowercase{text-transform:lowercase!important}.text-uppercase{text-transform:uppercase!important}.text-capitalize{text-transform:capitalize!important}.text-overline{text-decoration:overline!important}.text-underline{text-decoration:underline!important}.text-line-through{text-decoration:line-through!important}.font-wide{letter-spacing:.25rem}.font-normal{font-weight:400}.font-bold{font-weight:700}.font-italic{font-style:italic!important}ul.list-disc{list-style-type:disc!important}ul.list-circle{list-style-type:circle!important}ul.list-square{list-style-type:square!important}ol.list-decimal{list-style-type:decimal!important}ol.list-lower-alpha{list-style-type:lower-alpha!important}ol.list-lower-latin{list-style-type:lower-latin!important}ol.list-lower-roman{list-style-type:lower-roman!important}ol.list-upper-alpha{list-style-type:upper-alpha!important}ol.list-upper-latin{list-style-type:upper-latin!important}ol.list-upper-roman{list-style-type:upper-roman!important}.rounded{border-radius:5000px!important}.rounded:after{border-radius:50%}.radius{border-radius:.1875rem}.bordered{border:.0625rem solid #cacaca}.shadow{-webkit-box-shadow:0 2px 5px 0 rgba(0,0,0,.16),0 2px 10px 0 rgba(0,0,0,.12);box-shadow:0 2px 5px 0 rgba(0,0,0,.16),0 2px 10px 0 rgba(0,0,0,.12)}.arrow-down{display:block;width:0;height:0;border:inset .4375rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent}.arrow-up{display:block;width:0;height:0;border:inset .4375rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a}.arrow-right{display:block;width:0;height:0;border:inset .4375rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a}.arrow-left{display:block;width:0;height:0;border:inset .4375rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent}.separator-center{text-align:center!important}.separator-center::after,.separator-center::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.separator-center::after{clear:both}.separator-center::after{position:relative!important;width:3rem;border-bottom:.125rem solid #1779ba;margin:1rem auto 0}.separator-left{text-align:left!important}.separator-left::after,.separator-left::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.separator-left::after{clear:both}.separator-left::after{position:relative!important;width:3rem;border-bottom:.125rem solid #1779ba;margin:1rem auto 0;margin-left:0!important}.separator-right{text-align:right!important}.separator-right::after,.separator-right::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.separator-right::after{clear:both}.separator-right::after{position:relative!important;width:3rem;border-bottom:.125rem solid #1779ba;margin:1rem auto 0;margin-right:0!important}.overflow-visible{overflow:visible!important}.overflow-x-visible{overflow-x:visible!important}.overflow-y-visible{overflow-y:visible!important}.overflow-hidden{overflow:hidden!important}.overflow-x-hidden{overflow-x:hidden!important}.overflow-y-hidden{overflow-y:hidden!important}.overflow-scroll{overflow:scroll!important}.overflow-x-scroll{overflow-x:scroll!important}.overflow-y-scroll{overflow-y:scroll!important}.display-inline{display:inline!important}.display-inline-block{display:inline-block!important}.display-block{display:block!important}.display-table{display:table!important}.display-table-cell{display:table-cell!important}.position-static{position:static!important}.position-relative{position:relative!important}.position-absolute{position:absolute!important}.position-fixed{position:fixed!important}.position-fixed-top{position:fixed!important;top:0!important;right:0!important;left:0!important;z-index:975}.position-fixed-bottom{position:fixed!important;right:0!important;bottom:0!important;left:0!important;z-index:975}.border-box{-webkit-box-sizing:border-box!important;box-sizing:border-box!important}.border-none{border:none!important}.width-25{width:25%!important}.width-50{width:50%!important}.width-75{width:75%!important}.width-100{width:100%!important}.height-25{height:25%!important}.height-50{height:50%!important}.height-75{height:75%!important}.height-100{height:100%!important}.max-width-100{max-width:100%!important}.max-height-100{max-height:100%!important}.margin-0{margin:0}.margin-top-0{margin-top:0!important}.margin-right-0{margin-right:0!important}.margin-bottom-0{margin-bottom:0!important}.margin-left-0{margin-left:0!important}.margin-horizontal-0{margin-right:0!important;margin-left:0!important}.margin-vertical-0{margin-top:0!important;margin-bottom:0!important}.padding-0{padding:0}.padding-top-0{padding-top:0!important}.padding-right-0{padding-right:0!important}.padding-bottom-0{padding-bottom:0!important}.padding-left-0{padding-left:0!important}.padding-horizontal-0{padding-right:0!important;padding-left:0!important}.padding-vertical-0{padding-top:0!important;padding-bottom:0!important}.margin-1{margin:1rem}.margin-top-1{margin-top:1rem!important}.margin-right-1{margin-right:1rem!important}.margin-bottom-1{margin-bottom:1rem!important}.margin-left-1{margin-left:1rem!important}.margin-horizontal-1{margin-right:1rem!important;margin-left:1rem!important}.margin-vertical-1{margin-top:1rem!important;margin-bottom:1rem!important}.padding-1{padding:1rem}.padding-top-1{padding-top:1rem!important}.padding-right-1{padding-right:1rem!important}.padding-bottom-1{padding-bottom:1rem!important}.padding-left-1{padding-left:1rem!important}.padding-horizontal-1{padding-right:1rem!important;padding-left:1rem!important}.padding-vertical-1{padding-top:1rem!important;padding-bottom:1rem!important}.margin-2{margin:2rem}.margin-top-2{margin-top:2rem!important}.margin-right-2{margin-right:2rem!important}.margin-bottom-2{margin-bottom:2rem!important}.margin-left-2{margin-left:2rem!important}.margin-horizontal-2{margin-right:2rem!important;margin-left:2rem!important}.margin-vertical-2{margin-top:2rem!important;margin-bottom:2rem!important}.padding-2{padding:2rem}.padding-top-2{padding-top:2rem!important}.padding-right-2{padding-right:2rem!important}.padding-bottom-2{padding-bottom:2rem!important}.padding-left-2{padding-left:2rem!important}.padding-horizontal-2{padding-right:2rem!important;padding-left:2rem!important}.padding-vertical-2{padding-top:2rem!important;padding-bottom:2rem!important}.margin-3{margin:3rem}.margin-top-3{margin-top:3rem!important}.margin-right-3{margin-right:3rem!important}.margin-bottom-3{margin-bottom:3rem!important}.margin-left-3{margin-left:3rem!important}.margin-horizontal-3{margin-right:3rem!important;margin-left:3rem!important}.margin-vertical-3{margin-top:3rem!important;margin-bottom:3rem!important}.padding-3{padding:3rem}.padding-top-3{padding-top:3rem!important}.padding-right-3{padding-right:3rem!important}.padding-bottom-3{padding-bottom:3rem!important}.padding-left-3{padding-left:3rem!important}.padding-horizontal-3{padding-right:3rem!important;padding-left:3rem!important}.padding-vertical-3{padding-top:3rem!important;padding-bottom:3rem!important}
+/*# sourceMappingURL=foundation-prototype.min.css.map */
diff --git a/dist/css/foundation-prototype.min.css.map b/dist/css/foundation-prototype.min.css.map
new file mode 100644 (file)
index 0000000..aa2f4b6
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation-prototype.min.css"],"names":[],"mappings":"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ACE,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,UACT,mBACE,MAAO,MAEX,aAAc,4BACZ,oBACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,IACd,SAAU,EAAE,EAAE,IACV,KAAM,EAAE,EAAE,IAClB,MAAO,KACgB,iBAAoL,kBAAqB,kBAAqB,kBAA1M,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAzL,sBACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KACpB,sBACE,MAAO,KACT,iBACE,MAAO,SACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,iBACE,MAAO,UACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,iBACE,MAAO,UACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,UACT,kBACE,MAAO,MAEX,kCACE,MAAO,KAET,kCACE,OAAQ,KAEV,eACE,YAAa,SACb,aAAc,SACd,aAAc,4BACZ,eACE,YAAa,UACb,aAAc,WAClB,qBACE,MAAO,qBACP,YAAa,QACb,aAAc,QAChB,aAAc,4BACZ,qBACE,MAAO,sBACP,YAAa,SACb,aAAc,UAClB,qBACE,MAAO,KACT,uBACE,MAAO,KACT,wBACE,MAAO,yBACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,wBACE,MAAO,0BACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,wBACE,MAAO,0BACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,yBACE,MAAO,0BACT,yBACE,MAAO,0BACT,yBACE,MAAO,qBACT,aAAc,4BACZ,qBACE,MAAO,KACT,uBACE,MAAO,KACT,wBACE,MAAO,0BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,sBACT,4BACE,MAAO,KACT,8BACE,MAAO,KACT,yBACE,MAAO,0BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,0BACE,MAAO,2BACT,0BACE,MAAO,2BACT,0BACE,MAAO,uBACX,aAAc,4BACZ,2BACE,MAAO,KACT,6BACE,MAAO,KACT,wBACE,MAAO,0BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,uBAEb,gCACE,aAAc,SACd,YAAa,SACb,aAAc,4BACZ,gCACE,aAAc,UACd,YAAa,WAEnB,2CACE,aAAc,SACd,YAAa,SACb,aAAc,4BACZ,2CACE,aAAc,UACd,YAAa,WAEnB,sBACE,cAAe,QACf,aAAc,QACd,aAAc,4BACZ,sBACE,cAAe,SACf,aAAc,UAEpB,kBACE,MAAO,KAET,kBACE,MAAO,IAET,kBACE,MAAO,UAET,kBACE,MAAO,IAET,kBACE,MAAO,IAET,kBACE,MAAO,UAET,kBACE,MAAO,UAET,kBACE,MAAO,MAET,aAAc,4BACZ,mBACE,MAAO,KACT,mBACE,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,IACT,mBACE,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,UACT,mBACE,MAAO,OAEX,aAAc,4BACZ,kBACE,MAAO,KACT,kBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,IACT,kBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,UACT,kBACE,MAAO,OAEX,gCACE,MAAO,qBAET,gCACE,MAAO,oBAET,gCACE,MAAO,0BAET,gCACE,MAAO,oBAET,gCACE,MAAO,oBAET,gCACE,MAAO,0BAET,gCACE,MAAO,0BAET,gCACE,MAAO,sBAET,aAAc,4BACZ,gCACE,MAAO,sBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,qBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,2BACT,gCACE,MAAO,uBACT,iCACE,MAAO,sBACT,iCACE,MAAO,qBACT,iCACE,MAAO,2BACT,iCACE,MAAO,qBACT,iCACE,MAAO,qBACT,iCACE,MAAO,2BACT,iCACE,MAAO,2BACT,iCACE,MAAO,wBAEX,aAAc,4BACZ,gCACE,MAAO,sBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,qBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,2BACT,gCACE,MAAO,wBAEX,uBACE,aAAc,EACd,YAAa,EACb,6BACE,aAAc,EACd,YAAa,EACf,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,KACT,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MACX,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,MAEb,wBACE,aAAc,EACd,YAAa,EACb,8BACE,cAAe,EACf,aAAc,EAElB,aAAc,4BACZ,wBACE,aAAc,EACd,YAAa,EACb,8BACE,aAAc,EACd,YAAa,GAEnB,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,kCACE,MAAO,SACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,mCACE,MAAO,UACT,mCACE,MAAO,UACT,mCACE,MAAO,MAEX,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,yBACE,aAAc,EACd,YAAa,EACb,+BACE,cAAe,EACf,aAAc,GAEpB,aAAc,4BACZ,uBACE,aAAc,EACd,YAAa,EACb,6BACE,aAAc,EACd,YAAa,GAEnB,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,MAEX,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,MAEX,aAAc,4BACZ,wBACE,aAAc,EACd,YAAa,EACb,8BACE,cAAe,EACf,aAAc,GAEpB,gBACE,YAAa,EAEf,+BACE,YAAa,mBAEf,gBACE,YAAa,SAEf,+BACE,YAAa,yBAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,IAEf,+BACE,YAAa,oBAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,IAEf,+BACE,YAAa,oBAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,IAEf,+BACE,YAAa,oBAEf,iBACE,YAAa,UAEf,gCACE,YAAa,0BAEf,iBACE,YAAa,UAEf,gCACE,YAAa,0BAEf,aAAc,4BACZ,iBACE,YAAa,EACf,gCACE,YAAa,oBACf,iBACE,YAAa,SACf,gCACE,YAAa,0BACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,IACf,gCACE,YAAa,qBACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,IACf,gCACE,YAAa,qBACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,IACf,gCACE,YAAa,qBACf,kBACE,YAAa,UACf,iCACE,YAAa,2BACf,kBACE,YAAa,UACf,iCACE,YAAa,4BAEjB,aAAc,4BACZ,gBACE,YAAa,EACf,+BACE,YAAa,oBACf,gBACE,YAAa,SACf,+BACE,YAAa,0BACf,gBACE,YAAa,UACf,+BACE,YAAa,2BACf,gBACE,YAAa,IACf,+BACE,YAAa,qBACf,gBACE,YAAa,UACf,+BACE,YAAa,2B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","file":"foundation-prototype.min.css","sourcesContent":[]}
\ No newline at end of file
index 5bae40821ce872bc8fef9db067d130603de37909..3b4f38eb2a7a91a237dddd88bdac884787204238 100644 (file)
@@ -1,7 +1,7 @@
 @charset "UTF-8";
 /**
  * Foundation for Sites by ZURB
- * Version 6.4.3
+ * Version 6.5.3
  * foundation.zurb.com
  * Licensed under MIT Open Source
  */
     left: auto;
     margin: 0 auto; } }
 
-/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */
-/* Document
-       ========================================================================== */
-/**
-     * 1. Change the default font family in all browsers (opinionated).
-     * 2. Correct the line height in all browsers.
-     * 3. Prevent adjustments of font size after orientation changes in
-     *    IE on Windows Phone and in iOS.
-     */
+/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
 html {
-  font-family: sans-serif;
-  /* 1 */
   line-height: 1.15;
-  /* 2 */
-  -ms-text-size-adjust: 100%;
-  /* 3 */
-  -webkit-text-size-adjust: 100%;
-  /* 3 */ }
-
-/* Sections
-       ========================================================================== */
-/**
-     * Remove the margin in all browsers (opinionated).
-     */
+  -webkit-text-size-adjust: 100%; }
+
 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-.
-     */
-figcaption,
-figure {
-  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 */ }
-
-/**
-     * Add the correct display in IE.
-     */
-main {
-  display: block; }
+  overflow: visible; }
 
-/**
-     * 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 */ }
+  font-size: 1em; }
 
-/* Links
-       ========================================================================== */
-/**
-     * 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 */ }
+  background-color: transparent; }
 
-/**
-     * Remove the outline on focused links when they are also active or hovered
-     * in all browsers (opinionated).
-     */
-a:active,
-a:hover {
-  outline-width: 0; }
-
-/* Text-level semantics
-       ========================================================================== */
-/**
-     * 1. Remove the bottom border in 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 */
-  text-decoration: underline dotted;
-  /* 2 */ }
+  -webkit-text-decoration: underline dotted;
+          text-decoration: underline dotted; }
 
-/**
-     * 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; }
+  font-size: 1em; }
 
-/**
-     * 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%;
@@ -197,237 +68,94 @@ sub {
 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-family: inherit;
   font-size: 100%;
-  /* 1 */
   line-height: 1.15;
-  /* 1 */
-  margin: 0;
-  /* 2 */ }
+  margin: 0; }
 
-/**
-     * Show the overflow in IE.
-     */
-button {
+button,
+input {
   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 */ }
-
 button,
 [type="button"],
 [type="reset"],
 [type="submit"] {
-  /**
-       * Remove the inner border and padding in Firefox.
-       */
-  /**
-       * Restore the focus styles unset by the previous rule.
-       */ }
-  button::-moz-focus-inner,
-  [type="button"]::-moz-focus-inner,
-  [type="reset"]::-moz-focus-inner,
-  [type="submit"]::-moz-focus-inner {
-    border-style: none;
-    padding: 0; }
-  button:-moz-focusring,
-  [type="button"]:-moz-focusring,
-  [type="reset"]:-moz-focusring,
-  [type="submit"]:-moz-focusring {
-    outline: 1px dotted ButtonText; }
-
-/**
-     * Show the overflow in Edge.
-     */
-input {
-  overflow: visible; }
-
-/**
-     * 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 */ }
+  -webkit-appearance: button; }
 
-/**
-     * 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; }
+button::-moz-focus-inner,
+[type="button"]::-moz-focus-inner,
+[type="reset"]::-moz-focus-inner,
+[type="submit"]::-moz-focus-inner {
+  border-style: none;
+  padding: 0; }
 
-/**
-     * 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 */ }
+button:-moz-focusring,
+[type="button"]:-moz-focusring,
+[type="reset"]:-moz-focusring,
+[type="submit"]:-moz-focusring {
+  outline: 1px dotted ButtonText; }
 
-/**
-     * Change the border, margin, and padding in all browsers (opinionated).
-     */
 fieldset {
-  border: 1px solid #c0c0c0;
-  margin: 0 2px;
-  padding: 0.35em 0.625em 0.75em; }
+  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;
   display: table;
-  /* 1 */
   max-width: 100%;
-  /* 1 */
   padding: 0;
-  /* 3 */
-  color: inherit;
-  /* 2 */
-  white-space: normal;
-  /* 1 */ }
+  white-space: normal; }
 
-/**
-     * 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 */ }
+  vertical-align: baseline; }
 
-/**
-     * Remove the default vertical scrollbar in IE.
-     */
 textarea {
   overflow: auto; }
 
-/* Interactive
-       ========================================================================== */
-/*
-     * Add the correct display in Edge, IE, and Firefox.
-     */
+[type="checkbox"],
+[type="radio"] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  padding: 0; }
+
+[type="number"]::-webkit-inner-spin-button,
+[type="number"]::-webkit-outer-spin-button {
+  height: auto; }
+
+[type="search"] {
+  -webkit-appearance: textfield;
+  outline-offset: -2px; }
+
+[type="search"]::-webkit-search-decoration {
+  -webkit-appearance: none; }
+
+::-webkit-file-upload-button {
+  -webkit-appearance: button;
+  font: inherit; }
+
 details {
   display: block; }
 
-/*
-     * Add the correct display in all browsers.
-     */
 summary {
   display: list-item; }
 
-/*
-     * Add the correct display in IE 9-.
-     */
-menu {
-  display: block; }
-
-/* 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; }
 
@@ -511,3974 +239,3312 @@ textarea {
 .is-hidden {
   display: none !important; }
 
-.grid-container {
-  padding-right: 0.625rem;
-  padding-left: 0.625rem;
-  max-width: 75rem;
-  margin: 0 auto; }
-  @media print, screen and (min-width: 40em) {
-    .grid-container {
-      padding-right: 0.9375rem;
-      padding-left: 0.9375rem; } }
-  .grid-container.fluid {
-    padding-right: 0.625rem;
-    padding-left: 0.625rem;
-    max-width: 100%;
-    margin: 0 auto; }
-    @media print, screen and (min-width: 40em) {
-      .grid-container.fluid {
-        padding-right: 0.9375rem;
-        padding-left: 0.9375rem; } }
-  .grid-container.full {
-    padding-right: 0;
-    padding-left: 0;
-    max-width: 100%;
-    margin: 0 auto; }
-
-.grid-x {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-orient: horizontal;
-  -webkit-box-direction: normal;
-  -webkit-flex-flow: row wrap;
-      -ms-flex-flow: row wrap;
-          flex-flow: row wrap; }
-
-.cell {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto;
-  min-height: 0px;
-  min-width: 0px;
-  width: 100%; }
-  .cell.auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-  .cell.shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto; }
+[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],
+textarea {
+  display: block;
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  width: 100%;
+  height: 2.4375rem;
+  margin: 0 0 1rem;
+  padding: 0.5rem;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
+          box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
+  font-family: inherit;
+  font-size: 1rem;
+  font-weight: normal;
+  line-height: 1.5;
+  color: #0a0a0a;
+  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none; }
+  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,
+  textarea:focus {
+    outline: none;
+    border: 1px solid #8a8a8a;
+    background-color: #fefefe;
+    -webkit-box-shadow: 0 0 5px #cacaca;
+            box-shadow: 0 0 5px #cacaca;
+    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
 
-.grid-x > .auto {
-  width: auto; }
+textarea {
+  max-width: 100%; }
+  textarea[rows] {
+    height: auto; }
 
-.grid-x > .shrink {
-  width: auto; }
+input:disabled, input[readonly],
+textarea:disabled,
+textarea[readonly] {
+  background-color: #e6e6e6;
+  cursor: not-allowed; }
 
-.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
-  -webkit-flex-basis: auto;
-      -ms-flex-preferred-size: auto;
-          flex-basis: auto; }
+[type='submit'],
+[type='button'] {
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none;
+  border-radius: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; } }
+input[type='search'] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; } }
+::-webkit-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-1 {
-  width: 8.33333%; }
+:-ms-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-2 {
-  width: 16.66667%; }
+::-ms-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-3 {
-  width: 25%; }
+::placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-4 {
-  width: 33.33333%; }
+[type='file'],
+[type='checkbox'],
+[type='radio'] {
+  margin: 0 0 1rem; }
 
-.grid-x > .small-5 {
-  width: 41.66667%; }
+[type='checkbox'] + label,
+[type='radio'] + label {
+  display: inline-block;
+  vertical-align: baseline;
+  margin-right: 0.5rem;
+  margin-left: 1rem;
+  margin-bottom: 0; }
+  [type='checkbox'] + label[for],
+  [type='radio'] + label[for] {
+    cursor: pointer; }
 
-.grid-x > .small-6 {
-  width: 50%; }
+label > [type='checkbox'],
+label > [type='radio'] {
+  margin-left: 0.5rem; }
 
-.grid-x > .small-7 {
-  width: 58.33333%; }
+[type='file'] {
+  width: 100%; }
 
-.grid-x > .small-8 {
-  width: 66.66667%; }
+label {
+  display: block;
+  margin: 0;
+  font-size: 0.875rem;
+  font-weight: normal;
+  line-height: 1.8;
+  color: #0a0a0a; }
+  label.middle {
+    margin: 0 0 1rem;
+    padding: 0.5625rem 0; }
 
-.grid-x > .small-9 {
-  width: 75%; }
+.help-text {
+  margin-top: -0.5rem;
+  font-size: 0.8125rem;
+  font-style: italic;
+  color: #0a0a0a; }
 
-.grid-x > .small-10 {
-  width: 83.33333%; }
+.input-group {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  width: 100%;
+  margin-bottom: 1rem;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch; }
+  .input-group > :first-child, .input-group > :first-child.input-group-button > * {
+    border-radius: 0 0 0 0; }
+  .input-group > :last-child, .input-group > :last-child.input-group-button > * {
+    border-radius: 0 0 0 0; }
 
-.grid-x > .small-11 {
-  width: 91.66667%; }
+.input-group-label, .input-group-field, .input-group-button, .input-group-button a,
+.input-group-button input,
+.input-group-button button,
+.input-group-button label {
+  margin: 0;
+  white-space: nowrap; }
 
-.grid-x > .small-12 {
-  width: 100%; }
+.input-group-label {
+  padding: 0 1rem;
+  border: 1px solid #cacaca;
+  background: #e6e6e6;
+  color: #0a0a0a;
+  text-align: center;
+  white-space: nowrap;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto;
+  -webkit-box-align: center;
+  -webkit-align-items: center;
+      -ms-flex-align: center;
+          align-items: center; }
+  .input-group-label:first-child {
+    border-left: 0; }
+  .input-group-label:last-child {
+    border-right: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-x > .medium-auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px;
-    width: auto; }
-  .grid-x > .medium-shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto;
-    width: auto; }
-  .grid-x > .medium-1 {
-    width: 8.33333%; }
-  .grid-x > .medium-2 {
-    width: 16.66667%; }
-  .grid-x > .medium-3 {
-    width: 25%; }
-  .grid-x > .medium-4 {
-    width: 33.33333%; }
-  .grid-x > .medium-5 {
-    width: 41.66667%; }
-  .grid-x > .medium-6 {
-    width: 50%; }
-  .grid-x > .medium-7 {
-    width: 58.33333%; }
-  .grid-x > .medium-8 {
-    width: 66.66667%; }
-  .grid-x > .medium-9 {
-    width: 75%; }
-  .grid-x > .medium-10 {
-    width: 83.33333%; }
-  .grid-x > .medium-11 {
-    width: 91.66667%; }
-  .grid-x > .medium-12 {
-    width: 100%; } }
+.input-group-field {
+  border-radius: 0;
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 1 0px;
+      -ms-flex: 1 1 0px;
+          flex: 1 1 0px;
+  min-width: 0; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-x > .large-auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px;
-    width: auto; }
-  .grid-x > .large-shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto;
-    width: auto; }
-  .grid-x > .large-1 {
-    width: 8.33333%; }
-  .grid-x > .large-2 {
-    width: 16.66667%; }
-  .grid-x > .large-3 {
-    width: 25%; }
-  .grid-x > .large-4 {
-    width: 33.33333%; }
-  .grid-x > .large-5 {
-    width: 41.66667%; }
-  .grid-x > .large-6 {
-    width: 50%; }
-  .grid-x > .large-7 {
-    width: 58.33333%; }
-  .grid-x > .large-8 {
-    width: 66.66667%; }
-  .grid-x > .large-9 {
-    width: 75%; }
-  .grid-x > .large-10 {
-    width: 83.33333%; }
-  .grid-x > .large-11 {
-    width: 91.66667%; }
-  .grid-x > .large-12 {
-    width: 100%; } }
+.input-group-button {
+  padding-top: 0;
+  padding-bottom: 0;
+  text-align: center;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto; }
+  .input-group-button a,
+  .input-group-button input,
+  .input-group-button button,
+  .input-group-button label {
+    -webkit-align-self: stretch;
+        -ms-flex-item-align: stretch;
+            align-self: stretch;
+    height: auto;
+    padding-top: 0;
+    padding-bottom: 0;
+    font-size: 1rem; }
 
-.grid-margin-x:not(.grid-x) > .cell {
-  width: auto; }
+fieldset {
+  margin: 0;
+  padding: 0;
+  border: 0; }
 
-.grid-margin-y:not(.grid-y) > .cell {
-  height: auto; }
+legend {
+  max-width: 100%;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x {
-  margin-left: -0.625rem;
-  margin-right: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x {
-      margin-left: -0.9375rem;
-      margin-right: -0.9375rem; } }
-  .grid-margin-x > .cell {
-    width: calc(100% - 1.25rem);
-    margin-left: 0.625rem;
-    margin-right: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x > .cell {
-      width: calc(100% - 1.875rem);
-      margin-left: 0.9375rem;
-      margin-right: 0.9375rem; } }
-  .grid-margin-x > .auto {
-    width: auto; }
-  .grid-margin-x > .shrink {
-    width: auto; }
-  .grid-margin-x > .small-1 {
-    width: calc(8.33333% - 1.25rem); }
-  .grid-margin-x > .small-2 {
-    width: calc(16.66667% - 1.25rem); }
-  .grid-margin-x > .small-3 {
-    width: calc(25% - 1.25rem); }
-  .grid-margin-x > .small-4 {
-    width: calc(33.33333% - 1.25rem); }
-  .grid-margin-x > .small-5 {
-    width: calc(41.66667% - 1.25rem); }
-  .grid-margin-x > .small-6 {
-    width: calc(50% - 1.25rem); }
-  .grid-margin-x > .small-7 {
-    width: calc(58.33333% - 1.25rem); }
-  .grid-margin-x > .small-8 {
-    width: calc(66.66667% - 1.25rem); }
-  .grid-margin-x > .small-9 {
-    width: calc(75% - 1.25rem); }
-  .grid-margin-x > .small-10 {
-    width: calc(83.33333% - 1.25rem); }
-  .grid-margin-x > .small-11 {
-    width: calc(91.66667% - 1.25rem); }
-  .grid-margin-x > .small-12 {
-    width: calc(100% - 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x > .auto {
-      width: auto; }
-    .grid-margin-x > .shrink {
-      width: auto; }
-    .grid-margin-x > .small-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .small-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .small-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .small-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .small-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .small-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .small-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .small-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .small-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .small-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .small-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .small-12 {
-      width: calc(100% - 1.875rem); }
-    .grid-margin-x > .medium-auto {
-      width: auto; }
-    .grid-margin-x > .medium-shrink {
-      width: auto; }
-    .grid-margin-x > .medium-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .medium-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .medium-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .medium-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .medium-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .medium-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .medium-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .medium-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .medium-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .medium-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .medium-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .medium-12 {
-      width: calc(100% - 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-margin-x > .large-auto {
-      width: auto; }
-    .grid-margin-x > .large-shrink {
-      width: auto; }
-    .grid-margin-x > .large-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .large-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .large-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .large-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .large-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .large-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .large-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .large-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .large-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .large-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .large-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .large-12 {
-      width: calc(100% - 1.875rem); } }
+.fieldset {
+  margin: 1.125rem 0;
+  padding: 1.25rem;
+  border: 1px solid #cacaca; }
+  .fieldset legend {
+    margin: 0;
+    margin-right: -0.1875rem;
+    padding: 0 0.1875rem; }
 
-.grid-padding-x .grid-padding-x {
-  margin-right: -0.625rem;
-  margin-left: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-x .grid-padding-x {
-      margin-right: -0.9375rem;
-      margin-left: -0.9375rem; } }
+select {
+  height: 2.4375rem;
+  margin: 0 0 1rem;
+  padding: 0.5rem;
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  font-family: inherit;
+  font-size: 1rem;
+  font-weight: normal;
+  line-height: 1.5;
+  color: #0a0a0a;
+  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");
+  background-origin: content-box;
+  background-position: left -1rem center;
+  background-repeat: no-repeat;
+  background-size: 9px 6px;
+  padding-left: 1.5rem;
+  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+  @media screen and (min-width: 0\0) {
+    select {
+      background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } }
+  select:focus {
+    outline: none;
+    border: 1px solid #8a8a8a;
+    background-color: #fefefe;
+    -webkit-box-shadow: 0 0 5px #cacaca;
+            box-shadow: 0 0 5px #cacaca;
+    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+  select:disabled {
+    background-color: #e6e6e6;
+    cursor: not-allowed; }
+  select::-ms-expand {
+    display: none; }
+  select[multiple] {
+    height: auto;
+    background-image: none; }
 
-.grid-container:not(.full) > .grid-padding-x {
-  margin-right: -0.625rem;
-  margin-left: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-container:not(.full) > .grid-padding-x {
-      margin-right: -0.9375rem;
-      margin-left: -0.9375rem; } }
+.is-invalid-input:not(:focus) {
+  border-color: #cc4b37;
+  background-color: #f9ecea; }
+  .is-invalid-input:not(:focus)::-webkit-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus):-ms-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus)::-ms-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus)::placeholder {
+    color: #cc4b37; }
 
-.grid-padding-x > .cell {
-  padding-right: 0.625rem;
-  padding-left: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-x > .cell {
-      padding-right: 0.9375rem;
-      padding-left: 0.9375rem; } }
+.is-invalid-label {
+  color: #cc4b37; }
 
-.small-up-1 > .cell {
-  width: 100%; }
+.form-error {
+  display: none;
+  margin-top: -0.5rem;
+  margin-bottom: 1rem;
+  font-size: 0.75rem;
+  font-weight: bold;
+  color: #cc4b37; }
+  .form-error.is-visible {
+    display: block; }
 
-.small-up-2 > .cell {
-  width: 50%; }
+div,
+dl,
+dt,
+dd,
+ul,
+ol,
+li,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+pre,
+form,
+p,
+blockquote,
+th,
+td {
+  margin: 0;
+  padding: 0; }
 
-.small-up-3 > .cell {
-  width: 33.33333%; }
+p {
+  margin-bottom: 1rem;
+  font-size: inherit;
+  line-height: 1.6;
+  text-rendering: optimizeLegibility; }
 
-.small-up-4 > .cell {
-  width: 25%; }
+em,
+i {
+  font-style: italic;
+  line-height: inherit; }
 
-.small-up-5 > .cell {
-  width: 20%; }
+strong,
+b {
+  font-weight: bold;
+  line-height: inherit; }
 
-.small-up-6 > .cell {
-  width: 16.66667%; }
+small {
+  font-size: 80%;
+  line-height: inherit; }
 
-.small-up-7 > .cell {
-  width: 14.28571%; }
+h1, .h1,
+h2, .h2,
+h3, .h3,
+h4, .h4,
+h5, .h5,
+h6, .h6 {
+  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
+  font-style: normal;
+  font-weight: normal;
+  color: inherit;
+  text-rendering: optimizeLegibility; }
+  h1 small, .h1 small,
+  h2 small, .h2 small,
+  h3 small, .h3 small,
+  h4 small, .h4 small,
+  h5 small, .h5 small,
+  h6 small, .h6 small {
+    line-height: 0;
+    color: #cacaca; }
 
-.small-up-8 > .cell {
-  width: 12.5%; }
+h1, .h1 {
+  font-size: 1.5rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-up-1 > .cell {
-    width: 100%; }
-  .medium-up-2 > .cell {
-    width: 50%; }
-  .medium-up-3 > .cell {
-    width: 33.33333%; }
-  .medium-up-4 > .cell {
-    width: 25%; }
-  .medium-up-5 > .cell {
-    width: 20%; }
-  .medium-up-6 > .cell {
-    width: 16.66667%; }
-  .medium-up-7 > .cell {
-    width: 14.28571%; }
-  .medium-up-8 > .cell {
-    width: 12.5%; } }
+h2, .h2 {
+  font-size: 1.25rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-@media print, screen and (min-width: 64em) {
-  .large-up-1 > .cell {
-    width: 100%; }
-  .large-up-2 > .cell {
-    width: 50%; }
-  .large-up-3 > .cell {
-    width: 33.33333%; }
-  .large-up-4 > .cell {
-    width: 25%; }
-  .large-up-5 > .cell {
-    width: 20%; }
-  .large-up-6 > .cell {
-    width: 16.66667%; }
-  .large-up-7 > .cell {
-    width: 14.28571%; }
-  .large-up-8 > .cell {
-    width: 12.5%; } }
+h3, .h3 {
+  font-size: 1.1875rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-1 > .cell {
-  width: calc(100% - 1.25rem); }
+h4, .h4 {
+  font-size: 1.125rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-2 > .cell {
-  width: calc(50% - 1.25rem); }
+h5, .h5 {
+  font-size: 1.0625rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-3 > .cell {
-  width: calc(33.33333% - 1.25rem); }
+h6, .h6 {
+  font-size: 1rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-4 > .cell {
-  width: calc(25% - 1.25rem); }
+@media print, screen and (min-width: 40em) {
+  h1, .h1 {
+    font-size: 3rem; }
+  h2, .h2 {
+    font-size: 2.5rem; }
+  h3, .h3 {
+    font-size: 1.9375rem; }
+  h4, .h4 {
+    font-size: 1.5625rem; }
+  h5, .h5 {
+    font-size: 1.25rem; }
+  h6, .h6 {
+    font-size: 1rem; } }
 
-.grid-margin-x.small-up-5 > .cell {
-  width: calc(20% - 1.25rem); }
+a {
+  line-height: inherit;
+  color: #1779ba;
+  text-decoration: none;
+  cursor: pointer; }
+  a:hover, a:focus {
+    color: #1468a0; }
+  a img {
+    border: 0; }
 
-.grid-margin-x.small-up-6 > .cell {
-  width: calc(16.66667% - 1.25rem); }
+hr {
+  clear: both;
+  max-width: 75rem;
+  height: 0;
+  margin: 1.25rem auto;
+  border-top: 0;
+  border-right: 0;
+  border-bottom: 1px solid #cacaca;
+  border-left: 0; }
 
-.grid-margin-x.small-up-7 > .cell {
-  width: calc(14.28571% - 1.25rem); }
+ul,
+ol,
+dl {
+  margin-bottom: 1rem;
+  list-style-position: outside;
+  line-height: 1.6; }
 
-.grid-margin-x.small-up-8 > .cell {
-  width: calc(12.5% - 1.25rem); }
+li {
+  font-size: inherit; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-margin-x.small-up-1 > .cell {
-    width: calc(100% - 1.25rem); }
-  .grid-margin-x.small-up-2 > .cell {
-    width: calc(50% - 1.25rem); }
-  .grid-margin-x.small-up-3 > .cell {
-    width: calc(33.33333% - 1.25rem); }
-  .grid-margin-x.small-up-4 > .cell {
-    width: calc(25% - 1.25rem); }
-  .grid-margin-x.small-up-5 > .cell {
-    width: calc(20% - 1.25rem); }
-  .grid-margin-x.small-up-6 > .cell {
-    width: calc(16.66667% - 1.25rem); }
-  .grid-margin-x.small-up-7 > .cell {
-    width: calc(14.28571% - 1.25rem); }
-  .grid-margin-x.small-up-8 > .cell {
-    width: calc(12.5% - 1.25rem); }
-  .grid-margin-x.medium-up-1 > .cell {
-    width: calc(100% - 1.875rem); }
-  .grid-margin-x.medium-up-2 > .cell {
-    width: calc(50% - 1.875rem); }
-  .grid-margin-x.medium-up-3 > .cell {
-    width: calc(33.33333% - 1.875rem); }
-  .grid-margin-x.medium-up-4 > .cell {
-    width: calc(25% - 1.875rem); }
-  .grid-margin-x.medium-up-5 > .cell {
-    width: calc(20% - 1.875rem); }
-  .grid-margin-x.medium-up-6 > .cell {
-    width: calc(16.66667% - 1.875rem); }
-  .grid-margin-x.medium-up-7 > .cell {
-    width: calc(14.28571% - 1.875rem); }
-  .grid-margin-x.medium-up-8 > .cell {
-    width: calc(12.5% - 1.875rem); } }
+ul {
+  margin-right: 1.25rem;
+  list-style-type: disc; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-margin-x.large-up-1 > .cell {
-    width: calc(100% - 1.875rem); }
-  .grid-margin-x.large-up-2 > .cell {
-    width: calc(50% - 1.875rem); }
-  .grid-margin-x.large-up-3 > .cell {
-    width: calc(33.33333% - 1.875rem); }
-  .grid-margin-x.large-up-4 > .cell {
-    width: calc(25% - 1.875rem); }
-  .grid-margin-x.large-up-5 > .cell {
-    width: calc(20% - 1.875rem); }
-  .grid-margin-x.large-up-6 > .cell {
-    width: calc(16.66667% - 1.875rem); }
-  .grid-margin-x.large-up-7 > .cell {
-    width: calc(14.28571% - 1.875rem); }
-  .grid-margin-x.large-up-8 > .cell {
-    width: calc(12.5% - 1.875rem); } }
+ol {
+  margin-right: 1.25rem; }
 
-.small-margin-collapse {
-  margin-right: 0;
-  margin-left: 0; }
-  .small-margin-collapse > .cell {
-    margin-right: 0;
-    margin-left: 0; }
-  .small-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .small-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .small-margin-collapse > .small-3 {
-    width: 25%; }
-  .small-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .small-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .small-margin-collapse > .small-6 {
-    width: 50%; }
-  .small-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .small-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .small-margin-collapse > .small-9 {
-    width: 75%; }
-  .small-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .small-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .small-margin-collapse > .small-12 {
-    width: 100%; }
-  @media print, screen and (min-width: 40em) {
-    .small-margin-collapse > .medium-1 {
-      width: 8.33333%; }
-    .small-margin-collapse > .medium-2 {
-      width: 16.66667%; }
-    .small-margin-collapse > .medium-3 {
-      width: 25%; }
-    .small-margin-collapse > .medium-4 {
-      width: 33.33333%; }
-    .small-margin-collapse > .medium-5 {
-      width: 41.66667%; }
-    .small-margin-collapse > .medium-6 {
-      width: 50%; }
-    .small-margin-collapse > .medium-7 {
-      width: 58.33333%; }
-    .small-margin-collapse > .medium-8 {
-      width: 66.66667%; }
-    .small-margin-collapse > .medium-9 {
-      width: 75%; }
-    .small-margin-collapse > .medium-10 {
-      width: 83.33333%; }
-    .small-margin-collapse > .medium-11 {
-      width: 91.66667%; }
-    .small-margin-collapse > .medium-12 {
-      width: 100%; } }
-  @media print, screen and (min-width: 64em) {
-    .small-margin-collapse > .large-1 {
-      width: 8.33333%; }
-    .small-margin-collapse > .large-2 {
-      width: 16.66667%; }
-    .small-margin-collapse > .large-3 {
-      width: 25%; }
-    .small-margin-collapse > .large-4 {
-      width: 33.33333%; }
-    .small-margin-collapse > .large-5 {
-      width: 41.66667%; }
-    .small-margin-collapse > .large-6 {
-      width: 50%; }
-    .small-margin-collapse > .large-7 {
-      width: 58.33333%; }
-    .small-margin-collapse > .large-8 {
-      width: 66.66667%; }
-    .small-margin-collapse > .large-9 {
-      width: 75%; }
-    .small-margin-collapse > .large-10 {
-      width: 83.33333%; }
-    .small-margin-collapse > .large-11 {
-      width: 91.66667%; }
-    .small-margin-collapse > .large-12 {
-      width: 100%; } }
+ul ul, ol ul, ul ol, ol ol {
+  margin-right: 1.25rem;
+  margin-bottom: 0; }
 
-.small-padding-collapse {
-  margin-right: 0;
-  margin-left: 0; }
-  .small-padding-collapse > .cell {
-    padding-right: 0;
-    padding-left: 0; }
+dl {
+  margin-bottom: 1rem; }
+  dl dt {
+    margin-bottom: 0.3rem;
+    font-weight: bold; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .medium-margin-collapse > .cell {
-      margin-right: 0;
-      margin-left: 0; } }
-
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .small-3 {
-    width: 25%; }
-  .medium-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .small-6 {
-    width: 50%; }
-  .medium-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .small-9 {
-    width: 75%; }
-  .medium-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .small-12 {
-    width: 100%; } }
-
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse > .medium-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .medium-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .medium-3 {
-    width: 25%; }
-  .medium-margin-collapse > .medium-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .medium-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .medium-6 {
-    width: 50%; }
-  .medium-margin-collapse > .medium-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .medium-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .medium-9 {
-    width: 75%; }
-  .medium-margin-collapse > .medium-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .medium-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .medium-12 {
-    width: 100%; } }
-
-@media print, screen and (min-width: 64em) {
-  .medium-margin-collapse > .large-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .large-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .large-3 {
-    width: 25%; }
-  .medium-margin-collapse > .large-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .large-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .large-6 {
-    width: 50%; }
-  .medium-margin-collapse > .large-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .large-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .large-9 {
-    width: 75%; }
-  .medium-margin-collapse > .large-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .large-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .large-12 {
-    width: 100%; } }
+blockquote {
+  margin: 0 0 1rem;
+  padding: 0.5625rem 1.25rem 0 1.1875rem;
+  border-right: 1px solid #cacaca; }
+  blockquote, blockquote p {
+    line-height: 1.6;
+    color: #8a8a8a; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-padding-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .medium-padding-collapse > .cell {
-      padding-right: 0;
-      padding-left: 0; } }
+cite {
+  display: block;
+  font-size: 0.8125rem;
+  color: #8a8a8a; }
+  cite:before {
+    content: "— "; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .large-margin-collapse > .cell {
-      margin-right: 0;
-      margin-left: 0; } }
+abbr, abbr[title] {
+  border-bottom: 1px dotted #0a0a0a;
+  cursor: help;
+  text-decoration: none; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .small-3 {
-    width: 25%; }
-  .large-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .small-6 {
-    width: 50%; }
-  .large-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .small-9 {
-    width: 75%; }
-  .large-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .small-12 {
-    width: 100%; } }
+figure {
+  margin: 0; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .medium-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .medium-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .medium-3 {
-    width: 25%; }
-  .large-margin-collapse > .medium-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .medium-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .medium-6 {
-    width: 50%; }
-  .large-margin-collapse > .medium-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .medium-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .medium-9 {
-    width: 75%; }
-  .large-margin-collapse > .medium-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .medium-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .medium-12 {
-    width: 100%; } }
+code {
+  padding: 0.125rem 0.3125rem 0.0625rem;
+  border: 1px solid #cacaca;
+  background-color: #e6e6e6;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  font-weight: normal;
+  color: #0a0a0a; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .large-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .large-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .large-3 {
-    width: 25%; }
-  .large-margin-collapse > .large-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .large-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .large-6 {
-    width: 50%; }
-  .large-margin-collapse > .large-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .large-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .large-9 {
-    width: 75%; }
-  .large-margin-collapse > .large-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .large-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .large-12 {
-    width: 100%; } }
+kbd {
+  margin: 0;
+  padding: 0.125rem 0.25rem 0;
+  background-color: #e6e6e6;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  color: #0a0a0a; }
 
-@media print, screen and (min-width: 64em) {
-  .large-padding-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .large-padding-collapse > .cell {
-      padding-right: 0;
-      padding-left: 0; } }
+.subheader {
+  margin-top: 0.2rem;
+  margin-bottom: 0.5rem;
+  font-weight: normal;
+  line-height: 1.4;
+  color: #8a8a8a; }
 
-.small-offset-0 {
-  margin-right: 0%; }
+.lead {
+  font-size: 125%;
+  line-height: 1.6; }
 
-.grid-margin-x > .small-offset-0 {
-  margin-right: calc(0% + 0.625rem); }
+.stat {
+  font-size: 2.5rem;
+  line-height: 1; }
+  p + .stat {
+    margin-top: -1rem; }
 
-.small-offset-1 {
-  margin-right: 8.33333%; }
+ul.no-bullet, ol.no-bullet {
+  margin-right: 0;
+  list-style: none; }
 
-.grid-margin-x > .small-offset-1 {
-  margin-right: calc(8.33333% + 0.625rem); }
+.text-left {
+  text-align: left; }
 
-.small-offset-2 {
-  margin-right: 16.66667%; }
+.text-right {
+  text-align: right; }
 
-.grid-margin-x > .small-offset-2 {
-  margin-right: calc(16.66667% + 0.625rem); }
+.text-center {
+  text-align: center; }
 
-.small-offset-3 {
-  margin-right: 25%; }
+.text-justify {
+  text-align: justify; }
 
-.grid-margin-x > .small-offset-3 {
-  margin-right: calc(25% + 0.625rem); }
+@media print, screen and (min-width: 40em) {
+  .medium-text-left {
+    text-align: left; }
+  .medium-text-right {
+    text-align: right; }
+  .medium-text-center {
+    text-align: center; }
+  .medium-text-justify {
+    text-align: justify; } }
 
-.small-offset-4 {
-  margin-right: 33.33333%; }
+@media print, screen and (min-width: 64em) {
+  .large-text-left {
+    text-align: left; }
+  .large-text-right {
+    text-align: right; }
+  .large-text-center {
+    text-align: center; }
+  .large-text-justify {
+    text-align: justify; } }
 
-.grid-margin-x > .small-offset-4 {
-  margin-right: calc(33.33333% + 0.625rem); }
+.show-for-print {
+  display: none !important; }
 
-.small-offset-5 {
-  margin-right: 41.66667%; }
+@media print {
+  * {
+    background: transparent !important;
+    -webkit-box-shadow: none !important;
+            box-shadow: none !important;
+    color: black !important;
+    text-shadow: none !important; }
+  .show-for-print {
+    display: block !important; }
+  .hide-for-print {
+    display: none !important; }
+  table.show-for-print {
+    display: table !important; }
+  thead.show-for-print {
+    display: table-header-group !important; }
+  tbody.show-for-print {
+    display: table-row-group !important; }
+  tr.show-for-print {
+    display: table-row !important; }
+  td.show-for-print {
+    display: table-cell !important; }
+  th.show-for-print {
+    display: table-cell !important; }
+  a,
+  a:visited {
+    text-decoration: underline; }
+  a[href]:after {
+    content: " (" attr(href) ")"; }
+  .ir a:after,
+  a[href^='javascript:']:after,
+  a[href^='#']:after {
+    content: ''; }
+  abbr[title]:after {
+    content: " (" attr(title) ")"; }
+  pre,
+  blockquote {
+    border: 1px solid #8a8a8a;
+    page-break-inside: avoid; }
+  thead {
+    display: table-header-group; }
+  tr,
+  img {
+    page-break-inside: avoid; }
+  img {
+    max-width: 100% !important; }
+  @page {
+    margin: 0.5cm; }
+  p,
+  h2,
+  h3 {
+    orphans: 3;
+    widows: 3; }
+  h2,
+  h3 {
+    page-break-after: avoid; }
+  .print-break-inside {
+    page-break-inside: auto; } }
 
-.grid-margin-x > .small-offset-5 {
-  margin-right: calc(41.66667% + 0.625rem); }
+.grid-container {
+  padding-right: 0.625rem;
+  padding-left: 0.625rem;
+  max-width: 75rem;
+  margin-left: auto;
+  margin-right: auto; }
+  @media print, screen and (min-width: 40em) {
+    .grid-container {
+      padding-right: 0.9375rem;
+      padding-left: 0.9375rem; } }
+  .grid-container.fluid {
+    padding-right: 0.625rem;
+    padding-left: 0.625rem;
+    max-width: 100%;
+    margin-left: auto;
+    margin-right: auto; }
+    @media print, screen and (min-width: 40em) {
+      .grid-container.fluid {
+        padding-right: 0.9375rem;
+        padding-left: 0.9375rem; } }
+  .grid-container.full {
+    padding-right: 0;
+    padding-left: 0;
+    max-width: 100%;
+    margin-left: auto;
+    margin-right: auto; }
 
-.small-offset-6 {
-  margin-right: 50%; }
+.grid-x {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: horizontal;
+  -webkit-box-direction: normal;
+  -webkit-flex-flow: row wrap;
+      -ms-flex-flow: row wrap;
+          flex-flow: row wrap; }
 
-.grid-margin-x > .small-offset-6 {
-  margin-right: calc(50% + 0.625rem); }
+.cell {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto;
+  min-height: 0px;
+  min-width: 0px;
+  width: 100%; }
+  .cell.auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
+  .cell.shrink {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
 
-.small-offset-7 {
-  margin-right: 58.33333%; }
+.grid-x > .auto {
+  width: auto; }
 
-.grid-margin-x > .small-offset-7 {
-  margin-right: calc(58.33333% + 0.625rem); }
+.grid-x > .shrink {
+  width: auto; }
 
-.small-offset-8 {
-  margin-right: 66.66667%; }
+.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
+  -webkit-flex-basis: auto;
+      -ms-flex-preferred-size: auto;
+          flex-basis: auto; }
 
-.grid-margin-x > .small-offset-8 {
-  margin-right: calc(66.66667% + 0.625rem); }
+@media print, screen and (min-width: 40em) {
+  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; } }
 
-.small-offset-9 {
-  margin-right: 75%; }
+@media print, screen and (min-width: 64em) {
+  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; } }
 
-.grid-margin-x > .small-offset-9 {
-  margin-right: calc(75% + 0.625rem); }
+.grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto; }
 
-.small-offset-10 {
-  margin-right: 83.33333%; }
+.grid-x > .small-1 {
+  width: 8.33333%; }
 
-.grid-margin-x > .small-offset-10 {
-  margin-right: calc(83.33333% + 0.625rem); }
+.grid-x > .small-2 {
+  width: 16.66667%; }
 
-.small-offset-11 {
-  margin-right: 91.66667%; }
+.grid-x > .small-3 {
+  width: 25%; }
 
-.grid-margin-x > .small-offset-11 {
-  margin-right: calc(91.66667% + 0.625rem); }
+.grid-x > .small-4 {
+  width: 33.33333%; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-offset-0 {
-    margin-right: 0%; }
-  .grid-margin-x > .medium-offset-0 {
-    margin-right: calc(0% + 0.9375rem); }
-  .medium-offset-1 {
-    margin-right: 8.33333%; }
-  .grid-margin-x > .medium-offset-1 {
-    margin-right: calc(8.33333% + 0.9375rem); }
-  .medium-offset-2 {
-    margin-right: 16.66667%; }
-  .grid-margin-x > .medium-offset-2 {
-    margin-right: calc(16.66667% + 0.9375rem); }
-  .medium-offset-3 {
-    margin-right: 25%; }
-  .grid-margin-x > .medium-offset-3 {
-    margin-right: calc(25% + 0.9375rem); }
-  .medium-offset-4 {
-    margin-right: 33.33333%; }
-  .grid-margin-x > .medium-offset-4 {
-    margin-right: calc(33.33333% + 0.9375rem); }
-  .medium-offset-5 {
-    margin-right: 41.66667%; }
-  .grid-margin-x > .medium-offset-5 {
-    margin-right: calc(41.66667% + 0.9375rem); }
-  .medium-offset-6 {
-    margin-right: 50%; }
-  .grid-margin-x > .medium-offset-6 {
-    margin-right: calc(50% + 0.9375rem); }
-  .medium-offset-7 {
-    margin-right: 58.33333%; }
-  .grid-margin-x > .medium-offset-7 {
-    margin-right: calc(58.33333% + 0.9375rem); }
-  .medium-offset-8 {
-    margin-right: 66.66667%; }
-  .grid-margin-x > .medium-offset-8 {
-    margin-right: calc(66.66667% + 0.9375rem); }
-  .medium-offset-9 {
-    margin-right: 75%; }
-  .grid-margin-x > .medium-offset-9 {
-    margin-right: calc(75% + 0.9375rem); }
-  .medium-offset-10 {
-    margin-right: 83.33333%; }
-  .grid-margin-x > .medium-offset-10 {
-    margin-right: calc(83.33333% + 0.9375rem); }
-  .medium-offset-11 {
-    margin-right: 91.66667%; }
-  .grid-margin-x > .medium-offset-11 {
-    margin-right: calc(91.66667% + 0.9375rem); } }
+.grid-x > .small-5 {
+  width: 41.66667%; }
 
-@media print, screen and (min-width: 64em) {
-  .large-offset-0 {
-    margin-right: 0%; }
-  .grid-margin-x > .large-offset-0 {
-    margin-right: calc(0% + 0.9375rem); }
-  .large-offset-1 {
-    margin-right: 8.33333%; }
-  .grid-margin-x > .large-offset-1 {
-    margin-right: calc(8.33333% + 0.9375rem); }
-  .large-offset-2 {
-    margin-right: 16.66667%; }
-  .grid-margin-x > .large-offset-2 {
-    margin-right: calc(16.66667% + 0.9375rem); }
-  .large-offset-3 {
-    margin-right: 25%; }
-  .grid-margin-x > .large-offset-3 {
-    margin-right: calc(25% + 0.9375rem); }
-  .large-offset-4 {
-    margin-right: 33.33333%; }
-  .grid-margin-x > .large-offset-4 {
-    margin-right: calc(33.33333% + 0.9375rem); }
-  .large-offset-5 {
-    margin-right: 41.66667%; }
-  .grid-margin-x > .large-offset-5 {
-    margin-right: calc(41.66667% + 0.9375rem); }
-  .large-offset-6 {
-    margin-right: 50%; }
-  .grid-margin-x > .large-offset-6 {
-    margin-right: calc(50% + 0.9375rem); }
-  .large-offset-7 {
-    margin-right: 58.33333%; }
-  .grid-margin-x > .large-offset-7 {
-    margin-right: calc(58.33333% + 0.9375rem); }
-  .large-offset-8 {
-    margin-right: 66.66667%; }
-  .grid-margin-x > .large-offset-8 {
-    margin-right: calc(66.66667% + 0.9375rem); }
-  .large-offset-9 {
-    margin-right: 75%; }
-  .grid-margin-x > .large-offset-9 {
-    margin-right: calc(75% + 0.9375rem); }
-  .large-offset-10 {
-    margin-right: 83.33333%; }
-  .grid-margin-x > .large-offset-10 {
-    margin-right: calc(83.33333% + 0.9375rem); }
-  .large-offset-11 {
-    margin-right: 91.66667%; }
-  .grid-margin-x > .large-offset-11 {
-    margin-right: calc(91.66667% + 0.9375rem); } }
+.grid-x > .small-6 {
+  width: 50%; }
 
-.grid-y {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-orient: vertical;
-  -webkit-box-direction: normal;
-  -webkit-flex-flow: column nowrap;
-      -ms-flex-flow: column nowrap;
-          flex-flow: column nowrap; }
-  .grid-y > .cell {
+.grid-x > .small-7 {
+  width: 58.33333%; }
+
+.grid-x > .small-8 {
+  width: 66.66667%; }
+
+.grid-x > .small-9 {
+  width: 75%; }
+
+.grid-x > .small-10 {
+  width: 83.33333%; }
+
+.grid-x > .small-11 {
+  width: 91.66667%; }
+
+.grid-x > .small-12 {
+  width: 100%; }
+
+@media print, screen and (min-width: 40em) {
+  .grid-x > .medium-auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px;
     width: auto; }
-  .grid-y > .auto {
-    height: auto; }
-  .grid-y > .shrink {
-    height: auto; }
-  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; }
-  @media print, screen and (min-width: 40em) {
-    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
-      -webkit-flex-basis: auto;
-          -ms-flex-preferred-size: auto;
-              flex-basis: auto; } }
-  @media print, screen and (min-width: 64em) {
-    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
-      -webkit-flex-basis: auto;
-          -ms-flex-preferred-size: auto;
-              flex-basis: auto; } }
-  .grid-y > .small-1 {
-    height: 8.33333%; }
-  .grid-y > .small-2 {
-    height: 16.66667%; }
-  .grid-y > .small-3 {
-    height: 25%; }
-  .grid-y > .small-4 {
-    height: 33.33333%; }
-  .grid-y > .small-5 {
-    height: 41.66667%; }
-  .grid-y > .small-6 {
-    height: 50%; }
-  .grid-y > .small-7 {
-    height: 58.33333%; }
-  .grid-y > .small-8 {
-    height: 66.66667%; }
-  .grid-y > .small-9 {
-    height: 75%; }
-  .grid-y > .small-10 {
-    height: 83.33333%; }
-  .grid-y > .small-11 {
-    height: 91.66667%; }
-  .grid-y > .small-12 {
-    height: 100%; }
-  @media print, screen and (min-width: 40em) {
-    .grid-y > .medium-auto {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      height: auto; }
-    .grid-y > .medium-shrink {
-      height: auto; }
-    .grid-y > .medium-1 {
-      height: 8.33333%; }
-    .grid-y > .medium-2 {
-      height: 16.66667%; }
-    .grid-y > .medium-3 {
-      height: 25%; }
-    .grid-y > .medium-4 {
-      height: 33.33333%; }
-    .grid-y > .medium-5 {
-      height: 41.66667%; }
-    .grid-y > .medium-6 {
-      height: 50%; }
-    .grid-y > .medium-7 {
-      height: 58.33333%; }
-    .grid-y > .medium-8 {
-      height: 66.66667%; }
-    .grid-y > .medium-9 {
-      height: 75%; }
-    .grid-y > .medium-10 {
-      height: 83.33333%; }
-    .grid-y > .medium-11 {
-      height: 91.66667%; }
-    .grid-y > .medium-12 {
-      height: 100%; } }
-  @media print, screen and (min-width: 64em) {
-    .grid-y > .large-auto {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      height: auto; }
-    .grid-y > .large-shrink {
-      height: auto; }
-    .grid-y > .large-1 {
-      height: 8.33333%; }
-    .grid-y > .large-2 {
-      height: 16.66667%; }
-    .grid-y > .large-3 {
-      height: 25%; }
-    .grid-y > .large-4 {
-      height: 33.33333%; }
-    .grid-y > .large-5 {
-      height: 41.66667%; }
-    .grid-y > .large-6 {
-      height: 50%; }
-    .grid-y > .large-7 {
-      height: 58.33333%; }
-    .grid-y > .large-8 {
-      height: 66.66667%; }
-    .grid-y > .large-9 {
-      height: 75%; }
-    .grid-y > .large-10 {
-      height: 83.33333%; }
-    .grid-y > .large-11 {
-      height: 91.66667%; }
-    .grid-y > .large-12 {
-      height: 100%; } }
+  .grid-x > .medium-shrink, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-x > .medium-shrink {
+    width: auto; }
+  .grid-x > .medium-1 {
+    width: 8.33333%; }
+  .grid-x > .medium-2 {
+    width: 16.66667%; }
+  .grid-x > .medium-3 {
+    width: 25%; }
+  .grid-x > .medium-4 {
+    width: 33.33333%; }
+  .grid-x > .medium-5 {
+    width: 41.66667%; }
+  .grid-x > .medium-6 {
+    width: 50%; }
+  .grid-x > .medium-7 {
+    width: 58.33333%; }
+  .grid-x > .medium-8 {
+    width: 66.66667%; }
+  .grid-x > .medium-9 {
+    width: 75%; }
+  .grid-x > .medium-10 {
+    width: 83.33333%; }
+  .grid-x > .medium-11 {
+    width: 91.66667%; }
+  .grid-x > .medium-12 {
+    width: 100%; } }
 
-.grid-padding-y .grid-padding-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-y .grid-padding-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
+@media print, screen and (min-width: 64em) {
+  .grid-x > .large-auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px;
+    width: auto; }
+  .grid-x > .large-shrink, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-x > .large-shrink {
+    width: auto; }
+  .grid-x > .large-1 {
+    width: 8.33333%; }
+  .grid-x > .large-2 {
+    width: 16.66667%; }
+  .grid-x > .large-3 {
+    width: 25%; }
+  .grid-x > .large-4 {
+    width: 33.33333%; }
+  .grid-x > .large-5 {
+    width: 41.66667%; }
+  .grid-x > .large-6 {
+    width: 50%; }
+  .grid-x > .large-7 {
+    width: 58.33333%; }
+  .grid-x > .large-8 {
+    width: 66.66667%; }
+  .grid-x > .large-9 {
+    width: 75%; }
+  .grid-x > .large-10 {
+    width: 83.33333%; }
+  .grid-x > .large-11 {
+    width: 91.66667%; }
+  .grid-x > .large-12 {
+    width: 100%; } }
 
-.grid-padding-y > .cell {
-  padding-top: 0.625rem;
-  padding-bottom: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-y > .cell {
-      padding-top: 0.9375rem;
-      padding-bottom: 0.9375rem; } }
+.grid-margin-x:not(.grid-x) > .cell {
+  width: auto; }
 
-.grid-margin-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
-  .grid-margin-y > .cell {
-    height: calc(100% - 1.25rem);
-    margin-top: 0.625rem;
-    margin-bottom: 0.625rem; }
+.grid-margin-y:not(.grid-y) > .cell {
+  height: auto; }
+
+.grid-margin-x {
+  margin-left: -0.625rem;
+  margin-right: -0.625rem; }
   @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .cell {
-      height: calc(100% - 1.875rem);
-      margin-top: 0.9375rem;
-      margin-bottom: 0.9375rem; } }
-  .grid-margin-y > .auto {
-    height: auto; }
-  .grid-margin-y > .shrink {
-    height: auto; }
-  .grid-margin-y > .small-1 {
-    height: calc(8.33333% - 1.25rem); }
-  .grid-margin-y > .small-2 {
-    height: calc(16.66667% - 1.25rem); }
-  .grid-margin-y > .small-3 {
-    height: calc(25% - 1.25rem); }
-  .grid-margin-y > .small-4 {
-    height: calc(33.33333% - 1.25rem); }
-  .grid-margin-y > .small-5 {
-    height: calc(41.66667% - 1.25rem); }
-  .grid-margin-y > .small-6 {
-    height: calc(50% - 1.25rem); }
-  .grid-margin-y > .small-7 {
-    height: calc(58.33333% - 1.25rem); }
-  .grid-margin-y > .small-8 {
-    height: calc(66.66667% - 1.25rem); }
-  .grid-margin-y > .small-9 {
-    height: calc(75% - 1.25rem); }
-  .grid-margin-y > .small-10 {
-    height: calc(83.33333% - 1.25rem); }
-  .grid-margin-y > .small-11 {
-    height: calc(91.66667% - 1.25rem); }
-  .grid-margin-y > .small-12 {
-    height: calc(100% - 1.25rem); }
+    .grid-margin-x {
+      margin-left: -0.9375rem;
+      margin-right: -0.9375rem; } }
+  .grid-margin-x > .cell {
+    width: calc(100% - 1.25rem);
+    margin-left: 0.625rem;
+    margin-right: 0.625rem; }
   @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .auto {
-      height: auto; }
-    .grid-margin-y > .shrink {
-      height: auto; }
-    .grid-margin-y > .small-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .small-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .small-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .small-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .small-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .small-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .small-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .small-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .small-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .small-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .small-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .small-12 {
-      height: calc(100% - 1.875rem); }
-    .grid-margin-y > .medium-auto {
-      height: auto; }
-    .grid-margin-y > .medium-shrink {
-      height: auto; }
-    .grid-margin-y > .medium-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .medium-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .medium-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .medium-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .medium-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .medium-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .medium-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .medium-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .medium-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .medium-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .medium-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .medium-12 {
-      height: calc(100% - 1.875rem); } }
+    .grid-margin-x > .cell {
+      width: calc(100% - 1.875rem);
+      margin-left: 0.9375rem;
+      margin-right: 0.9375rem; } }
+  .grid-margin-x > .auto {
+    width: auto; }
+  .grid-margin-x > .shrink {
+    width: auto; }
+  .grid-margin-x > .small-1 {
+    width: calc(8.33333% - 1.25rem); }
+  .grid-margin-x > .small-2 {
+    width: calc(16.66667% - 1.25rem); }
+  .grid-margin-x > .small-3 {
+    width: calc(25% - 1.25rem); }
+  .grid-margin-x > .small-4 {
+    width: calc(33.33333% - 1.25rem); }
+  .grid-margin-x > .small-5 {
+    width: calc(41.66667% - 1.25rem); }
+  .grid-margin-x > .small-6 {
+    width: calc(50% - 1.25rem); }
+  .grid-margin-x > .small-7 {
+    width: calc(58.33333% - 1.25rem); }
+  .grid-margin-x > .small-8 {
+    width: calc(66.66667% - 1.25rem); }
+  .grid-margin-x > .small-9 {
+    width: calc(75% - 1.25rem); }
+  .grid-margin-x > .small-10 {
+    width: calc(83.33333% - 1.25rem); }
+  .grid-margin-x > .small-11 {
+    width: calc(91.66667% - 1.25rem); }
+  .grid-margin-x > .small-12 {
+    width: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-x > .auto {
+      width: auto; }
+    .grid-margin-x > .shrink {
+      width: auto; }
+    .grid-margin-x > .small-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .small-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .small-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .small-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .small-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .small-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .small-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .small-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .small-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .small-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .small-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .small-12 {
+      width: calc(100% - 1.875rem); }
+    .grid-margin-x > .medium-auto {
+      width: auto; }
+    .grid-margin-x > .medium-shrink {
+      width: auto; }
+    .grid-margin-x > .medium-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .medium-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .medium-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .medium-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .medium-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .medium-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .medium-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .medium-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .medium-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .medium-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .medium-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .medium-12 {
+      width: calc(100% - 1.875rem); } }
   @media print, screen and (min-width: 64em) {
-    .grid-margin-y > .large-auto {
-      height: auto; }
-    .grid-margin-y > .large-shrink {
-      height: auto; }
-    .grid-margin-y > .large-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .large-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .large-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .large-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .large-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .large-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .large-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .large-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .large-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .large-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .large-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .large-12 {
-      height: calc(100% - 1.875rem); } }
+    .grid-margin-x > .large-auto {
+      width: auto; }
+    .grid-margin-x > .large-shrink {
+      width: auto; }
+    .grid-margin-x > .large-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .large-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .large-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .large-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .large-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .large-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .large-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .large-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .large-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .large-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .large-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .large-12 {
+      width: calc(100% - 1.875rem); } }
 
-.grid-frame {
-  overflow: hidden;
-  position: relative;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch;
-  width: 100vw; }
+.grid-padding-x .grid-padding-x {
+  margin-right: -0.625rem;
+  margin-left: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-x .grid-padding-x {
+      margin-right: -0.9375rem;
+      margin-left: -0.9375rem; } }
 
-.cell .grid-frame {
+.grid-container:not(.full) > .grid-padding-x {
+  margin-right: -0.625rem;
+  margin-left: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-container:not(.full) > .grid-padding-x {
+      margin-right: -0.9375rem;
+      margin-left: -0.9375rem; } }
+
+.grid-padding-x > .cell {
+  padding-right: 0.625rem;
+  padding-left: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-x > .cell {
+      padding-right: 0.9375rem;
+      padding-left: 0.9375rem; } }
+
+.small-up-1 > .cell {
   width: 100%; }
 
-.cell-block {
-  overflow-x: auto;
-  max-width: 100%;
-  -webkit-overflow-scrolling: touch;
-  -ms-overflow-stype: -ms-autohiding-scrollbar; }
+.small-up-2 > .cell {
+  width: 50%; }
 
-.cell-block-y {
-  overflow-y: auto;
-  max-height: 100%;
-  -webkit-overflow-scrolling: touch;
-  -ms-overflow-stype: -ms-autohiding-scrollbar; }
+.small-up-3 > .cell {
+  width: 33.33333%; }
 
-.cell-block-container {
-  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;
-  max-height: 100%; }
-  .cell-block-container > .grid-x {
-    max-height: 100%;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap; }
+.small-up-4 > .cell {
+  width: 25%; }
+
+.small-up-5 > .cell {
+  width: 20%; }
+
+.small-up-6 > .cell {
+  width: 16.66667%; }
+
+.small-up-7 > .cell {
+  width: 14.28571%; }
+
+.small-up-8 > .cell {
+  width: 12.5%; }
 
 @media print, screen and (min-width: 40em) {
-  .medium-grid-frame {
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    width: 100vw; }
-  .cell .medium-grid-frame {
+  .medium-up-1 > .cell {
     width: 100%; }
-  .medium-cell-block {
-    overflow-x: auto;
-    max-width: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; }
-  .medium-cell-block-container {
-    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;
-    max-height: 100%; }
-    .medium-cell-block-container > .grid-x {
-      max-height: 100%;
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap; }
-  .medium-cell-block-y {
-    overflow-y: auto;
-    max-height: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; } }
+  .medium-up-2 > .cell {
+    width: 50%; }
+  .medium-up-3 > .cell {
+    width: 33.33333%; }
+  .medium-up-4 > .cell {
+    width: 25%; }
+  .medium-up-5 > .cell {
+    width: 20%; }
+  .medium-up-6 > .cell {
+    width: 16.66667%; }
+  .medium-up-7 > .cell {
+    width: 14.28571%; }
+  .medium-up-8 > .cell {
+    width: 12.5%; } }
 
 @media print, screen and (min-width: 64em) {
-  .large-grid-frame {
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    width: 100vw; }
-  .cell .large-grid-frame {
+  .large-up-1 > .cell {
     width: 100%; }
-  .large-cell-block {
-    overflow-x: auto;
-    max-width: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; }
-  .large-cell-block-container {
-    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;
-    max-height: 100%; }
-    .large-cell-block-container > .grid-x {
-      max-height: 100%;
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap; }
-  .large-cell-block-y {
-    overflow-y: auto;
-    max-height: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; } }
+  .large-up-2 > .cell {
+    width: 50%; }
+  .large-up-3 > .cell {
+    width: 33.33333%; }
+  .large-up-4 > .cell {
+    width: 25%; }
+  .large-up-5 > .cell {
+    width: 20%; }
+  .large-up-6 > .cell {
+    width: 16.66667%; }
+  .large-up-7 > .cell {
+    width: 14.28571%; }
+  .large-up-8 > .cell {
+    width: 12.5%; } }
 
-.grid-y.grid-frame {
-  width: auto;
-  overflow: hidden;
-  position: relative;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch;
-  height: 100vh; }
+.grid-margin-x.small-up-1 > .cell {
+  width: calc(100% - 1.25rem); }
 
-@media print, screen and (min-width: 40em) {
-  .grid-y.medium-grid-frame {
-    width: auto;
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    height: 100vh; } }
+.grid-margin-x.small-up-2 > .cell {
+  width: calc(50% - 1.25rem); }
 
-@media print, screen and (min-width: 64em) {
-  .grid-y.large-grid-frame {
-    width: auto;
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    height: 100vh; } }
+.grid-margin-x.small-up-3 > .cell {
+  width: calc(33.33333% - 1.25rem); }
 
-.cell .grid-y.grid-frame {
-  height: 100%; }
+.grid-margin-x.small-up-4 > .cell {
+  width: calc(25% - 1.25rem); }
 
-@media print, screen and (min-width: 40em) {
-  .cell .grid-y.medium-grid-frame {
-    height: 100%; } }
+.grid-margin-x.small-up-5 > .cell {
+  width: calc(20% - 1.25rem); }
 
-@media print, screen and (min-width: 64em) {
-  .cell .grid-y.large-grid-frame {
-    height: 100%; } }
+.grid-margin-x.small-up-6 > .cell {
+  width: calc(16.66667% - 1.25rem); }
 
-.grid-margin-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
-  .grid-margin-y > .cell {
-    height: calc(100% - 1.25rem);
-    margin-top: 0.625rem;
-    margin-bottom: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .cell {
-      height: calc(100% - 1.875rem);
-      margin-top: 0.9375rem;
-      margin-bottom: 0.9375rem; } }
-  .grid-margin-y > .auto {
-    height: auto; }
-  .grid-margin-y > .shrink {
-    height: auto; }
-  .grid-margin-y > .small-1 {
-    height: calc(8.33333% - 1.25rem); }
-  .grid-margin-y > .small-2 {
-    height: calc(16.66667% - 1.25rem); }
-  .grid-margin-y > .small-3 {
-    height: calc(25% - 1.25rem); }
-  .grid-margin-y > .small-4 {
-    height: calc(33.33333% - 1.25rem); }
-  .grid-margin-y > .small-5 {
-    height: calc(41.66667% - 1.25rem); }
-  .grid-margin-y > .small-6 {
-    height: calc(50% - 1.25rem); }
-  .grid-margin-y > .small-7 {
-    height: calc(58.33333% - 1.25rem); }
-  .grid-margin-y > .small-8 {
-    height: calc(66.66667% - 1.25rem); }
-  .grid-margin-y > .small-9 {
-    height: calc(75% - 1.25rem); }
-  .grid-margin-y > .small-10 {
-    height: calc(83.33333% - 1.25rem); }
-  .grid-margin-y > .small-11 {
-    height: calc(91.66667% - 1.25rem); }
-  .grid-margin-y > .small-12 {
-    height: calc(100% - 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .auto {
-      height: auto; }
-    .grid-margin-y > .shrink {
-      height: auto; }
-    .grid-margin-y > .small-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .small-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .small-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .small-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .small-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .small-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .small-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .small-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .small-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .small-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .small-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .small-12 {
-      height: calc(100% - 1.875rem); }
-    .grid-margin-y > .medium-auto {
-      height: auto; }
-    .grid-margin-y > .medium-shrink {
-      height: auto; }
-    .grid-margin-y > .medium-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .medium-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .medium-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .medium-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .medium-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .medium-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .medium-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .medium-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .medium-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .medium-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .medium-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .medium-12 {
-      height: calc(100% - 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-margin-y > .large-auto {
-      height: auto; }
-    .grid-margin-y > .large-shrink {
-      height: auto; }
-    .grid-margin-y > .large-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .large-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .large-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .large-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .large-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .large-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .large-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .large-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .large-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .large-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .large-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .large-12 {
-      height: calc(100% - 1.875rem); } }
+.grid-margin-x.small-up-7 > .cell {
+  width: calc(14.28571% - 1.25rem); }
 
-.grid-frame.grid-margin-y {
-  height: calc(100vh + 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-frame.grid-margin-y {
-      height: calc(100vh + 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-frame.grid-margin-y {
-      height: calc(100vh + 1.875rem); } }
+.grid-margin-x.small-up-8 > .cell {
+  width: calc(12.5% - 1.25rem); }
 
 @media print, screen and (min-width: 40em) {
-  .grid-margin-y.medium-grid-frame {
-    height: calc(100vh + 1.875rem); } }
+  .grid-margin-x.small-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.small-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.small-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.small-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.small-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.small-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.small-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.small-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); }
+  .grid-margin-x.medium-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.medium-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.medium-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.medium-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.medium-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.medium-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.medium-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.medium-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); } }
 
 @media print, screen and (min-width: 64em) {
-  .grid-margin-y.large-grid-frame {
-    height: calc(100vh + 1.875rem); } }
-
-div,
-dl,
-dt,
-dd,
-ul,
-ol,
-li,
-h1,
-h2,
-h3,
-h4,
-h5,
-h6,
-pre,
-form,
-p,
-blockquote,
-th,
-td {
-  margin: 0;
-  padding: 0; }
-
-p {
-  margin-bottom: 1rem;
-  font-size: inherit;
-  line-height: 1.6;
-  text-rendering: optimizeLegibility; }
-
-em,
-i {
-  font-style: italic;
-  line-height: inherit; }
-
-strong,
-b {
-  font-weight: bold;
-  line-height: inherit; }
-
-small {
-  font-size: 80%;
-  line-height: inherit; }
-
-h1, .h1,
-h2, .h2,
-h3, .h3,
-h4, .h4,
-h5, .h5,
-h6, .h6 {
-  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
-  font-style: normal;
-  font-weight: normal;
-  color: inherit;
-  text-rendering: optimizeLegibility; }
-  h1 small, .h1 small,
-  h2 small, .h2 small,
-  h3 small, .h3 small,
-  h4 small, .h4 small,
-  h5 small, .h5 small,
-  h6 small, .h6 small {
-    line-height: 0;
-    color: #cacaca; }
-
-h1, .h1 {
-  font-size: 1.5rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
-
-h2, .h2 {
-  font-size: 1.25rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
-
-h3, .h3 {
-  font-size: 1.1875rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+  .grid-margin-x.large-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.large-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.large-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.large-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.large-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.large-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.large-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.large-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); } }
 
-h4, .h4 {
-  font-size: 1.125rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
-
-h5, .h5 {
-  font-size: 1.0625rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-margin-collapse {
+  margin-right: 0;
+  margin-left: 0; }
+  .small-margin-collapse > .cell {
+    margin-right: 0;
+    margin-left: 0; }
+  .small-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .small-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .small-margin-collapse > .small-3 {
+    width: 25%; }
+  .small-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .small-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .small-margin-collapse > .small-6 {
+    width: 50%; }
+  .small-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .small-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .small-margin-collapse > .small-9 {
+    width: 75%; }
+  .small-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .small-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .small-margin-collapse > .small-12 {
+    width: 100%; }
+  @media print, screen and (min-width: 40em) {
+    .small-margin-collapse > .medium-1 {
+      width: 8.33333%; }
+    .small-margin-collapse > .medium-2 {
+      width: 16.66667%; }
+    .small-margin-collapse > .medium-3 {
+      width: 25%; }
+    .small-margin-collapse > .medium-4 {
+      width: 33.33333%; }
+    .small-margin-collapse > .medium-5 {
+      width: 41.66667%; }
+    .small-margin-collapse > .medium-6 {
+      width: 50%; }
+    .small-margin-collapse > .medium-7 {
+      width: 58.33333%; }
+    .small-margin-collapse > .medium-8 {
+      width: 66.66667%; }
+    .small-margin-collapse > .medium-9 {
+      width: 75%; }
+    .small-margin-collapse > .medium-10 {
+      width: 83.33333%; }
+    .small-margin-collapse > .medium-11 {
+      width: 91.66667%; }
+    .small-margin-collapse > .medium-12 {
+      width: 100%; } }
+  @media print, screen and (min-width: 64em) {
+    .small-margin-collapse > .large-1 {
+      width: 8.33333%; }
+    .small-margin-collapse > .large-2 {
+      width: 16.66667%; }
+    .small-margin-collapse > .large-3 {
+      width: 25%; }
+    .small-margin-collapse > .large-4 {
+      width: 33.33333%; }
+    .small-margin-collapse > .large-5 {
+      width: 41.66667%; }
+    .small-margin-collapse > .large-6 {
+      width: 50%; }
+    .small-margin-collapse > .large-7 {
+      width: 58.33333%; }
+    .small-margin-collapse > .large-8 {
+      width: 66.66667%; }
+    .small-margin-collapse > .large-9 {
+      width: 75%; }
+    .small-margin-collapse > .large-10 {
+      width: 83.33333%; }
+    .small-margin-collapse > .large-11 {
+      width: 91.66667%; }
+    .small-margin-collapse > .large-12 {
+      width: 100%; } }
 
-h6, .h6 {
-  font-size: 1rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-padding-collapse {
+  margin-right: 0;
+  margin-left: 0; }
+  .small-padding-collapse > .cell {
+    padding-right: 0;
+    padding-left: 0; }
 
 @media print, screen and (min-width: 40em) {
-  h1, .h1 {
-    font-size: 3rem; }
-  h2, .h2 {
-    font-size: 2.5rem; }
-  h3, .h3 {
-    font-size: 1.9375rem; }
-  h4, .h4 {
-    font-size: 1.5625rem; }
-  h5, .h5 {
-    font-size: 1.25rem; }
-  h6, .h6 {
-    font-size: 1rem; } }
-
-a {
-  line-height: inherit;
-  color: #1779ba;
-  text-decoration: none;
-  cursor: pointer; }
-  a:hover, a:focus {
-    color: #1468a0; }
-  a img {
-    border: 0; }
-
-hr {
-  clear: both;
-  max-width: 75rem;
-  height: 0;
-  margin: 1.25rem auto;
-  border-top: 0;
-  border-right: 0;
-  border-bottom: 1px solid #cacaca;
-  border-left: 0; }
-
-ul,
-ol,
-dl {
-  margin-bottom: 1rem;
-  list-style-position: outside;
-  line-height: 1.6; }
-
-li {
-  font-size: inherit; }
+  .medium-margin-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .medium-margin-collapse > .cell {
+      margin-right: 0;
+      margin-left: 0; } }
 
-ul {
-  margin-right: 1.25rem;
-  list-style-type: disc; }
+@media print, screen and (min-width: 40em) {
+  .medium-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .small-3 {
+    width: 25%; }
+  .medium-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .small-6 {
+    width: 50%; }
+  .medium-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .small-9 {
+    width: 75%; }
+  .medium-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .small-12 {
+    width: 100%; } }
 
-ol {
-  margin-right: 1.25rem; }
+@media print, screen and (min-width: 40em) {
+  .medium-margin-collapse > .medium-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .medium-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .medium-3 {
+    width: 25%; }
+  .medium-margin-collapse > .medium-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .medium-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .medium-6 {
+    width: 50%; }
+  .medium-margin-collapse > .medium-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .medium-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .medium-9 {
+    width: 75%; }
+  .medium-margin-collapse > .medium-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .medium-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .medium-12 {
+    width: 100%; } }
 
-ul ul, ol ul, ul ol, ol ol {
-  margin-right: 1.25rem;
-  margin-bottom: 0; }
+@media print, screen and (min-width: 64em) {
+  .medium-margin-collapse > .large-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .large-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .large-3 {
+    width: 25%; }
+  .medium-margin-collapse > .large-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .large-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .large-6 {
+    width: 50%; }
+  .medium-margin-collapse > .large-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .large-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .large-9 {
+    width: 75%; }
+  .medium-margin-collapse > .large-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .large-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .large-12 {
+    width: 100%; } }
 
-dl {
-  margin-bottom: 1rem; }
-  dl dt {
-    margin-bottom: 0.3rem;
-    font-weight: bold; }
+@media print, screen and (min-width: 40em) {
+  .medium-padding-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .medium-padding-collapse > .cell {
+      padding-right: 0;
+      padding-left: 0; } }
 
-blockquote {
-  margin: 0 0 1rem;
-  padding: 0.5625rem 1.25rem 0 1.1875rem;
-  border-right: 1px solid #cacaca; }
-  blockquote, blockquote p {
-    line-height: 1.6;
-    color: #8a8a8a; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .large-margin-collapse > .cell {
+      margin-right: 0;
+      margin-left: 0; } }
 
-cite {
-  display: block;
-  font-size: 0.8125rem;
-  color: #8a8a8a; }
-  cite:before {
-    content: "— "; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .small-3 {
+    width: 25%; }
+  .large-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .small-6 {
+    width: 50%; }
+  .large-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .small-9 {
+    width: 75%; }
+  .large-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .small-12 {
+    width: 100%; } }
 
-abbr, abbr[title] {
-  border-bottom: 1px dotted #0a0a0a;
-  cursor: help;
-  text-decoration: none; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .medium-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .medium-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .medium-3 {
+    width: 25%; }
+  .large-margin-collapse > .medium-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .medium-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .medium-6 {
+    width: 50%; }
+  .large-margin-collapse > .medium-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .medium-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .medium-9 {
+    width: 75%; }
+  .large-margin-collapse > .medium-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .medium-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .medium-12 {
+    width: 100%; } }
 
-figure {
-  margin: 0; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .large-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .large-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .large-3 {
+    width: 25%; }
+  .large-margin-collapse > .large-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .large-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .large-6 {
+    width: 50%; }
+  .large-margin-collapse > .large-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .large-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .large-9 {
+    width: 75%; }
+  .large-margin-collapse > .large-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .large-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .large-12 {
+    width: 100%; } }
 
-code {
-  padding: 0.125rem 0.3125rem 0.0625rem;
-  border: 1px solid #cacaca;
-  background-color: #e6e6e6;
-  font-family: Consolas, "Liberation Mono", Courier, monospace;
-  font-weight: normal;
-  color: #0a0a0a; }
+@media print, screen and (min-width: 64em) {
+  .large-padding-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .large-padding-collapse > .cell {
+      padding-right: 0;
+      padding-left: 0; } }
 
-kbd {
-  margin: 0;
-  padding: 0.125rem 0.25rem 0;
-  background-color: #e6e6e6;
-  font-family: Consolas, "Liberation Mono", Courier, monospace;
-  color: #0a0a0a; }
+.small-offset-0 {
+  margin-right: 0%; }
 
-.subheader {
-  margin-top: 0.2rem;
-  margin-bottom: 0.5rem;
-  font-weight: normal;
-  line-height: 1.4;
-  color: #8a8a8a; }
+.grid-margin-x > .small-offset-0 {
+  margin-right: calc(0% + 0.625rem); }
 
-.lead {
-  font-size: 125%;
-  line-height: 1.6; }
+.small-offset-1 {
+  margin-right: 8.33333%; }
 
-.stat {
-  font-size: 2.5rem;
-  line-height: 1; }
-  p + .stat {
-    margin-top: -1rem; }
+.grid-margin-x > .small-offset-1 {
+  margin-right: calc(8.33333% + 0.625rem); }
 
-ul.no-bullet, ol.no-bullet {
-  margin-right: 0;
-  list-style: none; }
+.small-offset-2 {
+  margin-right: 16.66667%; }
 
-.text-left {
-  text-align: left; }
+.grid-margin-x > .small-offset-2 {
+  margin-right: calc(16.66667% + 0.625rem); }
 
-.text-right {
-  text-align: right; }
+.small-offset-3 {
+  margin-right: 25%; }
 
-.text-center {
-  text-align: center; }
+.grid-margin-x > .small-offset-3 {
+  margin-right: calc(25% + 0.625rem); }
 
-.text-justify {
-  text-align: justify; }
+.small-offset-4 {
+  margin-right: 33.33333%; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-text-left {
-    text-align: left; }
-  .medium-text-right {
-    text-align: right; }
-  .medium-text-center {
-    text-align: center; }
-  .medium-text-justify {
-    text-align: justify; } }
+.grid-margin-x > .small-offset-4 {
+  margin-right: calc(33.33333% + 0.625rem); }
 
-@media print, screen and (min-width: 64em) {
-  .large-text-left {
-    text-align: left; }
-  .large-text-right {
-    text-align: right; }
-  .large-text-center {
-    text-align: center; }
-  .large-text-justify {
-    text-align: justify; } }
+.small-offset-5 {
+  margin-right: 41.66667%; }
 
-.show-for-print {
-  display: none !important; }
+.grid-margin-x > .small-offset-5 {
+  margin-right: calc(41.66667% + 0.625rem); }
 
-@media print {
-  * {
-    background: transparent !important;
-    -webkit-box-shadow: none !important;
-            box-shadow: none !important;
-    color: black !important;
-    text-shadow: none !important; }
-  .show-for-print {
-    display: block !important; }
-  .hide-for-print {
-    display: none !important; }
-  table.show-for-print {
-    display: table !important; }
-  thead.show-for-print {
-    display: table-header-group !important; }
-  tbody.show-for-print {
-    display: table-row-group !important; }
-  tr.show-for-print {
-    display: table-row !important; }
-  td.show-for-print {
-    display: table-cell !important; }
-  th.show-for-print {
-    display: table-cell !important; }
-  a,
-  a:visited {
-    text-decoration: underline; }
-  a[href]:after {
-    content: " (" attr(href) ")"; }
-  .ir a:after,
-  a[href^='javascript:']:after,
-  a[href^='#']:after {
-    content: ''; }
-  abbr[title]:after {
-    content: " (" attr(title) ")"; }
-  pre,
-  blockquote {
-    border: 1px solid #8a8a8a;
-    page-break-inside: avoid; }
-  thead {
-    display: table-header-group; }
-  tr,
-  img {
-    page-break-inside: avoid; }
-  img {
-    max-width: 100% !important; }
-  @page {
-    margin: 0.5cm; }
-  p,
-  h2,
-  h3 {
-    orphans: 3;
-    widows: 3; }
-  h2,
-  h3 {
-    page-break-after: avoid; }
-  .print-break-inside {
-    page-break-inside: auto; } }
+.small-offset-6 {
+  margin-right: 50%; }
 
-[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],
-textarea {
-  display: block;
-  -webkit-box-sizing: border-box;
-          box-sizing: border-box;
-  width: 100%;
-  height: 2.4375rem;
-  margin: 0 0 1rem;
-  padding: 0.5rem;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
-          box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
-  font-family: inherit;
-  font-size: 1rem;
-  font-weight: normal;
-  line-height: 1.5;
-  color: #0a0a0a;
-  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none; }
-  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,
-  textarea:focus {
-    outline: none;
-    border: 1px solid #8a8a8a;
-    background-color: #fefefe;
-    -webkit-box-shadow: 0 0 5px #cacaca;
-            box-shadow: 0 0 5px #cacaca;
-    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-
-textarea {
-  max-width: 100%; }
-  textarea[rows] {
-    height: auto; }
-
-input::-webkit-input-placeholder,
-textarea::-webkit-input-placeholder {
-  color: #cacaca; }
-
-input:-ms-input-placeholder,
-textarea:-ms-input-placeholder {
-  color: #cacaca; }
-
-input::placeholder,
-textarea::placeholder {
-  color: #cacaca; }
-
-input:disabled, input[readonly],
-textarea:disabled,
-textarea[readonly] {
-  background-color: #e6e6e6;
-  cursor: not-allowed; }
+.grid-margin-x > .small-offset-6 {
+  margin-right: calc(50% + 0.625rem); }
 
-[type='submit'],
-[type='button'] {
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none;
-  border-radius: 0; }
+.small-offset-7 {
+  margin-right: 58.33333%; }
 
-input[type='search'] {
-  -webkit-box-sizing: border-box;
-          box-sizing: border-box; }
+.grid-margin-x > .small-offset-7 {
+  margin-right: calc(58.33333% + 0.625rem); }
 
-[type='file'],
-[type='checkbox'],
-[type='radio'] {
-  margin: 0 0 1rem; }
+.small-offset-8 {
+  margin-right: 66.66667%; }
 
-[type='checkbox'] + label,
-[type='radio'] + label {
-  display: inline-block;
-  vertical-align: baseline;
-  margin-right: 0.5rem;
-  margin-left: 1rem;
-  margin-bottom: 0; }
-  [type='checkbox'] + label[for],
-  [type='radio'] + label[for] {
-    cursor: pointer; }
+.grid-margin-x > .small-offset-8 {
+  margin-right: calc(66.66667% + 0.625rem); }
 
-label > [type='checkbox'],
-label > [type='radio'] {
-  margin-left: 0.5rem; }
+.small-offset-9 {
+  margin-right: 75%; }
 
-[type='file'] {
-  width: 100%; }
+.grid-margin-x > .small-offset-9 {
+  margin-right: calc(75% + 0.625rem); }
 
-label {
-  display: block;
-  margin: 0;
-  font-size: 0.875rem;
-  font-weight: normal;
-  line-height: 1.8;
-  color: #0a0a0a; }
-  label.middle {
-    margin: 0 0 1rem;
-    padding: 0.5625rem 0; }
+.small-offset-10 {
+  margin-right: 83.33333%; }
 
-.help-text {
-  margin-top: -0.5rem;
-  font-size: 0.8125rem;
-  font-style: italic;
-  color: #0a0a0a; }
+.grid-margin-x > .small-offset-10 {
+  margin-right: calc(83.33333% + 0.625rem); }
 
-.input-group {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  width: 100%;
-  margin-bottom: 1rem;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch; }
-  .input-group > :first-child {
-    border-radius: 0 0 0 0; }
-  .input-group > :last-child > * {
-    border-radius: 0 0 0 0; }
+.small-offset-11 {
+  margin-right: 91.66667%; }
 
-.input-group-label, .input-group-field, .input-group-button, .input-group-button a,
-.input-group-button input,
-.input-group-button button,
-.input-group-button label {
-  margin: 0;
-  white-space: nowrap; }
+.grid-margin-x > .small-offset-11 {
+  margin-right: calc(91.66667% + 0.625rem); }
 
-.input-group-label {
-  padding: 0 1rem;
-  border: 1px solid #cacaca;
-  background: #e6e6e6;
-  color: #0a0a0a;
-  text-align: center;
-  white-space: nowrap;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto;
-  -webkit-box-align: center;
-  -webkit-align-items: center;
-      -ms-flex-align: center;
-          align-items: center; }
-  .input-group-label:first-child {
-    border-left: 0; }
-  .input-group-label:last-child {
-    border-right: 0; }
+@media print, screen and (min-width: 40em) {
+  .medium-offset-0 {
+    margin-right: 0%; }
+  .grid-margin-x > .medium-offset-0 {
+    margin-right: calc(0% + 0.9375rem); }
+  .medium-offset-1 {
+    margin-right: 8.33333%; }
+  .grid-margin-x > .medium-offset-1 {
+    margin-right: calc(8.33333% + 0.9375rem); }
+  .medium-offset-2 {
+    margin-right: 16.66667%; }
+  .grid-margin-x > .medium-offset-2 {
+    margin-right: calc(16.66667% + 0.9375rem); }
+  .medium-offset-3 {
+    margin-right: 25%; }
+  .grid-margin-x > .medium-offset-3 {
+    margin-right: calc(25% + 0.9375rem); }
+  .medium-offset-4 {
+    margin-right: 33.33333%; }
+  .grid-margin-x > .medium-offset-4 {
+    margin-right: calc(33.33333% + 0.9375rem); }
+  .medium-offset-5 {
+    margin-right: 41.66667%; }
+  .grid-margin-x > .medium-offset-5 {
+    margin-right: calc(41.66667% + 0.9375rem); }
+  .medium-offset-6 {
+    margin-right: 50%; }
+  .grid-margin-x > .medium-offset-6 {
+    margin-right: calc(50% + 0.9375rem); }
+  .medium-offset-7 {
+    margin-right: 58.33333%; }
+  .grid-margin-x > .medium-offset-7 {
+    margin-right: calc(58.33333% + 0.9375rem); }
+  .medium-offset-8 {
+    margin-right: 66.66667%; }
+  .grid-margin-x > .medium-offset-8 {
+    margin-right: calc(66.66667% + 0.9375rem); }
+  .medium-offset-9 {
+    margin-right: 75%; }
+  .grid-margin-x > .medium-offset-9 {
+    margin-right: calc(75% + 0.9375rem); }
+  .medium-offset-10 {
+    margin-right: 83.33333%; }
+  .grid-margin-x > .medium-offset-10 {
+    margin-right: calc(83.33333% + 0.9375rem); }
+  .medium-offset-11 {
+    margin-right: 91.66667%; }
+  .grid-margin-x > .medium-offset-11 {
+    margin-right: calc(91.66667% + 0.9375rem); } }
 
-.input-group-field {
-  border-radius: 0;
-  -webkit-box-flex: 1;
-  -webkit-flex: 1 1 0px;
-      -ms-flex: 1 1 0px;
-          flex: 1 1 0px;
-  height: auto;
-  min-width: 0; }
+@media print, screen and (min-width: 64em) {
+  .large-offset-0 {
+    margin-right: 0%; }
+  .grid-margin-x > .large-offset-0 {
+    margin-right: calc(0% + 0.9375rem); }
+  .large-offset-1 {
+    margin-right: 8.33333%; }
+  .grid-margin-x > .large-offset-1 {
+    margin-right: calc(8.33333% + 0.9375rem); }
+  .large-offset-2 {
+    margin-right: 16.66667%; }
+  .grid-margin-x > .large-offset-2 {
+    margin-right: calc(16.66667% + 0.9375rem); }
+  .large-offset-3 {
+    margin-right: 25%; }
+  .grid-margin-x > .large-offset-3 {
+    margin-right: calc(25% + 0.9375rem); }
+  .large-offset-4 {
+    margin-right: 33.33333%; }
+  .grid-margin-x > .large-offset-4 {
+    margin-right: calc(33.33333% + 0.9375rem); }
+  .large-offset-5 {
+    margin-right: 41.66667%; }
+  .grid-margin-x > .large-offset-5 {
+    margin-right: calc(41.66667% + 0.9375rem); }
+  .large-offset-6 {
+    margin-right: 50%; }
+  .grid-margin-x > .large-offset-6 {
+    margin-right: calc(50% + 0.9375rem); }
+  .large-offset-7 {
+    margin-right: 58.33333%; }
+  .grid-margin-x > .large-offset-7 {
+    margin-right: calc(58.33333% + 0.9375rem); }
+  .large-offset-8 {
+    margin-right: 66.66667%; }
+  .grid-margin-x > .large-offset-8 {
+    margin-right: calc(66.66667% + 0.9375rem); }
+  .large-offset-9 {
+    margin-right: 75%; }
+  .grid-margin-x > .large-offset-9 {
+    margin-right: calc(75% + 0.9375rem); }
+  .large-offset-10 {
+    margin-right: 83.33333%; }
+  .grid-margin-x > .large-offset-10 {
+    margin-right: calc(83.33333% + 0.9375rem); }
+  .large-offset-11 {
+    margin-right: 91.66667%; }
+  .grid-margin-x > .large-offset-11 {
+    margin-right: calc(91.66667% + 0.9375rem); } }
 
-.input-group-button {
-  padding-top: 0;
-  padding-bottom: 0;
-  text-align: center;
+.grid-y {
   display: -webkit-box;
   display: -webkit-flex;
   display: -ms-flexbox;
   display: flex;
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto; }
-  .input-group-button a,
-  .input-group-button input,
-  .input-group-button button,
-  .input-group-button label {
-    height: auto;
-    -webkit-align-self: stretch;
-        -ms-flex-item-align: stretch;
-                -ms-grid-row-align: stretch;
-            align-self: stretch;
-    padding-top: 0;
-    padding-bottom: 0;
-    font-size: 1rem; }
-
-fieldset {
-  margin: 0;
-  padding: 0;
-  border: 0; }
-
-legend {
-  max-width: 100%;
-  margin-bottom: 0.5rem; }
-
-.fieldset {
-  margin: 1.125rem 0;
-  padding: 1.25rem;
-  border: 1px solid #cacaca; }
-  .fieldset legend {
-    margin: 0;
-    margin-right: -0.1875rem;
-    padding: 0 0.1875rem; }
-
-select {
-  height: 2.4375rem;
-  margin: 0 0 1rem;
-  padding: 0.5rem;
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  font-family: inherit;
-  font-size: 1rem;
-  font-weight: normal;
-  line-height: 1.5;
-  color: #0a0a0a;
-  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");
-  -webkit-background-origin: content-box;
-          background-origin: content-box;
-  background-position: left -1rem center;
-  background-repeat: no-repeat;
-  -webkit-background-size: 9px 6px;
-          background-size: 9px 6px;
-  padding-left: 1.5rem;
-  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-  @media screen and (min-width: 0\0) {
-    select {
-      background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } }
-  select:focus {
-    outline: none;
-    border: 1px solid #8a8a8a;
-    background-color: #fefefe;
-    -webkit-box-shadow: 0 0 5px #cacaca;
-            box-shadow: 0 0 5px #cacaca;
-    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-  select:disabled {
-    background-color: #e6e6e6;
-    cursor: not-allowed; }
-  select::-ms-expand {
-    display: none; }
-  select[multiple] {
-    height: auto;
-    background-image: none; }
-
-.is-invalid-input:not(:focus) {
-  border-color: #cc4b37;
-  background-color: #f9ecea; }
-  .is-invalid-input:not(:focus)::-webkit-input-placeholder {
-    color: #cc4b37; }
-  .is-invalid-input:not(:focus):-ms-input-placeholder {
-    color: #cc4b37; }
-  .is-invalid-input:not(:focus)::placeholder {
-    color: #cc4b37; }
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-flow: column nowrap;
+      -ms-flex-flow: column nowrap;
+          flex-flow: column nowrap; }
+  .grid-y > .cell {
+    width: auto;
+    max-width: none; }
+  .grid-y > .auto {
+    height: auto; }
+  .grid-y > .shrink {
+    height: auto; }
+  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; }
+  @media print, screen and (min-width: 40em) {
+    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
+      -webkit-flex-basis: auto;
+          -ms-flex-preferred-size: auto;
+              flex-basis: auto; } }
+  @media print, screen and (min-width: 64em) {
+    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
+      -webkit-flex-basis: auto;
+          -ms-flex-preferred-size: auto;
+              flex-basis: auto; } }
+  .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-y > .small-1 {
+    height: 8.33333%; }
+  .grid-y > .small-2 {
+    height: 16.66667%; }
+  .grid-y > .small-3 {
+    height: 25%; }
+  .grid-y > .small-4 {
+    height: 33.33333%; }
+  .grid-y > .small-5 {
+    height: 41.66667%; }
+  .grid-y > .small-6 {
+    height: 50%; }
+  .grid-y > .small-7 {
+    height: 58.33333%; }
+  .grid-y > .small-8 {
+    height: 66.66667%; }
+  .grid-y > .small-9 {
+    height: 75%; }
+  .grid-y > .small-10 {
+    height: 83.33333%; }
+  .grid-y > .small-11 {
+    height: 91.66667%; }
+  .grid-y > .small-12 {
+    height: 100%; }
+  @media print, screen and (min-width: 40em) {
+    .grid-y > .medium-auto {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px;
+      height: auto; }
+    .grid-y > .medium-shrink, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto; }
+    .grid-y > .medium-shrink {
+      height: auto; }
+    .grid-y > .medium-1 {
+      height: 8.33333%; }
+    .grid-y > .medium-2 {
+      height: 16.66667%; }
+    .grid-y > .medium-3 {
+      height: 25%; }
+    .grid-y > .medium-4 {
+      height: 33.33333%; }
+    .grid-y > .medium-5 {
+      height: 41.66667%; }
+    .grid-y > .medium-6 {
+      height: 50%; }
+    .grid-y > .medium-7 {
+      height: 58.33333%; }
+    .grid-y > .medium-8 {
+      height: 66.66667%; }
+    .grid-y > .medium-9 {
+      height: 75%; }
+    .grid-y > .medium-10 {
+      height: 83.33333%; }
+    .grid-y > .medium-11 {
+      height: 91.66667%; }
+    .grid-y > .medium-12 {
+      height: 100%; } }
+  @media print, screen and (min-width: 64em) {
+    .grid-y > .large-auto {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px;
+      height: auto; }
+    .grid-y > .large-shrink, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto; }
+    .grid-y > .large-shrink {
+      height: auto; }
+    .grid-y > .large-1 {
+      height: 8.33333%; }
+    .grid-y > .large-2 {
+      height: 16.66667%; }
+    .grid-y > .large-3 {
+      height: 25%; }
+    .grid-y > .large-4 {
+      height: 33.33333%; }
+    .grid-y > .large-5 {
+      height: 41.66667%; }
+    .grid-y > .large-6 {
+      height: 50%; }
+    .grid-y > .large-7 {
+      height: 58.33333%; }
+    .grid-y > .large-8 {
+      height: 66.66667%; }
+    .grid-y > .large-9 {
+      height: 75%; }
+    .grid-y > .large-10 {
+      height: 83.33333%; }
+    .grid-y > .large-11 {
+      height: 91.66667%; }
+    .grid-y > .large-12 {
+      height: 100%; } }
 
-.is-invalid-label {
-  color: #cc4b37; }
+.grid-padding-y .grid-padding-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-y .grid-padding-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
 
-.form-error {
-  display: none;
-  margin-top: -0.5rem;
-  margin-bottom: 1rem;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #cc4b37; }
-  .form-error.is-visible {
-    display: block; }
+.grid-padding-y > .cell {
+  padding-top: 0.625rem;
+  padding-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-y > .cell {
+      padding-top: 0.9375rem;
+      padding-bottom: 0.9375rem; } }
 
-.button {
-  display: inline-block;
-  vertical-align: middle;
-  margin: 0 0 1rem 0;
-  font-family: inherit;
-  padding: 0.85em 1em;
-  -webkit-appearance: none;
-  border: 1px solid transparent;
-  border-radius: 0;
-  -webkit-transition: background-color 0.25s ease-out, color 0.25s ease-out;
-  transition: background-color 0.25s ease-out, color 0.25s ease-out;
-  font-size: 0.9rem;
-  line-height: 1;
-  text-align: center;
-  cursor: pointer;
-  background-color: #1779ba;
-  color: #fefefe; }
-  [data-whatinput='mouse'] .button {
-    outline: 0; }
-  .button:hover, .button:focus {
-    background-color: #14679e;
-    color: #fefefe; }
-  .button.tiny {
-    font-size: 0.6rem; }
-  .button.small {
-    font-size: 0.75rem; }
-  .button.large {
-    font-size: 1.25rem; }
-  .button.expanded {
-    display: block;
-    width: 100%;
-    margin-right: 0;
-    margin-left: 0; }
-  .button.primary {
-    background-color: #1779ba;
-    color: #fefefe; }
-    .button.primary:hover, .button.primary:focus {
-      background-color: #126195;
-      color: #fefefe; }
-  .button.secondary {
-    background-color: #767676;
-    color: #fefefe; }
-    .button.secondary:hover, .button.secondary:focus {
-      background-color: #5e5e5e;
-      color: #fefefe; }
-  .button.success {
-    background-color: #3adb76;
-    color: #0a0a0a; }
-    .button.success:hover, .button.success:focus {
-      background-color: #22bb5b;
-      color: #0a0a0a; }
-  .button.warning {
-    background-color: #ffae00;
-    color: #0a0a0a; }
-    .button.warning:hover, .button.warning:focus {
-      background-color: #cc8b00;
-      color: #0a0a0a; }
-  .button.alert {
-    background-color: #cc4b37;
-    color: #fefefe; }
-    .button.alert:hover, .button.alert:focus {
-      background-color: #a53b2a;
-      color: #fefefe; }
-  .button.disabled, .button[disabled] {
-    opacity: 0.25;
-    cursor: not-allowed; }
-    .button.disabled, .button.disabled:hover, .button.disabled:focus, .button[disabled], .button[disabled]:hover, .button[disabled]:focus {
-      background-color: #1779ba;
-      color: #fefefe; }
-    .button.disabled.primary, .button[disabled].primary {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.primary, .button.disabled.primary:hover, .button.disabled.primary:focus, .button[disabled].primary, .button[disabled].primary:hover, .button[disabled].primary:focus {
-        background-color: #1779ba;
-        color: #fefefe; }
-    .button.disabled.secondary, .button[disabled].secondary {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.secondary, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary, .button[disabled].secondary:hover, .button[disabled].secondary:focus {
-        background-color: #767676;
-        color: #fefefe; }
-    .button.disabled.success, .button[disabled].success {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.success, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success, .button[disabled].success:hover, .button[disabled].success:focus {
-        background-color: #3adb76;
-        color: #0a0a0a; }
-    .button.disabled.warning, .button[disabled].warning {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.warning, .button.disabled.warning:hover, .button.disabled.warning:focus, .button[disabled].warning, .button[disabled].warning:hover, .button[disabled].warning:focus {
-        background-color: #ffae00;
-        color: #0a0a0a; }
-    .button.disabled.alert, .button[disabled].alert {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.alert, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert, .button[disabled].alert:hover, .button[disabled].alert:focus {
-        background-color: #cc4b37;
-        color: #fefefe; }
-  .button.hollow {
-    border: 1px solid #1779ba;
-    color: #1779ba; }
-    .button.hollow, .button.hollow:hover, .button.hollow:focus {
-      background-color: transparent; }
-    .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {
-      background-color: transparent; }
-    .button.hollow:hover, .button.hollow:focus {
-      border-color: #0c3d5d;
-      color: #0c3d5d; }
-      .button.hollow:hover.disabled, .button.hollow:hover[disabled], .button.hollow:focus.disabled, .button.hollow:focus[disabled] {
-        border: 1px solid #1779ba;
-        color: #1779ba; }
-    .button.hollow.primary {
-      border: 1px solid #1779ba;
-      color: #1779ba; }
-      .button.hollow.primary:hover, .button.hollow.primary:focus {
-        border-color: #0c3d5d;
-        color: #0c3d5d; }
-        .button.hollow.primary:hover.disabled, .button.hollow.primary:hover[disabled], .button.hollow.primary:focus.disabled, .button.hollow.primary:focus[disabled] {
-          border: 1px solid #1779ba;
-          color: #1779ba; }
-    .button.hollow.secondary {
-      border: 1px solid #767676;
-      color: #767676; }
-      .button.hollow.secondary:hover, .button.hollow.secondary:focus {
-        border-color: #3b3b3b;
-        color: #3b3b3b; }
-        .button.hollow.secondary:hover.disabled, .button.hollow.secondary:hover[disabled], .button.hollow.secondary:focus.disabled, .button.hollow.secondary:focus[disabled] {
-          border: 1px solid #767676;
-          color: #767676; }
-    .button.hollow.success {
-      border: 1px solid #3adb76;
-      color: #3adb76; }
-      .button.hollow.success:hover, .button.hollow.success:focus {
-        border-color: #157539;
-        color: #157539; }
-        .button.hollow.success:hover.disabled, .button.hollow.success:hover[disabled], .button.hollow.success:focus.disabled, .button.hollow.success:focus[disabled] {
-          border: 1px solid #3adb76;
-          color: #3adb76; }
-    .button.hollow.warning {
-      border: 1px solid #ffae00;
-      color: #ffae00; }
-      .button.hollow.warning:hover, .button.hollow.warning:focus {
-        border-color: #805700;
-        color: #805700; }
-        .button.hollow.warning:hover.disabled, .button.hollow.warning:hover[disabled], .button.hollow.warning:focus.disabled, .button.hollow.warning:focus[disabled] {
-          border: 1px solid #ffae00;
-          color: #ffae00; }
-    .button.hollow.alert {
-      border: 1px solid #cc4b37;
-      color: #cc4b37; }
-      .button.hollow.alert:hover, .button.hollow.alert:focus {
-        border-color: #67251a;
-        color: #67251a; }
-        .button.hollow.alert:hover.disabled, .button.hollow.alert:hover[disabled], .button.hollow.alert:focus.disabled, .button.hollow.alert:focus[disabled] {
-          border: 1px solid #cc4b37;
-          color: #cc4b37; }
-  .button.clear {
-    border: 1px solid #1779ba;
-    color: #1779ba; }
-    .button.clear, .button.clear:hover, .button.clear:focus {
-      background-color: transparent; }
-    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {
-      background-color: transparent; }
-    .button.clear:hover, .button.clear:focus {
-      border-color: #0c3d5d;
-      color: #0c3d5d; }
-      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {
-        border: 1px solid #1779ba;
-        color: #1779ba; }
-    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {
-      border-color: transparent; }
-    .button.clear.primary {
-      border: 1px solid #1779ba;
-      color: #1779ba; }
-      .button.clear.primary:hover, .button.clear.primary:focus {
-        border-color: #0c3d5d;
-        color: #0c3d5d; }
-        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
-          border: 1px solid #1779ba;
-          color: #1779ba; }
-      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.secondary {
-      border: 1px solid #767676;
-      color: #767676; }
-      .button.clear.secondary:hover, .button.clear.secondary:focus {
-        border-color: #3b3b3b;
-        color: #3b3b3b; }
-        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
-          border: 1px solid #767676;
-          color: #767676; }
-      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.success {
-      border: 1px solid #3adb76;
-      color: #3adb76; }
-      .button.clear.success:hover, .button.clear.success:focus {
-        border-color: #157539;
-        color: #157539; }
-        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
-          border: 1px solid #3adb76;
-          color: #3adb76; }
-      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.warning {
-      border: 1px solid #ffae00;
-      color: #ffae00; }
-      .button.clear.warning:hover, .button.clear.warning:focus {
-        border-color: #805700;
-        color: #805700; }
-        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
-          border: 1px solid #ffae00;
-          color: #ffae00; }
-      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.alert {
-      border: 1px solid #cc4b37;
-      color: #cc4b37; }
-      .button.clear.alert:hover, .button.clear.alert:focus {
-        border-color: #67251a;
-        color: #67251a; }
-        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
-          border: 1px solid #cc4b37;
-          color: #cc4b37; }
-      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
-        border-color: transparent; }
-  .button.dropdown::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.4em;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #fefefe transparent transparent;
-    position: relative;
-    top: 0.4em;
-    display: inline-block;
-    float: left;
-    margin-right: 1em; }
-  .button.dropdown.hollow::after {
-    border-top-color: #1779ba; }
-  .button.dropdown.hollow.primary::after {
-    border-top-color: #1779ba; }
-  .button.dropdown.hollow.secondary::after {
-    border-top-color: #767676; }
-  .button.dropdown.hollow.success::after {
-    border-top-color: #3adb76; }
-  .button.dropdown.hollow.warning::after {
-    border-top-color: #ffae00; }
-  .button.dropdown.hollow.alert::after {
-    border-top-color: #cc4b37; }
-  .button.arrow-only::after {
-    top: -0.1em;
-    float: none;
-    margin-right: 0; }
-
-a.button:hover, a.button:focus {
-  text-decoration: none; }
-
-.accordion {
-  margin-right: 0;
-  background: #fefefe;
-  list-style-type: none; }
-  .accordion[disabled] .accordion-title {
-    cursor: not-allowed; }
-
-.accordion-item:first-child > :first-child {
-  border-radius: 0 0 0 0; }
-
-.accordion-item:last-child > :last-child {
-  border-radius: 0 0 0 0; }
-
-.accordion-title {
-  position: relative;
-  display: block;
-  padding: 1.25rem 1rem;
-  border: 1px solid #e6e6e6;
-  border-bottom: 0;
-  font-size: 0.75rem;
-  line-height: 1;
-  color: #1779ba; }
-  :last-child:not(.is-active) > .accordion-title {
-    border-bottom: 1px solid #e6e6e6;
-    border-radius: 0 0 0 0; }
-  .accordion-title:hover, .accordion-title:focus {
-    background-color: #e6e6e6; }
-  .accordion-title::before {
-    position: absolute;
-    top: 50%;
-    left: 1rem;
-    margin-top: -0.5rem;
-    content: '+'; }
-  .is-active > .accordion-title::before {
-    content: '\2013'; }
-
-.accordion-content {
-  display: none;
-  padding: 1rem;
-  border: 1px solid #e6e6e6;
-  border-bottom: 0;
-  background-color: #fefefe;
-  color: #0a0a0a; }
-  :last-child > .accordion-content:last-child {
-    border-bottom: 1px solid #e6e6e6; }
-
-.accordion-menu li {
-  width: 100%; }
-
-.accordion-menu a {
-  padding: 0.7rem 1rem; }
-
-.accordion-menu .is-accordion-submenu a {
-  padding: 0.7rem 1rem; }
-
-.accordion-menu .nested.is-accordion-submenu {
-  margin-left: 0;
-  margin-right: 1rem; }
-
-.accordion-menu.align-left .nested.is-accordion-submenu {
-  margin-left: 1rem;
-  margin-right: 0; }
-
-.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {
-  position: relative; }
-  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    position: absolute;
-    top: 50%;
-    margin-top: -3px;
-    left: 1rem; }
-
-.accordion-menu.align-left .is-accordion-submenu-parent > a::after {
-  left: auto;
-  right: 1rem; }
-
-.accordion-menu.align-right .is-accordion-submenu-parent > a::after {
-  right: auto;
-  left: 1rem; }
-
-.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {
-  -webkit-transform: rotate(180deg);
-      -ms-transform: rotate(180deg);
-          transform: rotate(180deg);
-  -webkit-transform-origin: 50% 50%;
-      -ms-transform-origin: 50% 50%;
-          transform-origin: 50% 50%; }
-
-.is-accordion-submenu-parent {
-  position: relative; }
-
-.has-submenu-toggle > a {
-  margin-left: 40px; }
-
-.submenu-toggle {
-  position: absolute;
-  top: 0;
-  left: 0;
-  cursor: pointer;
-  width: 40px;
-  height: 40px; }
-  .submenu-toggle::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    top: 0;
-    bottom: 0;
-    margin: auto; }
-
-.submenu-toggle[aria-expanded='true']::after {
-  -webkit-transform: scaleY(-1);
-      -ms-transform: scaleY(-1);
-          transform: scaleY(-1);
-  -webkit-transform-origin: 50% 50%;
-      -ms-transform-origin: 50% 50%;
-          transform-origin: 50% 50%; }
-
-.submenu-toggle-text {
-  position: absolute !important;
-  width: 1px;
-  height: 1px;
-  padding: 0;
-  overflow: hidden;
-  clip: rect(0, 0, 0, 0);
-  white-space: nowrap;
-  -webkit-clip-path: inset(50%);
-          clip-path: inset(50%);
-  border: 0; }
-
-.badge {
-  display: inline-block;
-  min-width: 2.1em;
-  padding: 0.3em;
-  border-radius: 50%;
-  font-size: 0.6rem;
-  text-align: center;
-  background: #1779ba;
-  color: #fefefe; }
-  .badge.primary {
-    background: #1779ba;
-    color: #fefefe; }
-  .badge.secondary {
-    background: #767676;
-    color: #fefefe; }
-  .badge.success {
-    background: #3adb76;
-    color: #0a0a0a; }
-  .badge.warning {
-    background: #ffae00;
-    color: #0a0a0a; }
-  .badge.alert {
-    background: #cc4b37;
-    color: #fefefe; }
-
-.breadcrumbs {
-  margin: 0 0 1rem 0;
-  list-style: none; }
-  .breadcrumbs::before, .breadcrumbs::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .breadcrumbs::after {
-    clear: both; }
-  .breadcrumbs li {
-    float: right;
-    font-size: 0.6875rem;
-    color: #0a0a0a;
-    cursor: default;
-    text-transform: uppercase; }
-    .breadcrumbs li:not(:last-child)::after {
-      position: relative;
-      margin: 0 0.75rem;
-      opacity: 1;
-      content: "\\";
-      color: #cacaca; }
-  .breadcrumbs a {
-    color: #1779ba; }
-    .breadcrumbs a:hover {
-      text-decoration: underline; }
-  .breadcrumbs .disabled {
-    color: #cacaca;
-    cursor: not-allowed; }
+.grid-margin-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
+  .grid-margin-y > .cell {
+    height: calc(100% - 1.25rem);
+    margin-top: 0.625rem;
+    margin-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .cell {
+      height: calc(100% - 1.875rem);
+      margin-top: 0.9375rem;
+      margin-bottom: 0.9375rem; } }
+  .grid-margin-y > .auto {
+    height: auto; }
+  .grid-margin-y > .shrink {
+    height: auto; }
+  .grid-margin-y > .small-1 {
+    height: calc(8.33333% - 1.25rem); }
+  .grid-margin-y > .small-2 {
+    height: calc(16.66667% - 1.25rem); }
+  .grid-margin-y > .small-3 {
+    height: calc(25% - 1.25rem); }
+  .grid-margin-y > .small-4 {
+    height: calc(33.33333% - 1.25rem); }
+  .grid-margin-y > .small-5 {
+    height: calc(41.66667% - 1.25rem); }
+  .grid-margin-y > .small-6 {
+    height: calc(50% - 1.25rem); }
+  .grid-margin-y > .small-7 {
+    height: calc(58.33333% - 1.25rem); }
+  .grid-margin-y > .small-8 {
+    height: calc(66.66667% - 1.25rem); }
+  .grid-margin-y > .small-9 {
+    height: calc(75% - 1.25rem); }
+  .grid-margin-y > .small-10 {
+    height: calc(83.33333% - 1.25rem); }
+  .grid-margin-y > .small-11 {
+    height: calc(91.66667% - 1.25rem); }
+  .grid-margin-y > .small-12 {
+    height: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .auto {
+      height: auto; }
+    .grid-margin-y > .shrink {
+      height: auto; }
+    .grid-margin-y > .small-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .small-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .small-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .small-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .small-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .small-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .small-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .small-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .small-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .small-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .small-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .small-12 {
+      height: calc(100% - 1.875rem); }
+    .grid-margin-y > .medium-auto {
+      height: auto; }
+    .grid-margin-y > .medium-shrink {
+      height: auto; }
+    .grid-margin-y > .medium-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .medium-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .medium-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .medium-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .medium-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .medium-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .medium-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .medium-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .medium-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .medium-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .medium-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .medium-12 {
+      height: calc(100% - 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-margin-y > .large-auto {
+      height: auto; }
+    .grid-margin-y > .large-shrink {
+      height: auto; }
+    .grid-margin-y > .large-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .large-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .large-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .large-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .large-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .large-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .large-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .large-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .large-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .large-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .large-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .large-12 {
+      height: calc(100% - 1.875rem); } }
 
-.button-group {
-  margin-bottom: 1rem;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
+.grid-frame {
+  overflow: hidden;
+  position: relative;
   -webkit-flex-wrap: nowrap;
       -ms-flex-wrap: nowrap;
           flex-wrap: nowrap;
   -webkit-box-align: stretch;
   -webkit-align-items: stretch;
       -ms-flex-align: stretch;
-          align-items: stretch; }
-  .button-group::before, .button-group::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .button-group::after {
-    clear: both; }
-  .button-group .button {
-    margin: 0;
-    margin-left: 1px;
-    margin-bottom: 1px;
-    font-size: 0.9rem;
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto; }
-    .button-group .button:last-child {
-      margin-left: 0; }
-  .button-group.tiny .button {
-    font-size: 0.6rem; }
-  .button-group.small .button {
-    font-size: 0.75rem; }
-  .button-group.large .button {
-    font-size: 1.25rem; }
-  .button-group.expanded .button {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-  .button-group.primary .button {
-    background-color: #1779ba;
-    color: #fefefe; }
-    .button-group.primary .button:hover, .button-group.primary .button:focus {
-      background-color: #126195;
-      color: #fefefe; }
-  .button-group.secondary .button {
-    background-color: #767676;
-    color: #fefefe; }
-    .button-group.secondary .button:hover, .button-group.secondary .button:focus {
-      background-color: #5e5e5e;
-      color: #fefefe; }
-  .button-group.success .button {
-    background-color: #3adb76;
-    color: #0a0a0a; }
-    .button-group.success .button:hover, .button-group.success .button:focus {
-      background-color: #22bb5b;
-      color: #0a0a0a; }
-  .button-group.warning .button {
-    background-color: #ffae00;
-    color: #0a0a0a; }
-    .button-group.warning .button:hover, .button-group.warning .button:focus {
-      background-color: #cc8b00;
-      color: #0a0a0a; }
-  .button-group.alert .button {
-    background-color: #cc4b37;
-    color: #fefefe; }
-    .button-group.alert .button:hover, .button-group.alert .button:focus {
-      background-color: #a53b2a;
-      color: #fefefe; }
-  .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium {
-    -webkit-flex-wrap: wrap;
-        -ms-flex-wrap: wrap;
-            flex-wrap: wrap; }
-    .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {
-      -webkit-box-flex: 0;
-      -webkit-flex: 0 0 100%;
-          -ms-flex: 0 0 100%;
-              flex: 0 0 100%; }
-      .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {
-        margin-bottom: 0; }
-  @media print, screen and (min-width: 40em) {
-    .button-group.stacked-for-small .button {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      margin-bottom: 0; } }
-  @media print, screen and (min-width: 64em) {
-    .button-group.stacked-for-medium .button {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      margin-bottom: 0; } }
-  @media screen and (max-width: 39.9375em) {
-    .button-group.stacked-for-small.expanded {
-      display: block; }
-      .button-group.stacked-for-small.expanded .button {
-        display: block;
-        margin-left: 0; } }
-
-.callout {
-  position: relative;
-  margin: 0 0 1rem 0;
-  padding: 1rem;
-  border: 1px solid rgba(10, 10, 10, 0.25);
-  border-radius: 0;
-  background-color: white;
-  color: #0a0a0a; }
-  .callout > :first-child {
-    margin-top: 0; }
-  .callout > :last-child {
-    margin-bottom: 0; }
-  .callout.primary {
-    background-color: #d7ecfa;
-    color: #0a0a0a; }
-  .callout.secondary {
-    background-color: #eaeaea;
-    color: #0a0a0a; }
-  .callout.success {
-    background-color: #e1faea;
-    color: #0a0a0a; }
-  .callout.warning {
-    background-color: #fff3d9;
-    color: #0a0a0a; }
-  .callout.alert {
-    background-color: #f7e4e1;
-    color: #0a0a0a; }
-  .callout.small {
-    padding-top: 0.5rem;
-    padding-right: 0.5rem;
-    padding-bottom: 0.5rem;
-    padding-left: 0.5rem; }
-  .callout.large {
-    padding-top: 3rem;
-    padding-right: 3rem;
-    padding-bottom: 3rem;
-    padding-left: 3rem; }
-
-.card {
-  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-grow: 1;
-      -ms-flex-positive: 1;
-          flex-grow: 1;
-  margin-bottom: 1rem;
-  border: 1px solid #e6e6e6;
-  border-radius: 0;
-  background: #fefefe;
-  -webkit-box-shadow: none;
-          box-shadow: none;
-  overflow: hidden;
-  color: #0a0a0a; }
-  .card > :last-child {
-    margin-bottom: 0; }
-
-.card-divider {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 1 auto;
-      -ms-flex: 0 1 auto;
-          flex: 0 1 auto;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  padding: 1rem;
-  background: #e6e6e6; }
-  .card-divider > :last-child {
-    margin-bottom: 0; }
+          align-items: stretch;
+  width: 100vw; }
 
-.card-section {
-  -webkit-box-flex: 1;
-  -webkit-flex: 1 0 auto;
-      -ms-flex: 1 0 auto;
-          flex: 1 0 auto;
-  padding: 1rem; }
-  .card-section > :last-child {
-    margin-bottom: 0; }
+.cell .grid-frame {
+  width: 100%; }
 
-.card-image {
-  min-height: 1px; }
+.cell-block {
+  overflow-x: auto;
+  max-width: 100%;
+  -webkit-overflow-scrolling: touch;
+  -ms-overflow-style: -ms-autohiding-scrollbar; }
 
-.close-button {
-  position: absolute;
-  color: #8a8a8a;
-  cursor: pointer; }
-  [data-whatinput='mouse'] .close-button {
-    outline: 0; }
-  .close-button:hover, .close-button:focus {
-    color: #0a0a0a; }
-  .close-button.small {
-    right: 0.66rem;
-    top: 0.33em;
-    font-size: 1.5em;
-    line-height: 1; }
-  .close-button, .close-button.medium {
-    right: 1rem;
-    top: 0.5rem;
-    font-size: 2em;
-    line-height: 1; }
+.cell-block-y {
+  overflow-y: auto;
+  max-height: 100%;
+  min-height: 100%;
+  -webkit-overflow-scrolling: touch;
+  -ms-overflow-style: -ms-autohiding-scrollbar; }
 
-.menu {
-  padding: 0;
-  margin: 0;
-  list-style: none;
-  position: relative;
+.cell-block-container {
   display: -webkit-box;
   display: -webkit-flex;
   display: -ms-flexbox;
   display: flex;
-  -webkit-flex-wrap: wrap;
-      -ms-flex-wrap: wrap;
-          flex-wrap: wrap; }
-  [data-whatinput='mouse'] .menu li {
-    outline: 0; }
-  .menu a,
-  .menu .button {
-    line-height: 1;
-    text-decoration: none;
-    display: block;
-    padding: 0.7rem 1rem; }
-  .menu input,
-  .menu select,
-  .menu a,
-  .menu button {
-    margin-bottom: 0; }
-  .menu input {
-    display: inline-block; }
-  .menu, .menu.horizontal {
-    -webkit-flex-wrap: wrap;
-        -ms-flex-wrap: wrap;
-            flex-wrap: wrap;
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-direction: row;
-        -ms-flex-direction: row;
-            flex-direction: row; }
-  .menu.vertical {
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-direction: column;
+      -ms-flex-direction: column;
+          flex-direction: column;
+  max-height: 100%; }
+  .cell-block-container > .grid-x {
+    max-height: 100%;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap; }
+
+@media print, screen and (min-width: 40em) {
+  .medium-grid-frame {
+    overflow: hidden;
+    position: relative;
     -webkit-flex-wrap: nowrap;
         -ms-flex-wrap: nowrap;
             flex-wrap: nowrap;
-    -webkit-box-orient: vertical;
-    -webkit-box-direction: normal;
-    -webkit-flex-direction: column;
-        -ms-flex-direction: column;
-            flex-direction: column; }
-  .menu.expanded li {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-  .menu.simple {
-    -webkit-box-align: center;
-    -webkit-align-items: center;
-        -ms-flex-align: center;
-            align-items: center; }
-    .menu.simple li + li {
-      margin-right: 1rem; }
-    .menu.simple a {
-      padding: 0; }
-  @media print, screen and (min-width: 40em) {
-    .menu.medium-horizontal {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap;
-      -webkit-box-orient: horizontal;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: row;
-          -ms-flex-direction: row;
-              flex-direction: row; }
-    .menu.medium-vertical {
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap;
-      -webkit-box-orient: vertical;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: column;
-          -ms-flex-direction: column;
-              flex-direction: column; }
-    .menu.medium-expanded li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; }
-    .menu.medium-simple li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; } }
-  @media print, screen and (min-width: 64em) {
-    .menu.large-horizontal {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap;
-      -webkit-box-orient: horizontal;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: row;
-          -ms-flex-direction: row;
-              flex-direction: row; }
-    .menu.large-vertical {
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap;
-      -webkit-box-orient: vertical;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: column;
-          -ms-flex-direction: column;
-              flex-direction: column; }
-    .menu.large-expanded li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; }
-    .menu.large-simple li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; } }
-  .menu.nested {
-    margin-left: 0;
-    margin-right: 1rem; }
-  .menu.icons a {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex; }
-  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    width: 100vw; }
+  .cell .medium-grid-frame {
+    width: 100%; }
+  .medium-cell-block {
+    overflow-x: auto;
+    max-width: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; }
+  .medium-cell-block-container {
     display: -webkit-box;
     display: -webkit-flex;
     display: -ms-flexbox;
-    display: flex; }
-  .menu.icon-left li a {
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: row nowrap;
-        -ms-flex-flow: row nowrap;
-            flex-flow: row nowrap; }
-    .menu.icon-left li a img,
-    .menu.icon-left li a i,
-    .menu.icon-left li a svg {
-      margin-left: 0.25rem; }
-  .menu.icon-right li a {
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: row nowrap;
-        -ms-flex-flow: row nowrap;
-            flex-flow: row nowrap; }
-    .menu.icon-right li a img,
-    .menu.icon-right li a i,
-    .menu.icon-right li a svg {
-      margin-right: 0.25rem; }
-  .menu.icon-top li a {
-    -webkit-box-orient: vertical;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: column nowrap;
-        -ms-flex-flow: column nowrap;
-            flex-flow: column nowrap; }
-    .menu.icon-top li a img,
-    .menu.icon-top li a i,
-    .menu.icon-top li a svg {
-      -webkit-align-self: stretch;
-          -ms-flex-item-align: stretch;
-                  -ms-grid-row-align: stretch;
-              align-self: stretch;
-      margin-bottom: 0.25rem;
-      text-align: center; }
-  .menu.icon-bottom li a {
+    display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
-    -webkit-flex-flow: column nowrap;
-        -ms-flex-flow: column nowrap;
-            flex-flow: column nowrap; }
-    .menu.icon-bottom li a img,
-    .menu.icon-bottom li a i,
-    .menu.icon-bottom li a svg {
-      -webkit-align-self: stretch;
-          -ms-flex-item-align: stretch;
-                  -ms-grid-row-align: stretch;
-              align-self: stretch;
-      margin-bottom: 0.25rem;
-      text-align: center; }
-  .menu .is-active > a {
-    background: #1779ba;
-    color: #fefefe; }
-  .menu .active > a {
-    background: #1779ba;
-    color: #fefefe; }
-  .menu.align-right {
-    -webkit-box-pack: start;
-    -webkit-justify-content: flex-start;
-        -ms-flex-pack: start;
-            justify-content: flex-start; }
-  .menu.align-left li {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex;
-    -webkit-box-pack: end;
-    -webkit-justify-content: flex-end;
-        -ms-flex-pack: end;
-            justify-content: flex-end; }
-    .menu.align-left li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
-  .menu.align-left.vertical li {
-    display: block;
-    text-align: left; }
-    .menu.align-left.vertical li .submenu li {
-      text-align: left; }
-  .menu.align-left .nested {
-    margin-left: 1rem;
-    margin-right: 0; }
-  .menu.align-center li {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex;
-    -webkit-box-pack: center;
-    -webkit-justify-content: center;
-        -ms-flex-pack: center;
-            justify-content: center; }
-    .menu.align-center li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
-  .menu .menu-text {
-    padding: 0.7rem 1rem;
-    font-weight: bold;
-    line-height: 1;
-    color: inherit; }
+    -webkit-flex-direction: column;
+        -ms-flex-direction: column;
+            flex-direction: column;
+    max-height: 100%; }
+    .medium-cell-block-container > .grid-x {
+      max-height: 100%;
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap; }
+  .medium-cell-block-y {
+    overflow-y: auto;
+    max-height: 100%;
+    min-height: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; } }
 
-.menu-centered > .menu {
-  -webkit-box-pack: center;
-  -webkit-justify-content: center;
-      -ms-flex-pack: center;
-          justify-content: center; }
-  .menu-centered > .menu li {
+@media print, screen and (min-width: 64em) {
+  .large-grid-frame {
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    width: 100vw; }
+  .cell .large-grid-frame {
+    width: 100%; }
+  .large-cell-block {
+    overflow-x: auto;
+    max-width: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; }
+  .large-cell-block-container {
     display: -webkit-box;
     display: -webkit-flex;
     display: -ms-flexbox;
     display: flex;
-    -webkit-box-pack: center;
-    -webkit-justify-content: center;
-        -ms-flex-pack: center;
-            justify-content: center; }
-    .menu-centered > .menu li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
-
-.no-js [data-responsive-menu] ul {
-  display: none; }
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: column;
+        -ms-flex-direction: column;
+            flex-direction: column;
+    max-height: 100%; }
+    .large-cell-block-container > .grid-x {
+      max-height: 100%;
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap; }
+  .large-cell-block-y {
+    overflow-y: auto;
+    max-height: 100%;
+    min-height: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; } }
 
-.menu-icon {
+.grid-y.grid-frame {
+  width: auto;
+  overflow: hidden;
   position: relative;
-  display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer; }
-  .menu-icon::after {
-    position: absolute;
-    top: 0;
-    left: 0;
-    display: block;
-    width: 100%;
-    height: 2px;
-    background: #fefefe;
-    -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
-            box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
-    content: ''; }
-  .menu-icon:hover::after {
-    background: #cacaca;
-    -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
-            box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch;
+  height: 100vh; }
+
+@media print, screen and (min-width: 40em) {
+  .grid-y.medium-grid-frame {
+    width: auto;
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    height: 100vh; } }
+
+@media print, screen and (min-width: 64em) {
+  .grid-y.large-grid-frame {
+    width: auto;
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    height: 100vh; } }
+
+.cell .grid-y.grid-frame {
+  height: 100%; }
+
+@media print, screen and (min-width: 40em) {
+  .cell .grid-y.medium-grid-frame {
+    height: 100%; } }
+
+@media print, screen and (min-width: 64em) {
+  .cell .grid-y.large-grid-frame {
+    height: 100%; } }
+
+.grid-margin-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
+  .grid-margin-y > .cell {
+    height: calc(100% - 1.25rem);
+    margin-top: 0.625rem;
+    margin-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .cell {
+      height: calc(100% - 1.875rem);
+      margin-top: 0.9375rem;
+      margin-bottom: 0.9375rem; } }
+  .grid-margin-y > .auto {
+    height: auto; }
+  .grid-margin-y > .shrink {
+    height: auto; }
+  .grid-margin-y > .small-1 {
+    height: calc(8.33333% - 1.25rem); }
+  .grid-margin-y > .small-2 {
+    height: calc(16.66667% - 1.25rem); }
+  .grid-margin-y > .small-3 {
+    height: calc(25% - 1.25rem); }
+  .grid-margin-y > .small-4 {
+    height: calc(33.33333% - 1.25rem); }
+  .grid-margin-y > .small-5 {
+    height: calc(41.66667% - 1.25rem); }
+  .grid-margin-y > .small-6 {
+    height: calc(50% - 1.25rem); }
+  .grid-margin-y > .small-7 {
+    height: calc(58.33333% - 1.25rem); }
+  .grid-margin-y > .small-8 {
+    height: calc(66.66667% - 1.25rem); }
+  .grid-margin-y > .small-9 {
+    height: calc(75% - 1.25rem); }
+  .grid-margin-y > .small-10 {
+    height: calc(83.33333% - 1.25rem); }
+  .grid-margin-y > .small-11 {
+    height: calc(91.66667% - 1.25rem); }
+  .grid-margin-y > .small-12 {
+    height: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .auto {
+      height: auto; }
+    .grid-margin-y > .shrink {
+      height: auto; }
+    .grid-margin-y > .small-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .small-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .small-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .small-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .small-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .small-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .small-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .small-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .small-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .small-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .small-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .small-12 {
+      height: calc(100% - 1.875rem); }
+    .grid-margin-y > .medium-auto {
+      height: auto; }
+    .grid-margin-y > .medium-shrink {
+      height: auto; }
+    .grid-margin-y > .medium-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .medium-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .medium-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .medium-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .medium-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .medium-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .medium-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .medium-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .medium-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .medium-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .medium-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .medium-12 {
+      height: calc(100% - 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-margin-y > .large-auto {
+      height: auto; }
+    .grid-margin-y > .large-shrink {
+      height: auto; }
+    .grid-margin-y > .large-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .large-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .large-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .large-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .large-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .large-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .large-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .large-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .large-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .large-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .large-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .large-12 {
+      height: calc(100% - 1.875rem); } }
 
-.menu-icon.dark {
-  position: relative;
-  display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer; }
-  .menu-icon.dark::after {
-    position: absolute;
-    top: 0;
-    left: 0;
-    display: block;
-    width: 100%;
-    height: 2px;
-    background: #0a0a0a;
-    -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-            box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-    content: ''; }
-  .menu-icon.dark:hover::after {
-    background: #8a8a8a;
-    -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
-            box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }
+.grid-frame.grid-margin-y {
+  height: calc(100vh + 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-frame.grid-margin-y {
+      height: calc(100vh + 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-frame.grid-margin-y {
+      height: calc(100vh + 1.875rem); } }
 
-.is-drilldown {
-  position: relative;
-  overflow: hidden; }
-  .is-drilldown li {
-    display: block; }
-  .is-drilldown.animate-height {
-    -webkit-transition: height 0.5s;
-    transition: height 0.5s; }
+@media print, screen and (min-width: 40em) {
+  .grid-margin-y.medium-grid-frame {
+    height: calc(100vh + 1.875rem); } }
 
-.drilldown a {
-  padding: 0.7rem 1rem;
-  background: #fefefe; }
+@media print, screen and (min-width: 64em) {
+  .grid-margin-y.large-grid-frame {
+    height: calc(100vh + 1.875rem); } }
 
-.drilldown .is-drilldown-submenu {
-  position: absolute;
-  top: 0;
-  right: 100%;
-  z-index: -1;
-  width: 100%;
-  background: #fefefe;
-  -webkit-transition: -webkit-transform 0.15s linear;
-  transition: -webkit-transform 0.15s linear;
-  transition: transform 0.15s linear;
-  transition: transform 0.15s linear, -webkit-transform 0.15s linear; }
-  .drilldown .is-drilldown-submenu.is-active {
-    z-index: 1;
+.button {
+  display: inline-block;
+  vertical-align: middle;
+  margin: 0 0 1rem 0;
+  padding: 0.85em 1em;
+  border: 1px solid transparent;
+  border-radius: 0;
+  -webkit-transition: background-color 0.25s ease-out, color 0.25s ease-out;
+  transition: background-color 0.25s ease-out, color 0.25s ease-out;
+  font-family: inherit;
+  font-size: 0.9rem;
+  -webkit-appearance: none;
+  line-height: 1;
+  text-align: center;
+  cursor: pointer;
+  background-color: #1779ba;
+  color: #fefefe; }
+  [data-whatinput='mouse'] .button {
+    outline: 0; }
+  .button:hover, .button:focus {
+    background-color: #14679e;
+    color: #fefefe; }
+  .button.tiny {
+    font-size: 0.6rem; }
+  .button.small {
+    font-size: 0.75rem; }
+  .button.large {
+    font-size: 1.25rem; }
+  .button.expanded {
     display: block;
-    -webkit-transform: translateX(100%);
-        -ms-transform: translateX(100%);
-            transform: translateX(100%); }
-  .drilldown .is-drilldown-submenu.is-closing {
-    -webkit-transform: translateX(-100%);
-        -ms-transform: translateX(-100%);
-            transform: translateX(-100%); }
-  .drilldown .is-drilldown-submenu a {
-    padding: 0.7rem 1rem; }
-
-.drilldown .nested.is-drilldown-submenu {
-  margin-left: 0;
-  margin-right: 0; }
-
-.drilldown .drilldown-submenu-cover-previous {
-  min-height: 100%; }
-
-.drilldown .is-drilldown-submenu-parent > a {
-  position: relative; }
-  .drilldown .is-drilldown-submenu-parent > a::after {
-    position: absolute;
-    top: 50%;
-    margin-top: -6px;
-    left: 1rem;
+    width: 100%;
+    margin-right: 0;
+    margin-left: 0; }
+  .button.primary {
+    background-color: #1779ba;
+    color: #fefefe; }
+    .button.primary:hover, .button.primary:focus {
+      background-color: #126195;
+      color: #fefefe; }
+  .button.secondary {
+    background-color: #767676;
+    color: #fefefe; }
+    .button.secondary:hover, .button.secondary:focus {
+      background-color: #5e5e5e;
+      color: #fefefe; }
+  .button.success {
+    background-color: #3adb76;
+    color: #0a0a0a; }
+    .button.success:hover, .button.success:focus {
+      background-color: #22bb5b;
+      color: #0a0a0a; }
+  .button.warning {
+    background-color: #ffae00;
+    color: #0a0a0a; }
+    .button.warning:hover, .button.warning:focus {
+      background-color: #cc8b00;
+      color: #0a0a0a; }
+  .button.alert {
+    background-color: #cc4b37;
+    color: #fefefe; }
+    .button.alert:hover, .button.alert:focus {
+      background-color: #a53b2a;
+      color: #fefefe; }
+  .button.disabled, .button[disabled] {
+    opacity: 0.25;
+    cursor: not-allowed; }
+    .button.disabled, .button.disabled:hover, .button.disabled:focus, .button[disabled], .button[disabled]:hover, .button[disabled]:focus {
+      background-color: #1779ba;
+      color: #fefefe; }
+    .button.disabled.primary, .button[disabled].primary {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.primary, .button.disabled.primary:hover, .button.disabled.primary:focus, .button[disabled].primary, .button[disabled].primary:hover, .button[disabled].primary:focus {
+        background-color: #1779ba;
+        color: #fefefe; }
+    .button.disabled.secondary, .button[disabled].secondary {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.secondary, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary, .button[disabled].secondary:hover, .button[disabled].secondary:focus {
+        background-color: #767676;
+        color: #fefefe; }
+    .button.disabled.success, .button[disabled].success {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.success, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success, .button[disabled].success:hover, .button[disabled].success:focus {
+        background-color: #3adb76;
+        color: #0a0a0a; }
+    .button.disabled.warning, .button[disabled].warning {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.warning, .button.disabled.warning:hover, .button.disabled.warning:focus, .button[disabled].warning, .button[disabled].warning:hover, .button[disabled].warning:focus {
+        background-color: #ffae00;
+        color: #0a0a0a; }
+    .button.disabled.alert, .button[disabled].alert {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.alert, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert, .button[disabled].alert:hover, .button[disabled].alert:focus {
+        background-color: #cc4b37;
+        color: #fefefe; }
+  .button.hollow {
+    border: 1px solid #1779ba;
+    color: #1779ba; }
+    .button.hollow, .button.hollow:hover, .button.hollow:focus {
+      background-color: transparent; }
+    .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {
+      background-color: transparent; }
+    .button.hollow:hover, .button.hollow:focus {
+      border-color: #0c3d5d;
+      color: #0c3d5d; }
+      .button.hollow:hover.disabled, .button.hollow:hover[disabled], .button.hollow:focus.disabled, .button.hollow:focus[disabled] {
+        border: 1px solid #1779ba;
+        color: #1779ba; }
+    .button.hollow.primary {
+      border: 1px solid #1779ba;
+      color: #1779ba; }
+      .button.hollow.primary:hover, .button.hollow.primary:focus {
+        border-color: #0c3d5d;
+        color: #0c3d5d; }
+        .button.hollow.primary:hover.disabled, .button.hollow.primary:hover[disabled], .button.hollow.primary:focus.disabled, .button.hollow.primary:focus[disabled] {
+          border: 1px solid #1779ba;
+          color: #1779ba; }
+    .button.hollow.secondary {
+      border: 1px solid #767676;
+      color: #767676; }
+      .button.hollow.secondary:hover, .button.hollow.secondary:focus {
+        border-color: #3b3b3b;
+        color: #3b3b3b; }
+        .button.hollow.secondary:hover.disabled, .button.hollow.secondary:hover[disabled], .button.hollow.secondary:focus.disabled, .button.hollow.secondary:focus[disabled] {
+          border: 1px solid #767676;
+          color: #767676; }
+    .button.hollow.success {
+      border: 1px solid #3adb76;
+      color: #3adb76; }
+      .button.hollow.success:hover, .button.hollow.success:focus {
+        border-color: #157539;
+        color: #157539; }
+        .button.hollow.success:hover.disabled, .button.hollow.success:hover[disabled], .button.hollow.success:focus.disabled, .button.hollow.success:focus[disabled] {
+          border: 1px solid #3adb76;
+          color: #3adb76; }
+    .button.hollow.warning {
+      border: 1px solid #ffae00;
+      color: #ffae00; }
+      .button.hollow.warning:hover, .button.hollow.warning:focus {
+        border-color: #805700;
+        color: #805700; }
+        .button.hollow.warning:hover.disabled, .button.hollow.warning:hover[disabled], .button.hollow.warning:focus.disabled, .button.hollow.warning:focus[disabled] {
+          border: 1px solid #ffae00;
+          color: #ffae00; }
+    .button.hollow.alert {
+      border: 1px solid #cc4b37;
+      color: #cc4b37; }
+      .button.hollow.alert:hover, .button.hollow.alert:focus {
+        border-color: #67251a;
+        color: #67251a; }
+        .button.hollow.alert:hover.disabled, .button.hollow.alert:hover[disabled], .button.hollow.alert:focus.disabled, .button.hollow.alert:focus[disabled] {
+          border: 1px solid #cc4b37;
+          color: #cc4b37; }
+  .button.clear {
+    border: 1px solid #1779ba;
+    color: #1779ba; }
+    .button.clear, .button.clear:hover, .button.clear:focus {
+      background-color: transparent; }
+    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {
+      background-color: transparent; }
+    .button.clear:hover, .button.clear:focus {
+      border-color: #0c3d5d;
+      color: #0c3d5d; }
+      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {
+        border: 1px solid #1779ba;
+        color: #1779ba; }
+    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {
+      border-color: transparent; }
+    .button.clear.primary {
+      border: 1px solid #1779ba;
+      color: #1779ba; }
+      .button.clear.primary:hover, .button.clear.primary:focus {
+        border-color: #0c3d5d;
+        color: #0c3d5d; }
+        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
+          border: 1px solid #1779ba;
+          color: #1779ba; }
+      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.secondary {
+      border: 1px solid #767676;
+      color: #767676; }
+      .button.clear.secondary:hover, .button.clear.secondary:focus {
+        border-color: #3b3b3b;
+        color: #3b3b3b; }
+        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
+          border: 1px solid #767676;
+          color: #767676; }
+      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.success {
+      border: 1px solid #3adb76;
+      color: #3adb76; }
+      .button.clear.success:hover, .button.clear.success:focus {
+        border-color: #157539;
+        color: #157539; }
+        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
+          border: 1px solid #3adb76;
+          color: #3adb76; }
+      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.warning {
+      border: 1px solid #ffae00;
+      color: #ffae00; }
+      .button.clear.warning:hover, .button.clear.warning:focus {
+        border-color: #805700;
+        color: #805700; }
+        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
+          border: 1px solid #ffae00;
+          color: #ffae00; }
+      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.alert {
+      border: 1px solid #cc4b37;
+      color: #cc4b37; }
+      .button.clear.alert:hover, .button.clear.alert:focus {
+        border-color: #67251a;
+        color: #67251a; }
+        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
+          border: 1px solid #cc4b37;
+          color: #cc4b37; }
+      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
+        border-color: transparent; }
+  .button.dropdown::after {
     display: block;
     width: 0;
     height: 0;
-    border: inset 6px;
+    border: inset 0.4em;
     content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-
-.drilldown.align-left .is-drilldown-submenu-parent > a::after {
-  left: auto;
-  right: 1rem;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba; }
-
-.drilldown.align-right .is-drilldown-submenu-parent > a::after {
-  right: auto;
-  left: 1rem;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent; }
-
-.drilldown .js-drilldown-back > a::before {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba;
-  border-right-width: 0;
-  display: inline-block;
-  vertical-align: middle;
-  margin-left: 0.75rem;
-  border-right-width: 0; }
-
-.dropdown-pane {
-  position: absolute;
-  z-index: 10;
-  width: 300px;
-  padding: 1rem;
-  visibility: hidden;
-  display: none;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  font-size: 1rem; }
-  .dropdown-pane.is-opening {
-    display: block; }
-  .dropdown-pane.is-open {
-    visibility: visible;
-    display: block; }
-
-.dropdown-pane.tiny {
-  width: 100px; }
-
-.dropdown-pane.small {
-  width: 200px; }
-
-.dropdown-pane.large {
-  width: 400px; }
-
-.dropdown.menu > li.opens-left > .is-dropdown-submenu {
-  top: 100%;
-  right: 0;
-  left: auto; }
-
-.dropdown.menu > li.opens-right > .is-dropdown-submenu {
-  top: 100%;
-  right: auto;
-  left: 0; }
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #fefefe transparent transparent;
+    position: relative;
+    top: 0.4em;
+    display: inline-block;
+    float: left;
+    margin-right: 1em; }
+  .button.dropdown.hollow::after, .button.dropdown.clear::after {
+    border-top-color: #1779ba; }
+  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {
+    border-top-color: #1779ba; }
+  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {
+    border-top-color: #767676; }
+  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {
+    border-top-color: #3adb76; }
+  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {
+    border-top-color: #ffae00; }
+  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {
+    border-top-color: #cc4b37; }
+  .button.arrow-only::after {
+    top: -0.1em;
+    float: none;
+    margin-right: 0; }
 
-.dropdown.menu > li.is-dropdown-submenu-parent > a {
-  position: relative;
-  padding-left: 1.5rem; }
+a.button:hover, a.button:focus {
+  text-decoration: none; }
 
-.dropdown.menu > li.is-dropdown-submenu-parent > a::after {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-bottom-width: 0;
-  border-top-style: solid;
-  border-color: #1779ba transparent transparent;
-  left: 5px;
-  right: auto;
-  margin-top: -3px; }
+.button-group {
+  margin-bottom: 1rem;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch; }
+  .button-group::before, .button-group::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .button-group::after {
+    clear: both; }
+  .button-group .button {
+    margin: 0;
+    margin-left: 1px;
+    margin-bottom: 1px;
+    font-size: 0.9rem;
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+    .button-group .button:last-child {
+      margin-left: 0; }
+  .button-group.tiny .button {
+    font-size: 0.6rem; }
+  .button-group.small .button {
+    font-size: 0.75rem; }
+  .button-group.large .button {
+    font-size: 1.25rem; }
+  .button-group.expanded .button {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
+  .button-group.primary .button {
+    background-color: #1779ba;
+    color: #fefefe; }
+    .button-group.primary .button:hover, .button-group.primary .button:focus {
+      background-color: #126195;
+      color: #fefefe; }
+  .button-group.secondary .button {
+    background-color: #767676;
+    color: #fefefe; }
+    .button-group.secondary .button:hover, .button-group.secondary .button:focus {
+      background-color: #5e5e5e;
+      color: #fefefe; }
+  .button-group.success .button {
+    background-color: #3adb76;
+    color: #0a0a0a; }
+    .button-group.success .button:hover, .button-group.success .button:focus {
+      background-color: #22bb5b;
+      color: #0a0a0a; }
+  .button-group.warning .button {
+    background-color: #ffae00;
+    color: #0a0a0a; }
+    .button-group.warning .button:hover, .button-group.warning .button:focus {
+      background-color: #cc8b00;
+      color: #0a0a0a; }
+  .button-group.alert .button {
+    background-color: #cc4b37;
+    color: #fefefe; }
+    .button-group.alert .button:hover, .button-group.alert .button:focus {
+      background-color: #a53b2a;
+      color: #fefefe; }
+  .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium {
+    -webkit-flex-wrap: wrap;
+        -ms-flex-wrap: wrap;
+            flex-wrap: wrap; }
+    .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 100%;
+          -ms-flex: 0 0 100%;
+              flex: 0 0 100%; }
+      .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {
+        margin-bottom: 0; }
+    .button-group.stacked.expanded .button, .button-group.stacked-for-small.expanded .button, .button-group.stacked-for-medium.expanded .button {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; }
+  @media print, screen and (min-width: 40em) {
+    .button-group.stacked-for-small .button {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto;
+      margin-bottom: 0; } }
+  @media print, screen and (min-width: 64em) {
+    .button-group.stacked-for-medium .button {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto;
+      margin-bottom: 0; } }
+  @media screen and (max-width: 39.99875em) {
+    .button-group.stacked-for-small.expanded {
+      display: block; }
+      .button-group.stacked-for-small.expanded .button {
+        display: block;
+        margin-left: 0; } }
+  @media screen and (max-width: 63.99875em) {
+    .button-group.stacked-for-medium.expanded {
+      display: block; }
+      .button-group.stacked-for-medium.expanded .button {
+        display: block;
+        margin-left: 0; } }
 
-.dropdown.menu a {
-  padding: 0.7rem 1rem; }
-  [data-whatinput='mouse'] .dropdown.menu a {
+.close-button {
+  position: absolute;
+  color: #8a8a8a;
+  cursor: pointer; }
+  [data-whatinput='mouse'] .close-button {
     outline: 0; }
+  .close-button:hover, .close-button:focus {
+    color: #0a0a0a; }
+  .close-button.small {
+    right: 0.66rem;
+    top: 0.33em;
+    font-size: 1.5em;
+    line-height: 1; }
+  .close-button, .close-button.medium {
+    right: 1rem;
+    top: 0.5rem;
+    font-size: 2em;
+    line-height: 1; }
 
-.dropdown.menu .is-active > a {
-  background: transparent;
-  color: #1779ba; }
-
-.no-js .dropdown.menu ul {
-  display: none; }
-
-.dropdown.menu .nested.is-dropdown-submenu {
-  margin-left: 0;
-  margin-right: 0; }
-
-.dropdown.menu.vertical > li .is-dropdown-submenu {
-  top: 0; }
-
-.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {
-  right: 100%;
-  left: auto;
-  top: 0; }
-
-.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {
-  right: auto;
-  left: 100%; }
-
-.dropdown.menu.vertical > li > a::after {
-  left: 14px; }
+.label {
+  display: inline-block;
+  padding: 0.33333rem 0.5rem;
+  border-radius: 0;
+  font-size: 0.8rem;
+  line-height: 1;
+  white-space: nowrap;
+  cursor: default;
+  background: #1779ba;
+  color: #fefefe; }
+  .label.primary {
+    background: #1779ba;
+    color: #fefefe; }
+  .label.secondary {
+    background: #767676;
+    color: #fefefe; }
+  .label.success {
+    background: #3adb76;
+    color: #0a0a0a; }
+  .label.warning {
+    background: #ffae00;
+    color: #0a0a0a; }
+  .label.alert {
+    background: #cc4b37;
+    color: #fefefe; }
 
-.dropdown.menu.vertical > li.opens-left > a::after {
-  right: auto;
-  left: 5px;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent; }
+.progress {
+  height: 1rem;
+  margin-bottom: 1rem;
+  border-radius: 0;
+  background-color: #cacaca; }
+  .progress.primary .progress-meter {
+    background-color: #1779ba; }
+  .progress.secondary .progress-meter {
+    background-color: #767676; }
+  .progress.success .progress-meter {
+    background-color: #3adb76; }
+  .progress.warning .progress-meter {
+    background-color: #ffae00; }
+  .progress.alert .progress-meter {
+    background-color: #cc4b37; }
 
-.dropdown.menu.vertical > li.opens-right > a::after {
+.progress-meter {
+  position: relative;
   display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba; }
+  width: 0%;
+  height: 100%;
+  background-color: #1779ba; }
 
-@media print, screen and (min-width: 40em) {
-  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {
-    top: 100%;
-    right: 0;
-    left: auto; }
-  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
-    top: 100%;
-    right: auto;
-    left: 0; }
-  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {
-    position: relative;
-    padding-left: 1.5rem; }
-  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    left: 5px;
-    right: auto;
-    margin-top: -3px; }
-  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {
-    top: 0; }
-  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto;
-    top: 0; }
-  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
-  .dropdown.menu.medium-vertical > li > a::after {
-    left: 14px; }
-  .dropdown.menu.medium-vertical > li.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .dropdown.menu.medium-vertical > li.opens-right > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; } }
+.progress-meter-text {
+  position: absolute;
+  top: 50%;
+  left: 50%;
+  -webkit-transform: translate(-50%, -50%);
+      -ms-transform: translate(-50%, -50%);
+          transform: translate(-50%, -50%);
+  margin: 0;
+  font-size: 0.75rem;
+  font-weight: bold;
+  color: #fefefe;
+  white-space: nowrap; }
 
-@media print, screen and (min-width: 64em) {
-  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {
-    top: 100%;
-    right: 0;
-    left: auto; }
-  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {
-    top: 100%;
-    right: auto;
-    left: 0; }
-  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {
-    position: relative;
-    padding-left: 1.5rem; }
-  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    left: 5px;
-    right: auto;
-    margin-top: -3px; }
-  .dropdown.menu.large-vertical > li .is-dropdown-submenu {
-    top: 0; }
-  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto;
-    top: 0; }
-  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
-  .dropdown.menu.large-vertical > li > a::after {
-    left: 14px; }
-  .dropdown.menu.large-vertical > li.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .dropdown.menu.large-vertical > li.opens-right > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; } }
+.slider {
+  position: relative;
+  height: 0.5rem;
+  margin-top: 1.25rem;
+  margin-bottom: 2.25rem;
+  background-color: #e6e6e6;
+  cursor: pointer;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+  -ms-touch-action: none;
+      touch-action: none; }
 
-.dropdown.menu.align-right .is-dropdown-submenu.first-sub {
-  top: 100%;
-  right: 0;
-  left: auto; }
+.slider-fill {
+  position: absolute;
+  top: 0;
+  left: 0;
+  display: inline-block;
+  max-width: 100%;
+  height: 0.5rem;
+  background-color: #cacaca;
+  -webkit-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out; }
+  .slider-fill.is-dragging {
+    -webkit-transition: all 0s linear;
+    transition: all 0s linear; }
 
-.is-dropdown-menu.vertical {
-  width: 100px; }
-  .is-dropdown-menu.vertical.align-right {
-    float: right; }
+.slider-handle {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%);
+  left: 0;
+  z-index: 1;
+  display: inline-block;
+  width: 1.4rem;
+  height: 1.4rem;
+  border-radius: 0;
+  background-color: #1779ba;
+  -webkit-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out;
+  -ms-touch-action: manipulation;
+      touch-action: manipulation; }
+  [data-whatinput='mouse'] .slider-handle {
+    outline: 0; }
+  .slider-handle:hover {
+    background-color: #14679e; }
+  .slider-handle.is-dragging {
+    -webkit-transition: all 0s linear;
+    transition: all 0s linear; }
 
-.is-dropdown-submenu-parent {
-  position: relative; }
-  .is-dropdown-submenu-parent a::after {
+.slider.disabled,
+.slider[disabled] {
+  opacity: 0.25;
+  cursor: not-allowed; }
+
+.slider.vertical {
+  display: inline-block;
+  width: 0.5rem;
+  height: 12.5rem;
+  margin: 0 1.25rem;
+  -webkit-transform: scale(1, -1);
+      -ms-transform: scale(1, -1);
+          transform: scale(1, -1); }
+  .slider.vertical .slider-fill {
+    top: 0;
+    width: 0.5rem;
+    max-height: 100%; }
+  .slider.vertical .slider-handle {
     position: absolute;
-    top: 50%;
-    left: 5px;
-    right: auto;
-    margin-top: -6px; }
-  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {
-    top: 100%;
-    right: auto; }
-  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto; }
-  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
+    top: 0;
+    left: 50%;
+    width: 1.4rem;
+    height: 1.4rem;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
 
-.is-dropdown-submenu {
+.slider:not(.vertical) {
+  -webkit-transform: scale(-1, 1);
+      -ms-transform: scale(-1, 1);
+          transform: scale(-1, 1); }
+
+.switch {
+  height: 2rem;
+  position: relative;
+  margin-bottom: 1rem;
+  outline: 0;
+  font-size: 0.875rem;
+  font-weight: bold;
+  color: #fefefe;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none; }
+
+.switch-input {
   position: absolute;
-  top: 0;
-  right: 100%;
-  z-index: 1;
-  display: none;
-  min-width: 200px;
-  border: 1px solid #cacaca;
-  background: #fefefe; }
-  .dropdown .is-dropdown-submenu a {
-    padding: 0.7rem 1rem; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {
-    left: 14px; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {
+  margin-bottom: 0;
+  opacity: 0; }
+
+.switch-paddle {
+  position: relative;
+  display: block;
+  width: 4rem;
+  height: 2rem;
+  border-radius: 0;
+  background: #cacaca;
+  -webkit-transition: all 0.25s ease-out;
+  transition: all 0.25s ease-out;
+  font-weight: inherit;
+  color: inherit;
+  cursor: pointer; }
+  input + .switch-paddle {
+    margin: 0; }
+  .switch-paddle::after {
+    position: absolute;
+    top: 0.25rem;
+    right: 0.25rem;
     display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; }
-  .is-dropdown-submenu .is-dropdown-submenu {
-    margin-top: -1px; }
-  .is-dropdown-submenu > li {
-    width: 100%; }
-  .is-dropdown-submenu.js-dropdown-active {
+    width: 1.5rem;
+    height: 1.5rem;
+    -webkit-transform: translate3d(0, 0, 0);
+            transform: translate3d(0, 0, 0);
+    border-radius: 0;
+    background: #fefefe;
+    -webkit-transition: all 0.25s ease-out;
+    transition: all 0.25s ease-out;
+    content: ''; }
+  input:checked ~ .switch-paddle {
+    background: #1779ba; }
+    input:checked ~ .switch-paddle::after {
+      right: 2.25rem; }
+  [data-whatinput='mouse'] input:focus ~ .switch-paddle {
+    outline: 0; }
+
+.switch-active, .switch-inactive {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%); }
+
+.switch-active {
+  right: 8%;
+  display: none; }
+  input:checked + label > .switch-active {
+    display: block; }
+
+.switch-inactive {
+  left: 15%; }
+  input:checked + label > .switch-inactive {
+    display: none; }
+
+.switch.tiny {
+  height: 1.5rem; }
+  .switch.tiny .switch-paddle {
+    width: 3rem;
+    height: 1.5rem;
+    font-size: 0.625rem; }
+  .switch.tiny .switch-paddle::after {
+    top: 0.25rem;
+    right: 0.25rem;
+    width: 1rem;
+    height: 1rem; }
+  .switch.tiny input:checked ~ .switch-paddle::after {
+    right: 1.75rem; }
+
+.switch.small {
+  height: 1.75rem; }
+  .switch.small .switch-paddle {
+    width: 3.5rem;
+    height: 1.75rem;
+    font-size: 0.75rem; }
+  .switch.small .switch-paddle::after {
+    top: 0.25rem;
+    right: 0.25rem;
+    width: 1.25rem;
+    height: 1.25rem; }
+  .switch.small input:checked ~ .switch-paddle::after {
+    right: 2rem; }
+
+.switch.large {
+  height: 2.5rem; }
+  .switch.large .switch-paddle {
+    width: 5rem;
+    height: 2.5rem;
+    font-size: 1rem; }
+  .switch.large .switch-paddle::after {
+    top: 0.25rem;
+    right: 0.25rem;
+    width: 2rem;
+    height: 2rem; }
+  .switch.large input:checked ~ .switch-paddle::after {
+    right: 2.75rem; }
+
+table {
+  border-collapse: collapse;
+  width: 100%;
+  margin-bottom: 1rem;
+  border-radius: 0; }
+  thead,
+  tbody,
+  tfoot {
+    border: 1px solid #f1f1f1;
+    background-color: #fefefe; }
+  caption {
+    padding: 0.5rem 0.625rem 0.625rem;
+    font-weight: bold; }
+  thead {
+    background: #f8f8f8;
+    color: #0a0a0a; }
+  tfoot {
+    background: #f1f1f1;
+    color: #0a0a0a; }
+  thead tr,
+  tfoot tr {
+    background: transparent; }
+  thead th,
+  thead td,
+  tfoot th,
+  tfoot td {
+    padding: 0.5rem 0.625rem 0.625rem;
+    font-weight: bold;
+    text-align: right; }
+  tbody th,
+  tbody td {
+    padding: 0.5rem 0.625rem 0.625rem; }
+  tbody tr:nth-child(even) {
+    border-bottom: 0;
+    background-color: #f1f1f1; }
+  table.unstriped tbody {
+    background-color: #fefefe; }
+    table.unstriped tbody tr {
+      border-bottom: 0;
+      border-bottom: 1px solid #f1f1f1;
+      background-color: #fefefe; }
+
+@media screen and (max-width: 63.99875em) {
+  table.stack thead {
+    display: none; }
+  table.stack tfoot {
+    display: none; }
+  table.stack tr,
+  table.stack th,
+  table.stack td {
     display: block; }
+  table.stack td {
+    border-top: 0; } }
 
-.responsive-embed,
-.flex-video {
-  position: relative;
-  height: 0;
-  margin-bottom: 1rem;
-  padding-bottom: 75%;
-  overflow: hidden; }
-  .responsive-embed iframe,
-  .responsive-embed object,
-  .responsive-embed embed,
-  .responsive-embed video,
-  .flex-video iframe,
-  .flex-video object,
-  .flex-video embed,
-  .flex-video video {
-    position: absolute;
-    top: 0;
-    right: 0;
-    width: 100%;
-    height: 100%; }
-  .responsive-embed.widescreen,
-  .flex-video.widescreen {
-    padding-bottom: 56.25%; }
+table.scroll {
+  display: block;
+  width: 100%;
+  overflow-x: auto; }
 
-.label {
+table.hover thead tr:hover {
+  background-color: #f3f3f3; }
+
+table.hover tfoot tr:hover {
+  background-color: #ececec; }
+
+table.hover tbody tr:hover {
+  background-color: #f9f9f9; }
+
+table.hover:not(.unstriped) tr:nth-of-type(even):hover {
+  background-color: #ececec; }
+
+.table-scroll {
+  overflow-x: auto; }
+
+.badge {
   display: inline-block;
-  padding: 0.33333rem 0.5rem;
-  border-radius: 0;
-  font-size: 0.8rem;
-  line-height: 1;
-  white-space: nowrap;
-  cursor: default;
+  min-width: 2.1em;
+  padding: 0.3em;
+  border-radius: 50%;
+  font-size: 0.6rem;
+  text-align: center;
   background: #1779ba;
   color: #fefefe; }
-  .label.primary {
+  .badge.primary {
     background: #1779ba;
     color: #fefefe; }
-  .label.secondary {
+  .badge.secondary {
     background: #767676;
     color: #fefefe; }
-  .label.success {
+  .badge.success {
     background: #3adb76;
     color: #0a0a0a; }
-  .label.warning {
+  .badge.warning {
     background: #ffae00;
     color: #0a0a0a; }
-  .label.alert {
+  .badge.alert {
     background: #cc4b37;
     color: #fefefe; }
 
-.media-object {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  margin-bottom: 1rem;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap; }
-  .media-object img {
-    max-width: none; }
-  @media screen and (max-width: 39.9375em) {
-    .media-object.stack-for-small {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap; } }
-  @media screen and (max-width: 39.9375em) {
-    .media-object.stack-for-small .media-object-section {
-      padding: 0;
-      padding-bottom: 1rem;
-      -webkit-flex-basis: 100%;
-          -ms-flex-preferred-size: 100%;
-              flex-basis: 100%;
-      max-width: 100%; }
-      .media-object.stack-for-small .media-object-section img {
-        width: 100%; } }
-
-.media-object-section {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 1 auto;
-      -ms-flex: 0 1 auto;
-          flex: 0 1 auto; }
-  .media-object-section:first-child {
-    padding-left: 1rem; }
-  .media-object-section:last-child:not(:nth-child(2)) {
-    padding-right: 1rem; }
-  .media-object-section > :last-child {
-    margin-bottom: 0; }
-  .media-object-section.main-section {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-
-.is-off-canvas-open {
-  overflow: hidden; }
-
-.js-off-canvas-overlay {
-  position: absolute;
-  top: 0;
-  left: 0;
-  z-index: 11;
-  width: 100%;
-  height: 100%;
-  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
-  transition: opacity 0.5s ease, visibility 0.5s ease;
-  background: rgba(254, 254, 254, 0.25);
-  opacity: 0;
-  visibility: hidden;
-  overflow: hidden; }
-  .js-off-canvas-overlay.is-visible {
-    opacity: 1;
-    visibility: visible; }
-  .js-off-canvas-overlay.is-closable {
-    cursor: pointer; }
-  .js-off-canvas-overlay.is-overlay-absolute {
-    position: absolute; }
-  .js-off-canvas-overlay.is-overlay-fixed {
-    position: fixed; }
-
-.off-canvas-wrapper {
-  position: relative;
-  overflow: hidden; }
-
-.off-canvas {
-  position: fixed;
-  z-index: 12;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  background: #e6e6e6; }
-  [data-whatinput='mouse'] .off-canvas {
-    outline: 0; }
-  .off-canvas.is-transition-push {
-    z-index: 12; }
-  .off-canvas.is-closed {
-    visibility: hidden; }
-  .off-canvas.is-transition-overlap {
-    z-index: 13; }
-    .off-canvas.is-transition-overlap.is-open {
-      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
-              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
-  .off-canvas.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
-
-.off-canvas-absolute {
-  position: absolute;
-  z-index: 12;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  background: #e6e6e6; }
-  [data-whatinput='mouse'] .off-canvas-absolute {
-    outline: 0; }
-  .off-canvas-absolute.is-transition-push {
-    z-index: 12; }
-  .off-canvas-absolute.is-closed {
-    visibility: hidden; }
-  .off-canvas-absolute.is-transition-overlap {
-    z-index: 13; }
-    .off-canvas-absolute.is-transition-overlap.is-open {
-      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
-              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
-  .off-canvas-absolute.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
-
-.position-left {
-  top: 0;
-  left: 0;
-  height: 100%;
-  overflow-y: auto;
-  width: 250px;
-  -webkit-transform: translateX(-250px);
-      -ms-transform: translateX(-250px);
-          transform: translateX(-250px); }
-  .off-canvas-content .off-canvas.position-left {
-    -webkit-transform: translateX(-250px);
-        -ms-transform: translateX(-250px);
-            transform: translateX(-250px); }
-    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-left.has-transition-push {
-    -webkit-transform: translateX(250px);
-        -ms-transform: translateX(250px);
-            transform: translateX(250px); }
-  .position-left.is-transition-push {
-    -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }
+.breadcrumbs {
+  margin: 0 0 1rem 0;
+  list-style: none; }
+  .breadcrumbs::before, .breadcrumbs::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .breadcrumbs::after {
+    clear: both; }
+  .breadcrumbs li {
+    float: right;
+    font-size: 0.6875rem;
+    color: #0a0a0a;
+    cursor: default;
+    text-transform: uppercase; }
+    .breadcrumbs li:not(:last-child)::after {
+      position: relative;
+      margin: 0 0.75rem;
+      opacity: 1;
+      content: "\\";
+      color: #cacaca; }
+  .breadcrumbs a {
+    color: #1779ba; }
+    .breadcrumbs a:hover {
+      text-decoration: underline; }
+  .breadcrumbs .disabled {
+    color: #cacaca;
+    cursor: not-allowed; }
 
-.position-right {
-  top: 0;
-  right: 0;
-  height: 100%;
-  overflow-y: auto;
-  width: 250px;
-  -webkit-transform: translateX(250px);
-      -ms-transform: translateX(250px);
-          transform: translateX(250px); }
-  .off-canvas-content .off-canvas.position-right {
-    -webkit-transform: translateX(250px);
-        -ms-transform: translateX(250px);
-            transform: translateX(250px); }
-    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-right.has-transition-push {
-    -webkit-transform: translateX(-250px);
-        -ms-transform: translateX(-250px);
-            transform: translateX(-250px); }
-  .position-right.is-transition-push {
-    -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }
+.callout {
+  position: relative;
+  margin: 0 0 1rem 0;
+  padding: 1rem;
+  border: 1px solid rgba(10, 10, 10, 0.25);
+  border-radius: 0;
+  background-color: white;
+  color: #0a0a0a; }
+  .callout > :first-child {
+    margin-top: 0; }
+  .callout > :last-child {
+    margin-bottom: 0; }
+  .callout.primary {
+    background-color: #d7ecfa;
+    color: #0a0a0a; }
+  .callout.secondary {
+    background-color: #eaeaea;
+    color: #0a0a0a; }
+  .callout.success {
+    background-color: #e1faea;
+    color: #0a0a0a; }
+  .callout.warning {
+    background-color: #fff3d9;
+    color: #0a0a0a; }
+  .callout.alert {
+    background-color: #f7e4e1;
+    color: #0a0a0a; }
+  .callout.small {
+    padding-top: 0.5rem;
+    padding-right: 0.5rem;
+    padding-bottom: 0.5rem;
+    padding-left: 0.5rem; }
+  .callout.large {
+    padding-top: 3rem;
+    padding-right: 3rem;
+    padding-bottom: 3rem;
+    padding-left: 3rem; }
 
-.position-top {
-  top: 0;
-  left: 0;
-  width: 100%;
-  overflow-x: auto;
-  height: 250px;
-  -webkit-transform: translateY(-250px);
-      -ms-transform: translateY(-250px);
-          transform: translateY(-250px); }
-  .off-canvas-content .off-canvas.position-top {
-    -webkit-transform: translateY(-250px);
-        -ms-transform: translateY(-250px);
-            transform: translateY(-250px); }
-    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-top.has-transition-push {
-    -webkit-transform: translateY(250px);
-        -ms-transform: translateY(250px);
-            transform: translateY(250px); }
-  .position-top.is-transition-push {
-    -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }
+.card {
+  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-grow: 1;
+      -ms-flex-positive: 1;
+          flex-grow: 1;
+  margin-bottom: 1rem;
+  border: 1px solid #e6e6e6;
+  border-radius: 0;
+  background: #fefefe;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  overflow: hidden;
+  color: #0a0a0a; }
+  .card > :last-child {
+    margin-bottom: 0; }
 
-.position-bottom {
-  bottom: 0;
-  left: 0;
-  width: 100%;
-  overflow-x: auto;
-  height: 250px;
-  -webkit-transform: translateY(250px);
-      -ms-transform: translateY(250px);
-          transform: translateY(250px); }
-  .off-canvas-content .off-canvas.position-bottom {
-    -webkit-transform: translateY(250px);
-        -ms-transform: translateY(250px);
-            transform: translateY(250px); }
-    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-bottom.has-transition-push {
-    -webkit-transform: translateY(-250px);
-        -ms-transform: translateY(-250px);
-            transform: translateY(-250px); }
-  .position-bottom.is-transition-push {
-    -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }
+.card-divider {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 1 auto;
+      -ms-flex: 0 1 auto;
+          flex: 0 1 auto;
+  padding: 1rem;
+  background: #e6e6e6; }
+  .card-divider > :last-child {
+    margin-bottom: 0; }
 
-.off-canvas-content {
-  -webkit-transform: none;
-      -ms-transform: none;
-          transform: none;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden; }
-  .off-canvas-content.has-transition-push {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
-  .off-canvas-content .off-canvas.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
+.card-section {
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 0 auto;
+      -ms-flex: 1 0 auto;
+          flex: 1 0 auto;
+  padding: 1rem; }
+  .card-section > :last-child {
+    margin-bottom: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .position-left.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-left.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-left.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-left {
-      margin-left: 250px; }
-    .position-left.reveal-for-medium ~ .off-canvas-content {
-      margin-left: 250px; }
-  .position-right.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-right.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-right.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-right {
-      margin-right: 250px; }
-    .position-right.reveal-for-medium ~ .off-canvas-content {
-      margin-right: 250px; }
-  .position-top.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-top.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-top.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-top {
-      margin-top: 250px; }
-    .position-top.reveal-for-medium ~ .off-canvas-content {
-      margin-top: 250px; }
-  .position-bottom.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-bottom.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-bottom.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-bottom {
-      margin-bottom: 250px; }
-    .position-bottom.reveal-for-medium ~ .off-canvas-content {
-      margin-bottom: 250px; } }
+.card-image {
+  min-height: 1px; }
 
-@media print, screen and (min-width: 64em) {
-  .position-left.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-left.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-left.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-left {
-      margin-left: 250px; }
-    .position-left.reveal-for-large ~ .off-canvas-content {
-      margin-left: 250px; }
-  .position-right.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-right.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-right.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-right {
-      margin-right: 250px; }
-    .position-right.reveal-for-large ~ .off-canvas-content {
-      margin-right: 250px; }
-  .position-top.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-top.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-top.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-top {
-      margin-top: 250px; }
-    .position-top.reveal-for-large ~ .off-canvas-content {
-      margin-top: 250px; }
-  .position-bottom.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
+.dropdown-pane {
+  position: absolute;
+  z-index: 10;
+  display: none;
+  width: 300px;
+  padding: 1rem;
+  visibility: hidden;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  font-size: 1rem; }
+  .dropdown-pane.is-opening {
+    display: block; }
+  .dropdown-pane.is-open {
+    display: block;
     visibility: visible; }
-    .position-bottom.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-bottom.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-bottom {
-      margin-bottom: 250px; }
-    .position-bottom.reveal-for-large ~ .off-canvas-content {
-      margin-bottom: 250px; } }
 
-@media print, screen and (min-width: 40em) {
-  .off-canvas.in-canvas-for-medium {
-    visibility: visible;
-    height: auto;
-    position: static;
-    background: inherit;
-    width: inherit;
-    overflow: inherit;
-    -webkit-transition: inherit;
-    transition: inherit; }
-    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {
-      -webkit-box-shadow: none;
-              box-shadow: none;
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas.in-canvas-for-medium .close-button {
-      display: none; } }
+.dropdown-pane.tiny {
+  width: 100px; }
+
+.dropdown-pane.small {
+  width: 200px; }
+
+.dropdown-pane.large {
+  width: 400px; }
+
+.pagination {
+  margin-right: 0;
+  margin-bottom: 1rem; }
+  .pagination::before, .pagination::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .pagination::after {
+    clear: both; }
+  .pagination li {
+    margin-left: 0.0625rem;
+    border-radius: 0;
+    font-size: 0.875rem;
+    display: none; }
+    .pagination li:last-child, .pagination li:first-child {
+      display: inline-block; }
+    @media print, screen and (min-width: 40em) {
+      .pagination li {
+        display: inline-block; } }
+  .pagination a,
+  .pagination button {
+    display: block;
+    padding: 0.1875rem 0.625rem;
+    border-radius: 0;
+    color: #0a0a0a; }
+    .pagination a:hover,
+    .pagination button:hover {
+      background: #e6e6e6; }
+  .pagination .current {
+    padding: 0.1875rem 0.625rem;
+    background: #1779ba;
+    color: #fefefe;
+    cursor: default; }
+  .pagination .disabled {
+    padding: 0.1875rem 0.625rem;
+    color: #cacaca;
+    cursor: not-allowed; }
+    .pagination .disabled:hover {
+      background: transparent; }
+  .pagination .ellipsis::after {
+    padding: 0.1875rem 0.625rem;
+    content: '\2026';
+    color: #0a0a0a; }
+
+.pagination-previous a::before,
+.pagination-previous.disabled::before {
+  display: inline-block;
+  margin-left: 0.5rem;
+  content: '\00ab'; }
+
+.pagination-next a::after,
+.pagination-next.disabled::after {
+  display: inline-block;
+  margin-right: 0.5rem;
+  content: '\00bb'; }
+
+.has-tip {
+  position: relative;
+  display: inline-block;
+  border-bottom: dotted 1px #8a8a8a;
+  font-weight: bold;
+  cursor: help; }
+
+.tooltip {
+  position: absolute;
+  top: calc(100% + 0.6495rem);
+  z-index: 1200;
+  max-width: 10rem;
+  padding: 0.75rem;
+  border-radius: 0;
+  background-color: #0a0a0a;
+  font-size: 80%;
+  color: #fefefe; }
+  .tooltip::before {
+    position: absolute; }
+  .tooltip.bottom::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-top-width: 0;
+    border-bottom-style: solid;
+    border-color: transparent transparent #0a0a0a;
+    bottom: 100%; }
+  .tooltip.bottom.align-center::before {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+  .tooltip.top::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #0a0a0a transparent transparent;
+    top: 100%;
+    bottom: auto; }
+  .tooltip.top.align-center::before {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+  .tooltip.left::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #0a0a0a;
+    left: 100%; }
+  .tooltip.left.align-center::before {
+    bottom: auto;
+    top: 50%;
+    -webkit-transform: translateY(-50%);
+        -ms-transform: translateY(-50%);
+            transform: translateY(-50%); }
+  .tooltip.right::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #0a0a0a transparent transparent;
+    right: 100%;
+    left: auto; }
+  .tooltip.right.align-center::before {
+    bottom: auto;
+    top: 50%;
+    -webkit-transform: translateY(-50%);
+        -ms-transform: translateY(-50%);
+            transform: translateY(-50%); }
+  .tooltip.align-top::before {
+    bottom: auto;
+    top: 10%; }
+  .tooltip.align-bottom::before {
+    bottom: 10%;
+    top: auto; }
+  .tooltip.align-left::before {
+    left: 10%;
+    right: auto; }
+  .tooltip.align-right::before {
+    left: auto;
+    right: 10%; }
+
+.accordion {
+  margin-right: 0;
+  background: #fefefe;
+  list-style-type: none; }
+  .accordion[disabled] .accordion-title {
+    cursor: not-allowed; }
 
-@media print, screen and (min-width: 64em) {
-  .off-canvas.in-canvas-for-large {
-    visibility: visible;
-    height: auto;
-    position: static;
-    background: inherit;
-    width: inherit;
-    overflow: inherit;
-    -webkit-transition: inherit;
-    transition: inherit; }
-    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {
-      -webkit-box-shadow: none;
-              box-shadow: none;
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas.in-canvas-for-large .close-button {
-      display: none; } }
+.accordion-item:first-child > :first-child {
+  border-radius: 0 0 0 0; }
+
+.accordion-item:last-child > :last-child {
+  border-radius: 0 0 0 0; }
+
+.accordion-title {
+  position: relative;
+  display: block;
+  padding: 1.25rem 1rem;
+  border: 1px solid #e6e6e6;
+  border-bottom: 0;
+  font-size: 0.75rem;
+  line-height: 1;
+  color: #1779ba; }
+  :last-child:not(.is-active) > .accordion-title {
+    border-bottom: 1px solid #e6e6e6;
+    border-radius: 0 0 0 0; }
+  .accordion-title:hover, .accordion-title:focus {
+    background-color: #e6e6e6; }
+  .accordion-title::before {
+    position: absolute;
+    top: 50%;
+    left: 1rem;
+    margin-top: -0.5rem;
+    content: '+'; }
+  .is-active > .accordion-title::before {
+    content: '\2013'; }
+
+.accordion-content {
+  display: none;
+  padding: 1rem;
+  border: 1px solid #e6e6e6;
+  border-bottom: 0;
+  background-color: #fefefe;
+  color: #0a0a0a; }
+  :last-child > .accordion-content:last-child {
+    border-bottom: 1px solid #e6e6e6; }
+
+.media-object {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  margin-bottom: 1rem;
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap; }
+  .media-object img {
+    max-width: none; }
+  @media screen and (max-width: 39.99875em) {
+    .media-object.stack-for-small {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap; } }
+
+.media-object-section {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 1 auto;
+      -ms-flex: 0 1 auto;
+          flex: 0 1 auto; }
+  .media-object-section:first-child {
+    padding-left: 1rem; }
+  .media-object-section:last-child:not(:nth-child(2)) {
+    padding-right: 1rem; }
+  .media-object-section > :last-child {
+    margin-bottom: 0; }
+  @media screen and (max-width: 39.99875em) {
+    .stack-for-small .media-object-section {
+      padding: 0;
+      padding-bottom: 1rem;
+      -webkit-flex-basis: 100%;
+          -ms-flex-preferred-size: 100%;
+              flex-basis: 100%;
+      max-width: 100%; }
+      .stack-for-small .media-object-section img {
+        width: 100%; } }
+  .media-object-section.main-section {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
 
 .orbit {
   position: relative; }
@@ -4491,7 +3557,8 @@ a.button:hover, a.button:focus {
   overflow: hidden; }
 
 .orbit-slide {
-  width: 100%; }
+  width: 100%;
+  position: absolute; }
   .orbit-slide.no-motionui.is-active {
     top: 0;
     left: 0; }
@@ -4504,763 +3571,1456 @@ a.button:hover, a.button:focus {
   max-width: 100%;
   margin: 0; }
 
-.orbit-caption {
-  position: absolute;
-  bottom: 0;
-  width: 100%;
-  margin-bottom: 0;
-  padding: 1rem;
-  background-color: rgba(10, 10, 10, 0.5);
-  color: #fefefe; }
+.orbit-caption {
+  position: absolute;
+  bottom: 0;
+  width: 100%;
+  margin-bottom: 0;
+  padding: 1rem;
+  background-color: rgba(10, 10, 10, 0.5);
+  color: #fefefe; }
+
+.orbit-previous, .orbit-next {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%);
+  z-index: 10;
+  padding: 1rem;
+  color: #fefefe; }
+  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
+    outline: 0; }
+  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {
+    background-color: rgba(10, 10, 10, 0.5); }
+
+.orbit-previous {
+  right: 0; }
+
+.orbit-next {
+  right: auto;
+  left: 0; }
+
+.orbit-bullets {
+  position: relative;
+  margin-top: 0.8rem;
+  margin-bottom: 0.8rem;
+  text-align: center; }
+  [data-whatinput='mouse'] .orbit-bullets {
+    outline: 0; }
+  .orbit-bullets button {
+    width: 1.2rem;
+    height: 1.2rem;
+    margin: 0.1rem;
+    border-radius: 50%;
+    background-color: #cacaca; }
+    .orbit-bullets button:hover {
+      background-color: #8a8a8a; }
+    .orbit-bullets button.is-active {
+      background-color: #8a8a8a; }
+
+.responsive-embed,
+.flex-video {
+  position: relative;
+  height: 0;
+  margin-bottom: 1rem;
+  padding-bottom: 75%;
+  overflow: hidden; }
+  .responsive-embed iframe,
+  .responsive-embed object,
+  .responsive-embed embed,
+  .responsive-embed video,
+  .flex-video iframe,
+  .flex-video object,
+  .flex-video embed,
+  .flex-video video {
+    position: absolute;
+    top: 0;
+    right: 0;
+    width: 100%;
+    height: 100%; }
+  .responsive-embed.widescreen,
+  .flex-video.widescreen {
+    padding-bottom: 56.25%; }
+
+.tabs {
+  margin: 0;
+  border: 1px solid #e6e6e6;
+  background: #fefefe;
+  list-style-type: none; }
+  .tabs::before, .tabs::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .tabs::after {
+    clear: both; }
+
+.tabs.vertical > li {
+  display: block;
+  float: none;
+  width: auto; }
+
+.tabs.simple > li > a {
+  padding: 0; }
+  .tabs.simple > li > a:hover {
+    background: transparent; }
+
+.tabs.primary {
+  background: #1779ba; }
+  .tabs.primary > li > a {
+    color: #fefefe; }
+    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
+      background: #1673b1; }
+
+.tabs-title {
+  float: right; }
+  .tabs-title > a {
+    display: block;
+    padding: 1.25rem 1.5rem;
+    font-size: 0.75rem;
+    line-height: 1;
+    color: #1779ba; }
+    [data-whatinput='mouse'] .tabs-title > a {
+      outline: 0; }
+    .tabs-title > a:hover {
+      background: #fefefe;
+      color: #1468a0; }
+    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {
+      background: #e6e6e6;
+      color: #1779ba; }
+
+.tabs-content {
+  border: 1px solid #e6e6e6;
+  border-top: 0;
+  background: #fefefe;
+  color: #0a0a0a;
+  -webkit-transition: all 0.5s ease;
+  transition: all 0.5s ease; }
+
+.tabs-content.vertical {
+  border: 1px solid #e6e6e6;
+  border-right: 0; }
+
+.tabs-panel {
+  display: none;
+  padding: 1rem; }
+  .tabs-panel.is-active {
+    display: block; }
+
+.thumbnail {
+  display: inline-block;
+  max-width: 100%;
+  margin-bottom: 1rem;
+  border: 4px solid #fefefe;
+  border-radius: 0;
+  -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
+          box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
+  line-height: 0; }
+
+a.thumbnail {
+  -webkit-transition: -webkit-box-shadow 200ms ease-out;
+  transition: -webkit-box-shadow 200ms ease-out;
+  transition: box-shadow 200ms ease-out;
+  transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; }
+  a.thumbnail:hover, a.thumbnail:focus {
+    -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
+            box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }
+  a.thumbnail image {
+    -webkit-box-shadow: none;
+            box-shadow: none; }
 
-.orbit-previous, .orbit-next {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%);
-  z-index: 10;
-  padding: 1rem;
-  color: #fefefe; }
-  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
+.menu {
+  padding: 0;
+  margin: 0;
+  list-style: none;
+  position: relative;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-flex-wrap: wrap;
+      -ms-flex-wrap: wrap;
+          flex-wrap: wrap; }
+  [data-whatinput='mouse'] .menu li {
     outline: 0; }
-  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {
-    background-color: rgba(10, 10, 10, 0.5); }
+  .menu a,
+  .menu .button {
+    line-height: 1;
+    text-decoration: none;
+    display: block;
+    padding: 0.7rem 1rem; }
+  .menu input,
+  .menu select,
+  .menu a,
+  .menu button {
+    margin-bottom: 0; }
+  .menu input {
+    display: inline-block; }
+  .menu, .menu.horizontal {
+    -webkit-flex-wrap: wrap;
+        -ms-flex-wrap: wrap;
+            flex-wrap: wrap;
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: row;
+        -ms-flex-direction: row;
+            flex-direction: row; }
+  .menu.vertical {
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: column;
+        -ms-flex-direction: column;
+            flex-direction: column; }
+  .menu.expanded li {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
+  .menu.simple {
+    -webkit-box-align: center;
+    -webkit-align-items: center;
+        -ms-flex-align: center;
+            align-items: center; }
+    .menu.simple li + li {
+      margin-right: 1rem; }
+    .menu.simple a {
+      padding: 0; }
+  @media print, screen and (min-width: 40em) {
+    .menu.medium-horizontal {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap;
+      -webkit-box-orient: horizontal;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: row;
+          -ms-flex-direction: row;
+              flex-direction: row; }
+    .menu.medium-vertical {
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap;
+      -webkit-box-orient: vertical;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: column;
+          -ms-flex-direction: column;
+              flex-direction: column; }
+    .menu.medium-expanded li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; }
+    .menu.medium-simple li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; } }
+  @media print, screen and (min-width: 64em) {
+    .menu.large-horizontal {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap;
+      -webkit-box-orient: horizontal;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: row;
+          -ms-flex-direction: row;
+              flex-direction: row; }
+    .menu.large-vertical {
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap;
+      -webkit-box-orient: vertical;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: column;
+          -ms-flex-direction: column;
+              flex-direction: column; }
+    .menu.large-expanded li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; }
+    .menu.large-simple li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; } }
+  .menu.nested {
+    margin-left: 0;
+    margin-right: 1rem; }
+  .menu.icons a {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex; }
+  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex; }
+  .menu.icon-left li a {
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: row nowrap;
+        -ms-flex-flow: row nowrap;
+            flex-flow: row nowrap; }
+    .menu.icon-left li a img,
+    .menu.icon-left li a i,
+    .menu.icon-left li a svg {
+      margin-left: 0.25rem; }
+  .menu.icon-right li a {
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: row nowrap;
+        -ms-flex-flow: row nowrap;
+            flex-flow: row nowrap; }
+    .menu.icon-right li a img,
+    .menu.icon-right li a i,
+    .menu.icon-right li a svg {
+      margin-right: 0.25rem; }
+  .menu.icon-top li a {
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: column nowrap;
+        -ms-flex-flow: column nowrap;
+            flex-flow: column nowrap; }
+    .menu.icon-top li a img,
+    .menu.icon-top li a i,
+    .menu.icon-top li a svg {
+      -webkit-align-self: stretch;
+          -ms-flex-item-align: stretch;
+              align-self: stretch;
+      margin-bottom: 0.25rem;
+      text-align: center; }
+  .menu.icon-bottom li a {
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: column nowrap;
+        -ms-flex-flow: column nowrap;
+            flex-flow: column nowrap; }
+    .menu.icon-bottom li a img,
+    .menu.icon-bottom li a i,
+    .menu.icon-bottom li a svg {
+      -webkit-align-self: stretch;
+          -ms-flex-item-align: stretch;
+              align-self: stretch;
+      margin-bottom: 0.25rem;
+      text-align: center; }
+  .menu .is-active > a {
+    background: #1779ba;
+    color: #fefefe; }
+  .menu .active > a {
+    background: #1779ba;
+    color: #fefefe; }
+  .menu.align-right {
+    -webkit-box-pack: start;
+    -webkit-justify-content: flex-start;
+        -ms-flex-pack: start;
+            justify-content: flex-start; }
+  .menu.align-left li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: end;
+    -webkit-justify-content: flex-end;
+        -ms-flex-pack: end;
+            justify-content: flex-end; }
+    .menu.align-left li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
+  .menu.align-left.vertical li {
+    display: block;
+    text-align: left; }
+    .menu.align-left.vertical li .submenu li {
+      text-align: left; }
+  .menu.align-left .nested {
+    margin-left: 1rem;
+    margin-right: 0; }
+  .menu.align-center li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: center;
+    -webkit-justify-content: center;
+        -ms-flex-pack: center;
+            justify-content: center; }
+    .menu.align-center li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
+  .menu .menu-text {
+    padding: 0.7rem 1rem;
+    font-weight: bold;
+    line-height: 1;
+    color: inherit; }
 
-.orbit-previous {
-  right: 0; }
+.menu-centered > .menu {
+  -webkit-box-pack: center;
+  -webkit-justify-content: center;
+      -ms-flex-pack: center;
+          justify-content: center; }
+  .menu-centered > .menu li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: center;
+    -webkit-justify-content: center;
+        -ms-flex-pack: center;
+            justify-content: center; }
+    .menu-centered > .menu li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
 
-.orbit-next {
-  right: auto;
-  left: 0; }
+.no-js [data-responsive-menu] ul {
+  display: none; }
 
-.orbit-bullets {
+.menu-icon {
   position: relative;
-  margin-top: 0.8rem;
-  margin-bottom: 0.8rem;
-  text-align: center; }
-  [data-whatinput='mouse'] .orbit-bullets {
-    outline: 0; }
-  .orbit-bullets button {
-    width: 1.2rem;
-    height: 1.2rem;
-    margin: 0.1rem;
-    border-radius: 50%;
-    background-color: #cacaca; }
-    .orbit-bullets button:hover {
-      background-color: #8a8a8a; }
-    .orbit-bullets button.is-active {
-      background-color: #8a8a8a; }
-
-.pagination {
-  margin-right: 0;
-  margin-bottom: 1rem; }
-  .pagination::before, .pagination::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .pagination::after {
-    clear: both; }
-  .pagination li {
-    margin-left: 0.0625rem;
-    border-radius: 0;
-    font-size: 0.875rem;
-    display: none; }
-    .pagination li:last-child, .pagination li:first-child {
-      display: inline-block; }
-    @media print, screen and (min-width: 40em) {
-      .pagination li {
-        display: inline-block; } }
-  .pagination a,
-  .pagination button {
-    display: block;
-    padding: 0.1875rem 0.625rem;
-    border-radius: 0;
-    color: #0a0a0a; }
-    .pagination a:hover,
-    .pagination button:hover {
-      background: #e6e6e6; }
-  .pagination .current {
-    padding: 0.1875rem 0.625rem;
-    background: #1779ba;
-    color: #fefefe;
-    cursor: default; }
-  .pagination .disabled {
-    padding: 0.1875rem 0.625rem;
-    color: #cacaca;
-    cursor: not-allowed; }
-    .pagination .disabled:hover {
-      background: transparent; }
-  .pagination .ellipsis::after {
-    padding: 0.1875rem 0.625rem;
-    content: '\2026';
-    color: #0a0a0a; }
-
-.pagination-previous a::before,
-.pagination-previous.disabled::before {
   display: inline-block;
-  margin-left: 0.5rem;
-  content: '\00ab'; }
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
+  cursor: pointer; }
+  .menu-icon::after {
+    position: absolute;
+    top: 0;
+    left: 0;
+    display: block;
+    width: 100%;
+    height: 2px;
+    background: #fefefe;
+    -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+            box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+    content: ''; }
+  .menu-icon:hover::after {
+    background: #cacaca;
+    -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
+            box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }
 
-.pagination-next a::after,
-.pagination-next.disabled::after {
+.menu-icon.dark {
+  position: relative;
   display: inline-block;
-  margin-right: 0.5rem;
-  content: '\00bb'; }
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
+  cursor: pointer; }
+  .menu-icon.dark::after {
+    position: absolute;
+    top: 0;
+    left: 0;
+    display: block;
+    width: 100%;
+    height: 2px;
+    background: #0a0a0a;
+    -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
+            box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
+    content: ''; }
+  .menu-icon.dark:hover::after {
+    background: #8a8a8a;
+    -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
+            box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }
 
-.progress {
-  height: 1rem;
-  margin-bottom: 1rem;
-  border-radius: 0;
-  background-color: #cacaca; }
-  .progress.primary .progress-meter {
-    background-color: #1779ba; }
-  .progress.secondary .progress-meter {
-    background-color: #767676; }
-  .progress.success .progress-meter {
-    background-color: #3adb76; }
-  .progress.warning .progress-meter {
-    background-color: #ffae00; }
-  .progress.alert .progress-meter {
-    background-color: #cc4b37; }
+.accordion-menu li {
+  width: 100%; }
 
-.progress-meter {
-  position: relative;
-  display: block;
-  width: 0%;
-  height: 100%;
-  background-color: #1779ba; }
+.accordion-menu a {
+  padding: 0.7rem 1rem; }
 
-.progress-meter-text {
-  position: absolute;
-  top: 50%;
-  left: 50%;
-  -webkit-transform: translate(-50%, -50%);
-      -ms-transform: translate(-50%, -50%);
-          transform: translate(-50%, -50%);
-  position: absolute;
-  margin: 0;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #fefefe;
-  white-space: nowrap; }
+.accordion-menu .is-accordion-submenu a {
+  padding: 0.7rem 1rem; }
 
-.slider {
-  position: relative;
-  height: 0.5rem;
-  margin-top: 1.25rem;
-  margin-bottom: 2.25rem;
-  background-color: #e6e6e6;
-  cursor: pointer;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none;
-  -ms-touch-action: none;
-      touch-action: none; }
+.accordion-menu .nested.is-accordion-submenu {
+  margin-left: 0;
+  margin-right: 1rem; }
 
-.slider-fill {
-  position: absolute;
-  top: 0;
-  left: 0;
-  display: inline-block;
-  max-width: 100%;
-  height: 0.5rem;
-  background-color: #cacaca;
-  -webkit-transition: all 0.2s ease-in-out;
-  transition: all 0.2s ease-in-out; }
-  .slider-fill.is-dragging {
-    -webkit-transition: all 0s linear;
-    transition: all 0s linear; }
+.accordion-menu.align-left .nested.is-accordion-submenu {
+  margin-left: 1rem;
+  margin-right: 0; }
 
-.slider-handle {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%);
-  left: 0;
-  z-index: 1;
-  display: inline-block;
-  width: 1.4rem;
-  height: 1.4rem;
-  border-radius: 0;
-  background-color: #1779ba;
-  -webkit-transition: all 0.2s ease-in-out;
-  transition: all 0.2s ease-in-out;
-  -ms-touch-action: manipulation;
-      touch-action: manipulation; }
-  [data-whatinput='mouse'] .slider-handle {
-    outline: 0; }
-  .slider-handle:hover {
-    background-color: #14679e; }
-  .slider-handle.is-dragging {
-    -webkit-transition: all 0s linear;
-    transition: all 0s linear; }
+.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {
+  position: relative; }
+  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    position: absolute;
+    top: 50%;
+    margin-top: -3px;
+    left: 1rem; }
 
-.slider.disabled,
-.slider[disabled] {
-  opacity: 0.25;
-  cursor: not-allowed; }
+.accordion-menu.align-left .is-accordion-submenu-parent > a::after {
+  right: 1rem;
+  left: auto; }
 
-.slider.vertical {
-  display: inline-block;
-  width: 0.5rem;
-  height: 12.5rem;
-  margin: 0 1.25rem;
-  -webkit-transform: scale(1, -1);
-      -ms-transform: scale(1, -1);
-          transform: scale(1, -1); }
-  .slider.vertical .slider-fill {
-    top: 0;
-    width: 0.5rem;
-    max-height: 100%; }
-  .slider.vertical .slider-handle {
-    position: absolute;
-    top: 0;
-    left: 50%;
-    width: 1.4rem;
-    height: 1.4rem;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
+.accordion-menu.align-right .is-accordion-submenu-parent > a::after {
+  right: auto;
+  left: 1rem; }
 
-.slider:not(.vertical) {
-  -webkit-transform: scale(-1, 1);
-      -ms-transform: scale(-1, 1);
-          transform: scale(-1, 1); }
+.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {
+  -webkit-transform: rotate(180deg);
+      -ms-transform: rotate(180deg);
+          transform: rotate(180deg);
+  -webkit-transform-origin: 50% 50%;
+      -ms-transform-origin: 50% 50%;
+          transform-origin: 50% 50%; }
 
-.sticky-container {
+.is-accordion-submenu-parent {
   position: relative; }
 
-.sticky {
-  position: relative;
-  z-index: 0;
-  -webkit-transform: translate3d(0, 0, 0);
-          transform: translate3d(0, 0, 0); }
+.has-submenu-toggle > a {
+  margin-left: 40px; }
 
-.sticky.is-stuck {
-  position: fixed;
-  z-index: 5;
-  width: 100%; }
-  .sticky.is-stuck.is-at-top {
-    top: 0; }
-  .sticky.is-stuck.is-at-bottom {
-    bottom: 0; }
+.submenu-toggle {
+  position: absolute;
+  top: 0;
+  left: 0;
+  width: 40px;
+  height: 40px;
+  cursor: pointer; }
+  .submenu-toggle::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    top: 0;
+    bottom: 0;
+    margin: auto; }
 
-.sticky.is-anchored {
-  position: relative;
-  right: auto;
-  left: auto; }
-  .sticky.is-anchored.is-at-bottom {
-    bottom: 0; }
+.submenu-toggle[aria-expanded='true']::after {
+  -webkit-transform: scaleY(-1);
+      -ms-transform: scaleY(-1);
+          transform: scaleY(-1);
+  -webkit-transform-origin: 50% 50%;
+      -ms-transform-origin: 50% 50%;
+          transform-origin: 50% 50%; }
 
-body.is-reveal-open {
+.submenu-toggle-text {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  padding: 0;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
+  white-space: nowrap;
+  border: 0; }
+
+.is-drilldown {
+  position: relative;
   overflow: hidden; }
+  .is-drilldown li {
+    display: block; }
+  .is-drilldown.animate-height {
+    -webkit-transition: height 0.5s;
+    transition: height 0.5s; }
 
-html.is-reveal-open,
-html.is-reveal-open body {
-  min-height: 100%;
-  overflow: hidden;
-  position: fixed;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none; }
+.drilldown a {
+  padding: 0.7rem 1rem;
+  background: #fefefe; }
 
-.reveal-overlay {
-  position: fixed;
+.drilldown .is-drilldown-submenu {
+  position: absolute;
   top: 0;
-  right: 0;
-  bottom: 0;
-  left: 0;
-  z-index: 1005;
-  display: none;
-  background-color: rgba(10, 10, 10, 0.45);
-  overflow-y: scroll; }
+  right: 100%;
+  z-index: -1;
+  width: 100%;
+  background: #fefefe;
+  -webkit-transition: -webkit-transform 0.15s linear;
+  transition: -webkit-transform 0.15s linear;
+  transition: transform 0.15s linear;
+  transition: transform 0.15s linear, -webkit-transform 0.15s linear; }
+  .drilldown .is-drilldown-submenu.is-active {
+    z-index: 1;
+    display: block;
+    -webkit-transform: translateX(100%);
+        -ms-transform: translateX(100%);
+            transform: translateX(100%); }
+  .drilldown .is-drilldown-submenu.is-closing {
+    -webkit-transform: translateX(-100%);
+        -ms-transform: translateX(-100%);
+            transform: translateX(-100%); }
+  .drilldown .is-drilldown-submenu a {
+    padding: 0.7rem 1rem; }
 
-.reveal {
-  z-index: 1006;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  display: none;
-  padding: 1rem;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  position: relative;
-  top: 100px;
-  margin-right: auto;
-  margin-left: auto;
-  overflow-y: auto; }
-  [data-whatinput='mouse'] .reveal {
-    outline: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal {
-      min-height: 0; } }
-  .reveal .column {
-    min-width: 0; }
-  .reveal > :last-child {
-    margin-bottom: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal {
-      width: 600px;
-      max-width: 75rem; } }
-  .reveal.collapse {
-    padding: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal.tiny {
-      width: 30%;
-      max-width: 75rem; } }
-  @media print, screen and (min-width: 40em) {
-    .reveal.small {
-      width: 50%;
-      max-width: 75rem; } }
-  @media print, screen and (min-width: 40em) {
-    .reveal.large {
-      width: 90%;
-      max-width: 75rem; } }
-  .reveal.full {
-    top: 0;
-    left: 0;
-    width: 100%;
-    max-width: none;
-    height: 100%;
-    height: 100vh;
-    min-height: 100vh;
-    margin-left: 0;
-    border: 0;
-    border-radius: 0; }
-  @media screen and (max-width: 39.9375em) {
-    .reveal {
-      top: 0;
-      left: 0;
-      width: 100%;
-      max-width: none;
-      height: 100%;
-      height: 100vh;
-      min-height: 100vh;
-      margin-left: 0;
-      border: 0;
-      border-radius: 0; } }
-  .reveal.without-overlay {
-    position: fixed; }
+.drilldown .nested.is-drilldown-submenu {
+  margin-left: 0;
+  margin-right: 0; }
+
+.drilldown .drilldown-submenu-cover-previous {
+  min-height: 100%; }
+
+.drilldown .is-drilldown-submenu-parent > a {
+  position: relative; }
+  .drilldown .is-drilldown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    position: absolute;
+    top: 50%;
+    margin-top: -6px;
+    left: 1rem; }
+
+.drilldown.align-left .is-drilldown-submenu-parent > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba;
+  right: 1rem;
+  left: auto; }
+
+.drilldown.align-right .is-drilldown-submenu-parent > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  right: auto;
+  left: 1rem; }
 
-.switch {
-  height: 2rem;
-  position: relative;
-  margin-bottom: 1rem;
-  outline: 0;
-  font-size: 0.875rem;
-  font-weight: bold;
-  color: #fefefe;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none; }
+.drilldown .js-drilldown-back > a::before {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba;
+  display: inline-block;
+  vertical-align: middle;
+  margin-left: 0.75rem; }
 
-.switch-input {
-  position: absolute;
-  margin-bottom: 0;
-  opacity: 0; }
+.dropdown.menu > li.opens-left > .is-dropdown-submenu {
+  top: 100%;
+  right: 0;
+  left: auto; }
 
-.switch-paddle {
+.dropdown.menu > li.opens-right > .is-dropdown-submenu {
+  top: 100%;
+  right: auto;
+  left: 0; }
+
+.dropdown.menu > li.is-dropdown-submenu-parent > a {
   position: relative;
+  padding-left: 1.5rem; }
+
+.dropdown.menu > li.is-dropdown-submenu-parent > a::after {
   display: block;
-  width: 4rem;
-  height: 2rem;
-  border-radius: 0;
-  background: #cacaca;
-  -webkit-transition: all 0.25s ease-out;
-  transition: all 0.25s ease-out;
-  font-weight: inherit;
-  color: inherit;
-  cursor: pointer; }
-  input + .switch-paddle {
-    margin: 0; }
-  .switch-paddle::after {
-    position: absolute;
-    top: 0.25rem;
-    right: 0.25rem;
-    display: block;
-    width: 1.5rem;
-    height: 1.5rem;
-    -webkit-transform: translate3d(0, 0, 0);
-            transform: translate3d(0, 0, 0);
-    border-radius: 0;
-    background: #fefefe;
-    -webkit-transition: all 0.25s ease-out;
-    transition: all 0.25s ease-out;
-    content: ''; }
-  input:checked ~ .switch-paddle {
-    background: #1779ba; }
-    input:checked ~ .switch-paddle::after {
-      right: 2.25rem; }
-  [data-whatinput='mouse'] input:focus ~ .switch-paddle {
-    outline: 0; }
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-bottom-width: 0;
+  border-top-style: solid;
+  border-color: #1779ba transparent transparent;
+  left: 5px;
+  right: auto;
+  margin-top: -3px; }
 
-.switch-active, .switch-inactive {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%); }
+[data-whatinput='mouse'] .dropdown.menu a {
+  outline: 0; }
 
-.switch-active {
-  right: 8%;
+.dropdown.menu > li > a {
+  padding: 0.7rem 1rem; }
+
+.dropdown.menu > li.is-active > a {
+  background: transparent;
+  color: #1779ba; }
+
+.no-js .dropdown.menu ul {
   display: none; }
-  input:checked + label > .switch-active {
-    display: block; }
 
-.switch-inactive {
-  left: 15%; }
-  input:checked + label > .switch-inactive {
-    display: none; }
+.dropdown.menu .nested.is-dropdown-submenu {
+  margin-left: 0;
+  margin-right: 0; }
 
-.switch.tiny {
-  height: 1.5rem; }
-  .switch.tiny .switch-paddle {
-    width: 3rem;
-    height: 1.5rem;
-    font-size: 0.625rem; }
-  .switch.tiny .switch-paddle::after {
-    top: 0.25rem;
-    right: 0.25rem;
-    width: 1rem;
-    height: 1rem; }
-  .switch.tiny input:checked ~ .switch-paddle::after {
-    right: 1.75rem; }
+.dropdown.menu.vertical > li .is-dropdown-submenu {
+  top: 0; }
+
+.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {
+  top: 0;
+  right: 100%;
+  left: auto; }
+
+.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {
+  right: auto;
+  left: 100%; }
+
+.dropdown.menu.vertical > li > a::after {
+  left: 14px; }
+
+.dropdown.menu.vertical > li.opens-left > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  right: auto;
+  left: 5px; }
+
+.dropdown.menu.vertical > li.opens-right > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba; }
+
+@media print, screen and (min-width: 40em) {
+  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {
+    top: 100%;
+    right: 0;
+    left: auto; }
+  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
+    top: 100%;
+    right: auto;
+    left: 0; }
+  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {
+    position: relative;
+    padding-left: 1.5rem; }
+  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    left: 5px;
+    right: auto;
+    margin-top: -3px; }
+  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {
+    top: 0; }
+  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {
+    top: 0;
+    right: 100%;
+    left: auto; }
+  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
+  .dropdown.menu.medium-vertical > li > a::after {
+    left: 14px; }
+  .dropdown.menu.medium-vertical > li.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .dropdown.menu.medium-vertical > li.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; } }
+
+@media print, screen and (min-width: 64em) {
+  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {
+    top: 100%;
+    right: 0;
+    left: auto; }
+  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {
+    top: 100%;
+    right: auto;
+    left: 0; }
+  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {
+    position: relative;
+    padding-left: 1.5rem; }
+  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    left: 5px;
+    right: auto;
+    margin-top: -3px; }
+  .dropdown.menu.large-vertical > li .is-dropdown-submenu {
+    top: 0; }
+  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {
+    top: 0;
+    right: 100%;
+    left: auto; }
+  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
+  .dropdown.menu.large-vertical > li > a::after {
+    left: 14px; }
+  .dropdown.menu.large-vertical > li.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .dropdown.menu.large-vertical > li.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; } }
 
-.switch.small {
-  height: 1.75rem; }
-  .switch.small .switch-paddle {
-    width: 3.5rem;
-    height: 1.75rem;
-    font-size: 0.75rem; }
-  .switch.small .switch-paddle::after {
-    top: 0.25rem;
-    right: 0.25rem;
-    width: 1.25rem;
-    height: 1.25rem; }
-  .switch.small input:checked ~ .switch-paddle::after {
-    right: 2rem; }
+.dropdown.menu.align-right .is-dropdown-submenu.first-sub {
+  top: 100%;
+  right: 0;
+  left: auto; }
 
-.switch.large {
-  height: 2.5rem; }
-  .switch.large .switch-paddle {
-    width: 5rem;
-    height: 2.5rem;
-    font-size: 1rem; }
-  .switch.large .switch-paddle::after {
-    top: 0.25rem;
-    right: 0.25rem;
-    width: 2rem;
-    height: 2rem; }
-  .switch.large input:checked ~ .switch-paddle::after {
-    right: 2.75rem; }
+.is-dropdown-menu.vertical {
+  width: 100px; }
+  .is-dropdown-menu.vertical.align-right {
+    float: right; }
 
-table {
-  border-collapse: collapse;
-  width: 100%;
-  margin-bottom: 1rem;
-  border-radius: 0; }
-  table thead,
-  table tbody,
-  table tfoot {
-    border: 1px solid #f1f1f1;
-    background-color: #fefefe; }
-  table caption {
-    padding: 0.5rem 0.625rem 0.625rem;
-    font-weight: bold; }
-  table thead {
-    background: #f8f8f8;
-    color: #0a0a0a; }
-  table tfoot {
-    background: #f1f1f1;
-    color: #0a0a0a; }
-  table thead tr,
-  table tfoot tr {
-    background: transparent; }
-  table thead th,
-  table thead td,
-  table tfoot th,
-  table tfoot td {
-    padding: 0.5rem 0.625rem 0.625rem;
-    font-weight: bold;
-    text-align: right; }
-  table tbody th,
-  table tbody td {
-    padding: 0.5rem 0.625rem 0.625rem; }
-  table tbody tr:nth-child(even) {
-    border-bottom: 0;
-    background-color: #f1f1f1; }
-  table.unstriped tbody {
-    background-color: #fefefe; }
-    table.unstriped tbody tr {
-      border-bottom: 0;
-      border-bottom: 1px solid #f1f1f1;
-      background-color: #fefefe; }
+.is-dropdown-submenu-parent {
+  position: relative; }
+  .is-dropdown-submenu-parent a::after {
+    position: absolute;
+    top: 50%;
+    left: 5px;
+    right: auto;
+    margin-top: -6px; }
+  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {
+    top: 100%;
+    right: auto; }
+  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {
+    right: 100%;
+    left: auto; }
+  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
 
-@media screen and (max-width: 63.9375em) {
-  table.stack thead {
-    display: none; }
-  table.stack tfoot {
-    display: none; }
-  table.stack tr,
-  table.stack th,
-  table.stack td {
+.is-dropdown-submenu {
+  position: absolute;
+  top: 0;
+  right: 100%;
+  z-index: 1;
+  display: none;
+  min-width: 200px;
+  border: 1px solid #cacaca;
+  background: #fefefe; }
+  .dropdown .is-dropdown-submenu a {
+    padding: 0.7rem 1rem; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {
+    left: 14px; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; }
+  .is-dropdown-submenu .is-dropdown-submenu {
+    margin-top: -1px; }
+  .is-dropdown-submenu > li {
+    width: 100%; }
+  .is-dropdown-submenu.js-dropdown-active {
     display: block; }
-  table.stack td {
-    border-top: 0; } }
 
-table.scroll {
-  display: block;
+.is-off-canvas-open {
+  overflow: hidden; }
+
+.js-off-canvas-overlay {
+  position: absolute;
+  top: 0;
+  left: 0;
+  z-index: 11;
   width: 100%;
-  overflow-x: auto; }
+  height: 100%;
+  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
+  transition: opacity 0.5s ease, visibility 0.5s ease;
+  background: rgba(254, 254, 254, 0.25);
+  opacity: 0;
+  visibility: hidden;
+  overflow: hidden; }
+  .js-off-canvas-overlay.is-visible {
+    opacity: 1;
+    visibility: visible; }
+  .js-off-canvas-overlay.is-closable {
+    cursor: pointer; }
+  .js-off-canvas-overlay.is-overlay-absolute {
+    position: absolute; }
+  .js-off-canvas-overlay.is-overlay-fixed {
+    position: fixed; }
 
-table.hover thead tr:hover {
-  background-color: #f3f3f3; }
+.off-canvas-wrapper {
+  position: relative;
+  overflow: hidden; }
 
-table.hover tfoot tr:hover {
-  background-color: #ececec; }
+.off-canvas {
+  position: fixed;
+  z-index: 12;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  background: #e6e6e6; }
+  [data-whatinput='mouse'] .off-canvas {
+    outline: 0; }
+  .off-canvas.is-transition-push {
+    z-index: 12; }
+  .off-canvas.is-closed {
+    visibility: hidden; }
+  .off-canvas.is-transition-overlap {
+    z-index: 13; }
+    .off-canvas.is-transition-overlap.is-open {
+      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
+              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
+  .off-canvas.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-table.hover tbody tr:hover {
-  background-color: #f9f9f9; }
+.off-canvas-absolute {
+  position: absolute;
+  z-index: 12;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  background: #e6e6e6; }
+  [data-whatinput='mouse'] .off-canvas-absolute {
+    outline: 0; }
+  .off-canvas-absolute.is-transition-push {
+    z-index: 12; }
+  .off-canvas-absolute.is-closed {
+    visibility: hidden; }
+  .off-canvas-absolute.is-transition-overlap {
+    z-index: 13; }
+    .off-canvas-absolute.is-transition-overlap.is-open {
+      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
+              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
+  .off-canvas-absolute.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-table.hover:not(.unstriped) tr:nth-of-type(even):hover {
-  background-color: #ececec; }
+.position-left {
+  top: 0;
+  left: 0;
+  height: 100%;
+  overflow-y: auto;
+  width: 250px;
+  -webkit-transform: translateX(-250px);
+      -ms-transform: translateX(-250px);
+          transform: translateX(-250px); }
+  .off-canvas-content .off-canvas.position-left {
+    -webkit-transform: translateX(-250px);
+        -ms-transform: translateX(-250px);
+            transform: translateX(-250px); }
+    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-left.has-transition-push {
+    -webkit-transform: translateX(250px);
+        -ms-transform: translateX(250px);
+            transform: translateX(250px); }
+  .position-left.is-transition-push {
+    -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }
 
-.table-scroll {
-  overflow-x: auto; }
-  .table-scroll table {
-    width: auto; }
+.position-right {
+  top: 0;
+  right: 0;
+  height: 100%;
+  overflow-y: auto;
+  width: 250px;
+  -webkit-transform: translateX(250px);
+      -ms-transform: translateX(250px);
+          transform: translateX(250px); }
+  .off-canvas-content .off-canvas.position-right {
+    -webkit-transform: translateX(250px);
+        -ms-transform: translateX(250px);
+            transform: translateX(250px); }
+    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-right.has-transition-push {
+    -webkit-transform: translateX(-250px);
+        -ms-transform: translateX(-250px);
+            transform: translateX(-250px); }
+  .position-right.is-transition-push {
+    -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }
 
-.tabs {
-  margin: 0;
-  border: 1px solid #e6e6e6;
-  background: #fefefe;
-  list-style-type: none; }
-  .tabs::before, .tabs::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .tabs::after {
-    clear: both; }
+.position-top {
+  top: 0;
+  left: 0;
+  width: 100%;
+  overflow-x: auto;
+  height: 250px;
+  -webkit-transform: translateY(-250px);
+      -ms-transform: translateY(-250px);
+          transform: translateY(-250px); }
+  .off-canvas-content .off-canvas.position-top {
+    -webkit-transform: translateY(-250px);
+        -ms-transform: translateY(-250px);
+            transform: translateY(-250px); }
+    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-top.has-transition-push {
+    -webkit-transform: translateY(250px);
+        -ms-transform: translateY(250px);
+            transform: translateY(250px); }
+  .position-top.is-transition-push {
+    -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }
 
-.tabs.vertical > li {
-  display: block;
-  float: none;
-  width: auto; }
+.position-bottom {
+  bottom: 0;
+  left: 0;
+  width: 100%;
+  overflow-x: auto;
+  height: 250px;
+  -webkit-transform: translateY(250px);
+      -ms-transform: translateY(250px);
+          transform: translateY(250px); }
+  .off-canvas-content .off-canvas.position-bottom {
+    -webkit-transform: translateY(250px);
+        -ms-transform: translateY(250px);
+            transform: translateY(250px); }
+    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-bottom.has-transition-push {
+    -webkit-transform: translateY(-250px);
+        -ms-transform: translateY(-250px);
+            transform: translateY(-250px); }
+  .position-bottom.is-transition-push {
+    -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }
 
-.tabs.simple > li > a {
-  padding: 0; }
-  .tabs.simple > li > a:hover {
-    background: transparent; }
+.off-canvas-content {
+  -webkit-transform: none;
+      -ms-transform: none;
+          transform: none;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden; }
+  .off-canvas-content.has-transition-push {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
+  .off-canvas-content .off-canvas.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-.tabs.primary {
-  background: #1779ba; }
-  .tabs.primary > li > a {
-    color: #fefefe; }
-    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
-      background: #1673b1; }
+@media print, screen and (min-width: 40em) {
+  .position-left.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-left.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-left.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-left {
+      margin-left: 250px; }
+    .position-left.reveal-for-medium ~ .off-canvas-content {
+      margin-left: 250px; }
+  .position-right.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-right.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-right.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-right {
+      margin-right: 250px; }
+    .position-right.reveal-for-medium ~ .off-canvas-content {
+      margin-right: 250px; }
+  .position-top.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-top.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-top.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-top {
+      margin-top: 250px; }
+    .position-top.reveal-for-medium ~ .off-canvas-content {
+      margin-top: 250px; }
+  .position-bottom.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-bottom.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-bottom.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-bottom {
+      margin-bottom: 250px; }
+    .position-bottom.reveal-for-medium ~ .off-canvas-content {
+      margin-bottom: 250px; } }
 
-.tabs-title {
-  float: right; }
-  .tabs-title > a {
-    display: block;
-    padding: 1.25rem 1.5rem;
-    font-size: 0.75rem;
-    line-height: 1;
-    color: #1779ba; }
-    .tabs-title > a:hover {
-      background: #fefefe;
-      color: #1468a0; }
-    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {
-      background: #e6e6e6;
-      color: #1779ba; }
+@media print, screen and (min-width: 64em) {
+  .position-left.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-left.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-left.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-left {
+      margin-left: 250px; }
+    .position-left.reveal-for-large ~ .off-canvas-content {
+      margin-left: 250px; }
+  .position-right.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-right.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-right.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-right {
+      margin-right: 250px; }
+    .position-right.reveal-for-large ~ .off-canvas-content {
+      margin-right: 250px; }
+  .position-top.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-top.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-top.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-top {
+      margin-top: 250px; }
+    .position-top.reveal-for-large ~ .off-canvas-content {
+      margin-top: 250px; }
+  .position-bottom.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-bottom.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-bottom.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-bottom {
+      margin-bottom: 250px; }
+    .position-bottom.reveal-for-large ~ .off-canvas-content {
+      margin-bottom: 250px; } }
 
-.tabs-content {
-  border: 1px solid #e6e6e6;
-  border-top: 0;
-  background: #fefefe;
-  color: #0a0a0a;
-  -webkit-transition: all 0.5s ease;
-  transition: all 0.5s ease; }
+@media print, screen and (min-width: 40em) {
+  .off-canvas.in-canvas-for-medium {
+    visibility: visible;
+    height: auto;
+    position: static;
+    background: none;
+    width: auto;
+    overflow: visible;
+    -webkit-transition: none;
+    transition: none; }
+    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {
+      -webkit-box-shadow: none;
+              box-shadow: none;
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas.in-canvas-for-medium .close-button {
+      display: none; } }
 
-.tabs-content.vertical {
-  border: 1px solid #e6e6e6;
-  border-right: 0; }
+@media print, screen and (min-width: 64em) {
+  .off-canvas.in-canvas-for-large {
+    visibility: visible;
+    height: auto;
+    position: static;
+    background: none;
+    width: auto;
+    overflow: visible;
+    -webkit-transition: none;
+    transition: none; }
+    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {
+      -webkit-box-shadow: none;
+              box-shadow: none;
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas.in-canvas-for-large .close-button {
+      display: none; } }
 
-.tabs-panel {
+html.is-reveal-open {
+  position: fixed;
+  width: 100%;
+  overflow-y: hidden; }
+  html.is-reveal-open.zf-has-scroll {
+    overflow-y: scroll; }
+  html.is-reveal-open body {
+    overflow-y: hidden; }
+
+.reveal-overlay {
+  position: fixed;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  z-index: 1005;
   display: none;
-  padding: 1rem; }
-  .tabs-panel.is-active {
-    display: block; }
+  background-color: rgba(10, 10, 10, 0.45);
+  overflow-y: auto; }
 
-.thumbnail {
-  display: inline-block;
-  max-width: 100%;
-  margin-bottom: 1rem;
-  border: solid 4px #fefefe;
+.reveal {
+  z-index: 1006;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  display: none;
+  padding: 1rem;
+  border: 1px solid #cacaca;
   border-radius: 0;
-  -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-          box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-  line-height: 0; }
-
-a.thumbnail {
-  -webkit-transition: -webkit-box-shadow 200ms ease-out;
-  transition: -webkit-box-shadow 200ms ease-out;
-  transition: box-shadow 200ms ease-out;
-  transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; }
-  a.thumbnail:hover, a.thumbnail:focus {
-    -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
-            box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }
-  a.thumbnail image {
-    -webkit-box-shadow: none;
-            box-shadow: none; }
-
-.title-bar {
-  padding: 0.5rem;
-  background: #0a0a0a;
-  color: #fefefe;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-pack: start;
-  -webkit-justify-content: flex-start;
-      -ms-flex-pack: start;
-          justify-content: flex-start;
-  -webkit-box-align: center;
-  -webkit-align-items: center;
-      -ms-flex-align: center;
-          align-items: center; }
-  .title-bar .menu-icon {
-    margin-right: 0.25rem;
-    margin-left: 0.25rem; }
-
-.title-bar-left,
-.title-bar-right {
-  -webkit-box-flex: 1;
-  -webkit-flex: 1 1 0px;
-      -ms-flex: 1 1 0px;
-          flex: 1 1 0px; }
-
-.title-bar-right {
-  text-align: right; }
-
-.title-bar-title {
-  display: inline-block;
-  vertical-align: middle;
-  font-weight: bold; }
-
-.has-tip {
+  background-color: #fefefe;
   position: relative;
-  display: inline-block;
-  border-bottom: dotted 1px #8a8a8a;
-  font-weight: bold;
-  cursor: help; }
-
-.tooltip {
-  position: absolute;
-  top: calc(100% + 0.6495rem);
-  z-index: 1200;
-  max-width: 10rem;
-  padding: 0.75rem;
-  border-radius: 0;
-  background-color: #0a0a0a;
-  font-size: 80%;
-  color: #fefefe; }
-  .tooltip::before {
-    position: absolute; }
-  .tooltip.bottom::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-top-width: 0;
-    border-bottom-style: solid;
-    border-color: transparent transparent #0a0a0a;
-    bottom: 100%; }
-  .tooltip.bottom.align-center::before {
-    left: 50%;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
-  .tooltip.top::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #0a0a0a transparent transparent;
-    top: 100%;
-    bottom: auto; }
-  .tooltip.top.align-center::before {
-    left: 50%;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
-  .tooltip.left::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #0a0a0a;
-    left: 100%; }
-  .tooltip.left.align-center::before {
-    bottom: auto;
-    top: 50%;
-    -webkit-transform: translateY(-50%);
-        -ms-transform: translateY(-50%);
-            transform: translateY(-50%); }
-  .tooltip.right::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #0a0a0a transparent transparent;
-    right: 100%;
-    left: auto; }
-  .tooltip.right.align-center::before {
-    bottom: auto;
-    top: 50%;
-    -webkit-transform: translateY(-50%);
-        -ms-transform: translateY(-50%);
-            transform: translateY(-50%); }
-  .tooltip.align-top::before {
-    bottom: auto;
-    top: 10%; }
-  .tooltip.align-bottom::before {
-    bottom: 10%;
-    top: auto; }
-  .tooltip.align-left::before {
-    left: 10%;
-    right: auto; }
-  .tooltip.align-right::before {
-    left: auto;
-    right: 10%; }
+  top: 100px;
+  margin-right: auto;
+  margin-left: auto;
+  overflow-y: auto; }
+  [data-whatinput='mouse'] .reveal {
+    outline: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal {
+      min-height: 0; } }
+  .reveal .column {
+    min-width: 0; }
+  .reveal > :last-child {
+    margin-bottom: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal {
+      width: 600px;
+      max-width: 75rem; } }
+  .reveal.collapse {
+    padding: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal.tiny {
+      width: 30%;
+      max-width: 75rem; } }
+  @media print, screen and (min-width: 40em) {
+    .reveal.small {
+      width: 50%;
+      max-width: 75rem; } }
+  @media print, screen and (min-width: 40em) {
+    .reveal.large {
+      width: 90%;
+      max-width: 75rem; } }
+  .reveal.full {
+    top: 0;
+    right: 0;
+    bottom: 0;
+    left: 0;
+    width: 100%;
+    max-width: none;
+    height: 100%;
+    min-height: 100%;
+    margin-left: 0;
+    border: 0;
+    border-radius: 0; }
+  @media screen and (max-width: 39.99875em) {
+    .reveal {
+      top: 0;
+      right: 0;
+      bottom: 0;
+      left: 0;
+      width: 100%;
+      max-width: none;
+      height: 100%;
+      min-height: 100%;
+      margin-left: 0;
+      border: 0;
+      border-radius: 0; } }
+  .reveal.without-overlay {
+    position: fixed; }
+
+.sticky-container {
+  position: relative; }
+
+.sticky {
+  position: relative;
+  z-index: 0;
+  -webkit-transform: translate3d(0, 0, 0);
+          transform: translate3d(0, 0, 0); }
+
+.sticky.is-stuck {
+  position: fixed;
+  z-index: 5;
+  width: 100%; }
+  .sticky.is-stuck.is-at-top {
+    top: 0; }
+  .sticky.is-stuck.is-at-bottom {
+    bottom: 0; }
+
+.sticky.is-anchored {
+  position: relative;
+  right: auto;
+  left: auto; }
+  .sticky.is-anchored.is-at-bottom {
+    bottom: 0; }
+
+.title-bar {
+  padding: 0.5rem;
+  background: #0a0a0a;
+  color: #fefefe;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-pack: start;
+  -webkit-justify-content: flex-start;
+      -ms-flex-pack: start;
+          justify-content: flex-start;
+  -webkit-box-align: center;
+  -webkit-align-items: center;
+      -ms-flex-align: center;
+          align-items: center; }
+  .title-bar .menu-icon {
+    margin-right: 0.25rem;
+    margin-left: 0.25rem; }
+
+.title-bar-left,
+.title-bar-right {
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 1 0px;
+      -ms-flex: 1 1 0px;
+          flex: 1 1 0px; }
+
+.title-bar-right {
+  text-align: right; }
+
+.title-bar-title {
+  display: inline-block;
+  vertical-align: middle;
+  font-weight: bold; }
 
 .top-bar {
   display: -webkit-box;
@@ -5317,7 +5077,7 @@ a.thumbnail {
             -ms-flex: 0 1 auto;
                 flex: 0 1 auto;
         margin-left: auto; } }
-  @media screen and (max-width: 63.9375em) {
+  @media screen and (max-width: 63.99875em) {
     .top-bar.stacked-for-medium {
       -webkit-flex-wrap: wrap;
           -ms-flex-wrap: wrap;
@@ -5329,7 +5089,7 @@ a.thumbnail {
             -ms-flex: 0 0 100%;
                 flex: 0 0 100%;
         max-width: 100%; } }
-  @media screen and (max-width: 74.9375em) {
+  @media screen and (max-width: 74.99875em) {
     .top-bar.stacked-for-large {
       -webkit-flex-wrap: wrap;
           -ms-flex-wrap: wrap;
@@ -5356,99 +5116,6 @@ a.thumbnail {
       -ms-flex: 0 0 auto;
           flex: 0 0 auto; }
 
-.hide {
-  display: none !important; }
-
-.invisible {
-  visibility: hidden; }
-
-@media screen and (max-width: 39.9375em) {
-  .hide-for-small-only {
-    display: none !important; } }
-
-@media screen and (max-width: 0em), screen and (min-width: 40em) {
-  .show-for-small-only {
-    display: none !important; } }
-
-@media print, screen and (min-width: 40em) {
-  .hide-for-medium {
-    display: none !important; } }
-
-@media screen and (max-width: 39.9375em) {
-  .show-for-medium {
-    display: none !important; } }
-
-@media screen and (min-width: 40em) and (max-width: 63.9375em) {
-  .hide-for-medium-only {
-    display: none !important; } }
-
-@media screen and (max-width: 39.9375em), screen and (min-width: 64em) {
-  .show-for-medium-only {
-    display: none !important; } }
-
-@media print, screen and (min-width: 64em) {
-  .hide-for-large {
-    display: none !important; } }
-
-@media screen and (max-width: 63.9375em) {
-  .show-for-large {
-    display: none !important; } }
-
-@media screen and (min-width: 64em) and (max-width: 74.9375em) {
-  .hide-for-large-only {
-    display: none !important; } }
-
-@media screen and (max-width: 63.9375em), screen and (min-width: 75em) {
-  .show-for-large-only {
-    display: none !important; } }
-
-.show-for-sr,
-.show-on-focus {
-  position: absolute !important;
-  width: 1px;
-  height: 1px;
-  padding: 0;
-  overflow: hidden;
-  clip: rect(0, 0, 0, 0);
-  white-space: nowrap;
-  -webkit-clip-path: inset(50%);
-          clip-path: inset(50%);
-  border: 0; }
-
-.show-on-focus:active, .show-on-focus:focus {
-  position: static !important;
-  width: auto;
-  height: auto;
-  overflow: visible;
-  clip: auto;
-  white-space: normal;
-  -webkit-clip-path: none;
-          clip-path: none; }
-
-.show-for-landscape,
-.hide-for-portrait {
-  display: block !important; }
-  @media screen and (orientation: landscape) {
-    .show-for-landscape,
-    .hide-for-portrait {
-      display: block !important; } }
-  @media screen and (orientation: portrait) {
-    .show-for-landscape,
-    .hide-for-portrait {
-      display: none !important; } }
-
-.hide-for-landscape,
-.show-for-portrait {
-  display: none !important; }
-  @media screen and (orientation: landscape) {
-    .hide-for-landscape,
-    .show-for-portrait {
-      display: none !important; } }
-  @media screen and (orientation: portrait) {
-    .hide-for-landscape,
-    .show-for-portrait {
-      display: block !important; } }
-
 .float-left {
   float: left !important; }
 
@@ -5474,12 +5141,18 @@ a.thumbnail {
 .clearfix::after {
   clear: both; }
 
-.align-right {
+.align-left {
   -webkit-box-pack: end;
   -webkit-justify-content: flex-end;
       -ms-flex-pack: end;
           justify-content: flex-end; }
 
+.align-right {
+  -webkit-box-pack: start;
+  -webkit-justify-content: flex-start;
+      -ms-flex-pack: start;
+          justify-content: flex-start; }
+
 .align-center {
   -webkit-box-pack: center;
   -webkit-justify-content: center;
@@ -5497,12 +5170,18 @@ a.thumbnail {
       -ms-flex-pack: distribute;
           justify-content: space-around; }
 
-.align-right.vertical.menu > li > a {
+.align-left.vertical.menu > li > a {
   -webkit-box-pack: end;
   -webkit-justify-content: flex-end;
       -ms-flex-pack: end;
           justify-content: flex-end; }
 
+.align-right.vertical.menu > li > a {
+  -webkit-box-pack: start;
+  -webkit-justify-content: flex-start;
+      -ms-flex-pack: start;
+          justify-content: flex-start; }
+
 .align-center.vertical.menu > li > a {
   -webkit-box-pack: center;
   -webkit-justify-content: center;
@@ -5540,7 +5219,6 @@ a.thumbnail {
 .align-self-middle {
   -webkit-align-self: center;
       -ms-flex-item-align: center;
-              -ms-grid-row-align: center;
           align-self: center; }
 
 .align-stretch {
@@ -5552,7 +5230,6 @@ a.thumbnail {
 .align-self-stretch {
   -webkit-align-self: stretch;
       -ms-flex-item-align: stretch;
-              -ms-grid-row-align: stretch;
           align-self: stretch; }
 
 .align-center-middle {
@@ -5812,4 +5489,93 @@ a.thumbnail {
         -ms-flex-direction: column-reverse;
             flex-direction: column-reverse; } }
 
+.hide {
+  display: none !important; }
+
+.invisible {
+  visibility: hidden; }
+
+@media screen and (max-width: 39.99875em) {
+  .hide-for-small-only {
+    display: none !important; } }
+
+@media screen and (max-width: 0em), screen and (min-width: 40em) {
+  .show-for-small-only {
+    display: none !important; } }
+
+@media print, screen and (min-width: 40em) {
+  .hide-for-medium {
+    display: none !important; } }
+
+@media screen and (max-width: 39.99875em) {
+  .show-for-medium {
+    display: none !important; } }
+
+@media screen and (min-width: 40em) and (max-width: 63.99875em) {
+  .hide-for-medium-only {
+    display: none !important; } }
+
+@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {
+  .show-for-medium-only {
+    display: none !important; } }
+
+@media print, screen and (min-width: 64em) {
+  .hide-for-large {
+    display: none !important; } }
+
+@media screen and (max-width: 63.99875em) {
+  .show-for-large {
+    display: none !important; } }
+
+@media screen and (min-width: 64em) and (max-width: 74.99875em) {
+  .hide-for-large-only {
+    display: none !important; } }
+
+@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {
+  .show-for-large-only {
+    display: none !important; } }
+
+.show-for-sr,
+.show-on-focus {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  padding: 0;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
+  white-space: nowrap;
+  border: 0; }
+
+.show-on-focus:active, .show-on-focus:focus {
+  position: static !important;
+  width: auto;
+  height: auto;
+  overflow: visible;
+  clip: auto;
+  white-space: normal; }
+
+.show-for-landscape,
+.hide-for-portrait {
+  display: block !important; }
+  @media screen and (orientation: landscape) {
+    .show-for-landscape,
+    .hide-for-portrait {
+      display: block !important; } }
+  @media screen and (orientation: portrait) {
+    .show-for-landscape,
+    .hide-for-portrait {
+      display: none !important; } }
+
+.hide-for-landscape,
+.show-for-portrait {
+  display: none !important; }
+  @media screen and (orientation: landscape) {
+    .hide-for-landscape,
+    .show-for-portrait {
+      display: none !important; } }
+  @media screen and (orientation: portrait) {
+    .hide-for-landscape,
+    .show-for-portrait {
+      display: block !important; } }
+
 /*# sourceMappingURL=foundation-rtl.css.map */
diff --git a/dist/css/foundation-rtl.css.map b/dist/css/foundation-rtl.css.map
new file mode 100644 (file)
index 0000000..2be52a6
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation-rtl.css","../scss/foundation.scss","../scss/util/_breakpoint.scss","../scss/components/_reveal.scss","../scss/vendor/normalize.scss","../scss/_global.scss","../scss/util/_unit.scss","../scss/util/_mixins.scss","../scss/forms/_text.scss","../scss/forms/_checkbox.scss","../scss/forms/_label.scss","../scss/forms/_help-text.scss","../scss/forms/_input-group.scss","../scss/forms/_fieldset.scss","../scss/forms/_select.scss","../scss/forms/_error.scss","../scss/typography/_base.scss","../scss/typography/_helpers.scss","../scss/typography/_alignment.scss","../scss/typography/_print.scss","../scss/xy-grid/_classes.scss","../scss/xy-grid/_gutters.scss","../scss/xy-grid/_grid.scss","../scss/xy-grid/_cell.scss","../scss/xy-grid/_layout.scss","../scss/xy-grid/_collapse.scss","../scss/xy-grid/_position.scss","../scss/xy-grid/_frame.scss","../scss/components/_button.scss","../scss/components/_button-group.scss","../scss/components/_close-button.scss","../scss/components/_label.scss","../scss/components/_progress-bar.scss","../scss/forms/_progress.scss","../scss/components/_slider.scss","../scss/forms/_range.scss","../scss/components/_switch.scss","../scss/components/_table.scss","../scss/util/_color.scss","../scss/components/_badge.scss","../scss/components/_breadcrumbs.scss","../scss/components/_callout.scss","../scss/components/_card.scss","../scss/components/_dropdown.scss","../scss/components/_pagination.scss","../scss/components/_tooltip.scss","../scss/components/_accordion.scss","../scss/components/_media-object.scss","../scss/components/_orbit.scss","../scss/components/_responsive-embed.scss","../scss/util/_math.scss","../scss/components/_tabs.scss","../scss/components/_thumbnail.scss","../scss/components/_menu.scss","../scss/components/_menu-icon.scss","../scss/components/_accordion-menu.scss","../scss/components/_drilldown.scss","../scss/components/_dropdown-menu.scss","../scss/components/_off-canvas.scss","../scss/components/_sticky.scss","../scss/components/_title-bar.scss","../scss/components/_top-bar.scss","../scss/components/_float.scss","../scss/components/_flex.scss","../scss/util/_flex.scss","../scss/components/_visibility.scss"],"names":[],"mappings":"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,EAAA;;ArB6ElD;EsBxIJ;ID4DE,WADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,YADoD,EAAA,ECzDrD;;AtBsIG;EsBxIJ;ID4DE,WADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,YADoD,EAAA,ECzDrD;;AAFD;ED4DE,2BADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,4BADgH,EAAA;;ArB6E9G;EsBxIJ;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,6BADgH,EAAA;EC3DlH;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,6BADgH,EAAA,ECzDjH;;AtBsIG;EsBxIJ;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADg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AA;;ANoO3B;EMpOF,wCAA6B,EAAA;;ANgO3B;EMhOF,iBAA6B,EAAA;;ANoO3B;EMpOF,kCAA6B,EAAA;;ANgO3B;EMhOF,uBAA6B,EAAA;;ANoO3B;EMpOF,wCAA6B,EAAA;;ANgO3B;EMhOF,uBAA6B,EAAA;;ANoO3B;EMpOF,wCAA6B,EAAA;;ANgO3B;EMhOF,iBAA6B,EAAA;;ANoO3B;EMpOF,kCAA6B,EAAA;;ANgO3B;EMhOF,uBAA6B,EAAA;;ANoO3B;EMpOF,wCAA6B,EAAA;;ANgO3B;EMhOF,uBAA6B,EAAA;;ANoO3B;EMpOF,wCAA6B,EAAA;;AxByI3B;EkBuFA;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMpOF,yCAA6B,EAAA;ENgO3B;IMhOF,iBAA6B,EAAA;ENoO3B;IMpOF,mCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMpOF,yCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMpOF,yCAA6B,EAAA;ENgO3B;IMhOF,iBAA6B,EAAA;ENoO3B;IMpOF,mCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMpOF,yCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMpOF,yCAA6B,EAAA;ENgO3B;IMhOF,iBAA6B,EAAA;ENoO3B;IMpOF,mCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMpOF,yCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMpOF,yCAA6B,EAAA,ENsO1B;;AlB7FD;EkBuFA;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMpOF,yCAA6B,EAAA;ENgO3B;IMhOF,iBAA6B,EAAA;ENoO3B;IMpOF,mCAA6B,EAAA;ENgO3B;IMhOF,uBAA6B,EAAA;ENoO3B;IMp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,EAAA,ED6G1D;EArCP;IG/BE,YAAmB,EAAA;EHmCrB;IG/BE,YAAmB,EAAA;EHuCnB;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,4BADgH,EAAA;ErB6E9G;IkBrDJ;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,6BADgH,EAAA;IHwBlH;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,6BADgH,EAAA,EHsC/G;ElBuCC;IkBrDJ;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA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MAyClB,mBAzCkB;UAyClB,qBAzCkB,EAAA;;ADiFhB;ECxBF,4BAzDkB;MAyDlB,wBAzDkB;UAyDlB,oBAzDkB,EAAA;;AD6EhB;ECpCF,yBAxCgB;EAwChB,2BAxCgB;MAwChB,sBAxCgB;UAwChB,mBAxCgB,EAAA;;ADgFd;ECxBF,0BAxDgB;MAwDhB,2BAxDgB;UAwDhB,kBAxDgB,EAAA;;AD4Ed;ECpCF,0BAvCkB;EAuClB,4BAvCkB;MAuClB,uBAvCkB;UAuClB,oBAvCkB,EAAA;;AD+EhB;ECxBF,2BAvDkB;MAuDlB,4BAvDkB;UAuDlB,mBAvDkB,EAAA;;ADqFlB;EC/CA,wBAnDkB;EAmDlB,+BAnDkB;MAmDlB,qBAnDkB;UAmDlB,uBAnDkB;EAoDlB,yBAxCgB;EAwChB,2BAxCgB;MAwChB,sBAxCgB;UAwChB,mBAxCgB;EDwFd,6BAAqB;MAArB,0BAAqB;UAArB,qBAAqB,EAAA;;AAMnB;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;A7DyDZ;E6DxDA;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/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","file":"foundation-rtl.css","sourcesContent":["@charset \"UTF-8\";\n/**\n * Foundation for Sites by ZURB\n * Version 6.5.3\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n@media print, screen and (min-width: 40em) {\n  .reveal, .reveal.tiny, .reveal.small, .reveal.large {\n    right: auto;\n    left: auto;\n    margin: 0 auto; } }\n\n/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  line-height: 1.15;\n  -webkit-text-size-adjust: 100%; }\n\nbody {\n  margin: 0; }\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0; }\n\nhr {\n  box-sizing: content-box;\n  height: 0;\n  overflow: visible; }\n\npre {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\na {\n  background-color: transparent; }\n\nabbr[title] {\n  border-bottom: none;\n  text-decoration: underline;\n  text-decoration: underline dotted; }\n\nb,\nstrong {\n  font-weight: bolder; }\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\nsmall {\n  font-size: 80%; }\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline; }\n\nsub {\n  bottom: -0.25em; }\n\nsup {\n  top: -0.5em; }\n\nimg {\n  border-style: none; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: 100%;\n  line-height: 1.15;\n  margin: 0; }\n\nbutton,\ninput {\n  overflow: visible; }\n\nbutton,\nselect {\n  text-transform: none; }\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button; }\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0; }\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText; }\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em; }\n\nlegend {\n  box-sizing: border-box;\n  color: inherit;\n  display: table;\n  max-width: 100%;\n  padding: 0;\n  white-space: normal; }\n\nprogress {\n  vertical-align: baseline; }\n\ntextarea {\n  overflow: auto; }\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  padding: 0; }\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto; }\n\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  outline-offset: -2px; }\n\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none; }\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  font: inherit; }\n\ndetails {\n  display: block; }\n\nsummary {\n  display: list-item; }\n\ntemplate {\n  display: none; }\n\n[hidden] {\n  display: none; }\n\n.foundation-mq {\n  font-family: \"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em\"; }\n\nhtml {\n  box-sizing: border-box;\n  font-size: 100%; }\n\n*,\n*::before,\n*::after {\n  box-sizing: inherit; }\n\nbody {\n  margin: 0;\n  padding: 0;\n  background: #fefefe;\n  font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale; }\n\nimg {\n  display: inline-block;\n  vertical-align: middle;\n  max-width: 100%;\n  height: auto;\n  -ms-interpolation-mode: bicubic; }\n\ntextarea {\n  height: auto;\n  min-height: 50px;\n  border-radius: 0; }\n\nselect {\n  box-sizing: border-box;\n  width: 100%;\n  border-radius: 0; }\n\n.map_canvas img,\n.map_canvas embed,\n.map_canvas object,\n.mqa-display img,\n.mqa-display embed,\n.mqa-display object {\n  max-width: none !important; }\n\nbutton {\n  padding: 0;\n  appearance: none;\n  border: 0;\n  border-radius: 0;\n  background: transparent;\n  line-height: 1;\n  cursor: auto; }\n  [data-whatinput='mouse'] button {\n    outline: 0; }\n\npre {\n  overflow: auto; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit; }\n\n.is-visible {\n  display: block !important; }\n\n.is-hidden {\n  display: none !important; }\n\n[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],\ntextarea {\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n  appearance: none; }\n  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,\n  textarea:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n\ntextarea {\n  max-width: 100%; }\n  textarea[rows] {\n    height: auto; }\n\ninput:disabled, input[readonly],\ntextarea:disabled,\ntextarea[readonly] {\n  background-color: #e6e6e6;\n  cursor: not-allowed; }\n\n[type='submit'],\n[type='button'] {\n  appearance: none;\n  border-radius: 0; }\n\ninput[type='search'] {\n  box-sizing: border-box; }\n\n::placeholder {\n  color: #cacaca; }\n\n[type='file'],\n[type='checkbox'],\n[type='radio'] {\n  margin: 0 0 1rem; }\n\n[type='checkbox'] + label,\n[type='radio'] + label {\n  display: inline-block;\n  vertical-align: baseline;\n  margin-right: 0.5rem;\n  margin-left: 1rem;\n  margin-bottom: 0; }\n  [type='checkbox'] + label[for],\n  [type='radio'] + label[for] {\n    cursor: pointer; }\n\nlabel > [type='checkbox'],\nlabel > [type='radio'] {\n  margin-left: 0.5rem; }\n\n[type='file'] {\n  width: 100%; }\n\nlabel {\n  display: block;\n  margin: 0;\n  font-size: 0.875rem;\n  font-weight: normal;\n  line-height: 1.8;\n  color: #0a0a0a; }\n  label.middle {\n    margin: 0 0 1rem;\n    padding: 0.5625rem 0; }\n\n.help-text {\n  margin-top: -0.5rem;\n  font-size: 0.8125rem;\n  font-style: italic;\n  color: #0a0a0a; }\n\n.input-group {\n  display: flex;\n  width: 100%;\n  margin-bottom: 1rem;\n  align-items: stretch; }\n  .input-group > :first-child, .input-group > :first-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n  .input-group > :last-child, .input-group > :last-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n\n.input-group-label, .input-group-field, .input-group-button, .input-group-button a,\n.input-group-button input,\n.input-group-button button,\n.input-group-button label {\n  margin: 0;\n  white-space: nowrap; }\n\n.input-group-label {\n  padding: 0 1rem;\n  border: 1px solid #cacaca;\n  background: #e6e6e6;\n  color: #0a0a0a;\n  text-align: center;\n  white-space: nowrap;\n  display: flex;\n  flex: 0 0 auto;\n  align-items: center; }\n  .input-group-label:first-child {\n    border-left: 0; }\n  .input-group-label:last-child {\n    border-right: 0; }\n\n.input-group-field {\n  border-radius: 0;\n  flex: 1 1 0px;\n  min-width: 0; }\n\n.input-group-button {\n  padding-top: 0;\n  padding-bottom: 0;\n  text-align: center;\n  display: flex;\n  flex: 0 0 auto; }\n  .input-group-button a,\n  .input-group-button input,\n  .input-group-button button,\n  .input-group-button label {\n    align-self: stretch;\n    height: auto;\n    padding-top: 0;\n    padding-bottom: 0;\n    font-size: 1rem; }\n\nfieldset {\n  margin: 0;\n  padding: 0;\n  border: 0; }\n\nlegend {\n  max-width: 100%;\n  margin-bottom: 0.5rem; }\n\n.fieldset {\n  margin: 1.125rem 0;\n  padding: 1.25rem;\n  border: 1px solid #cacaca; }\n  .fieldset legend {\n    margin: 0;\n    margin-right: -0.1875rem;\n    padding: 0 0.1875rem; }\n\nselect {\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  appearance: none;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>\");\n  background-origin: content-box;\n  background-position: left -1rem center;\n  background-repeat: no-repeat;\n  background-size: 9px 6px;\n  padding-left: 1.5rem;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  @media screen and (min-width: 0\\0) {\n    select {\n      background-image: url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==\"); } }\n  select:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  select:disabled {\n    background-color: #e6e6e6;\n    cursor: not-allowed; }\n  select::-ms-expand {\n    display: none; }\n  select[multiple] {\n    height: auto;\n    background-image: none; }\n\n.is-invalid-input:not(:focus) {\n  border-color: #cc4b37;\n  background-color: #f9ecea; }\n  .is-invalid-input:not(:focus)::placeholder {\n    color: #cc4b37; }\n\n.is-invalid-label {\n  color: #cc4b37; }\n\n.form-error {\n  display: none;\n  margin-top: -0.5rem;\n  margin-bottom: 1rem;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #cc4b37; }\n  .form-error.is-visible {\n    display: block; }\n\ndiv,\ndl,\ndt,\ndd,\nul,\nol,\nli,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\npre,\nform,\np,\nblockquote,\nth,\ntd {\n  margin: 0;\n  padding: 0; }\n\np {\n  margin-bottom: 1rem;\n  font-size: inherit;\n  line-height: 1.6;\n  text-rendering: optimizeLegibility; }\n\nem,\ni {\n  font-style: italic;\n  line-height: inherit; }\n\nstrong,\nb {\n  font-weight: bold;\n  line-height: inherit; }\n\nsmall {\n  font-size: 80%;\n  line-height: inherit; }\n\nh1, .h1,\nh2, .h2,\nh3, .h3,\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n  font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  color: inherit;\n  text-rendering: optimizeLegibility; }\n  h1 small, .h1 small,\n  h2 small, .h2 small,\n  h3 small, .h3 small,\n  h4 small, .h4 small,\n  h5 small, .h5 small,\n  h6 small, .h6 small {\n    line-height: 0;\n    color: #cacaca; }\n\nh1, .h1 {\n  font-size: 1.5rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh2, .h2 {\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh3, .h3 {\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh4, .h4 {\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh5, .h5 {\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh6, .h6 {\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n  h1, .h1 {\n    font-size: 3rem; }\n  h2, .h2 {\n    font-size: 2.5rem; }\n  h3, .h3 {\n    font-size: 1.9375rem; }\n  h4, .h4 {\n    font-size: 1.5625rem; }\n  h5, .h5 {\n    font-size: 1.25rem; }\n  h6, .h6 {\n    font-size: 1rem; } }\n\na {\n  line-height: inherit;\n  color: #1779ba;\n  text-decoration: none;\n  cursor: pointer; }\n  a:hover, a:focus {\n    color: #1468a0; }\n  a img {\n    border: 0; }\n\nhr {\n  clear: both;\n  max-width: 75rem;\n  height: 0;\n  margin: 1.25rem auto;\n  border-top: 0;\n  border-right: 0;\n  border-bottom: 1px solid #cacaca;\n  border-left: 0; }\n\nul,\nol,\ndl {\n  margin-bottom: 1rem;\n  list-style-position: outside;\n  line-height: 1.6; }\n\nli {\n  font-size: inherit; }\n\nul {\n  margin-right: 1.25rem;\n  list-style-type: disc; }\n\nol {\n  margin-right: 1.25rem; }\n\nul ul, ol ul, ul ol, ol ol {\n  margin-right: 1.25rem;\n  margin-bottom: 0; }\n\ndl {\n  margin-bottom: 1rem; }\n  dl dt {\n    margin-bottom: 0.3rem;\n    font-weight: bold; }\n\nblockquote {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 1.25rem 0 1.1875rem;\n  border-right: 1px solid #cacaca; }\n  blockquote, blockquote p {\n    line-height: 1.6;\n    color: #8a8a8a; }\n\ncite {\n  display: block;\n  font-size: 0.8125rem;\n  color: #8a8a8a; }\n  cite:before {\n    content: \"— \"; }\n\nabbr, abbr[title] {\n  border-bottom: 1px dotted #0a0a0a;\n  cursor: help;\n  text-decoration: none; }\n\nfigure {\n  margin: 0; }\n\ncode {\n  padding: 0.125rem 0.3125rem 0.0625rem;\n  border: 1px solid #cacaca;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  font-weight: normal;\n  color: #0a0a0a; }\n\nkbd {\n  margin: 0;\n  padding: 0.125rem 0.25rem 0;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  color: #0a0a0a; }\n\n.subheader {\n  margin-top: 0.2rem;\n  margin-bottom: 0.5rem;\n  font-weight: normal;\n  line-height: 1.4;\n  color: #8a8a8a; }\n\n.lead {\n  font-size: 125%;\n  line-height: 1.6; }\n\n.stat {\n  font-size: 2.5rem;\n  line-height: 1; }\n  p + .stat {\n    margin-top: -1rem; }\n\nul.no-bullet, ol.no-bullet {\n  margin-right: 0;\n  list-style: none; }\n\n.text-left {\n  text-align: left; }\n\n.text-right {\n  text-align: right; }\n\n.text-center {\n  text-align: center; }\n\n.text-justify {\n  text-align: justify; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-text-left {\n    text-align: left; }\n  .medium-text-right {\n    text-align: right; }\n  .medium-text-center {\n    text-align: center; }\n  .medium-text-justify {\n    text-align: justify; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-text-left {\n    text-align: left; }\n  .large-text-right {\n    text-align: right; }\n  .large-text-center {\n    text-align: center; }\n  .large-text-justify {\n    text-align: justify; } }\n\n.show-for-print {\n  display: none !important; }\n\n@media print {\n  * {\n    background: transparent !important;\n    box-shadow: none !important;\n    color: black !important;\n    text-shadow: none !important; }\n  .show-for-print {\n    display: block !important; }\n  .hide-for-print {\n    display: none !important; }\n  table.show-for-print {\n    display: table !important; }\n  thead.show-for-print {\n    display: table-header-group !important; }\n  tbody.show-for-print {\n    display: table-row-group !important; }\n  tr.show-for-print {\n    display: table-row !important; }\n  td.show-for-print {\n    display: table-cell !important; }\n  th.show-for-print {\n    display: table-cell !important; }\n  a,\n  a:visited {\n    text-decoration: underline; }\n  a[href]:after {\n    content: \" (\" attr(href) \")\"; }\n  .ir a:after,\n  a[href^='javascript:']:after,\n  a[href^='#']:after {\n    content: ''; }\n  abbr[title]:after {\n    content: \" (\" attr(title) \")\"; }\n  pre,\n  blockquote {\n    border: 1px solid #8a8a8a;\n    page-break-inside: avoid; }\n  thead {\n    display: table-header-group; }\n  tr,\n  img {\n    page-break-inside: avoid; }\n  img {\n    max-width: 100% !important; }\n  @page {\n    margin: 0.5cm; }\n  p,\n  h2,\n  h3 {\n    orphans: 3;\n    widows: 3; }\n  h2,\n  h3 {\n    page-break-after: avoid; }\n  .print-break-inside {\n    page-break-inside: auto; } }\n\n.grid-container {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n  max-width: 75rem;\n  margin-left: auto;\n  margin-right: auto; }\n  @media print, screen and (min-width: 40em) {\n    .grid-container {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n  .grid-container.fluid {\n    padding-right: 0.625rem;\n    padding-left: 0.625rem;\n    max-width: 100%;\n    margin-left: auto;\n    margin-right: auto; }\n    @media print, screen and (min-width: 40em) {\n      .grid-container.fluid {\n        padding-right: 0.9375rem;\n        padding-left: 0.9375rem; } }\n  .grid-container.full {\n    padding-right: 0;\n    padding-left: 0;\n    max-width: 100%;\n    margin-left: auto;\n    margin-right: auto; }\n\n.grid-x {\n  display: flex;\n  flex-flow: row wrap; }\n\n.cell {\n  flex: 0 0 auto;\n  min-height: 0px;\n  min-width: 0px;\n  width: 100%; }\n  .cell.auto {\n    flex: 1 1 0px; }\n  .cell.shrink {\n    flex: 0 0 auto; }\n\n.grid-x > .auto {\n  width: auto; }\n\n.grid-x > .shrink {\n  width: auto; }\n\n.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {\n  flex-basis: auto; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {\n    flex-basis: auto; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {\n    flex-basis: auto; } }\n\n.grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {\n  flex: 0 0 auto; }\n\n.grid-x > .small-1 {\n  width: 8.33333%; }\n\n.grid-x > .small-2 {\n  width: 16.66667%; }\n\n.grid-x > .small-3 {\n  width: 25%; }\n\n.grid-x > .small-4 {\n  width: 33.33333%; }\n\n.grid-x > .small-5 {\n  width: 41.66667%; }\n\n.grid-x > .small-6 {\n  width: 50%; }\n\n.grid-x > .small-7 {\n  width: 58.33333%; }\n\n.grid-x > .small-8 {\n  width: 66.66667%; }\n\n.grid-x > .small-9 {\n  width: 75%; }\n\n.grid-x > .small-10 {\n  width: 83.33333%; }\n\n.grid-x > .small-11 {\n  width: 91.66667%; }\n\n.grid-x > .small-12 {\n  width: 100%; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-x > .medium-auto {\n    flex: 1 1 0px;\n    width: auto; }\n  .grid-x > .medium-shrink, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {\n    flex: 0 0 auto; }\n  .grid-x > .medium-shrink {\n    width: auto; }\n  .grid-x > .medium-1 {\n    width: 8.33333%; }\n  .grid-x > .medium-2 {\n    width: 16.66667%; }\n  .grid-x > .medium-3 {\n    width: 25%; }\n  .grid-x > .medium-4 {\n    width: 33.33333%; }\n  .grid-x > .medium-5 {\n    width: 41.66667%; }\n  .grid-x > .medium-6 {\n    width: 50%; }\n  .grid-x > .medium-7 {\n    width: 58.33333%; }\n  .grid-x > .medium-8 {\n    width: 66.66667%; }\n  .grid-x > .medium-9 {\n    width: 75%; }\n  .grid-x > .medium-10 {\n    width: 83.33333%; }\n  .grid-x > .medium-11 {\n    width: 91.66667%; }\n  .grid-x > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-x > .large-auto {\n    flex: 1 1 0px;\n    width: auto; }\n  .grid-x > .large-shrink, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {\n    flex: 0 0 auto; }\n  .grid-x > .large-shrink {\n    width: auto; }\n  .grid-x > .large-1 {\n    width: 8.33333%; }\n  .grid-x > .large-2 {\n    width: 16.66667%; }\n  .grid-x > .large-3 {\n    width: 25%; }\n  .grid-x > .large-4 {\n    width: 33.33333%; }\n  .grid-x > .large-5 {\n    width: 41.66667%; }\n  .grid-x > .large-6 {\n    width: 50%; }\n  .grid-x > .large-7 {\n    width: 58.33333%; }\n  .grid-x > .large-8 {\n    width: 66.66667%; }\n  .grid-x > .large-9 {\n    width: 75%; }\n  .grid-x > .large-10 {\n    width: 83.33333%; }\n  .grid-x > .large-11 {\n    width: 91.66667%; }\n  .grid-x > .large-12 {\n    width: 100%; } }\n\n.grid-margin-x:not(.grid-x) > .cell {\n  width: auto; }\n\n.grid-margin-y:not(.grid-y) > .cell {\n  height: auto; }\n\n.grid-margin-x {\n  margin-left: -0.625rem;\n  margin-right: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x {\n      margin-left: -0.9375rem;\n      margin-right: -0.9375rem; } }\n  .grid-margin-x > .cell {\n    width: calc(100% - 1.25rem);\n    margin-left: 0.625rem;\n    margin-right: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x > .cell {\n      width: calc(100% - 1.875rem);\n      margin-left: 0.9375rem;\n      margin-right: 0.9375rem; } }\n  .grid-margin-x > .auto {\n    width: auto; }\n  .grid-margin-x > .shrink {\n    width: auto; }\n  .grid-margin-x > .small-1 {\n    width: calc(8.33333% - 1.25rem); }\n  .grid-margin-x > .small-2 {\n    width: calc(16.66667% - 1.25rem); }\n  .grid-margin-x > .small-3 {\n    width: calc(25% - 1.25rem); }\n  .grid-margin-x > .small-4 {\n    width: calc(33.33333% - 1.25rem); }\n  .grid-margin-x > .small-5 {\n    width: calc(41.66667% - 1.25rem); }\n  .grid-margin-x > .small-6 {\n    width: calc(50% - 1.25rem); }\n  .grid-margin-x > .small-7 {\n    width: calc(58.33333% - 1.25rem); }\n  .grid-margin-x > .small-8 {\n    width: calc(66.66667% - 1.25rem); }\n  .grid-margin-x > .small-9 {\n    width: calc(75% - 1.25rem); }\n  .grid-margin-x > .small-10 {\n    width: calc(83.33333% - 1.25rem); }\n  .grid-margin-x > .small-11 {\n    width: calc(91.66667% - 1.25rem); }\n  .grid-margin-x > .small-12 {\n    width: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x > .auto {\n      width: auto; }\n    .grid-margin-x > .shrink {\n      width: auto; }\n    .grid-margin-x > .small-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .small-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .small-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .small-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .small-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .small-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .small-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .small-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .small-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .small-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .small-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .small-12 {\n      width: calc(100% - 1.875rem); }\n    .grid-margin-x > .medium-auto {\n      width: auto; }\n    .grid-margin-x > .medium-shrink {\n      width: auto; }\n    .grid-margin-x > .medium-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .medium-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .medium-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .medium-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .medium-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .medium-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .medium-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .medium-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .medium-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .medium-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .medium-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .medium-12 {\n      width: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-x > .large-auto {\n      width: auto; }\n    .grid-margin-x > .large-shrink {\n      width: auto; }\n    .grid-margin-x > .large-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .large-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .large-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .large-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .large-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .large-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .large-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .large-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .large-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .large-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .large-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .large-12 {\n      width: calc(100% - 1.875rem); } }\n\n.grid-padding-x .grid-padding-x {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-x .grid-padding-x {\n      margin-right: -0.9375rem;\n      margin-left: -0.9375rem; } }\n\n.grid-container:not(.full) > .grid-padding-x {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-container:not(.full) > .grid-padding-x {\n      margin-right: -0.9375rem;\n      margin-left: -0.9375rem; } }\n\n.grid-padding-x > .cell {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-x > .cell {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n\n.small-up-1 > .cell {\n  width: 100%; }\n\n.small-up-2 > .cell {\n  width: 50%; }\n\n.small-up-3 > .cell {\n  width: 33.33333%; }\n\n.small-up-4 > .cell {\n  width: 25%; }\n\n.small-up-5 > .cell {\n  width: 20%; }\n\n.small-up-6 > .cell {\n  width: 16.66667%; }\n\n.small-up-7 > .cell {\n  width: 14.28571%; }\n\n.small-up-8 > .cell {\n  width: 12.5%; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-up-1 > .cell {\n    width: 100%; }\n  .medium-up-2 > .cell {\n    width: 50%; }\n  .medium-up-3 > .cell {\n    width: 33.33333%; }\n  .medium-up-4 > .cell {\n    width: 25%; }\n  .medium-up-5 > .cell {\n    width: 20%; }\n  .medium-up-6 > .cell {\n    width: 16.66667%; }\n  .medium-up-7 > .cell {\n    width: 14.28571%; }\n  .medium-up-8 > .cell {\n    width: 12.5%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-up-1 > .cell {\n    width: 100%; }\n  .large-up-2 > .cell {\n    width: 50%; }\n  .large-up-3 > .cell {\n    width: 33.33333%; }\n  .large-up-4 > .cell {\n    width: 25%; }\n  .large-up-5 > .cell {\n    width: 20%; }\n  .large-up-6 > .cell {\n    width: 16.66667%; }\n  .large-up-7 > .cell {\n    width: 14.28571%; }\n  .large-up-8 > .cell {\n    width: 12.5%; } }\n\n.grid-margin-x.small-up-1 > .cell {\n  width: calc(100% - 1.25rem); }\n\n.grid-margin-x.small-up-2 > .cell {\n  width: calc(50% - 1.25rem); }\n\n.grid-margin-x.small-up-3 > .cell {\n  width: calc(33.33333% - 1.25rem); }\n\n.grid-margin-x.small-up-4 > .cell {\n  width: calc(25% - 1.25rem); }\n\n.grid-margin-x.small-up-5 > .cell {\n  width: calc(20% - 1.25rem); }\n\n.grid-margin-x.small-up-6 > .cell {\n  width: calc(16.66667% - 1.25rem); }\n\n.grid-margin-x.small-up-7 > .cell {\n  width: calc(14.28571% - 1.25rem); }\n\n.grid-margin-x.small-up-8 > .cell {\n  width: calc(12.5% - 1.25rem); }\n\n@media print, screen and (min-width: 40em) {\n  .grid-margin-x.small-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.small-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.small-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.small-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.small-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.small-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.small-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.small-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); }\n  .grid-margin-x.medium-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.medium-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.medium-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.medium-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.medium-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.medium-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.medium-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.medium-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-margin-x.large-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.large-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.large-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.large-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.large-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.large-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.large-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.large-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); } }\n\n.small-margin-collapse {\n  margin-right: 0;\n  margin-left: 0; }\n  .small-margin-collapse > .cell {\n    margin-right: 0;\n    margin-left: 0; }\n  .small-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .small-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .small-margin-collapse > .small-3 {\n    width: 25%; }\n  .small-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .small-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .small-margin-collapse > .small-6 {\n    width: 50%; }\n  .small-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .small-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .small-margin-collapse > .small-9 {\n    width: 75%; }\n  .small-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .small-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .small-margin-collapse > .small-12 {\n    width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .small-margin-collapse > .medium-1 {\n      width: 8.33333%; }\n    .small-margin-collapse > .medium-2 {\n      width: 16.66667%; }\n    .small-margin-collapse > .medium-3 {\n      width: 25%; }\n    .small-margin-collapse > .medium-4 {\n      width: 33.33333%; }\n    .small-margin-collapse > .medium-5 {\n      width: 41.66667%; }\n    .small-margin-collapse > .medium-6 {\n      width: 50%; }\n    .small-margin-collapse > .medium-7 {\n      width: 58.33333%; }\n    .small-margin-collapse > .medium-8 {\n      width: 66.66667%; }\n    .small-margin-collapse > .medium-9 {\n      width: 75%; }\n    .small-margin-collapse > .medium-10 {\n      width: 83.33333%; }\n    .small-margin-collapse > .medium-11 {\n      width: 91.66667%; }\n    .small-margin-collapse > .medium-12 {\n      width: 100%; } }\n  @media print, screen and (min-width: 64em) {\n    .small-margin-collapse > .large-1 {\n      width: 8.33333%; }\n    .small-margin-collapse > .large-2 {\n      width: 16.66667%; }\n    .small-margin-collapse > .large-3 {\n      width: 25%; }\n    .small-margin-collapse > .large-4 {\n      width: 33.33333%; }\n    .small-margin-collapse > .large-5 {\n      width: 41.66667%; }\n    .small-margin-collapse > .large-6 {\n      width: 50%; }\n    .small-margin-collapse > .large-7 {\n      width: 58.33333%; }\n    .small-margin-collapse > .large-8 {\n      width: 66.66667%; }\n    .small-margin-collapse > .large-9 {\n      width: 75%; }\n    .small-margin-collapse > .large-10 {\n      width: 83.33333%; }\n    .small-margin-collapse > .large-11 {\n      width: 91.66667%; }\n    .small-margin-collapse > .large-12 {\n      width: 100%; } }\n\n.small-padding-collapse {\n  margin-right: 0;\n  margin-left: 0; }\n  .small-padding-collapse > .cell {\n    padding-right: 0;\n    padding-left: 0; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-margin-collapse > .cell {\n      margin-right: 0;\n      margin-left: 0; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .small-3 {\n    width: 25%; }\n  .medium-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .small-6 {\n    width: 50%; }\n  .medium-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .small-9 {\n    width: 75%; }\n  .medium-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .small-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse > .medium-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .medium-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .medium-3 {\n    width: 25%; }\n  .medium-margin-collapse > .medium-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .medium-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .medium-6 {\n    width: 50%; }\n  .medium-margin-collapse > .medium-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .medium-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .medium-9 {\n    width: 75%; }\n  .medium-margin-collapse > .medium-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .medium-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .medium-margin-collapse > .large-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .large-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .large-3 {\n    width: 25%; }\n  .medium-margin-collapse > .large-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .large-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .large-6 {\n    width: 50%; }\n  .medium-margin-collapse > .large-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .large-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .large-9 {\n    width: 75%; }\n  .medium-margin-collapse > .large-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .large-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .large-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-padding-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-padding-collapse > .cell {\n      padding-right: 0;\n      padding-left: 0; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .large-margin-collapse > .cell {\n      margin-right: 0;\n      margin-left: 0; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .small-3 {\n    width: 25%; }\n  .large-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .small-6 {\n    width: 50%; }\n  .large-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .small-9 {\n    width: 75%; }\n  .large-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .small-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .medium-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .medium-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .medium-3 {\n    width: 25%; }\n  .large-margin-collapse > .medium-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .medium-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .medium-6 {\n    width: 50%; }\n  .large-margin-collapse > .medium-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .medium-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .medium-9 {\n    width: 75%; }\n  .large-margin-collapse > .medium-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .medium-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .large-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .large-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .large-3 {\n    width: 25%; }\n  .large-margin-collapse > .large-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .large-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .large-6 {\n    width: 50%; }\n  .large-margin-collapse > .large-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .large-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .large-9 {\n    width: 75%; }\n  .large-margin-collapse > .large-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .large-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .large-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-padding-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .large-padding-collapse > .cell {\n      padding-right: 0;\n      padding-left: 0; } }\n\n.small-offset-0 {\n  margin-right: 0%; }\n\n.grid-margin-x > .small-offset-0 {\n  margin-right: calc(0% + 0.625rem); }\n\n.small-offset-1 {\n  margin-right: 8.33333%; }\n\n.grid-margin-x > .small-offset-1 {\n  margin-right: calc(8.33333% + 0.625rem); }\n\n.small-offset-2 {\n  margin-right: 16.66667%; }\n\n.grid-margin-x > .small-offset-2 {\n  margin-right: calc(16.66667% + 0.625rem); }\n\n.small-offset-3 {\n  margin-right: 25%; }\n\n.grid-margin-x > .small-offset-3 {\n  margin-right: calc(25% + 0.625rem); }\n\n.small-offset-4 {\n  margin-right: 33.33333%; }\n\n.grid-margin-x > .small-offset-4 {\n  margin-right: calc(33.33333% + 0.625rem); }\n\n.small-offset-5 {\n  margin-right: 41.66667%; }\n\n.grid-margin-x > .small-offset-5 {\n  margin-right: calc(41.66667% + 0.625rem); }\n\n.small-offset-6 {\n  margin-right: 50%; }\n\n.grid-margin-x > .small-offset-6 {\n  margin-right: calc(50% + 0.625rem); }\n\n.small-offset-7 {\n  margin-right: 58.33333%; }\n\n.grid-margin-x > .small-offset-7 {\n  margin-right: calc(58.33333% + 0.625rem); }\n\n.small-offset-8 {\n  margin-right: 66.66667%; }\n\n.grid-margin-x > .small-offset-8 {\n  margin-right: calc(66.66667% + 0.625rem); }\n\n.small-offset-9 {\n  margin-right: 75%; }\n\n.grid-margin-x > .small-offset-9 {\n  margin-right: calc(75% + 0.625rem); }\n\n.small-offset-10 {\n  margin-right: 83.33333%; }\n\n.grid-margin-x > .small-offset-10 {\n  margin-right: calc(83.33333% + 0.625rem); }\n\n.small-offset-11 {\n  margin-right: 91.66667%; }\n\n.grid-margin-x > .small-offset-11 {\n  margin-right: calc(91.66667% + 0.625rem); }\n\n@media print, screen and (min-width: 40em) {\n  .medium-offset-0 {\n    margin-right: 0%; }\n  .grid-margin-x > .medium-offset-0 {\n    margin-right: calc(0% + 0.9375rem); }\n  .medium-offset-1 {\n    margin-right: 8.33333%; }\n  .grid-margin-x > .medium-offset-1 {\n    margin-right: calc(8.33333% + 0.9375rem); }\n  .medium-offset-2 {\n    margin-right: 16.66667%; }\n  .grid-margin-x > .medium-offset-2 {\n    margin-right: calc(16.66667% + 0.9375rem); }\n  .medium-offset-3 {\n    margin-right: 25%; }\n  .grid-margin-x > .medium-offset-3 {\n    margin-right: calc(25% + 0.9375rem); }\n  .medium-offset-4 {\n    margin-right: 33.33333%; }\n  .grid-margin-x > .medium-offset-4 {\n    margin-right: calc(33.33333% + 0.9375rem); }\n  .medium-offset-5 {\n    margin-right: 41.66667%; }\n  .grid-margin-x > .medium-offset-5 {\n    margin-right: calc(41.66667% + 0.9375rem); }\n  .medium-offset-6 {\n    margin-right: 50%; }\n  .grid-margin-x > .medium-offset-6 {\n    margin-right: calc(50% + 0.9375rem); }\n  .medium-offset-7 {\n    margin-right: 58.33333%; }\n  .grid-margin-x > .medium-offset-7 {\n    margin-right: calc(58.33333% + 0.9375rem); }\n  .medium-offset-8 {\n    margin-right: 66.66667%; }\n  .grid-margin-x > .medium-offset-8 {\n    margin-right: calc(66.66667% + 0.9375rem); }\n  .medium-offset-9 {\n    margin-right: 75%; }\n  .grid-margin-x > .medium-offset-9 {\n    margin-right: calc(75% + 0.9375rem); }\n  .medium-offset-10 {\n    margin-right: 83.33333%; }\n  .grid-margin-x > .medium-offset-10 {\n    margin-right: calc(83.33333% + 0.9375rem); }\n  .medium-offset-11 {\n    margin-right: 91.66667%; }\n  .grid-margin-x > .medium-offset-11 {\n    margin-right: calc(91.66667% + 0.9375rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .large-offset-0 {\n    margin-right: 0%; }\n  .grid-margin-x > .large-offset-0 {\n    margin-right: calc(0% + 0.9375rem); }\n  .large-offset-1 {\n    margin-right: 8.33333%; }\n  .grid-margin-x > .large-offset-1 {\n    margin-right: calc(8.33333% + 0.9375rem); }\n  .large-offset-2 {\n    margin-right: 16.66667%; }\n  .grid-margin-x > .large-offset-2 {\n    margin-right: calc(16.66667% + 0.9375rem); }\n  .large-offset-3 {\n    margin-right: 25%; }\n  .grid-margin-x > .large-offset-3 {\n    margin-right: calc(25% + 0.9375rem); }\n  .large-offset-4 {\n    margin-right: 33.33333%; }\n  .grid-margin-x > .large-offset-4 {\n    margin-right: calc(33.33333% + 0.9375rem); }\n  .large-offset-5 {\n    margin-right: 41.66667%; }\n  .grid-margin-x > .large-offset-5 {\n    margin-right: calc(41.66667% + 0.9375rem); }\n  .large-offset-6 {\n    margin-right: 50%; }\n  .grid-margin-x > .large-offset-6 {\n    margin-right: calc(50% + 0.9375rem); }\n  .large-offset-7 {\n    margin-right: 58.33333%; }\n  .grid-margin-x > .large-offset-7 {\n    margin-right: calc(58.33333% + 0.9375rem); }\n  .large-offset-8 {\n    margin-right: 66.66667%; }\n  .grid-margin-x > .large-offset-8 {\n    margin-right: calc(66.66667% + 0.9375rem); }\n  .large-offset-9 {\n    margin-right: 75%; }\n  .grid-margin-x > .large-offset-9 {\n    margin-right: calc(75% + 0.9375rem); }\n  .large-offset-10 {\n    margin-right: 83.33333%; }\n  .grid-margin-x > .large-offset-10 {\n    margin-right: calc(83.33333% + 0.9375rem); }\n  .large-offset-11 {\n    margin-right: 91.66667%; }\n  .grid-margin-x > .large-offset-11 {\n    margin-right: calc(91.66667% + 0.9375rem); } }\n\n.grid-y {\n  display: flex;\n  flex-flow: column nowrap; }\n  .grid-y > .cell {\n    width: auto;\n    max-width: none; }\n  .grid-y > .auto {\n    height: auto; }\n  .grid-y > .shrink {\n    height: auto; }\n  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {\n    flex-basis: auto; }\n  @media print, screen and (min-width: 40em) {\n    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {\n      flex-basis: auto; } }\n  @media print, screen and (min-width: 64em) {\n    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {\n      flex-basis: auto; } }\n  .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {\n    flex: 0 0 auto; }\n  .grid-y > .small-1 {\n    height: 8.33333%; }\n  .grid-y > .small-2 {\n    height: 16.66667%; }\n  .grid-y > .small-3 {\n    height: 25%; }\n  .grid-y > .small-4 {\n    height: 33.33333%; }\n  .grid-y > .small-5 {\n    height: 41.66667%; }\n  .grid-y > .small-6 {\n    height: 50%; }\n  .grid-y > .small-7 {\n    height: 58.33333%; }\n  .grid-y > .small-8 {\n    height: 66.66667%; }\n  .grid-y > .small-9 {\n    height: 75%; }\n  .grid-y > .small-10 {\n    height: 83.33333%; }\n  .grid-y > .small-11 {\n    height: 91.66667%; }\n  .grid-y > .small-12 {\n    height: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .grid-y > .medium-auto {\n      flex: 1 1 0px;\n      height: auto; }\n    .grid-y > .medium-shrink, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {\n      flex: 0 0 auto; }\n    .grid-y > .medium-shrink {\n      height: auto; }\n    .grid-y > .medium-1 {\n      height: 8.33333%; }\n    .grid-y > .medium-2 {\n      height: 16.66667%; }\n    .grid-y > .medium-3 {\n      height: 25%; }\n    .grid-y > .medium-4 {\n      height: 33.33333%; }\n    .grid-y > .medium-5 {\n      height: 41.66667%; }\n    .grid-y > .medium-6 {\n      height: 50%; }\n    .grid-y > .medium-7 {\n      height: 58.33333%; }\n    .grid-y > .medium-8 {\n      height: 66.66667%; }\n    .grid-y > .medium-9 {\n      height: 75%; }\n    .grid-y > .medium-10 {\n      height: 83.33333%; }\n    .grid-y > .medium-11 {\n      height: 91.66667%; }\n    .grid-y > .medium-12 {\n      height: 100%; } }\n  @media print, screen and (min-width: 64em) {\n    .grid-y > .large-auto {\n      flex: 1 1 0px;\n      height: auto; }\n    .grid-y > .large-shrink, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {\n      flex: 0 0 auto; }\n    .grid-y > .large-shrink {\n      height: auto; }\n    .grid-y > .large-1 {\n      height: 8.33333%; }\n    .grid-y > .large-2 {\n      height: 16.66667%; }\n    .grid-y > .large-3 {\n      height: 25%; }\n    .grid-y > .large-4 {\n      height: 33.33333%; }\n    .grid-y > .large-5 {\n      height: 41.66667%; }\n    .grid-y > .large-6 {\n      height: 50%; }\n    .grid-y > .large-7 {\n      height: 58.33333%; }\n    .grid-y > .large-8 {\n      height: 66.66667%; }\n    .grid-y > .large-9 {\n      height: 75%; }\n    .grid-y > .large-10 {\n      height: 83.33333%; }\n    .grid-y > .large-11 {\n      height: 91.66667%; }\n    .grid-y > .large-12 {\n      height: 100%; } }\n\n.grid-padding-y .grid-padding-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-y .grid-padding-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n\n.grid-padding-y > .cell {\n  padding-top: 0.625rem;\n  padding-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-y > .cell {\n      padding-top: 0.9375rem;\n      padding-bottom: 0.9375rem; } }\n\n.grid-margin-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n  .grid-margin-y > .cell {\n    height: calc(100% - 1.25rem);\n    margin-top: 0.625rem;\n    margin-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .cell {\n      height: calc(100% - 1.875rem);\n      margin-top: 0.9375rem;\n      margin-bottom: 0.9375rem; } }\n  .grid-margin-y > .auto {\n    height: auto; }\n  .grid-margin-y > .shrink {\n    height: auto; }\n  .grid-margin-y > .small-1 {\n    height: calc(8.33333% - 1.25rem); }\n  .grid-margin-y > .small-2 {\n    height: calc(16.66667% - 1.25rem); }\n  .grid-margin-y > .small-3 {\n    height: calc(25% - 1.25rem); }\n  .grid-margin-y > .small-4 {\n    height: calc(33.33333% - 1.25rem); }\n  .grid-margin-y > .small-5 {\n    height: calc(41.66667% - 1.25rem); }\n  .grid-margin-y > .small-6 {\n    height: calc(50% - 1.25rem); }\n  .grid-margin-y > .small-7 {\n    height: calc(58.33333% - 1.25rem); }\n  .grid-margin-y > .small-8 {\n    height: calc(66.66667% - 1.25rem); }\n  .grid-margin-y > .small-9 {\n    height: calc(75% - 1.25rem); }\n  .grid-margin-y > .small-10 {\n    height: calc(83.33333% - 1.25rem); }\n  .grid-margin-y > .small-11 {\n    height: calc(91.66667% - 1.25rem); }\n  .grid-margin-y > .small-12 {\n    height: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .auto {\n      height: auto; }\n    .grid-margin-y > .shrink {\n      height: auto; }\n    .grid-margin-y > .small-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .small-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .small-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .small-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .small-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .small-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .small-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .small-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .small-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .small-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .small-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .small-12 {\n      height: calc(100% - 1.875rem); }\n    .grid-margin-y > .medium-auto {\n      height: auto; }\n    .grid-margin-y > .medium-shrink {\n      height: auto; }\n    .grid-margin-y > .medium-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .medium-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .medium-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .medium-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .medium-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .medium-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .medium-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .medium-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .medium-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .medium-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .medium-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .medium-12 {\n      height: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-y > .large-auto {\n      height: auto; }\n    .grid-margin-y > .large-shrink {\n      height: auto; }\n    .grid-margin-y > .large-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .large-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .large-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .large-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .large-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .large-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .large-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .large-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .large-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .large-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .large-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .large-12 {\n      height: calc(100% - 1.875rem); } }\n\n.grid-frame {\n  overflow: hidden;\n  position: relative;\n  flex-wrap: nowrap;\n  align-items: stretch;\n  width: 100vw; }\n\n.cell .grid-frame {\n  width: 100%; }\n\n.cell-block {\n  overflow-x: auto;\n  max-width: 100%;\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar; }\n\n.cell-block-y {\n  overflow-y: auto;\n  max-height: 100%;\n  min-height: 100%;\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar; }\n\n.cell-block-container {\n  display: flex;\n  flex-direction: column;\n  max-height: 100%; }\n  .cell-block-container > .grid-x {\n    max-height: 100%;\n    flex-wrap: nowrap; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-grid-frame {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    width: 100vw; }\n  .cell .medium-grid-frame {\n    width: 100%; }\n  .medium-cell-block {\n    overflow-x: auto;\n    max-width: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; }\n  .medium-cell-block-container {\n    display: flex;\n    flex-direction: column;\n    max-height: 100%; }\n    .medium-cell-block-container > .grid-x {\n      max-height: 100%;\n      flex-wrap: nowrap; }\n  .medium-cell-block-y {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-grid-frame {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    width: 100vw; }\n  .cell .large-grid-frame {\n    width: 100%; }\n  .large-cell-block {\n    overflow-x: auto;\n    max-width: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; }\n  .large-cell-block-container {\n    display: flex;\n    flex-direction: column;\n    max-height: 100%; }\n    .large-cell-block-container > .grid-x {\n      max-height: 100%;\n      flex-wrap: nowrap; }\n  .large-cell-block-y {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; } }\n\n.grid-y.grid-frame {\n  width: auto;\n  overflow: hidden;\n  position: relative;\n  flex-wrap: nowrap;\n  align-items: stretch;\n  height: 100vh; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-y.medium-grid-frame {\n    width: auto;\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    height: 100vh; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-y.large-grid-frame {\n    width: auto;\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    height: 100vh; } }\n\n.cell .grid-y.grid-frame {\n  height: 100%; }\n\n@media print, screen and (min-width: 40em) {\n  .cell .grid-y.medium-grid-frame {\n    height: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .cell .grid-y.large-grid-frame {\n    height: 100%; } }\n\n.grid-margin-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n  .grid-margin-y > .cell {\n    height: calc(100% - 1.25rem);\n    margin-top: 0.625rem;\n    margin-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .cell {\n      height: calc(100% - 1.875rem);\n      margin-top: 0.9375rem;\n      margin-bottom: 0.9375rem; } }\n  .grid-margin-y > .auto {\n    height: auto; }\n  .grid-margin-y > .shrink {\n    height: auto; }\n  .grid-margin-y > .small-1 {\n    height: calc(8.33333% - 1.25rem); }\n  .grid-margin-y > .small-2 {\n    height: calc(16.66667% - 1.25rem); }\n  .grid-margin-y > .small-3 {\n    height: calc(25% - 1.25rem); }\n  .grid-margin-y > .small-4 {\n    height: calc(33.33333% - 1.25rem); }\n  .grid-margin-y > .small-5 {\n    height: calc(41.66667% - 1.25rem); }\n  .grid-margin-y > .small-6 {\n    height: calc(50% - 1.25rem); }\n  .grid-margin-y > .small-7 {\n    height: calc(58.33333% - 1.25rem); }\n  .grid-margin-y > .small-8 {\n    height: calc(66.66667% - 1.25rem); }\n  .grid-margin-y > .small-9 {\n    height: calc(75% - 1.25rem); }\n  .grid-margin-y > .small-10 {\n    height: calc(83.33333% - 1.25rem); }\n  .grid-margin-y > .small-11 {\n    height: calc(91.66667% - 1.25rem); }\n  .grid-margin-y > .small-12 {\n    height: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .auto {\n      height: auto; }\n    .grid-margin-y > .shrink {\n      height: auto; }\n    .grid-margin-y > .small-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .small-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .small-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .small-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .small-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .small-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .small-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .small-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .small-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .small-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .small-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .small-12 {\n      height: calc(100% - 1.875rem); }\n    .grid-margin-y > .medium-auto {\n      height: auto; }\n    .grid-margin-y > .medium-shrink {\n      height: auto; }\n    .grid-margin-y > .medium-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .medium-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .medium-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .medium-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .medium-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .medium-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .medium-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .medium-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .medium-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .medium-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .medium-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .medium-12 {\n      height: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-y > .large-auto {\n      height: auto; }\n    .grid-margin-y > .large-shrink {\n      height: auto; }\n    .grid-margin-y > .large-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .large-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .large-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .large-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .large-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .large-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .large-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .large-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .large-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .large-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .large-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .large-12 {\n      height: calc(100% - 1.875rem); } }\n\n.grid-frame.grid-margin-y {\n  height: calc(100vh + 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-frame.grid-margin-y {\n      height: calc(100vh + 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-frame.grid-margin-y {\n      height: calc(100vh + 1.875rem); } }\n\n@media print, screen and (min-width: 40em) {\n  .grid-margin-y.medium-grid-frame {\n    height: calc(100vh + 1.875rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-margin-y.large-grid-frame {\n    height: calc(100vh + 1.875rem); } }\n\n.button {\n  display: inline-block;\n  vertical-align: middle;\n  margin: 0 0 1rem 0;\n  padding: 0.85em 1em;\n  border: 1px solid transparent;\n  border-radius: 0;\n  transition: background-color 0.25s ease-out, color 0.25s ease-out;\n  font-family: inherit;\n  font-size: 0.9rem;\n  -webkit-appearance: none;\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n  background-color: #1779ba;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .button {\n    outline: 0; }\n  .button:hover, .button:focus {\n    background-color: #14679e;\n    color: #fefefe; }\n  .button.tiny {\n    font-size: 0.6rem; }\n  .button.small {\n    font-size: 0.75rem; }\n  .button.large {\n    font-size: 1.25rem; }\n  .button.expanded {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0; }\n  .button.primary {\n    background-color: #1779ba;\n    color: #fefefe; }\n    .button.primary:hover, .button.primary:focus {\n      background-color: #126195;\n      color: #fefefe; }\n  .button.secondary {\n    background-color: #767676;\n    color: #fefefe; }\n    .button.secondary:hover, .button.secondary:focus {\n      background-color: #5e5e5e;\n      color: #fefefe; }\n  .button.success {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n    .button.success:hover, .button.success:focus {\n      background-color: #22bb5b;\n      color: #0a0a0a; }\n  .button.warning {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n    .button.warning:hover, .button.warning:focus {\n      background-color: #cc8b00;\n      color: #0a0a0a; }\n  .button.alert {\n    background-color: #cc4b37;\n    color: #fefefe; }\n    .button.alert:hover, .button.alert:focus {\n      background-color: #a53b2a;\n      color: #fefefe; }\n  .button.disabled, .button[disabled] {\n    opacity: 0.25;\n    cursor: not-allowed; }\n    .button.disabled, .button.disabled:hover, .button.disabled:focus, .button[disabled], .button[disabled]:hover, .button[disabled]:focus {\n      background-color: #1779ba;\n      color: #fefefe; }\n    .button.disabled.primary, .button[disabled].primary {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.primary, .button.disabled.primary:hover, .button.disabled.primary:focus, .button[disabled].primary, .button[disabled].primary:hover, .button[disabled].primary:focus {\n        background-color: #1779ba;\n        color: #fefefe; }\n    .button.disabled.secondary, .button[disabled].secondary {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.secondary, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary, .button[disabled].secondary:hover, .button[disabled].secondary:focus {\n        background-color: #767676;\n        color: #fefefe; }\n    .button.disabled.success, .button[disabled].success {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.success, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success, .button[disabled].success:hover, .button[disabled].success:focus {\n        background-color: #3adb76;\n        color: #0a0a0a; }\n    .button.disabled.warning, .button[disabled].warning {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.warning, .button.disabled.warning:hover, .button.disabled.warning:focus, .button[disabled].warning, .button[disabled].warning:hover, .button[disabled].warning:focus {\n        background-color: #ffae00;\n        color: #0a0a0a; }\n    .button.disabled.alert, .button[disabled].alert {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.alert, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert, .button[disabled].alert:hover, .button[disabled].alert:focus {\n        background-color: #cc4b37;\n        color: #fefefe; }\n  .button.hollow {\n    border: 1px solid #1779ba;\n    color: #1779ba; }\n    .button.hollow, .button.hollow:hover, .button.hollow:focus {\n      background-color: transparent; }\n    .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {\n      background-color: transparent; }\n    .button.hollow:hover, .button.hollow:focus {\n      border-color: #0c3d5d;\n      color: #0c3d5d; }\n      .button.hollow:hover.disabled, .button.hollow:hover[disabled], .button.hollow:focus.disabled, .button.hollow:focus[disabled] {\n        border: 1px solid #1779ba;\n        color: #1779ba; }\n    .button.hollow.primary {\n      border: 1px solid #1779ba;\n      color: #1779ba; }\n      .button.hollow.primary:hover, .button.hollow.primary:focus {\n        border-color: #0c3d5d;\n        color: #0c3d5d; }\n        .button.hollow.primary:hover.disabled, .button.hollow.primary:hover[disabled], .button.hollow.primary:focus.disabled, .button.hollow.primary:focus[disabled] {\n          border: 1px solid #1779ba;\n          color: #1779ba; }\n    .button.hollow.secondary {\n      border: 1px solid #767676;\n      color: #767676; }\n      .button.hollow.secondary:hover, .button.hollow.secondary:focus {\n        border-color: #3b3b3b;\n        color: #3b3b3b; }\n        .button.hollow.secondary:hover.disabled, .button.hollow.secondary:hover[disabled], .button.hollow.secondary:focus.disabled, .button.hollow.secondary:focus[disabled] {\n          border: 1px solid #767676;\n          color: #767676; }\n    .button.hollow.success {\n      border: 1px solid #3adb76;\n      color: #3adb76; }\n      .button.hollow.success:hover, .button.hollow.success:focus {\n        border-color: #157539;\n        color: #157539; }\n        .button.hollow.success:hover.disabled, .button.hollow.success:hover[disabled], .button.hollow.success:focus.disabled, .button.hollow.success:focus[disabled] {\n          border: 1px solid #3adb76;\n          color: #3adb76; }\n    .button.hollow.warning {\n      border: 1px solid #ffae00;\n      color: #ffae00; }\n      .button.hollow.warning:hover, .button.hollow.warning:focus {\n        border-color: #805700;\n        color: #805700; }\n        .button.hollow.warning:hover.disabled, .button.hollow.warning:hover[disabled], .button.hollow.warning:focus.disabled, .button.hollow.warning:focus[disabled] {\n          border: 1px solid #ffae00;\n          color: #ffae00; }\n    .button.hollow.alert {\n      border: 1px solid #cc4b37;\n      color: #cc4b37; }\n      .button.hollow.alert:hover, .button.hollow.alert:focus {\n        border-color: #67251a;\n        color: #67251a; }\n        .button.hollow.alert:hover.disabled, .button.hollow.alert:hover[disabled], .button.hollow.alert:focus.disabled, .button.hollow.alert:focus[disabled] {\n          border: 1px solid #cc4b37;\n          color: #cc4b37; }\n  .button.clear {\n    border: 1px solid #1779ba;\n    color: #1779ba; }\n    .button.clear, .button.clear:hover, .button.clear:focus {\n      background-color: transparent; }\n    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {\n      background-color: transparent; }\n    .button.clear:hover, .button.clear:focus {\n      border-color: #0c3d5d;\n      color: #0c3d5d; }\n      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {\n        border: 1px solid #1779ba;\n        color: #1779ba; }\n    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {\n      border-color: transparent; }\n    .button.clear.primary {\n      border: 1px solid #1779ba;\n      color: #1779ba; }\n      .button.clear.primary:hover, .button.clear.primary:focus {\n        border-color: #0c3d5d;\n        color: #0c3d5d; }\n        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {\n          border: 1px solid #1779ba;\n          color: #1779ba; }\n      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.secondary {\n      border: 1px solid #767676;\n      color: #767676; }\n      .button.clear.secondary:hover, .button.clear.secondary:focus {\n        border-color: #3b3b3b;\n        color: #3b3b3b; }\n        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {\n          border: 1px solid #767676;\n          color: #767676; }\n      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.success {\n      border: 1px solid #3adb76;\n      color: #3adb76; }\n      .button.clear.success:hover, .button.clear.success:focus {\n        border-color: #157539;\n        color: #157539; }\n        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {\n          border: 1px solid #3adb76;\n          color: #3adb76; }\n      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.warning {\n      border: 1px solid #ffae00;\n      color: #ffae00; }\n      .button.clear.warning:hover, .button.clear.warning:focus {\n        border-color: #805700;\n        color: #805700; }\n        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {\n          border: 1px solid #ffae00;\n          color: #ffae00; }\n      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.alert {\n      border: 1px solid #cc4b37;\n      color: #cc4b37; }\n      .button.clear.alert:hover, .button.clear.alert:focus {\n        border-color: #67251a;\n        color: #67251a; }\n        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {\n          border: 1px solid #cc4b37;\n          color: #cc4b37; }\n      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {\n        border-color: transparent; }\n  .button.dropdown::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.4em;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #fefefe transparent transparent;\n    position: relative;\n    top: 0.4em;\n    display: inline-block;\n    float: left;\n    margin-right: 1em; }\n  .button.dropdown.hollow::after, .button.dropdown.clear::after {\n    border-top-color: #1779ba; }\n  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {\n    border-top-color: #1779ba; }\n  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {\n    border-top-color: #767676; }\n  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {\n    border-top-color: #3adb76; }\n  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {\n    border-top-color: #ffae00; }\n  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {\n    border-top-color: #cc4b37; }\n  .button.arrow-only::after {\n    top: -0.1em;\n    float: none;\n    margin-right: 0; }\n\na.button:hover, a.button:focus {\n  text-decoration: none; }\n\n.button-group {\n  margin-bottom: 1rem;\n  display: flex;\n  flex-wrap: nowrap;\n  align-items: stretch; }\n  .button-group::before, .button-group::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .button-group::after {\n    clear: both; }\n  .button-group .button {\n    margin: 0;\n    margin-left: 1px;\n    margin-bottom: 1px;\n    font-size: 0.9rem;\n    flex: 0 0 auto; }\n    .button-group .button:last-child {\n      margin-left: 0; }\n  .button-group.tiny .button {\n    font-size: 0.6rem; }\n  .button-group.small .button {\n    font-size: 0.75rem; }\n  .button-group.large .button {\n    font-size: 1.25rem; }\n  .button-group.expanded .button {\n    flex: 1 1 0px; }\n  .button-group.primary .button {\n    background-color: #1779ba;\n    color: #fefefe; }\n    .button-group.primary .button:hover, .button-group.primary .button:focus {\n      background-color: #126195;\n      color: #fefefe; }\n  .button-group.secondary .button {\n    background-color: #767676;\n    color: #fefefe; }\n    .button-group.secondary .button:hover, .button-group.secondary .button:focus {\n      background-color: #5e5e5e;\n      color: #fefefe; }\n  .button-group.success .button {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n    .button-group.success .button:hover, .button-group.success .button:focus {\n      background-color: #22bb5b;\n      color: #0a0a0a; }\n  .button-group.warning .button {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n    .button-group.warning .button:hover, .button-group.warning .button:focus {\n      background-color: #cc8b00;\n      color: #0a0a0a; }\n  .button-group.alert .button {\n    background-color: #cc4b37;\n    color: #fefefe; }\n    .button-group.alert .button:hover, .button-group.alert .button:focus {\n      background-color: #a53b2a;\n      color: #fefefe; }\n  .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium {\n    flex-wrap: wrap; }\n    .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {\n      flex: 0 0 100%; }\n      .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {\n        margin-bottom: 0; }\n    .button-group.stacked.expanded .button, .button-group.stacked-for-small.expanded .button, .button-group.stacked-for-medium.expanded .button {\n      flex: 1 1 0px; }\n  @media print, screen and (min-width: 40em) {\n    .button-group.stacked-for-small .button {\n      flex: 0 0 auto;\n      margin-bottom: 0; } }\n  @media print, screen and (min-width: 64em) {\n    .button-group.stacked-for-medium .button {\n      flex: 0 0 auto;\n      margin-bottom: 0; } }\n  @media screen and (max-width: 39.99875em) {\n    .button-group.stacked-for-small.expanded {\n      display: block; }\n      .button-group.stacked-for-small.expanded .button {\n        display: block;\n        margin-left: 0; } }\n  @media screen and (max-width: 63.99875em) {\n    .button-group.stacked-for-medium.expanded {\n      display: block; }\n      .button-group.stacked-for-medium.expanded .button {\n        display: block;\n        margin-left: 0; } }\n\n.close-button {\n  position: absolute;\n  color: #8a8a8a;\n  cursor: pointer; }\n  [data-whatinput='mouse'] .close-button {\n    outline: 0; }\n  .close-button:hover, .close-button:focus {\n    color: #0a0a0a; }\n  .close-button.small {\n    right: 0.66rem;\n    top: 0.33em;\n    font-size: 1.5em;\n    line-height: 1; }\n  .close-button, .close-button.medium {\n    right: 1rem;\n    top: 0.5rem;\n    font-size: 2em;\n    line-height: 1; }\n\n.label {\n  display: inline-block;\n  padding: 0.33333rem 0.5rem;\n  border-radius: 0;\n  font-size: 0.8rem;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n  background: #1779ba;\n  color: #fefefe; }\n  .label.primary {\n    background: #1779ba;\n    color: #fefefe; }\n  .label.secondary {\n    background: #767676;\n    color: #fefefe; }\n  .label.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .label.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .label.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.progress {\n  height: 1rem;\n  margin-bottom: 1rem;\n  border-radius: 0;\n  background-color: #cacaca; }\n  .progress.primary .progress-meter {\n    background-color: #1779ba; }\n  .progress.secondary .progress-meter {\n    background-color: #767676; }\n  .progress.success .progress-meter {\n    background-color: #3adb76; }\n  .progress.warning .progress-meter {\n    background-color: #ffae00; }\n  .progress.alert .progress-meter {\n    background-color: #cc4b37; }\n\n.progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: #1779ba; }\n\n.progress-meter-text {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #fefefe;\n  white-space: nowrap; }\n\n.slider {\n  position: relative;\n  height: 0.5rem;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n  background-color: #e6e6e6;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none; }\n\n.slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: inline-block;\n  max-width: 100%;\n  height: 0.5rem;\n  background-color: #cacaca;\n  transition: all 0.2s ease-in-out; }\n  .slider-fill.is-dragging {\n    transition: all 0s linear; }\n\n.slider-handle {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  left: 0;\n  z-index: 1;\n  display: inline-block;\n  width: 1.4rem;\n  height: 1.4rem;\n  border-radius: 0;\n  background-color: #1779ba;\n  transition: all 0.2s ease-in-out;\n  touch-action: manipulation; }\n  [data-whatinput='mouse'] .slider-handle {\n    outline: 0; }\n  .slider-handle:hover {\n    background-color: #14679e; }\n  .slider-handle.is-dragging {\n    transition: all 0s linear; }\n\n.slider.disabled,\n.slider[disabled] {\n  opacity: 0.25;\n  cursor: not-allowed; }\n\n.slider.vertical {\n  display: inline-block;\n  width: 0.5rem;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1); }\n  .slider.vertical .slider-fill {\n    top: 0;\n    width: 0.5rem;\n    max-height: 100%; }\n  .slider.vertical .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: 1.4rem;\n    height: 1.4rem;\n    transform: translateX(-50%); }\n\n.slider:not(.vertical) {\n  transform: scale(-1, 1); }\n\n.switch {\n  height: 2rem;\n  position: relative;\n  margin-bottom: 1rem;\n  outline: 0;\n  font-size: 0.875rem;\n  font-weight: bold;\n  color: #fefefe;\n  user-select: none; }\n\n.switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0; }\n\n.switch-paddle {\n  position: relative;\n  display: block;\n  width: 4rem;\n  height: 2rem;\n  border-radius: 0;\n  background: #cacaca;\n  transition: all 0.25s ease-out;\n  font-weight: inherit;\n  color: inherit;\n  cursor: pointer; }\n  input + .switch-paddle {\n    margin: 0; }\n  .switch-paddle::after {\n    position: absolute;\n    top: 0.25rem;\n    right: 0.25rem;\n    display: block;\n    width: 1.5rem;\n    height: 1.5rem;\n    transform: translate3d(0, 0, 0);\n    border-radius: 0;\n    background: #fefefe;\n    transition: all 0.25s ease-out;\n    content: ''; }\n  input:checked ~ .switch-paddle {\n    background: #1779ba; }\n    input:checked ~ .switch-paddle::after {\n      right: 2.25rem; }\n  [data-whatinput='mouse'] input:focus ~ .switch-paddle {\n    outline: 0; }\n\n.switch-active, .switch-inactive {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%); }\n\n.switch-active {\n  right: 8%;\n  display: none; }\n  input:checked + label > .switch-active {\n    display: block; }\n\n.switch-inactive {\n  left: 15%; }\n  input:checked + label > .switch-inactive {\n    display: none; }\n\n.switch.tiny {\n  height: 1.5rem; }\n  .switch.tiny .switch-paddle {\n    width: 3rem;\n    height: 1.5rem;\n    font-size: 0.625rem; }\n  .switch.tiny .switch-paddle::after {\n    top: 0.25rem;\n    right: 0.25rem;\n    width: 1rem;\n    height: 1rem; }\n  .switch.tiny input:checked ~ .switch-paddle::after {\n    right: 1.75rem; }\n\n.switch.small {\n  height: 1.75rem; }\n  .switch.small .switch-paddle {\n    width: 3.5rem;\n    height: 1.75rem;\n    font-size: 0.75rem; }\n  .switch.small .switch-paddle::after {\n    top: 0.25rem;\n    right: 0.25rem;\n    width: 1.25rem;\n    height: 1.25rem; }\n  .switch.small input:checked ~ .switch-paddle::after {\n    right: 2rem; }\n\n.switch.large {\n  height: 2.5rem; }\n  .switch.large .switch-paddle {\n    width: 5rem;\n    height: 2.5rem;\n    font-size: 1rem; }\n  .switch.large .switch-paddle::after {\n    top: 0.25rem;\n    right: 0.25rem;\n    width: 2rem;\n    height: 2rem; }\n  .switch.large input:checked ~ .switch-paddle::after {\n    right: 2.75rem; }\n\ntable {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: 1rem;\n  border-radius: 0; }\n  thead,\n  tbody,\n  tfoot {\n    border: 1px solid #f1f1f1;\n    background-color: #fefefe; }\n  caption {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold; }\n  thead {\n    background: #f8f8f8;\n    color: #0a0a0a; }\n  tfoot {\n    background: #f1f1f1;\n    color: #0a0a0a; }\n  thead tr,\n  tfoot tr {\n    background: transparent; }\n  thead th,\n  thead td,\n  tfoot th,\n  tfoot td {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold;\n    text-align: right; }\n  tbody th,\n  tbody td {\n    padding: 0.5rem 0.625rem 0.625rem; }\n  tbody tr:nth-child(even) {\n    border-bottom: 0;\n    background-color: #f1f1f1; }\n  table.unstriped tbody {\n    background-color: #fefefe; }\n    table.unstriped tbody tr {\n      border-bottom: 0;\n      border-bottom: 1px solid #f1f1f1;\n      background-color: #fefefe; }\n\n@media screen and (max-width: 63.99875em) {\n  table.stack thead {\n    display: none; }\n  table.stack tfoot {\n    display: none; }\n  table.stack tr,\n  table.stack th,\n  table.stack td {\n    display: block; }\n  table.stack td {\n    border-top: 0; } }\n\ntable.scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto; }\n\ntable.hover thead tr:hover {\n  background-color: #f3f3f3; }\n\ntable.hover tfoot tr:hover {\n  background-color: #ececec; }\n\ntable.hover tbody tr:hover {\n  background-color: #f9f9f9; }\n\ntable.hover:not(.unstriped) tr:nth-of-type(even):hover {\n  background-color: #ececec; }\n\n.table-scroll {\n  overflow-x: auto; }\n\n.badge {\n  display: inline-block;\n  min-width: 2.1em;\n  padding: 0.3em;\n  border-radius: 50%;\n  font-size: 0.6rem;\n  text-align: center;\n  background: #1779ba;\n  color: #fefefe; }\n  .badge.primary {\n    background: #1779ba;\n    color: #fefefe; }\n  .badge.secondary {\n    background: #767676;\n    color: #fefefe; }\n  .badge.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .badge.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .badge.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.breadcrumbs {\n  margin: 0 0 1rem 0;\n  list-style: none; }\n  .breadcrumbs::before, .breadcrumbs::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .breadcrumbs::after {\n    clear: both; }\n  .breadcrumbs li {\n    float: right;\n    font-size: 0.6875rem;\n    color: #0a0a0a;\n    cursor: default;\n    text-transform: uppercase; }\n    .breadcrumbs li:not(:last-child)::after {\n      position: relative;\n      margin: 0 0.75rem;\n      opacity: 1;\n      content: \"\\\\\";\n      color: #cacaca; }\n  .breadcrumbs a {\n    color: #1779ba; }\n    .breadcrumbs a:hover {\n      text-decoration: underline; }\n  .breadcrumbs .disabled {\n    color: #cacaca;\n    cursor: not-allowed; }\n\n.callout {\n  position: relative;\n  margin: 0 0 1rem 0;\n  padding: 1rem;\n  border: 1px solid rgba(10, 10, 10, 0.25);\n  border-radius: 0;\n  background-color: white;\n  color: #0a0a0a; }\n  .callout > :first-child {\n    margin-top: 0; }\n  .callout > :last-child {\n    margin-bottom: 0; }\n  .callout.primary {\n    background-color: #d7ecfa;\n    color: #0a0a0a; }\n  .callout.secondary {\n    background-color: #eaeaea;\n    color: #0a0a0a; }\n  .callout.success {\n    background-color: #e1faea;\n    color: #0a0a0a; }\n  .callout.warning {\n    background-color: #fff3d9;\n    color: #0a0a0a; }\n  .callout.alert {\n    background-color: #f7e4e1;\n    color: #0a0a0a; }\n  .callout.small {\n    padding-top: 0.5rem;\n    padding-right: 0.5rem;\n    padding-bottom: 0.5rem;\n    padding-left: 0.5rem; }\n  .callout.large {\n    padding-top: 3rem;\n    padding-right: 3rem;\n    padding-bottom: 3rem;\n    padding-left: 3rem; }\n\n.card {\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n  margin-bottom: 1rem;\n  border: 1px solid #e6e6e6;\n  border-radius: 0;\n  background: #fefefe;\n  box-shadow: none;\n  overflow: hidden;\n  color: #0a0a0a; }\n  .card > :last-child {\n    margin-bottom: 0; }\n\n.card-divider {\n  display: flex;\n  flex: 0 1 auto;\n  padding: 1rem;\n  background: #e6e6e6; }\n  .card-divider > :last-child {\n    margin-bottom: 0; }\n\n.card-section {\n  flex: 1 0 auto;\n  padding: 1rem; }\n  .card-section > :last-child {\n    margin-bottom: 0; }\n\n.card-image {\n  min-height: 1px; }\n\n.dropdown-pane {\n  position: absolute;\n  z-index: 10;\n  display: none;\n  width: 300px;\n  padding: 1rem;\n  visibility: hidden;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-size: 1rem; }\n  .dropdown-pane.is-opening {\n    display: block; }\n  .dropdown-pane.is-open {\n    display: block;\n    visibility: visible; }\n\n.dropdown-pane.tiny {\n  width: 100px; }\n\n.dropdown-pane.small {\n  width: 200px; }\n\n.dropdown-pane.large {\n  width: 400px; }\n\n.pagination {\n  margin-right: 0;\n  margin-bottom: 1rem; }\n  .pagination::before, .pagination::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .pagination::after {\n    clear: both; }\n  .pagination li {\n    margin-left: 0.0625rem;\n    border-radius: 0;\n    font-size: 0.875rem;\n    display: none; }\n    .pagination li:last-child, .pagination li:first-child {\n      display: inline-block; }\n    @media print, screen and (min-width: 40em) {\n      .pagination li {\n        display: inline-block; } }\n  .pagination a,\n  .pagination button {\n    display: block;\n    padding: 0.1875rem 0.625rem;\n    border-radius: 0;\n    color: #0a0a0a; }\n    .pagination a:hover,\n    .pagination button:hover {\n      background: #e6e6e6; }\n  .pagination .current {\n    padding: 0.1875rem 0.625rem;\n    background: #1779ba;\n    color: #fefefe;\n    cursor: default; }\n  .pagination .disabled {\n    padding: 0.1875rem 0.625rem;\n    color: #cacaca;\n    cursor: not-allowed; }\n    .pagination .disabled:hover {\n      background: transparent; }\n  .pagination .ellipsis::after {\n    padding: 0.1875rem 0.625rem;\n    content: '\\2026';\n    color: #0a0a0a; }\n\n.pagination-previous a::before,\n.pagination-previous.disabled::before {\n  display: inline-block;\n  margin-left: 0.5rem;\n  content: '\\00ab'; }\n\n.pagination-next a::after,\n.pagination-next.disabled::after {\n  display: inline-block;\n  margin-right: 0.5rem;\n  content: '\\00bb'; }\n\n.has-tip {\n  position: relative;\n  display: inline-block;\n  border-bottom: dotted 1px #8a8a8a;\n  font-weight: bold;\n  cursor: help; }\n\n.tooltip {\n  position: absolute;\n  top: calc(100% + 0.6495rem);\n  z-index: 1200;\n  max-width: 10rem;\n  padding: 0.75rem;\n  border-radius: 0;\n  background-color: #0a0a0a;\n  font-size: 80%;\n  color: #fefefe; }\n  .tooltip::before {\n    position: absolute; }\n  .tooltip.bottom::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent #0a0a0a;\n    bottom: 100%; }\n  .tooltip.bottom.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.top::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #0a0a0a transparent transparent;\n    top: 100%;\n    bottom: auto; }\n  .tooltip.top.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.left::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #0a0a0a;\n    left: 100%; }\n  .tooltip.left.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.right::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #0a0a0a transparent transparent;\n    right: 100%;\n    left: auto; }\n  .tooltip.right.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.align-top::before {\n    bottom: auto;\n    top: 10%; }\n  .tooltip.align-bottom::before {\n    bottom: 10%;\n    top: auto; }\n  .tooltip.align-left::before {\n    left: 10%;\n    right: auto; }\n  .tooltip.align-right::before {\n    left: auto;\n    right: 10%; }\n\n.accordion {\n  margin-right: 0;\n  background: #fefefe;\n  list-style-type: none; }\n  .accordion[disabled] .accordion-title {\n    cursor: not-allowed; }\n\n.accordion-item:first-child > :first-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-item:last-child > :last-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-title {\n  position: relative;\n  display: block;\n  padding: 1.25rem 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  font-size: 0.75rem;\n  line-height: 1;\n  color: #1779ba; }\n  :last-child:not(.is-active) > .accordion-title {\n    border-bottom: 1px solid #e6e6e6;\n    border-radius: 0 0 0 0; }\n  .accordion-title:hover, .accordion-title:focus {\n    background-color: #e6e6e6; }\n  .accordion-title::before {\n    position: absolute;\n    top: 50%;\n    left: 1rem;\n    margin-top: -0.5rem;\n    content: '+'; }\n  .is-active > .accordion-title::before {\n    content: '\\2013'; }\n\n.accordion-content {\n  display: none;\n  padding: 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  background-color: #fefefe;\n  color: #0a0a0a; }\n  :last-child > .accordion-content:last-child {\n    border-bottom: 1px solid #e6e6e6; }\n\n.media-object {\n  display: flex;\n  margin-bottom: 1rem;\n  flex-wrap: nowrap; }\n  .media-object img {\n    max-width: none; }\n  @media screen and (max-width: 39.99875em) {\n    .media-object.stack-for-small {\n      flex-wrap: wrap; } }\n\n.media-object-section {\n  flex: 0 1 auto; }\n  .media-object-section:first-child {\n    padding-left: 1rem; }\n  .media-object-section:last-child:not(:nth-child(2)) {\n    padding-right: 1rem; }\n  .media-object-section > :last-child {\n    margin-bottom: 0; }\n  @media screen and (max-width: 39.99875em) {\n    .stack-for-small .media-object-section {\n      padding: 0;\n      padding-bottom: 1rem;\n      flex-basis: 100%;\n      max-width: 100%; }\n      .stack-for-small .media-object-section img {\n        width: 100%; } }\n  .media-object-section.main-section {\n    flex: 1 1 0px; }\n\n.orbit {\n  position: relative; }\n\n.orbit-container {\n  position: relative;\n  height: 0;\n  margin: 0;\n  list-style: none;\n  overflow: hidden; }\n\n.orbit-slide {\n  width: 100%;\n  position: absolute; }\n  .orbit-slide.no-motionui.is-active {\n    top: 0;\n    left: 0; }\n\n.orbit-figure {\n  margin: 0; }\n\n.orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0; }\n\n.orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: 1rem;\n  background-color: rgba(10, 10, 10, 0.5);\n  color: #fefefe; }\n\n.orbit-previous, .orbit-next {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  z-index: 10;\n  padding: 1rem;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {\n    outline: 0; }\n  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {\n    background-color: rgba(10, 10, 10, 0.5); }\n\n.orbit-previous {\n  right: 0; }\n\n.orbit-next {\n  right: auto;\n  left: 0; }\n\n.orbit-bullets {\n  position: relative;\n  margin-top: 0.8rem;\n  margin-bottom: 0.8rem;\n  text-align: center; }\n  [data-whatinput='mouse'] .orbit-bullets {\n    outline: 0; }\n  .orbit-bullets button {\n    width: 1.2rem;\n    height: 1.2rem;\n    margin: 0.1rem;\n    border-radius: 50%;\n    background-color: #cacaca; }\n    .orbit-bullets button:hover {\n      background-color: #8a8a8a; }\n    .orbit-bullets button.is-active {\n      background-color: #8a8a8a; }\n\n.responsive-embed,\n.flex-video {\n  position: relative;\n  height: 0;\n  margin-bottom: 1rem;\n  padding-bottom: 75%;\n  overflow: hidden; }\n  .responsive-embed iframe,\n  .responsive-embed object,\n  .responsive-embed embed,\n  .responsive-embed video,\n  .flex-video iframe,\n  .flex-video object,\n  .flex-video embed,\n  .flex-video video {\n    position: absolute;\n    top: 0;\n    right: 0;\n    width: 100%;\n    height: 100%; }\n  .responsive-embed.widescreen,\n  .flex-video.widescreen {\n    padding-bottom: 56.25%; }\n\n.tabs {\n  margin: 0;\n  border: 1px solid #e6e6e6;\n  background: #fefefe;\n  list-style-type: none; }\n  .tabs::before, .tabs::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .tabs::after {\n    clear: both; }\n\n.tabs.vertical > li {\n  display: block;\n  float: none;\n  width: auto; }\n\n.tabs.simple > li > a {\n  padding: 0; }\n  .tabs.simple > li > a:hover {\n    background: transparent; }\n\n.tabs.primary {\n  background: #1779ba; }\n  .tabs.primary > li > a {\n    color: #fefefe; }\n    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {\n      background: #1673b1; }\n\n.tabs-title {\n  float: right; }\n  .tabs-title > a {\n    display: block;\n    padding: 1.25rem 1.5rem;\n    font-size: 0.75rem;\n    line-height: 1;\n    color: #1779ba; }\n    [data-whatinput='mouse'] .tabs-title > a {\n      outline: 0; }\n    .tabs-title > a:hover {\n      background: #fefefe;\n      color: #1468a0; }\n    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {\n      background: #e6e6e6;\n      color: #1779ba; }\n\n.tabs-content {\n  border: 1px solid #e6e6e6;\n  border-top: 0;\n  background: #fefefe;\n  color: #0a0a0a;\n  transition: all 0.5s ease; }\n\n.tabs-content.vertical {\n  border: 1px solid #e6e6e6;\n  border-right: 0; }\n\n.tabs-panel {\n  display: none;\n  padding: 1rem; }\n  .tabs-panel.is-active {\n    display: block; }\n\n.thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: 1rem;\n  border: 4px solid #fefefe;\n  border-radius: 0;\n  box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);\n  line-height: 0; }\n\na.thumbnail {\n  transition: box-shadow 200ms ease-out; }\n  a.thumbnail:hover, a.thumbnail:focus {\n    box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }\n  a.thumbnail image {\n    box-shadow: none; }\n\n.menu {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n  display: flex;\n  flex-wrap: wrap; }\n  [data-whatinput='mouse'] .menu li {\n    outline: 0; }\n  .menu a,\n  .menu .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: 0.7rem 1rem; }\n  .menu input,\n  .menu select,\n  .menu a,\n  .menu button {\n    margin-bottom: 0; }\n  .menu input {\n    display: inline-block; }\n  .menu, .menu.horizontal {\n    flex-wrap: wrap;\n    flex-direction: row; }\n  .menu.vertical {\n    flex-wrap: nowrap;\n    flex-direction: column; }\n  .menu.expanded li {\n    flex: 1 1 0px; }\n  .menu.simple {\n    align-items: center; }\n    .menu.simple li + li {\n      margin-right: 1rem; }\n    .menu.simple a {\n      padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .menu.medium-horizontal {\n      flex-wrap: wrap;\n      flex-direction: row; }\n    .menu.medium-vertical {\n      flex-wrap: nowrap;\n      flex-direction: column; }\n    .menu.medium-expanded li {\n      flex: 1 1 0px; }\n    .menu.medium-simple li {\n      flex: 1 1 0px; } }\n  @media print, screen and (min-width: 64em) {\n    .menu.large-horizontal {\n      flex-wrap: wrap;\n      flex-direction: row; }\n    .menu.large-vertical {\n      flex-wrap: nowrap;\n      flex-direction: column; }\n    .menu.large-expanded li {\n      flex: 1 1 0px; }\n    .menu.large-simple li {\n      flex: 1 1 0px; } }\n  .menu.nested {\n    margin-left: 0;\n    margin-right: 1rem; }\n  .menu.icons a {\n    display: flex; }\n  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {\n    display: flex; }\n  .menu.icon-left li a {\n    flex-flow: row nowrap; }\n    .menu.icon-left li a img,\n    .menu.icon-left li a i,\n    .menu.icon-left li a svg {\n      margin-left: 0.25rem; }\n  .menu.icon-right li a {\n    flex-flow: row nowrap; }\n    .menu.icon-right li a img,\n    .menu.icon-right li a i,\n    .menu.icon-right li a svg {\n      margin-right: 0.25rem; }\n  .menu.icon-top li a {\n    flex-flow: column nowrap; }\n    .menu.icon-top li a img,\n    .menu.icon-top li a i,\n    .menu.icon-top li a svg {\n      align-self: stretch;\n      margin-bottom: 0.25rem;\n      text-align: center; }\n  .menu.icon-bottom li a {\n    flex-flow: column nowrap; }\n    .menu.icon-bottom li a img,\n    .menu.icon-bottom li a i,\n    .menu.icon-bottom li a svg {\n      align-self: stretch;\n      margin-bottom: 0.25rem;\n      text-align: center; }\n  .menu .is-active > a {\n    background: #1779ba;\n    color: #fefefe; }\n  .menu .active > a {\n    background: #1779ba;\n    color: #fefefe; }\n  .menu.align-right {\n    justify-content: flex-start; }\n  .menu.align-left li {\n    display: flex;\n    justify-content: flex-end; }\n    .menu.align-left li .submenu li {\n      justify-content: flex-start; }\n  .menu.align-left.vertical li {\n    display: block;\n    text-align: left; }\n    .menu.align-left.vertical li .submenu li {\n      text-align: left; }\n  .menu.align-left .nested {\n    margin-left: 1rem;\n    margin-right: 0; }\n  .menu.align-center li {\n    display: flex;\n    justify-content: center; }\n    .menu.align-center li .submenu li {\n      justify-content: flex-start; }\n  .menu .menu-text {\n    padding: 0.7rem 1rem;\n    font-weight: bold;\n    line-height: 1;\n    color: inherit; }\n\n.menu-centered > .menu {\n  justify-content: center; }\n  .menu-centered > .menu li {\n    display: flex;\n    justify-content: center; }\n    .menu-centered > .menu li .submenu li {\n      justify-content: flex-start; }\n\n.no-js [data-responsive-menu] ul {\n  display: none; }\n\n.menu-icon {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #fefefe;\n    box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;\n    content: ''; }\n  .menu-icon:hover::after {\n    background: #cacaca;\n    box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }\n\n.menu-icon.dark {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon.dark::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #0a0a0a;\n    box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;\n    content: ''; }\n  .menu-icon.dark:hover::after {\n    background: #8a8a8a;\n    box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }\n\n.accordion-menu li {\n  width: 100%; }\n\n.accordion-menu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .is-accordion-submenu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .nested.is-accordion-submenu {\n  margin-left: 0;\n  margin-right: 1rem; }\n\n.accordion-menu.align-left .nested.is-accordion-submenu {\n  margin-left: 1rem;\n  margin-right: 0; }\n\n.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n  position: relative; }\n  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    position: absolute;\n    top: 50%;\n    margin-top: -3px;\n    left: 1rem; }\n\n.accordion-menu.align-left .is-accordion-submenu-parent > a::after {\n  right: 1rem;\n  left: auto; }\n\n.accordion-menu.align-right .is-accordion-submenu-parent > a::after {\n  right: auto;\n  left: 1rem; }\n\n.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n  transform: rotate(180deg);\n  transform-origin: 50% 50%; }\n\n.is-accordion-submenu-parent {\n  position: relative; }\n\n.has-submenu-toggle > a {\n  margin-left: 40px; }\n\n.submenu-toggle {\n  position: absolute;\n  top: 0;\n  left: 0;\n  width: 40px;\n  height: 40px;\n  cursor: pointer; }\n  .submenu-toggle::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    top: 0;\n    bottom: 0;\n    margin: auto; }\n\n.submenu-toggle[aria-expanded='true']::after {\n  transform: scaleY(-1);\n  transform-origin: 50% 50%; }\n\n.submenu-toggle-text {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  white-space: nowrap;\n  border: 0; }\n\n.is-drilldown {\n  position: relative;\n  overflow: hidden; }\n  .is-drilldown li {\n    display: block; }\n  .is-drilldown.animate-height {\n    transition: height 0.5s; }\n\n.drilldown a {\n  padding: 0.7rem 1rem;\n  background: #fefefe; }\n\n.drilldown .is-drilldown-submenu {\n  position: absolute;\n  top: 0;\n  right: 100%;\n  z-index: -1;\n  width: 100%;\n  background: #fefefe;\n  transition: transform 0.15s linear; }\n  .drilldown .is-drilldown-submenu.is-active {\n    z-index: 1;\n    display: block;\n    transform: translateX(100%); }\n  .drilldown .is-drilldown-submenu.is-closing {\n    transform: translateX(-100%); }\n  .drilldown .is-drilldown-submenu a {\n    padding: 0.7rem 1rem; }\n\n.drilldown .nested.is-drilldown-submenu {\n  margin-left: 0;\n  margin-right: 0; }\n\n.drilldown .drilldown-submenu-cover-previous {\n  min-height: 100%; }\n\n.drilldown .is-drilldown-submenu-parent > a {\n  position: relative; }\n  .drilldown .is-drilldown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    position: absolute;\n    top: 50%;\n    margin-top: -6px;\n    left: 1rem; }\n\n.drilldown.align-left .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba;\n  right: 1rem;\n  left: auto; }\n\n.drilldown.align-right .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  right: auto;\n  left: 1rem; }\n\n.drilldown .js-drilldown-back > a::before {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba;\n  display: inline-block;\n  vertical-align: middle;\n  margin-left: 0.75rem; }\n\n.dropdown.menu > li.opens-left > .is-dropdown-submenu {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.dropdown.menu > li.opens-right > .is-dropdown-submenu {\n  top: 100%;\n  right: auto;\n  left: 0; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a {\n  position: relative;\n  padding-left: 1.5rem; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-bottom-width: 0;\n  border-top-style: solid;\n  border-color: #1779ba transparent transparent;\n  left: 5px;\n  right: auto;\n  margin-top: -3px; }\n\n[data-whatinput='mouse'] .dropdown.menu a {\n  outline: 0; }\n\n.dropdown.menu > li > a {\n  padding: 0.7rem 1rem; }\n\n.dropdown.menu > li.is-active > a {\n  background: transparent;\n  color: #1779ba; }\n\n.no-js .dropdown.menu ul {\n  display: none; }\n\n.dropdown.menu .nested.is-dropdown-submenu {\n  margin-left: 0;\n  margin-right: 0; }\n\n.dropdown.menu.vertical > li .is-dropdown-submenu {\n  top: 0; }\n\n.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {\n  top: 0;\n  right: 100%;\n  left: auto; }\n\n.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%; }\n\n.dropdown.menu.vertical > li > a::after {\n  left: 14px; }\n\n.dropdown.menu.vertical > li.opens-left > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  right: auto;\n  left: 5px; }\n\n.dropdown.menu.vertical > li.opens-right > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba; }\n\n@media print, screen and (min-width: 40em) {\n  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-left: 1.5rem; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    left: 5px;\n    right: auto;\n    margin-top: -3px; }\n  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.medium-vertical > li > a::after {\n    left: 14px; }\n  .dropdown.menu.medium-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.medium-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; } }\n\n@media print, screen and (min-width: 64em) {\n  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-left: 1.5rem; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    left: 5px;\n    right: auto;\n    margin-top: -3px; }\n  .dropdown.menu.large-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.large-vertical > li > a::after {\n    left: 14px; }\n  .dropdown.menu.large-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.large-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; } }\n\n.dropdown.menu.align-right .is-dropdown-submenu.first-sub {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.is-dropdown-menu.vertical {\n  width: 100px; }\n  .is-dropdown-menu.vertical.align-right {\n    float: right; }\n\n.is-dropdown-submenu-parent {\n  position: relative; }\n  .is-dropdown-submenu-parent a::after {\n    position: absolute;\n    top: 50%;\n    left: 5px;\n    right: auto;\n    margin-top: -6px; }\n  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {\n    top: 100%;\n    right: auto; }\n  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n\n.is-dropdown-submenu {\n  position: absolute;\n  top: 0;\n  right: 100%;\n  z-index: 1;\n  display: none;\n  min-width: 200px;\n  border: 1px solid #cacaca;\n  background: #fefefe; }\n  .dropdown .is-dropdown-submenu a {\n    padding: 0.7rem 1rem; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {\n    left: 14px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; }\n  .is-dropdown-submenu .is-dropdown-submenu {\n    margin-top: -1px; }\n  .is-dropdown-submenu > li {\n    width: 100%; }\n  .is-dropdown-submenu.js-dropdown-active {\n    display: block; }\n\n.is-off-canvas-open {\n  overflow: hidden; }\n\n.js-off-canvas-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 11;\n  width: 100%;\n  height: 100%;\n  transition: opacity 0.5s ease, visibility 0.5s ease;\n  background: rgba(254, 254, 254, 0.25);\n  opacity: 0;\n  visibility: hidden;\n  overflow: hidden; }\n  .js-off-canvas-overlay.is-visible {\n    opacity: 1;\n    visibility: visible; }\n  .js-off-canvas-overlay.is-closable {\n    cursor: pointer; }\n  .js-off-canvas-overlay.is-overlay-absolute {\n    position: absolute; }\n  .js-off-canvas-overlay.is-overlay-fixed {\n    position: fixed; }\n\n.off-canvas-wrapper {\n  position: relative;\n  overflow: hidden; }\n\n.off-canvas {\n  position: fixed;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas {\n    outline: 0; }\n  .off-canvas.is-transition-push {\n    z-index: 12; }\n  .off-canvas.is-closed {\n    visibility: hidden; }\n  .off-canvas.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n.off-canvas-absolute {\n  position: absolute;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas-absolute {\n    outline: 0; }\n  .off-canvas-absolute.is-transition-push {\n    z-index: 12; }\n  .off-canvas-absolute.is-closed {\n    visibility: hidden; }\n  .off-canvas-absolute.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas-absolute.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas-absolute.is-open {\n    transform: translate(0, 0); }\n\n.position-left {\n  top: 0;\n  left: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(-250px); }\n  .off-canvas-content .off-canvas.position-left {\n    transform: translateX(-250px); }\n    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-left.has-transition-push {\n    transform: translateX(250px); }\n  .position-left.is-transition-push {\n    box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-right {\n  top: 0;\n  right: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(250px); }\n  .off-canvas-content .off-canvas.position-right {\n    transform: translateX(250px); }\n    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-right.has-transition-push {\n    transform: translateX(-250px); }\n  .position-right.is-transition-push {\n    box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-top {\n  top: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(-250px); }\n  .off-canvas-content .off-canvas.position-top {\n    transform: translateY(-250px); }\n    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-top.has-transition-push {\n    transform: translateY(250px); }\n  .position-top.is-transition-push {\n    box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-bottom {\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(250px); }\n  .off-canvas-content .off-canvas.position-bottom {\n    transform: translateY(250px); }\n    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-bottom.has-transition-push {\n    transform: translateY(-250px); }\n  .position-bottom.is-transition-push {\n    box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.off-canvas-content {\n  transform: none;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden; }\n  .off-canvas-content.has-transition-push {\n    transform: translate(0, 0); }\n  .off-canvas-content .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n@media print, screen and (min-width: 40em) {\n  .position-left.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-medium ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-medium ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-medium ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-medium ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 64em) {\n  .position-left.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-large ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-large ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-large ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-large ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 40em) {\n  .off-canvas.in-canvas-for-medium {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-medium .close-button {\n      display: none; } }\n\n@media print, screen and (min-width: 64em) {\n  .off-canvas.in-canvas-for-large {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-large .close-button {\n      display: none; } }\n\nhtml.is-reveal-open {\n  position: fixed;\n  width: 100%;\n  overflow-y: hidden; }\n  html.is-reveal-open.zf-has-scroll {\n    overflow-y: scroll; }\n  html.is-reveal-open body {\n    overflow-y: hidden; }\n\n.reveal-overlay {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1005;\n  display: none;\n  background-color: rgba(10, 10, 10, 0.45);\n  overflow-y: auto; }\n\n.reveal {\n  z-index: 1006;\n  backface-visibility: hidden;\n  display: none;\n  padding: 1rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  position: relative;\n  top: 100px;\n  margin-right: auto;\n  margin-left: auto;\n  overflow-y: auto; }\n  [data-whatinput='mouse'] .reveal {\n    outline: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      min-height: 0; } }\n  .reveal .column {\n    min-width: 0; }\n  .reveal > :last-child {\n    margin-bottom: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      width: 600px;\n      max-width: 75rem; } }\n  .reveal.collapse {\n    padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal.tiny {\n      width: 30%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.small {\n      width: 50%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.large {\n      width: 90%;\n      max-width: 75rem; } }\n  .reveal.full {\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    max-width: none;\n    height: 100%;\n    min-height: 100%;\n    margin-left: 0;\n    border: 0;\n    border-radius: 0; }\n  @media screen and (max-width: 39.99875em) {\n    .reveal {\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      width: 100%;\n      max-width: none;\n      height: 100%;\n      min-height: 100%;\n      margin-left: 0;\n      border: 0;\n      border-radius: 0; } }\n  .reveal.without-overlay {\n    position: fixed; }\n\n.sticky-container {\n  position: relative; }\n\n.sticky {\n  position: relative;\n  z-index: 0;\n  transform: translate3d(0, 0, 0); }\n\n.sticky.is-stuck {\n  position: fixed;\n  z-index: 5;\n  width: 100%; }\n  .sticky.is-stuck.is-at-top {\n    top: 0; }\n  .sticky.is-stuck.is-at-bottom {\n    bottom: 0; }\n\n.sticky.is-anchored {\n  position: relative;\n  right: auto;\n  left: auto; }\n  .sticky.is-anchored.is-at-bottom {\n    bottom: 0; }\n\n.title-bar {\n  padding: 0.5rem;\n  background: #0a0a0a;\n  color: #fefefe;\n  display: flex;\n  justify-content: flex-start;\n  align-items: center; }\n  .title-bar .menu-icon {\n    margin-right: 0.25rem;\n    margin-left: 0.25rem; }\n\n.title-bar-left,\n.title-bar-right {\n  flex: 1 1 0px; }\n\n.title-bar-right {\n  text-align: right; }\n\n.title-bar-title {\n  display: inline-block;\n  vertical-align: middle;\n  font-weight: bold; }\n\n.top-bar {\n  display: flex;\n  flex-wrap: nowrap;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0.5rem;\n  flex-wrap: wrap; }\n  .top-bar,\n  .top-bar ul {\n    background-color: #e6e6e6; }\n  .top-bar input {\n    max-width: 200px;\n    margin-left: 1rem; }\n  .top-bar .input-group-field {\n    width: 100%;\n    margin-left: 0; }\n  .top-bar input.button {\n    width: auto; }\n  .top-bar .top-bar-left,\n  .top-bar .top-bar-right {\n    flex: 0 0 100%;\n    max-width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .top-bar {\n      flex-wrap: nowrap; }\n      .top-bar .top-bar-left {\n        flex: 1 1 auto;\n        margin-right: auto; }\n      .top-bar .top-bar-right {\n        flex: 0 1 auto;\n        margin-left: auto; } }\n  @media screen and (max-width: 63.99875em) {\n    .top-bar.stacked-for-medium {\n      flex-wrap: wrap; }\n      .top-bar.stacked-for-medium .top-bar-left,\n      .top-bar.stacked-for-medium .top-bar-right {\n        flex: 0 0 100%;\n        max-width: 100%; } }\n  @media screen and (max-width: 74.99875em) {\n    .top-bar.stacked-for-large {\n      flex-wrap: wrap; }\n      .top-bar.stacked-for-large .top-bar-left,\n      .top-bar.stacked-for-large .top-bar-right {\n        flex: 0 0 100%;\n        max-width: 100%; } }\n\n.top-bar-title {\n  flex: 0 0 auto;\n  margin: 0.5rem 1rem 0.5rem 0; }\n\n.top-bar-left,\n.top-bar-right {\n  flex: 0 0 auto; }\n\n.float-left {\n  float: left !important; }\n\n.float-right {\n  float: right !important; }\n\n.float-center {\n  display: block;\n  margin-right: auto;\n  margin-left: auto; }\n\n.clearfix::before, .clearfix::after {\n  display: table;\n  content: ' ';\n  flex-basis: 0;\n  order: 1; }\n\n.clearfix::after {\n  clear: both; }\n\n.align-left {\n  justify-content: flex-end; }\n\n.align-right {\n  justify-content: flex-start; }\n\n.align-center {\n  justify-content: center; }\n\n.align-justify {\n  justify-content: space-between; }\n\n.align-spaced {\n  justify-content: space-around; }\n\n.align-left.vertical.menu > li > a {\n  justify-content: flex-end; }\n\n.align-right.vertical.menu > li > a {\n  justify-content: flex-start; }\n\n.align-center.vertical.menu > li > a {\n  justify-content: center; }\n\n.align-top {\n  align-items: flex-start; }\n\n.align-self-top {\n  align-self: flex-start; }\n\n.align-bottom {\n  align-items: flex-end; }\n\n.align-self-bottom {\n  align-self: flex-end; }\n\n.align-middle {\n  align-items: center; }\n\n.align-self-middle {\n  align-self: center; }\n\n.align-stretch {\n  align-items: stretch; }\n\n.align-self-stretch {\n  align-self: stretch; }\n\n.align-center-middle {\n  justify-content: center;\n  align-items: center;\n  align-content: center; }\n\n.small-order-1 {\n  order: 1; }\n\n.small-order-2 {\n  order: 2; }\n\n.small-order-3 {\n  order: 3; }\n\n.small-order-4 {\n  order: 4; }\n\n.small-order-5 {\n  order: 5; }\n\n.small-order-6 {\n  order: 6; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-order-1 {\n    order: 1; }\n  .medium-order-2 {\n    order: 2; }\n  .medium-order-3 {\n    order: 3; }\n  .medium-order-4 {\n    order: 4; }\n  .medium-order-5 {\n    order: 5; }\n  .medium-order-6 {\n    order: 6; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-order-1 {\n    order: 1; }\n  .large-order-2 {\n    order: 2; }\n  .large-order-3 {\n    order: 3; }\n  .large-order-4 {\n    order: 4; }\n  .large-order-5 {\n    order: 5; }\n  .large-order-6 {\n    order: 6; } }\n\n.flex-container {\n  display: flex; }\n\n.flex-child-auto {\n  flex: 1 1 auto; }\n\n.flex-child-grow {\n  flex: 1 0 auto; }\n\n.flex-child-shrink {\n  flex: 0 1 auto; }\n\n.flex-dir-row {\n  flex-direction: row; }\n\n.flex-dir-row-reverse {\n  flex-direction: row-reverse; }\n\n.flex-dir-column {\n  flex-direction: column; }\n\n.flex-dir-column-reverse {\n  flex-direction: column-reverse; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-flex-container {\n    display: flex; }\n  .medium-flex-child-auto {\n    flex: 1 1 auto; }\n  .medium-flex-child-grow {\n    flex: 1 0 auto; }\n  .medium-flex-child-shrink {\n    flex: 0 1 auto; }\n  .medium-flex-dir-row {\n    flex-direction: row; }\n  .medium-flex-dir-row-reverse {\n    flex-direction: row-reverse; }\n  .medium-flex-dir-column {\n    flex-direction: column; }\n  .medium-flex-dir-column-reverse {\n    flex-direction: column-reverse; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-flex-container {\n    display: flex; }\n  .large-flex-child-auto {\n    flex: 1 1 auto; }\n  .large-flex-child-grow {\n    flex: 1 0 auto; }\n  .large-flex-child-shrink {\n    flex: 0 1 auto; }\n  .large-flex-dir-row {\n    flex-direction: row; }\n  .large-flex-dir-row-reverse {\n    flex-direction: row-reverse; }\n  .large-flex-dir-column {\n    flex-direction: column; }\n  .large-flex-dir-column-reverse {\n    flex-direction: column-reverse; } }\n\n.hide {\n  display: none !important; }\n\n.invisible {\n  visibility: hidden; }\n\n@media screen and (max-width: 39.99875em) {\n  .hide-for-small-only {\n    display: none !important; } }\n\n@media screen and (max-width: 0em), screen and (min-width: 40em) {\n  .show-for-small-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 40em) {\n  .hide-for-medium {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em) {\n  .show-for-medium {\n    display: none !important; } }\n\n@media screen and (min-width: 40em) and (max-width: 63.99875em) {\n  .hide-for-medium-only {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {\n  .show-for-medium-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 64em) {\n  .hide-for-large {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em) {\n  .show-for-large {\n    display: none !important; } }\n\n@media screen and (min-width: 64em) and (max-width: 74.99875em) {\n  .hide-for-large-only {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {\n  .show-for-large-only {\n    display: none !important; } }\n\n.show-for-sr,\n.show-on-focus {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  white-space: nowrap;\n  border: 0; }\n\n.show-on-focus:active, .show-on-focus:focus {\n  position: static !important;\n  width: auto;\n  height: auto;\n  overflow: visible;\n  clip: auto;\n  white-space: normal; }\n\n.show-for-landscape,\n.hide-for-portrait {\n  display: block !important; }\n  @media screen and (orientation: landscape) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: block !important; } }\n  @media screen and (orientation: portrait) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: none !important; } }\n\n.hide-for-landscape,\n.show-for-portrait {\n  display: none !important; }\n  @media screen and (orientation: landscape) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: none !important; } }\n  @media screen and (orientation: portrait) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: block !important; } }\n","/**\n * Foundation for Sites by ZURB\n * Version 6.5.3\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n\n// Dependencies\n@import 'vendor/normalize';\n@import '../_vendor/sassy-lists/stylesheets/helpers/missing-dependencies';\n@import '../_vendor/sassy-lists/stylesheets/helpers/true';\n@import '../_vendor/sassy-lists/stylesheets/functions/contain';\n@import '../_vendor/sassy-lists/stylesheets/functions/purge';\n@import '../_vendor/sassy-lists/stylesheets/functions/remove';\n@import '../_vendor/sassy-lists/stylesheets/functions/replace';\n@import '../_vendor/sassy-lists/stylesheets/functions/to-list';\n\n// --- Settings ---\n// import your own `settings` here or\n// import and modify the default settings through\n// @import 'settings/settings';\n\n// --- Components ---\n// Utilities\n@import 'util/util';\n// Global styles\n@import 'global';\n@import 'forms/forms';\n@import 'typography/typography';\n\n// Grids\n@import 'grid/grid';\n@import 'xy-grid/xy-grid';\n// Generic components\n@import 'components/button';\n@import 'components/button-group';\n@import 'components/close-button';\n@import 'components/label';\n@import 'components/progress-bar';\n@import 'components/slider';\n@import 'components/switch';\n@import 'components/table';\n// Basic components\n@import 'components/badge';\n@import 'components/breadcrumbs';\n@import 'components/callout';\n@import 'components/card';\n@import 'components/dropdown';\n@import 'components/pagination';\n@import 'components/tooltip';\n\n// Containers\n@import 'components/accordion';\n@import 'components/media-object';\n@import 'components/orbit';\n@import 'components/responsive-embed';\n@import 'components/tabs';\n@import 'components/thumbnail';\n// Menu-based containers\n@import 'components/menu';\n@import 'components/menu-icon';\n@import 'components/accordion-menu';\n@import 'components/drilldown';\n@import 'components/dropdown-menu';\n\n// Layout components\n@import 'components/off-canvas';\n@import 'components/reveal';\n@import 'components/sticky';\n@import 'components/title-bar';\n@import 'components/top-bar';\n\n// Helpers\n@import 'components/float';\n@import 'components/flex';\n@import 'components/visibility';\n@import 'prototype/prototype';\n\n\n@mixin foundation-everything(\n  $flex: true,\n  $prototype: false\n) {\n  @if $flex {\n    $global-flexbox: true !global;\n  }\n\n  // Global styles\n  @include foundation-global-styles;\n  @include foundation-forms;\n  @include foundation-typography;\n\n  // Grids\n  @if not $flex {\n    @include foundation-grid;\n  }\n  @else {\n    @if $xy-grid {\n      @include foundation-xy-grid-classes;\n    }\n    @else {\n      @include foundation-flex-grid;\n    }\n  }\n\n  // Generic components\n  @include foundation-button;\n  @include foundation-button-group;\n  @include foundation-close-button;\n  @include foundation-label;\n  @include foundation-progress-bar;\n  @include foundation-slider;\n  @include foundation-switch;\n  @include foundation-table;\n  // Basic components\n  @include foundation-badge;\n  @include foundation-breadcrumbs;\n  @include foundation-callout;\n  @include foundation-card;\n  @include foundation-dropdown;\n  @include foundation-pagination;\n  @include foundation-tooltip;\n\n  // Containers\n  @include foundation-accordion;\n  @include foundation-media-object;\n  @include foundation-orbit;\n  @include foundation-responsive-embed;\n  @include foundation-tabs;\n  @include foundation-thumbnail;\n  // Menu-based containers\n  @include foundation-menu;\n  @include foundation-menu-icon;\n  @include foundation-accordion-menu;\n  @include foundation-drilldown-menu;\n  @include foundation-dropdown-menu;\n\n  // Layout components\n  @include foundation-off-canvas;\n  @include foundation-reveal;\n  @include foundation-sticky;\n  @include foundation-title-bar;\n  @include foundation-top-bar;\n\n  // Helpers\n  @include foundation-float-classes;\n  @if $flex { @include foundation-flex-classes; }\n  @include foundation-visibility-classes;\n  @if $prototype { @include foundation-prototype-classes; }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group breakpoints\n////\n\n/// A list of named breakpoints. You can use these with the `breakpoint()` mixin to quickly create media queries.\n/// @type Map\n$breakpoints: (\n  small: 0,\n  medium: 640px,\n  large: 1024px,\n  xlarge: 1200px,\n  xxlarge: 1440px,\n) !default;\n\n/// The largest named breakpoint in which to include print as a media type\n/// @type Keyword\n$print-breakpoint: large !default;\n\n$-zf-zero-breakpoint: small !default;\n\n$-zf-breakpoints-keys: map-to-list($breakpoints, 'keys');\n\n@if nth(map-values($breakpoints), 1) != 0 {\n  @error 'The first key in the $breakpoints map must have a value of \"0\".';\n}\n@else {\n  $-zf-zero-breakpoint: nth(map-keys($breakpoints), 1);\n}\n\n/// All of the names in this list will be output as classes in your CSS, like `.small-12`, `.medium-6`, and so on. Each value in this list must also be in the `$breakpoints` map.\n/// @type List\n$breakpoint-classes: (small medium large) !default;\n\n/// Generates a media query string matching the input value. Refer to the documentation for the `breakpoint()` mixin to see what the possible inputs are.\n///\n/// @param {Keyword|Number} $val [small] - Breakpoint name, or px, rem, or em value to process.\n@function breakpoint($val: $-zf-zero-breakpoint) {\n  // Size or keyword\n  $bp: nth($val, 1);\n  // Value for max-width media queries\n  $bp-max: 0;\n  // Direction of media query (up, down, or only)\n  $dir: if(length($val) > 1, nth($val, 2), up);\n  // Eventual output\n  $str: '';\n  // Is it a named media query?\n  $named: false;\n\n  // Orientation media queries have a unique syntax\n  @if $bp == 'landscape' or $bp == 'portrait' {\n    @return '(orientation: #{$bp})';\n  }\n  @else if $bp == 'retina' {\n    @return '(-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi)';\n  }\n\n  // Try to pull a named breakpoint out of the $breakpoints map\n  @if type-of($bp) == 'string' {\n    @if map-has-key($breakpoints, $bp) {\n      @if $dir == 'only' or $dir == 'down' {\n        $bp-max: -zf-map-next($breakpoints, $bp);\n      }\n\n      $bp: map-get($breakpoints, $bp);\n      $named: true;\n    }\n    @else {\n      $bp: 0;\n      @warn 'breakpoint(): \"#{$val}\" is not defined in your $breakpoints setting.';\n    }\n  }\n\n  // Convert any pixel, rem, or unitless value to em\n  $bp: -zf-bp-to-em($bp);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/zurb/foundation-sites/issues/11313\n  @if $bp-max {\n    $bp-max: -zf-bp-to-em($bp-max) - .00125;\n  }\n\n  // Conditions to skip media query creation\n  // - It's a named breakpoint that resolved to \"0 down\" or \"0 up\"\n  // - It's a numeric breakpoint that resolved to \"0 \" + anything\n  @if $bp > 0em or $dir == 'only' or $dir == 'down' {\n    // `only` ranges use the format `(min-width: n) and (max-width: n)`\n    @if $dir == 'only' {\n      // Only named media queries can have an \"only\" range\n      @if $named == true {\n        // Only use \"min-width\" if the floor is greater than 0\n        @if $bp > 0em {\n          $str: $str + '(min-width: #{$bp})';\n\n          // Only add \"and\" to the media query if there's a ceiling\n          @if $bp-max != null {\n            $str: $str + ' and ';\n          }\n        }\n\n        // Only use \"max-width\" if there's a ceiling\n        @if $bp-max != null {\n          $str: $str + '(max-width: #{$bp-max})';\n        }\n      }\n      @else {\n        @warn 'breakpoint(): Only named media queries can have an `only` range.';\n      }\n    }\n\n    // `down` ranges use the format `(max-width: n)`\n    @else if $dir == 'down' {\n      $max: if($named, $bp-max, $bp);\n\n      // Skip media query creation if input value is exactly \"0 down\",\n      // unless the function was called as \"small down\", in which case it's just \"small only\"\n      @if $named or $bp > 0em {\n        @if $max != null {\n          $str: $str + '(max-width: #{$max})';\n        }\n      }\n    }\n\n    // `up` ranges use the format `(min-width: n)`\n    @else if $bp > 0em {\n      $str: $str + '(min-width: #{$bp})';\n    }\n  }\n\n  @return $str;\n}\n\n/// Wraps a media query around the content you put inside the mixin. This mixin accepts a number of values:\n///  - If a string is passed, the mixin will look for it in the `$breakpoints` map, and use a media query there.\n///  - If a pixel value is passed, it will be converted to an em value using `$global-font-size` as the base.\n///  - If a rem value is passed, the unit will be changed to em.\n///  - If an em value is passed, the value will be used as-is.\n///\n/// @param {Keyword|Number} $value - Breakpoint name, or px, rem, or em value to process.\n///\n/// @output If the breakpoint is \"0px and larger\", outputs the content as-is. Otherwise, outputs the content wrapped in a media query.\n@mixin breakpoint($value) {\n  $str: breakpoint($value);\n  $bp: index($-zf-breakpoints-keys, $value);\n  $pbp: index($-zf-breakpoints-keys, $print-breakpoint);\n\n  $old-zf-size: null;\n\n  // Make breakpoint size available as a variable\n  @if global-variable-exists(-zf-size) {\n    $old-zf-size: $-zf-size;\n  }\n  $-zf-size: nth($value, 1) !global; // get the first value to account for `only` and `down` keywords\n\n  // If $str is still an empty string, no media query is needed\n  @if $str == '' {\n    @content;\n  }\n\n  // Otherwise, wrap the content in a media query\n  @else {\n    // For named breakpoints less than or equal to $print-breakpoint, add print to the media types\n    @if $bp != null and $bp <= $pbp {\n      @media print, screen and #{$str} {\n        @content;\n       }\n    }\n    @else {\n      @media screen and #{$str} {\n        @content;\n      }\n    }\n  }\n\n  $-zf-size: $old-zf-size !global;\n}\n\n/// Converts the breakpoints map to a URL-encoded string, like this: `key1=value1&key2=value2`. The value is then dropped into the CSS for a special `<meta>` tag, which is read by the Foundation JavaScript. This is how we transfer values from Sass to JavaScript, so they can be defined in one place.\n/// @access private\n///\n/// @param {Map} $map - Map to convert.\n///\n/// @returns {String} A string containing the map's contents.\n@function -zf-bp-serialize($map) {\n  $str: '';\n  @each $key, $value in $map {\n    $str: $str + $key + '=' + -zf-bp-to-em($value) + '&';\n  }\n  $str: str-slice($str, 1, -2);\n\n  @return $str;\n}\n\n/// Find the next key in a map.\n/// @access private\n///\n/// @param {Map} $map - Map to traverse.\n/// @param {Mixed} $key - Key to use as a starting point.\n///\n/// @returns {Mixed} The value for the key after `$key`, if `$key` was found. If `$key` was not found, or `$key` was the last value in the map, returns `null`.\n@function -zf-map-next($map, $key) {\n\n  // Store the keys of the map as a list\n  $values: map-keys($map);\n\n  $i: 0;\n\n  // If the Key Exists, Get the index of the key within the map and add 1 to it for the next breakpoint in the map\n  @if (map-has-key($map, $key)) {\n    $i: index($values, $key) + 1;\n  }\n\n  // If the key doesn't exist, or it's the last key in the map, return null\n  @if ($i > length($map) or $i == 0) {\n    @return null;\n  }\n  // Otherwise, return the value\n  @else {\n    @return map-get($map, nth($values, $i));\n  }\n\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $key - Key to use as last breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-breakpoints-less-than($key) {\n  $list: ();\n  $found_key: false;\n\n  @each $name in $-zf-breakpoints-keys {\n    @if ($name == $key) {\n      $found_key: true;\n    }\n    @if not $found_key {\n      $list: append($list, $name);\n    }\n  }\n  @return $list;\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $breakpoint - a named or non-named breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-closest-named-breakpoint($breakpoint) {\n  $last: $-zf-zero-breakpoint;\n  $found: false;\n\n  $value: unitless-calc($breakpoint, 1px);\n  @each $key, $val in $breakpoints {\n    @if not $found {\n      @if unitless-calc($val) > $value {\n        $found: true;\n      } @else {\n        $last: $key;\n      }\n    }\n  }\n\n  @return $last;\n}\n\n/// Get a value for a breakpoint from a responsive config map or single value.\n/// - If the config is a single value, return it regardless of `$value`.\n/// - If the config is a map and has the key `$value`, the exact breakpoint value is returned.\n/// - If the config is a map and does *not* have the breakpoint, the value matching the next lowest breakpoint in the config map is returned.\n/// @access private\n///\n/// @param {Number|Map} $map - Responsive config map or single value.\n/// @param {Keyword} $value - Breakpoint name to use.\n///\n/// @return {Mixed} The corresponding breakpoint value.\n@function -zf-get-bp-val($map, $value) {\n  // If the given map is a single value, return it\n  @if type-of($map) == 'number' {\n    @return $map;\n  }\n\n\n  // Check if the breakpoint name exists globally\n  @if not map-has-key($breakpoints, $value) {\n    @if type-of($value) == 'number' {\n      $value: -zf-closest-named-breakpoint($value);\n    } @else {\n      @return null;\n    }\n  }\n  // Check if the breakpoint name exists in the local config map\n  @else if map-has-key($map, $value) {\n    // If it does, just return the value\n    @return map-get($map, $value);\n  }\n  // Otherwise, find the next lowest breakpoint and return that value\n  @else {\n    $anchor: null;\n    $found: false;\n\n    @each $key, $val in $breakpoints {\n      @if not $found {\n        @if map-has-key($map, $key) {\n          $anchor: $key;\n        }\n        @if $key == $value {\n          $found: true;\n        }\n      }\n    }\n\n    @return map-get($map, $anchor);\n  }\n}\n\n$small-up: '';\n$small-only: '';\n\n@if map-has-key($breakpoints, small) {\n  $small-up: screen;\n  $small-only: unquote('screen and #{breakpoint(small only)}');\n}\n\n$medium-up: '';\n$medium-only: '';\n\n@if map-has-key($breakpoints, medium) {\n  $medium-up: unquote('screen and #{breakpoint(medium)}');\n  $medium-only: unquote('screen and #{breakpoint(medium only)}');\n}\n\n$large-up: '';\n$large-only: '';\n\n@if map-has-key($breakpoints, large) {\n  $large-up: unquote('screen and #{breakpoint(large)}');\n  $large-only: unquote('screen and #{breakpoint(large only)}');\n}\n\n$xlarge-up: '';\n$xlarge-only: '';\n\n@if map-has-key($breakpoints, xlarge) {\n  $xlarge-up: unquote('screen and #{breakpoint(xlarge)}');\n  $xlarge-only: unquote('screen and #{breakpoint(xlarge only)}');\n}\n\n$xxlarge-up: '';\n\n@if map-has-key($breakpoints, xxlarge) {\n  $xxlarge-up: unquote('screen and #{breakpoint(xxlarge)}');\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group reveal\n////\n\n/// Default background color of a modal.\n/// @type Color\n$reveal-background: $white !default;\n\n/// Default width of a modal, with no class applied.\n/// @type Number\n$reveal-width: 600px !default;\n\n/// Default maximum width of a modal.\n/// @type Number\n$reveal-max-width: $global-width !default;\n\n/// Default padding inside a modal.\n/// @type Number\n$reveal-padding: $global-padding !default;\n\n/// Default border around a modal.\n/// @type Number\n$reveal-border: 1px solid $medium-gray !default;\n\n/// Default radius for modal.\n/// @type Number\n$reveal-radius: $global-radius !default;\n\n/// z-index for modals. The overlay uses this value, while the modal itself uses this value plus one.\n/// @type Number\n$reveal-zindex: 1005 !default;\n\n/// Background color of modal overlays.\n/// @type Color\n$reveal-overlay-background: rgba($black, 0.45) !default;\n\n\n// Placeholder selector for medium-and-up modals\n// Prevents duplicate CSS when defining multiple Reveal sizes\n// This should be in the same breakpoint then `@mixin reveal-modal-width`\n@include breakpoint(medium) {\n  %reveal-centered {\n    right: auto;\n    left: auto;\n    margin: 0 auto;\n  }\n}\n\n\n/// Adds styles for a modal overlay.\n/// @param {Color} $background [$reveal-overlay-background] - Background color of the overlay.\n@mixin reveal-overlay($background: $reveal-overlay-background) {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: $reveal-zindex;\n\n  display: none;\n  background-color: $background;\n  overflow-y: auto;\n}\n\n/// Adds base styles for a modal.\n@mixin reveal-modal-base {\n  @include disable-mouse-outline;\n  z-index: $reveal-zindex + 1;\n  // Workaround android browser z-index bug\n  backface-visibility: hidden;\n\n  display: none;\n  padding: $reveal-padding;\n\n  border: $reveal-border;\n  border-radius: $reveal-radius;\n  background-color: $reveal-background;\n\n  @include breakpoint(medium) {\n    min-height: 0;\n  }\n\n  // Make sure rows don't have a min-width on them\n  .column {\n    min-width: 0;\n  }\n\n  // Strip margins from the last item in the modal\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adjusts the width of a modal.\n/// @param {Number} $width - Width of the modal. Generally a percentage.\n/// @param {Number} $max-width [$reveal-max-width] - Maximum width of the modal.\n@mixin reveal-modal-width(\n  $width: $reveal-width,\n  $max-width: $reveal-max-width\n) {\n  // Extends must be made outside of breakpoints for compatibility with newer Sass versions (libsass v3.5)\n  @extend %reveal-centered;\n  @include breakpoint(medium) {\n    width: $width;\n    max-width: $max-width;\n  }\n}\n\n/// Creates a full-screen modal, which stretches the full width and height of the window.\n@mixin reveal-modal-fullscreen {\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n\n  width: 100%;\n  max-width: none;\n  height: 100%;\n  min-height: 100%;\n  margin-left: 0;\n\n  border: 0;\n  border-radius: 0;\n}\n\n@mixin foundation-reveal {\n\n  /// Disables the scroll when Reveal is shown to prevent the background from shifting\n  html.is-reveal-open {\n    position: fixed;\n    width: 100%;\n    overflow-y: hidden;\n\n    &.zf-has-scroll {\n      overflow-y: scroll;\n    }\n\n    body { // sass-lint:disable-line no-qualifying-elements\n      overflow-y: hidden;\n    }\n  }\n\n  // Overlay\n  .reveal-overlay {\n    @include reveal-overlay;\n  }\n\n  // Modal container\n  .reveal {\n    @include reveal-modal-base;\n    @include reveal-modal-width($reveal-width);\n    position: relative;\n    top: 100px;\n    margin-right: auto;\n    margin-left: auto;\n    overflow-y: auto;\n\n    // Remove padding\n    &.collapse {\n      padding: 0;\n    }\n\n    // Sizing classes\n    &.tiny  { @include reveal-modal-width(30%); }\n    &.small { @include reveal-modal-width(50%); }\n    &.large { @include reveal-modal-width(90%); }\n\n    // Full-screen mode\n    &.full {\n      @include reveal-modal-fullscreen;\n    }\n\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include reveal-modal-fullscreen;\n    }\n\n    &.without-overlay {\n      position: fixed;\n    }\n  }\n}\n","@mixin foundation-normalize() {\n  /*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\n\n  // Document\n  // ==========================================================================\n\n  // 1. Correct the line height in all browsers.\n  // 2. Prevent adjustments of font size after orientation changes in iOS.\n\n  html {\n    line-height: 1.15; // 1\n    -webkit-text-size-adjust: 100%; // 2\n  }\n\n  // Sections\n  // ==========================================================================\n\n  // Remove the margin in all browsers.\n\n  body {\n    margin: 0;\n  }\n\n  // Correct the font size and margin on `h1` elements within `section` and\n  // `article` contexts in Chrome, Firefox, and Safari.\n\n  h1 {\n    font-size: 2em;\n    margin: 0.67em 0;\n  }\n\n  // Grouping content\n  // ==========================================================================\n\n  // 1. Add the correct box sizing in Firefox.\n  // 2. Show the overflow in Edge and IE.\n\n  hr {\n    box-sizing: content-box; // 1\n    height: 0; // 1\n    overflow: visible; // 2\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  pre {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Text-level semantics\n  // ==========================================================================\n\n  // Remove the gray background on active links in IE 10.\n\n  a {\n    background-color: transparent;\n  }\n\n  // 1. Remove the bottom border in Chrome 57-\n  // 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n\n  abbr[title] {\n    border-bottom: none; // 1\n    text-decoration: underline; // 2\n    text-decoration: underline dotted; // 2\n  }\n\n  // Add the correct font weight in Chrome, Edge, and Safari.\n\n  b,\n  strong {\n    font-weight: bolder;\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  code,\n  kbd,\n  samp {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Add the correct font size in all browsers.\n\n  small {\n    font-size: 80%;\n  }\n\n  // Prevent `sub` and `sup` elements from affecting the line height in\n  // all browsers.\n\n  sub,\n  sup {\n    font-size: 75%;\n    line-height: 0;\n    position: relative;\n    vertical-align: baseline;\n  }\n\n  sub {\n    bottom: -0.25em;\n  }\n\n  sup {\n    top: -0.5em;\n  }\n\n  // Embedded content\n  // ==========================================================================\n\n  // Remove the border on images inside links in IE 10.\n\n  img {\n    border-style: none;\n  }\n\n  // Forms\n  // ==========================================================================\n\n  // 1. Change the font styles in all browsers.\n  // 2. Remove the margin in Firefox and Safari.\n\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit; // 1\n    font-size: 100%; // 1\n    line-height: 1.15; // 1\n    margin: 0; // 2\n  }\n\n  // Show the overflow in IE.\n  // 1. Show the overflow in Edge.\n\n  button,\n  input { // 1\n    overflow: visible;\n  }\n\n  // Remove the inheritance of text transform in Edge, Firefox, and IE.\n  // 1. Remove the inheritance of text transform in Firefox.\n\n  button,\n  select { // 1\n    text-transform: none;\n  }\n\n  // Correct the inability to style clickable types in iOS and Safari.\n\n  button,\n  [type=\"button\"],\n  [type=\"reset\"],\n  [type=\"submit\"] {\n    -webkit-appearance: button;\n  }\n\n  // Remove the inner border and padding in Firefox.\n\n  button::-moz-focus-inner,\n  [type=\"button\"]::-moz-focus-inner,\n  [type=\"reset\"]::-moz-focus-inner,\n  [type=\"submit\"]::-moz-focus-inner {\n    border-style: none;\n    padding: 0;\n  }\n\n  // Restore the focus styles unset by the previous rule.\n\n  button:-moz-focusring,\n  [type=\"button\"]:-moz-focusring,\n  [type=\"reset\"]:-moz-focusring,\n  [type=\"submit\"]:-moz-focusring {\n    outline: 1px dotted ButtonText;\n  }\n\n  // Correct the padding in Firefox.\n\n  fieldset {\n    padding: 0.35em 0.75em 0.625em;\n  }\n\n  // 1. Correct the text wrapping in Edge and IE.\n  // 2. Correct the color inheritance from `fieldset` elements in IE.\n  // 3. Remove the padding so developers are not caught out when they zero out\n  //    `fieldset` elements in all browsers.\n\n  legend {\n    box-sizing: border-box; // 1\n    color: inherit; // 2\n    display: table; // 1\n    max-width: 100%; // 1\n    padding: 0; // 3\n    white-space: normal; // 1\n  }\n\n  // Add the correct vertical alignment in Chrome, Firefox, and Opera.\n\n  progress {\n    vertical-align: baseline;\n  }\n\n  // Remove the default vertical scrollbar in IE 10+.\n\n  textarea {\n    overflow: auto;\n  }\n\n  // 1. Add the correct box sizing in IE 10.\n  // 2. Remove the padding in IE 10.\n\n  [type=\"checkbox\"],\n  [type=\"radio\"] {\n    box-sizing: border-box; // 1\n    padding: 0; // 2\n  }\n\n  // Correct the cursor style of increment and decrement buttons in Chrome.\n\n  [type=\"number\"]::-webkit-inner-spin-button,\n  [type=\"number\"]::-webkit-outer-spin-button {\n    height: auto;\n  }\n\n  // 1. Correct the odd appearance in Chrome and Safari.\n  // 2. Correct the outline style in Safari.\n\n  [type=\"search\"] {\n    -webkit-appearance: textfield; // 1\n    outline-offset: -2px; // 2\n  }\n\n  // Remove the inner padding in Chrome and Safari on macOS.\n\n  [type=\"search\"]::-webkit-search-decoration {\n    -webkit-appearance: none;\n  }\n\n  // 1. Correct the inability to style clickable types in iOS and Safari.\n  // 2. Change font properties to `inherit` in Safari.\n\n  ::-webkit-file-upload-button {\n    -webkit-appearance: button; // 1\n    font: inherit; // 2\n  }\n\n  // Interactive\n  // ==========================================================================\n\n  // Add the correct display in Edge, IE 10+, and Firefox.\n\n  details {\n    display: block;\n  }\n\n  // Add the correct display in all browsers.\n\n  summary {\n    display: list-item;\n  }\n\n  // Misc\n  // ==========================================================================\n\n  // Add the correct display in IE 10+.\n\n  template {\n    display: none;\n  }\n\n  // Add the correct display in IE 10.\n\n  [hidden] {\n    display: none;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-color-literals, no-qualifying-elements\n\n////\n/// @group global\n////\n\n@import 'util/util';\n\n/// Font size attribute applied to `<html>` and `<body>`. We use 100% by default so the value is inherited from the user's browser settings.\n/// @type Number\n$global-font-size: 100% !default;\n\n/// Global width of your site. Used by the grid to determine row width.\n/// @type Number\n$global-width: rem-calc(1200) !default;\n\n/// Default line height for all type. `$global-lineheight` is 24px while `$global-font-size` is 16px\n/// @type Number\n$global-lineheight: 1.5 !default;\n\n/// Colors used for buttons, callouts, links, etc. There must always be a color called `primary`.\n/// @type Map\n$foundation-palette: (\n  primary: #1779ba,\n  secondary: #767676,\n  success: #3adb76,\n  warning: #ffae00,\n  alert: #cc4b37,\n) !default;\n\n/// Color used for light gray UI items.\n/// @type Color\n$light-gray: #e6e6e6 !default;\n\n/// Color used for medium gray UI items.\n/// @type Color\n$medium-gray: #cacaca !default;\n\n/// Color used for dark gray UI items.\n/// @type Color\n$dark-gray: #8a8a8a !default;\n\n/// Color used for black ui items.\n/// @type Color\n$black: #0a0a0a !default;\n\n/// Color used for white ui items.\n/// @type Color\n$white: #fefefe !default;\n\n/// Background color of the body.\n/// @type Color\n$body-background: $white !default;\n\n/// Text color of the body.\n/// @type Color\n$body-font-color: $black !default;\n\n/// Font stack of the body.\n/// @type List\n$body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif !default;\n\n/// Set to `true` to enable antialiased type, using the `-webkit-font-smoothing` and `-moz-osx-font-smoothing` CSS properties.\n/// @type Boolean\n$body-antialiased: true !default;\n\n/// Global value used for margin on components.\n/// @type Number\n$global-margin: 1rem !default;\n\n/// Global value used for padding on components.\n/// @type Number\n$global-padding: 1rem !default;\n\n/// Global value used for positioning on components.\n/// @type Number\n$global-position: 1rem !default;\n\n/// Global font weight used for normal type.\n/// @type Keyword | Number\n$global-weight-normal: normal !default;\n\n/// Global font weight used for bold type.\n/// @type Keyword | Number\n$global-weight-bold: bold !default;\n\n/// Global value used for all elements that have a border radius.\n/// @type Number\n$global-radius: 0 !default;\n\n/// Global value used for all menu styles. Can be overwritten at individual menu component level.\n/// @type Number\n$global-menu-padding: 0.7rem 1rem !default;\n\n/// Global value used for all menu styles. Nested margin for submenu.\n$global-menu-nested-margin: 1rem !default;\n\n/// Sets the text direction of the CSS. Can be either `ltr` or `rtl`.\n/// @type Keyword\n$global-text-direction: ltr !default;\n\n/// Enables flexbox for components that support it.\n/// @type Boolean\n$global-flexbox: true !default;\n\n/// Enabled responsive breakpoints for prototypes if applicable\n/// @type Boolean\n$global-prototype-breakpoints: false !default;\n\n/// Button cursor's value, `auto` by default\n/// @type Keyword\n$global-button-cursor: auto !default;\n\n@if not map-has-key($foundation-palette, primary) {\n  @error 'In $foundation-palette, you must have a color named \"primary\".';\n}\n\n// Internal variables used for text direction\n$global-left: if($global-text-direction == rtl, right, left);\n$global-right: if($global-text-direction == rtl, left, right);\n\n// Internal variable that contains the flex justifying options\n$-zf-flex-justify: -zf-flex-justify($global-text-direction);\n\n/// Global tolerance for color pick contrast.\n/// @type Number\n$global-color-pick-contrast-tolerance: 0 !default;\n\n// Internal variables used for colors\n@include add-foundation-colors;\n\n@mixin foundation-global-styles {\n  @include foundation-normalize;\n\n  // These styles are applied to a <meta> tag, which is read by the Foundation JavaScript\n  .foundation-mq {\n    font-family: '#{-zf-bp-serialize($breakpoints)}';\n  }\n\n  html {\n    box-sizing: border-box;\n    font-size: $global-font-size;\n  }\n\n  // Set box-sizing globally to handle padding and border widths\n  *,\n  *::before,\n  *::after {\n    box-sizing: inherit;\n  }\n\n  // Default body styles\n  body {\n    margin: 0;\n    padding: 0;\n\n    background: $body-background;\n\n    font-family: $body-font-family;\n    font-weight: $global-weight-normal;\n    line-height: $global-lineheight;\n    color: $body-font-color;\n\n    @if ($body-antialiased) {\n      -webkit-font-smoothing: antialiased; // sass-lint:disable-line no-vendor-prefixes\n      -moz-osx-font-smoothing: grayscale; // sass-lint:disable-line no-vendor-prefixes\n    }\n  }\n\n  img {\n    // Get rid of gap under images by making them display: inline-block; by default\n    display: inline-block;\n    vertical-align: middle;\n\n    // Grid defaults to get images and embeds to work properly\n    max-width: 100%;\n    height: auto;\n    -ms-interpolation-mode: bicubic;\n  }\n\n  // Make sure textarea takes on height automatically\n  textarea {\n    height: auto;\n    min-height: 50px;\n    border-radius: $global-radius;\n  }\n\n  // Make select elements are 100% width by default\n  select {\n    box-sizing: border-box;\n    width: 100%;\n    border-radius: $global-radius;\n  }\n\n  // Styles Google Maps and MapQuest embeds properly\n  // sass-lint:disable-line no-ids\n  .map_canvas,\n  .mqa-display {\n    img,\n    embed,\n    object {\n      max-width: none !important;\n    }\n  }\n\n  // Reset <button> styles created by most browsers\n  button {\n    @include disable-mouse-outline;\n    padding: 0;\n    appearance: none;\n    border: 0;\n    border-radius: $global-radius;\n    background: transparent;\n    line-height: 1;\n    cursor: $global-button-cursor;\n  }\n\n  // Prevent text overflow on pre\n  pre {\n    overflow: auto;\n  }\n\n  // Make reset inherit font-family instead of settings sans-serif\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit;\n  }\n\n  // Internal classes to show/hide elements in JavaScript\n  .is-visible {\n    display: block !important;\n  }\n\n  .is-hidden {\n    display: none !important;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n$global-font-size: 100% !default;\n\n/// Removes the unit (e.g. px, em, rem) from a value, returning the number only.\n///\n/// @param {Number} $num - Number to strip unit from.\n///\n/// @returns {Number} The same number, sans unit.\n@function strip-unit($num) {\n  @return $num / ($num * 0 + 1);\n}\n\n/// Converts one or more pixel values into matching rem values.\n///\n/// @param {Number|List} $values - One or more values to convert. Be sure to separate them with spaces and not commas. If you need to convert a comma-separated list, wrap the list in parentheses.\n/// @param {Number} $base [null] - The base value to use when calculating the `rem`. If you're using Foundation out of the box, this is 16px. If this parameter is `null`, the function will reference the `$global-font-size` variable as the base.\n///\n/// @returns {List} A list of converted values.\n@function rem-calc($values, $base: null) {\n  $rem-values: ();\n  $count: length($values);\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // If the base font size is a %, then multiply it by 16px\n  // This is because 100% font size = 16px in most all browsers\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  // Using rem as base allows correct scaling\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if $count == 1 {\n    @return -zf-to-rem($values, $base);\n  }\n\n  @for $i from 1 through $count {\n    $rem-values: append($rem-values, -zf-to-rem(nth($values, $i), $base));\n  }\n\n  @return $rem-values;\n}\n\n// Converts a unitless, pixel, or rem value to em, for use in breakpoints.\n@function -zf-bp-to-em($value) {\n  // Pixel and unitless values are converted to rems\n  @if unit($value) == 'px' or unitless($value) {\n    $value: rem-calc($value, $base: 16px);\n  }\n\n  // Then the value is converted to ems\n  @return strip-unit($value) * 1em;\n}\n\n/// Converts a pixel value to matching rem value. *Any* value passed, regardless of unit, is assumed to be a pixel value. By default, the base pixel value used to calculate the rem value is taken from the `$global-font-size` variable.\n/// @access private\n///\n/// @param {Number} $value - Pixel value to convert.\n/// @param {Number} $base [null] - Base for pixel conversion.\n///\n/// @returns {Number} A number in rems, calculated based on the given value and the base pixel value. rem values are passed through as is.\n@function -zf-to-rem($value, $base: null) {\n  // Check if the value is a number\n  @if type-of($value) != 'number' {\n    @warn inspect($value) + ' was passed to rem-calc(), which is not a number.';\n    @return $value;\n  }\n\n  // Transform em into rem if someone hands over 'em's\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * 1rem;\n  }\n\n  // Calculate rem if units for $value is not rem or em\n  @if unit($value) != 'rem' {\n    $value: strip-unit($value) / strip-unit($base) * 1rem;\n  }\n\n  // Turn 0rem into 0\n  @if $value == 0rem {\n    $value: 0;\n  }\n\n  @return $value;\n}\n\n/// Converts a pixel, percentage, rem or em value to a unitless value based on a given font size. Ideal for working out unitless line heights.\n///\n/// @param {Number} $value - Value to convert to a unitless line height\n/// @param {Number} $base - The font size to use to work out the line height - defaults to $global-font-size\n///\n/// @return {Number} - Unitless number\n@function unitless-calc($value, $base: null) {\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // First, lets convert our $base to pixels\n\n  // If the base font size is a %, then multiply it by 16px\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if unit($base) == 'em' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  // Now let's convert our value to pixels too\n  @if unit($value) == '%' {\n    $value: ($value / 100%) * $base;\n  }\n\n  @if unit($value) == 'rem' {\n    $value: strip-unit($value) * $base;\n  }\n\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * $base;\n  }\n\n  // 'px'\n  @if unit($value) == 'px' {\n    @return strip-unit($value) / strip-unit($base);\n  }\n\n  // assume that line-heights greater than 10 are meant to be absolute in 'px'\n  @if unitless($value) and ($value > 10) {\n    @return $value / strip-unit($base);\n  }\n\n  @return $value;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Creates an inner box-shadow for only one side\n///\n/// @param {Keyword} $side - Side the shadow is supposed to appear. Can be `top`, `left`, `right` or `bottom`.\n/// @param {Number} $size - Width for the target side.\n/// @param {Color} $color - Color of the shadow.\n@mixin inner-side-shadow(\n  $side: bottom,\n  $size: 20px,\n  $color: rgba($black, 0.25)\n) {\n\n  $helper: round($size * 0.65);\n\n  @if ($side == top) {\n    box-shadow: inset 0 $helper $size (-1)*$helper $color;\n  } @else if ($side == left) {\n    box-shadow: inset $helper 0 $size (-1)*$helper $color;\n  } @else if ($side == right) {\n    box-shadow: inset (-1)*$helper 0 $size (-1)*$helper $color;\n  } @else if ($side == bottom) {\n    box-shadow: inset 0 (-1)*$helper $size (-1)*$helper $color;\n  }\n}\n\n/// Creates a CSS triangle, which can be used for dropdown arrows, dropdown pips, and more. Use this mixin inside a `&::before` or `&::after` selector, to attach the triangle to an existing element.\n///\n/// @param {Number} $triangle-size - Width of the triangle.\n/// @param {Color} $triangle-color - Color of the triangle.\n/// @param {Keyword} $triangle-direction - Direction the triangle points. Can be `up`, `right`, `down`, or `left`.\n@mixin css-triangle(\n  $triangle-size,\n  $triangle-color,\n  $triangle-direction\n) {\n  display: block;\n  width: 0;\n  height: 0;\n\n  border: inset $triangle-size;\n\n  content: '';\n\n  @if ($triangle-direction == down) {\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: $triangle-color transparent transparent;\n  }\n  @if ($triangle-direction == up) {\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == right) {\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == left) {\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent $triangle-color transparent transparent;\n  }\n}\n\n/// Creates a menu icon with a set width, height, number of bars, and colors. The mixin uses the height of the icon and the weight of the bars to determine spacing. <div class=\"docs-example-burger\"></div>\n///\n/// @param {Color} $color [$black] - Color to use for the icon.\n/// @param {Color} $color-hover [$dark-gray] - Color to use when the icon is hovered over.\n/// @param {Number} $width [20px] - Width of the icon.\n/// @param {Number} $height [16px] - Height of the icon.\n/// @param {Number} $weight [2px] - Height of individual bars in the icon.\n/// @param {Number} $bars [3] - Number of bars in the icon.\n@mixin hamburger(\n  $color: $black,\n  $color-hover: $dark-gray,\n  $width: 20px,\n  $height: 16px,\n  $weight: 2px,\n  $bars: 3\n) {\n  // box-shadow CSS output\n  $shadow: ();\n  $hover-shadow: ();\n\n  // Spacing between bars is calculated based on the total height of the icon and the weight of each bar\n  $spacing: ($height - ($weight * $bars)) / ($bars - 1);\n\n  @if unit($spacing) == 'px' {\n    $spacing: floor($spacing);\n  }\n\n  @for $i from 2 through $bars {\n    $offset: ($weight + $spacing) * ($i - 1);\n    $shadow: append($shadow, 0 $offset 0 $color, comma);\n  }\n\n  // Icon container\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: $width;\n  height: $height;\n  cursor: pointer;\n\n  // Icon bars\n  &::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n\n    display: block;\n    width: 100%;\n    height: $weight;\n\n    background: $color;\n    box-shadow: $shadow;\n\n    content: '';\n  }\n\n  // Hover state\n  @if $color-hover {\n    // Generate CSS\n    @for $i from 2 through $bars {\n      $offset: ($weight + $spacing) * ($i - 1);\n      $hover-shadow: append($hover-shadow, 0 $offset 0 $color-hover, comma);\n    }\n\n    &:hover::after {\n      background: $color-hover;\n      box-shadow: $hover-shadow;\n    }\n  }\n}\n\n/// Adds a downward-facing triangle as a background image to an element. The image is formatted as an SVG, making it easy to change the color. Because Internet Explorer doesn't support encoded SVGs as background images, a PNG fallback is also included.\n/// There are two PNG fallbacks: a black triangle and a white triangle. The one used depends on the lightness of the input color.\n///\n/// @param {Color} $color [$black] - Color to use for the triangle.\n@mixin background-triangle($color: $black) {\n  $rgb: 'rgb%28#{round(red($color))}, #{round(green($color))}, #{round(blue($color))}%29';\n\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: #{$rgb}'></polygon></svg>\");\n\n  @media screen and (min-width:0\\0) {\n    @if lightness($color) < 60% {\n      // White triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==');\n    }\n    @else {\n      // Black triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAMBJREFUeNrEllsOhCAMRVszC9IlzU7KCmVHTJsoMWYMUtpyv9BgbuXQB5ZSdgBYYY4ycgBivk8KYFsQMfMiTTBP4o3nUzCKzOabLJbLy2/g31evGkAginR4/ZegKH5qX3bJCscA3t0x3kgO5tQFyhhFf50xRqFLbyMUNJQzgyjGS/wgCpvKqkRBpuWrE4V9d+1E4dPUXqIg107SQOE/2DRQxMwTDygIInVDET9T3lCoj/6j/VCmGjZOl2lKpZ8AAwDQP7zIimDGFQAAAABJRU5ErkJggg==');\n    }\n  }\n}\n\n/// Applies the micro clearfix hack popularized by Nicolas Gallagher. Include this mixin on a container if its children are all floated, to give the container a proper height.\n/// The clearfix is augmented with specific styles to prevent borders in flexbox environments\n/// @link http://nicolasgallagher.com/micro-clearfix-hack/ Micro Clearfix Hack\n/// @link http://danisadesigner.com/blog/flexbox-clear-fix-pseudo-elements/ Flexbox fix\n@mixin clearfix {\n  &::before,\n  &::after {\n    display: table;\n    content: ' ';\n\n    @if $global-flexbox {\n      flex-basis: 0;\n      order: 1;\n    }\n  }\n\n  &::after {\n    clear: both;\n  }\n}\n\n/// Adds CSS for a \"quantity query\" selector that automatically sizes elements based on how many there are inside a container.\n/// @link http://alistapart.com/article/quantity-queries-for-css Quantity Queries for CSS\n///\n/// @param {Number} $max - Maximum number of items to detect. The higher this number is, the more CSS that's required to cover each number of items.\n/// @param {Keyword} $elem [li] - Tag to use for sibling selectors.\n@mixin auto-width($max, $elem: li) {\n  @for $i from 2 through $max {\n    &:nth-last-child(#{$i}):first-child,\n    &:nth-last-child(#{$i}):first-child ~ #{$elem} {\n      width: percentage(1 / $i);\n    }\n  }\n}\n\n/// Removes the focus ring around an element when a mouse input is detected.\n@mixin disable-mouse-outline {\n  [data-whatinput='mouse'] & {\n    outline: 0;\n  }\n}\n\n/// Makes an element visually hidden, but still accessible to keyboards and assistive devices.\n/// @link http://snook.ca/archives/html_and_css/hiding-content-for-accessibility Hiding Content for Accessibility\n/// @link http://hugogiraudel.com/2016/10/13/css-hide-and-seek/\n@mixin element-invisible {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0,0,0,0);\n  white-space: nowrap;\n  border: 0;\n}\n\n/// Reverses the CSS output created by the `element-invisible()` mixin.\n@mixin element-invisible-off {\n  position: static !important;\n  width: auto;\n  height: auto;\n  overflow: visible;\n  clip: auto;\n  white-space: normal;\n}\n\n/// Vertically centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin vertical-center {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Horizontally centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin horizontal-center {\n  position: absolute;\n  left: 50%;\n  transform: translateX(-50%);\n}\n\n/// Absolutely centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin absolute-center {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n}\n\n/// Iterates through breakpoints defined in `$breakpoint-classes` and prints the CSS inside the mixin at each breakpoint's media query. Use this with the grid, or any other component that has responsive classes.\n///\n/// @param {Boolean} $small [true] - If `false`, the mixin will skip the `small` breakpoint. Use this with components that don't prefix classes with `small-`, only `medium-` and up.\n/// @param {Boolean} $auto-insert-breakpoints [true] - If `false`, the mixin will iterate over breakpoints without doing the media query itself. Useful for more complex media query generation as in the margin grid.\n@mixin -zf-each-breakpoint($small: true, $auto-insert-breakpoints: true) {\n  $list: $breakpoint-classes;\n\n  @if not $small {\n    $list: sl-remove($list, $-zf-zero-breakpoint);\n  }\n\n  @each $name in $list {\n    $old-zf-size: null;\n    @if global-variable-exists(-zf-size) {\n      $old-zf-size: $-zf-size;\n    }\n    $-zf-size: $name !global;\n\n    @if $auto-insert-breakpoints {\n      @include breakpoint($name) {\n        @content;\n      }\n    }\n    @else {\n      @content;\n    }\n\n    $-zf-size: $old-zf-size !global;\n  }\n}\n\n/// Generate the `@content` passed to the mixin with a value `$-zf-bp-value` related to a breakpoint, depending on the `$name` parameter:\n/// - For a single value, `$-zf-bp-value` is this value.\n/// - For a breakpoint name, `$-zf-bp-value` is the corresponding breakpoint value in `$map`.\n/// - For \"auto\", `$-zf-bp-value` is the corresponding breakpoint value in `$map` and is passed to `@content`, which is made responsive for each breakpoint of `$map`.\n/// @param {Number|Array|Keyword} $name [auto] - Single value, breakpoint name, or list of breakpoint names to use. \"auto\" by default.\n/// @param {Number|Map} $map - Map of breakpoints and values or single value to use.\n@mixin -zf-breakpoint-value(\n  $name: auto,\n  $map: null\n) {\n  @if $name == auto and type-of($map) == 'map' {\n    // \"auto\"\n    @each $k, $v in $map {\n      @include breakpoint($k) {\n        @include -zf-breakpoint-value($v, $map) {\n          @content;\n        }\n      }\n    }\n  }\n  @else {\n    // breakpoint name\n    @if type-of($name) == 'string' {\n      $name: -zf-get-bp-val($map, $name);\n    }\n\n    // breakpoint value\n    $-zf-bp-value: $name !global;\n    @content;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Font color of text inputs.\n/// @type Color\n$input-color: $black !default;\n\n/// Font color of placeholder text within text inputs.\n/// @type Color\n$input-placeholder-color: $medium-gray !default;\n\n/// Font family of text inputs.\n/// @type Font\n$input-font-family: inherit !default;\n\n/// Font size of text inputs.\n/// @type Number\n$input-font-size: rem-calc(16) !default;\n\n/// Font weight of text inputs.\n/// @type Keyword\n$input-font-weight: $global-weight-normal !default;\n\n/// Line height of text inputs.\n/// @type Keyword\n$input-line-height: $global-lineheight !default;\n\n/// Background color of text inputs.\n/// @type Color\n$input-background: $white !default;\n\n/// Background color of focused of text inputs.\n/// @type Color\n$input-background-focus: $white !default;\n\n/// Background color of disabled text inputs.\n/// @type Color\n$input-background-disabled: $light-gray !default;\n\n/// Border around text inputs.\n/// @type Border\n$input-border: 1px solid $medium-gray !default;\n\n/// Border around focused text inputs.\n/// @type Color\n$input-border-focus: 1px solid $dark-gray !default;\n\n/// Padding of text inputs.\n/// @type Color\n$input-padding: $form-spacing / 2 !default;\n\n/// Box shadow inside text inputs when not focused.\n/// @type Shadow\n$input-shadow: inset 0 1px 2px rgba($black, 0.1) !default;\n\n/// Box shadow outside text inputs when focused.\n/// @type Shadow\n$input-shadow-focus: 0 0 5px $medium-gray !default;\n\n/// Cursor to use when hovering over a disabled text input.\n/// @type Cursor\n$input-cursor-disabled: not-allowed !default;\n\n/// Properties to transition on text inputs.\n/// @type Transition\n$input-transition: box-shadow 0.5s, border-color 0.25s ease-in-out !default;\n\n/// Enables the up/down buttons that Chrome and Firefox add to `<input type='number'>` elements.\n/// @type Boolean\n$input-number-spinners: true !default;\n\n/// Radius for text inputs.\n/// @type Border\n$input-radius: $global-radius !default;\n\n/// Border radius for form buttons, defaulted to global-radius.\n/// @type Number\n$form-button-radius: $global-radius !default;\n\n@mixin form-element {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  border: $input-border;\n  border-radius: $input-radius;\n  background-color: $input-background;\n  box-shadow: $input-shadow;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n}\n\n@mixin foundation-form-text {\n  // Text inputs\n  #{text-inputs()},\n  textarea {\n    @include form-element;\n    appearance: none;\n  }\n\n  // Text areas\n  textarea {\n    max-width: 100%;\n\n    &[rows] {\n      height: auto;\n    }\n  }\n\n  input,\n  textarea {\n    // Disabled/readonly state\n    &:disabled,\n    &[readonly] {\n      background-color: $input-background-disabled;\n      cursor: $input-cursor-disabled;\n    }\n  }\n\n  // Reset styles on button-like inputs\n  [type='submit'],\n  [type='button'] {\n    appearance: none;\n    border-radius: $form-button-radius;\n  }\n\n  // Reset Normalize setting content-box to search elements\n  input[type='search'] { // sass-lint:disable-line no-qualifying-elements\n    box-sizing: border-box;\n  }\n\n  // Number input styles\n  [type='number'] {\n    @if not $input-number-spinners {\n      -moz-appearance: textfield; // sass-lint:disable-line no-vendor-prefixes\n\n      &::-webkit-inner-spin-button,\n      &::-webkit-outer-spin-button {\n        -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n        margin: 0;\n      }\n    }\n  }\n\n  // Placeholder text\n  ::placeholder {\n    color: $input-placeholder-color;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n@mixin foundation-form-checkbox {\n  [type='file'],\n  [type='checkbox'],\n  [type='radio'] {\n    margin: 0 0 $form-spacing;\n  }\n\n  // Styles for input/label siblings\n  [type='checkbox'] + label,\n  [type='radio'] + label {\n    display: inline-block;\n    vertical-align: baseline;\n\n    margin-#{$global-left}: $form-spacing * 0.5;\n    margin-#{$global-right}: $form-spacing;\n    margin-bottom: 0;\n\n    &[for] {\n      cursor: pointer;\n    }\n  }\n\n  // Styles for inputs inside labels\n  label > [type='checkbox'],\n  label > [type='radio'] {\n    margin-#{$global-right}: $form-spacing * 0.5;\n  }\n\n  // Normalize file input width\n  [type='file'] {\n    width: 100%;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color for form labels.\n/// @type Color\n$form-label-color: $black !default;\n\n/// Font size for form labels.\n/// @type Number\n$form-label-font-size: rem-calc(14) !default;\n\n/// Font weight for form labels.\n/// @type Keyword\n$form-label-font-weight: $global-weight-normal !default;\n\n/// Line height for form labels. The higher the number, the more space between the label and its input field.\n/// @type Number\n$form-label-line-height: 1.8 !default;\n\n@mixin form-label {\n  display: block;\n  margin: 0;\n\n  font-size: $form-label-font-size;\n  font-weight: $form-label-font-weight;\n  line-height: $form-label-line-height;\n  color: $form-label-color;\n}\n\n@mixin form-label-middle {\n  $input-border-width: get-border-value($input-border, width);\n\n  margin: 0 0 $form-spacing;\n  padding: ($form-spacing / 2 + rem-calc($input-border-width)) 0;\n}\n\n@mixin foundation-form-label {\n  label {\n    @include form-label;\n\n    &.middle {\n      @include form-label-middle;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default color for help text.\n/// @type Color\n$helptext-color: $black !default;\n\n/// Default font size for help text.\n/// @type Number\n$helptext-font-size: rem-calc(13) !default;\n\n/// Default font style for help text.\n/// @type Keyword\n$helptext-font-style: italic !default;\n\n@mixin foundation-form-helptext {\n  .help-text {\n    $margin-top: ($form-spacing * 0.5) * -1;\n\n    margin-top: $margin-top;\n    font-size: $helptext-font-size;\n    font-style: $helptext-font-style;\n    color: $helptext-color;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color of labels prefixed to an input.\n/// @type Color\n$input-prefix-color: $black !default;\n\n/// Background color of labels prefixed to an input.\n/// @type Color\n$input-prefix-background: $light-gray !default;\n\n/// Border around labels prefixed to an input.\n/// @type Border\n$input-prefix-border: 1px solid $medium-gray !default;\n\n/// Left/right padding of an pre/postfixed input label\n$input-prefix-padding: 1rem !default;\n\n@mixin foundation-form-prepostfix {\n  $height: ($input-font-size * $input-line-height) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  .input-group {\n    display: if($global-flexbox, flex, table);\n    width: 100%;\n    margin-bottom: $form-spacing;\n\n    @if $global-flexbox {\n      align-items: stretch;\n    }\n\n    > :first-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, 0 $input-radius $input-radius 0, $input-radius 0 0 $input-radius);\n      }\n    }\n\n    > :last-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, $input-radius 0 0 $input-radius, 0 $input-radius $input-radius 0);\n      }\n    }\n  }\n\n  %input-group-child {\n    margin: 0;\n    white-space: nowrap;\n\n    @if not $global-flexbox {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n\n  .input-group-label {\n    @extend %input-group-child;\n    padding: 0 $input-prefix-padding;\n    border: $input-prefix-border;\n    background: $input-prefix-background;\n\n    color: $input-prefix-color;\n    text-align: center;\n    white-space: nowrap;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n      align-items: center;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    @if has-value($input-prefix-border) {\n      &:first-child {\n        border-#{$global-right}: 0;\n      }\n\n      &:last-child {\n        border-#{$global-left}: 0;\n      }\n    }\n  }\n\n  .input-group-field {\n    @extend %input-group-child;\n    border-radius: 0;\n\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n      min-width: 0;\n    }\n  }\n\n  .input-group-button {\n    @extend %input-group-child;\n    padding-top: 0;\n    padding-bottom: 0;\n    text-align: center;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    a,\n    input,\n    button,\n    label {\n      @extend %input-group-child;\n\n      @if $global-flexbox {\n        align-self: stretch;\n        height: auto;\n      }\n      @else {\n        height: $height;\n      }\n      padding-top: 0;\n      padding-bottom: 0;\n      font-size: $input-font-size;\n    }\n  }\n\n  // Specificity bump needed to prevent override by buttons\n  @if not $global-flexbox {\n    .input-group {\n      .input-group-button {\n        display: table-cell;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default border around custom fieldsets.\n/// @type Border\n$fieldset-border: 1px solid $medium-gray !default;\n\n/// Default padding inside custom fieldsets.\n/// @type Number\n$fieldset-padding: rem-calc(20) !default;\n\n/// Default margin around custom fieldsets.\n/// @type Number\n$fieldset-margin: rem-calc(18 0) !default;\n\n/// Default padding between the legend text and fieldset border.\n/// @type Number\n$legend-padding: rem-calc(0 3) !default;\n\n@mixin fieldset {\n  margin: $fieldset-margin;\n  padding: $fieldset-padding;\n  border: $fieldset-border;\n\n  legend {\n    // Covers up the fieldset's border to create artificial padding\n    margin: 0;\n    margin-#{$global-left}: rem-calc(-3);\n    padding: $legend-padding;\n  }\n}\n\n@mixin foundation-form-fieldset {\n  fieldset {\n    margin: 0;\n    padding: 0;\n    border: 0;\n  }\n\n  legend {\n    max-width: 100%;\n    margin-bottom: $form-spacing * 0.5;\n  }\n\n  .fieldset {\n    @include fieldset;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Background color for select menus.\n/// @type Color\n$select-background: $white !default;\n\n/// Color of the dropdown triangle inside select menus. Set to `transparent` to remove it entirely.\n/// @type Color\n$select-triangle-color: $dark-gray !default;\n\n/// Default radius for select menus.\n/// @type Color\n$select-radius: $global-radius !default;\n\n@mixin form-select {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  appearance: none;\n  border: $input-border;\n  border-radius: $select-radius;\n  background-color: $select-background;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if $select-triangle-color != transparent {\n    @include background-triangle($select-triangle-color);\n    background-origin: content-box;\n    background-position: $global-right (-$form-spacing) center;\n    background-repeat: no-repeat;\n    background-size: 9px 6px;\n\n    padding-#{$global-right}: ($form-spacing * 1.5);\n  }\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n\n  // Disabled state\n  &:disabled {\n    background-color: $input-background-disabled;\n    cursor: $input-cursor-disabled;\n  }\n\n  // Hide the dropdown arrow shown in newer IE versions\n  &::-ms-expand {\n    display: none;\n  }\n\n  &[multiple] {\n    height: auto;\n    background-image: none;\n  }\n}\n\n@mixin foundation-form-select {\n  select {\n    @include form-select;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group abide\n////\n\n/// Sets if error styles should be added to inputs.\n/// @type Boolean\n$abide-inputs: true !default;\n\n/// Sets if error styles should be added to labels.\n/// @type Boolean\n$abide-labels: true !default;\n\n/// Background color to use for invalid text inputs.\n/// @type Color\n$input-background-invalid: get-color(alert) !default;\n\n/// Color to use for labels of invalid inputs.\n/// @type Color\n$form-label-color-invalid: get-color(alert) !default;\n\n/// Default font color for form error text.\n/// @type Color\n$input-error-color: get-color(alert) !default;\n\n/// Default font size for form error text.\n/// @type Number\n$input-error-font-size: rem-calc(12) !default;\n\n/// Default font weight for form error text.\n/// @type Keyword\n$input-error-font-weight: $global-weight-bold !default;\n\n/// Styles the background and border of an input field to have an error state.\n///\n/// @param {Color} $background [$alert-color] - Color to use for the background and border.\n/// @param {Number} $background-lighten [10%] - Lightness level of the background color.\n@mixin form-input-error(\n  $background: $input-background-invalid,\n  $background-lighten: 10%\n) {\n  &:not(:focus) {\n    border-color: $background;\n    background-color: mix($background, $white, $background-lighten);\n\n    &::placeholder {\n      color: $background;\n    }\n  }\n}\n\n/// Adds error styles to a form element, using the values in the settings file.\n@mixin form-error {\n  display: none;\n  margin-top: $form-spacing * -0.5;\n  margin-bottom: $form-spacing;\n\n  font-size: $input-error-font-size;\n  font-weight: $input-error-font-weight;\n  color: $input-error-color;\n}\n\n@mixin foundation-form-error {\n  @if $abide-inputs {\n    // Error class for invalid inputs\n    .is-invalid-input {\n      @include form-input-error;\n    }\n  }\n\n  @if $abide-labels {\n    // Error class for labels of invalid outputs\n    .is-invalid-label {\n      color: $form-label-color-invalid;\n    }\n  }\n\n  // Form error element\n  .form-error {\n    @include form-error;\n\n    &.is-visible {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group typography-base\n////\n\n// Base Typography\n// - - - - - - - - - - - - - - -\n// These are styles applied to basic HTML tags, including:\n//   - Paragraphs <p>\n//   - Bold/italics <b> <strong> <i> <em>\n//   - Small text <small>\n//   - Headings <h1>-<h6>\n//   - Anchors <a>\n//   - Dividers <hr>\n//   - Lists <ul> <ol> <dl>\n//   - Blockquotes <blockquote>\n//   - Code blocks <code>\n//   - Abbreviations <abbr>\n//   - Citations <cite>\n//   - Keystrokes <kbd>\n\n/// Font family for header elements.\n/// @type String | List\n$header-font-family: $body-font-family !default;\n\n/// Font weight of headers.\n/// @type String\n$header-font-weight: $global-weight-normal !default;\n\n/// Font style (e.g. italicized) of headers.\n/// @type String\n$header-font-style: normal !default;\n\n/// Font stack used for elements that use monospaced type, such as code samples\n/// @type String | List\n$font-family-monospace: Consolas, 'Liberation Mono', Courier, monospace !default;\n\n/// Color of headers.\n/// @type Color\n$header-color: inherit !default;\n\n/// Line height of headers.\n/// @type Number\n$header-lineheight: 1.4 !default;\n\n/// Bottom margin of headers.\n/// @type Number\n$header-margin-bottom: 0.5rem !default;\n\n/// Styles for headings at various screen sizes. Each key is a breakpoint, and each value is a map of heading styles.\n/// @type Map\n$header-styles: (\n  small: (\n    'h1': ('font-size': 24),\n    'h2': ('font-size': 20),\n    'h3': ('font-size': 19),\n    'h4': ('font-size': 18),\n    'h5': ('font-size': 17),\n    'h6': ('font-size': 16),\n  ),\n  medium: (\n    'h1': ('font-size': 48),\n    'h2': ('font-size': 40),\n    'h3': ('font-size': 31),\n    'h4': ('font-size': 25),\n    'h5': ('font-size': 20),\n    'h6': ('font-size': 16),\n  ),\n) !default;\n\n// $header-styles map is built from $header-sizes in order to ensure downward compatibility\n// when $header-sizes is depreciated, $header-styles needs to get !default values like settings.scss\n@function build_from_header-sizes($header-sizes) {\n  @warn 'Note, that $header-sizes has been replaced with $header-styles. $header-sizes still works, but it is going to be depreciated.';\n  $header-styles: ();\n  @each $size, $headers in $header-sizes {\n    $header-map: ();\n    @each $header, $font-size in $headers {\n      $header-map: map-merge($header-map, ($header: ('font-size': $font-size)));\n    }\n    $header-styles: map-merge($header-styles, ($size: $header-map));\n  }\n  @return $header-styles;\n}\n\n// If it exists $headers-sizes is used to build $header-styles. See the documentation.\n@if variable-exists(header-sizes) {\n  $header-styles: build_from_header-sizes($header-sizes);\n}\n\n/// Text rendering method of headers.\n/// @type String\n$header-text-rendering: optimizeLegibility !default;\n\n/// Font size of `<small>` elements.\n/// @type Number\n$small-font-size: 80% !default;\n\n/// Color of `<small>` elements when placed inside headers.\n/// @type Color\n$header-small-font-color: $medium-gray !default;\n\n/// Line height of text inside `<p>` elements.\n/// @type Number\n$paragraph-lineheight: 1.6 !default;\n\n/// Bottom margin of paragraphs.\n/// @type Number\n$paragraph-margin-bottom: 1rem !default;\n\n/// Text rendering method for paragraph text.\n/// @type String\n$paragraph-text-rendering: optimizeLegibility !default;\n\n/// Text color of code samples.\n/// @type Color\n$code-color: $black !default;\n\n/// Font family of code samples.\n/// @type String | List\n$code-font-family: $font-family-monospace !default;\n\n/// Font weight of text in code samples.\n/// @type String\n$code-font-weight: $global-weight-normal !default;\n\n/// Background color of code samples.\n/// @type Color\n$code-background: $light-gray !default;\n\n/// Border around code samples.\n/// @type List\n$code-border: 1px solid $medium-gray !default;\n\n/// Padding around text of code samples.\n/// @type Number | List\n$code-padding: rem-calc(2 5 1) !default;\n\n/// Default color for links.\n/// @type Color\n$anchor-color: $primary-color !default;\n\n/// Default color for links on hover.\n/// @type Color\n$anchor-color-hover: scale-color($anchor-color, $lightness: -14%) !default;\n\n/// Default text decoration for links.\n/// @type String\n$anchor-text-decoration: none !default;\n\n/// Default text decoration for links on hover.\n/// @type String\n$anchor-text-decoration-hover: none !default;\n\n/// Maximum width of a divider.\n/// @type Number\n$hr-width: $global-width !default;\n\n/// Default border for a divider.\n/// @type List\n$hr-border: 1px solid $medium-gray !default;\n\n/// Default margin for a divider.\n/// @type Number | List\n$hr-margin: rem-calc(20) auto !default;\n\n/// Line height for items in a list.\n/// @type Number\n$list-lineheight: $paragraph-lineheight !default;\n\n/// Bottom margin for items in a list.\n/// @type Number\n$list-margin-bottom: $paragraph-margin-bottom !default;\n\n/// Bullet type to use for unordered lists (e.g., `square`, `circle`, `disc`).\n/// @type String\n$list-style-type: disc !default;\n\n/// Positioning for bullets on unordered list items.\n/// @type String\n$list-style-position: outside !default;\n\n/// Left (or right) margin for lists.\n/// @type Number\n$list-side-margin: 1.25rem !default;\n\n/// Left (or right) margin for a list inside a list.\n/// @type Number\n$list-nested-side-margin: 1.25rem !default;\n\n/// Bottom margin for `<dl>` elements.\n/// @type Number\n$defnlist-margin-bottom: 1rem !default;\n\n/// Font weight for `<dt>` elements.\n/// @type String\n$defnlist-term-weight: $global-weight-bold !default;\n\n/// Spacing between `<dt>` and `<dd>` elements.\n/// @type Number\n$defnlist-term-margin-bottom: 0.3rem !default;\n\n/// Text color of `<blockquote>` elements.\n/// @type Color\n$blockquote-color: $dark-gray !default;\n\n/// Padding inside a `<blockquote>` element.\n/// @type Number | List\n$blockquote-padding: rem-calc(9 20 0 19) !default;\n\n/// Side border for `<blockquote>` elements.\n/// @type List\n$blockquote-border: 1px solid $medium-gray !default;\n\n/// Font size for `<cite>` elements.\n/// @type Number\n$cite-font-size: rem-calc(13) !default;\n\n/// Text color for `<cite>` elements.\n/// @type Color\n$cite-color: $dark-gray !default;\n\n/// Pseudo content for `<cite>` elements.\n/// @type String\n$cite-pseudo-content: '\\2014 \\0020' !default;\n\n/// Font family for `<kbd>` elements.\n/// @type String | List\n$keystroke-font: $font-family-monospace !default;\n\n/// Text color for `<kbd>` elements.\n/// @type Color\n$keystroke-color: $black !default;\n\n/// Background color for `<kbd>` elements.\n/// @type Color\n$keystroke-background: $light-gray !default;\n\n/// Padding for `<kbd>` elements.\n/// @type Number | List\n$keystroke-padding: rem-calc(2 4 0) !default;\n\n/// Border radius for `<kbd>` elements.\n/// @type Number | List\n$keystroke-radius: $global-radius !default;\n\n/// Bottom border style for `<abbr>` elements.\n/// @type List\n$abbr-underline: 1px dotted $black !default;\n\n@mixin foundation-typography-base {\n  // Typography resets\n  div,\n  dl,\n  dt,\n  dd,\n  ul,\n  ol,\n  li,\n  h1,\n  h2,\n  h3,\n  h4,\n  h5,\n  h6,\n  pre,\n  form,\n  p,\n  blockquote,\n  th,\n  td {\n    margin: 0;\n    padding: 0;\n  }\n\n  // Paragraphs\n  p {\n    margin-bottom: $paragraph-margin-bottom;\n\n    font-size: inherit;\n    line-height: $paragraph-lineheight;\n    text-rendering: $paragraph-text-rendering;\n  }\n\n  // Emphasized text\n  em,\n  i {\n    font-style: italic;\n    line-height: inherit;\n  }\n\n  // Strong text\n  strong,\n  b {\n    font-weight: $global-weight-bold;\n    line-height: inherit;\n  }\n\n  // Small text\n  small {\n    font-size: $small-font-size;\n    line-height: inherit;\n  }\n\n  // Headings\n  h1, .h1,\n  h2, .h2,\n  h3, .h3,\n  h4, .h4,\n  h5, .h5,\n  h6, .h6 {\n    font-family: $header-font-family;\n    font-style: $header-font-style;\n    font-weight: $header-font-weight;\n    color: $header-color;\n    text-rendering: $header-text-rendering;\n\n    small {\n      line-height: 0;\n      color: $header-small-font-color;\n    }\n  }\n\n  // Heading styles\n  @each $size, $headers in $header-styles {\n    @include breakpoint($size) {\n      @each $header, $header-defs in $headers {\n        $font-size-temp: 1rem;\n        #{$header}, .#{$header} {\n\n          @if map-has-key($header-defs, font-size) {\n            $font-size-temp: rem-calc(map-get($header-defs, font-size));\n            font-size: $font-size-temp;\n          } @else if map-has-key($header-defs, fs) {\n            $font-size-temp: rem-calc(map-get($header-defs, fs));\n            font-size: $font-size-temp;\n          } @else if $size == $-zf-zero-breakpoint {\n            font-size: $font-size-temp;\n          }\n          @if map-has-key($header-defs, line-height) {\n            line-height: unitless-calc(map-get($header-defs, line-height), $font-size-temp);\n          } @else if map-has-key($header-defs, lh) {\n            line-height: unitless-calc(map-get($header-defs, lh), $font-size-temp);\n          } @else if $size == $-zf-zero-breakpoint {\n            line-height: unitless-calc($header-lineheight, $font-size-temp);\n          }\n\n          @if map-has-key($header-defs, margin-top) {\n            margin-top: rem-calc(map-get($header-defs, margin-top));\n          } @else if map-has-key($header-defs, mt) {\n            margin-top: rem-calc(map-get($header-defs, mt));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-top: 0;\n          }\n          @if map-has-key($header-defs, margin-bottom) {\n            margin-bottom: rem-calc(map-get($header-defs, margin-bottom));\n          } @else if map-has-key($header-defs, mb) {\n            margin-bottom: rem-calc(map-get($header-defs, mb));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-bottom: rem-calc($header-margin-bottom);\n          }\n        }\n      }\n    }\n  }\n\n  // Links\n  a {\n    line-height: inherit;\n    color: $anchor-color;\n    text-decoration: $anchor-text-decoration;\n\n    cursor: pointer;\n\n    &:hover,\n    &:focus {\n      color: $anchor-color-hover;\n      @if $anchor-text-decoration-hover != $anchor-text-decoration {\n        text-decoration: $anchor-text-decoration-hover;\n      }\n    }\n\n    img {\n      border: 0;\n    }\n  }\n\n  // Horizontal rule\n  hr {\n    clear: both;\n\n    max-width: $hr-width;\n    height: 0;\n    margin: $hr-margin;\n\n    border-top: 0;\n    border-right: 0;\n    border-bottom: $hr-border;\n    border-left: 0;\n  }\n\n  // Lists\n  ul,\n  ol,\n  dl {\n    margin-bottom: $list-margin-bottom;\n    list-style-position: $list-style-position;\n    line-height: $list-lineheight;\n  }\n\n  // List items\n  li {\n    font-size: inherit;\n  }\n\n  // Unordered lists\n  ul {\n    margin-#{$global-left}: $list-side-margin;\n    list-style-type: $list-style-type;\n  }\n\n  // Ordered lists\n  ol {\n    margin-#{$global-left}: $list-side-margin;\n  }\n\n  // Nested unordered/ordered lists\n  ul, ol {\n    & & {\n      margin-#{$global-left}: $list-nested-side-margin;\n      margin-bottom: 0;\n    }\n  }\n\n  // Definition lists\n  dl {\n    margin-bottom: $defnlist-margin-bottom;\n\n    dt {\n      margin-bottom: $defnlist-term-margin-bottom;\n      font-weight: $defnlist-term-weight;\n    }\n  }\n\n  // Blockquotes\n  blockquote {\n    margin: 0 0 $paragraph-margin-bottom;\n    padding: $blockquote-padding;\n    border-#{$global-left}: $blockquote-border;\n\n    &, p {\n      line-height: $paragraph-lineheight;\n      color: $blockquote-color;\n    }\n  }\n\n  // Citations\n  cite {\n    display: block;\n    font-size: $cite-font-size;\n    color: $cite-color;\n\n    &:before {\n      content: $cite-pseudo-content;\n    }\n  }\n\n  // Abbreviations\n  abbr, abbr[title] {\n    border-bottom: $abbr-underline;\n    cursor: help;\n    text-decoration: none;\n  }\n\n  // Figures\n  figure {\n    margin: 0;\n  }\n\n  // Code\n  code {\n    padding: $code-padding;\n\n    border: $code-border;\n    background-color: $code-background;\n\n    font-family: $code-font-family;\n    font-weight: $code-font-weight;\n    color: $code-color;\n  }\n\n  // Keystrokes\n  kbd {\n    margin: 0;\n    padding: $keystroke-padding;\n\n    background-color: $keystroke-background;\n\n    font-family: $keystroke-font;\n    color: $keystroke-color;\n\n    @if has-value($keystroke-radius) {\n      border-radius: $keystroke-radius;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group typography-helpers\n////\n\n/// Default font size for lead paragraphs.\n/// @type Number\n$lead-font-size: $global-font-size * 1.25 !default;\n\n/// Default line height for lead paragraphs.\n/// @type String\n$lead-lineheight: 1.6 !default;\n\n/// Default line height for subheaders.\n/// @type Number\n$subheader-lineheight: 1.4 !default;\n\n/// Default font color for subheaders.\n/// @type Color\n$subheader-color: $dark-gray !default;\n\n/// Default font weight for subheaders.\n/// @type String\n$subheader-font-weight: $global-weight-normal !default;\n\n/// Default top margin for subheaders.\n/// @type Number\n$subheader-margin-top: 0.2rem !default;\n\n/// Default bottom margin for subheaders.\n/// @type Number\n$subheader-margin-bottom: 0.5rem !default;\n\n/// Default font size for statistic numbers.\n/// @type Number\n$stat-font-size: 2.5rem !default;\n\n@mixin foundation-typography-helpers {\n  // Use to create a subheading under a main header\n  // Make sure you pair the two elements in a <header> element, like this:\n  // <header>\n  //   <h1>Heading</h1>\n  //   <h2>Subheading</h2>\n  // </header>\n  .subheader {\n    margin-top: $subheader-margin-top;\n    margin-bottom: $subheader-margin-bottom;\n\n    font-weight: $subheader-font-weight;\n    line-height: $subheader-lineheight;\n    color: $subheader-color;\n  }\n\n  // Use to style an introductory lead, deck, blurb, etc.\n  .lead {\n    font-size: $lead-font-size;\n    line-height: $lead-lineheight;\n  }\n\n  // Use to style a large number to display a statistic\n  .stat {\n    font-size: $stat-font-size;\n    line-height: 1;\n\n    p + & {\n      margin-top: -1rem;\n    }\n  }\n\n  ul, ol {\n    // Use to remove numbers from ordered list & bullets from unordered list\n    &.no-bullet {\n      margin-#{$global-left}: 0;\n      list-style: none;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@mixin foundation-text-alignment {\n  @each $size in $breakpoint-classes {\n    @include breakpoint($size) {\n      @each $align in (left, right, center, justify) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-text-#{$align} {\n            text-align: $align;\n          }\n        }\n        @else {\n          .text-#{$align} {\n            text-align: $align;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// If `true`, all elements will have transparent backgrounds when printed, to save on ink.\n/// @type Boolean\n/// @group global\n$print-transparent-backgrounds: true !default;\n\n/// If `true`, displays next to all links their \"href\" when printed.\n/// @type Boolean\n/// @group global\n$print-hrefs: true !default;\n\n// sass-lint:disable-all\n\n@mixin foundation-print-styles {\n  .show-for-print { display: none !important; }\n\n  @media print {\n    * {\n      @if $print-transparent-backgrounds {\n        background: transparent !important;\n      }\n\n      box-shadow: none !important;\n\n      color: black !important; // Black prints faster: h5bp.com/s\n      text-shadow: none !important;\n    }\n\n    .show-for-print { display: block !important; }\n    .hide-for-print { display: none !important; }\n\n    table.show-for-print { display: table !important; }\n    thead.show-for-print { display: table-header-group !important; }\n    tbody.show-for-print { display: table-row-group !important; }\n    tr.show-for-print { display: table-row !important; }\n    td.show-for-print { display: table-cell !important; }\n    th.show-for-print { display: table-cell !important; }\n\n    // Display the URL of a link after the text\n    a,\n    a:visited { text-decoration: underline;}\n    @if $print-hrefs {\n      a[href]:after { content: ' (' attr(href) ')'; }\n    }\n\n    // Don't display the URL for images or JavaScript/internal links\n    .ir a:after,\n    a[href^='javascript:']:after,\n    a[href^='#']:after { content: ''; }\n\n    // Display what an abbreviation stands for after the text\n    abbr[title]:after { content: ' (' attr(title) ')'; }\n\n    // Prevent page breaks in the middle of a blockquote or preformatted text block\n    pre,\n    blockquote {\n      border: 1px solid $dark-gray;\n      page-break-inside: avoid;\n    }\n\n    // h5bp.com/t\n    thead { display: table-header-group; }\n\n    tr,\n    img { page-break-inside: avoid; }\n\n    img { max-width: 100% !important; }\n\n    @page { margin: 0.5cm; }\n\n    p,\n    h2,\n    h3 {\n      orphans: 3;\n      widows: 3;\n    }\n\n    // Avoid page breaks after a heading\n    h2,\n    h3 { page-break-after: avoid; }\n\n    // Helper to re-allow page breaks in the middle of certain elements (e.g. pre, blockquote, tr)\n    .print-break-inside {\n      page-break-inside: auto;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n// Margin Grid classes\n@mixin xy-base-grid-classes {\n\n  // Grid Container\n  .grid-container {\n    @include xy-grid-container;\n\n    &.fluid {\n      @include xy-grid-container(100%);\n    }\n\n    &.full {\n      @include xy-grid-container(100%, 0);\n    }\n  }\n\n  // Base grid styles\n  .grid-x {\n    @include xy-grid;\n  }\n\n  .cell {\n    @include xy-cell-base();\n    @include xy-cell-static($grid-columns, false, $gutter-type: padding);\n\n    &.auto {\n      @include xy-cell-base(auto);\n    }\n\n    &.shrink {\n      @include xy-cell-base(shrink);\n    }\n\n  }\n  .grid-x {\n    > .auto {\n      @include xy-cell-static(auto, false);\n    }\n\n    > .shrink {\n      @include xy-cell-static(shrink, false);\n    }\n  }\n\n  // Auto width\n  @include -zf-each-breakpoint() {\n    // This is a bit of a hack/workaround, see these issues & PRs for the backstory:\n    // https://github.com/zurb/foundation-sites/issues/10244\n    // https://github.com/zurb/foundation-sites/pull/10222 and\n    // https://github.com/zurb/foundation-sites/pull/10164\n    .grid-x {\n      $str: \"> .#{$-zf-size}-shrink, > .#{$-zf-size}-full\";\n      @for $i from 1 through $grid-columns {\n        $str: $str + \", > .#{$-zf-size}-#{$i}\"\n      }\n      #{$str} {\n        flex-basis: auto;\n      }\n    }\n  }\n\n  @include -zf-each-breakpoint() {\n    // Responsive \"auto\" modifier\n    @if not($-zf-size == small) {\n      .grid-x > .#{$-zf-size}-auto {\n        @include xy-cell-base(auto);\n        @include xy-cell-static(auto, false);\n      }\n    }\n\n    %-xy-cell-base-shrink-horizontal-#{$-zf-size} {\n      @include xy-cell-base(shrink);\n    }\n\n    // Responsive \"shrink\" modifier\n    @if not($-zf-size == small) {\n      .grid-x > .#{$-zf-size}-shrink {\n        @extend %-xy-cell-base-shrink-horizontal-#{$-zf-size};\n        @include xy-cell-static(shrink, false);\n      }\n    }\n\n    // Responsive width modifiers\n    @for $i from 1 through $grid-columns {\n      // Sizing (percentage)\n      .grid-x > .#{$-zf-size}-#{$i} {\n        @extend %-xy-cell-base-shrink-horizontal-#{$-zf-size};\n        @include xy-cell-static($i, false, $gutter-type: padding);\n      }\n    }\n  }\n\n  // Reset width when using `.grid-margin-x` not on `.grid-x`\n  .grid-margin-x:not(.grid-x) > .cell {\n    width: auto;\n  }\n\n  // Reset height when using `.grid-margin-y` not on `.grid-y`\n  .grid-margin-y:not(.grid-y) > .cell {\n    height: auto;\n  }\n}\n\n@mixin -xy-breakpoint-cell-classes($class-breakpoint, $gutter-breakpoint, $vertical) {\n  $prefix: if($class-breakpoint == $-zf-zero-breakpoint, '', '#{$class-breakpoint}-');\n  > .#{$prefix}auto {\n    @include xy-cell-static(auto, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n  }\n\n  > .#{$prefix}shrink {\n    @include xy-cell-static(shrink, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n  }\n\n  @for $i from 1 through $grid-columns {\n    // Sizing (percentage)\n    $classname: if($vertical, '.#{$class-breakpoint}-#{$i}', '.#{$class-breakpoint}-#{$i}');\n\n    > #{$classname} {\n      @include xy-cell-static($i, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n    }\n  }\n}\n\n// Margin Grid classes\n@mixin xy-margin-grid-classes(\n  $gutter-position: left right,\n  $vertical: false,\n  $wrapping-selector: '.grid-margin-x'\n){\n  #{$wrapping-selector} {\n    @include xy-gutters($negative: true, $gutter-position: $gutter-position);\n\n    // Base cell styles\n    > .cell {\n      @include xy-cell-static($vertical: $vertical);\n    }\n\n    // base styles need to all be before the auto and shrink styles\n    @include -zf-each-breakpoint() {\n      @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size) and $-zf-size != $-zf-zero-breakpoint) {\n        > .cell {\n          @include xy-cell-static($breakpoint: $-zf-size, $vertical: $vertical);\n        }\n      }\n    }\n\n    @include -zf-each-breakpoint() {\n\n      // This is purely for responsive gutters - the margin grid has to go back and adjust widths (or heights)\n      // for all prior breakpoints.\n      // As their gutter is defined with their width/height, even breakpoint without a new margin must be\n      // generated to not having their width/height overrided by re-adjusted smaller breakpoints.\n      @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size)) {\n        @each $bp in -zf-breakpoints-less-than($-zf-size) {\n          @include -xy-breakpoint-cell-classes($bp, $-zf-size, $vertical);\n        }\n      }\n\n      @include -xy-breakpoint-cell-classes($-zf-size, $-zf-size, $vertical);\n    }\n  }\n}\n\n// Padding Grid classes\n@mixin xy-padding-grid-classes {\n  .grid-padding-x {\n\n    // Negative margin for nested grids\n    .grid-padding-x {\n      @include xy-gutters($negative: true);\n    }\n\n    // Negative margin for grids within `grid-container/grid-container.fluid`\n    // This allows margin and padding grids to line up with eachother\n    .grid-container:not(.full) > & {\n      @include xy-gutters($negative: true);\n    }\n\n    // Base cell styles\n    > .cell {\n      @include xy-gutters($gutters: $grid-padding-gutters, $gutter-type: padding);\n    }\n  }\n}\n\n// Block Grid classes\n@mixin xy-block-grid-classes($margin-grid: true, $padding-grid: true) {\n  @if $padding-grid {\n    @include -zf-each-breakpoint {\n      @for $i from 1 through $xy-block-grid-max {\n        .#{$-zf-size}-up-#{$i} {\n          @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: padding, $breakpoint: $-zf-size);\n        }\n      }\n    }\n  }\n\n  @if $margin-grid {\n    @include -zf-each-breakpoint {\n      @for $i from 1 through $xy-block-grid-max {\n        // This is purely for responsive gutters - the margin grid has to go back and adjust widths (or heights)\n        // for prior breakpoints based on the responsive gutter.\n        @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size)) {\n          @each $bp in -zf-breakpoints-less-than($-zf-size) {\n            @if(map-has-key($grid-margin-gutters, $bp)) {\n              .grid-margin-x.#{$bp}-up-#{$i} {\n                @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: margin, $breakpoint: $-zf-size);\n              }\n            }\n          }\n        }\n      }\n      @for $i from 1 through $xy-block-grid-max {\n        .grid-margin-x.#{$-zf-size}-up-#{$i} {\n          @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: margin, $breakpoint: $-zf-size);\n        }\n      }\n    }\n  }\n}\n\n// Collapse classes\n@mixin xy-collapse-grid-classes($margin-grid: true, $padding-grid: true) {\n  @each $bp in $breakpoint-classes {\n    @if $margin-grid {\n      .#{$bp}-margin-collapse {\n        @include xy-grid-collapse($gutter-type: margin, $min-breakpoint: $bp);\n      }\n    }\n\n    @if $padding-grid {\n      .#{$bp}-padding-collapse {\n        @include xy-grid-collapse($gutter-type: padding, $min-breakpoint: $bp);\n      }\n    }\n  }\n}\n\n// Offset classes\n@mixin xy-offset-cell-classes {\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $grid-columns {\n      // Offsets\n      $o: $i - 1;\n\n      .#{$-zf-size}-offset-#{$o} {\n        @include xy-cell-offset($o, $gutters: $grid-padding-gutters, $gutter-type: padding, $breakpoint: $-zf-size);\n      }\n\n      .grid-margin-x > .#{$-zf-size}-offset-#{$o} {\n        @include xy-cell-offset($o, $breakpoint: $-zf-size);\n      }\n    }\n  }\n}\n\n// Vertical Grid classes\n@mixin xy-vertical-grid-classes(\n  $margin-grid: true,\n  $padding-grid: true\n) {\n\n  @include -zf-each-breakpoint() {\n    @if not($-zf-size == small) {\n    }\n  }\n\n  .grid-y {\n    @include xy-grid(vertical, false);\n\n\n    > .cell {\n      @include xy-cell-reset();\n    }\n\n    > .auto {\n      @include xy-cell-static(auto, false, $vertical: true);\n    }\n\n    > .shrink {\n      @include xy-cell-static(shrink, false, $vertical: true);\n    }\n\n\n    @include -zf-each-breakpoint() {\n      // This is a bit of a hack/workaround, see these issues and PRs for the backstory:\n      // https://github.com/zurb/foundation-sites/issues/10244\n      // https://github.com/zurb/foundation-sites/pull/10222 and\n      // https://github.com/zurb/foundation-sites/pull/10164\n      $str: \"> .#{$-zf-size}-shrink, > .#{$-zf-size}-full\";\n      @for $i from 1 through $grid-columns {\n        $str: $str + \", > .#{$-zf-size}-#{$i}\"\n      }\n      #{$str} {\n        flex-basis: auto;\n      }\n    }\n\n    @include -zf-each-breakpoint() {\n      // Responsive \"auto\" modifier\n      @if not($-zf-size == small) {\n        > .#{$-zf-size}-auto {\n          @include xy-cell-base(auto);\n          @include xy-cell-static(auto, false, $breakpoint: $-zf-size, $vertical: true);\n        }\n      }\n\n      %-xy-cell-base-shrink-vertical-#{$-zf-size} {\n        @include xy-cell-base(shrink);\n      }\n\n      // Responsive \"shrink\" modifier\n      @if not($-zf-size == small) {\n        > .#{$-zf-size}-shrink {\n          @extend %-xy-cell-base-shrink-vertical-#{$-zf-size};\n          @include xy-cell-static(shrink, false, $breakpoint: $-zf-size, $vertical: true);\n        }\n      }\n\n      // Responsive width modifiers\n      @for $i from 1 through $grid-columns {\n        // Sizing (percentage)\n        > .#{$-zf-size}-#{$i} {\n          @extend %-xy-cell-base-shrink-vertical-#{$-zf-size};\n          @include xy-cell-static($i, false, $vertical: true, $gutter-type: padding);\n        }\n      }\n\n    }\n  }\n\n  @if $padding-grid {\n    .grid-padding-y {\n      // Negative margin for nested grids\n      .grid-padding-y {\n        @include xy-gutters($negative: true, $gutter-position: top bottom);\n      }\n\n      // Base cell styles\n      > .cell {\n        @include xy-gutters($gutters: $grid-padding-gutters, $gutter-type: padding, $gutter-position: top bottom);\n      }\n    }\n  }\n\n  @if $margin-grid {\n    @include xy-margin-grid-classes(top bottom, true, '.grid-margin-y');\n  }\n\n}\n\n@mixin xy-frame-grid-classes($vertical-grid: true, $margin-grid: true) {\n  // Framed grid styles\n  .grid-frame {\n    @include xy-grid-frame;\n  }\n\n  .cell .grid-frame {\n    width: 100%; // Same as include with $nested, but with less css\n  }\n\n  .cell-block {\n    @include xy-cell-block();\n  }\n\n  .cell-block-y {\n    @include xy-cell-block(true);\n  }\n\n\n  .cell-block-container {\n    @include xy-cell-block-container();\n  }\n\n\n  @include -zf-each-breakpoint(false) {\n\n    .#{$-zf-size}-grid-frame {\n      @include xy-grid-frame;\n    }\n\n    .cell .#{$-zf-size}-grid-frame {\n      width: 100%; // Same as include with $nested, but with less css\n    }\n\n    .#{$-zf-size}-cell-block {\n      @include xy-cell-block();\n    }\n\n    .#{$-zf-size}-cell-block-container {\n      @include xy-cell-block-container();\n    }\n\n    .#{$-zf-size}-cell-block-y {\n      @include xy-cell-block(true);\n    }\n  }\n\n  @if $vertical-grid {\n    .grid-y {\n      &.grid-frame {\n        width: auto;\n        @include xy-grid-frame(true);\n      }\n\n      @include -zf-each-breakpoint(false) {\n        &.#{$-zf-size}-grid-frame {\n          width: auto;\n          @include xy-grid-frame(true);\n        }\n\n      }\n    }\n    .cell {\n      .grid-y.grid-frame {\n        height: 100%; // Same as include with $nested, but with less css\n      }\n      @include -zf-each-breakpoint(false) {\n        .grid-y.#{$-zf-size}-grid-frame {\n          height: 100%; // Same as include with $nested, but with less css\n        }\n      }\n    }\n  }\n  @if $margin-grid {\n    @include xy-margin-grid-classes(top bottom, true, '.grid-margin-y');\n    .grid-frame.grid-margin-y {\n      @include xy-grid-frame(true, false, $grid-margin-gutters, $include-base: false);\n    }\n    @include -zf-each-breakpoint(false) {\n      .grid-margin-y.#{$-zf-size}-grid-frame {\n        @include xy-grid-frame(true, false, $grid-margin-gutters, $-zf-size, false);\n      }\n    }\n  }\n}\n\n// Final classes\n@mixin foundation-xy-grid-classes(\n  $base-grid: true,\n  $margin-grid: true,\n  $padding-grid: true,\n  $block-grid: true,\n  $collapse: true,\n  $offset: true,\n  $vertical-grid: true,\n  $frame-grid: true\n) {\n\n  // Base grid styles\n  @if($base-grid) {\n    @include xy-base-grid-classes();\n  }\n\n  // Margin grid\n  @if($margin-grid) {\n    @include xy-margin-grid-classes();\n  }\n\n  // Padding grid\n  @if($padding-grid) {\n    @include xy-padding-grid-classes();\n  }\n\n  // Block grid\n  @if($block-grid) {\n    @include xy-block-grid-classes($margin-grid, $padding-grid);\n  }\n\n  // Collapse gutters\n  @if($collapse) {\n    @include xy-collapse-grid-classes($margin-grid, $padding-grid);\n  }\n\n  // Offset gutters\n  @if($offset) {\n    @include xy-offset-cell-classes();\n  }\n\n  // Vertical grid\n  @if($vertical-grid) {\n    @include xy-vertical-grid-classes($margin-grid, $padding-grid);\n  }\n\n  @if ($frame-grid) {\n    @include xy-frame-grid-classes($vertical-grid, $margin-grid)\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Create gutters for a cell/container.\n///\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts either margin or padding.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {Boolean} $negative [false] - Whether to apply the gutter as a negative value. Commonly used for nested grids.\n@mixin xy-gutters(\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $negative: false\n) {\n  $operator: if($negative, '-', '');\n\n  // If we have declared negative gutters, force type to `margin.\n  $gutter-type: if($negative, 'margin', $gutter-type);\n\n  // Output our margin gutters.\n  @if (type-of($gutters) == 'map') {\n    @include -zf-breakpoint-value(auto, $gutters) {\n      $gutter: rem-calc($-zf-bp-value) / 2;\n\n      // Loop through each gutter position\n      @each $value in $gutter-position {\n        #{$gutter-type}-#{$value}: unquote(\"#{$operator}#{$gutter}\");\n      }\n    }\n  }\n  @else if (type-of($gutters) == 'number') {\n    $gutter: rem-calc($gutters) / 2;\n\n    // Loop through each gutter position\n    @each $value in $gutter-position {\n      #{$gutter-type}-#{$value}: unquote(\"#{$operator}#{$gutter}\");\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Creates a max width container, designed to house your grid content.\n///\n/// @param {Number} $width [$grid-container] - a width to limit the container to.\n/// @param {Number} $padding [$grid-container-padding] - paddings of the container.\n@mixin xy-grid-container(\n  $width: $grid-container,\n  $padding: $grid-container-padding\n) {\n  @include xy-gutters($gutters: $padding, $gutter-type: padding);\n\n  max-width: $width;\n  margin-left: auto;\n  margin-right: auto;\n}\n\n/// Creates a container for your flex cells.\n///\n/// @param {Keyword} $direction [horizontal] - Either horizontal or vertical direction of cells within.\n/// @param {Boolean} $wrap [true] - If the cells within should wrap or not.\n@mixin xy-grid(\n  $direction: horizontal,\n  $wrap: true\n) {\n  $direction: if($direction == 'horizontal', row, column);\n  $wrap: if($wrap, wrap, nowrap);\n\n  display: flex;\n  flex-flow: $direction $wrap;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Calculate the percentage size of a cell.\n///\n/// @param {Number|List} $size [$grid-columns] - Size to make the cell. You can pass a value in multiple formats, such as `6`, `50%`, `1 of 2` or `1/3`.\n@function xy-cell-size(\n  $size: $grid-columns\n) {\n  // Parsing percents, decimals, n of n and number counts\n  @if type-of($size) == 'number' {\n    @if unit($size) == '%' {\n      $size: $size;\n    }\n    @else if $size < 1 {\n      $size: percentage($size);\n    }\n    @else {\n      $size: percentage($size / $grid-columns);\n    }\n  }\n\n  // Parsing \"n of n\" or \"n/n\" expressions\n  @else if type-of($size) == 'list' {\n    @if length($size) != 3 {\n      @error 'Wrong syntax for xy-cell-size(). Use the format \"n of n\" or \"n/n\".';\n    }\n    @else {\n      $size: percentage(nth($size, 1) / nth($size, 3));\n    }\n  }\n  // Anything else is incorrect\n  @else {\n    @error 'Wrong syntax for xy-cell-size(). Use a number, decimal, percentage, or \"n of n\" / \"n/n\".';\n  }\n\n  @return $size;\n}\n\n/// Sets base flex properties for cells.\n///\n/// @param {Keyword} $size [full] - The size of your cell. Accepts `full`, `auto`, `shrink` or `grow`.\n@mixin xy-cell-base($size: full) {\n  @if($size == 'full') {\n    // This is the base style, all others inherit from it\n    flex: 0 0 auto;\n    min-height: 0px;\n    min-width: 0px;\n  }\n  @else if ($size == 'auto') {\n    flex: 1 1 0px; // sass-lint:disable-line zero-unit\n  }\n  @else if ($size == 'shrink') {\n    flex: 0 0 auto;\n  }\n  @else if ($size == 'grow') {\n    flex: 1 0 auto;\n  }\n}\n\n/// Resets a cells width (or height if vertical is true) as well as strips its gutters.\n///\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-reset($vertical: true) {\n  $direction: if($vertical == true, width, height);\n  #{$direction}: auto;\n  max-#{$direction}: none;\n}\n\n// Sets our cell widths or heights depending on gutter type.\n@mixin -xy-cell-properties($size, $margin-gutter, $vertical) {\n  $direction: if($vertical == true, height, width);\n  @if($size == 'full') {\n    $val: if($margin-gutter == 0, 100%, calc(100% - #{rem-calc($margin-gutter)}));\n    #{$direction}: $val;\n  }\n  @else if ($size == 'auto') {\n    #{$direction}: auto;\n    $val: if($margin-gutter == 0, 100%, calc(100% - #{rem-calc($margin-gutter)}));\n  }\n  @else if ($size == 'shrink') {\n    #{$direction}: auto;\n  }\n  @else {\n    $val: if($margin-gutter == 0, #{xy-cell-size($size)}, calc(#{xy-cell-size($size)} - #{rem-calc($margin-gutter)}));\n    #{$direction}: $val;\n  }\n}\n\n/// Creates a cell for your grid.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (default) for 100% width, `auto` to use up available space and `shrink` to use up only required space.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Map or single value for gutters.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell(\n  $size: full,\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $breakpoint: null,\n  $vertical: false\n) {\n  $bp-is-fallback: false;\n\n  @if($breakpoint == null) {\n    // If `$bp-size` is available then use this, otherwise revert to the smallest bp.\n    @if(variable-exists(-zf-size) and type-of($-zf-size) != 'number') and $-zf-size != null {\n      $breakpoint: $-zf-size;\n    }\n    @else {\n      $breakpoint: $-zf-zero-breakpoint;\n      $bp-is-fallback: true;\n    }\n  }\n\n  // Get the gutter for the given breakpoint/value.\n  $gutter: -zf-get-bp-val($gutters, $breakpoint);\n  // If the breakpoint is a fallback, use a fallback gutter as well\n  @if ($bp-is-fallback == true and $gutter == null) {\n    $gutter: 0;\n  }\n\n  @if($gutter != null) {\n    // Base flex properties\n    @include xy-cell-base($size);\n\n    @if($gutter-type == 'margin') {\n      @include -xy-cell-properties($size, $gutter, $vertical);\n    }\n    @else {\n      @include -xy-cell-properties($size, 0, $vertical);\n    }\n\n    @if $gutter-output {\n      @include xy-gutters($gutter, $gutter-type, $gutter-position);\n    }\n  }\n  @else {\n    @warn 'xy-cell: no gutters were found in `$gutters` for \"$breakpoint: #{$breakpoint}\", cell was not generated`'\n  }\n}\n\n/// Creates a single breakpoint sized grid. Used to generate our grid classes.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (default) for 100% width, `auto` to use up available space and `shrink` to use up only required space.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-static(\n  $size: full,\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $breakpoint: $-zf-zero-breakpoint,\n  $vertical: false\n) {\n\n  $gutter: -zf-get-bp-val($gutters, $breakpoint);\n  $gutter-position: if($vertical == true, top bottom, left right);\n\n  @if($gutter-type == 'margin') {\n    @include -xy-cell-properties($size, $gutter, $vertical);\n  }\n  @else {\n    @include -xy-cell-properties($size, 0, $vertical);\n  }\n\n  // If we want to output the gutters\n  @if($gutter-output) {\n    // TODO: Figure out if we need to pass breakpoint in here too.\n    @include xy-gutters($gutter, $gutter-type, $gutter-position);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Sizes child elements so that `$n` number of items appear on each row.\n///\n/// @param {Number} $n - Number of elements to display per row.\n/// @param {String} $selector ['.cell'] - Selector(s) to use for child elements.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts `margin` or `padding`.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {String} $breakpoint [null] - The breakpoint to use for the cell generation.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-grid-layout(\n  $n,\n  $selector: '.cell',\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $breakpoint: null,\n  $vertical: false\n) {\n  $size: percentage(1/$n);\n\n  & > #{$selector} {\n    @include xy-cell($size, $gutter-output, $gutters, $gutter-type, $gutter-position, $breakpoint, $vertical);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Collapses the grid a cells within it.\n///\n/// @param {String} $selector [.cell] - The child element to remove the gutter from.\n/// @param {Keyword} $gutter-type [margin] - The type of gutter to remove.\n/// @param {List} $gutter-position [right left] - The positions to remove gutters from. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {Keyword} $min-breakpoint [$-zf-zero-breakpoint] - Minimum breakpoint in `$breakpoint-classes` for which to collapse the gutter.\n@mixin xy-grid-collapse(\n  $selector: '.cell',\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $min-breakpoint: $-zf-zero-breakpoint\n) {\n  // First, lets negate any margins on the top level\n  @if ($gutter-type == 'margin') {\n\n    @include breakpoint($min-breakpoint) {\n      @each $value in $gutter-position {\n        margin-#{$value}: 0;\n      }\n\n      > #{$selector} {\n        @each $value in $gutter-position {\n          margin-#{$value}: 0;\n        }\n      }\n    }\n\n    $excluded-bps: -zf-breakpoints-less-than($min-breakpoint);\n\n    // Output new widths to not include gutters\n    @each $bp in $breakpoint-classes {\n      @if(sl-contain($excluded-bps, $bp)) {\n        @include breakpoint($min-breakpoint) {\n          @for $i from 1 through $grid-columns {\n            // Sizing (percentage)\n            > .#{$bp}-#{$i} {\n              @include xy-cell-static($i, $gutter-output: false, $gutter-type: padding);\n            }\n          }\n        }\n      } @else {\n        @include breakpoint($bp) {\n          @for $i from 1 through $grid-columns {\n            // Sizing (percentage)\n            > .#{$bp}-#{$i} {\n              @include xy-cell-static($i, $gutter-output: false, $gutter-type: padding);\n            }\n          }\n        }\n      }\n    }\n  }\n  @else {\n\n    @include breakpoint($min-breakpoint) {\n      @each $value in $gutter-position {\n        margin-#{$value}: 0;\n      }\n\n      > #{$selector} {\n        @each $value in $gutter-position {\n          padding-#{$value}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Offsets a column to the right/bottom by `$n` columns.\n///\n/// @param {Number|List} $n - Size to offset by. You can pass in any value accepted by the `zf-cell()` mixin, such as `6`, `50%`, or `1 of 2`.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] Map of gutters or single value to use for responsive gutters.\n/// @param {Keyword} $gutter-type [margin] The type of gutter to use. Can be `margin` or `padding`\n/// @param {Number|Array|Keyword} $breakpoint [$-zf-zero-breakpoint] - Single value, breakpoint name, or list of breakpoint names to use for `$gutters`. See `-zf-breakpoint-value()`.\n/// @param {Boolean} $vertical [false] Sets the direction of the offset. If set to true will apply margin-top instead.\n@mixin xy-cell-offset(\n $n,\n $gutters: $grid-margin-gutters,\n $gutter-type: margin,\n $breakpoint: $-zf-zero-breakpoint,\n $vertical: false\n) {\n  $direction: if($vertical, 'top', $global-left);\n\n  @include -zf-breakpoint-value($breakpoint, $gutters) {\n    $gutter: rem-calc($-zf-bp-value) / 2;\n    $gutter-margin: if($gutter-type == 'margin', $gutter, 0);\n    $size: if($gutter-margin == 0, #{xy-cell-size($n)}, calc(#{xy-cell-size($n)} + #{$gutter-margin}));\n\n    margin-#{$direction}: #{$size};\n  }\n}\n","/// Modifies a grid to give it \"frame\" behavior (no overflow, no wrap, stretch behavior)\n///\n/// @param {Boolean} $vertical [false] - Is grid vertical or horizontal. Should match grid.\n/// @param {Boolean} $nested [false] - Is grid nested or not. If nested is true this sets the frame to 100% height, otherwise will be 100vh.\n/// @param {Number|Map} $gutters [null] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from.\n/// @param {Boolean} $include-base [true] - Include the base styles that don't vary per breakpoint.\n@mixin xy-grid-frame(\n  $vertical: false,\n  $nested: false,\n  $gutters: null,\n  $breakpoint: null,\n  $include-base: true\n) {\n\n  @if $include-base {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n  }\n\n  @if $breakpoint == null and type-of($gutters) == 'map' {\n    @include -zf-each-breakpoint() {\n      @include xy-grid-frame($vertical, $nested, $gutters, $-zf-size, false);\n    }\n  } @else {\n    // Get our gutters if applicable\n    $gutter: -zf-get-bp-val($gutters, $breakpoint);\n\n    // If we have a gutter, add it to the width/height\n    @if $gutter {\n      @if $vertical == true {\n        $unit: if($nested == true, 100%, 100vh);\n        $gutter: rem-calc($gutter);\n        height: calc(#{$unit} + #{$gutter});\n      } @else {\n        $unit: if($nested == true, 100%, 100vw);\n        $gutter: rem-calc($gutter);\n        width: calc(#{$unit} + #{$gutter});\n      }\n    }\n    @else {\n      @if $vertical == true {\n        height: if($nested == true, 100%, 100vh);\n      } @else {\n        width: if($nested == true, 100%, 100vw);\n      }\n    }\n  }\n}\n\n/// Modifies a cell to give it \"block\" behavior (overflow auto, inertial scrolling)\n///\n/// @param {Boolean} $vertical [false] - Is grid vertical or horizontal. Should match grid.\n@mixin xy-cell-block(\n  $vertical: false\n) {\n  $property: if($vertical == true, 'overflow-y', 'overflow-x');\n\n  @if $vertical == true {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n  } @else {\n    overflow-x: auto;\n    max-width: 100%;\n  }\n\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar;\n}\n\n/// Container for inside a grid frame containing multiple blocks. Typically used\n/// as a modifier for a `.cell` to allow the cell to pass along flex sizing\n/// constraints / from parents to children.\n@mixin xy-cell-block-container() {\n  display: flex;\n  flex-direction: column;\n  max-height: 100%;\n\n  > .grid-x {\n    max-height: 100%;\n    flex-wrap: nowrap;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group button\n////\n\n/// Font family for button elements.\n/// @type Font\n$button-font-family: inherit !default;\n\n/// Padding inside buttons.\n/// @type List\n$button-padding: 0.85em 1em !default;\n\n/// Margin around buttons.\n/// @type List\n$button-margin: 0 0 $global-margin 0 !default;\n\n/// Default fill for buttons. Can either be `solid` or `hollow`.\n/// @type Keyword\n$button-fill: solid !default;\n\n/// Default background color for buttons.\n/// @type Color\n$button-background: $primary-color !default;\n\n/// Background color on hover for buttons.\n/// @type Color\n$button-background-hover: scale-color($button-background, $lightness: -15%) !default;\n\n/// Font color for buttons.\n/// @type List\n$button-color: $white !default;\n\n/// Alternative font color for buttons.\n/// @type List\n$button-color-alt: $black !default;\n\n/// Border radius for buttons, defaulted to global-radius.\n/// @type Number\n$button-radius: $global-radius !default;\n\n/// Border width for hollow outline buttons\n/// @type Number\n$button-hollow-border-width: 1px !default;\n\n/// Sizes for buttons.\n/// @type Map\n$button-sizes: (\n  tiny: 0.6rem,\n  small: 0.75rem,\n  default: 0.9rem,\n  large: 1.25rem,\n) !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$button-palette: $foundation-palette !default;\n\n/// opacity for a disabled button.\n/// @type List\n$button-opacity-disabled: 0.25 !default;\n\n/// Background color lightness on hover for buttons.\n/// @type Number\n$button-background-hover-lightness: -20% !default;\n\n/// Color lightness on hover for hollow buttons.\n/// @type Number\n$button-hollow-hover-lightness: -50% !default;\n\n// Internal: flip from margin-right to margin-left for defaults\n@if $global-text-direction == 'rtl' {\n  $button-margin: 0 0 $global-margin $global-margin !default;\n}\n\n/// transitions for buttons.\n/// @type List\n$button-transition: background-color 0.25s ease-out, color 0.25s ease-out !default;\n\n/// Additional responsive classes for .expanded\n/// @type Boolean\n$button-responsive-expanded: false !default;\n\n// TODO: Document button-base() mixin\n@mixin button-base {\n  @include disable-mouse-outline;\n  display: inline-block;\n  vertical-align: middle;\n  margin: $button-margin;\n\n  @if (type-of($button-padding) == 'map') {\n    @each $size, $padding in $button-padding {\n      @include breakpoint($size) {\n        padding: $padding;\n      }\n    }\n  }\n  @else {\n    padding: $button-padding;\n  }\n\n  border: 1px solid transparent;\n  border-radius: $button-radius;\n  transition: $button-transition;\n  font-family: $button-font-family;\n  font-size: map-get($button-sizes, default);\n  -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n}\n\n/// Expands a button to make it full-width.\n/// @param {Boolean} $expand [true] - Set to `true` to enable the expand behavior. Set to `false` to reverse this behavior.\n@mixin button-expand($expand: true) {\n  @if $expand {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0;\n  }\n  @else {\n    display: inline-block;\n    width: auto;\n    margin: $button-margin;\n  }\n}\n\n/// Sets the visual style of a button.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n@mixin button-style(\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $background-hover-lightness: $button-background-hover-lightness\n) {\n  @if $color == auto {\n    $color: color-pick-contrast($background, ($button-color, $button-color-alt));\n  }\n\n  @if $background-hover == auto {\n    $background-hover: scale-color($background, $lightness: $background-hover-lightness);\n  }\n\n  background-color: $background;\n  color: $color;\n\n  &:hover, &:focus {\n    background-color: $background-hover;\n    color: $color;\n  }\n}\n\n/// Removes background fill on hover and focus for hollow buttons.\n@mixin button-hollow {\n  &,\n  &:hover,\n  &:focus {\n    background-color: transparent;\n  }\n\n  &.disabled,\n  &[disabled] {\n    &,\n    &:hover, &:focus {\n      background-color: transparent;\n    }\n  }\n}\n\n@mixin button-hollow-style(\n  $color: $button-background,\n  $hover-lightness: $button-hollow-hover-lightness,\n  $border-width: $button-hollow-border-width\n) {\n  $color-hover: scale-color($color, $lightness: $hover-lightness);\n\n  border: $border-width solid $color;\n  color: $color;\n\n  &:hover, &:focus {\n    border-color: $color-hover;\n    color: $color-hover;\n    &.disabled,\n    &[disabled] {\n      border: $border-width solid $color;\n      color: $color;\n    }\n  }\n}\n\n/// Adds disabled styles to a button by fading the element, reseting the cursor, and disabling pointer events.\n/// @param {Color} $background [$button-background] - Background color of the disabled button.\n/// @param {Color} $color [$button-color] - Text color of the disabled button. Set to `auto` to have the mixin automatically generate a color based on the background color.\n@mixin button-disabled(\n  $background: $button-background,\n  $color: $button-color\n) {\n  @if $color == auto {\n    $color: color-pick-contrast($background, ($button-color, $button-color-alt));\n  }\n\n  opacity: $button-opacity-disabled;\n  cursor: not-allowed;\n\n  &, &:hover, &:focus {\n    background-color: $background;\n    color: $color;\n  }\n}\n\n/// Adds a dropdown arrow to a button.\n/// @param {Number} $size [0.4em] - Size of the arrow. We recommend using an `em` value so the triangle scales when used inside different sizes of buttons.\n/// @param {Color} $color [white] - Color of the arrow.\n/// @param {Number} $offset [$button-padding] - Distance between the arrow and the text of the button. Defaults to whatever the right padding of a button is.\n@mixin button-dropdown(\n  $size: 0.4em,\n  $color: $white,\n  $offset: get-side($button-padding, right)\n) {\n  &::after {\n    @include css-triangle($size, $color, down);\n    position: relative;\n    top: 0.4em; // Aligns the arrow with the text of the button\n\n    display: inline-block;\n    float: #{$global-right};\n    margin-#{$global-left}: $offset;\n  }\n}\n\n/// Adds all styles for a button. For more granular control over styles, use the individual button mixins.\n/// @param {Boolean} $expand [false] - Set to `true` to make the button full-width.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n/// @param {Keyword} $style [solid] - Set to `hollow` to create a hollow button. The color defined in `$background` will be used as the primary color of the button.\n@mixin button(\n  $expand: false,\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $style: $button-fill\n) {\n  @include button-base;\n\n  @if $style == solid {\n    @include button-style($background, $background-hover, $color);\n  }\n  @else if $style == hollow {\n    @include button-hollow;\n    @include button-hollow-style($background);\n  }\n\n  @if $expand {\n    @include button-expand;\n  }\n}\n\n@mixin foundation-button {\n  .button {\n    @include button;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} {\n        font-size: $value;\n      }\n    }\n\n    &.expanded { @include button-expand; }\n\n    @if $button-responsive-expanded {\n      @each $size in $breakpoint-classes {\n        @include breakpoint(#{$size} only) {\n          &.#{$size}-only-expanded {\n            @include button-expand;\n          }\n        }\n        @if $size != $-zf-zero-breakpoint {\n          @include breakpoint(#{$size} down) {\n            &.#{$size}-down-expanded {\n              @include button-expand;\n            }\n          }\n\n          @include breakpoint(#{$size}) {\n            &.#{$size}-expanded {\n              @include button-expand;\n            }\n          }\n        }\n      }\n    }\n\n    // Colors\n    @each $name, $color in $button-palette {\n      @if $button-fill != hollow {\n        &.#{$name} {\n          @include button-style($color, auto, auto);\n        }\n      }\n      @else {\n        &.#{$name} {\n          @include button-hollow-style($color);\n        }\n\n        &.#{$name}.dropdown::after {\n          border-top-color: $color;\n        }\n      }\n    }\n\n    // Disabled style\n    &.disabled,\n    &[disabled] {\n      @include button-disabled;\n\n      @each $name, $color in $button-palette {\n        &.#{$name} {\n          @include button-disabled($color, auto);\n        }\n      }\n    }\n\n    // Hollow style\n    @if $button-fill != hollow {\n      &.hollow {\n        @include button-hollow;\n        @include button-hollow-style;\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-hollow-style($color);\n          }\n        }\n      }\n    }\n\n    // Clear style\n    @if $button-fill != clear {\n      &.clear {\n        @include button-hollow;\n        @include button-hollow-style;\n\n        &, &:hover, &:focus {\n          &, &.disabled, &[disabled] {\n            border-color: transparent;\n          }\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-hollow-style($color);\n\n            &, &:hover,\n            &:focus {\n              &,\n              &.disabled,\n              &[disabled] {\n                border-color: transparent;\n              }\n            }\n          }\n        }\n      }\n    }\n\n    // Dropdown arrow\n    &.dropdown {\n      @include button-dropdown;\n\n      @if $button-fill == hollow {\n        &::after {\n          border-top-color: $button-background;\n        }\n      }\n\n      &.hollow, &.clear {\n        &::after {\n          border-top-color: $button-background;\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            &::after {\n              border-top-color: $color;\n            }\n          }\n        }\n      }\n    }\n\n    // Button with dropdown arrow only\n    &.arrow-only::after {\n      top: -0.1em;\n      float: none;\n      margin-#{$global-left}: 0;\n    }\n  }\n\n  a.button { // sass-lint:disable-line no-qualifying-elements\n    &:hover,\n    &:focus {\n      text-decoration: none;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group button-group\n////\n\n/// Margin for button groups.\n/// @type Number\n$buttongroup-margin: 1rem !default;\n\n/// Margin between buttons in a button group.\n/// @type Number\n$buttongroup-spacing: 1px !default;\n\n/// Selector for the buttons inside a button group.\n/// @type String\n$buttongroup-child-selector: '.button' !default;\n\n/// Maximum number of buttons that can be in an even-width button group. (Only needed when $global-flexbox: false;)\n/// @type Number\n$buttongroup-expand-max: 6 !default;\n\n/// Determines if $button-radius is applied to each button or the button group as a whole. Use $global-radius in _settings.scss to change radius.\n/// @type Boolean\n$buttongroup-radius-on-each: true !default;\n\n/// Add styles for a button group container.\n/// @param {String} $child-selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group(\n  $child-selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing\n) {\n  @include clearfix;\n  margin-bottom: $buttongroup-margin;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    align-items: stretch;\n  }\n  @else {\n    font-size: 0;\n  }\n\n  #{$child-selector} {\n    margin: 0;\n    margin-#{$global-right}: $spacing;\n    margin-bottom: $spacing;\n    font-size: map-get($button-sizes, default);\n\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n\n    &:last-child {\n      margin-#{$global-right}: 0;\n    }\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $button-radius;\n        border-bottom-#{$global-left}-radius: $button-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $button-radius;\n        border-bottom-#{$global-right}-radius: $button-radius;\n      }\n    }\n\n  }\n}\n\n/// Creates a full-width button group, making each button equal width.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group-expand(\n  $selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing,\n  $count: null\n) {\n  @if not $global-flexbox {\n    margin-#{$global-right}: -$spacing;\n\n    &::before,\n    &::after {\n      display: none;\n    }\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n    @else {\n      // One child\n      &:first-child {\n        &:last-child {\n          width: calc(100% - #{$spacing});\n        }\n      }\n\n      // Two or more childreen\n      @for $i from 2 through $buttongroup-expand-max {\n        &:first-child:nth-last-child(#{$i}) {\n          &, &:first-child:nth-last-child(#{$i}) ~ #{$selector} {\n            display: inline-block;\n            width: calc(#{percentage(1 / $i)} - #{$spacing});\n            margin-#{$global-right}: $spacing;\n\n            &:last-child {\n              margin-#{$global-right}: $spacing * -$buttongroup-expand-max;\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n/// Stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-stack(\n  $selector: $buttongroup-child-selector\n) {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 100%;\n    }\n    @else {\n      width: 100%;\n    }\n\n    &:last-child {\n      margin-bottom: 0;\n    }\n\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: $global-radius;\n      }\n\n      &:last-child {\n        margin-bottom: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n      }\n    }\n\n  }\n}\n\n/// Un-stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-unstack(\n  $selector: $buttongroup-child-selector\n) {\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n    @else {\n      width: auto;\n    }\n    margin-bottom: 0;\n\n    @if not $buttongroup-radius-on-each {\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-left}-radius: 0;\n      }\n    }\n\n  }\n}\n\n@mixin foundation-button-group {\n  .button-group {\n    @include button-group;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} #{$buttongroup-child-selector} {\n        font-size: $value;\n      }\n    }\n\n    // Even-width Group\n    &.expanded {\n      @include button-group-expand;\n    }\n\n    // Colors\n    @each $name, $color in $button-palette {\n      @if $button-fill != hollow {\n        &.#{$name} #{$buttongroup-child-selector} {\n          @include button-style($color, auto, auto);\n        }\n      }\n      @else {\n        &.#{$name} #{$buttongroup-child-selector} {\n          @include button-hollow;\n          @include button-hollow-style($color);\n        }\n      }\n    }\n\n    &.stacked,\n    &.stacked-for-small,\n    &.stacked-for-medium {\n      @include button-group-stack;\n\n      &.expanded {\n        @include button-group-expand;\n      }\n    }\n\n    &.stacked-for-small {\n      @include breakpoint(medium) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-medium {\n      @include breakpoint(large) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-small.expanded {\n      @include breakpoint(small only) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n\n    &.stacked-for-medium.expanded {\n      @include breakpoint(medium down) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group close-button\n////\n\n/// Default position of the close button. The first value should be `right` or `left`, and the second value should be `top` or `bottom`.\n/// @type List\n$closebutton-position: right top !default;\n\n/// Right (or left) offset(s) for a close button.\n/// @type Number|Map\n$closebutton-offset-horizontal: (\n  small: 0.66rem,\n  medium: 1rem,\n) !default;\n\n/// Top (or bottom) offset(s) for a close button.\n/// @type Number|Map\n$closebutton-offset-vertical: (\n  small: 0.33em,\n  medium: 0.5rem,\n) !default;\n\n/// Default font size(s) of the close button.\n/// @type Number|Map\n$closebutton-size: (\n  small: 1.5em,\n  medium: 2em,\n) !default;\n\n/// The line-height of the close button. It affects the spacing of the element.\n/// @type Number\n$closebutton-lineheight: 1 !default;\n\n/// Default color of the close button.\n/// @type Color\n$closebutton-color: $dark-gray !default;\n\n/// Default color of the close button when being hovered on.\n/// @type Color\n$closebutton-color-hover: $black !default;\n\n\n/// Get the size and position for a close button. If the input value is a number, the number is returned. If the input value is a config map and the map has the key `$size`, the value is returned.\n///\n/// @param {Number|Map} $value - A number or map that represents the size or position value(s) of the close button.\n/// @param {Keyword} $size - The size of the close button to use.\n///\n/// @return {Number} The given number or the value found in the map.\n@function -zf-get-size-val($value, $size) {\n  // Check if the value is a number\n  @if type-of($value) == 'number' {\n    // If it is, just return the number\n    @return $value;\n  }\n\n  // Check if the size name exists in the value map\n  @else if map-has-key($value, $size) {\n    // If it does, return the value\n    @return map-get($value, $size);\n  }\n}\n\n/// Sets the size and position of a close button.\n/// @param {Keyword} $size [medium] - The size to use. Set to `small` to create a small close button. The 'medium' values defined in `$closebutton-*` variables will be used as the default size and position of the close button.\n@mixin close-button-size($size) {\n  $x: nth($closebutton-position, 1);\n  $y: nth($closebutton-position, 2);\n\n  #{$x}: -zf-get-size-val($closebutton-offset-horizontal, $size);\n  #{$y}: -zf-get-size-val($closebutton-offset-vertical, $size);\n  font-size: -zf-get-size-val($closebutton-size, $size);\n  line-height: -zf-get-size-val($closebutton-lineheight, $size);\n}\n\n/// Adds styles for a close button, using the styles in the settings variables.\n@mixin close-button {\n  $x: nth($closebutton-position, 1);\n  $y: nth($closebutton-position, 2);\n\n  @include disable-mouse-outline;\n  position: absolute;\n  color: $closebutton-color;\n  cursor: pointer;\n\n  &:hover,\n  &:focus {\n    color: $closebutton-color-hover;\n  }\n}\n\n@mixin foundation-close-button {\n  .close-button {\n    @include close-button;\n\n    &.small { @include close-button-size(small) }\n    &, &.medium { @include close-button-size(medium) }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group label\n////\n\n/// Default background color for labels.\n/// @type Color\n$label-background: $primary-color !default;\n\n/// Default text color for labels.\n/// @type Color\n$label-color: $white !default;\n\n/// Alternate text color for labels.\n/// @type Color\n$label-color-alt: $black !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$label-palette: $foundation-palette !default;\n\n/// Default font size for labels.\n/// @type Number\n$label-font-size: 0.8rem !default;\n\n/// Default padding inside labels.\n/// @type Number\n$label-padding: 0.33333rem 0.5rem !default;\n\n/// Default radius of labels.\n/// @type Number\n$label-radius: $global-radius !default;\n\n/// Generates base styles for a label.\n@mixin label {\n  display: inline-block;\n  padding: $label-padding;\n\n  border-radius: $label-radius;\n\n  font-size: $label-font-size;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n}\n\n@mixin foundation-label {\n  .label {\n    @include label;\n\n    background: $label-background;\n    color: $label-color;\n\n    @each $name, $color in $label-palette {\n      &.#{$name} {\n        background: $color;\n        color: color-pick-contrast($color, ($label-color, $label-color-alt));\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// Adds styles for a progress bar container.\n@mixin progress-container {\n  height: $progress-height;\n  margin-bottom: $progress-margin-bottom;\n  border-radius: $progress-radius;\n  background-color: $progress-background;\n}\n\n/// Adds styles for the inner meter of a progress bar.\n@mixin progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: $progress-meter-background;\n\n  @if has-value($progress-radius) {\n    border-radius: $global-radius;\n  }\n}\n\n/// Adds styles for text in the progress meter.\n@mixin progress-meter-text {\n  @include absolute-center;\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: $white;\n  white-space: nowrap;\n\n  @if has-value($progress-radius) {\n    border-radius: $progress-radius;\n  }\n}\n\n@mixin foundation-progress-bar {\n  // Progress bar\n  .progress {\n    @include progress-container;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        .progress-meter {\n          background-color: $color;\n        }\n      }\n    }\n  }\n\n  // Inner meter\n  .progress-meter {\n    @include progress-meter;\n  }\n\n  // Inner meter text\n  .progress-meter-text {\n    @include progress-meter-text;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group progress-bar\n////\n\n/// Height of a progress bar.\n/// @type Number\n$progress-height: 1rem !default;\n\n/// Background color of a progress bar.\n/// @type Color\n$progress-background: $medium-gray !default;\n\n/// Bottom margin of a progress bar.\n/// @type Number\n$progress-margin-bottom: $global-margin !default;\n\n/// Default color of a progress bar's meter.\n/// @type Color\n$progress-meter-background: $primary-color !default;\n\n/// Default radius of a progress bar.\n/// @type Number\n$progress-radius: $global-radius !default;\n\n@mixin foundation-progress-element {\n  progress {\n    display: block;\n    width: 100%;\n    height: $progress-height;\n    margin-bottom: $progress-margin-bottom;\n\n    appearance: none;\n\n    @if has-value($progress-radius) {\n      border-radius: $progress-radius;\n    }\n\n    // For Firefox\n    border: 0;\n    background: $progress-background;\n\n    &::-webkit-progress-bar {\n      background: $progress-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    &::-webkit-progress-value {\n      background: $progress-meter-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    &::-moz-progress-bar {\n      background: $progress-meter-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        // Internet Explorer sets the fill with color\n        color: $color;\n\n        &::-webkit-progress-value {\n          background: $color;\n        }\n\n        &::-moz-progress-bar {\n          background: $color;\n        }\n      }\n    }\n\n    // For IE and Edge\n    &::-ms-fill { // sass-lint:disable-line no-vendor-prefixes\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n\n      border: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// [TODO] Check how plugin confirms disabled or vertical status\n// [TODO] Check if transition: all; is necessary\n\n////\n/// @group slider\n////\n\n/// Default slider width of a vertical slider. (Doesn't apply to the native slider.)\n/// @type Number\n$slider-width-vertical: 0.5rem !default;\n\n/// Transition properties to apply to the slider handle and fill. (Doesn't apply to the native slider.)\n/// @type Transition\n$slider-transition: all 0.2s ease-in-out !default;\n\n/// Adds the general styles for sliders.\n@mixin slider-container {\n  position: relative;\n  height: $slider-height;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n\n  background-color: $slider-background;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none;\n}\n\n/// Adds the general styles for active fill for sliders.\n@mixin slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n\n  display: inline-block;\n  max-width: 100%;\n  height: $slider-height;\n\n  background-color: $slider-fill-background;\n  transition: $slider-transition;\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n/// Adds the general styles for the slider handles.\n@mixin slider-handle {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  left: 0;\n  z-index: 1;\n\n  display: inline-block;\n  width: $slider-handle-width;\n  height: $slider-handle-height;\n\n  border-radius: $slider-radius;\n  background-color: $slider-handle-background;\n  transition: $slider-transition;\n  touch-action: manipulation;\n\n  &:hover {\n    background-color: scale-color($slider-handle-background, $lightness: -15%);\n  }\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n@mixin slider-disabled {\n  opacity: $slider-opacity-disabled;\n  cursor: not-allowed;\n}\n\n@mixin slider-vertical {\n  display: inline-block;\n  width: $slider-width-vertical;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1);\n\n  .slider-fill {\n    top: 0;\n    width: $slider-width-vertical;\n    max-height: 100%;\n  }\n\n  .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: $slider-handle-height;\n    height: $slider-handle-width;\n    transform: translateX(-50%);\n  }\n}\n\n@mixin foundation-slider {\n  // Container\n  .slider {\n    @include slider-container;\n  }\n\n  // Fill area\n  .slider-fill {\n    @include slider-fill;\n  }\n\n  // Draggable handle\n  .slider-handle {\n    @include slider-handle;\n  }\n\n  // Disabled state\n  .slider.disabled,\n  .slider[disabled] {\n    @include slider-disabled;\n  }\n\n  // Vertical slider\n  .slider.vertical {\n    @include slider-vertical;\n  }\n\n  // RTL support\n  @if $global-text-direction == rtl {\n    .slider:not(.vertical) {\n      transform: scale(-1, 1);\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group slider\n////\n\n/// Default height of the slider.\n/// @type Number\n$slider-height: 0.5rem !default;\n\n/// Default background color of the slider's track.\n/// @type Color\n$slider-background: $light-gray !default;\n\n/// Default color of the active fill color of the slider.\n/// @type Color\n$slider-fill-background: $medium-gray !default;\n\n/// Default height of the handle of the slider.\n/// @type Number\n$slider-handle-height: 1.4rem !default;\n\n/// Default width of the handle of the slider.\n/// @type Number\n$slider-handle-width: 1.4rem !default;\n\n/// Default color of the handle for the slider.\n/// @type Color\n$slider-handle-background: $primary-color !default;\n\n/// Default fade amount of a disabled slider.\n/// @type Number\n$slider-opacity-disabled: 0.25 !default;\n\n/// Default radius for slider.\n/// @type Number\n$slider-radius: $global-radius !default;\n\n@mixin foundation-range-input {\n  input[type='range'] {  // sass-lint:disable-line no-qualifying-elements\n    $margin: ($slider-handle-height - $slider-height) / 2;\n\n    display: block;\n    width: 100%;\n    height: auto;\n    margin-top: $margin;\n    margin-bottom: $margin;\n\n    appearance: none;\n    border: 0;\n    line-height: 1;\n    cursor: pointer;\n\n    @if has-value($slider-radius) {\n      border-radius: $slider-radius;\n    }\n\n    &:focus {\n      outline: 0;\n    }\n\n    &[disabled] {\n      opacity: $slider-opacity-disabled;\n    }\n\n    // sass-lint:disable no-vendor-prefix\n\n    // Chrome/Safari\n    &::-webkit-slider-runnable-track {\n      height: $slider-height;\n      background: $slider-background;\n    }\n\n    &::-webkit-slider-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      margin-top: -$margin;\n\n      -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    // Firefox\n    &::-moz-range-track {\n      height: $slider-height;\n      -moz-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-background;\n    }\n\n    &::-moz-range-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      margin-top: -$margin;\n\n      -moz-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    // Internet Explorer\n    &::-ms-track {\n      height: $slider-height;\n\n      border: 0;\n      border-top: $margin solid $body-background;\n      border-bottom: $margin solid $body-background;\n      background: $slider-background;\n\n      overflow: visible;\n      color: transparent;\n    }\n\n    &::-ms-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      border: 0;\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    &::-ms-fill-lower {\n      background: $slider-fill-background;\n    }\n\n    &::-ms-fill-upper {\n      background: $slider-background;\n    }\n\n    @at-root {\n      output {\n        vertical-align: middle;\n        margin-left: 0.5em;\n        line-height: $slider-handle-height;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group switch\n////\n\n/// Background color of a switch.\n/// @type Color\n$switch-background: $medium-gray !default;\n\n/// Background active color of a switch.\n/// @type Color\n$switch-background-active: $primary-color !default;\n\n/// Height of a switch, with no class applied.\n/// @type Number\n$switch-height: 2rem !default;\n\n/// Height of a switch with .tiny class.\n/// @type Number\n$switch-height-tiny: 1.5rem !default;\n\n/// Height of a switch with .small class.\n/// @type Number\n$switch-height-small: 1.75rem !default;\n\n/// Height of a switch with .large class.\n/// @type Number\n$switch-height-large: 2.5rem !default;\n\n/// Border radius of the switch\n/// @type Number\n$switch-radius: $global-radius !default;\n\n/// border around a modal.\n/// @type Number\n$switch-margin: $global-margin !default;\n\n/// Background color for the switch container and paddle.\n/// @type Color\n$switch-paddle-background: $white !default;\n\n/// Spacing between a switch paddle and the edge of the body.\n/// @type Number\n$switch-paddle-offset: 0.25rem !default;\n\n/// border radius of the switch paddle\n/// @type Number\n$switch-paddle-radius: $global-radius !default;\n\n/// switch transition.\n/// @type Number\n$switch-paddle-transition: all 0.25s ease-out !default;\n\n// make them variables\n// ask about accessibility on label\n// change class name for text\n\n/// Adds styles for a switch container. Apply this to a container class.\n@mixin switch-container {\n  position: relative;\n  margin-bottom: $switch-margin;\n  outline: 0;\n\n  // These properties cascade down to the switch text\n  font-size: rem-calc(14);\n  font-weight: bold;\n  color: $white;\n\n  user-select: none;\n}\n\n/// Adds styles for a switch input. Apply this to an `<input>` within a switch.\n@mixin switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0;\n}\n\n/// Adds styles for the background and paddle of a switch. Apply this to a `<label>` within a switch.\n@mixin switch-paddle {\n  $switch-width: $switch-height * 2;\n  $paddle-height: $switch-height - ($switch-paddle-offset * 2);\n  $paddle-width: $switch-height - ($switch-paddle-offset * 2);\n  $paddle-active-offest: $switch-width - $paddle-width - $switch-paddle-offset;\n\n  position: relative;\n  display: block;\n  width: $switch-width;\n  height: $switch-height;\n\n  border-radius: $switch-radius;\n  background: $switch-background;\n  transition: $switch-paddle-transition;\n\n  // Resetting these <label> presets so type styles cascade down\n  font-weight: inherit;\n  color: inherit;\n\n  cursor: pointer;\n\n  // Needed to override specificity\n  input + & {\n    margin: 0;\n  }\n\n  // The paddle itself\n  &::after {\n    position: absolute;\n    top: $switch-paddle-offset;\n    #{$global-left}: $switch-paddle-offset;\n\n    display: block;\n    width: $paddle-width;\n    height: $paddle-height;\n\n    transform: translate3d(0, 0, 0);\n    border-radius: $switch-paddle-radius;\n    background: $switch-paddle-background;\n    transition: $switch-paddle-transition;\n    content: '';\n  }\n\n  // Change the visual style when the switch is active\n  input:checked ~ & {\n    background: $switch-background-active;\n\n    &::after {\n      #{$global-left}: $paddle-active-offest;\n    }\n  }\n\n  input:focus ~ & {\n    @include disable-mouse-outline;\n  }\n}\n\n/// Adds base styles for active/inactive text inside a switch. Apply this to text elements inside the switch `<label>`.\n@mixin switch-text {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Adds styles for the active state text within a switch.\n@mixin switch-text-active {\n  #{$global-left}: 8%;\n  display: none;\n\n  input:checked + label > & {\n    display: block;\n  }\n}\n\n/// Adds styles for the inactive state text within a switch.\n@mixin switch-text-inactive {\n  #{$global-right}: 15%;\n\n  input:checked + label > & {\n    display: none;\n  }\n}\n\n/// Changes the size of a switch by modifying the size of the body and paddle. Apply this to a switch container.\n/// @param {Number} $font-size [1rem] - Font size of label text within the switch.\n/// @param {Number} $switch-height [2rem] - Height of the switch body.\n/// @param {Number} $paddle-offset [0.25rem] - Spacing between the switch paddle and the edge of the switch body.\n@mixin switch-size(\n  $font-size: 1rem,\n  $switch-height: 2rem,\n  $paddle-offset: 0.25rem\n) {\n\n  $switch-width: $switch-height * 2;\n  $paddle-width: $switch-height - ($paddle-offset * 2);\n  $paddle-height: $switch-height - ($paddle-offset * 2);\n  $paddle-active-offest: $switch-width - $paddle-width - $paddle-offset;\n\n  height: $switch-height;\n\n  .switch-paddle {\n    width: $switch-width;\n    height: $switch-height;\n    font-size: $font-size;\n  }\n\n  .switch-paddle::after {\n    top: $paddle-offset;\n    #{$global-left}: $paddle-offset;\n    width: $paddle-width;\n    height: $paddle-height;\n  }\n\n  input:checked ~ .switch-paddle::after {\n    #{$global-left}: $paddle-active-offest;\n  }\n}\n\n@mixin foundation-switch {\n  // Container class\n  .switch {\n    height: $switch-height;\n    @include switch-container;\n  }\n\n  // <input> element\n  .switch-input {\n    @include switch-input;\n  }\n\n  // <label> element\n  .switch-paddle {\n    @include switch-paddle;\n  }\n\n  // Base label text styles\n  %switch-text {\n    @include switch-text;\n  }\n\n  // Active label text styles\n  .switch-active {\n    @extend %switch-text;\n    @include switch-text-active;\n  }\n\n  // Inactive label text styles\n  .switch-inactive {\n    @extend %switch-text;\n    @include switch-text-inactive;\n  }\n\n  // Switch sizes\n  .switch.tiny {\n    @include switch-size(rem-calc(10), $switch-height-tiny, $switch-paddle-offset);\n  }\n\n  .switch.small {\n    @include switch-size(rem-calc(12), $switch-height-small, $switch-paddle-offset);\n  }\n\n  .switch.large {\n    @include switch-size(rem-calc(16), $switch-height-large, $switch-paddle-offset);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-qualifying-elements\n\n////\n/// @group table\n////\n\n/// Default color for table background.\n/// @type Color\n$table-background: $white  !default;\n\n/// Default scale for darkening the striped table rows and the table border.\n/// @type Number\n$table-color-scale: 5% !default;\n\n/// Default style for table border.\n/// @type List\n$table-border: 1px solid smart-scale($table-background, $table-color-scale) !default;\n\n/// Default padding for table.\n/// @type Number\n$table-padding: rem-calc(8 10 10) !default;\n\n/// Default scale for darkening the table rows on hover.\n/// @type Number\n$table-hover-scale: 2% !default;\n\n/// Default color of standard rows on hover.\n/// @type List\n$table-row-hover: darken($table-background, $table-hover-scale) !default;\n\n/// Default color of striped rows on hover.\n/// @type List\n$table-row-stripe-hover: darken($table-background, $table-color-scale + $table-hover-scale) !default;\n\n/// If `true`, tables are striped by default and an .unstriped class is created. If `false`, a .striped class is created.\n/// @type Boolean\n$table-is-striped: true !default;\n\n/// Default background color for striped rows.\n/// @type Color\n$table-striped-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default value for showing the stripe on rows of the tables, excluding the header and footer. If even, the even rows will have a background color. If odd, the odd rows will have a background color. If empty, or any other value, the table rows will have no striping.\n/// @type Keyword\n$table-stripe: even !default;\n\n/// Default color for header background.\n/// @type Color\n$table-head-background: smart-scale($table-background, $table-color-scale / 2) !default;\n\n/// Default color of header rows on hover.\n/// @type List\n$table-head-row-hover: darken($table-head-background, $table-hover-scale) !default;\n\n/// Default color for footer background.\n/// @type Color\n$table-foot-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default color of footer rows on hover.\n/// @type List\n$table-foot-row-hover: darken($table-foot-background, $table-hover-scale) !default;\n\n/// Default font color for header.\n/// @type Color\n$table-head-font-color: $body-font-color !default;\n\n/// Default font color for footer.\n/// @type Color\n$table-foot-font-color: $body-font-color !default;\n\n/// Default value for showing the header when using stacked tables.\n/// @type Boolean\n$show-header-for-stacked: false !default;\n\n/// Breakpoint at which stacked table switches from mobile to desktop view.\n/// @type Breakpoint\n$table-stack-breakpoint: medium !default;\n\n@mixin -zf-table-stripe($stripe: $table-stripe) {\n  tr {\n    // If stripe is set to even, darken the even rows.\n    @if $stripe == even {\n      &:nth-child(even) {\n        border-bottom: 0;\n        background-color: $table-striped-background;\n      }\n    }\n\n    // If stripe is set to odd, darken the odd rows.\n    @else if $stripe == odd {\n      &:nth-child(odd) {\n        background-color: $table-striped-background;\n      }\n    }\n  }\n}\n\n@mixin -zf-table-unstripe() {\n  tr {\n    border-bottom: 0;\n    border-bottom: $table-border;\n    background-color: $table-background;\n  }\n}\n\n@mixin -zf-table-children-styles($stripe: $table-stripe, $is-striped: $table-is-striped) {\n  thead,\n  tbody,\n  tfoot {\n    border: $table-border;\n    background-color: $table-background;\n  }\n\n  // Caption\n  caption {\n    padding: $table-padding;\n    font-weight: $global-weight-bold;\n  }\n\n  // Table head\n  thead {\n    background: $table-head-background;\n    color: $table-head-font-color;\n  }\n\n  // Table foot\n  tfoot {\n    background: $table-foot-background;\n    color: $table-foot-font-color;\n  }\n\n  // Table head and foot\n  thead,\n  tfoot {\n    // Rows within head and foot\n    tr {\n      background: transparent;\n    }\n\n    // Cells within head and foot\n    th,\n    td {\n      padding: $table-padding;\n      font-weight: $global-weight-bold;\n      text-align: #{$global-left};\n    }\n  }\n\n  // Table rows\n  tbody {\n    th,\n    td {\n      padding: $table-padding;\n    }\n  }\n\n  // If tables are striped\n  @if $is-striped == true {\n    tbody {\n      @include -zf-table-stripe($stripe);\n    }\n\n    &.unstriped {\n      tbody {\n        @include -zf-table-unstripe();\n        background-color: $table-background;\n      }\n    }\n  }\n\n  // If tables are not striped\n  @else if $is-striped == false {\n    tbody {\n      @include -zf-table-unstripe();\n    }\n\n    &.striped {\n      tbody {\n        @include -zf-table-stripe($stripe);\n      }\n    }\n  }\n}\n\n/// Adds the general styles for tables.\n/// @param {Keyword} $stripe [$table-stripe] - Uses keywords even, odd, or none to darken rows of the table. The default value is even.\n@mixin table(\n  $stripe: $table-stripe,\n  $nest: false\n) {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: $global-margin;\n  border-radius: $global-radius;\n\n  @if $nest {\n    @include -zf-table-children-styles($stripe);\n  }\n  @else {\n    @at-root {\n      @include -zf-table-children-styles($stripe);\n    }\n  }\n}\n\n/// Adds the ability to horizontally scroll the table when the content overflows horizontally.\n@mixin table-scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto;\n}\n\n/// Slightly darkens the table rows on hover.\n@mixin table-hover {\n  thead tr {\n    //Darkens the table header rows on hover.\n    &:hover {\n      background-color: $table-head-row-hover;\n    }\n  }\n\n  tfoot tr {\n    //Darkens the table footer rows on hover.\n    &:hover {\n      background-color: $table-foot-row-hover;\n    }\n  }\n\n  tbody tr {\n    //Darkens the non-striped table rows on hover.\n    &:hover {\n      background-color: $table-row-hover;\n    }\n  }\n\n  @if $table-is-striped == true {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &:not(.unstriped) tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &:not(.unstriped) tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n\n  @else if $table-is-striped == false {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &.striped tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &.striped tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n}\n\n/// Adds styles for a stacked table. Useful for small-screen layouts.\n/// @param {Boolean} $header [$show-header-for-stacked] - Show the first th of header when stacked.\n@mixin table-stack($header: $show-header-for-stacked) {\n  @if $header {\n    thead {\n      th {\n        display: block;\n      }\n    }\n  }\n  @else {\n    thead {\n      display: none;\n    }\n  }\n\n  tfoot {\n    display: none;\n  }\n\n  tr,\n  th,\n  td {\n    display: block;\n  }\n\n  td {\n    border-top: 0;\n  }\n}\n\n@mixin foundation-table($nest: false) {\n  table {\n    @include table($nest: $nest);\n  }\n\n  table.stack {\n    @include breakpoint($table-stack-breakpoint down) {\n      @include table-stack;\n    }\n  }\n\n  table.scroll {\n    @include table-scroll;\n  }\n\n  table.hover {\n    @include table-hover;\n  }\n\n  .table-scroll {\n    overflow-x: auto;\n\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@import 'math';\n\n$contrast-warnings: true !default;\n\n////\n/// @group functions\n////\n\n/// Checks the luminance of `$color`.\n///\n/// @param {Color} $color - Color to check the luminance of.\n///\n/// @returns {Number} The luminance of `$color`.\n@function color-luminance($color) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n  $rgba: red($color), green($color), blue($color);\n  $rgba2: ();\n\n  @for $i from 1 through 3 {\n    $rgb: nth($rgba, $i);\n    $rgb: $rgb / 255;\n\n    $rgb: if($rgb < 0.03928, $rgb / 12.92, pow(($rgb + 0.055) / 1.055, 2.4));\n\n    $rgba2: append($rgba2, $rgb);\n  }\n\n  @return 0.2126 * nth($rgba2, 1) + 0.7152 * nth($rgba2, 2) + 0.0722 * nth($rgba2, 3);\n}\n\n/// Checks the contrast ratio of two colors.\n///\n/// @param {Color} $color1 - First color to compare.\n/// @param {Color} $color2 - Second color to compare.\n///\n/// @returns {Number} The contrast ratio of the compared colors.\n@function color-contrast($color1, $color2) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef\n  $luminance1: color-luminance($color1) + 0.05;\n  $luminance2: color-luminance($color2) + 0.05;\n  $ratio: $luminance1 / $luminance2;\n\n  @if $luminance2 > $luminance1 {\n    $ratio: 1 / $ratio;\n  }\n\n  $ratio: round($ratio * 10) / 10;\n\n  @return $ratio;\n}\n\n/// Checks the luminance of `$base`, and returns the color from `$colors` (list of colors) that has the most contrast.\n///\n/// @param {Color} $base - Color to check luminance.\n/// @param {List} $colors [($white, $black)] - Colors to compare.\n/// @param {Number} $tolerance [$global-color-pick-contrast-tolerance] - Contrast tolerance.\n///\n/// @returns {Color} the color from `$colors` (list of colors) that has the most contrast.\n@function color-pick-contrast($base, $colors: ($white, $black), $tolerance: $global-color-pick-contrast-tolerance) {\n  $contrast: color-contrast($base, nth($colors, 1));\n  $best: nth($colors, 1);\n\n  @for $i from 2 through length($colors) {\n    $current-contrast: color-contrast($base, nth($colors, $i));\n    @if ($current-contrast - $contrast > $tolerance) {\n      $contrast: color-contrast($base, nth($colors, $i));\n      $best: nth($colors, $i);\n    }\n  }\n\n  @if ($contrast-warnings and $contrast < 3) {\n    @warn \"Contrast ratio of #{$best} on #{$base} is pretty bad, just #{$contrast}\";\n  }\n\n  @return $best;\n}\n\n/// Scales a color to be darker if it's light, or lighter if it's dark. Use this function to tint a color appropriate to its lightness.\n///\n/// @param {Color} $color - Color to scale.\n/// @param {Percentage} $scale [5%] - Amount to scale up or down.\n/// @param {Percentage} $threshold [40%] - Threshold of lightness to check against.\n///\n/// @returns {Color} A scaled color.\n@function smart-scale($color, $scale: 5%, $threshold: 40%) {\n  @if lightness($color) > $threshold {\n    $scale: -$scale;\n  }\n  @return scale-color($color, $lightness: $scale);\n}\n\n/// Get color from foundation-palette\n///\n/// @param {key} color key from foundation-palette\n///\n/// @returns {Color} color from foundation-palette\n@function get-color($key) {\n  @if map-has-key($foundation-palette, $key) {\n    @return map-get($foundation-palette, $key);\n  }\n  @else {\n    @error 'given $key is not available in $foundation-palette';\n  }\n}\n\n/// Transfers the colors in the `$foundation-palette` map into variables, such as `$primary-color` and `$secondary-color`. Call this mixin below the Global section of your settings file to properly migrate your codebase.\n@mixin add-foundation-colors() {\n  @if map-has-key($foundation-palette, primary) {\n    $primary-color: map-get($foundation-palette, primary) !global;\n  } @else {\n    $primary-color: #1779ba !global;\n  }\n  @if map-has-key($foundation-palette, secondary) {\n    $secondary-color: map-get($foundation-palette, secondary) !global;\n  } @else {\n    $secondary-color: #767676 !global;\n  }\n  @if map-has-key($foundation-palette, success) {\n    $success-color: map-get($foundation-palette, success) !global;\n  } @else {\n    $success-color: #3adb76 !global;\n  }\n  @if map-has-key($foundation-palette, warning) {\n    $warning-color: map-get($foundation-palette, warning) !global;\n  } @else {\n    $warning-color: #ffae00 !global;\n  }\n  @if map-has-key($foundation-palette, alert) {\n    $alert-color: map-get($foundation-palette, alert) !global;\n  } @else {\n    $alert-color: #cc4b37 !global;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group badge\n////\n\n/// Default background color for badges.\n/// @type Color\n$badge-background: $primary-color !default;\n\n/// Default text color for badges.\n/// @type Color\n$badge-color: $white !default;\n\n/// Alternate text color for badges.\n/// @type Color\n$badge-color-alt: $black !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$badge-palette: $foundation-palette !default;\n\n/// Default padding inside badges.\n/// @type Number\n$badge-padding: 0.3em !default;\n\n/// Minimum width of a badge.\n/// @type Number\n$badge-minwidth: 2.1em !default;\n\n/// Default font size for badges.\n/// @type Number\n$badge-font-size: 0.6rem !default;\n\n/// Generates the base styles for a badge.\n@mixin badge {\n  display: inline-block;\n  min-width: $badge-minwidth;\n  padding: $badge-padding;\n\n  border-radius: 50%;\n\n  font-size: $badge-font-size;\n  text-align: center;\n}\n\n@mixin foundation-badge {\n  .badge {\n    @include badge;\n\n    background: $badge-background;\n    color: $badge-color;\n\n    @each $name, $color in $badge-palette {\n      &.#{$name} {\n        background: $color;\n        color: color-pick-contrast($color, ($badge-color, $badge-color-alt));\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group breadcrumbs\n////\n\n/// Margin around a breadcrumbs container.\n/// @type Number\n$breadcrumbs-margin: 0 0 $global-margin 0 !default;\n\n/// Font size of breadcrumb links.\n/// @type Number\n$breadcrumbs-item-font-size: rem-calc(11) !default;\n\n/// Color of breadcrumb links.\n/// @type Color\n$breadcrumbs-item-color: $primary-color !default;\n\n/// Color of the active breadcrumb link.\n/// @type Color\n$breadcrumbs-item-color-current: $black !default;\n\n/// Opacity of disabled breadcrumb links.\n/// @type Number\n$breadcrumbs-item-color-disabled: $medium-gray !default;\n\n/// Margin between breadcrumb items.\n/// @type Number\n$breadcrumbs-item-margin: 0.75rem !default;\n\n/// If `true`, makes breadcrumb links uppercase.\n/// @type Boolean\n$breadcrumbs-item-uppercase: true !default;\n\n/// If `true`, adds a seperator between breadcrumb links.\n/// @type Boolean\n$breadcrumbs-item-separator: true !default;\n\n// If it exists $breadcrumbs-item-slash is used to build $breadcrumbs-item-separator. See the documentation.\n@if variable-exists(breadcrumbs-item-slash) {\n  $breadcrumbs-item-separator: $breadcrumbs-item-slash;\n}\n\n/// Used character for the breadcrumb separator.\n/// @type Content\n$breadcrumbs-item-separator-item: '/' !default;\n\n/// Used character for the breadcrumb separator in rtl mode.\n/// @type Content\n$breadcrumbs-item-separator-item-rtl: '\\\\' !default;\n\n/// Color of breadcrumb item.\n/// @type Color\n$breadcrumbs-item-separator-color: $medium-gray !default;\n\n// If it exists $breadcrumbs-item-slash-color is used to build $breadcrumbs-item-separator-color. See the documentation.\n@if variable-exists(breadcrumbs-item-slash-color) {\n  $breadcrumbs-item-separator-color: $breadcrumbs-item-slash-color;\n}\n\n/// Adds styles for a breadcrumbs container, along with the styles for the `<li>` and `<a>` elements inside of it.\n@mixin breadcrumbs-container {\n  @include clearfix;\n  margin: $breadcrumbs-margin;\n  list-style: none;\n\n  // Item wrapper\n  li {\n    float: #{$global-left};\n\n    font-size: $breadcrumbs-item-font-size;\n    color: $breadcrumbs-item-color-current;\n    cursor: default;\n\n    @if $breadcrumbs-item-uppercase {\n      text-transform: uppercase;\n    }\n\n    @if $breadcrumbs-item-separator {\n      // Need to escape the backslash\n      $separator: if($global-text-direction == 'ltr', $breadcrumbs-item-separator-item, $breadcrumbs-item-separator-item-rtl);\n\n      &:not(:last-child) {\n        &::after {\n          position: relative;\n          margin: 0 $breadcrumbs-item-margin;\n          opacity: 1;\n          content: $separator;\n          color: $breadcrumbs-item-separator-color;\n        }\n      }\n    }\n    @else {\n      margin-#{$global-right}: $breadcrumbs-item-margin;\n    }\n  }\n\n  // Page links\n  a {\n    color: $breadcrumbs-item-color;\n\n    &:hover {\n      text-decoration: underline;\n    }\n  }\n}\n\n@mixin foundation-breadcrumbs {\n  .breadcrumbs {\n    @include breadcrumbs-container;\n\n    .disabled {\n      color: $breadcrumbs-item-color-disabled;\n      cursor: not-allowed;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group callout\n////\n\n/// Default background color.\n/// @type Color\n$callout-background: $white !default;\n\n/// Default fade value for callout backgrounds.\n/// @type Number\n$callout-background-fade: 85% !default;\n\n/// Default border style for callouts.\n/// @type List\n$callout-border: 1px solid rgba($black, 0.25) !default;\n\n/// Default bottom margin for callouts.\n/// @type Number\n$callout-margin: 0 0 1rem 0 !default;\n\n/// Default inner padding for callouts.\n/// @type Number\n$callout-padding: 1rem !default;\n\n/// Default font color for callouts.\n/// @type Color\n$callout-font-color: $body-font-color !default;\n\n/// Default font color for callouts, if the callout has a dark background.\n/// @type Color\n$callout-font-color-alt: $body-background !default;\n\n/// Default border radius for callouts.\n/// @type Color\n$callout-radius: $global-radius !default;\n\n/// Amount to tint links used within colored panels. Set to `false` to disable this feature.\n/// @type Number | Boolean\n$callout-link-tint: 30% !default;\n\n/// Adds basic styles for a callout, including padding and margin.\n@mixin callout-base() {\n  position: relative;\n  margin: $callout-margin;\n  padding: $callout-padding;\n\n  border: $callout-border;\n  border-radius: $callout-radius;\n\n  // Respect the padding, fool.\n  > :first-child {\n    margin-top: 0;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Generate quick styles for a callout using a single color as a baseline.\n/// @param {Color} $color [$callout-background] - Color to use.\n@mixin callout-style($color: $callout-background) {\n  $background: scale-color($color, $lightness: $callout-background-fade);\n\n  background-color: $background;\n  color: color-pick-contrast($background, ($callout-font-color, $callout-font-color-alt));\n}\n\n@mixin callout-size($padding) {\n  padding-top: $padding;\n  padding-right: $padding;\n  padding-bottom: $padding;\n  padding-left: $padding;\n}\n\n\n/// Adds styles for a callout.\n/// @param {Color} $color [$callout-background] - Color to use.\n@mixin callout($color: $callout-background) {\n  @include callout-base;\n  @include callout-style($color);\n}\n\n@mixin foundation-callout {\n  .callout {\n    @include callout;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        @include callout-style($color);\n      }\n    }\n\n    &.small {\n      @include callout-size(0.5rem);\n    }\n\n    &.large {\n      @include callout-size(3rem);\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group card\n////\n\n/// Default background color.\n/// @type Color\n$card-background: $white !default;\n\n/// Default font color for cards.\n/// @type Color\n$card-font-color: $body-font-color !default;\n\n/// Default background.\n/// @type Color\n$card-divider-background: $light-gray !default;\n\n/// Default border style.\n/// @type List\n$card-border: 1px solid $light-gray !default;\n\n/// Default card shadow.\n/// @type List\n$card-shadow: none !default;\n\n/// Default border radius.\n/// @type List\n$card-border-radius: $global-radius !default;\n\n/// Default padding.\n/// @type Number\n$card-padding: $global-padding !default;\n\n/// Default bottom margin.\n/// @type number\n$card-margin-bottom: $global-margin !default;\n\n/// Adds styles for a card container.\n/// @param {Color} $background - Background color of the card.\n/// @param {Color} $color - font color of the card.\n/// @param {Number} $margin - Bottom margin of the card.\n/// @param {List} $border - Border around the card.\n/// @param {List} $radius - border radius of the card.\n/// @param {List} $shadow - box shadow of the card.\n@mixin card-container(\n  $background: $card-background,\n  $color: $card-font-color,\n  $margin: $card-margin-bottom,\n  $border: $card-border,\n  $radius: $card-border-radius,\n  $shadow: $card-shadow\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex-direction: column;\n    flex-grow: 1;\n  }\n\n  margin-bottom: $margin;\n\n  border: $border;\n  border-radius: $radius;\n\n  background: $background;\n  box-shadow: $shadow;\n\n  overflow: hidden;\n  color: $color;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card divider.\n@mixin card-divider(\n  $background: $card-divider-background,\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex: 0 1 auto;\n  }\n\n  padding: $padding;\n  background: $background;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card section.\n@mixin card-section(\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    flex: 1 0 auto;\n  }\n\n  padding: $padding;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n@mixin foundation-card {\n  .card {\n    @include card-container;\n  }\n\n  .card-divider {\n    @include card-divider;\n  }\n\n  .card-section {\n    @include card-section;\n  }\n\n  // For IE 11 - Flexbug\n  // https://github.com/philipwalton/flexbugs/issues/75\n  .card-image {\n    min-height: 1px;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown\n////\n\n/// Padding for dropdown panes.\n/// @type List\n$dropdown-padding: 1rem !default;\n\n/// Background for dropdown panes.\n/// @type Color\n$dropdown-background: $body-background !default;\n\n/// Border for dropdown panes.\n/// @type List\n$dropdown-border: 1px solid $medium-gray !default;\n\n/// Font size for dropdown panes.\n/// @type List\n$dropdown-font-size: 1rem !default;\n\n/// Width for dropdown panes.\n/// @type Number\n$dropdown-width: 300px !default;\n\n/// Border radius dropdown panes.\n/// @type Number\n$dropdown-radius: $global-radius !default;\n\n/// Sizes for dropdown panes. Each size is a CSS class you can apply.\n/// @type Map\n$dropdown-sizes: (\n  tiny: 100px,\n  small: 200px,\n  large: 400px,\n) !default;\n\n/// Applies styles for a basic dropdown.\n@mixin dropdown-container {\n  position: absolute;\n  z-index: 10;\n\n  display: none;\n\n  width: $dropdown-width;\n  padding: $dropdown-padding;\n\n  visibility: hidden;\n  border: $dropdown-border;\n  border-radius: $dropdown-radius;\n  background-color: $dropdown-background;\n\n  font-size: $dropdown-font-size;\n\n\n  // Allow an intermittent state to do positioning before making visible.\n  &.is-opening {\n    display: block;\n  }\n\n  &.is-open {\n    display: block;\n    visibility: visible;\n  }\n}\n\n@mixin foundation-dropdown {\n  .dropdown-pane {\n    @include dropdown-container;\n  }\n\n  @each $name, $size in $dropdown-sizes {\n    .dropdown-pane {\n      &.#{$name} {\n        width: $size;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group pagination\n////\n\n/// Font size of pagination items.\n/// @type Number\n$pagination-font-size: rem-calc(14) !default;\n\n/// Default bottom margin of the pagination object.\n/// @type Number\n$pagination-margin-bottom: $global-margin !default;\n\n/// Text color of pagination items.\n/// @type Color\n$pagination-item-color: $black !default;\n\n/// Padding inside of pagination items.\n/// @type Number\n$pagination-item-padding: rem-calc(3 10) !default;\n\n/// Right margin to separate pagination items.\n/// @type Number\n$pagination-item-spacing: rem-calc(1) !default;\n\n/// Default radius for pagination items.\n/// @type Number\n$pagination-radius: $global-radius !default;\n\n/// Background color of pagination items on hover.\n/// @type Color\n$pagination-item-background-hover: $light-gray !default;\n\n/// Background color of pagination item for the current page.\n/// @type Color\n$pagination-item-background-current: $primary-color !default;\n\n/// Text color of the pagination item for the current page.\n/// @type Color\n$pagination-item-color-current: $white !default;\n\n/// Text color of a disabled pagination item.\n/// @type Color\n$pagination-item-color-disabled: $medium-gray !default;\n\n/// Color of the ellipsis in a pagination menu.\n/// @type Color\n$pagination-ellipsis-color: $black !default;\n\n/// If `false`, don't display page number links on mobile, only next/previous links\n/// and optionally current page number.\n/// @type Boolean\n$pagination-mobile-items: false !default;\n\n/// If `true`, display the current page number on mobile even if `$pagination-mobile-items` is set to `false`.\n/// This parameter will only override the visibility setting of the current item for `$pagination-mobile-items: false;`,\n/// it will not affect the current page number visibility when `$pagination-mobile-items` is set to `true`.\n/// @type Boolean\n$pagination-mobile-current-item: false !default;\n\n/// If `true`, arrows are added to the next and previous links of pagination.\n/// @type Boolean\n$pagination-arrows: true !default;\n\n/// Adds styles for a pagination container. Apply this to a `<ul>`.\n@mixin pagination-container (\n  $margin-bottom: $pagination-margin-bottom,\n  $font-size: $pagination-font-size,\n  $spacing: $pagination-item-spacing,\n  $radius: $pagination-radius,\n  $color: $pagination-item-color,\n  $padding: $pagination-item-padding,\n  $background-hover: $pagination-item-background-hover\n) {\n  @include clearfix;\n  margin-#{$global-left}: 0;\n  margin-bottom: $margin-bottom;\n\n  // List item\n  li {\n    margin-#{$global-right}: $spacing;\n    border-radius: $radius;\n    font-size: $font-size;\n\n    @if $pagination-mobile-items {\n      display: inline-block;\n    }\n    @else {\n      display: none;\n\n      &:last-child,\n      &:first-child {\n        display: inline-block;\n      }\n\n      @if $pagination-mobile-current-item {\n        &.current {\n          display: inline-block;\n        }\n      }\n\n      @include breakpoint(medium) {\n        display: inline-block;\n      }\n    }\n  }\n\n  // Page links\n  a,\n  button {\n    display: block;\n    padding: $padding;\n    border-radius: $radius;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n    }\n  }\n}\n\n/// Adds styles for the current pagination item. Apply this to an `<a>`.\n@mixin pagination-item-current (\n  $padding: $pagination-item-padding,\n  $background-current: $pagination-item-background-current,\n  $color-current: $pagination-item-color-current\n) {\n  padding: $padding;\n  background: $background-current;\n  color: $color-current;\n  cursor: default;\n}\n\n/// Adds styles for a disabled pagination item. Apply this to an `<a>`.\n@mixin pagination-item-disabled (\n  $padding: $pagination-item-padding,\n  $color: $pagination-item-color-disabled\n) {\n  padding: $padding;\n  color: $color;\n  cursor: not-allowed;\n\n  &:hover {\n    background: transparent;\n  }\n}\n\n/// Adds styles for an ellipsis for use in a pagination list.\n@mixin pagination-ellipsis (\n  $padding: $pagination-item-padding,\n  $color: $pagination-ellipsis-color\n) {\n  padding: $padding;\n  content: '\\2026';\n  color: $color;\n}\n\n@mixin foundation-pagination {\n  .pagination {\n    @include pagination-container;\n\n    .current {\n      @include pagination-item-current;\n    }\n\n    .disabled {\n      @include pagination-item-disabled;\n    }\n\n    .ellipsis::after {\n      @include pagination-ellipsis;\n    }\n  }\n\n  @if $pagination-arrows {\n    .pagination-previous a::before,\n    .pagination-previous.disabled::before {\n      display: inline-block;\n      margin-#{$global-right}: 0.5rem;\n      content: '\\00ab';\n    }\n\n    .pagination-next a::after,\n    .pagination-next.disabled::after {\n      display: inline-block;\n      margin-#{$global-left}: 0.5rem;\n      content: '\\00bb';\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group tooltip\n////\n\n/// Default cursor of the defined term.\n/// @type Keyword\n$has-tip-cursor: help !default;\n\n/// Default font weight of the defined term.\n/// @type Keyword | Number\n$has-tip-font-weight: $global-weight-bold !default;\n\n/// Default border bottom of the defined term.\n/// @type List\n$has-tip-border-bottom: dotted 1px $dark-gray !default;\n\n/// Default color of the tooltip background.\n/// @type Color\n$tooltip-background-color: $black !default;\n\n/// Default color of the tooltip font.\n/// @type Color\n$tooltip-color: $white !default;\n\n/// Default padding of the tooltip background.\n/// @type Number\n$tooltip-padding: 0.75rem !default;\n\n/// Default max width for tooltips.\n/// @type Number\n$tooltip-max-width: 10rem !default;\n\n/// Default font size of the tooltip text. By default, we recommend a smaller font size than the body copy.\n/// @type Number\n$tooltip-font-size: $small-font-size !default;\n\n/// Default pip width for tooltips.\n/// @type Number\n$tooltip-pip-width: 0.75rem !default;\n\n/// Default pip height for tooltips. This is helpful for calculating the distance of the tooltip from the tooltip word.\n/// @type Number\n$tooltip-pip-height: $tooltip-pip-width * 0.866 !default;\n\n/// Default radius for tooltips.\n/// @type Number\n$tooltip-radius: $global-radius !default;\n\n@mixin has-tip {\n  position: relative;\n  display: inline-block;\n\n  border-bottom: $has-tip-border-bottom;\n  font-weight: $has-tip-font-weight;\n  cursor: $has-tip-cursor;\n}\n\n@mixin tooltip {\n  position: absolute;\n  top: calc(100% + #{$tooltip-pip-height});\n  z-index: 1200;\n\n  max-width: $tooltip-max-width;\n  padding: $tooltip-padding;\n\n  border-radius: $tooltip-radius;\n  background-color: $tooltip-background-color;\n  font-size: $tooltip-font-size;\n  color: $tooltip-color;\n\n  &::before {\n    position: absolute;\n  }\n\n  &.bottom {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, up);\n      bottom: 100%;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.top {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, down);\n      top: 100%;\n      bottom: auto;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.left {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, right);\n      left: 100%;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.right {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, left);\n      right: 100%;\n      left: auto;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.align-top::before {\n    bottom: auto;\n    top: 10%;\n  }\n\n  &.align-bottom::before {\n    bottom: 10%;\n    top: auto;\n  }\n\n  &.align-left::before {\n    left: 10%;\n    right: auto;\n  }\n\n  &.align-right::before {\n    left: auto;\n    right: 10%;\n  }\n}\n\n@mixin foundation-tooltip {\n  .has-tip {\n    @include has-tip;\n  }\n\n  .tooltip {\n    @include tooltip;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group accordion\n////\n\n/// Default background color of an accordion group.\n/// @type Color\n$accordion-background: $white !default;\n\n/// If `true`, adds plus and minus icons to the side of each accordion title.\n/// @type Boolean\n$accordion-plusminus: true !default;\n\n/// Font size of accordion titles.\n/// @type Number\n$accordion-title-font-size: rem-calc(12) !default;\n\n/// Default text color for items in a Menu.\n/// @type Color\n$accordion-item-color: $primary-color !default;\n\n/// Default background color on hover for items in a Menu.\n/// @type Color\n$accordion-item-background-hover: $light-gray !default;\n\n/// Default padding of an accordion item.\n/// @type Number | List\n$accordion-item-padding: 1.25rem 1rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$accordion-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$accordion-content-border: 1px solid $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$accordion-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$accordion-content-padding: 1rem !default;\n\n/// Adds styles for an accordion container. Apply this to the same element that gets `data-accordion`.\n@mixin accordion-container (\n  $background: $accordion-background\n) {\n  margin-#{$global-left}: 0;\n  background: $background;\n  list-style-type: none;\n\n  &[disabled] {\n    .accordion-title {\n      cursor: not-allowed;\n    }\n  }\n}\n\n/// Adds styles for the accordion item. Apply this to the list item within an accordion ul.\n@mixin accordion-item {\n  &:first-child > :first-child {\n    border-radius: $global-radius $global-radius 0 0;\n  }\n\n  &:last-child > :last-child {\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n}\n\n/// Adds styles for the title of an accordion item. Apply this to the link within an accordion item.\n@mixin accordion-title (\n  $padding: $accordion-item-padding,\n  $font-size: $accordion-title-font-size,\n  $color: $accordion-item-color,\n  $border: $accordion-content-border,\n  $background-hover: $accordion-item-background-hover\n) {\n  position: relative;\n  display: block;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n\n  font-size: $font-size;\n  line-height: 1;\n  color: $color;\n\n  :last-child:not(.is-active) > & {\n    border-bottom: $border;\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n\n  &:hover,\n  &:focus {\n    background-color: $background-hover;\n  }\n\n  @if $accordion-plusminus {\n    &::before {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 1rem;\n      margin-top: -0.5rem;\n      content: '+';\n    }\n\n    .is-active > &::before {\n      content: '\\2013';\n    }\n  }\n}\n\n/// Adds styles for accordion content. Apply this to the content pane below an accordion item's title.\n@mixin accordion-content (\n  $padding: $accordion-content-padding,\n  $border: $accordion-content-border,\n  $background: $accordion-content-background,\n  $color: $accordion-content-color\n) {\n  display: none;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n  background-color: $background;\n\n  color: $color;\n\n  :last-child > &:last-child {\n    border-bottom: $border;\n  }\n}\n\n@mixin foundation-accordion {\n  .accordion {\n    @include accordion-container;\n  }\n\n  .accordion-item {\n    @include accordion-item;\n  }\n\n  .accordion-title {\n    @include accordion-title;\n  }\n\n  .accordion-content {\n    @include accordion-content;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group media-object\n////\n\n/// Bottom margin of a media object.\n/// @type Number\n$mediaobject-margin-bottom: $global-margin !default;\n\n/// Left and right padding on sections within a media object.\n/// @type Number\n$mediaobject-section-padding: $global-padding !default;\n\n/// Width of images within a media object, when the object is stacked vertically. Set to 'auto' to use the image's natural width.\n/// @type Number\n$mediaobject-image-width-stacked: 100% !default;\n\n/// Adds styles for a media object container.\n@mixin media-object-container {\n  display: if($global-flexbox, flex, block);\n  margin-bottom: $mediaobject-margin-bottom;\n\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n  }\n\n  img {\n    max-width: none;\n  }\n\n  @if $global-flexbox {\n    &.stack-for-#{$-zf-zero-breakpoint} {\n      @include breakpoint($-zf-zero-breakpoint only) {\n        flex-wrap: wrap;\n      }\n    }\n  }\n}\n\n/// Adds styles for sections within a media object.\n/// @param {Number} $padding [$mediaobject-section-padding] - Padding between sections.\n@mixin media-object-section($padding: $mediaobject-section-padding) {\n  @if $global-flexbox {\n    flex: 0 1 auto;\n  }\n  @else {\n    display: table-cell;\n    vertical-align: top;\n  }\n\n  &:first-child {\n    padding-#{$global-right}: $padding;\n  }\n\n  &:last-child:not(:nth-child(2)) {\n    padding-#{$global-left}: $padding;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n\n  .stack-for-#{$-zf-zero-breakpoint} & {\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include media-object-stack;\n    }\n  }\n\n  @if $global-flexbox {\n    &.main-section {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    &.middle {\n      vertical-align: middle;\n    }\n\n    &.bottom {\n      vertical-align: bottom;\n    }\n  }\n}\n\n/// Adds styles to stack sections of a media object. Apply this to the section elements, not the container.\n@mixin media-object-stack {\n  padding: 0;\n  padding-bottom: $mediaobject-section-padding;\n\n  @if $global-flexbox {\n    flex-basis: 100%;\n    max-width: 100%;\n  }\n  @else {\n    display: block;\n  }\n\n  img {\n    width: $mediaobject-image-width-stacked;\n  }\n}\n\n@mixin foundation-media-object {\n  .media-object {\n    @include media-object-container;\n  }\n\n  .media-object-section {\n    @include media-object-section;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group orbit\n////\n\n/// Default color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background: $medium-gray !default;\n\n/// Default active color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background-active: $dark-gray !default;\n\n/// Default diameter for Orbit's bullets.\n/// @type Number\n$orbit-bullet-diameter: 1.2rem !default;\n\n/// Default margin between Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin: 0.1rem !default;\n\n/// Default distance from slide region for Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin-top: 0.8rem !default;\n\n/// Default bottom margin from Orbit's bullets to whatever content may lurk below it.\n/// @type Number\n$orbit-bullet-margin-bottom: 0.8rem !default;\n\n/// Default background color for Orbit's caption.\n/// @type Color\n$orbit-caption-background: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's caption.\n/// @type Number\n$orbit-caption-padding: 1rem !default;\n\n/// Default background color for Orbit's controls when hovered.\n/// @type Color\n$orbit-control-background-hover: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's controls.\n/// @type Number\n$orbit-control-padding: 1rem !default;\n\n/// Default z-index for Orbit's controls.\n/// @type Number\n$orbit-control-zindex: 10 !default;\n\n/// Adds styles for the outer Orbit wrapper. These styles are used on the `.orbit` class.\n@mixin orbit-wrapper {\n  position: relative;\n}\n\n/// Adds styles for the inner Orbit slide container. These styles are used on the `.orbit-container` class.\n@mixin orbit-container {\n  position: relative;\n  height: 0; // Prevent FOUC by not showing until JS sets height\n  margin: 0;\n  list-style: none;\n  overflow: hidden;\n}\n\n/// Adds styles for the individual slides of an Orbit slider. These styles are used on the `.orbit-slide` class.\n@mixin orbit-slide {\n  width: 100%;\n  position: absolute;\n\n  &.no-motionui {\n    &.is-active {\n      top: 0;\n      left: 0;\n    }\n  }\n}\n\n@mixin orbit-figure {\n  margin: 0;\n}\n\n/// Adds styles for a slide containing an image. These styles are used on the `.orbit-image` class.\n@mixin orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0;\n}\n\n/// Adds styles for an orbit slide caption. These styles are used on the `.orbit-caption` class.\n@mixin orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: $orbit-caption-padding;\n\n  background-color: $orbit-caption-background;\n  color: color-pick-contrast($orbit-caption-background);\n}\n\n/// Adds base styles for the next/previous buttons in an Orbit slider. These styles are shared between the `.orbit-next` and `.orbit-previous` classes in the default CSS.\n@mixin orbit-control {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  z-index: $orbit-control-zindex;\n  padding: $orbit-control-padding;\n  color: $white;\n\n  &:hover,\n  &:active,\n  &:focus {\n    background-color: $orbit-control-background-hover;\n  }\n}\n\n/// Adds styles for the Orbit previous button. These styles are used on the `.orbit-previous` class.\n@mixin orbit-previous {\n  #{$global-left}: 0;\n}\n\n/// Adds styles for the Orbit next button. These styles are used on the `.orbit-next` class.\n@mixin orbit-next {\n  #{$global-left}: auto;\n  #{$global-right}: 0;\n}\n\n/// Adds styles for a container of Orbit bullets. /// Adds styles for the Orbit previous button. These styles are used on the `.orbit-bullets` class.\n@mixin orbit-bullets {\n  @include disable-mouse-outline;\n  position: relative;\n  margin-top: $orbit-bullet-margin-top;\n  margin-bottom: $orbit-bullet-margin-bottom;\n  text-align: center;\n\n  button {\n    width: $orbit-bullet-diameter;\n    height: $orbit-bullet-diameter;\n    margin: $orbit-bullet-margin;\n\n    border-radius: 50%;\n    background-color: $orbit-bullet-background;\n\n    &:hover {\n      background-color: $orbit-bullet-background-active;\n    }\n\n    &.is-active {\n      background-color: $orbit-bullet-background-active;\n    }\n  }\n}\n\n@mixin foundation-orbit {\n  .orbit {\n    @include orbit-wrapper;\n  }\n\n  .orbit-container {\n    @include orbit-container;\n  }\n\n  .orbit-slide {\n    @include orbit-slide;\n  }\n\n  .orbit-figure {\n    @include orbit-figure;\n  }\n\n  .orbit-image {\n    @include orbit-image;\n  }\n\n  .orbit-caption {\n    @include orbit-caption;\n  }\n\n  %orbit-control {\n    @include orbit-control;\n  }\n\n  .orbit-previous {\n    @extend %orbit-control;\n    @include orbit-previous;\n  }\n\n  .orbit-next {\n    @extend %orbit-control;\n    @include orbit-next;\n  }\n\n  .orbit-bullets {\n    @include orbit-bullets;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group responsive-embed\n////\n\n/// Margin below a responsive embed container.\n/// @type Number\n$responsive-embed-margin-bottom: rem-calc(16) !default;\n\n/// Aspect ratios used to determine padding-bottom of responsive embed containers.\n/// @type Map\n$responsive-embed-ratios: (\n  default: 4 by 3,\n  widescreen: 16 by 9,\n) !default;\n\n/// Creates a responsive embed container.\n/// @param {String|List} $ratio [default] - Ratio of the container. Can be a key from the `$responsive-embed-ratios` map or a list formatted as `x by y`.\n@mixin responsive-embed($ratio: default) {\n  @if type-of($ratio) == 'string' {\n    $ratio: map-get($responsive-embed-ratios, $ratio);\n  }\n  position: relative;\n  height: 0;\n  margin-bottom: $responsive-embed-margin-bottom;\n  padding-bottom: ratio-to-percentage($ratio);\n  overflow: hidden;\n\n  iframe,\n  object,\n  embed,\n  video {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 0;\n    width: 100%;\n    height: 100%;\n  }\n}\n\n@mixin foundation-responsive-embed {\n  .responsive-embed,\n  .flex-video {\n    @include responsive-embed($ratio: default);\n\n    $ratios: map-remove($responsive-embed-ratios,default);\n\n    @each $name, $ratio in $ratios {\n      &.#{$name} {\n        padding-bottom: ratio-to-percentage($ratio);\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Finds the greatest common divisor of two integers.\n///\n/// @param {Number} $a - First number to compare.\n/// @param {Number} $b - Second number to compare.\n///\n/// @returns {Number} The greatest common divisor.\n@function gcd($a, $b) {\n  // From: http://rosettacode.org/wiki/Greatest_common_divisor#JavaScript\n  @if ($b != 0) {\n    @return gcd($b, $a % $b);\n  }\n  @else {\n    @return abs($a);\n  }\n}\n\n/// Handles decimal exponents by trying to convert them into a fraction and then use a nth-root-algorithm for parts of the calculation\n///\n/// @param {Number} $base - The base number.\n/// @param {Number} $exponent - The exponent.\n///\n/// @returns {Number} The product of the exponentiation.\n@function pow($base, $exponent, $prec: 16) {\n  @if (floor($exponent) != $exponent) {\n    $prec2 : pow(10, $prec);\n    $exponent: round($exponent * $prec2);\n    $denominator: gcd($exponent, $prec2);\n    @return nth-root(pow($base, $exponent / $denominator), $prec2 / $denominator, $prec);\n  }\n\n  $value: $base;\n  @if $exponent > 1 {\n    @for $i from 2 through $exponent {\n      $value: $value * $base;\n    }\n  }\n  @else if $exponent < 1 {\n    @for $i from 0 through -$exponent {\n      $value: $value / $base;\n    }\n  }\n\n  @return $value;\n}\n\n@function nth-root($num, $n: 2, $prec: 12) {\n  // From: http://rosettacode.org/wiki/Nth_root#JavaScript\n  $x: 1;\n\n  @for $i from 0 through $prec {\n    $x: 1 / $n * (($n - 1) * $x + ($num / pow($x, $n - 1)));\n  }\n\n  @return $x;\n}\n\n/// Calculates the height as a percentage of the width for a given ratio.\n/// @param {List} $ratio - Ratio to use to calculate the height, formatted as `x by y`.\n/// @return {Number} A percentage value for the height relative to the width of a responsive container.\n@function ratio-to-percentage($ratio) {\n  $w: nth($ratio, 1);\n  $h: nth($ratio, 3);\n  @return $h / $w * 100%;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group tabs\n////\n\n/// Default margin of the tab bar.\n/// @type Number\n$tab-margin: 0 !default;\n\n/// Default background color of a tab bar.\n/// @type Color\n$tab-background: $white !default;\n\n/// Font color of tab item.\n/// @type Color\n$tab-color: $primary-color !default;\n\n/// Active background color of a tab bar.\n/// @type Color\n$tab-background-active: $light-gray !default;\n\n/// Active font color of tab item.\n/// @type Color\n$tab-active-color: $primary-color !default;\n\n/// Font size of tab items.\n/// @type Number\n$tab-item-font-size: rem-calc(12) !default;\n\n/// Default background color on hover for items in a Menu.\n$tab-item-background-hover: $white !default;\n\n/// Default padding of a tab item.\n/// @type Number\n$tab-item-padding: 1.25rem 1.5rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$tab-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$tab-content-border: $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$tab-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$tab-content-padding: 1rem !default;\n\n/// Adds styles for a tab container. Apply this to a `<ul>`.\n@mixin tabs-container (\n  $margin: $tab-margin,\n  $background: $tab-background,\n  $border-color: $tab-content-border\n) {\n  @include clearfix;\n  margin: $margin;\n  border: 1px solid $border-color;\n  background: $background;\n  list-style-type: none;\n}\n\n/// Augments a tab container to have vertical tabs. Use this in conjunction with `tabs-container()`.\n@mixin tabs-container-vertical {\n  > li {\n    display: block;\n    float: none;\n    width: auto;\n  }\n}\n\n/// Adds styles for the links within a tab container. Apply this to the `<li>` elements inside a tab container.\n@mixin tabs-title (\n  $padding: $tab-item-padding,\n  $font-size: $tab-item-font-size,\n  $color: $tab-color,\n  $color-active: $tab-active-color,\n  $background-hover: $tab-item-background-hover,\n  $background-active: $tab-background-active\n) {\n  float: #{$global-left};\n\n  > a {\n    @include disable-mouse-outline;\n    display: block;\n    padding: $padding;\n    font-size: $font-size;\n    line-height: 1;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n      color: scale-color($color, $lightness: -14%);\n    }\n\n    &:focus,\n    &[aria-selected='true'] {\n      background: $background-active;\n      color: $color-active;\n    }\n  }\n}\n\n/// Adds styles for the wrapper that surrounds a tab group's content panes.\n@mixin tabs-content (\n  $background: $tab-content-background,\n  $color: $tab-content-color,\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-top: 0;\n  background: $background;\n  color: $color;\n  transition: all 0.5s ease;\n}\n\n/// Augments a tab content container to have a vertical style, by shifting the border around. Use this in conjunction with `tabs-content()`.\n@mixin tabs-content-vertical (\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-#{$global-left}: 0;\n}\n\n/// Adds styles for an individual tab content panel within the tab content container.\n@mixin tabs-panel (\n  $padding: $tab-content-padding\n) {\n  display: none;\n  padding: $padding;\n\n  &.is-active {\n    display: block;\n  }\n}\n\n@mixin foundation-tabs {\n  .tabs {\n    @include tabs-container;\n  }\n\n  // Vertical\n  .tabs.vertical {\n    @include tabs-container-vertical;\n  }\n\n  // Simple\n  .tabs.simple {\n    > li > a {\n      padding: 0;\n\n      &:hover {\n        background: transparent;\n      }\n    }\n  }\n\n  // Primary color\n  .tabs.primary {\n    background: $primary-color;\n\n    > li > a {\n      color: color-pick-contrast($primary-color);\n\n      &:hover,\n      &:focus {\n        background: smart-scale($primary-color);\n      }\n    }\n  }\n\n  .tabs-title {\n    @include tabs-title;\n  }\n\n  .tabs-content {\n    @include tabs-content;\n  }\n\n  .tabs-content.vertical {\n    @include tabs-content-vertical;\n  }\n\n  .tabs-panel {\n    @include tabs-panel;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group thumbnail\n////\n\n/// Border around thumbnail images.\n/// @type Border\n$thumbnail-border: 4px solid $white !default;\n\n/// Bottom margin for thumbnail images.\n/// @type Length\n$thumbnail-margin-bottom: $global-margin !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow: 0 0 0 1px rgba($black, 0.2) !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow-hover: 0 0 6px 1px rgba($primary-color, 0.5) !default;\n\n/// Transition proprties for thumbnail images.\n/// @type Transition\n$thumbnail-transition: box-shadow 200ms ease-out !default;\n\n/// Default radius for thumbnail images.\n/// @type Number\n$thumbnail-radius: $global-radius !default;\n\n/// Adds thumbnail styles to an element.\n@mixin thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: $thumbnail-margin-bottom;\n\n  border: $thumbnail-border;\n  border-radius: $thumbnail-radius;\n  box-shadow: $thumbnail-shadow;\n\n  line-height: 0;\n}\n\n@mixin thumbnail-link {\n  transition: $thumbnail-transition;\n\n  &:hover,\n  &:focus {\n    box-shadow: $thumbnail-shadow-hover;\n  }\n\n  image {\n    box-shadow: none;\n  }\n}\n\n@mixin foundation-thumbnail {\n  .thumbnail {\n    @include thumbnail;\n  }\n\n  a.thumbnail {\n    @include thumbnail-link;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group menu\n////\n\n/// Margin of a menu.\n/// @type Number\n$menu-margin: 0 !default;\n\n/// Left-hand margin of a nested menu.\n/// @type Number\n$menu-nested-margin: $global-menu-nested-margin !default;\n\n/// Padding for items in a pill menu.\n/// @type Number\n$menu-items-padding: $global-menu-padding !default;\n\n/// margin for items in a simple menu.\n/// @type Number\n$menu-simple-margin: 1rem !default;\n\n/// Text color of an active menu item.\n/// @type Color\n$menu-item-color-active: $white !default;\n\n/// Background color of an active menu item.\n/// @type Color\n$menu-item-background-active: get-color(primary) !default;\n\n/// Spacing between an icon and text in a menu item.\n/// @type Number\n$menu-icon-spacing: 0.25rem !default;\n\n/// Backward compatibility for menu state. If true, this duplicate `active` with `is-active`. \n/// But please note that `active` will be removed in upcoming versions.\n/// @type Boolean\n$menu-state-back-compat: true !default;\n\n/// Backward compatibility for menu centered. If true, this duplicate `.menu-centered > .menu` with `.menu.align-center`. \n/// But please note that `menu-centered` will be removed in upcoming versions.\n/// @type Boolean\n$menu-centered-back-compat: true !default;\n\n/// Backward compatibility for using `icon-*` classes without `.icons` classes\n/// But please note that this backward compatibility will be removed in upcoming versions.\n/// @type Boolean\n$menu-icons-back-compat: true !default;\n\n/// Creates the base styles for a Menu.\n@mixin menu-base {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: wrap;\n  }\n\n  li {\n    @include disable-mouse-outline;\n  }\n\n  a,\n  .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: $menu-items-padding;\n  }\n\n  // Reset styles of inner elements\n  input,\n  select,\n  a,\n  button {\n    margin-bottom: 0;\n  }\n\n  input {\n    display: inline-block;\n  }\n}\n\n/// Expands the items of a Menu, so each item is the same width.\n@mixin menu-expand {\n  @if $global-flexbox {\n    li {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    display: table;\n    width: 100%;\n\n    > li {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n}\n\n/// Align menu items.\n@mixin menu-align($alignment) {\n  @if $alignment == left {\n    @if $global-flexbox {\n      justify-content: flex-start;\n    }\n    @else {\n      text-align: $global-left;\n    }\n  }\n  @else if $alignment == right {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: flex-end;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n\n      &.vertical li {\n        display: block;\n        text-align: $global-right;\n\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n    @else {\n      text-align: $global-right;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n\n      &.vertical {\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n  }\n  @else if $alignment == center {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: center;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n    }\n    @else {\n      text-align: center;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n    }\n  }\n}\n\n/// Sets the direction of a Menu.\n/// @param {Keyword} $dir [horizontal] - Direction of the Menu. Can be `horizontal` or `vertical`.\n@mixin menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    @if $global-flexbox {\n      flex-wrap: wrap;\n      flex-direction: row;\n    }\n    @else {\n      li {\n        display: inline-block;\n      }\n    }\n  }\n  @else if $dir == vertical {\n    @if $global-flexbox {\n      flex-wrap: nowrap;\n      flex-direction: column;\n    }\n    @else {\n      li {\n        display: block;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for menu-direction() must be horizontal or vertical.';\n  }\n}\n\n/// Creates a simple Menu, which has no padding or hover state.\n/// @param {Keyword} $dir [$global-left] - Direction of the menu. This effects the side of the `<li>` that receives the margin.\n/// @param {Number} $margin [$menu-simple-margin] - The margin to apply to each `<li>`.\n@mixin menu-simple($dir: $global-left, $margin: $menu-simple-margin) {\n  @if $global-flexbox {\n    align-items: center;\n  }\n\n  li + li {\n    margin-#{$dir}: $margin;\n  }\n\n  a {\n    padding: 0;\n  }\n}\n\n/// Adds styles for a nested Menu, by adding `margin-left` to the menu.\n/// @param {Keyword|Number} $margin [$menu-nested-margin] - Length of the margin.\n/// @param {Keyword} $nested-alignment [left] - Alignment of the nested class\n@mixin menu-nested(\n  $margin: $menu-nested-margin,\n  $nested-alignment: left\n) {\n  @if $nested-alignment == right {\n    margin-#{$global-right}: $margin;\n    margin-#{$global-left}: 0;\n  }\n  @else {\n    margin-#{$global-right}: 0;\n    margin-#{$global-left}: $margin;\n  }\n\n}\n\n/// Adds basic styles for icons in menus.\n@mixin menu-icons() {\n  @if $global-flexbox {\n    a {\n      display: flex;\n    }\n  }\n  @else {\n    img,\n    i,\n    svg {\n      vertical-align: middle;\n\n      + span {\n        vertical-align: middle;\n      }\n    }\n  }\n}\n\n/// Adds position classes for icons within a menu.\n@mixin menu-icon-position($position: left, $spacing: $menu-icon-spacing) {\n  @if $position == left {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-right}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-left}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: 0 auto $spacing;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: $spacing auto 0;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n}\n\n@mixin menu-text {\n  padding: $global-menu-padding;\n\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n@mixin menu-state-active {\n  background: $menu-item-background-active;\n  color: $menu-item-color-active;\n}\n\n@mixin foundation-menu {\n  .menu {\n    @include menu-base;\n\n    // Default orientation: horizontal\n    &, &.horizontal {\n      @include menu-direction(horizontal);\n    }\n\n    // Vertical orientation modifier\n    &.vertical {\n      @include menu-direction(vertical);\n    }\n\n    // Even-width modifier for horizontal orientation\n    &.expanded {\n      @include menu-expand;\n    }\n\n    // Simple\n    &.simple {\n      @include menu-simple;\n    }\n\n    // Breakpoint specific versions\n    @include -zf-each-breakpoint($small: false) {\n      &.#{$-zf-size}-horizontal {\n        @include menu-direction(horizontal);\n      }\n\n      &.#{$-zf-size}-vertical {\n        @include menu-direction(vertical);\n      }\n\n      &.#{$-zf-size}-expanded {\n        @include menu-expand;\n      }\n\n      &.#{$-zf-size}-simple {\n        @include menu-expand;\n      }\n    }\n\n    // Nesting\n    &.nested {\n      @include menu-nested;\n    }\n\n    // Icon Base Styles\n    &.icons {\n      @include menu-icons;\n    }\n\n    // Backward Compatibility for active state\n    @if $menu-icons-back-compat {\n      &.icon-top,\n      &.icon-right,\n      &.icon-bottom,\n      &.icon-left {\n        @include menu-icons;\n      }\n    }\n\n    // Icon Left\n    &.icon-left {\n      @include menu-icon-position(left);\n    }\n\n    // Icon Right\n    &.icon-right {\n      @include menu-icon-position(right);\n    }\n\n    // Icon Top\n    &.icon-top {\n      @include menu-icon-position(top);\n    }\n\n    // Icon Bottom\n    &.icon-bottom {\n      @include menu-icon-position(bottom);\n    }\n\n    // Active state\n    .is-active > a {\n      @include menu-state-active;\n    }\n    \n    // Backward Compatibility for active state\n    @if $menu-state-back-compat {\n      .active > a {\n        @include menu-state-active;\n      }\n    }\n\n    // Align left\n    &.align-#{$global-left} {\n      @include menu-align(left);\n    }\n\n    // Align right\n    &.align-#{$global-right} {\n      @include menu-align(right);\n\n      .nested {\n        @include menu-nested($nested-alignment: right);\n      }\n    }\n\n    // Align center\n    &.align-center {\n      @include menu-align(center);\n    }\n\n    .menu-text {\n      @include menu-text;\n    }\n  }\n\n  @if $menu-centered-back-compat {\n    .menu-centered {\n      > .menu {\n        @if $global-flexbox {\n          justify-content: center;\n        }\n        \n        @include menu-align(center);\n      }\n    }\n  }\n\n  // Prevent FOUC when using the Responsive Menu plugin\n  .no-js [data-responsive-menu] ul {\n    display: none;\n  }\n}\n","@mixin foundation-menu-icon {\n  .menu-icon {\n    @include hamburger($color: $titlebar-icon-color, $color-hover: $titlebar-icon-color-hover);\n  }\n\n  .menu-icon.dark {\n    @include hamburger;\n  }\n}\n","////\n/// @group accordion-menu\n////\n\n/// Sets accordion menu padding.\n/// @type Number\n$accordionmenu-padding: $global-menu-padding !default;\n\n/// Sets accordion menu nested margin\n/// @type Number\n$accordionmenu-nested-margin: $global-menu-nested-margin !default;\n\n/// Sets accordion menu submenu padding.\n/// @type Number\n$accordionmenu-submenu-padding: $accordionmenu-padding !default;\n\n/// Sets if accordion menus have the default arrow styles.\n/// @type Boolean\n$accordionmenu-arrows: true !default;\n\n/// Sets accordion menu arrow color if arrow is used.\n/// @type Color\n$accordionmenu-arrow-color: $primary-color !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-item-background: null !default;\n\n/// Sets accordion menu item border.\n/// @type Color\n$accordionmenu-border: null !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-submenu-toggle-background: null !default;\n\n/// Sets accordion menu item padding.\n/// @type List\n$accordion-submenu-toggle-border: $accordionmenu-border !default;\n\n/// Sets accordion menu submenu toggle background width.\n/// @type Number\n$accordionmenu-submenu-toggle-width: 40px !default;\n\n/// Sets accordion menu submenu toggle background height.\n/// @type Number\n$accordionmenu-submenu-toggle-height: $accordionmenu-submenu-toggle-width !default;\n\n/// Sets accordion menu arrow size if arrow is used.\n/// @type Length\n$accordionmenu-arrow-size: 6px !default;\n\n@mixin zf-accordion-menu-left-right-arrows {\n  .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($accordionmenu-arrow-size, $accordionmenu-arrow-color, down);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * ($accordionmenu-arrow-size / 2);\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-accordion-submenu-parent > a::after {\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-accordion-submenu-parent > a::after {\n    right: auto;\n    left: 1rem;\n  }\n}\n@mixin foundation-accordion-menu {\n\n  .accordion-menu {\n    @if $accordionmenu-border {\n      border-bottom: $accordionmenu-border;\n    }\n\n    li {\n      @if $accordionmenu-border {\n        border-top: $accordionmenu-border;\n        border-right: $accordionmenu-border;\n        border-left: $accordionmenu-border;\n      }\n      width: 100%;\n    }\n\n    a {\n      @if $accordionmenu-item-background {\n        background: $accordionmenu-item-background;\n      }\n      padding: $accordionmenu-padding;\n    }\n\n    .is-accordion-submenu a {\n      padding: $accordionmenu-submenu-padding;\n    }\n\n    .nested.is-accordion-submenu {\n      @include menu-nested($accordionmenu-nested-margin);\n    }\n\n    &.align-#{$global-right} {\n      .nested.is-accordion-submenu {\n        @include menu-nested($accordionmenu-nested-margin, right);\n      }\n    }\n\n    @if $accordionmenu-arrows {\n      @include zf-accordion-menu-left-right-arrows;\n\n      .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n        transform: rotate(180deg);\n        transform-origin: 50% 50%;\n      }\n    }\n  }\n\n  .is-accordion-submenu li {\n    @if $accordionmenu-border {\n      border-right: 0;\n      border-left: 0;\n    }\n  }\n\n  .is-accordion-submenu-parent {\n    position: relative;\n  }\n\n  .has-submenu-toggle > a {\n    margin-#{$global-right}: $accordionmenu-submenu-toggle-width;\n  }\n\n  // Submenu toggle\n  .submenu-toggle {\n    position: absolute;\n    top: 0;\n    #{$global-right}: 0;\n\n    width: $accordionmenu-submenu-toggle-width;\n    height: $accordionmenu-submenu-toggle-height;\n\n    cursor: pointer;\n\n    border-#{$global-left}: $accordion-submenu-toggle-border;\n\n    @if $accordionmenu-submenu-toggle-background {\n      background: $accordionmenu-submenu-toggle-background;\n    }\n\n    // Add the arrow to the toggle\n    &::after {\n      @include css-triangle(6px, $accordionmenu-arrow-color, down);\n\n      top: 0;\n      bottom: 0;\n      margin: auto;\n    }\n  }\n\n  // Rotate the arrow when menu is open\n  .submenu-toggle[aria-expanded='true']::after {\n    transform: scaleY(-1);\n    transform-origin: 50% 50%;\n  }\n\n  .submenu-toggle-text {\n    @include element-invisible;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group drilldown\n////\n\n/// Transition property to use for animating menus.\n/// @type Transition\n$drilldown-transition: transform 0.15s linear !default;\n\n/// Adds arrows to drilldown items with submenus, as well as the back button.\n/// @type Boolean\n$drilldown-arrows: true !default;\n\n/// Sets drilldown menu item padding.\n/// @type Number\n$drilldown-padding: $global-menu-padding !default;\n\n/// Sets drilldown menu nested margin\n/// @type Number\n$drilldown-nested-margin: 0 !default;\n\n/// Background color for drilldown top level items.\n/// @type Color\n$drilldown-background: $white !default;\n\n/// Sets drilldown menu item padding in the submenu.\n/// @type Number\n$drilldown-submenu-padding: $drilldown-padding !default;\n\n/// Background color for drilldown submenus.\n/// @type Color\n$drilldown-submenu-background: $white !default;\n\n/// Sets drilldown arrow color if arrow is used.\n/// @type Color\n$drilldown-arrow-color: $primary-color !default;\n\n/// Sets drilldown arrow size if arrow is used.\n/// @type Length\n$drilldown-arrow-size: 6px !default;\n\n@mixin zf-drilldown-left-right-arrows {\n  .is-drilldown-submenu-parent > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-right);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * $drilldown-arrow-size;\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 1rem;\n  }\n\n}\n\n@mixin foundation-drilldown-menu {\n  // Applied to the Menu container\n  .is-drilldown {\n    position: relative;\n    overflow: hidden;\n\n    li {\n      display: block;\n    }\n\n    &.animate-height {\n      transition: height 0.5s;\n    }\n  }\n\n  // The top level <ul>\n  .drilldown {\n    a {\n      padding: $drilldown-padding;\n      background: $drilldown-background;\n    }\n\n    // Applied to submenu <ul>s\n    .is-drilldown-submenu {\n      position: absolute;\n      top: 0;\n      #{$global-left}: 100%;\n      z-index: -1;\n\n      width: 100%;\n      background: $drilldown-submenu-background;\n      transition: $drilldown-transition;\n\n      &.is-active {\n        z-index: 1;\n        display: block;\n        transform: translateX(if($global-text-direction == ltr, -100%, 100%));\n      }\n\n      &.is-closing {\n        transform: translateX(if($global-text-direction == ltr, 100%, -100%));\n      }\n\n      // Submenu item padding\n      a {\n        padding: $drilldown-submenu-padding;\n      }\n    }\n\n    .nested.is-drilldown-submenu {\n      @include menu-nested($drilldown-nested-margin);\n    }\n\n    .drilldown-submenu-cover-previous {\n      min-height: 100%;\n    }\n\n    @if $drilldown-arrows {\n      @include zf-drilldown-left-right-arrows;\n\n      .js-drilldown-back > a::before {\n        @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-left);\n        display: inline-block;\n        vertical-align: middle;\n        margin-#{$global-right}: 0.75rem; // Creates space between the arrow and the text\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown-menu\n////\n\n/// Enables arrows for items with dropdown menus.\n/// @type Boolean\n$dropdownmenu-arrows: true !default;\n\n/// Sets dropdown menu arrow color if arrow is used.\n/// @type Color\n$dropdownmenu-arrow-color: $anchor-color !default;\n\n/// Sets dropdown menu arrow size if arrow is used.\n/// @type Length\n$dropdownmenu-arrow-size: 6px !default;\n\n/// Sets dropdown menu arrow padding for aligning the arrow correctly.\n/// @type Length\n$dropdownmenu-arrow-padding: 1.5rem !default;\n\n/// Minimum width of dropdown sub-menus.\n/// @type Length\n$dropdownmenu-min-width: 200px !default;\n\n/// Background color for top level items.\n/// @type Color\n$dropdownmenu-background: null !default;\n\n/// Background color for dropdowns.\n/// @type Color\n$dropdownmenu-submenu-background: $white !default;\n\n/// Padding for top level items.\n/// @type Number\n$dropdownmenu-padding: $global-menu-padding !default;\n\n/// Sets dropdown menu nested margin\n/// @type Number\n$dropdownmenu-nested-margin: 0 !default;\n\n/// Padding for sub-menu items.\n/// @type Number\n$dropdownmenu-submenu-padding: $dropdownmenu-padding !default;\n\n/// Border for dropdown sub-menus.\n/// @type List\n$dropdownmenu-border: 1px solid $medium-gray !default;\n\n// Border width for dropdown sub-menus.\n// Used to adjust top margin of a sub-menu if a border is used.\n// @type Length\n$dropdownmenu-border-width: nth($dropdownmenu-border, 1);\n\n/// Text color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-color-active: get-color(primary) !default;\n\n/// Background color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-background-active: transparent !default;\n\n@mixin zf-dropdown-left-right-arrows {\n  > a::after {\n    #{$global-right}: 14px;\n  }\n\n  &.opens-left > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 5px;\n  }\n\n  &.opens-right > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n  }\n}\n\n@mixin dropdown-menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    > li.opens-left { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n\n    > li.opens-right { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: auto;\n        left: 0;\n      }\n    }\n\n    @if $dropdownmenu-arrows {\n      > li.is-dropdown-submenu-parent > a { // sass-lint:disable-line no-qualifying-elements\n        position: relative;\n        padding-#{$global-right}: $dropdownmenu-arrow-padding;\n      }\n\n      > li.is-dropdown-submenu-parent > a::after { // sass-lint:disable-line no-qualifying-elements\n        @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, down);\n        #{$global-right}: 5px;\n        #{$global-left}: auto;\n        margin-top: -1 * ($dropdownmenu-arrow-size / 2);\n      }\n    }\n  }\n  @else if $dir == vertical {\n    > li {\n      .is-dropdown-submenu {\n        top: 0;\n      }\n\n      &.opens-left {\n        > .is-dropdown-submenu {\n          top: 0;\n          right: 100%;\n          left: auto;\n        }\n      }\n\n      &.opens-right {\n        > .is-dropdown-submenu {\n          right: auto;\n          left: 100%;\n        }\n      }\n\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for dropdown-menu-direction() must be horizontal or vertical.';\n  }\n}\n\n@mixin foundation-dropdown-menu {\n  .dropdown.menu {\n    @include dropdown-menu-direction(horizontal);\n\n    a {\n      @include disable-mouse-outline;\n    }\n\n    // Top-level item\n    > li > a {\n      background: $dropdownmenu-background;\n      padding: $dropdownmenu-padding;\n    }\n\n    // Top-level item active state\n    > li.is-active > a {\n      background: $dropdown-menu-item-background-active;\n      color: $dropdown-menu-item-color-active;\n    }\n\n    .no-js & ul {\n      display: none;\n    }\n\n    .nested.is-dropdown-submenu {\n      @include menu-nested($dropdownmenu-nested-margin);\n    }\n\n    &.vertical {\n      @include dropdown-menu-direction(vertical);\n    }\n\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        @include breakpoint($size) {\n          &.#{$size}-horizontal {\n            @include dropdown-menu-direction(horizontal);\n          }\n\n          &.#{$size}-vertical {\n            @include dropdown-menu-direction(vertical);\n          }\n        }\n      }\n    }\n\n    &.align-right {\n      .is-dropdown-submenu.first-sub {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n  }\n\n  .is-dropdown-menu.vertical {\n    width: 100px;\n\n    &.align-right {\n      float: right;\n    }\n  }\n\n  .is-dropdown-submenu-parent {\n    position: relative;\n\n    a::after {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 5px;\n      #{$global-left}: auto;\n      margin-top: -1 * $dropdownmenu-arrow-size;\n    }\n\n    &.opens-inner > .is-dropdown-submenu {\n\n      top: 100%;\n      @if $global-text-direction == 'rtl' {\n        right: auto;\n      }\n      @else {\n        left: auto;\n      }\n    }\n\n    &.opens-left > .is-dropdown-submenu {\n      right: 100%;\n      left: auto;\n    }\n\n    &.opens-right > .is-dropdown-submenu {\n      right: auto;\n      left: 100%;\n    }\n  }\n\n  .is-dropdown-submenu {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 100%;\n    z-index: 1;\n\n    display: none;\n    min-width: $dropdownmenu-min-width;\n\n    border: $dropdownmenu-border;\n    background: $dropdownmenu-submenu-background;\n\n    .dropdown & a {\n      padding: $dropdownmenu-submenu-padding;\n    }\n\n    .is-dropdown-submenu-parent {\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n\n    @if (type-of($dropdownmenu-border-width) == 'number') {\n      .is-dropdown-submenu {\n        margin-top: (-$dropdownmenu-border-width);\n      }\n    }\n\n    > li {\n      width: 100%;\n    }\n\n    // [TODO] Cut back specificity\n    //&:not(.js-dropdown-nohover) > .is-dropdown-submenu-parent:hover > &, // why is this line needed? Opening is handled by JS and this causes some ugly flickering when the sub is re-positioned automatically...\n    &.js-dropdown-active {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group off-canvas\n////\n\n/// Width map of a left/right off-canvas panel.\n/// @type Map\n$offcanvas-sizes: (\n  small: 250px,\n) !default;\n\n/// Height map of a top/bottom off-canvas panel.\n/// @type Map\n$offcanvas-vertical-sizes: (\n  small: 250px,\n) !default;\n\n/// Background color of an off-canvas panel.\n/// @type Color\n$offcanvas-background: $light-gray !default;\n\n/// Box shadow for the off-canvas overlap panel.\n/// @type Shadow\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7) !default;\n\n/// Inner box shadow size for the off-canvas push panel.\n/// @type Number\n$offcanvas-inner-shadow-size: 20px !default;\n\n/// Inner box shadow color for the off-canvas push panel.\n/// @type Color\n$offcanvas-inner-shadow-color: rgba($black, 0.25) !default;\n\n/// Z-index of an off-canvas content overlay.\n/// @type Number\n$offcanvas-overlay-zindex: 11 !default;\n\n/// Z-index of an off-canvas panel with the `push` transition.\n/// @type Number\n$offcanvas-push-zindex: 12 !default;\n\n/// Z-index of an off-canvas panel with the `overlap` transition.\n/// @type Number\n$offcanvas-overlap-zindex: 13 !default;\n\n/// Z-index of an off-canvas panel using the `reveal-for-*` classes or mixin.\n/// @type Number\n$offcanvas-reveal-zindex: 12 !default;\n\n/// Length of the animation on an off-canvas panel.\n/// @type Number\n$offcanvas-transition-length: 0.5s !default;\n\n/// Timing function of the animation on an off-canvas panel.\n/// @type Keyword\n$offcanvas-transition-timing: ease !default;\n\n/// If `true`, a revealed off-canvas will be fixed-position, and scroll with the screen.\n/// @type Bool\n$offcanvas-fixed-reveal: true !default;\n\n/// Background color for the overlay that appears when an off-canvas panel is open.\n/// @type Color\n$offcanvas-exit-background: rgba($white, 0.25) !default;\n\n/// CSS class used for the main content area. The off-canvas mixins use this to target the page content.\n$maincontent-class: 'off-canvas-content' !default;\n\n/// Adds baseline styles for off-canvas. This CSS is required to make the other pieces work.\n@mixin off-canvas-basics {\n\n  /// Transform deprecated size settings into map & show warning\n  @if variable-exists(offcanvas-size) {\n    $offcanvas-sizes: (small: $offcanvas-size, medium: $offcanvas-size) !global;\n    @warn '$offcanvas-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-sizes instead';\n  }\n  @if variable-exists(offcanvas-vertical-size) {\n    $offcanvas-vertical-sizes: (small: $offcanvas-vertical-size, medium: $offcanvas-vertical-size) !global;\n    @warn '$offcanvas-vertical-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-vertical-sizes instead';\n  }\n\n  // Checks the z-indexes and increase them due to backwards compatibility.\n  // This is necessary because the overlay's z-index is new since v6.4 and may be identical to the user custom settings of the push z-index.\n  @if $offcanvas-push-zindex <= $offcanvas-overlay-zindex { $offcanvas-push-zindex: $offcanvas-overlay-zindex + 1 !global; }\n  @if $offcanvas-overlap-zindex <= $offcanvas-push-zindex { $offcanvas-overlap-zindex: $offcanvas-push-zindex + 1 !global; }\n  @if $offcanvas-reveal-zindex <= $offcanvas-overlay-zindex { $offcanvas-reveal-zindex: $offcanvas-overlay-zindex + 1 !global; }\n\n  // Hides overflow on body when an off-canvas panel is open.\n  .is-off-canvas-open {\n    overflow: hidden;\n  }\n\n  // Off-canvas overlay (generated by JavaScript)\n  .js-off-canvas-overlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    z-index: $offcanvas-overlay-zindex;\n\n    width: 100%;\n    height: 100%;\n\n    transition: opacity $offcanvas-transition-length $offcanvas-transition-timing, visibility $offcanvas-transition-length $offcanvas-transition-timing;\n\n    background: $offcanvas-exit-background;\n\n    opacity: 0;\n    visibility: hidden;\n\n    overflow: hidden;\n\n    &.is-visible {\n      opacity: 1;\n      visibility: visible;\n    }\n\n    &.is-closable {\n      cursor: pointer;\n    }\n\n    &.is-overlay-absolute {\n      position: absolute;\n    }\n\n    &.is-overlay-fixed {\n      position: fixed;\n    }\n  }\n}\n\n// Adds basic styles for an off-canvas wrapper.\n@mixin off-canvas-wrapper() {\n  position: relative;\n  overflow: hidden;\n}\n\n/// Adds basic styles for an off-canvas panel.\n@mixin off-canvas-base(\n  $background: $offcanvas-background,\n  $transition: $offcanvas-transition-length $offcanvas-transition-timing,\n  $fixed: true\n) {\n  @include disable-mouse-outline;\n\n  @if $fixed == true {\n    position: fixed;\n  }\n  @else {\n    position: absolute;\n  }\n\n  // Set the off-canvas z-index.\n  z-index: $offcanvas-push-zindex;\n\n  // Increase CSS specificity\n  &.is-transition-push {\n    z-index: $offcanvas-push-zindex;\n  }\n\n  transition: transform $transition;\n  backface-visibility: hidden;\n\n  background: $background;\n\n  // Hide inactive off-canvas within the content that have the same position\n  &.is-closed {\n    visibility: hidden;\n  }\n\n  // Overlap only styles.\n  &.is-transition-overlap {\n    z-index: $offcanvas-overlap-zindex;\n\n    &.is-open {\n      box-shadow: $offcanvas-shadow;\n    }\n  }\n\n  // Sets transform to 0 to show an off-canvas panel.\n  &.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles to position an off-canvas panel to the left/right/top/bottom.\n@mixin off-canvas-position(\n  $position: left,\n  $orientation: horizontal,\n  $sizes: if($orientation == horizontal, $offcanvas-sizes, $offcanvas-vertical-sizes)\n) {\n  @if $position == left {\n    top: 0;\n    left: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    top: 0;\n    right: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX(-$size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    top: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY(-$size);\n          }\n        }\n      }\n    }\n  }\n\n  // If $offcanvas-inner-shadow-size is set, add inner box-shadow.\n  // This mimics the off-canvas panel having a lower z-index, without having to have one.\n  @if $offcanvas-inner-shadow-size {\n    &.is-transition-push {\n      @if $position == left {\n        @include inner-side-shadow(right, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == right {\n        @include inner-side-shadow(left, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == top {\n        @include inner-side-shadow(bottom, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == bottom {\n        @include inner-side-shadow(top, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n    }\n  }\n\n}\n\n/// Sets the styles for the content container.\n@mixin off-canvas-content() {\n  transform: none;\n  transition: transform $offcanvas-transition-length $offcanvas-transition-timing;\n  backface-visibility: hidden;\n\n  // Transform scope until the element is closed (makes sure transitionend gets triggered)\n  &.has-transition-push {\n    transform: translate(0, 0);\n  }\n\n  // Consider element & content, nested in another content\n  .off-canvas.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles that reveal an off-canvas panel.\n@mixin off-canvas-reveal(\n$position: left,\n$zindex: $offcanvas-reveal-zindex,\n$content: $maincontent-class,\n$breakpoint: small\n) {\n  transform: none;\n  z-index: $zindex;\n  transition: none;\n  visibility: visible;\n\n  @if not $offcanvas-fixed-reveal {\n    position: absolute;\n  }\n\n  .close-button {\n    display: none;\n  }\n\n  // Consider revealed element is nested in content\n  .#{$maincontent-class} & {\n    transform: none;\n  }\n\n  @at-root .#{$content}.has-reveal-#{$position} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n\n  // backwards compatibility (prior to v6.4)\n  & ~ .#{$content} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n}\n\n/// Overrides the off-canvas styles\n@mixin in-canvas() {\n  visibility: visible;\n  height: auto;\n  position: static;\n  background: none;\n  width: auto;\n  overflow: visible;\n  transition: none;\n\n  // Increase CSS specificity\n  &.position-left,\n  &.position-right,\n  &.position-top,\n  &.position-bottom {\n    box-shadow: none;\n    transform: none;\n  }\n\n  .close-button {\n    display: none;\n  }\n}\n\n@mixin foundation-off-canvas {\n  @include off-canvas-basics;\n\n  // Off-canvas wrapper\n  .off-canvas-wrapper {\n    @include off-canvas-wrapper;\n  }\n\n  // Off-canvas container\n  .off-canvas {\n    @include off-canvas-base;\n\n    // Force position absolute for nested off-canvas because fixed doesn't work for push transition within the transform scope.\n    @at-root .#{$maincontent-class} & {\n      // NOTE: since overlap transition is currently forced if nested, there's no need to force position absolute until nested push transition is supported.\n      // position: absolute;\n    }\n  }\n\n  // Off-canvas container with absolute position\n  .off-canvas-absolute {\n    @include off-canvas-base($fixed: false);\n  }\n\n  // Off-canvas position classes\n  .position-left    { @include off-canvas-position(left,   horizontal); }\n  .position-right   { @include off-canvas-position(right,  horizontal); }\n  .position-top     { @include off-canvas-position(top,    vertical); }\n  .position-bottom  { @include off-canvas-position(bottom, vertical); }\n\n  .off-canvas-content {\n    @include off-canvas-content;\n  }\n\n  // Reveal off-canvas panel on larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .position-left.reveal-for-#{$name} {\n          @include off-canvas-reveal(left, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-right.reveal-for-#{$name} {\n          @include off-canvas-reveal(right, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-top.reveal-for-#{$name} {\n          @include off-canvas-reveal(top, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-bottom.reveal-for-#{$name} {\n          @include off-canvas-reveal(bottom, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n      }\n    }\n  }\n\n  // Move in-canvas for larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .off-canvas.in-canvas-for-#{$name} {\n          @include in-canvas;\n        }\n      }\n    }\n  }\n}\n\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@mixin foundation-sticky {\n  .sticky-container {\n    position: relative;\n  }\n\n  .sticky {\n    position: relative;\n    z-index: 0;\n    transform: translate3d(0, 0, 0);\n  }\n\n  .sticky.is-stuck {\n    position: fixed;\n    z-index: 5;\n    width: 100%;\n\n    &.is-at-top {\n      top: 0;\n    }\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n\n  .sticky.is-anchored {\n    position: relative;\n    right: auto;\n    left: auto;\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group title-bar\n////\n\n/// Background color of a title bar.\n/// @type Color\n$titlebar-background: $black !default;\n\n/// Color of text inside a title bar.\n/// @type Color\n$titlebar-color: $white !default;\n\n/// Padding inside a title bar.\n/// @type Length\n$titlebar-padding: 0.5rem !default;\n\n/// Font weight of text inside a title bar.\n/// @type Weight\n$titlebar-text-font-weight: bold !default;\n\n/// Color of menu icons inside a title bar.\n/// @type Color\n$titlebar-icon-color: $white !default;\n\n/// Color of menu icons inside a title bar on hover.\n/// @type Color\n$titlebar-icon-color-hover: $medium-gray !default;\n\n/// Spacing between the menu icon and text inside a title bar.\n/// @type Length\n$titlebar-icon-spacing: 0.25rem !default;\n\n@mixin foundation-title-bar {\n  .title-bar {\n    padding: $titlebar-padding;\n    background: $titlebar-background;\n    color: $titlebar-color;\n\n    @if $global-flexbox {\n      display: flex;\n      justify-content: flex-start;\n      align-items: center;\n    }\n    @else {\n      @include clearfix;\n    }\n\n    .menu-icon {\n      margin-#{$global-left}: $titlebar-icon-spacing;\n      margin-#{$global-right}: $titlebar-icon-spacing;\n    }\n  }\n\n  @if $global-flexbox {\n    .title-bar-left,\n    .title-bar-right {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n\n    .title-bar-right {\n      text-align: right;\n    }\n  }\n  @else {\n    .title-bar-left {\n      float: left;\n    }\n\n    .title-bar-right {\n      float: right;\n      text-align: right;\n    }\n  }\n\n  .title-bar-title {\n    display: inline-block;\n    vertical-align: middle;\n    font-weight: $titlebar-text-font-weight;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group top-bar\n////\n\n/// Padding for the top bar.\n/// @type Number\n$topbar-padding: 0.5rem !default;\n\n/// Background color for the top bar. This color also cascades to menus within the top bar.\n/// @type Color\n$topbar-background: $light-gray !default;\n\n/// Background color submenus within the top bar. Usefull if $topbar-background is transparent.\n/// @type Color\n$topbar-submenu-background: $topbar-background !default;\n\n/// Spacing for the top bar title.\n/// @type Number\n$topbar-title-spacing: 0.5rem 1rem 0.5rem 0 !default;\n\n/// Maximum width of `<input>` elements inside the top bar.\n/// @type Number\n$topbar-input-width: 200px !default;\n\n/// Breakpoint at which top bar switches from mobile to desktop view.\n/// @type Breakpoint\n$topbar-unstack-breakpoint: medium !default;\n\n/// Adds styles for a top bar container.\n@mixin top-bar-container {\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    justify-content: space-between;\n    align-items: center;\n  }\n  @else {\n    @include clearfix;\n  }\n\n  padding: $topbar-padding;\n\n  &,\n  ul {\n    background-color: $topbar-background;\n  }\n\n  // Check if $topbar-background is differnt from $topbar-background-submenu\n  @if ($topbar-background != $topbar-submenu-background) {\n    ul ul {\n      background-color: $topbar-submenu-background;\n    }\n  }\n\n  // Restrain width of inputs by default to make them easier to arrange\n  input {\n    max-width: $topbar-input-width;\n    margin-#{$global-right}: 1rem;\n  }\n\n  // The above styles shouldn't apply to input group fields\n  .input-group-field {\n    width: 100%;\n    margin-#{$global-right}: 0;\n  }\n\n  input.button { // sass-lint:disable-line no-qualifying-elements\n    width: auto;\n  }\n}\n\n/// Makes sections of a top bar stack on top of each other.\n@mixin top-bar-stacked {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 100%;\n      max-width: 100%;\n    }\n  }\n  @else {\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      width: 100%;\n    }\n  }\n}\n\n/// Undoes the CSS applied by the `top-bar-stacked()` mixin.\n@mixin top-bar-unstack {\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n\n    .top-bar-left {\n      flex: 1 1 auto;\n      margin-right: auto;\n    }\n\n    .top-bar-right {\n      flex: 0 1 auto;\n      margin-left: auto;\n    }\n  }\n  @else {\n    .top-bar-left,\n    .top-bar-right {\n      width: auto;\n    }\n  }\n}\n\n@mixin foundation-top-bar {\n  // Top bar container\n  .top-bar {\n    @include top-bar-container;\n\n    // Stack on small screens by default\n    @include top-bar-stacked;\n\n    @include breakpoint($topbar-unstack-breakpoint) {\n      @include top-bar-unstack;\n    }\n\n    // Generate classes for stacking on each screen size (defined in $breakpoint-classes)\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        &.stacked-for-#{$size} {\n          @include breakpoint($size down) {\n            @include top-bar-stacked;\n          }\n        }\n      }\n    }\n  }\n\n  // Sub-sections\n  @if $global-flexbox {\n    .top-bar-title {\n      flex: 0 0 auto;\n      margin: $topbar-title-spacing;\n    }\n\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 auto;\n    }\n  }\n  @else {\n    .top-bar-title {\n      display: inline-block;\n      float: left;\n      padding: $topbar-title-spacing;\n\n      .menu-icon {\n        bottom: 2px;\n      }\n    }\n\n    .top-bar-left {\n      float: left;\n    }\n\n    .top-bar-right {\n      float: right;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group float\n////\n\n@mixin foundation-float-classes {\n  .float-left {\n    float: left !important;\n  }\n\n  .float-right {\n    float: right !important;\n  }\n\n  .float-center {\n    display: block;\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  .clearfix {\n    @include clearfix;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group Flexbox Utilities\n////\n//\n/// Default value for the count of source ordering`\n/// @type Number\n$flex-source-ordering-count: 6 !default;\n\n/// Quickly disable/enable Responsive breakpoints for Vanilla Flex Helpers.\n/// @type Boolean\n$flexbox-responsive-breakpoints: true !default;\n\n@mixin flex-helpers {\n  .flex-container {\n    @include flex;\n  }\n\n  .flex-child-auto {\n    flex: 1 1 auto;\n  }\n\n  .flex-child-grow {\n    flex: 1 0 auto;\n  }\n\n  .flex-child-shrink {\n    flex: 0 1 auto;\n  }\n\n  @each $dir, $prop in $-zf-flex-direction {\n    .flex-dir-#{$dir} {\n      @include flex-direction($prop);\n    }\n  }\n\n  @if ($flexbox-responsive-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-flex-container {\n            @include flex;\n          }\n\n          .#{$size}-flex-child-auto {\n            flex: 1 1 auto;\n          }\n\n          .#{$size}-flex-child-grow {\n            flex: 1 0 auto;\n          }\n\n          .#{$size}-flex-child-shrink {\n            flex: 0 1 auto;\n          }\n\n          @each $dir, $prop in $-zf-flex-direction {\n            .#{$size}-flex-dir-#{$dir} {\n              @include flex-direction($prop);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n@mixin foundation-flex-classes {\n  // Horizontal alignment using justify-content\n  @each $hdir, $prop in $-zf-flex-justify {\n    .align-#{$hdir} {\n      @include flex-align($x: $hdir);\n    }\n  }\n  \n  // Horizontal alignment Specifically for Vertical Menu\n  @each $hdir, $prop in map-remove($-zf-flex-justify, 'justify', 'spaced') {\n    .align-#{$hdir} {\n      &.vertical {\n        &.menu > li > a {\n          @include flex-align($x: $hdir);\n        }\n      }\n    }\n  }\n\n  // Vertical alignment using align-items and align-self\n  @each $vdir, $prop in $-zf-flex-align {\n    .align-#{$vdir} {\n      @include flex-align($y: $vdir);\n    }\n\n    .align-self-#{$vdir} {\n      @include flex-align-self($y: $vdir);\n    }\n  }\n\n  // Central alignment of content\n  .align-center-middle {\n    @include flex-align($x: center, $y: middle);\n    align-content: center;\n  }\n\n  // Source ordering\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $flex-source-ordering-count {\n      .#{$-zf-size}-order-#{$i} {\n        @include flex-order($i);\n      }\n    }\n  }\n\n  // Vanilla Flexbox Helpers\n  @include flex-helpers;\n}\n","@function -zf-flex-justify($text-direction){\n  $-zf-flex-justify: (\n    'left': if($text-direction == rtl, flex-end, flex-start),\n    'right': if($text-direction == rtl, flex-start, flex-end),\n    'center': center,\n    'justify': space-between,\n    'spaced': space-around,\n  );\n\n  @return $-zf-flex-justify;\n}\n\n\n$-zf-flex-align: (\n  'top': flex-start,\n  'bottom': flex-end,\n  'middle': center,\n  'stretch': stretch,\n);\n\n$-zf-flex-direction: (\n  'row': row,\n  'row-reverse': row-reverse,\n  'column': column,\n  'column-reverse': column-reverse,\n);\n\n/// Enables flexbox by adding `display: flex` to the element.\n@mixin flex {\n  display: flex;\n}\n\n/// Horizontally or vertically aligns the items within a flex container.\n///\n/// @param {Keyword} $x [null] - Horizontal alignment to use. Can be `left`, `right`, `center`, `justify`, or `spaced`. Or, set it to `null` (the default) to not set horizontal alignment.\n/// @param {Keyword} $y [null] - Vertical alignment to use. Can be `top`, `bottom`, `middle`, or `stretch`. Or, set it to `null` (the default) to not set vertical alignment.\n@mixin flex-align($x: null, $y: null) {\n  @if $x {\n    @if map-has-key($-zf-flex-justify, $x) {\n      $x: map-get($-zf-flex-justify, $x);\n    }\n    @else {\n      @warn 'flex-grid-row-align(): #{$x} is not a valid value for horizontal alignment. Use left, right, center, justify, or spaced.';\n    }\n  }\n\n  @if $y {\n    @if map-has-key($-zf-flex-align, $y) {\n      $y: map-get($-zf-flex-align, $y);\n    }\n    @else {\n      @warn 'flex-grid-row-align(): #{$y} is not a valid value for vertical alignment. Use top, bottom, middle, or stretch.';\n    }\n  }\n\n  justify-content: $x;\n  align-items: $y;\n}\n\n/// Vertically align a single column within a flex row. Apply this mixin to a flex column.\n///\n/// @param {Keyword} $y [null] - Vertical alignment to use. Can be `top`, `bottom`, `middle`, or `stretch`. Or, set it to `null` (the default) to not set vertical alignment.\n@mixin flex-align-self($y: null) {\n  @if $y {\n    @if map-has-key($-zf-flex-align, $y) {\n      $y: map-get($-zf-flex-align, $y);\n    }\n    @else {\n      @warn 'flex-grid-column-align(): #{$y} is not a valid value for alignment. Use top, bottom, middle, or stretch.';\n    }\n  }\n\n  align-self: $y;\n}\n\n/// Changes the source order of a flex child. Children with lower numbers appear first in the layout.\n/// @param {Number} $order [0] - Order number to apply.\n@mixin flex-order($order: 0) {\n  order: $order;\n}\n\n/// Change flex-direction\n/// @param {Keyword} $direction [row] - Flex direction to use. Can be\n///   - row (default): same as text direction\n///   - row-reverse: opposite to text direction\n///   - column: same as row but top to bottom\n///   - column-reverse: same as row-reverse top to bottom\n@mixin flex-direction($direction: row) {\n  flex-direction: $direction;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// Hide an element by default, only displaying it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for($size) {\n  $size: map-get($breakpoints, $size);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/zurb/foundation-sites/issues/11313\n  $size: -zf-bp-to-em($size) - .00125;\n\n  @include breakpoint($size down) {\n    display: none !important;\n  }\n}\n\n/// Hide an element by default, only displaying it within a certain breakpoint.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for-only($size) {\n  $lower-bound-size: map-get($breakpoints, $size);\n  $upper-bound-size: -zf-map-next($breakpoints, $size);\n\n  // more often than not this will be correct, just one time round the loop it won't so set in scope here\n  $lower-bound: -zf-bp-to-em($lower-bound-size) - .00125;\n  // test actual lower-bound-size, if 0 set it to 0em\n  @if strip-unit($lower-bound-size) == 0 {\n    $lower-bound: -zf-bp-to-em($lower-bound-size);\n  }\n\n  @if $upper-bound-size == null {\n    @media screen and (max-width: $lower-bound) {\n      display: none !important;\n    }\n  }\n  @else {\n    $upper-bound: -zf-bp-to-em($upper-bound-size);\n\n    @media screen and (max-width: $lower-bound), screen and (min-width: $upper-bound) {\n      display: none !important;\n    }\n  }\n}\n\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for($size) {\n  @include breakpoint($size) {\n    display: none !important;\n  }\n}\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for-only($size) {\n  @include breakpoint($size only) {\n    display: none !important;\n  }\n}\n\n@mixin foundation-visibility-classes {\n  // Basic hiding classes\n  .hide {\n    display: none !important;\n  }\n\n  .invisible {\n    visibility: hidden;\n  }\n\n  // Responsive visibility classes\n  @each $size in $breakpoint-classes {\n    @if $size != $-zf-zero-breakpoint {\n      .hide-for-#{$size} {\n        @include hide-for($size);\n      }\n\n      .show-for-#{$size} {\n        @include show-for($size);\n      }\n    }\n\n    .hide-for-#{$size}-only {\n      @include hide-for-only($size);\n    }\n\n    .show-for-#{$size}-only {\n      @include show-for-only($size);\n    }\n  }\n\n  // Screen reader visibility classes\n  // Need a \"hide-for-sr\" class? Add aria-hidden='true' to the element\n  .show-for-sr,\n  .show-on-focus {\n    @include element-invisible;\n  }\n\n  // Only display the element when it's focused\n  .show-on-focus {\n    &:active,\n    &:focus {\n      @include element-invisible-off;\n    }\n  }\n\n  // Landscape and portrait visibility\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: block !important;\n\n    @include breakpoint(landscape) {\n      display: block !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: none !important;\n    }\n  }\n\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: none !important;\n\n    @include breakpoint(landscape) {\n      display: none !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: block !important;\n    }\n  }\n}\n"]}
\ No newline at end of file
index 7beb808bdc654136c3fc742d2572366c8fdf4957..e72fa23e5d1b0e5f8f677352d9777d052e2ef793 100644 (file)
@@ -1 +1,2 @@
-@charset "UTF-8";@media print,screen and (min-width:40em){.reveal,.reveal.large,.reveal.small,.reveal.tiny{right:auto;left:auto;margin:0 auto}}/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */html{font-family:sans-serif;line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure{display:block}figure{margin:1em 40px}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}main{display:block}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}a:active,a:hover{outline-width:0}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}input{overflow:visible}[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{-webkit-box-sizing:border-box;box-sizing:border-box;display:table;max-width:100%;padding:0;color:inherit;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}details{display:block}summary{display:list-item}menu{display:block}canvas{display:inline-block}template{display:none}[hidden]{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{-webkit-box-sizing:border-box;box-sizing:border-box;font-size:100%}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;padding:0;background:#fefefe;font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle;max-width:100%;height:auto;-ms-interpolation-mode:bicubic}textarea{height:auto;min-height:50px;border-radius:0}select{-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;border-radius:0}.map_canvas embed,.map_canvas img,.map_canvas object,.mqa-display embed,.mqa-display img,.mqa-display object{max-width:none!important}button{padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:0;background:0 0;line-height:1;cursor:auto}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}button,input,optgroup,select,textarea{font-family:inherit}.is-visible{display:block!important}.is-hidden{display:none!important}.grid-container{padding-right:.625rem;padding-left:.625rem;max-width:75rem;margin:0 auto}@media print,screen and (min-width:40em){.grid-container{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.fluid{padding-right:.625rem;padding-left:.625rem;max-width:100%;margin:0 auto}@media print,screen and (min-width:40em){.grid-container.fluid{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.full{padding-right:0;padding-left:0;max-width:100%;margin:0 auto}.grid-x{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row wrap;-ms-flex-flow:row wrap;flex-flow:row wrap}.cell{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;min-height:0;min-width:0;width:100%}.cell.auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.cell.shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.auto{width:auto}.grid-x>.shrink{width:auto}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9,.grid-x>.small-full,.grid-x>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-full,.grid-x>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-full,.grid-x>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-x>.small-1{width:8.33333%}.grid-x>.small-2{width:16.66667%}.grid-x>.small-3{width:25%}.grid-x>.small-4{width:33.33333%}.grid-x>.small-5{width:41.66667%}.grid-x>.small-6{width:50%}.grid-x>.small-7{width:58.33333%}.grid-x>.small-8{width:66.66667%}.grid-x>.small-9{width:75%}.grid-x>.small-10{width:83.33333%}.grid-x>.small-11{width:91.66667%}.grid-x>.small-12{width:100%}@media print,screen and (min-width:40em){.grid-x>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;width:auto}.grid-x>.medium-1{width:8.33333%}.grid-x>.medium-2{width:16.66667%}.grid-x>.medium-3{width:25%}.grid-x>.medium-4{width:33.33333%}.grid-x>.medium-5{width:41.66667%}.grid-x>.medium-6{width:50%}.grid-x>.medium-7{width:58.33333%}.grid-x>.medium-8{width:66.66667%}.grid-x>.medium-9{width:75%}.grid-x>.medium-10{width:83.33333%}.grid-x>.medium-11{width:91.66667%}.grid-x>.medium-12{width:100%}}@media print,screen and (min-width:64em){.grid-x>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;width:auto}.grid-x>.large-1{width:8.33333%}.grid-x>.large-2{width:16.66667%}.grid-x>.large-3{width:25%}.grid-x>.large-4{width:33.33333%}.grid-x>.large-5{width:41.66667%}.grid-x>.large-6{width:50%}.grid-x>.large-7{width:58.33333%}.grid-x>.large-8{width:66.66667%}.grid-x>.large-9{width:75%}.grid-x>.large-10{width:83.33333%}.grid-x>.large-11{width:91.66667%}.grid-x>.large-12{width:100%}}.grid-margin-x:not(.grid-x)>.cell{width:auto}.grid-margin-y:not(.grid-y)>.cell{height:auto}.grid-margin-x{margin-left:-.625rem;margin-right:-.625rem}@media print,screen and (min-width:40em){.grid-margin-x{margin-left:-.9375rem;margin-right:-.9375rem}}.grid-margin-x>.cell{width:calc(100% - 1.25rem);margin-left:.625rem;margin-right:.625rem}@media print,screen and (min-width:40em){.grid-margin-x>.cell{width:calc(100% - 1.875rem);margin-left:.9375rem;margin-right:.9375rem}}.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.25rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.25rem)}.grid-margin-x>.small-3{width:calc(25% - 1.25rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.25rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.25rem)}.grid-margin-x>.small-6{width:calc(50% - 1.25rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.25rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.25rem)}.grid-margin-x>.small-9{width:calc(75% - 1.25rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.25rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.25rem)}.grid-margin-x>.small-12{width:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.small-3{width:calc(25% - 1.875rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.small-6{width:calc(50% - 1.875rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.small-9{width:calc(75% - 1.875rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.small-12{width:calc(100% - 1.875rem)}.grid-margin-x>.medium-auto{width:auto}.grid-margin-x>.medium-shrink{width:auto}.grid-margin-x>.medium-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.medium-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.medium-3{width:calc(25% - 1.875rem)}.grid-margin-x>.medium-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.medium-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.medium-6{width:calc(50% - 1.875rem)}.grid-margin-x>.medium-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.medium-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.medium-9{width:calc(75% - 1.875rem)}.grid-margin-x>.medium-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.medium-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.medium-12{width:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x>.large-auto{width:auto}.grid-margin-x>.large-shrink{width:auto}.grid-margin-x>.large-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.large-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.large-3{width:calc(25% - 1.875rem)}.grid-margin-x>.large-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.large-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.large-6{width:calc(50% - 1.875rem)}.grid-margin-x>.large-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.large-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.large-9{width:calc(75% - 1.875rem)}.grid-margin-x>.large-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.large-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.large-12{width:calc(100% - 1.875rem)}}.grid-padding-x .grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-padding-x .grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-container:not(.full)>.grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-container:not(.full)>.grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-padding-x>.cell{padding-right:.625rem;padding-left:.625rem}@media print,screen and (min-width:40em){.grid-padding-x>.cell{padding-right:.9375rem;padding-left:.9375rem}}.small-up-1>.cell{width:100%}.small-up-2>.cell{width:50%}.small-up-3>.cell{width:33.33333%}.small-up-4>.cell{width:25%}.small-up-5>.cell{width:20%}.small-up-6>.cell{width:16.66667%}.small-up-7>.cell{width:14.28571%}.small-up-8>.cell{width:12.5%}@media print,screen and (min-width:40em){.medium-up-1>.cell{width:100%}.medium-up-2>.cell{width:50%}.medium-up-3>.cell{width:33.33333%}.medium-up-4>.cell{width:25%}.medium-up-5>.cell{width:20%}.medium-up-6>.cell{width:16.66667%}.medium-up-7>.cell{width:14.28571%}.medium-up-8>.cell{width:12.5%}}@media print,screen and (min-width:64em){.large-up-1>.cell{width:100%}.large-up-2>.cell{width:50%}.large-up-3>.cell{width:33.33333%}.large-up-4>.cell{width:25%}.large-up-5>.cell{width:20%}.large-up-6>.cell{width:16.66667%}.large-up-7>.cell{width:14.28571%}.large-up-8>.cell{width:12.5%}}.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}.grid-margin-x.medium-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.medium-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.medium-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.medium-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.medium-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.medium-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.medium-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.medium-up-8>.cell{width:calc(12.5% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x.large-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.large-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.large-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.large-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.large-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.large-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.large-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.large-up-8>.cell{width:calc(12.5% - 1.875rem)}}.small-margin-collapse{margin-right:0;margin-left:0}.small-margin-collapse>.cell{margin-right:0;margin-left:0}.small-margin-collapse>.small-1{width:8.33333%}.small-margin-collapse>.small-2{width:16.66667%}.small-margin-collapse>.small-3{width:25%}.small-margin-collapse>.small-4{width:33.33333%}.small-margin-collapse>.small-5{width:41.66667%}.small-margin-collapse>.small-6{width:50%}.small-margin-collapse>.small-7{width:58.33333%}.small-margin-collapse>.small-8{width:66.66667%}.small-margin-collapse>.small-9{width:75%}.small-margin-collapse>.small-10{width:83.33333%}.small-margin-collapse>.small-11{width:91.66667%}.small-margin-collapse>.small-12{width:100%}@media print,screen and (min-width:40em){.small-margin-collapse>.medium-1{width:8.33333%}.small-margin-collapse>.medium-2{width:16.66667%}.small-margin-collapse>.medium-3{width:25%}.small-margin-collapse>.medium-4{width:33.33333%}.small-margin-collapse>.medium-5{width:41.66667%}.small-margin-collapse>.medium-6{width:50%}.small-margin-collapse>.medium-7{width:58.33333%}.small-margin-collapse>.medium-8{width:66.66667%}.small-margin-collapse>.medium-9{width:75%}.small-margin-collapse>.medium-10{width:83.33333%}.small-margin-collapse>.medium-11{width:91.66667%}.small-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.small-margin-collapse>.large-1{width:8.33333%}.small-margin-collapse>.large-2{width:16.66667%}.small-margin-collapse>.large-3{width:25%}.small-margin-collapse>.large-4{width:33.33333%}.small-margin-collapse>.large-5{width:41.66667%}.small-margin-collapse>.large-6{width:50%}.small-margin-collapse>.large-7{width:58.33333%}.small-margin-collapse>.large-8{width:66.66667%}.small-margin-collapse>.large-9{width:75%}.small-margin-collapse>.large-10{width:83.33333%}.small-margin-collapse>.large-11{width:91.66667%}.small-margin-collapse>.large-12{width:100%}}.small-padding-collapse{margin-right:0;margin-left:0}.small-padding-collapse>.cell{padding-right:0;padding-left:0}@media print,screen and (min-width:40em){.medium-margin-collapse{margin-right:0;margin-left:0}.medium-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:40em){.medium-margin-collapse>.small-1{width:8.33333%}.medium-margin-collapse>.small-2{width:16.66667%}.medium-margin-collapse>.small-3{width:25%}.medium-margin-collapse>.small-4{width:33.33333%}.medium-margin-collapse>.small-5{width:41.66667%}.medium-margin-collapse>.small-6{width:50%}.medium-margin-collapse>.small-7{width:58.33333%}.medium-margin-collapse>.small-8{width:66.66667%}.medium-margin-collapse>.small-9{width:75%}.medium-margin-collapse>.small-10{width:83.33333%}.medium-margin-collapse>.small-11{width:91.66667%}.medium-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:40em){.medium-margin-collapse>.medium-1{width:8.33333%}.medium-margin-collapse>.medium-2{width:16.66667%}.medium-margin-collapse>.medium-3{width:25%}.medium-margin-collapse>.medium-4{width:33.33333%}.medium-margin-collapse>.medium-5{width:41.66667%}.medium-margin-collapse>.medium-6{width:50%}.medium-margin-collapse>.medium-7{width:58.33333%}.medium-margin-collapse>.medium-8{width:66.66667%}.medium-margin-collapse>.medium-9{width:75%}.medium-margin-collapse>.medium-10{width:83.33333%}.medium-margin-collapse>.medium-11{width:91.66667%}.medium-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.medium-margin-collapse>.large-1{width:8.33333%}.medium-margin-collapse>.large-2{width:16.66667%}.medium-margin-collapse>.large-3{width:25%}.medium-margin-collapse>.large-4{width:33.33333%}.medium-margin-collapse>.large-5{width:41.66667%}.medium-margin-collapse>.large-6{width:50%}.medium-margin-collapse>.large-7{width:58.33333%}.medium-margin-collapse>.large-8{width:66.66667%}.medium-margin-collapse>.large-9{width:75%}.medium-margin-collapse>.large-10{width:83.33333%}.medium-margin-collapse>.large-11{width:91.66667%}.medium-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:40em){.medium-padding-collapse{margin-right:0;margin-left:0}.medium-padding-collapse>.cell{padding-right:0;padding-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse{margin-right:0;margin-left:0}.large-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse>.small-1{width:8.33333%}.large-margin-collapse>.small-2{width:16.66667%}.large-margin-collapse>.small-3{width:25%}.large-margin-collapse>.small-4{width:33.33333%}.large-margin-collapse>.small-5{width:41.66667%}.large-margin-collapse>.small-6{width:50%}.large-margin-collapse>.small-7{width:58.33333%}.large-margin-collapse>.small-8{width:66.66667%}.large-margin-collapse>.small-9{width:75%}.large-margin-collapse>.small-10{width:83.33333%}.large-margin-collapse>.small-11{width:91.66667%}.large-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.medium-1{width:8.33333%}.large-margin-collapse>.medium-2{width:16.66667%}.large-margin-collapse>.medium-3{width:25%}.large-margin-collapse>.medium-4{width:33.33333%}.large-margin-collapse>.medium-5{width:41.66667%}.large-margin-collapse>.medium-6{width:50%}.large-margin-collapse>.medium-7{width:58.33333%}.large-margin-collapse>.medium-8{width:66.66667%}.large-margin-collapse>.medium-9{width:75%}.large-margin-collapse>.medium-10{width:83.33333%}.large-margin-collapse>.medium-11{width:91.66667%}.large-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.large-1{width:8.33333%}.large-margin-collapse>.large-2{width:16.66667%}.large-margin-collapse>.large-3{width:25%}.large-margin-collapse>.large-4{width:33.33333%}.large-margin-collapse>.large-5{width:41.66667%}.large-margin-collapse>.large-6{width:50%}.large-margin-collapse>.large-7{width:58.33333%}.large-margin-collapse>.large-8{width:66.66667%}.large-margin-collapse>.large-9{width:75%}.large-margin-collapse>.large-10{width:83.33333%}.large-margin-collapse>.large-11{width:91.66667%}.large-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:64em){.large-padding-collapse{margin-right:0;margin-left:0}.large-padding-collapse>.cell{padding-right:0;padding-left:0}}.small-offset-0{margin-right:0}.grid-margin-x>.small-offset-0{margin-right:calc(0% + .625rem)}.small-offset-1{margin-right:8.33333%}.grid-margin-x>.small-offset-1{margin-right:calc(8.33333% + .625rem)}.small-offset-2{margin-right:16.66667%}.grid-margin-x>.small-offset-2{margin-right:calc(16.66667% + .625rem)}.small-offset-3{margin-right:25%}.grid-margin-x>.small-offset-3{margin-right:calc(25% + .625rem)}.small-offset-4{margin-right:33.33333%}.grid-margin-x>.small-offset-4{margin-right:calc(33.33333% + .625rem)}.small-offset-5{margin-right:41.66667%}.grid-margin-x>.small-offset-5{margin-right:calc(41.66667% + .625rem)}.small-offset-6{margin-right:50%}.grid-margin-x>.small-offset-6{margin-right:calc(50% + .625rem)}.small-offset-7{margin-right:58.33333%}.grid-margin-x>.small-offset-7{margin-right:calc(58.33333% + .625rem)}.small-offset-8{margin-right:66.66667%}.grid-margin-x>.small-offset-8{margin-right:calc(66.66667% + .625rem)}.small-offset-9{margin-right:75%}.grid-margin-x>.small-offset-9{margin-right:calc(75% + .625rem)}.small-offset-10{margin-right:83.33333%}.grid-margin-x>.small-offset-10{margin-right:calc(83.33333% + .625rem)}.small-offset-11{margin-right:91.66667%}.grid-margin-x>.small-offset-11{margin-right:calc(91.66667% + .625rem)}@media print,screen and (min-width:40em){.medium-offset-0{margin-right:0}.grid-margin-x>.medium-offset-0{margin-right:calc(0% + .9375rem)}.medium-offset-1{margin-right:8.33333%}.grid-margin-x>.medium-offset-1{margin-right:calc(8.33333% + .9375rem)}.medium-offset-2{margin-right:16.66667%}.grid-margin-x>.medium-offset-2{margin-right:calc(16.66667% + .9375rem)}.medium-offset-3{margin-right:25%}.grid-margin-x>.medium-offset-3{margin-right:calc(25% + .9375rem)}.medium-offset-4{margin-right:33.33333%}.grid-margin-x>.medium-offset-4{margin-right:calc(33.33333% + .9375rem)}.medium-offset-5{margin-right:41.66667%}.grid-margin-x>.medium-offset-5{margin-right:calc(41.66667% + .9375rem)}.medium-offset-6{margin-right:50%}.grid-margin-x>.medium-offset-6{margin-right:calc(50% + .9375rem)}.medium-offset-7{margin-right:58.33333%}.grid-margin-x>.medium-offset-7{margin-right:calc(58.33333% + .9375rem)}.medium-offset-8{margin-right:66.66667%}.grid-margin-x>.medium-offset-8{margin-right:calc(66.66667% + .9375rem)}.medium-offset-9{margin-right:75%}.grid-margin-x>.medium-offset-9{margin-right:calc(75% + .9375rem)}.medium-offset-10{margin-right:83.33333%}.grid-margin-x>.medium-offset-10{margin-right:calc(83.33333% + .9375rem)}.medium-offset-11{margin-right:91.66667%}.grid-margin-x>.medium-offset-11{margin-right:calc(91.66667% + .9375rem)}}@media print,screen and (min-width:64em){.large-offset-0{margin-right:0}.grid-margin-x>.large-offset-0{margin-right:calc(0% + .9375rem)}.large-offset-1{margin-right:8.33333%}.grid-margin-x>.large-offset-1{margin-right:calc(8.33333% + .9375rem)}.large-offset-2{margin-right:16.66667%}.grid-margin-x>.large-offset-2{margin-right:calc(16.66667% + .9375rem)}.large-offset-3{margin-right:25%}.grid-margin-x>.large-offset-3{margin-right:calc(25% + .9375rem)}.large-offset-4{margin-right:33.33333%}.grid-margin-x>.large-offset-4{margin-right:calc(33.33333% + .9375rem)}.large-offset-5{margin-right:41.66667%}.grid-margin-x>.large-offset-5{margin-right:calc(41.66667% + .9375rem)}.large-offset-6{margin-right:50%}.grid-margin-x>.large-offset-6{margin-right:calc(50% + .9375rem)}.large-offset-7{margin-right:58.33333%}.grid-margin-x>.large-offset-7{margin-right:calc(58.33333% + .9375rem)}.large-offset-8{margin-right:66.66667%}.grid-margin-x>.large-offset-8{margin-right:calc(66.66667% + .9375rem)}.large-offset-9{margin-right:75%}.grid-margin-x>.large-offset-9{margin-right:calc(75% + .9375rem)}.large-offset-10{margin-right:83.33333%}.grid-margin-x>.large-offset-10{margin-right:calc(83.33333% + .9375rem)}.large-offset-11{margin-right:91.66667%}.grid-margin-x>.large-offset-11{margin-right:calc(91.66667% + .9375rem)}}.grid-y{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.grid-y>.cell{width:auto}.grid-y>.auto{height:auto}.grid-y>.shrink{height:auto}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9,.grid-y>.small-full,.grid-y>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-full,.grid-y>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-full,.grid-y>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-y>.small-1{height:8.33333%}.grid-y>.small-2{height:16.66667%}.grid-y>.small-3{height:25%}.grid-y>.small-4{height:33.33333%}.grid-y>.small-5{height:41.66667%}.grid-y>.small-6{height:50%}.grid-y>.small-7{height:58.33333%}.grid-y>.small-8{height:66.66667%}.grid-y>.small-9{height:75%}.grid-y>.small-10{height:83.33333%}.grid-y>.small-11{height:91.66667%}.grid-y>.small-12{height:100%}@media print,screen and (min-width:40em){.grid-y>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.medium-shrink{height:auto}.grid-y>.medium-1{height:8.33333%}.grid-y>.medium-2{height:16.66667%}.grid-y>.medium-3{height:25%}.grid-y>.medium-4{height:33.33333%}.grid-y>.medium-5{height:41.66667%}.grid-y>.medium-6{height:50%}.grid-y>.medium-7{height:58.33333%}.grid-y>.medium-8{height:66.66667%}.grid-y>.medium-9{height:75%}.grid-y>.medium-10{height:83.33333%}.grid-y>.medium-11{height:91.66667%}.grid-y>.medium-12{height:100%}}@media print,screen and (min-width:64em){.grid-y>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.large-shrink{height:auto}.grid-y>.large-1{height:8.33333%}.grid-y>.large-2{height:16.66667%}.grid-y>.large-3{height:25%}.grid-y>.large-4{height:33.33333%}.grid-y>.large-5{height:41.66667%}.grid-y>.large-6{height:50%}.grid-y>.large-7{height:58.33333%}.grid-y>.large-8{height:66.66667%}.grid-y>.large-9{height:75%}.grid-y>.large-10{height:83.33333%}.grid-y>.large-11{height:91.66667%}.grid-y>.large-12{height:100%}}.grid-padding-y .grid-padding-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-padding-y .grid-padding-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-padding-y>.cell{padding-top:.625rem;padding-bottom:.625rem}@media print,screen and (min-width:40em){.grid-padding-y>.cell{padding-top:.9375rem;padding-bottom:.9375rem}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .grid-frame{width:100%}.cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.cell-block-container{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;max-height:100%}.cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}@media print,screen and (min-width:40em){.medium-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .medium-grid-frame{width:100%}.medium-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.medium-cell-block-container{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;max-height:100%}.medium-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.medium-cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}}@media print,screen and (min-width:64em){.large-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .large-grid-frame{width:100%}.large-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.large-cell-block-container{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;max-height:100%}.large-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.large-cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}}.grid-y.grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}@media print,screen and (min-width:40em){.grid-y.medium-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}@media print,screen and (min-width:64em){.grid-y.large-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}.cell .grid-y.grid-frame{height:100%}@media print,screen and (min-width:40em){.cell .grid-y.medium-grid-frame{height:100%}}@media print,screen and (min-width:64em){.cell .grid-y.large-grid-frame{height:100%}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame.grid-margin-y{height:calc(100vh + 1.25rem)}@media print,screen and (min-width:40em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:40em){.grid-margin-y.medium-grid-frame{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y.large-grid-frame{height:calc(100vh + 1.875rem)}}blockquote,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,li,ol,p,pre,td,th,ul{margin:0;padding:0}p{margin-bottom:1rem;font-size:inherit;line-height:1.6;text-rendering:optimizeLegibility}em,i{font-style:italic;line-height:inherit}b,strong{font-weight:700;line-height:inherit}small{font-size:80%;line-height:inherit}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-style:normal;font-weight:400;color:inherit;text-rendering:optimizeLegibility}.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small,h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{line-height:0;color:#cacaca}.h1,h1{font-size:1.5rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h2,h2{font-size:1.25rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h3,h3{font-size:1.1875rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h4,h4{font-size:1.125rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h5,h5{font-size:1.0625rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h6,h6{font-size:1rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}@media print,screen and (min-width:40em){.h1,h1{font-size:3rem}.h2,h2{font-size:2.5rem}.h3,h3{font-size:1.9375rem}.h4,h4{font-size:1.5625rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}}a{line-height:inherit;color:#1779ba;text-decoration:none;cursor:pointer}a:focus,a:hover{color:#1468a0}a img{border:0}hr{clear:both;max-width:75rem;height:0;margin:1.25rem auto;border-top:0;border-right:0;border-bottom:1px solid #cacaca;border-left:0}dl,ol,ul{margin-bottom:1rem;list-style-position:outside;line-height:1.6}li{font-size:inherit}ul{margin-right:1.25rem;list-style-type:disc}ol{margin-right:1.25rem}ol ol,ol ul,ul ol,ul ul{margin-right:1.25rem;margin-bottom:0}dl{margin-bottom:1rem}dl dt{margin-bottom:.3rem;font-weight:700}blockquote{margin:0 0 1rem;padding:.5625rem 1.25rem 0 1.1875rem;border-right:1px solid #cacaca}blockquote,blockquote p{line-height:1.6;color:#8a8a8a}cite{display:block;font-size:.8125rem;color:#8a8a8a}cite:before{content:"— "}abbr,abbr[title]{border-bottom:1px dotted #0a0a0a;cursor:help;text-decoration:none}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:400;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;color:#0a0a0a}.subheader{margin-top:.2rem;margin-bottom:.5rem;font-weight:400;line-height:1.4;color:#8a8a8a}.lead{font-size:125%;line-height:1.6}.stat{font-size:2.5rem;line-height:1}p+.stat{margin-top:-1rem}ol.no-bullet,ul.no-bullet{margin-right:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}@media print,screen and (min-width:40em){.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}}@media print,screen and (min-width:64em){.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}}.show-for-print{display:none!important}@media print{*{background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}.show-for-print{display:block!important}.hide-for-print{display:none!important}table.show-for-print{display:table!important}thead.show-for-print{display:table-header-group!important}tbody.show-for-print{display:table-row-group!important}tr.show-for-print{display:table-row!important}td.show-for-print{display:table-cell!important}th.show-for-print{display:table-cell!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}.ir a:after,a[href^='#']:after,a[href^='javascript:']:after{content:''}abbr[title]:after{content:" (" attr(title) ")"}blockquote,pre{border:1px solid #8a8a8a;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.print-break-inside{page-break-inside:auto}}[type=color],[type=date],[type=datetime-local],[type=datetime],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],textarea{display:block;-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;height:2.4375rem;margin:0 0 1rem;padding:.5rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;-webkit-box-shadow:inset 0 1px 2px rgba(10,10,10,.1);box-shadow:inset 0 1px 2px rgba(10,10,10,.1);font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s;-webkit-appearance:none;-moz-appearance:none;appearance:none}[type=color]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=datetime]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,textarea:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}textarea{max-width:100%}textarea[rows]{height:auto}input::-webkit-input-placeholder,textarea::-webkit-input-placeholder{color:#cacaca}input:-ms-input-placeholder,textarea:-ms-input-placeholder{color:#cacaca}input::placeholder,textarea::placeholder{color:#cacaca}input:disabled,input[readonly],textarea:disabled,textarea[readonly]{background-color:#e6e6e6;cursor:not-allowed}[type=button],[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}input[type=search]{-webkit-box-sizing:border-box;box-sizing:border-box}[type=checkbox],[type=file],[type=radio]{margin:0 0 1rem}[type=checkbox]+label,[type=radio]+label{display:inline-block;vertical-align:baseline;margin-right:.5rem;margin-left:1rem;margin-bottom:0}[type=checkbox]+label[for],[type=radio]+label[for]{cursor:pointer}label>[type=checkbox],label>[type=radio]{margin-left:.5rem}[type=file]{width:100%}label{display:block;margin:0;font-size:.875rem;font-weight:400;line-height:1.8;color:#0a0a0a}label.middle{margin:0 0 1rem;padding:.5625rem 0}.help-text{margin-top:-.5rem;font-size:.8125rem;font-style:italic;color:#0a0a0a}.input-group{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;width:100%;margin-bottom:1rem;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.input-group>:first-child{border-radius:0}.input-group>:last-child>*{border-radius:0}.input-group-button,.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label,.input-group-field,.input-group-label{margin:0;white-space:nowrap}.input-group-label{padding:0 1rem;border:1px solid #cacaca;background:#e6e6e6;color:#0a0a0a;text-align:center;white-space:nowrap;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.input-group-label:first-child{border-left:0}.input-group-label:last-child{border-right:0}.input-group-field{border-radius:0;-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto;min-width:0}.input-group-button{padding-top:0;padding-bottom:0;text-align:center;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label{height:auto;-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;padding-top:0;padding-bottom:0;font-size:1rem}fieldset{margin:0;padding:0;border:0}legend{max-width:100%;margin-bottom:.5rem}.fieldset{margin:1.125rem 0;padding:1.25rem;border:1px solid #cacaca}.fieldset legend{margin:0;margin-right:-.1875rem;padding:0 .1875rem}select{height:2.4375rem;margin:0 0 1rem;padding:.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");-webkit-background-origin:content-box;background-origin:content-box;background-position:left -1rem center;background-repeat:no-repeat;-webkit-background-size:9px 6px;background-size:9px 6px;padding-left:1.5rem;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}@media screen and (min-width:0\0){select{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==)}}select:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}select:disabled{background-color:#e6e6e6;cursor:not-allowed}select::-ms-expand{display:none}select[multiple]{height:auto;background-image:none}.is-invalid-input:not(:focus){border-color:#cc4b37;background-color:#f9ecea}.is-invalid-input:not(:focus)::-webkit-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus):-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::placeholder{color:#cc4b37}.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700;color:#cc4b37}.form-error.is-visible{display:block}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem 0;font-family:inherit;padding:.85em 1em;-webkit-appearance:none;border:1px solid transparent;border-radius:0;-webkit-transition:background-color .25s ease-out,color .25s ease-out;transition:background-color .25s ease-out,color .25s ease-out;font-size:.9rem;line-height:1;text-align:center;cursor:pointer;background-color:#1779ba;color:#fefefe}[data-whatinput=mouse] .button{outline:0}.button:focus,.button:hover{background-color:#14679e;color:#fefefe}.button.tiny{font-size:.6rem}.button.small{font-size:.75rem}.button.large{font-size:1.25rem}.button.expanded{display:block;width:100%;margin-right:0;margin-left:0}.button.primary{background-color:#1779ba;color:#fefefe}.button.primary:focus,.button.primary:hover{background-color:#126195;color:#fefefe}.button.secondary{background-color:#767676;color:#fefefe}.button.secondary:focus,.button.secondary:hover{background-color:#5e5e5e;color:#fefefe}.button.success{background-color:#3adb76;color:#0a0a0a}.button.success:focus,.button.success:hover{background-color:#22bb5b;color:#0a0a0a}.button.warning{background-color:#ffae00;color:#0a0a0a}.button.warning:focus,.button.warning:hover{background-color:#cc8b00;color:#0a0a0a}.button.alert{background-color:#cc4b37;color:#fefefe}.button.alert:focus,.button.alert:hover{background-color:#a53b2a;color:#fefefe}.button.disabled,.button[disabled]{opacity:.25;cursor:not-allowed}.button.disabled,.button.disabled:focus,.button.disabled:hover,.button[disabled],.button[disabled]:focus,.button[disabled]:hover{background-color:#1779ba;color:#fefefe}.button.disabled.primary,.button[disabled].primary{opacity:.25;cursor:not-allowed}.button.disabled.primary,.button.disabled.primary:focus,.button.disabled.primary:hover,.button[disabled].primary,.button[disabled].primary:focus,.button[disabled].primary:hover{background-color:#1779ba;color:#fefefe}.button.disabled.secondary,.button[disabled].secondary{opacity:.25;cursor:not-allowed}.button.disabled.secondary,.button.disabled.secondary:focus,.button.disabled.secondary:hover,.button[disabled].secondary,.button[disabled].secondary:focus,.button[disabled].secondary:hover{background-color:#767676;color:#fefefe}.button.disabled.success,.button[disabled].success{opacity:.25;cursor:not-allowed}.button.disabled.success,.button.disabled.success:focus,.button.disabled.success:hover,.button[disabled].success,.button[disabled].success:focus,.button[disabled].success:hover{background-color:#3adb76;color:#0a0a0a}.button.disabled.warning,.button[disabled].warning{opacity:.25;cursor:not-allowed}.button.disabled.warning,.button.disabled.warning:focus,.button.disabled.warning:hover,.button[disabled].warning,.button[disabled].warning:focus,.button[disabled].warning:hover{background-color:#ffae00;color:#0a0a0a}.button.disabled.alert,.button[disabled].alert{opacity:.25;cursor:not-allowed}.button.disabled.alert,.button.disabled.alert:focus,.button.disabled.alert:hover,.button[disabled].alert,.button[disabled].alert:focus,.button[disabled].alert:hover{background-color:#cc4b37;color:#fefefe}.button.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow.disabled,.button.hollow.disabled:focus,.button.hollow.disabled:hover,.button.hollow[disabled],.button.hollow[disabled]:focus,.button.hollow[disabled]:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow:focus.disabled,.button.hollow:focus[disabled],.button.hollow:hover.disabled,.button.hollow:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary:focus.disabled,.button.hollow.primary:focus[disabled],.button.hollow.primary:hover.disabled,.button.hollow.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.secondary:focus.disabled,.button.hollow.secondary:focus[disabled],.button.hollow.secondary:hover.disabled,.button.hollow.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.success:focus.disabled,.button.hollow.success:focus[disabled],.button.hollow.success:hover.disabled,.button.hollow.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.warning:focus.disabled,.button.hollow.warning:focus[disabled],.button.hollow.warning:hover.disabled,.button.hollow.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.button.hollow.alert:focus.disabled,.button.hollow.alert:focus[disabled],.button.hollow.alert:hover.disabled,.button.hollow.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear:focus,.button.clear:hover{background-color:transparent}.button.clear.disabled,.button.clear.disabled:focus,.button.clear.disabled:hover,.button.clear[disabled],.button.clear[disabled]:focus,.button.clear[disabled]:hover{background-color:transparent}.button.clear:focus,.button.clear:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover.disabled,.button.clear:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear.disabled,.button.clear:focus,.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover,.button.clear:hover.disabled,.button.clear:hover[disabled],.button.clear[disabled]{border-color:transparent}.button.clear.primary{border:1px solid #1779ba;color:#1779ba}.button.clear.primary:focus,.button.clear.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear.primary,.button.clear.primary.disabled,.button.clear.primary:focus,.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover,.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled],.button.clear.primary[disabled]{border-color:transparent}.button.clear.secondary{border:1px solid #767676;color:#767676}.button.clear.secondary:focus,.button.clear.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.clear.secondary,.button.clear.secondary.disabled,.button.clear.secondary:focus,.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover,.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled],.button.clear.secondary[disabled]{border-color:transparent}.button.clear.success{border:1px solid #3adb76;color:#3adb76}.button.clear.success:focus,.button.clear.success:hover{border-color:#157539;color:#157539}.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover.disabled,.button.clear.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.clear.success,.button.clear.success.disabled,.button.clear.success:focus,.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover,.button.clear.success:hover.disabled,.button.clear.success:hover[disabled],.button.clear.success[disabled]{border-color:transparent}.button.clear.warning{border:1px solid #ffae00;color:#ffae00}.button.clear.warning:focus,.button.clear.warning:hover{border-color:#805700;color:#805700}.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.clear.warning,.button.clear.warning.disabled,.button.clear.warning:focus,.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover,.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled],.button.clear.warning[disabled]{border-color:transparent}.button.clear.alert{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert:focus,.button.clear.alert:hover{border-color:#67251a;color:#67251a}.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert,.button.clear.alert.disabled,.button.clear.alert:focus,.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover,.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled],.button.clear.alert[disabled]{border-color:transparent}.button.dropdown::after{display:block;width:0;height:0;border:inset .4em;content:'';border-bottom-width:0;border-top-style:solid;border-color:#fefefe transparent transparent;position:relative;top:.4em;display:inline-block;float:left;margin-right:1em}.button.dropdown.hollow::after{border-top-color:#1779ba}.button.dropdown.hollow.primary::after{border-top-color:#1779ba}.button.dropdown.hollow.secondary::after{border-top-color:#767676}.button.dropdown.hollow.success::after{border-top-color:#3adb76}.button.dropdown.hollow.warning::after{border-top-color:#ffae00}.button.dropdown.hollow.alert::after{border-top-color:#cc4b37}.button.arrow-only::after{top:-.1em;float:none;margin-right:0}a.button:focus,a.button:hover{text-decoration:none}.accordion{margin-right:0;background:#fefefe;list-style-type:none}.accordion[disabled] .accordion-title{cursor:not-allowed}.accordion-item:first-child>:first-child{border-radius:0}.accordion-item:last-child>:last-child{border-radius:0}.accordion-title{position:relative;display:block;padding:1.25rem 1rem;border:1px solid #e6e6e6;border-bottom:0;font-size:.75rem;line-height:1;color:#1779ba}:last-child:not(.is-active)>.accordion-title{border-bottom:1px solid #e6e6e6;border-radius:0}.accordion-title:focus,.accordion-title:hover{background-color:#e6e6e6}.accordion-title::before{position:absolute;top:50%;left:1rem;margin-top:-.5rem;content:'+'}.is-active>.accordion-title::before{content:'\2013'}.accordion-content{display:none;padding:1rem;border:1px solid #e6e6e6;border-bottom:0;background-color:#fefefe;color:#0a0a0a}:last-child>.accordion-content:last-child{border-bottom:1px solid #e6e6e6}.accordion-menu li{width:100%}.accordion-menu a{padding:.7rem 1rem}.accordion-menu .is-accordion-submenu a{padding:.7rem 1rem}.accordion-menu .nested.is-accordion-submenu{margin-left:0;margin-right:1rem}.accordion-menu.align-left .nested.is-accordion-submenu{margin-left:1rem;margin-right:0}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a{position:relative}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;left:1rem}.accordion-menu.align-left .is-accordion-submenu-parent>a::after{left:auto;right:1rem}.accordion-menu.align-right .is-accordion-submenu-parent>a::after{right:auto;left:1rem}.accordion-menu .is-accordion-submenu-parent[aria-expanded=true]>a::after{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.is-accordion-submenu-parent{position:relative}.has-submenu-toggle>a{margin-left:40px}.submenu-toggle{position:absolute;top:0;left:0;cursor:pointer;width:40px;height:40px}.submenu-toggle::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;top:0;bottom:0;margin:auto}.submenu-toggle[aria-expanded=true]::after{-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.submenu-toggle-text{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center;background:#1779ba;color:#fefefe}.badge.primary{background:#1779ba;color:#fefefe}.badge.secondary{background:#767676;color:#fefefe}.badge.success{background:#3adb76;color:#0a0a0a}.badge.warning{background:#ffae00;color:#0a0a0a}.badge.alert{background:#cc4b37;color:#fefefe}.breadcrumbs{margin:0 0 1rem 0;list-style:none}.breadcrumbs::after,.breadcrumbs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.breadcrumbs::after{clear:both}.breadcrumbs li{float:right;font-size:.6875rem;color:#0a0a0a;cursor:default;text-transform:uppercase}.breadcrumbs li:not(:last-child)::after{position:relative;margin:0 .75rem;opacity:1;content:"\\";color:#cacaca}.breadcrumbs a{color:#1779ba}.breadcrumbs a:hover{text-decoration:underline}.breadcrumbs .disabled{color:#cacaca;cursor:not-allowed}.button-group{margin-bottom:1rem;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.button-group::after,.button-group::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.button-group::after{clear:both}.button-group .button{margin:0;margin-left:1px;margin-bottom:1px;font-size:.9rem;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.button-group .button:last-child{margin-left:0}.button-group.tiny .button{font-size:.6rem}.button-group.small .button{font-size:.75rem}.button-group.large .button{font-size:1.25rem}.button-group.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.button-group.primary .button{background-color:#1779ba;color:#fefefe}.button-group.primary .button:focus,.button-group.primary .button:hover{background-color:#126195;color:#fefefe}.button-group.secondary .button{background-color:#767676;color:#fefefe}.button-group.secondary .button:focus,.button-group.secondary .button:hover{background-color:#5e5e5e;color:#fefefe}.button-group.success .button{background-color:#3adb76;color:#0a0a0a}.button-group.success .button:focus,.button-group.success .button:hover{background-color:#22bb5b;color:#0a0a0a}.button-group.warning .button{background-color:#ffae00;color:#0a0a0a}.button-group.warning .button:focus,.button-group.warning .button:hover{background-color:#cc8b00;color:#0a0a0a}.button-group.alert .button{background-color:#cc4b37;color:#fefefe}.button-group.alert .button:focus,.button-group.alert .button:hover{background-color:#a53b2a;color:#fefefe}.button-group.stacked,.button-group.stacked-for-medium,.button-group.stacked-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.button-group.stacked .button,.button-group.stacked-for-medium .button,.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%}.button-group.stacked .button:last-child,.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.button-group.stacked-for-small .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;margin-bottom:0}}@media print,screen and (min-width:64em){.button-group.stacked-for-medium .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;margin-bottom:0}}@media screen and (max-width:39.9375em){.button-group.stacked-for-small.expanded{display:block}.button-group.stacked-for-small.expanded .button{display:block;margin-left:0}}.callout{position:relative;margin:0 0 1rem 0;padding:1rem;border:1px solid rgba(10,10,10,.25);border-radius:0;background-color:#fff;color:#0a0a0a}.callout>:first-child{margin-top:0}.callout>:last-child{margin-bottom:0}.callout.primary{background-color:#d7ecfa;color:#0a0a0a}.callout.secondary{background-color:#eaeaea;color:#0a0a0a}.callout.success{background-color:#e1faea;color:#0a0a0a}.callout.warning{background-color:#fff3d9;color:#0a0a0a}.callout.alert{background-color:#f7e4e1;color:#0a0a0a}.callout.small{padding-top:.5rem;padding-right:.5rem;padding-bottom:.5rem;padding-left:.5rem}.callout.large{padding-top:3rem;padding-right:3rem;padding-bottom:3rem;padding-left:3rem}.card{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-grow:1;-ms-flex-positive:1;flex-grow:1;margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;color:#0a0a0a}.card>:last-child{margin-bottom:0}.card-divider{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;padding:1rem;background:#e6e6e6}.card-divider>:last-child{margin-bottom:0}.card-section{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto;padding:1rem}.card-section>:last-child{margin-bottom:0}.card-image{min-height:1px}.close-button{position:absolute;color:#8a8a8a;cursor:pointer}[data-whatinput=mouse] .close-button{outline:0}.close-button:focus,.close-button:hover{color:#0a0a0a}.close-button.small{right:.66rem;top:.33em;font-size:1.5em;line-height:1}.close-button,.close-button.medium{right:1rem;top:.5rem;font-size:2em;line-height:1}.menu{padding:0;margin:0;list-style:none;position:relative;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}[data-whatinput=mouse] .menu li{outline:0}.menu .button,.menu a{line-height:1;text-decoration:none;display:block;padding:.7rem 1rem}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu input{display:inline-block}.menu,.menu.horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.simple{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.menu.simple li+li{margin-right:1rem}.menu.simple a{padding:0}@media print,screen and (min-width:40em){.menu.medium-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.medium-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.medium-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.medium-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}@media print,screen and (min-width:64em){.menu.large-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.large-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.large-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.large-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}.menu.nested{margin-left:0;margin-right:1rem}.menu.icons a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-bottom a,.menu.icon-left a,.menu.icon-right a,.menu.icon-top a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-left li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-left li a i,.menu.icon-left li a img,.menu.icon-left li a svg{margin-left:.25rem}.menu.icon-right li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-right li a i,.menu.icon-right li a img,.menu.icon-right li a svg{margin-right:.25rem}.menu.icon-top li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-top li a i,.menu.icon-top li a img,.menu.icon-top li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu.icon-bottom li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-bottom li a i,.menu.icon-bottom li a img,.menu.icon-bottom li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu .is-active>a{background:#1779ba;color:#fefefe}.menu .active>a{background:#1779ba;color:#fefefe}.menu.align-right{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-left li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.menu.align-left li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-left.vertical li{display:block;text-align:left}.menu.align-left.vertical li .submenu li{text-align:left}.menu.align-left .nested{margin-left:1rem;margin-right:0}.menu.align-center li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu.align-center li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu .menu-text{padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered>.menu{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.no-js [data-responsive-menu] ul{display:none}.menu-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#fefefe;-webkit-box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:''}.menu-icon:hover::after{background:#cacaca;-webkit-box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.menu-icon.dark{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon.dark::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;-webkit-box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:''}.menu-icon.dark:hover::after{background:#8a8a8a;-webkit-box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a;box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a}.is-drilldown{position:relative;overflow:hidden}.is-drilldown li{display:block}.is-drilldown.animate-height{-webkit-transition:height .5s;transition:height .5s}.drilldown a{padding:.7rem 1rem;background:#fefefe}.drilldown .is-drilldown-submenu{position:absolute;top:0;right:100%;z-index:-1;width:100%;background:#fefefe;-webkit-transition:-webkit-transform .15s linear;transition:-webkit-transform .15s linear;transition:transform .15s linear;transition:transform .15s linear,-webkit-transform .15s linear}.drilldown .is-drilldown-submenu.is-active{z-index:1;display:block;-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%)}.drilldown .is-drilldown-submenu.is-closing{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%)}.drilldown .is-drilldown-submenu a{padding:.7rem 1rem}.drilldown .nested.is-drilldown-submenu{margin-left:0;margin-right:0}.drilldown .drilldown-submenu-cover-previous{min-height:100%}.drilldown .is-drilldown-submenu-parent>a{position:relative}.drilldown .is-drilldown-submenu-parent>a::after{position:absolute;top:50%;margin-top:-6px;left:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.drilldown.align-left .is-drilldown-submenu-parent>a::after{left:auto;right:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.drilldown.align-right .is-drilldown-submenu-parent>a::after{right:auto;left:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.drilldown .js-drilldown-back>a::before{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;border-right-width:0;display:inline-block;vertical-align:middle;margin-left:.75rem;border-right-width:0}.dropdown-pane{position:absolute;z-index:10;width:300px;padding:1rem;visibility:hidden;display:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-opening{display:block}.dropdown-pane.is-open{visibility:visible;display:block}.dropdown-pane.tiny{width:100px}.dropdown-pane.small{width:200px}.dropdown-pane.large{width:400px}.dropdown.menu>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu>li.is-dropdown-submenu-parent>a{position:relative;padding-left:1.5rem}.dropdown.menu>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;left:5px;right:auto;margin-top:-3px}.dropdown.menu a{padding:.7rem 1rem}[data-whatinput=mouse] .dropdown.menu a{outline:0}.dropdown.menu .is-active>a{background:0 0;color:#1779ba}.no-js .dropdown.menu ul{display:none}.dropdown.menu .nested.is-dropdown-submenu{margin-left:0;margin-right:0}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.vertical>li>a::after{left:14px}.dropdown.menu.vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}@media print,screen and (min-width:40em){.dropdown.menu.medium-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.medium-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-left:1.5rem}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;left:5px;right:auto;margin-top:-3px}.dropdown.menu.medium-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.medium-vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.medium-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.medium-vertical>li>a::after{left:14px}.dropdown.menu.medium-vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.medium-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}@media print,screen and (min-width:64em){.dropdown.menu.large-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.large-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-left:1.5rem}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;left:5px;right:auto;margin-top:-3px}.dropdown.menu.large-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.large-vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.large-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.large-vertical>li>a::after{left:14px}.dropdown.menu.large-vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.large-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}.dropdown.menu.align-right .is-dropdown-submenu.first-sub{top:100%;right:0;left:auto}.is-dropdown-menu.vertical{width:100px}.is-dropdown-menu.vertical.align-right{float:right}.is-dropdown-submenu-parent{position:relative}.is-dropdown-submenu-parent a::after{position:absolute;top:50%;left:5px;right:auto;margin-top:-6px}.is-dropdown-submenu-parent.opens-inner>.is-dropdown-submenu{top:100%;right:auto}.is-dropdown-submenu-parent.opens-left>.is-dropdown-submenu{right:100%;left:auto}.is-dropdown-submenu-parent.opens-right>.is-dropdown-submenu{right:auto;left:100%}.is-dropdown-submenu{position:absolute;top:0;right:100%;z-index:1;display:none;min-width:200px;border:1px solid #cacaca;background:#fefefe}.dropdown .is-dropdown-submenu a{padding:.7rem 1rem}.is-dropdown-submenu .is-dropdown-submenu-parent>a::after{left:14px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.is-dropdown-submenu .is-dropdown-submenu{margin-top:-1px}.is-dropdown-submenu>li{width:100%}.is-dropdown-submenu.js-dropdown-active{display:block}.flex-video,.responsive-embed{position:relative;height:0;margin-bottom:1rem;padding-bottom:75%;overflow:hidden}.flex-video embed,.flex-video iframe,.flex-video object,.flex-video video,.responsive-embed embed,.responsive-embed iframe,.responsive-embed object,.responsive-embed video{position:absolute;top:0;right:0;width:100%;height:100%}.flex-video.widescreen,.responsive-embed.widescreen{padding-bottom:56.25%}.label{display:inline-block;padding:.33333rem .5rem;border-radius:0;font-size:.8rem;line-height:1;white-space:nowrap;cursor:default;background:#1779ba;color:#fefefe}.label.primary{background:#1779ba;color:#fefefe}.label.secondary{background:#767676;color:#fefefe}.label.success{background:#3adb76;color:#0a0a0a}.label.warning{background:#ffae00;color:#0a0a0a}.label.alert{background:#cc4b37;color:#fefefe}.media-object{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;margin-bottom:1rem;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.media-object img{max-width:none}@media screen and (max-width:39.9375em){.media-object.stack-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}}@media screen and (max-width:39.9375em){.media-object.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;-webkit-flex-basis:100%;-ms-flex-preferred-size:100%;flex-basis:100%;max-width:100%}.media-object.stack-for-small .media-object-section img{width:100%}}.media-object-section{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.media-object-section:first-child{padding-left:1rem}.media-object-section:last-child:not(:nth-child(2)){padding-right:1rem}.media-object-section>:last-child{margin-bottom:0}.media-object-section.main-section{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.is-off-canvas-open{overflow:hidden}.js-off-canvas-overlay{position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;-webkit-transition:opacity .5s ease,visibility .5s ease;transition:opacity .5s ease,visibility .5s ease;background:rgba(254,254,254,.25);opacity:0;visibility:hidden;overflow:hidden}.js-off-canvas-overlay.is-visible{opacity:1;visibility:visible}.js-off-canvas-overlay.is-closable{cursor:pointer}.js-off-canvas-overlay.is-overlay-absolute{position:absolute}.js-off-canvas-overlay.is-overlay-fixed{position:fixed}.off-canvas-wrapper{position:relative;overflow:hidden}.off-canvas{position:fixed;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-push{z-index:12}.off-canvas.is-closed{visibility:hidden}.off-canvas.is-transition-overlap{z-index:13}.off-canvas.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-absolute{position:absolute;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas-absolute{outline:0}.off-canvas-absolute.is-transition-push{z-index:12}.off-canvas-absolute.is-closed{visibility:hidden}.off-canvas-absolute.is-transition-overlap{z-index:13}.off-canvas-absolute.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas-absolute.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.position-left{top:0;left:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-left.has-transition-push{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.position-left.is-transition-push{-webkit-box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25)}.position-right{top:0;right:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-right.has-transition-push{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.position-right.is-transition-push{-webkit-box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25)}.position-top{top:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-top.has-transition-push{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.position-top.is-transition-push{-webkit-box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25)}.position-bottom{bottom:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-bottom.has-transition-push{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.position-bottom.is-transition-push{-webkit-box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25)}.off-canvas-content{-webkit-transform:none;-ms-transform:none;transform:none;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.off-canvas-content.has-transition-push{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content .off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}@media print,screen and (min-width:40em){.position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-medium .close-button{display:none}.off-canvas-content .position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-medium .close-button{display:none}.off-canvas-content .position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-medium .close-button{display:none}.off-canvas-content .position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-medium .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:64em){.position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-large .close-button{display:none}.off-canvas-content .position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-large .close-button{display:none}.off-canvas-content .position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-large .close-button{display:none}.off-canvas-content .position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-large .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:40em){.off-canvas.in-canvas-for-medium{visibility:visible;height:auto;position:static;background:inherit;width:inherit;overflow:inherit;-webkit-transition:inherit;transition:inherit}.off-canvas.in-canvas-for-medium.position-bottom,.off-canvas.in-canvas-for-medium.position-left,.off-canvas.in-canvas-for-medium.position-right,.off-canvas.in-canvas-for-medium.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-medium .close-button{display:none}}@media print,screen and (min-width:64em){.off-canvas.in-canvas-for-large{visibility:visible;height:auto;position:static;background:inherit;width:inherit;overflow:inherit;-webkit-transition:inherit;transition:inherit}.off-canvas.in-canvas-for-large.position-bottom,.off-canvas.in-canvas-for-large.position-left,.off-canvas.in-canvas-for-large.position-right,.off-canvas.in-canvas-for-large.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-large .close-button{display:none}}.orbit{position:relative}.orbit-container{position:relative;height:0;margin:0;list-style:none;overflow:hidden}.orbit-slide{width:100%}.orbit-slide.no-motionui.is-active{top:0;left:0}.orbit-figure{margin:0}.orbit-image{width:100%;max-width:100%;margin:0}.orbit-caption{position:absolute;bottom:0;width:100%;margin-bottom:0;padding:1rem;background-color:rgba(10,10,10,.5);color:#fefefe}.orbit-next,.orbit-previous{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);z-index:10;padding:1rem;color:#fefefe}[data-whatinput=mouse] .orbit-next,[data-whatinput=mouse] .orbit-previous{outline:0}.orbit-next:active,.orbit-next:focus,.orbit-next:hover,.orbit-previous:active,.orbit-previous:focus,.orbit-previous:hover{background-color:rgba(10,10,10,.5)}.orbit-previous{right:0}.orbit-next{right:auto;left:0}.orbit-bullets{position:relative;margin-top:.8rem;margin-bottom:.8rem;text-align:center}[data-whatinput=mouse] .orbit-bullets{outline:0}.orbit-bullets button{width:1.2rem;height:1.2rem;margin:.1rem;border-radius:50%;background-color:#cacaca}.orbit-bullets button:hover{background-color:#8a8a8a}.orbit-bullets button.is-active{background-color:#8a8a8a}.pagination{margin-right:0;margin-bottom:1rem}.pagination::after,.pagination::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.pagination::after{clear:both}.pagination li{margin-left:.0625rem;border-radius:0;font-size:.875rem;display:none}.pagination li:first-child,.pagination li:last-child{display:inline-block}@media print,screen and (min-width:40em){.pagination li{display:inline-block}}.pagination a,.pagination button{display:block;padding:.1875rem .625rem;border-radius:0;color:#0a0a0a}.pagination a:hover,.pagination button:hover{background:#e6e6e6}.pagination .current{padding:.1875rem .625rem;background:#1779ba;color:#fefefe;cursor:default}.pagination .disabled{padding:.1875rem .625rem;color:#cacaca;cursor:not-allowed}.pagination .disabled:hover{background:0 0}.pagination .ellipsis::after{padding:.1875rem .625rem;content:'\2026';color:#0a0a0a}.pagination-previous a::before,.pagination-previous.disabled::before{display:inline-block;margin-left:.5rem;content:'\00ab'}.pagination-next a::after,.pagination-next.disabled::after{display:inline-block;margin-right:.5rem;content:'\00bb'}.progress{height:1rem;margin-bottom:1rem;border-radius:0;background-color:#cacaca}.progress.primary .progress-meter{background-color:#1779ba}.progress.secondary .progress-meter{background-color:#767676}.progress.success .progress-meter{background-color:#3adb76}.progress.warning .progress-meter{background-color:#ffae00}.progress.alert .progress-meter{background-color:#cc4b37}.progress-meter{position:relative;display:block;width:0%;height:100%;background-color:#1779ba}.progress-meter-text{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);transform:translate(-50%,-50%);position:absolute;margin:0;font-size:.75rem;font-weight:700;color:#fefefe;white-space:nowrap}.slider{position:relative;height:.5rem;margin-top:1.25rem;margin-bottom:2.25rem;background-color:#e6e6e6;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none}.slider-fill{position:absolute;top:0;left:0;display:inline-block;max-width:100%;height:.5rem;background-color:#cacaca;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.slider-fill.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider-handle{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;-ms-touch-action:manipulation;touch-action:manipulation}[data-whatinput=mouse] .slider-handle{outline:0}.slider-handle:hover{background-color:#14679e}.slider-handle.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider.disabled,.slider[disabled]{opacity:.25;cursor:not-allowed}.slider.vertical{display:inline-block;width:.5rem;height:12.5rem;margin:0 1.25rem;-webkit-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scale(1,-1)}.slider.vertical .slider-fill{top:0;width:.5rem;max-height:100%}.slider.vertical .slider-handle{position:absolute;top:0;left:50%;width:1.4rem;height:1.4rem;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.slider:not(.vertical){-webkit-transform:scale(-1,1);-ms-transform:scale(-1,1);transform:scale(-1,1)}.sticky-container{position:relative}.sticky{position:relative;z-index:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.sticky.is-stuck{position:fixed;z-index:5;width:100%}.sticky.is-stuck.is-at-top{top:0}.sticky.is-stuck.is-at-bottom{bottom:0}.sticky.is-anchored{position:relative;right:auto;left:auto}.sticky.is-anchored.is-at-bottom{bottom:0}body.is-reveal-open{overflow:hidden}html.is-reveal-open,html.is-reveal-open body{min-height:100%;overflow:hidden;position:fixed;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;display:none;background-color:rgba(10,10,10,.45);overflow-y:scroll}.reveal{z-index:1006;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:none;padding:1rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;position:relative;top:100px;margin-right:auto;margin-left:auto;overflow-y:auto}[data-whatinput=mouse] .reveal{outline:0}@media print,screen and (min-width:40em){.reveal{min-height:0}}.reveal .column{min-width:0}.reveal>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.reveal{width:600px;max-width:75rem}}.reveal.collapse{padding:0}@media print,screen and (min-width:40em){.reveal.tiny{width:30%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.small{width:50%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.large{width:90%;max-width:75rem}}.reveal.full{top:0;left:0;width:100%;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}@media screen and (max-width:39.9375em){.reveal{top:0;left:0;width:100%;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}}.reveal.without-overlay{position:fixed}.switch{height:2rem;position:relative;margin-bottom:1rem;outline:0;font-size:.875rem;font-weight:700;color:#fefefe;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.switch-input{position:absolute;margin-bottom:0;opacity:0}.switch-paddle{position:relative;display:block;width:4rem;height:2rem;border-radius:0;background:#cacaca;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;font-weight:inherit;color:inherit;cursor:pointer}input+.switch-paddle{margin:0}.switch-paddle::after{position:absolute;top:.25rem;right:.25rem;display:block;width:1.5rem;height:1.5rem;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);border-radius:0;background:#fefefe;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;content:''}input:checked~.switch-paddle{background:#1779ba}input:checked~.switch-paddle::after{right:2.25rem}[data-whatinput=mouse] input:focus~.switch-paddle{outline:0}.switch-active,.switch-inactive{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.switch-active{right:8%;display:none}input:checked+label>.switch-active{display:block}.switch-inactive{left:15%}input:checked+label>.switch-inactive{display:none}.switch.tiny{height:1.5rem}.switch.tiny .switch-paddle{width:3rem;height:1.5rem;font-size:.625rem}.switch.tiny .switch-paddle::after{top:.25rem;right:.25rem;width:1rem;height:1rem}.switch.tiny input:checked~.switch-paddle::after{right:1.75rem}.switch.small{height:1.75rem}.switch.small .switch-paddle{width:3.5rem;height:1.75rem;font-size:.75rem}.switch.small .switch-paddle::after{top:.25rem;right:.25rem;width:1.25rem;height:1.25rem}.switch.small input:checked~.switch-paddle::after{right:2rem}.switch.large{height:2.5rem}.switch.large .switch-paddle{width:5rem;height:2.5rem;font-size:1rem}.switch.large .switch-paddle::after{top:.25rem;right:.25rem;width:2rem;height:2rem}.switch.large input:checked~.switch-paddle::after{right:2.75rem}table{border-collapse:collapse;width:100%;margin-bottom:1rem;border-radius:0}table tbody,table tfoot,table thead{border:1px solid #f1f1f1;background-color:#fefefe}table caption{padding:.5rem .625rem .625rem;font-weight:700}table thead{background:#f8f8f8;color:#0a0a0a}table tfoot{background:#f1f1f1;color:#0a0a0a}table tfoot tr,table thead tr{background:0 0}table tfoot td,table tfoot th,table thead td,table thead th{padding:.5rem .625rem .625rem;font-weight:700;text-align:right}table tbody td,table tbody th{padding:.5rem .625rem .625rem}table tbody tr:nth-child(even){border-bottom:0;background-color:#f1f1f1}table.unstriped tbody{background-color:#fefefe}table.unstriped tbody tr{border-bottom:0;border-bottom:1px solid #f1f1f1;background-color:#fefefe}@media screen and (max-width:63.9375em){table.stack thead{display:none}table.stack tfoot{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}}table.scroll{display:block;width:100%;overflow-x:auto}table.hover thead tr:hover{background-color:#f3f3f3}table.hover tfoot tr:hover{background-color:#ececec}table.hover tbody tr:hover{background-color:#f9f9f9}table.hover:not(.unstriped) tr:nth-of-type(even):hover{background-color:#ececec}.table-scroll{overflow-x:auto}.table-scroll table{width:auto}.tabs{margin:0;border:1px solid #e6e6e6;background:#fefefe;list-style-type:none}.tabs::after,.tabs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.tabs::after{clear:both}.tabs.vertical>li{display:block;float:none;width:auto}.tabs.simple>li>a{padding:0}.tabs.simple>li>a:hover{background:0 0}.tabs.primary{background:#1779ba}.tabs.primary>li>a{color:#fefefe}.tabs.primary>li>a:focus,.tabs.primary>li>a:hover{background:#1673b1}.tabs-title{float:right}.tabs-title>a{display:block;padding:1.25rem 1.5rem;font-size:.75rem;line-height:1;color:#1779ba}.tabs-title>a:hover{background:#fefefe;color:#1468a0}.tabs-title>a:focus,.tabs-title>a[aria-selected=true]{background:#e6e6e6;color:#1779ba}.tabs-content{border:1px solid #e6e6e6;border-top:0;background:#fefefe;color:#0a0a0a;-webkit-transition:all .5s ease;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-right:0}.tabs-panel{display:none;padding:1rem}.tabs-panel.is-active{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:solid 4px #fefefe;border-radius:0;-webkit-box-shadow:0 0 0 1px rgba(10,10,10,.2);box-shadow:0 0 0 1px rgba(10,10,10,.2);line-height:0}a.thumbnail{-webkit-transition:-webkit-box-shadow .2s ease-out;transition:-webkit-box-shadow .2s ease-out;transition:box-shadow .2s ease-out;transition:box-shadow .2s ease-out,-webkit-box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{-webkit-box-shadow:0 0 6px 1px rgba(23,121,186,.5);box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{-webkit-box-shadow:none;box-shadow:none}.title-bar{padding:.5rem;background:#0a0a0a;color:#fefefe;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.title-bar .menu-icon{margin-right:.25rem;margin-left:.25rem}.title-bar-left,.title-bar-right{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.title-bar-right{text-align:right}.title-bar-title{display:inline-block;vertical-align:middle;font-weight:700}.has-tip{position:relative;display:inline-block;border-bottom:dotted 1px #8a8a8a;font-weight:700;cursor:help}.tooltip{position:absolute;top:calc(100% + .6495rem);z-index:1200;max-width:10rem;padding:.75rem;border-radius:0;background-color:#0a0a0a;font-size:80%;color:#fefefe}.tooltip::before{position:absolute}.tooltip.bottom::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;bottom:100%}.tooltip.bottom.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.top::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.top.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.left::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.right::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.tooltip.right.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.align-top::before{bottom:auto;top:10%}.tooltip.align-bottom::before{bottom:10%;top:auto}.tooltip.align-left::before{left:10%;right:auto}.tooltip.align-right::before{left:auto;right:10%}.top-bar{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;padding:.5rem;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar,.top-bar ul{background-color:#e6e6e6}.top-bar input{max-width:200px;margin-left:1rem}.top-bar .input-group-field{width:100%;margin-left:0}.top-bar input.button{width:auto}.top-bar .top-bar-left,.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}@media print,screen and (min-width:40em){.top-bar{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.top-bar .top-bar-left{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;margin-right:auto}.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;margin-left:auto}}@media screen and (max-width:63.9375em){.top-bar.stacked-for-medium{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}@media screen and (max-width:74.9375em){.top-bar.stacked-for-large{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-large .top-bar-left,.top-bar.stacked-for-large .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}.top-bar-title{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin:.5rem 1rem .5rem 0}.top-bar-left,.top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.hide{display:none!important}.invisible{visibility:hidden}@media screen and (max-width:39.9375em){.hide-for-small-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media print,screen and (min-width:40em){.hide-for-medium{display:none!important}}@media screen and (max-width:39.9375em){.show-for-medium{display:none!important}}@media screen and (min-width:40em) and (max-width:63.9375em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:39.9375em),screen and (min-width:64em){.show-for-medium-only{display:none!important}}@media print,screen and (min-width:64em){.hide-for-large{display:none!important}}@media screen and (max-width:63.9375em){.show-for-large{display:none!important}}@media screen and (min-width:64em) and (max-width:74.9375em){.hide-for-large-only{display:none!important}}@media screen and (max-width:63.9375em),screen and (min-width:75em){.show-for-large-only{display:none!important}}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal;-webkit-clip-path:none;clip-path:none}.hide-for-portrait,.show-for-landscape{display:block!important}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}}.hide-for-landscape,.show-for-portrait{display:none!important}@media screen and (orientation:landscape){.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-landscape,.show-for-portrait{display:block!important}}.float-left{float:left!important}.float-right{float:right!important}.float-center{display:block;margin-right:auto;margin-left:auto}.clearfix::after,.clearfix::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.clearfix::after{clear:both}.align-right{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-justify{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between}.align-spaced{-webkit-justify-content:space-around;-ms-flex-pack:distribute;justify-content:space-around}.align-right.vertical.menu>li>a{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center.vertical.menu>li>a{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-top{-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start}.align-self-top{-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start}.align-bottom{-webkit-box-align:end;-webkit-align-items:flex-end;-ms-flex-align:end;align-items:flex-end}.align-self-bottom{-webkit-align-self:flex-end;-ms-flex-item-align:end;align-self:flex-end}.align-middle{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.align-self-middle{-webkit-align-self:center;-ms-flex-item-align:center;-ms-grid-row-align:center;align-self:center}.align-stretch{-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.align-self-stretch{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch}.align-center-middle{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-align-content:center;-ms-flex-line-pack:center;align-content:center}.small-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.small-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.small-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.small-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.small-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.small-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}@media print,screen and (min-width:40em){.medium-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.medium-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.medium-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.medium-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.medium-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.medium-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}@media print,screen and (min-width:64em){.large-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.large-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.large-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.large-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.large-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.large-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}.flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}@media print,screen and (min-width:40em){.medium-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.medium-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.medium-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.medium-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.medium-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.medium-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.medium-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.medium-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}@media print,screen and (min-width:64em){.large-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.large-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.large-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.large-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.large-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.large-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.large-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.large-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}
\ No newline at end of file
+@charset "UTF-8";@media print,screen and (min-width:40em){.reveal,.reveal.large,.reveal.small,.reveal.tiny{right:auto;left:auto;margin:0 auto}}/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}h1{font-size:2em;margin:.67em 0}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{-webkit-box-sizing:border-box;box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{-webkit-box-sizing:border-box;box-sizing:border-box;font-size:100%}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;padding:0;background:#fefefe;font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle;max-width:100%;height:auto;-ms-interpolation-mode:bicubic}textarea{height:auto;min-height:50px;border-radius:0}select{-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;border-radius:0}.map_canvas embed,.map_canvas img,.map_canvas object,.mqa-display embed,.mqa-display img,.mqa-display object{max-width:none!important}button{padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:0;background:0 0;line-height:1;cursor:auto}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}button,input,optgroup,select,textarea{font-family:inherit}.is-visible{display:block!important}.is-hidden{display:none!important}[type=color],[type=date],[type=datetime-local],[type=datetime],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],textarea{display:block;-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;height:2.4375rem;margin:0 0 1rem;padding:.5rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;-webkit-box-shadow:inset 0 1px 2px rgba(10,10,10,.1);box-shadow:inset 0 1px 2px rgba(10,10,10,.1);font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s;-webkit-appearance:none;-moz-appearance:none;appearance:none}[type=color]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=datetime]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,textarea:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}textarea{max-width:100%}textarea[rows]{height:auto}input:disabled,input[readonly],textarea:disabled,textarea[readonly]{background-color:#e6e6e6;cursor:not-allowed}[type=button],[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}input[type=search]{-webkit-box-sizing:border-box;box-sizing:border-box}::-webkit-input-placeholder{color:#cacaca}:-ms-input-placeholder{color:#cacaca}::-ms-input-placeholder{color:#cacaca}::placeholder{color:#cacaca}[type=checkbox],[type=file],[type=radio]{margin:0 0 1rem}[type=checkbox]+label,[type=radio]+label{display:inline-block;vertical-align:baseline;margin-right:.5rem;margin-left:1rem;margin-bottom:0}[type=checkbox]+label[for],[type=radio]+label[for]{cursor:pointer}label>[type=checkbox],label>[type=radio]{margin-left:.5rem}[type=file]{width:100%}label{display:block;margin:0;font-size:.875rem;font-weight:400;line-height:1.8;color:#0a0a0a}label.middle{margin:0 0 1rem;padding:.5625rem 0}.help-text{margin-top:-.5rem;font-size:.8125rem;font-style:italic;color:#0a0a0a}.input-group{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;width:100%;margin-bottom:1rem;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.input-group>:first-child,.input-group>:first-child.input-group-button>*{border-radius:0}.input-group>:last-child,.input-group>:last-child.input-group-button>*{border-radius:0}.input-group-button,.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label,.input-group-field,.input-group-label{margin:0;white-space:nowrap}.input-group-label{padding:0 1rem;border:1px solid #cacaca;background:#e6e6e6;color:#0a0a0a;text-align:center;white-space:nowrap;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.input-group-label:first-child{border-left:0}.input-group-label:last-child{border-right:0}.input-group-field{border-radius:0;-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;min-width:0}.input-group-button{padding-top:0;padding-bottom:0;text-align:center;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;height:auto;padding-top:0;padding-bottom:0;font-size:1rem}fieldset{margin:0;padding:0;border:0}legend{max-width:100%;margin-bottom:.5rem}.fieldset{margin:1.125rem 0;padding:1.25rem;border:1px solid #cacaca}.fieldset legend{margin:0;margin-right:-.1875rem;padding:0 .1875rem}select{height:2.4375rem;margin:0 0 1rem;padding:.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");background-origin:content-box;background-position:left -1rem center;background-repeat:no-repeat;background-size:9px 6px;padding-left:1.5rem;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}@media screen and (min-width:0\0){select{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==)}}select:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}select:disabled{background-color:#e6e6e6;cursor:not-allowed}select::-ms-expand{display:none}select[multiple]{height:auto;background-image:none}.is-invalid-input:not(:focus){border-color:#cc4b37;background-color:#f9ecea}.is-invalid-input:not(:focus)::-webkit-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus):-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::placeholder{color:#cc4b37}.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700;color:#cc4b37}.form-error.is-visible{display:block}blockquote,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,li,ol,p,pre,td,th,ul{margin:0;padding:0}p{margin-bottom:1rem;font-size:inherit;line-height:1.6;text-rendering:optimizeLegibility}em,i{font-style:italic;line-height:inherit}b,strong{font-weight:700;line-height:inherit}small{font-size:80%;line-height:inherit}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-style:normal;font-weight:400;color:inherit;text-rendering:optimizeLegibility}.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small,h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{line-height:0;color:#cacaca}.h1,h1{font-size:1.5rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h2,h2{font-size:1.25rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h3,h3{font-size:1.1875rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h4,h4{font-size:1.125rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h5,h5{font-size:1.0625rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h6,h6{font-size:1rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}@media print,screen and (min-width:40em){.h1,h1{font-size:3rem}.h2,h2{font-size:2.5rem}.h3,h3{font-size:1.9375rem}.h4,h4{font-size:1.5625rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}}a{line-height:inherit;color:#1779ba;text-decoration:none;cursor:pointer}a:focus,a:hover{color:#1468a0}a img{border:0}hr{clear:both;max-width:75rem;height:0;margin:1.25rem auto;border-top:0;border-right:0;border-bottom:1px solid #cacaca;border-left:0}dl,ol,ul{margin-bottom:1rem;list-style-position:outside;line-height:1.6}li{font-size:inherit}ul{margin-right:1.25rem;list-style-type:disc}ol{margin-right:1.25rem}ol ol,ol ul,ul ol,ul ul{margin-right:1.25rem;margin-bottom:0}dl{margin-bottom:1rem}dl dt{margin-bottom:.3rem;font-weight:700}blockquote{margin:0 0 1rem;padding:.5625rem 1.25rem 0 1.1875rem;border-right:1px solid #cacaca}blockquote,blockquote p{line-height:1.6;color:#8a8a8a}cite{display:block;font-size:.8125rem;color:#8a8a8a}cite:before{content:"— "}abbr,abbr[title]{border-bottom:1px dotted #0a0a0a;cursor:help;text-decoration:none}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:400;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;color:#0a0a0a}.subheader{margin-top:.2rem;margin-bottom:.5rem;font-weight:400;line-height:1.4;color:#8a8a8a}.lead{font-size:125%;line-height:1.6}.stat{font-size:2.5rem;line-height:1}p+.stat{margin-top:-1rem}ol.no-bullet,ul.no-bullet{margin-right:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}@media print,screen and (min-width:40em){.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}}@media print,screen and (min-width:64em){.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}}.show-for-print{display:none!important}@media print{*{background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}.show-for-print{display:block!important}.hide-for-print{display:none!important}table.show-for-print{display:table!important}thead.show-for-print{display:table-header-group!important}tbody.show-for-print{display:table-row-group!important}tr.show-for-print{display:table-row!important}td.show-for-print{display:table-cell!important}th.show-for-print{display:table-cell!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}.ir a:after,a[href^='#']:after,a[href^='javascript:']:after{content:''}abbr[title]:after{content:" (" attr(title) ")"}blockquote,pre{border:1px solid #8a8a8a;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.print-break-inside{page-break-inside:auto}}.grid-container{padding-right:.625rem;padding-left:.625rem;max-width:75rem;margin-left:auto;margin-right:auto}@media print,screen and (min-width:40em){.grid-container{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.fluid{padding-right:.625rem;padding-left:.625rem;max-width:100%;margin-left:auto;margin-right:auto}@media print,screen and (min-width:40em){.grid-container.fluid{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.full{padding-right:0;padding-left:0;max-width:100%;margin-left:auto;margin-right:auto}.grid-x{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row wrap;-ms-flex-flow:row wrap;flex-flow:row wrap}.cell{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;min-height:0;min-width:0;width:100%}.cell.auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.cell.shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.auto{width:auto}.grid-x>.shrink{width:auto}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9,.grid-x>.small-full,.grid-x>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-full,.grid-x>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-full,.grid-x>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.small-1{width:8.33333%}.grid-x>.small-2{width:16.66667%}.grid-x>.small-3{width:25%}.grid-x>.small-4{width:33.33333%}.grid-x>.small-5{width:41.66667%}.grid-x>.small-6{width:50%}.grid-x>.small-7{width:58.33333%}.grid-x>.small-8{width:66.66667%}.grid-x>.small-9{width:75%}.grid-x>.small-10{width:83.33333%}.grid-x>.small-11{width:91.66667%}.grid-x>.small-12{width:100%}@media print,screen and (min-width:40em){.grid-x>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.medium-shrink{width:auto}.grid-x>.medium-1{width:8.33333%}.grid-x>.medium-2{width:16.66667%}.grid-x>.medium-3{width:25%}.grid-x>.medium-4{width:33.33333%}.grid-x>.medium-5{width:41.66667%}.grid-x>.medium-6{width:50%}.grid-x>.medium-7{width:58.33333%}.grid-x>.medium-8{width:66.66667%}.grid-x>.medium-9{width:75%}.grid-x>.medium-10{width:83.33333%}.grid-x>.medium-11{width:91.66667%}.grid-x>.medium-12{width:100%}}@media print,screen and (min-width:64em){.grid-x>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.large-shrink{width:auto}.grid-x>.large-1{width:8.33333%}.grid-x>.large-2{width:16.66667%}.grid-x>.large-3{width:25%}.grid-x>.large-4{width:33.33333%}.grid-x>.large-5{width:41.66667%}.grid-x>.large-6{width:50%}.grid-x>.large-7{width:58.33333%}.grid-x>.large-8{width:66.66667%}.grid-x>.large-9{width:75%}.grid-x>.large-10{width:83.33333%}.grid-x>.large-11{width:91.66667%}.grid-x>.large-12{width:100%}}.grid-margin-x:not(.grid-x)>.cell{width:auto}.grid-margin-y:not(.grid-y)>.cell{height:auto}.grid-margin-x{margin-left:-.625rem;margin-right:-.625rem}@media print,screen and (min-width:40em){.grid-margin-x{margin-left:-.9375rem;margin-right:-.9375rem}}.grid-margin-x>.cell{width:calc(100% - 1.25rem);margin-left:.625rem;margin-right:.625rem}@media print,screen and (min-width:40em){.grid-margin-x>.cell{width:calc(100% - 1.875rem);margin-left:.9375rem;margin-right:.9375rem}}.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.25rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.25rem)}.grid-margin-x>.small-3{width:calc(25% - 1.25rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.25rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.25rem)}.grid-margin-x>.small-6{width:calc(50% - 1.25rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.25rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.25rem)}.grid-margin-x>.small-9{width:calc(75% - 1.25rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.25rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.25rem)}.grid-margin-x>.small-12{width:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.small-3{width:calc(25% - 1.875rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.small-6{width:calc(50% - 1.875rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.small-9{width:calc(75% - 1.875rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.small-12{width:calc(100% - 1.875rem)}.grid-margin-x>.medium-auto{width:auto}.grid-margin-x>.medium-shrink{width:auto}.grid-margin-x>.medium-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.medium-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.medium-3{width:calc(25% - 1.875rem)}.grid-margin-x>.medium-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.medium-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.medium-6{width:calc(50% - 1.875rem)}.grid-margin-x>.medium-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.medium-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.medium-9{width:calc(75% - 1.875rem)}.grid-margin-x>.medium-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.medium-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.medium-12{width:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x>.large-auto{width:auto}.grid-margin-x>.large-shrink{width:auto}.grid-margin-x>.large-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.large-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.large-3{width:calc(25% - 1.875rem)}.grid-margin-x>.large-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.large-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.large-6{width:calc(50% - 1.875rem)}.grid-margin-x>.large-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.large-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.large-9{width:calc(75% - 1.875rem)}.grid-margin-x>.large-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.large-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.large-12{width:calc(100% - 1.875rem)}}.grid-padding-x .grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-padding-x .grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-container:not(.full)>.grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-container:not(.full)>.grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-padding-x>.cell{padding-right:.625rem;padding-left:.625rem}@media print,screen and (min-width:40em){.grid-padding-x>.cell{padding-right:.9375rem;padding-left:.9375rem}}.small-up-1>.cell{width:100%}.small-up-2>.cell{width:50%}.small-up-3>.cell{width:33.33333%}.small-up-4>.cell{width:25%}.small-up-5>.cell{width:20%}.small-up-6>.cell{width:16.66667%}.small-up-7>.cell{width:14.28571%}.small-up-8>.cell{width:12.5%}@media print,screen and (min-width:40em){.medium-up-1>.cell{width:100%}.medium-up-2>.cell{width:50%}.medium-up-3>.cell{width:33.33333%}.medium-up-4>.cell{width:25%}.medium-up-5>.cell{width:20%}.medium-up-6>.cell{width:16.66667%}.medium-up-7>.cell{width:14.28571%}.medium-up-8>.cell{width:12.5%}}@media print,screen and (min-width:64em){.large-up-1>.cell{width:100%}.large-up-2>.cell{width:50%}.large-up-3>.cell{width:33.33333%}.large-up-4>.cell{width:25%}.large-up-5>.cell{width:20%}.large-up-6>.cell{width:16.66667%}.large-up-7>.cell{width:14.28571%}.large-up-8>.cell{width:12.5%}}.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.875rem)}.grid-margin-x.medium-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.medium-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.medium-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.medium-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.medium-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.medium-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.medium-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.medium-up-8>.cell{width:calc(12.5% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x.large-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.large-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.large-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.large-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.large-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.large-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.large-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.large-up-8>.cell{width:calc(12.5% - 1.875rem)}}.small-margin-collapse{margin-right:0;margin-left:0}.small-margin-collapse>.cell{margin-right:0;margin-left:0}.small-margin-collapse>.small-1{width:8.33333%}.small-margin-collapse>.small-2{width:16.66667%}.small-margin-collapse>.small-3{width:25%}.small-margin-collapse>.small-4{width:33.33333%}.small-margin-collapse>.small-5{width:41.66667%}.small-margin-collapse>.small-6{width:50%}.small-margin-collapse>.small-7{width:58.33333%}.small-margin-collapse>.small-8{width:66.66667%}.small-margin-collapse>.small-9{width:75%}.small-margin-collapse>.small-10{width:83.33333%}.small-margin-collapse>.small-11{width:91.66667%}.small-margin-collapse>.small-12{width:100%}@media print,screen and (min-width:40em){.small-margin-collapse>.medium-1{width:8.33333%}.small-margin-collapse>.medium-2{width:16.66667%}.small-margin-collapse>.medium-3{width:25%}.small-margin-collapse>.medium-4{width:33.33333%}.small-margin-collapse>.medium-5{width:41.66667%}.small-margin-collapse>.medium-6{width:50%}.small-margin-collapse>.medium-7{width:58.33333%}.small-margin-collapse>.medium-8{width:66.66667%}.small-margin-collapse>.medium-9{width:75%}.small-margin-collapse>.medium-10{width:83.33333%}.small-margin-collapse>.medium-11{width:91.66667%}.small-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.small-margin-collapse>.large-1{width:8.33333%}.small-margin-collapse>.large-2{width:16.66667%}.small-margin-collapse>.large-3{width:25%}.small-margin-collapse>.large-4{width:33.33333%}.small-margin-collapse>.large-5{width:41.66667%}.small-margin-collapse>.large-6{width:50%}.small-margin-collapse>.large-7{width:58.33333%}.small-margin-collapse>.large-8{width:66.66667%}.small-margin-collapse>.large-9{width:75%}.small-margin-collapse>.large-10{width:83.33333%}.small-margin-collapse>.large-11{width:91.66667%}.small-margin-collapse>.large-12{width:100%}}.small-padding-collapse{margin-right:0;margin-left:0}.small-padding-collapse>.cell{padding-right:0;padding-left:0}@media print,screen and (min-width:40em){.medium-margin-collapse{margin-right:0;margin-left:0}.medium-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:40em){.medium-margin-collapse>.small-1{width:8.33333%}.medium-margin-collapse>.small-2{width:16.66667%}.medium-margin-collapse>.small-3{width:25%}.medium-margin-collapse>.small-4{width:33.33333%}.medium-margin-collapse>.small-5{width:41.66667%}.medium-margin-collapse>.small-6{width:50%}.medium-margin-collapse>.small-7{width:58.33333%}.medium-margin-collapse>.small-8{width:66.66667%}.medium-margin-collapse>.small-9{width:75%}.medium-margin-collapse>.small-10{width:83.33333%}.medium-margin-collapse>.small-11{width:91.66667%}.medium-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:40em){.medium-margin-collapse>.medium-1{width:8.33333%}.medium-margin-collapse>.medium-2{width:16.66667%}.medium-margin-collapse>.medium-3{width:25%}.medium-margin-collapse>.medium-4{width:33.33333%}.medium-margin-collapse>.medium-5{width:41.66667%}.medium-margin-collapse>.medium-6{width:50%}.medium-margin-collapse>.medium-7{width:58.33333%}.medium-margin-collapse>.medium-8{width:66.66667%}.medium-margin-collapse>.medium-9{width:75%}.medium-margin-collapse>.medium-10{width:83.33333%}.medium-margin-collapse>.medium-11{width:91.66667%}.medium-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.medium-margin-collapse>.large-1{width:8.33333%}.medium-margin-collapse>.large-2{width:16.66667%}.medium-margin-collapse>.large-3{width:25%}.medium-margin-collapse>.large-4{width:33.33333%}.medium-margin-collapse>.large-5{width:41.66667%}.medium-margin-collapse>.large-6{width:50%}.medium-margin-collapse>.large-7{width:58.33333%}.medium-margin-collapse>.large-8{width:66.66667%}.medium-margin-collapse>.large-9{width:75%}.medium-margin-collapse>.large-10{width:83.33333%}.medium-margin-collapse>.large-11{width:91.66667%}.medium-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:40em){.medium-padding-collapse{margin-right:0;margin-left:0}.medium-padding-collapse>.cell{padding-right:0;padding-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse{margin-right:0;margin-left:0}.large-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse>.small-1{width:8.33333%}.large-margin-collapse>.small-2{width:16.66667%}.large-margin-collapse>.small-3{width:25%}.large-margin-collapse>.small-4{width:33.33333%}.large-margin-collapse>.small-5{width:41.66667%}.large-margin-collapse>.small-6{width:50%}.large-margin-collapse>.small-7{width:58.33333%}.large-margin-collapse>.small-8{width:66.66667%}.large-margin-collapse>.small-9{width:75%}.large-margin-collapse>.small-10{width:83.33333%}.large-margin-collapse>.small-11{width:91.66667%}.large-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.medium-1{width:8.33333%}.large-margin-collapse>.medium-2{width:16.66667%}.large-margin-collapse>.medium-3{width:25%}.large-margin-collapse>.medium-4{width:33.33333%}.large-margin-collapse>.medium-5{width:41.66667%}.large-margin-collapse>.medium-6{width:50%}.large-margin-collapse>.medium-7{width:58.33333%}.large-margin-collapse>.medium-8{width:66.66667%}.large-margin-collapse>.medium-9{width:75%}.large-margin-collapse>.medium-10{width:83.33333%}.large-margin-collapse>.medium-11{width:91.66667%}.large-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.large-1{width:8.33333%}.large-margin-collapse>.large-2{width:16.66667%}.large-margin-collapse>.large-3{width:25%}.large-margin-collapse>.large-4{width:33.33333%}.large-margin-collapse>.large-5{width:41.66667%}.large-margin-collapse>.large-6{width:50%}.large-margin-collapse>.large-7{width:58.33333%}.large-margin-collapse>.large-8{width:66.66667%}.large-margin-collapse>.large-9{width:75%}.large-margin-collapse>.large-10{width:83.33333%}.large-margin-collapse>.large-11{width:91.66667%}.large-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:64em){.large-padding-collapse{margin-right:0;margin-left:0}.large-padding-collapse>.cell{padding-right:0;padding-left:0}}.small-offset-0{margin-right:0}.grid-margin-x>.small-offset-0{margin-right:calc(0% + .625rem)}.small-offset-1{margin-right:8.33333%}.grid-margin-x>.small-offset-1{margin-right:calc(8.33333% + .625rem)}.small-offset-2{margin-right:16.66667%}.grid-margin-x>.small-offset-2{margin-right:calc(16.66667% + .625rem)}.small-offset-3{margin-right:25%}.grid-margin-x>.small-offset-3{margin-right:calc(25% + .625rem)}.small-offset-4{margin-right:33.33333%}.grid-margin-x>.small-offset-4{margin-right:calc(33.33333% + .625rem)}.small-offset-5{margin-right:41.66667%}.grid-margin-x>.small-offset-5{margin-right:calc(41.66667% + .625rem)}.small-offset-6{margin-right:50%}.grid-margin-x>.small-offset-6{margin-right:calc(50% + .625rem)}.small-offset-7{margin-right:58.33333%}.grid-margin-x>.small-offset-7{margin-right:calc(58.33333% + .625rem)}.small-offset-8{margin-right:66.66667%}.grid-margin-x>.small-offset-8{margin-right:calc(66.66667% + .625rem)}.small-offset-9{margin-right:75%}.grid-margin-x>.small-offset-9{margin-right:calc(75% + .625rem)}.small-offset-10{margin-right:83.33333%}.grid-margin-x>.small-offset-10{margin-right:calc(83.33333% + .625rem)}.small-offset-11{margin-right:91.66667%}.grid-margin-x>.small-offset-11{margin-right:calc(91.66667% + .625rem)}@media print,screen and (min-width:40em){.medium-offset-0{margin-right:0}.grid-margin-x>.medium-offset-0{margin-right:calc(0% + .9375rem)}.medium-offset-1{margin-right:8.33333%}.grid-margin-x>.medium-offset-1{margin-right:calc(8.33333% + .9375rem)}.medium-offset-2{margin-right:16.66667%}.grid-margin-x>.medium-offset-2{margin-right:calc(16.66667% + .9375rem)}.medium-offset-3{margin-right:25%}.grid-margin-x>.medium-offset-3{margin-right:calc(25% + .9375rem)}.medium-offset-4{margin-right:33.33333%}.grid-margin-x>.medium-offset-4{margin-right:calc(33.33333% + .9375rem)}.medium-offset-5{margin-right:41.66667%}.grid-margin-x>.medium-offset-5{margin-right:calc(41.66667% + .9375rem)}.medium-offset-6{margin-right:50%}.grid-margin-x>.medium-offset-6{margin-right:calc(50% + .9375rem)}.medium-offset-7{margin-right:58.33333%}.grid-margin-x>.medium-offset-7{margin-right:calc(58.33333% + .9375rem)}.medium-offset-8{margin-right:66.66667%}.grid-margin-x>.medium-offset-8{margin-right:calc(66.66667% + .9375rem)}.medium-offset-9{margin-right:75%}.grid-margin-x>.medium-offset-9{margin-right:calc(75% + .9375rem)}.medium-offset-10{margin-right:83.33333%}.grid-margin-x>.medium-offset-10{margin-right:calc(83.33333% + .9375rem)}.medium-offset-11{margin-right:91.66667%}.grid-margin-x>.medium-offset-11{margin-right:calc(91.66667% + .9375rem)}}@media print,screen and (min-width:64em){.large-offset-0{margin-right:0}.grid-margin-x>.large-offset-0{margin-right:calc(0% + .9375rem)}.large-offset-1{margin-right:8.33333%}.grid-margin-x>.large-offset-1{margin-right:calc(8.33333% + .9375rem)}.large-offset-2{margin-right:16.66667%}.grid-margin-x>.large-offset-2{margin-right:calc(16.66667% + .9375rem)}.large-offset-3{margin-right:25%}.grid-margin-x>.large-offset-3{margin-right:calc(25% + .9375rem)}.large-offset-4{margin-right:33.33333%}.grid-margin-x>.large-offset-4{margin-right:calc(33.33333% + .9375rem)}.large-offset-5{margin-right:41.66667%}.grid-margin-x>.large-offset-5{margin-right:calc(41.66667% + .9375rem)}.large-offset-6{margin-right:50%}.grid-margin-x>.large-offset-6{margin-right:calc(50% + .9375rem)}.large-offset-7{margin-right:58.33333%}.grid-margin-x>.large-offset-7{margin-right:calc(58.33333% + .9375rem)}.large-offset-8{margin-right:66.66667%}.grid-margin-x>.large-offset-8{margin-right:calc(66.66667% + .9375rem)}.large-offset-9{margin-right:75%}.grid-margin-x>.large-offset-9{margin-right:calc(75% + .9375rem)}.large-offset-10{margin-right:83.33333%}.grid-margin-x>.large-offset-10{margin-right:calc(83.33333% + .9375rem)}.large-offset-11{margin-right:91.66667%}.grid-margin-x>.large-offset-11{margin-right:calc(91.66667% + .9375rem)}}.grid-y{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.grid-y>.cell{width:auto;max-width:none}.grid-y>.auto{height:auto}.grid-y>.shrink{height:auto}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9,.grid-y>.small-full,.grid-y>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-full,.grid-y>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-full,.grid-y>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.small-1{height:8.33333%}.grid-y>.small-2{height:16.66667%}.grid-y>.small-3{height:25%}.grid-y>.small-4{height:33.33333%}.grid-y>.small-5{height:41.66667%}.grid-y>.small-6{height:50%}.grid-y>.small-7{height:58.33333%}.grid-y>.small-8{height:66.66667%}.grid-y>.small-9{height:75%}.grid-y>.small-10{height:83.33333%}.grid-y>.small-11{height:91.66667%}.grid-y>.small-12{height:100%}@media print,screen and (min-width:40em){.grid-y>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.medium-shrink{height:auto}.grid-y>.medium-1{height:8.33333%}.grid-y>.medium-2{height:16.66667%}.grid-y>.medium-3{height:25%}.grid-y>.medium-4{height:33.33333%}.grid-y>.medium-5{height:41.66667%}.grid-y>.medium-6{height:50%}.grid-y>.medium-7{height:58.33333%}.grid-y>.medium-8{height:66.66667%}.grid-y>.medium-9{height:75%}.grid-y>.medium-10{height:83.33333%}.grid-y>.medium-11{height:91.66667%}.grid-y>.medium-12{height:100%}}@media print,screen and (min-width:64em){.grid-y>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.large-shrink{height:auto}.grid-y>.large-1{height:8.33333%}.grid-y>.large-2{height:16.66667%}.grid-y>.large-3{height:25%}.grid-y>.large-4{height:33.33333%}.grid-y>.large-5{height:41.66667%}.grid-y>.large-6{height:50%}.grid-y>.large-7{height:58.33333%}.grid-y>.large-8{height:66.66667%}.grid-y>.large-9{height:75%}.grid-y>.large-10{height:83.33333%}.grid-y>.large-11{height:91.66667%}.grid-y>.large-12{height:100%}}.grid-padding-y .grid-padding-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-padding-y .grid-padding-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-padding-y>.cell{padding-top:.625rem;padding-bottom:.625rem}@media print,screen and (min-width:40em){.grid-padding-y>.cell{padding-top:.9375rem;padding-bottom:.9375rem}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .grid-frame{width:100%}.cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.cell-block-container{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;max-height:100%}.cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}@media print,screen and (min-width:40em){.medium-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .medium-grid-frame{width:100%}.medium-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.medium-cell-block-container{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;max-height:100%}.medium-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.medium-cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}}@media print,screen and (min-width:64em){.large-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .large-grid-frame{width:100%}.large-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.large-cell-block-container{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;max-height:100%}.large-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.large-cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}}.grid-y.grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}@media print,screen and (min-width:40em){.grid-y.medium-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}@media print,screen and (min-width:64em){.grid-y.large-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}.cell .grid-y.grid-frame{height:100%}@media print,screen and (min-width:40em){.cell .grid-y.medium-grid-frame{height:100%}}@media print,screen and (min-width:64em){.cell .grid-y.large-grid-frame{height:100%}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame.grid-margin-y{height:calc(100vh + 1.25rem)}@media print,screen and (min-width:40em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:40em){.grid-margin-y.medium-grid-frame{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y.large-grid-frame{height:calc(100vh + 1.875rem)}}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem 0;padding:.85em 1em;border:1px solid transparent;border-radius:0;-webkit-transition:background-color .25s ease-out,color .25s ease-out;transition:background-color .25s ease-out,color .25s ease-out;font-family:inherit;font-size:.9rem;-webkit-appearance:none;line-height:1;text-align:center;cursor:pointer;background-color:#1779ba;color:#fefefe}[data-whatinput=mouse] .button{outline:0}.button:focus,.button:hover{background-color:#14679e;color:#fefefe}.button.tiny{font-size:.6rem}.button.small{font-size:.75rem}.button.large{font-size:1.25rem}.button.expanded{display:block;width:100%;margin-right:0;margin-left:0}.button.primary{background-color:#1779ba;color:#fefefe}.button.primary:focus,.button.primary:hover{background-color:#126195;color:#fefefe}.button.secondary{background-color:#767676;color:#fefefe}.button.secondary:focus,.button.secondary:hover{background-color:#5e5e5e;color:#fefefe}.button.success{background-color:#3adb76;color:#0a0a0a}.button.success:focus,.button.success:hover{background-color:#22bb5b;color:#0a0a0a}.button.warning{background-color:#ffae00;color:#0a0a0a}.button.warning:focus,.button.warning:hover{background-color:#cc8b00;color:#0a0a0a}.button.alert{background-color:#cc4b37;color:#fefefe}.button.alert:focus,.button.alert:hover{background-color:#a53b2a;color:#fefefe}.button.disabled,.button[disabled]{opacity:.25;cursor:not-allowed}.button.disabled,.button.disabled:focus,.button.disabled:hover,.button[disabled],.button[disabled]:focus,.button[disabled]:hover{background-color:#1779ba;color:#fefefe}.button.disabled.primary,.button[disabled].primary{opacity:.25;cursor:not-allowed}.button.disabled.primary,.button.disabled.primary:focus,.button.disabled.primary:hover,.button[disabled].primary,.button[disabled].primary:focus,.button[disabled].primary:hover{background-color:#1779ba;color:#fefefe}.button.disabled.secondary,.button[disabled].secondary{opacity:.25;cursor:not-allowed}.button.disabled.secondary,.button.disabled.secondary:focus,.button.disabled.secondary:hover,.button[disabled].secondary,.button[disabled].secondary:focus,.button[disabled].secondary:hover{background-color:#767676;color:#fefefe}.button.disabled.success,.button[disabled].success{opacity:.25;cursor:not-allowed}.button.disabled.success,.button.disabled.success:focus,.button.disabled.success:hover,.button[disabled].success,.button[disabled].success:focus,.button[disabled].success:hover{background-color:#3adb76;color:#0a0a0a}.button.disabled.warning,.button[disabled].warning{opacity:.25;cursor:not-allowed}.button.disabled.warning,.button.disabled.warning:focus,.button.disabled.warning:hover,.button[disabled].warning,.button[disabled].warning:focus,.button[disabled].warning:hover{background-color:#ffae00;color:#0a0a0a}.button.disabled.alert,.button[disabled].alert{opacity:.25;cursor:not-allowed}.button.disabled.alert,.button.disabled.alert:focus,.button.disabled.alert:hover,.button[disabled].alert,.button[disabled].alert:focus,.button[disabled].alert:hover{background-color:#cc4b37;color:#fefefe}.button.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow.disabled,.button.hollow.disabled:focus,.button.hollow.disabled:hover,.button.hollow[disabled],.button.hollow[disabled]:focus,.button.hollow[disabled]:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow:focus.disabled,.button.hollow:focus[disabled],.button.hollow:hover.disabled,.button.hollow:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary:focus.disabled,.button.hollow.primary:focus[disabled],.button.hollow.primary:hover.disabled,.button.hollow.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.secondary:focus.disabled,.button.hollow.secondary:focus[disabled],.button.hollow.secondary:hover.disabled,.button.hollow.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.success:focus.disabled,.button.hollow.success:focus[disabled],.button.hollow.success:hover.disabled,.button.hollow.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.warning:focus.disabled,.button.hollow.warning:focus[disabled],.button.hollow.warning:hover.disabled,.button.hollow.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.button.hollow.alert:focus.disabled,.button.hollow.alert:focus[disabled],.button.hollow.alert:hover.disabled,.button.hollow.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear:focus,.button.clear:hover{background-color:transparent}.button.clear.disabled,.button.clear.disabled:focus,.button.clear.disabled:hover,.button.clear[disabled],.button.clear[disabled]:focus,.button.clear[disabled]:hover{background-color:transparent}.button.clear:focus,.button.clear:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover.disabled,.button.clear:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear.disabled,.button.clear:focus,.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover,.button.clear:hover.disabled,.button.clear:hover[disabled],.button.clear[disabled]{border-color:transparent}.button.clear.primary{border:1px solid #1779ba;color:#1779ba}.button.clear.primary:focus,.button.clear.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear.primary,.button.clear.primary.disabled,.button.clear.primary:focus,.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover,.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled],.button.clear.primary[disabled]{border-color:transparent}.button.clear.secondary{border:1px solid #767676;color:#767676}.button.clear.secondary:focus,.button.clear.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.clear.secondary,.button.clear.secondary.disabled,.button.clear.secondary:focus,.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover,.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled],.button.clear.secondary[disabled]{border-color:transparent}.button.clear.success{border:1px solid #3adb76;color:#3adb76}.button.clear.success:focus,.button.clear.success:hover{border-color:#157539;color:#157539}.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover.disabled,.button.clear.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.clear.success,.button.clear.success.disabled,.button.clear.success:focus,.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover,.button.clear.success:hover.disabled,.button.clear.success:hover[disabled],.button.clear.success[disabled]{border-color:transparent}.button.clear.warning{border:1px solid #ffae00;color:#ffae00}.button.clear.warning:focus,.button.clear.warning:hover{border-color:#805700;color:#805700}.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.clear.warning,.button.clear.warning.disabled,.button.clear.warning:focus,.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover,.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled],.button.clear.warning[disabled]{border-color:transparent}.button.clear.alert{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert:focus,.button.clear.alert:hover{border-color:#67251a;color:#67251a}.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert,.button.clear.alert.disabled,.button.clear.alert:focus,.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover,.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled],.button.clear.alert[disabled]{border-color:transparent}.button.dropdown::after{display:block;width:0;height:0;border:inset .4em;content:'';border-bottom-width:0;border-top-style:solid;border-color:#fefefe transparent transparent;position:relative;top:.4em;display:inline-block;float:left;margin-right:1em}.button.dropdown.clear::after,.button.dropdown.hollow::after{border-top-color:#1779ba}.button.dropdown.clear.primary::after,.button.dropdown.hollow.primary::after{border-top-color:#1779ba}.button.dropdown.clear.secondary::after,.button.dropdown.hollow.secondary::after{border-top-color:#767676}.button.dropdown.clear.success::after,.button.dropdown.hollow.success::after{border-top-color:#3adb76}.button.dropdown.clear.warning::after,.button.dropdown.hollow.warning::after{border-top-color:#ffae00}.button.dropdown.clear.alert::after,.button.dropdown.hollow.alert::after{border-top-color:#cc4b37}.button.arrow-only::after{top:-.1em;float:none;margin-right:0}a.button:focus,a.button:hover{text-decoration:none}.button-group{margin-bottom:1rem;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.button-group::after,.button-group::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.button-group::after{clear:both}.button-group .button{margin:0;margin-left:1px;margin-bottom:1px;font-size:.9rem;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.button-group .button:last-child{margin-left:0}.button-group.tiny .button{font-size:.6rem}.button-group.small .button{font-size:.75rem}.button-group.large .button{font-size:1.25rem}.button-group.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.button-group.primary .button{background-color:#1779ba;color:#fefefe}.button-group.primary .button:focus,.button-group.primary .button:hover{background-color:#126195;color:#fefefe}.button-group.secondary .button{background-color:#767676;color:#fefefe}.button-group.secondary .button:focus,.button-group.secondary .button:hover{background-color:#5e5e5e;color:#fefefe}.button-group.success .button{background-color:#3adb76;color:#0a0a0a}.button-group.success .button:focus,.button-group.success .button:hover{background-color:#22bb5b;color:#0a0a0a}.button-group.warning .button{background-color:#ffae00;color:#0a0a0a}.button-group.warning .button:focus,.button-group.warning .button:hover{background-color:#cc8b00;color:#0a0a0a}.button-group.alert .button{background-color:#cc4b37;color:#fefefe}.button-group.alert .button:focus,.button-group.alert .button:hover{background-color:#a53b2a;color:#fefefe}.button-group.stacked,.button-group.stacked-for-medium,.button-group.stacked-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.button-group.stacked .button,.button-group.stacked-for-medium .button,.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%}.button-group.stacked .button:last-child,.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child{margin-bottom:0}.button-group.stacked-for-medium.expanded .button,.button-group.stacked-for-small.expanded .button,.button-group.stacked.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}@media print,screen and (min-width:40em){.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin-bottom:0}}@media print,screen and (min-width:64em){.button-group.stacked-for-medium .button{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin-bottom:0}}@media screen and (max-width:39.99875em){.button-group.stacked-for-small.expanded{display:block}.button-group.stacked-for-small.expanded .button{display:block;margin-left:0}}@media screen and (max-width:63.99875em){.button-group.stacked-for-medium.expanded{display:block}.button-group.stacked-for-medium.expanded .button{display:block;margin-left:0}}.close-button{position:absolute;color:#8a8a8a;cursor:pointer}[data-whatinput=mouse] .close-button{outline:0}.close-button:focus,.close-button:hover{color:#0a0a0a}.close-button.small{right:.66rem;top:.33em;font-size:1.5em;line-height:1}.close-button,.close-button.medium{right:1rem;top:.5rem;font-size:2em;line-height:1}.label{display:inline-block;padding:.33333rem .5rem;border-radius:0;font-size:.8rem;line-height:1;white-space:nowrap;cursor:default;background:#1779ba;color:#fefefe}.label.primary{background:#1779ba;color:#fefefe}.label.secondary{background:#767676;color:#fefefe}.label.success{background:#3adb76;color:#0a0a0a}.label.warning{background:#ffae00;color:#0a0a0a}.label.alert{background:#cc4b37;color:#fefefe}.progress{height:1rem;margin-bottom:1rem;border-radius:0;background-color:#cacaca}.progress.primary .progress-meter{background-color:#1779ba}.progress.secondary .progress-meter{background-color:#767676}.progress.success .progress-meter{background-color:#3adb76}.progress.warning .progress-meter{background-color:#ffae00}.progress.alert .progress-meter{background-color:#cc4b37}.progress-meter{position:relative;display:block;width:0%;height:100%;background-color:#1779ba}.progress-meter-text{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);transform:translate(-50%,-50%);margin:0;font-size:.75rem;font-weight:700;color:#fefefe;white-space:nowrap}.slider{position:relative;height:.5rem;margin-top:1.25rem;margin-bottom:2.25rem;background-color:#e6e6e6;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none}.slider-fill{position:absolute;top:0;left:0;display:inline-block;max-width:100%;height:.5rem;background-color:#cacaca;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.slider-fill.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider-handle{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;-ms-touch-action:manipulation;touch-action:manipulation}[data-whatinput=mouse] .slider-handle{outline:0}.slider-handle:hover{background-color:#14679e}.slider-handle.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider.disabled,.slider[disabled]{opacity:.25;cursor:not-allowed}.slider.vertical{display:inline-block;width:.5rem;height:12.5rem;margin:0 1.25rem;-webkit-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scale(1,-1)}.slider.vertical .slider-fill{top:0;width:.5rem;max-height:100%}.slider.vertical .slider-handle{position:absolute;top:0;left:50%;width:1.4rem;height:1.4rem;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.slider:not(.vertical){-webkit-transform:scale(-1,1);-ms-transform:scale(-1,1);transform:scale(-1,1)}.switch{height:2rem;position:relative;margin-bottom:1rem;outline:0;font-size:.875rem;font-weight:700;color:#fefefe;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.switch-input{position:absolute;margin-bottom:0;opacity:0}.switch-paddle{position:relative;display:block;width:4rem;height:2rem;border-radius:0;background:#cacaca;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;font-weight:inherit;color:inherit;cursor:pointer}input+.switch-paddle{margin:0}.switch-paddle::after{position:absolute;top:.25rem;right:.25rem;display:block;width:1.5rem;height:1.5rem;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);border-radius:0;background:#fefefe;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;content:''}input:checked~.switch-paddle{background:#1779ba}input:checked~.switch-paddle::after{right:2.25rem}[data-whatinput=mouse] input:focus~.switch-paddle{outline:0}.switch-active,.switch-inactive{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.switch-active{right:8%;display:none}input:checked+label>.switch-active{display:block}.switch-inactive{left:15%}input:checked+label>.switch-inactive{display:none}.switch.tiny{height:1.5rem}.switch.tiny .switch-paddle{width:3rem;height:1.5rem;font-size:.625rem}.switch.tiny .switch-paddle::after{top:.25rem;right:.25rem;width:1rem;height:1rem}.switch.tiny input:checked~.switch-paddle::after{right:1.75rem}.switch.small{height:1.75rem}.switch.small .switch-paddle{width:3.5rem;height:1.75rem;font-size:.75rem}.switch.small .switch-paddle::after{top:.25rem;right:.25rem;width:1.25rem;height:1.25rem}.switch.small input:checked~.switch-paddle::after{right:2rem}.switch.large{height:2.5rem}.switch.large .switch-paddle{width:5rem;height:2.5rem;font-size:1rem}.switch.large .switch-paddle::after{top:.25rem;right:.25rem;width:2rem;height:2rem}.switch.large input:checked~.switch-paddle::after{right:2.75rem}table{border-collapse:collapse;width:100%;margin-bottom:1rem;border-radius:0}tbody,tfoot,thead{border:1px solid #f1f1f1;background-color:#fefefe}caption{padding:.5rem .625rem .625rem;font-weight:700}thead{background:#f8f8f8;color:#0a0a0a}tfoot{background:#f1f1f1;color:#0a0a0a}tfoot tr,thead tr{background:0 0}tfoot td,tfoot th,thead td,thead th{padding:.5rem .625rem .625rem;font-weight:700;text-align:right}tbody td,tbody th{padding:.5rem .625rem .625rem}tbody tr:nth-child(even){border-bottom:0;background-color:#f1f1f1}table.unstriped tbody{background-color:#fefefe}table.unstriped tbody tr{border-bottom:0;border-bottom:1px solid #f1f1f1;background-color:#fefefe}@media screen and (max-width:63.99875em){table.stack thead{display:none}table.stack tfoot{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}}table.scroll{display:block;width:100%;overflow-x:auto}table.hover thead tr:hover{background-color:#f3f3f3}table.hover tfoot tr:hover{background-color:#ececec}table.hover tbody tr:hover{background-color:#f9f9f9}table.hover:not(.unstriped) tr:nth-of-type(even):hover{background-color:#ececec}.table-scroll{overflow-x:auto}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center;background:#1779ba;color:#fefefe}.badge.primary{background:#1779ba;color:#fefefe}.badge.secondary{background:#767676;color:#fefefe}.badge.success{background:#3adb76;color:#0a0a0a}.badge.warning{background:#ffae00;color:#0a0a0a}.badge.alert{background:#cc4b37;color:#fefefe}.breadcrumbs{margin:0 0 1rem 0;list-style:none}.breadcrumbs::after,.breadcrumbs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.breadcrumbs::after{clear:both}.breadcrumbs li{float:right;font-size:.6875rem;color:#0a0a0a;cursor:default;text-transform:uppercase}.breadcrumbs li:not(:last-child)::after{position:relative;margin:0 .75rem;opacity:1;content:"\\";color:#cacaca}.breadcrumbs a{color:#1779ba}.breadcrumbs a:hover{text-decoration:underline}.breadcrumbs .disabled{color:#cacaca;cursor:not-allowed}.callout{position:relative;margin:0 0 1rem 0;padding:1rem;border:1px solid rgba(10,10,10,.25);border-radius:0;background-color:#fff;color:#0a0a0a}.callout>:first-child{margin-top:0}.callout>:last-child{margin-bottom:0}.callout.primary{background-color:#d7ecfa;color:#0a0a0a}.callout.secondary{background-color:#eaeaea;color:#0a0a0a}.callout.success{background-color:#e1faea;color:#0a0a0a}.callout.warning{background-color:#fff3d9;color:#0a0a0a}.callout.alert{background-color:#f7e4e1;color:#0a0a0a}.callout.small{padding-top:.5rem;padding-right:.5rem;padding-bottom:.5rem;padding-left:.5rem}.callout.large{padding-top:3rem;padding-right:3rem;padding-bottom:3rem;padding-left:3rem}.card{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-grow:1;-ms-flex-positive:1;flex-grow:1;margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;color:#0a0a0a}.card>:last-child{margin-bottom:0}.card-divider{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;padding:1rem;background:#e6e6e6}.card-divider>:last-child{margin-bottom:0}.card-section{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto;padding:1rem}.card-section>:last-child{margin-bottom:0}.card-image{min-height:1px}.dropdown-pane{position:absolute;z-index:10;display:none;width:300px;padding:1rem;visibility:hidden;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-opening{display:block}.dropdown-pane.is-open{display:block;visibility:visible}.dropdown-pane.tiny{width:100px}.dropdown-pane.small{width:200px}.dropdown-pane.large{width:400px}.pagination{margin-right:0;margin-bottom:1rem}.pagination::after,.pagination::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.pagination::after{clear:both}.pagination li{margin-left:.0625rem;border-radius:0;font-size:.875rem;display:none}.pagination li:first-child,.pagination li:last-child{display:inline-block}@media print,screen and (min-width:40em){.pagination li{display:inline-block}}.pagination a,.pagination button{display:block;padding:.1875rem .625rem;border-radius:0;color:#0a0a0a}.pagination a:hover,.pagination button:hover{background:#e6e6e6}.pagination .current{padding:.1875rem .625rem;background:#1779ba;color:#fefefe;cursor:default}.pagination .disabled{padding:.1875rem .625rem;color:#cacaca;cursor:not-allowed}.pagination .disabled:hover{background:0 0}.pagination .ellipsis::after{padding:.1875rem .625rem;content:'\2026';color:#0a0a0a}.pagination-previous a::before,.pagination-previous.disabled::before{display:inline-block;margin-left:.5rem;content:'\00ab'}.pagination-next a::after,.pagination-next.disabled::after{display:inline-block;margin-right:.5rem;content:'\00bb'}.has-tip{position:relative;display:inline-block;border-bottom:dotted 1px #8a8a8a;font-weight:700;cursor:help}.tooltip{position:absolute;top:calc(100% + .6495rem);z-index:1200;max-width:10rem;padding:.75rem;border-radius:0;background-color:#0a0a0a;font-size:80%;color:#fefefe}.tooltip::before{position:absolute}.tooltip.bottom::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;bottom:100%}.tooltip.bottom.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.top::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.top.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.left::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.right::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.tooltip.right.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.align-top::before{bottom:auto;top:10%}.tooltip.align-bottom::before{bottom:10%;top:auto}.tooltip.align-left::before{left:10%;right:auto}.tooltip.align-right::before{left:auto;right:10%}.accordion{margin-right:0;background:#fefefe;list-style-type:none}.accordion[disabled] .accordion-title{cursor:not-allowed}.accordion-item:first-child>:first-child{border-radius:0}.accordion-item:last-child>:last-child{border-radius:0}.accordion-title{position:relative;display:block;padding:1.25rem 1rem;border:1px solid #e6e6e6;border-bottom:0;font-size:.75rem;line-height:1;color:#1779ba}:last-child:not(.is-active)>.accordion-title{border-bottom:1px solid #e6e6e6;border-radius:0}.accordion-title:focus,.accordion-title:hover{background-color:#e6e6e6}.accordion-title::before{position:absolute;top:50%;left:1rem;margin-top:-.5rem;content:'+'}.is-active>.accordion-title::before{content:'\2013'}.accordion-content{display:none;padding:1rem;border:1px solid #e6e6e6;border-bottom:0;background-color:#fefefe;color:#0a0a0a}:last-child>.accordion-content:last-child{border-bottom:1px solid #e6e6e6}.media-object{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;margin-bottom:1rem;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.media-object img{max-width:none}@media screen and (max-width:39.99875em){.media-object.stack-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}}.media-object-section{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.media-object-section:first-child{padding-left:1rem}.media-object-section:last-child:not(:nth-child(2)){padding-right:1rem}.media-object-section>:last-child{margin-bottom:0}@media screen and (max-width:39.99875em){.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;-webkit-flex-basis:100%;-ms-flex-preferred-size:100%;flex-basis:100%;max-width:100%}.stack-for-small .media-object-section img{width:100%}}.media-object-section.main-section{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.orbit{position:relative}.orbit-container{position:relative;height:0;margin:0;list-style:none;overflow:hidden}.orbit-slide{width:100%;position:absolute}.orbit-slide.no-motionui.is-active{top:0;left:0}.orbit-figure{margin:0}.orbit-image{width:100%;max-width:100%;margin:0}.orbit-caption{position:absolute;bottom:0;width:100%;margin-bottom:0;padding:1rem;background-color:rgba(10,10,10,.5);color:#fefefe}.orbit-next,.orbit-previous{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);z-index:10;padding:1rem;color:#fefefe}[data-whatinput=mouse] .orbit-next,[data-whatinput=mouse] .orbit-previous{outline:0}.orbit-next:active,.orbit-next:focus,.orbit-next:hover,.orbit-previous:active,.orbit-previous:focus,.orbit-previous:hover{background-color:rgba(10,10,10,.5)}.orbit-previous{right:0}.orbit-next{right:auto;left:0}.orbit-bullets{position:relative;margin-top:.8rem;margin-bottom:.8rem;text-align:center}[data-whatinput=mouse] .orbit-bullets{outline:0}.orbit-bullets button{width:1.2rem;height:1.2rem;margin:.1rem;border-radius:50%;background-color:#cacaca}.orbit-bullets button:hover{background-color:#8a8a8a}.orbit-bullets button.is-active{background-color:#8a8a8a}.flex-video,.responsive-embed{position:relative;height:0;margin-bottom:1rem;padding-bottom:75%;overflow:hidden}.flex-video embed,.flex-video iframe,.flex-video object,.flex-video video,.responsive-embed embed,.responsive-embed iframe,.responsive-embed object,.responsive-embed video{position:absolute;top:0;right:0;width:100%;height:100%}.flex-video.widescreen,.responsive-embed.widescreen{padding-bottom:56.25%}.tabs{margin:0;border:1px solid #e6e6e6;background:#fefefe;list-style-type:none}.tabs::after,.tabs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.tabs::after{clear:both}.tabs.vertical>li{display:block;float:none;width:auto}.tabs.simple>li>a{padding:0}.tabs.simple>li>a:hover{background:0 0}.tabs.primary{background:#1779ba}.tabs.primary>li>a{color:#fefefe}.tabs.primary>li>a:focus,.tabs.primary>li>a:hover{background:#1673b1}.tabs-title{float:right}.tabs-title>a{display:block;padding:1.25rem 1.5rem;font-size:.75rem;line-height:1;color:#1779ba}[data-whatinput=mouse] .tabs-title>a{outline:0}.tabs-title>a:hover{background:#fefefe;color:#1468a0}.tabs-title>a:focus,.tabs-title>a[aria-selected=true]{background:#e6e6e6;color:#1779ba}.tabs-content{border:1px solid #e6e6e6;border-top:0;background:#fefefe;color:#0a0a0a;-webkit-transition:all .5s ease;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-right:0}.tabs-panel{display:none;padding:1rem}.tabs-panel.is-active{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:4px solid #fefefe;border-radius:0;-webkit-box-shadow:0 0 0 1px rgba(10,10,10,.2);box-shadow:0 0 0 1px rgba(10,10,10,.2);line-height:0}a.thumbnail{-webkit-transition:-webkit-box-shadow .2s ease-out;transition:-webkit-box-shadow .2s ease-out;transition:box-shadow .2s ease-out;transition:box-shadow .2s ease-out,-webkit-box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{-webkit-box-shadow:0 0 6px 1px rgba(23,121,186,.5);box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{-webkit-box-shadow:none;box-shadow:none}.menu{padding:0;margin:0;list-style:none;position:relative;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}[data-whatinput=mouse] .menu li{outline:0}.menu .button,.menu a{line-height:1;text-decoration:none;display:block;padding:.7rem 1rem}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu input{display:inline-block}.menu,.menu.horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.simple{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.menu.simple li+li{margin-right:1rem}.menu.simple a{padding:0}@media print,screen and (min-width:40em){.menu.medium-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.medium-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.medium-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.medium-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}@media print,screen and (min-width:64em){.menu.large-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.large-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.large-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.large-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}.menu.nested{margin-left:0;margin-right:1rem}.menu.icons a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-bottom a,.menu.icon-left a,.menu.icon-right a,.menu.icon-top a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-left li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-left li a i,.menu.icon-left li a img,.menu.icon-left li a svg{margin-left:.25rem}.menu.icon-right li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-right li a i,.menu.icon-right li a img,.menu.icon-right li a svg{margin-right:.25rem}.menu.icon-top li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-top li a i,.menu.icon-top li a img,.menu.icon-top li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu.icon-bottom li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-bottom li a i,.menu.icon-bottom li a img,.menu.icon-bottom li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu .is-active>a{background:#1779ba;color:#fefefe}.menu .active>a{background:#1779ba;color:#fefefe}.menu.align-right{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-left li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.menu.align-left li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-left.vertical li{display:block;text-align:left}.menu.align-left.vertical li .submenu li{text-align:left}.menu.align-left .nested{margin-left:1rem;margin-right:0}.menu.align-center li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu.align-center li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu .menu-text{padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered>.menu{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.no-js [data-responsive-menu] ul{display:none}.menu-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#fefefe;-webkit-box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:''}.menu-icon:hover::after{background:#cacaca;-webkit-box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.menu-icon.dark{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon.dark::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;-webkit-box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:''}.menu-icon.dark:hover::after{background:#8a8a8a;-webkit-box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a;box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a}.accordion-menu li{width:100%}.accordion-menu a{padding:.7rem 1rem}.accordion-menu .is-accordion-submenu a{padding:.7rem 1rem}.accordion-menu .nested.is-accordion-submenu{margin-left:0;margin-right:1rem}.accordion-menu.align-left .nested.is-accordion-submenu{margin-left:1rem;margin-right:0}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a{position:relative}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;left:1rem}.accordion-menu.align-left .is-accordion-submenu-parent>a::after{right:1rem;left:auto}.accordion-menu.align-right .is-accordion-submenu-parent>a::after{right:auto;left:1rem}.accordion-menu .is-accordion-submenu-parent[aria-expanded=true]>a::after{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.is-accordion-submenu-parent{position:relative}.has-submenu-toggle>a{margin-left:40px}.submenu-toggle{position:absolute;top:0;left:0;width:40px;height:40px;cursor:pointer}.submenu-toggle::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;top:0;bottom:0;margin:auto}.submenu-toggle[aria-expanded=true]::after{-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.submenu-toggle-text{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.is-drilldown{position:relative;overflow:hidden}.is-drilldown li{display:block}.is-drilldown.animate-height{-webkit-transition:height .5s;transition:height .5s}.drilldown a{padding:.7rem 1rem;background:#fefefe}.drilldown .is-drilldown-submenu{position:absolute;top:0;right:100%;z-index:-1;width:100%;background:#fefefe;-webkit-transition:-webkit-transform .15s linear;transition:-webkit-transform .15s linear;transition:transform .15s linear;transition:transform .15s linear,-webkit-transform .15s linear}.drilldown .is-drilldown-submenu.is-active{z-index:1;display:block;-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%)}.drilldown .is-drilldown-submenu.is-closing{-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%)}.drilldown .is-drilldown-submenu a{padding:.7rem 1rem}.drilldown .nested.is-drilldown-submenu{margin-left:0;margin-right:0}.drilldown .drilldown-submenu-cover-previous{min-height:100%}.drilldown .is-drilldown-submenu-parent>a{position:relative}.drilldown .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;position:absolute;top:50%;margin-top:-6px;left:1rem}.drilldown.align-left .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;right:1rem;left:auto}.drilldown.align-right .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:1rem}.drilldown .js-drilldown-back>a::before{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;display:inline-block;vertical-align:middle;margin-left:.75rem}.dropdown.menu>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu>li.is-dropdown-submenu-parent>a{position:relative;padding-left:1.5rem}.dropdown.menu>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;left:5px;right:auto;margin-top:-3px}[data-whatinput=mouse] .dropdown.menu a{outline:0}.dropdown.menu>li>a{padding:.7rem 1rem}.dropdown.menu>li.is-active>a{background:0 0;color:#1779ba}.no-js .dropdown.menu ul{display:none}.dropdown.menu .nested.is-dropdown-submenu{margin-left:0;margin-right:0}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.vertical>li>a::after{left:14px}.dropdown.menu.vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}@media print,screen and (min-width:40em){.dropdown.menu.medium-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.medium-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-left:1.5rem}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;left:5px;right:auto;margin-top:-3px}.dropdown.menu.medium-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.medium-vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.medium-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.medium-vertical>li>a::after{left:14px}.dropdown.menu.medium-vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.medium-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}@media print,screen and (min-width:64em){.dropdown.menu.large-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.large-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-left:1.5rem}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;left:5px;right:auto;margin-top:-3px}.dropdown.menu.large-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.large-vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.large-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.large-vertical>li>a::after{left:14px}.dropdown.menu.large-vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.large-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}.dropdown.menu.align-right .is-dropdown-submenu.first-sub{top:100%;right:0;left:auto}.is-dropdown-menu.vertical{width:100px}.is-dropdown-menu.vertical.align-right{float:right}.is-dropdown-submenu-parent{position:relative}.is-dropdown-submenu-parent a::after{position:absolute;top:50%;left:5px;right:auto;margin-top:-6px}.is-dropdown-submenu-parent.opens-inner>.is-dropdown-submenu{top:100%;right:auto}.is-dropdown-submenu-parent.opens-left>.is-dropdown-submenu{right:100%;left:auto}.is-dropdown-submenu-parent.opens-right>.is-dropdown-submenu{right:auto;left:100%}.is-dropdown-submenu{position:absolute;top:0;right:100%;z-index:1;display:none;min-width:200px;border:1px solid #cacaca;background:#fefefe}.dropdown .is-dropdown-submenu a{padding:.7rem 1rem}.is-dropdown-submenu .is-dropdown-submenu-parent>a::after{left:14px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.is-dropdown-submenu .is-dropdown-submenu{margin-top:-1px}.is-dropdown-submenu>li{width:100%}.is-dropdown-submenu.js-dropdown-active{display:block}.is-off-canvas-open{overflow:hidden}.js-off-canvas-overlay{position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;-webkit-transition:opacity .5s ease,visibility .5s ease;transition:opacity .5s ease,visibility .5s ease;background:rgba(254,254,254,.25);opacity:0;visibility:hidden;overflow:hidden}.js-off-canvas-overlay.is-visible{opacity:1;visibility:visible}.js-off-canvas-overlay.is-closable{cursor:pointer}.js-off-canvas-overlay.is-overlay-absolute{position:absolute}.js-off-canvas-overlay.is-overlay-fixed{position:fixed}.off-canvas-wrapper{position:relative;overflow:hidden}.off-canvas{position:fixed;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-push{z-index:12}.off-canvas.is-closed{visibility:hidden}.off-canvas.is-transition-overlap{z-index:13}.off-canvas.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-absolute{position:absolute;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas-absolute{outline:0}.off-canvas-absolute.is-transition-push{z-index:12}.off-canvas-absolute.is-closed{visibility:hidden}.off-canvas-absolute.is-transition-overlap{z-index:13}.off-canvas-absolute.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas-absolute.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.position-left{top:0;left:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-left.has-transition-push{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.position-left.is-transition-push{-webkit-box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25)}.position-right{top:0;right:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-right.has-transition-push{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.position-right.is-transition-push{-webkit-box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25)}.position-top{top:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-top.has-transition-push{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.position-top.is-transition-push{-webkit-box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25)}.position-bottom{bottom:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-bottom.has-transition-push{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.position-bottom.is-transition-push{-webkit-box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25)}.off-canvas-content{-webkit-transform:none;-ms-transform:none;transform:none;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.off-canvas-content.has-transition-push{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content .off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}@media print,screen and (min-width:40em){.position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-medium .close-button{display:none}.off-canvas-content .position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-medium .close-button{display:none}.off-canvas-content .position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-medium .close-button{display:none}.off-canvas-content .position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-medium .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:64em){.position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-large .close-button{display:none}.off-canvas-content .position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-large .close-button{display:none}.off-canvas-content .position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-large .close-button{display:none}.off-canvas-content .position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-large .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:40em){.off-canvas.in-canvas-for-medium{visibility:visible;height:auto;position:static;background:0 0;width:auto;overflow:visible;-webkit-transition:none;transition:none}.off-canvas.in-canvas-for-medium.position-bottom,.off-canvas.in-canvas-for-medium.position-left,.off-canvas.in-canvas-for-medium.position-right,.off-canvas.in-canvas-for-medium.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-medium .close-button{display:none}}@media print,screen and (min-width:64em){.off-canvas.in-canvas-for-large{visibility:visible;height:auto;position:static;background:0 0;width:auto;overflow:visible;-webkit-transition:none;transition:none}.off-canvas.in-canvas-for-large.position-bottom,.off-canvas.in-canvas-for-large.position-left,.off-canvas.in-canvas-for-large.position-right,.off-canvas.in-canvas-for-large.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-large .close-button{display:none}}html.is-reveal-open{position:fixed;width:100%;overflow-y:hidden}html.is-reveal-open.zf-has-scroll{overflow-y:scroll}html.is-reveal-open body{overflow-y:hidden}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;display:none;background-color:rgba(10,10,10,.45);overflow-y:auto}.reveal{z-index:1006;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:none;padding:1rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;position:relative;top:100px;margin-right:auto;margin-left:auto;overflow-y:auto}[data-whatinput=mouse] .reveal{outline:0}@media print,screen and (min-width:40em){.reveal{min-height:0}}.reveal .column{min-width:0}.reveal>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.reveal{width:600px;max-width:75rem}}.reveal.collapse{padding:0}@media print,screen and (min-width:40em){.reveal.tiny{width:30%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.small{width:50%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.large{width:90%;max-width:75rem}}.reveal.full{top:0;right:0;bottom:0;left:0;width:100%;max-width:none;height:100%;min-height:100%;margin-left:0;border:0;border-radius:0}@media screen and (max-width:39.99875em){.reveal{top:0;right:0;bottom:0;left:0;width:100%;max-width:none;height:100%;min-height:100%;margin-left:0;border:0;border-radius:0}}.reveal.without-overlay{position:fixed}.sticky-container{position:relative}.sticky{position:relative;z-index:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.sticky.is-stuck{position:fixed;z-index:5;width:100%}.sticky.is-stuck.is-at-top{top:0}.sticky.is-stuck.is-at-bottom{bottom:0}.sticky.is-anchored{position:relative;right:auto;left:auto}.sticky.is-anchored.is-at-bottom{bottom:0}.title-bar{padding:.5rem;background:#0a0a0a;color:#fefefe;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.title-bar .menu-icon{margin-right:.25rem;margin-left:.25rem}.title-bar-left,.title-bar-right{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.title-bar-right{text-align:right}.title-bar-title{display:inline-block;vertical-align:middle;font-weight:700}.top-bar{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;padding:.5rem;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar,.top-bar ul{background-color:#e6e6e6}.top-bar input{max-width:200px;margin-left:1rem}.top-bar .input-group-field{width:100%;margin-left:0}.top-bar input.button{width:auto}.top-bar .top-bar-left,.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}@media print,screen and (min-width:40em){.top-bar{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.top-bar .top-bar-left{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;margin-right:auto}.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;margin-left:auto}}@media screen and (max-width:63.99875em){.top-bar.stacked-for-medium{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}@media screen and (max-width:74.99875em){.top-bar.stacked-for-large{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-large .top-bar-left,.top-bar.stacked-for-large .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}.top-bar-title{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin:.5rem 1rem .5rem 0}.top-bar-left,.top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.float-left{float:left!important}.float-right{float:right!important}.float-center{display:block;margin-right:auto;margin-left:auto}.clearfix::after,.clearfix::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.clearfix::after{clear:both}.align-left{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-right{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.align-center{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-justify{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between}.align-spaced{-webkit-justify-content:space-around;-ms-flex-pack:distribute;justify-content:space-around}.align-left.vertical.menu>li>a{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-right.vertical.menu>li>a{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.align-center.vertical.menu>li>a{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-top{-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start}.align-self-top{-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start}.align-bottom{-webkit-box-align:end;-webkit-align-items:flex-end;-ms-flex-align:end;align-items:flex-end}.align-self-bottom{-webkit-align-self:flex-end;-ms-flex-item-align:end;align-self:flex-end}.align-middle{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.align-self-middle{-webkit-align-self:center;-ms-flex-item-align:center;align-self:center}.align-stretch{-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.align-self-stretch{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch}.align-center-middle{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-align-content:center;-ms-flex-line-pack:center;align-content:center}.small-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.small-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.small-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.small-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.small-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.small-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}@media print,screen and (min-width:40em){.medium-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.medium-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.medium-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.medium-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.medium-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.medium-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}@media print,screen and (min-width:64em){.large-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.large-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.large-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.large-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.large-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.large-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}.flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}@media print,screen and (min-width:40em){.medium-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.medium-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.medium-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.medium-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.medium-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.medium-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.medium-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.medium-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}@media print,screen and (min-width:64em){.large-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.large-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.large-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.large-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.large-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.large-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.large-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.large-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}.hide{display:none!important}.invisible{visibility:hidden}@media screen and (max-width:39.99875em){.hide-for-small-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media print,screen and (min-width:40em){.hide-for-medium{display:none!important}}@media screen and (max-width:39.99875em){.show-for-medium{display:none!important}}@media screen and (min-width:40em) and (max-width:63.99875em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:39.99875em),screen and (min-width:64em){.show-for-medium-only{display:none!important}}@media print,screen and (min-width:64em){.hide-for-large{display:none!important}}@media screen and (max-width:63.99875em){.show-for-large{display:none!important}}@media screen and (min-width:64em) and (max-width:74.99875em){.hide-for-large-only{display:none!important}}@media screen and (max-width:63.99875em),screen and (min-width:75em){.show-for-large-only{display:none!important}}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}.hide-for-portrait,.show-for-landscape{display:block!important}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}}.hide-for-landscape,.show-for-portrait{display:none!important}@media screen and (orientation:landscape){.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-landscape,.show-for-portrait{display:block!important}}
+/*# sourceMappingURL=foundation-rtl.min.css.map */
diff --git a/dist/css/foundation-rtl.min.css.map b/dist/css/foundation-rtl.min.css.map
new file mode 100644 (file)
index 0000000..6749185
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation-rtl.min.css"],"names":[],"mappings":"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E,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,UACT,mBACE,MAAO,MAEX,aAAc,4BACZ,oBACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,IACd,SAAU,EAAE,EAAE,IACV,KAAM,EAAE,EAAE,IAClB,MAAO,KACgB,iBAAoL,kBAAqB,kBAAqB,kBAA1M,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAzL,sBACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KACpB,sBACE,MAAO,KACT,iBACE,MAAO,SACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,iBACE,MAAO,UACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,iBACE,MAAO,UACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,UACT,kBACE,MAAO,MAEX,kCACE,MAAO,KAET,kCACE,OAAQ,KAEV,eACE,YAAa,SACb,aAAc,SACd,aAAc,4BACZ,eACE,YAAa,UACb,aAAc,WAClB,qBACE,MAAO,qBACP,YAAa,QACb,aAAc,QAChB,aAAc,4BACZ,qBACE,MAAO,sBACP,YAAa,SACb,aAAc,UAClB,qBACE,MAAO,KACT,uBACE,MAAO,KACT,wBACE,MAAO,yBACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,wBACE,MAAO,0BACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,wBACE,MAAO,0BACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,yBACE,MAAO,0BACT,yBACE,MAAO,0BACT,yBACE,MAAO,qBACT,aAAc,4BACZ,qBACE,MAAO,KACT,uBACE,MAAO,KACT,wBACE,MAAO,0BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,sBACT,4BACE,MAAO,KACT,8BACE,MAAO,KACT,yBACE,MAAO,0BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,0BACE,MAAO,2BACT,0BACE,MAAO,2BACT,0BACE,MAAO,uBACX,aAAc,4BACZ,2BACE,MAAO,KACT,6BACE,MAAO,KACT,wBACE,MAAO,0BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,uBAEb,gCACE,aAAc,SACd,YAAa,SACb,aAAc,4BACZ,gCACE,aAAc,UACd,YAAa,WAEnB,2CACE,aAAc,SACd,YAAa,SACb,aAAc,4BACZ,2CACE,aAAc,UACd,YAAa,WAEnB,sBACE,cAAe,QACf,aAAc,QACd,aAAc,4BACZ,sBACE,cAAe,SACf,aAAc,UAEpB,kBACE,MAAO,KAET,kBACE,MAAO,IAET,kBACE,MAAO,UAET,kBACE,MAAO,IAET,kBACE,MAAO,IAET,kBACE,MAAO,UAET,kBACE,MAAO,UAET,kBACE,MAAO,MAET,aAAc,4BACZ,mBACE,MAAO,KACT,mBACE,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,IACT,mBACE,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,UACT,mBACE,MAAO,OAEX,aAAc,4BACZ,kBACE,MAAO,KACT,kBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,IACT,kBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,UACT,kBACE,MAAO,OAEX,gCACE,MAAO,qBAET,gCACE,MAAO,oBAET,gCACE,MAAO,0BAET,gCACE,MAAO,oBAET,gCACE,MAAO,oBAET,gCACE,MAAO,0BAET,gCACE,MAAO,0BAET,gCACE,MAAO,sBAET,aAAc,4BACZ,gCACE,MAAO,sBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,qBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,2BACT,gCACE,MAAO,uBACT,iCACE,MAAO,sBACT,iCACE,MAAO,qBACT,iCACE,MAAO,2BACT,iCACE,MAAO,qBACT,iCACE,MAAO,qBACT,iCACE,MAAO,2BACT,iCACE,MAAO,2BACT,iCACE,MAAO,wBAEX,aAAc,4BACZ,gCACE,MAAO,sBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,qBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,2BACT,gCACE,MAAO,wBAEX,uBACE,aAAc,EACd,YAAa,EACb,6BACE,aAAc,EACd,YAAa,EACf,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,KACT,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MACX,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,MAEb,wBACE,aAAc,EACd,YAAa,EACb,8BACE,cAAe,EACf,aAAc,EAElB,aAAc,4BACZ,wBACE,aAAc,EACd,YAAa,EACb,8BACE,aAAc,EACd,YAAa,GAEnB,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,kCACE,MAAO,SACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,mCACE,MAAO,UACT,mCACE,MAAO,UACT,mCACE,MAAO,MAEX,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,yBACE,aAAc,EACd,YAAa,EACb,+BACE,cAAe,EACf,aAAc,GAEpB,aAAc,4BACZ,uBACE,aAAc,EACd,YAAa,EACb,6BACE,aAAc,EACd,YAAa,GAEnB,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,MAEX,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gC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","file":"foundation-rtl.min.css","sourcesContent":[]}
\ No newline at end of file
index d114bf90bf598cccb1bda261cbf6ff9b7bdee3d6..1cb96e18f1b70e41e73b114855149652d91a607e 100644 (file)
@@ -1,7 +1,7 @@
 @charset "UTF-8";
 /**
  * Foundation for Sites by ZURB
- * Version 6.4.3
+ * Version 6.5.3
  * foundation.zurb.com
  * Licensed under MIT Open Source
  */
     left: auto;
     margin: 0 auto; } }
 
-/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */
-/* Document
-       ========================================================================== */
-/**
-     * 1. Change the default font family in all browsers (opinionated).
-     * 2. Correct the line height in all browsers.
-     * 3. Prevent adjustments of font size after orientation changes in
-     *    IE on Windows Phone and in iOS.
-     */
+/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */
 html {
-  font-family: sans-serif;
-  /* 1 */
   line-height: 1.15;
-  /* 2 */
-  -ms-text-size-adjust: 100%;
-  /* 3 */
-  -webkit-text-size-adjust: 100%;
-  /* 3 */ }
-
-/* Sections
-       ========================================================================== */
-/**
-     * Remove the margin in all browsers (opinionated).
-     */
+  -webkit-text-size-adjust: 100%; }
+
 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-.
-     */
-figcaption,
-figure {
-  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 */ }
-
-/**
-     * Add the correct display in IE.
-     */
-main {
-  display: block; }
+  overflow: visible; }
 
-/**
-     * 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 */ }
+  font-size: 1em; }
 
-/* Links
-       ========================================================================== */
-/**
-     * 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 */ }
+  background-color: transparent; }
 
-/**
-     * Remove the outline on focused links when they are also active or hovered
-     * in all browsers (opinionated).
-     */
-a:active,
-a:hover {
-  outline-width: 0; }
-
-/* Text-level semantics
-       ========================================================================== */
-/**
-     * 1. Remove the bottom border in 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 */
-  text-decoration: underline dotted;
-  /* 2 */ }
+  -webkit-text-decoration: underline dotted;
+          text-decoration: underline dotted; }
 
-/**
-     * 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; }
+  font-size: 1em; }
 
-/**
-     * 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%;
@@ -197,237 +68,94 @@ sub {
 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-family: inherit;
   font-size: 100%;
-  /* 1 */
   line-height: 1.15;
-  /* 1 */
-  margin: 0;
-  /* 2 */ }
+  margin: 0; }
 
-/**
-     * Show the overflow in IE.
-     */
-button {
+button,
+input {
   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 */ }
-
 button,
 [type="button"],
 [type="reset"],
 [type="submit"] {
-  /**
-       * Remove the inner border and padding in Firefox.
-       */
-  /**
-       * Restore the focus styles unset by the previous rule.
-       */ }
-  button::-moz-focus-inner,
-  [type="button"]::-moz-focus-inner,
-  [type="reset"]::-moz-focus-inner,
-  [type="submit"]::-moz-focus-inner {
-    border-style: none;
-    padding: 0; }
-  button:-moz-focusring,
-  [type="button"]:-moz-focusring,
-  [type="reset"]:-moz-focusring,
-  [type="submit"]:-moz-focusring {
-    outline: 1px dotted ButtonText; }
-
-/**
-     * Show the overflow in Edge.
-     */
-input {
-  overflow: visible; }
-
-/**
-     * 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 */ }
+  -webkit-appearance: button; }
 
-/**
-     * 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; }
+button::-moz-focus-inner,
+[type="button"]::-moz-focus-inner,
+[type="reset"]::-moz-focus-inner,
+[type="submit"]::-moz-focus-inner {
+  border-style: none;
+  padding: 0; }
 
-/**
-     * 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 */ }
+button:-moz-focusring,
+[type="button"]:-moz-focusring,
+[type="reset"]:-moz-focusring,
+[type="submit"]:-moz-focusring {
+  outline: 1px dotted ButtonText; }
 
-/**
-     * Change the border, margin, and padding in all browsers (opinionated).
-     */
 fieldset {
-  border: 1px solid #c0c0c0;
-  margin: 0 2px;
-  padding: 0.35em 0.625em 0.75em; }
+  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;
   display: table;
-  /* 1 */
   max-width: 100%;
-  /* 1 */
   padding: 0;
-  /* 3 */
-  color: inherit;
-  /* 2 */
-  white-space: normal;
-  /* 1 */ }
+  white-space: normal; }
 
-/**
-     * 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 */ }
+  vertical-align: baseline; }
 
-/**
-     * Remove the default vertical scrollbar in IE.
-     */
 textarea {
   overflow: auto; }
 
-/* Interactive
-       ========================================================================== */
-/*
-     * Add the correct display in Edge, IE, and Firefox.
-     */
+[type="checkbox"],
+[type="radio"] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  padding: 0; }
+
+[type="number"]::-webkit-inner-spin-button,
+[type="number"]::-webkit-outer-spin-button {
+  height: auto; }
+
+[type="search"] {
+  -webkit-appearance: textfield;
+  outline-offset: -2px; }
+
+[type="search"]::-webkit-search-decoration {
+  -webkit-appearance: none; }
+
+::-webkit-file-upload-button {
+  -webkit-appearance: button;
+  font: inherit; }
+
 details {
   display: block; }
 
-/*
-     * Add the correct display in all browsers.
-     */
 summary {
   display: list-item; }
 
-/*
-     * Add the correct display in IE 9-.
-     */
-menu {
-  display: block; }
-
-/* 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; }
 
@@ -511,3974 +239,3307 @@ textarea {
 .is-hidden {
   display: none !important; }
 
-.grid-container {
-  padding-right: 0.625rem;
-  padding-left: 0.625rem;
-  max-width: 75rem;
-  margin: 0 auto; }
-  @media print, screen and (min-width: 40em) {
-    .grid-container {
-      padding-right: 0.9375rem;
-      padding-left: 0.9375rem; } }
-  .grid-container.fluid {
-    padding-right: 0.625rem;
-    padding-left: 0.625rem;
-    max-width: 100%;
-    margin: 0 auto; }
-    @media print, screen and (min-width: 40em) {
-      .grid-container.fluid {
-        padding-right: 0.9375rem;
-        padding-left: 0.9375rem; } }
-  .grid-container.full {
-    padding-right: 0;
-    padding-left: 0;
-    max-width: 100%;
-    margin: 0 auto; }
-
-.grid-x {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-orient: horizontal;
-  -webkit-box-direction: normal;
-  -webkit-flex-flow: row wrap;
-      -ms-flex-flow: row wrap;
-          flex-flow: row wrap; }
-
-.cell {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto;
-  min-height: 0px;
-  min-width: 0px;
-  width: 100%; }
-  .cell.auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-  .cell.shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto; }
+[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],
+textarea {
+  display: block;
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box;
+  width: 100%;
+  height: 2.4375rem;
+  margin: 0 0 1rem;
+  padding: 0.5rem;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
+          box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
+  font-family: inherit;
+  font-size: 1rem;
+  font-weight: normal;
+  line-height: 1.5;
+  color: #0a0a0a;
+  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none; }
+  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,
+  textarea:focus {
+    outline: none;
+    border: 1px solid #8a8a8a;
+    background-color: #fefefe;
+    -webkit-box-shadow: 0 0 5px #cacaca;
+            box-shadow: 0 0 5px #cacaca;
+    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
 
-.grid-x > .auto {
-  width: auto; }
+textarea {
+  max-width: 100%; }
+  textarea[rows] {
+    height: auto; }
 
-.grid-x > .shrink {
-  width: auto; }
+input:disabled, input[readonly],
+textarea:disabled,
+textarea[readonly] {
+  background-color: #e6e6e6;
+  cursor: not-allowed; }
 
-.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
-  -webkit-flex-basis: auto;
-      -ms-flex-preferred-size: auto;
-          flex-basis: auto; }
+[type='submit'],
+[type='button'] {
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none;
+  border-radius: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; } }
+input[type='search'] {
+  -webkit-box-sizing: border-box;
+          box-sizing: border-box; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; } }
+::-webkit-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-1 {
-  width: 8.33333%; }
+:-ms-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-2 {
-  width: 16.66667%; }
+::-ms-input-placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-3 {
-  width: 25%; }
+::placeholder {
+  color: #cacaca; }
 
-.grid-x > .small-4 {
-  width: 33.33333%; }
+[type='file'],
+[type='checkbox'],
+[type='radio'] {
+  margin: 0 0 1rem; }
 
-.grid-x > .small-5 {
-  width: 41.66667%; }
+[type='checkbox'] + label,
+[type='radio'] + label {
+  display: inline-block;
+  vertical-align: baseline;
+  margin-left: 0.5rem;
+  margin-right: 1rem;
+  margin-bottom: 0; }
+  [type='checkbox'] + label[for],
+  [type='radio'] + label[for] {
+    cursor: pointer; }
 
-.grid-x > .small-6 {
-  width: 50%; }
+label > [type='checkbox'],
+label > [type='radio'] {
+  margin-right: 0.5rem; }
 
-.grid-x > .small-7 {
-  width: 58.33333%; }
+[type='file'] {
+  width: 100%; }
 
-.grid-x > .small-8 {
-  width: 66.66667%; }
+label {
+  display: block;
+  margin: 0;
+  font-size: 0.875rem;
+  font-weight: normal;
+  line-height: 1.8;
+  color: #0a0a0a; }
+  label.middle {
+    margin: 0 0 1rem;
+    padding: 0.5625rem 0; }
 
-.grid-x > .small-9 {
-  width: 75%; }
+.help-text {
+  margin-top: -0.5rem;
+  font-size: 0.8125rem;
+  font-style: italic;
+  color: #0a0a0a; }
 
-.grid-x > .small-10 {
-  width: 83.33333%; }
+.input-group {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  width: 100%;
+  margin-bottom: 1rem;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch; }
+  .input-group > :first-child, .input-group > :first-child.input-group-button > * {
+    border-radius: 0 0 0 0; }
+  .input-group > :last-child, .input-group > :last-child.input-group-button > * {
+    border-radius: 0 0 0 0; }
 
-.grid-x > .small-11 {
-  width: 91.66667%; }
+.input-group-label, .input-group-field, .input-group-button, .input-group-button a,
+.input-group-button input,
+.input-group-button button,
+.input-group-button label {
+  margin: 0;
+  white-space: nowrap; }
 
-.grid-x > .small-12 {
-  width: 100%; }
+.input-group-label {
+  padding: 0 1rem;
+  border: 1px solid #cacaca;
+  background: #e6e6e6;
+  color: #0a0a0a;
+  text-align: center;
+  white-space: nowrap;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto;
+  -webkit-box-align: center;
+  -webkit-align-items: center;
+      -ms-flex-align: center;
+          align-items: center; }
+  .input-group-label:first-child {
+    border-right: 0; }
+  .input-group-label:last-child {
+    border-left: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-x > .medium-auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px;
-    width: auto; }
-  .grid-x > .medium-shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto;
-    width: auto; }
-  .grid-x > .medium-1 {
-    width: 8.33333%; }
-  .grid-x > .medium-2 {
-    width: 16.66667%; }
-  .grid-x > .medium-3 {
-    width: 25%; }
-  .grid-x > .medium-4 {
-    width: 33.33333%; }
-  .grid-x > .medium-5 {
-    width: 41.66667%; }
-  .grid-x > .medium-6 {
-    width: 50%; }
-  .grid-x > .medium-7 {
-    width: 58.33333%; }
-  .grid-x > .medium-8 {
-    width: 66.66667%; }
-  .grid-x > .medium-9 {
-    width: 75%; }
-  .grid-x > .medium-10 {
-    width: 83.33333%; }
-  .grid-x > .medium-11 {
-    width: 91.66667%; }
-  .grid-x > .medium-12 {
-    width: 100%; } }
+.input-group-field {
+  border-radius: 0;
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 1 0px;
+      -ms-flex: 1 1 0px;
+          flex: 1 1 0px;
+  min-width: 0; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-x > .large-auto {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px;
-    width: auto; }
-  .grid-x > .large-shrink {
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto;
-    width: auto; }
-  .grid-x > .large-1 {
-    width: 8.33333%; }
-  .grid-x > .large-2 {
-    width: 16.66667%; }
-  .grid-x > .large-3 {
-    width: 25%; }
-  .grid-x > .large-4 {
-    width: 33.33333%; }
-  .grid-x > .large-5 {
-    width: 41.66667%; }
-  .grid-x > .large-6 {
-    width: 50%; }
-  .grid-x > .large-7 {
-    width: 58.33333%; }
-  .grid-x > .large-8 {
-    width: 66.66667%; }
-  .grid-x > .large-9 {
-    width: 75%; }
-  .grid-x > .large-10 {
-    width: 83.33333%; }
-  .grid-x > .large-11 {
-    width: 91.66667%; }
-  .grid-x > .large-12 {
-    width: 100%; } }
+.input-group-button {
+  padding-top: 0;
+  padding-bottom: 0;
+  text-align: center;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto; }
+  .input-group-button a,
+  .input-group-button input,
+  .input-group-button button,
+  .input-group-button label {
+    -webkit-align-self: stretch;
+        -ms-flex-item-align: stretch;
+            align-self: stretch;
+    height: auto;
+    padding-top: 0;
+    padding-bottom: 0;
+    font-size: 1rem; }
 
-.grid-margin-x:not(.grid-x) > .cell {
-  width: auto; }
+fieldset {
+  margin: 0;
+  padding: 0;
+  border: 0; }
 
-.grid-margin-y:not(.grid-y) > .cell {
-  height: auto; }
+legend {
+  max-width: 100%;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x {
-  margin-left: -0.625rem;
-  margin-right: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x {
-      margin-left: -0.9375rem;
-      margin-right: -0.9375rem; } }
-  .grid-margin-x > .cell {
-    width: calc(100% - 1.25rem);
-    margin-left: 0.625rem;
-    margin-right: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x > .cell {
-      width: calc(100% - 1.875rem);
-      margin-left: 0.9375rem;
-      margin-right: 0.9375rem; } }
-  .grid-margin-x > .auto {
-    width: auto; }
-  .grid-margin-x > .shrink {
-    width: auto; }
-  .grid-margin-x > .small-1 {
-    width: calc(8.33333% - 1.25rem); }
-  .grid-margin-x > .small-2 {
-    width: calc(16.66667% - 1.25rem); }
-  .grid-margin-x > .small-3 {
-    width: calc(25% - 1.25rem); }
-  .grid-margin-x > .small-4 {
-    width: calc(33.33333% - 1.25rem); }
-  .grid-margin-x > .small-5 {
-    width: calc(41.66667% - 1.25rem); }
-  .grid-margin-x > .small-6 {
-    width: calc(50% - 1.25rem); }
-  .grid-margin-x > .small-7 {
-    width: calc(58.33333% - 1.25rem); }
-  .grid-margin-x > .small-8 {
-    width: calc(66.66667% - 1.25rem); }
-  .grid-margin-x > .small-9 {
-    width: calc(75% - 1.25rem); }
-  .grid-margin-x > .small-10 {
-    width: calc(83.33333% - 1.25rem); }
-  .grid-margin-x > .small-11 {
-    width: calc(91.66667% - 1.25rem); }
-  .grid-margin-x > .small-12 {
-    width: calc(100% - 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-x > .auto {
-      width: auto; }
-    .grid-margin-x > .shrink {
-      width: auto; }
-    .grid-margin-x > .small-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .small-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .small-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .small-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .small-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .small-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .small-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .small-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .small-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .small-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .small-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .small-12 {
-      width: calc(100% - 1.875rem); }
-    .grid-margin-x > .medium-auto {
-      width: auto; }
-    .grid-margin-x > .medium-shrink {
-      width: auto; }
-    .grid-margin-x > .medium-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .medium-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .medium-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .medium-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .medium-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .medium-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .medium-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .medium-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .medium-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .medium-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .medium-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .medium-12 {
-      width: calc(100% - 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-margin-x > .large-auto {
-      width: auto; }
-    .grid-margin-x > .large-shrink {
-      width: auto; }
-    .grid-margin-x > .large-1 {
-      width: calc(8.33333% - 1.875rem); }
-    .grid-margin-x > .large-2 {
-      width: calc(16.66667% - 1.875rem); }
-    .grid-margin-x > .large-3 {
-      width: calc(25% - 1.875rem); }
-    .grid-margin-x > .large-4 {
-      width: calc(33.33333% - 1.875rem); }
-    .grid-margin-x > .large-5 {
-      width: calc(41.66667% - 1.875rem); }
-    .grid-margin-x > .large-6 {
-      width: calc(50% - 1.875rem); }
-    .grid-margin-x > .large-7 {
-      width: calc(58.33333% - 1.875rem); }
-    .grid-margin-x > .large-8 {
-      width: calc(66.66667% - 1.875rem); }
-    .grid-margin-x > .large-9 {
-      width: calc(75% - 1.875rem); }
-    .grid-margin-x > .large-10 {
-      width: calc(83.33333% - 1.875rem); }
-    .grid-margin-x > .large-11 {
-      width: calc(91.66667% - 1.875rem); }
-    .grid-margin-x > .large-12 {
-      width: calc(100% - 1.875rem); } }
+.fieldset {
+  margin: 1.125rem 0;
+  padding: 1.25rem;
+  border: 1px solid #cacaca; }
+  .fieldset legend {
+    margin: 0;
+    margin-left: -0.1875rem;
+    padding: 0 0.1875rem; }
 
-.grid-padding-x .grid-padding-x {
-  margin-right: -0.625rem;
-  margin-left: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-x .grid-padding-x {
-      margin-right: -0.9375rem;
-      margin-left: -0.9375rem; } }
+select {
+  height: 2.4375rem;
+  margin: 0 0 1rem;
+  padding: 0.5rem;
+  -webkit-appearance: none;
+     -moz-appearance: none;
+          appearance: none;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  font-family: inherit;
+  font-size: 1rem;
+  font-weight: normal;
+  line-height: 1.5;
+  color: #0a0a0a;
+  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");
+  background-origin: content-box;
+  background-position: right -1rem center;
+  background-repeat: no-repeat;
+  background-size: 9px 6px;
+  padding-right: 1.5rem;
+  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+  @media screen and (min-width: 0\0) {
+    select {
+      background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } }
+  select:focus {
+    outline: none;
+    border: 1px solid #8a8a8a;
+    background-color: #fefefe;
+    -webkit-box-shadow: 0 0 5px #cacaca;
+            box-shadow: 0 0 5px #cacaca;
+    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
+    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
+  select:disabled {
+    background-color: #e6e6e6;
+    cursor: not-allowed; }
+  select::-ms-expand {
+    display: none; }
+  select[multiple] {
+    height: auto;
+    background-image: none; }
 
-.grid-container:not(.full) > .grid-padding-x {
-  margin-right: -0.625rem;
-  margin-left: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-container:not(.full) > .grid-padding-x {
-      margin-right: -0.9375rem;
-      margin-left: -0.9375rem; } }
+.is-invalid-input:not(:focus) {
+  border-color: #cc4b37;
+  background-color: #f9ecea; }
+  .is-invalid-input:not(:focus)::-webkit-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus):-ms-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus)::-ms-input-placeholder {
+    color: #cc4b37; }
+  .is-invalid-input:not(:focus)::placeholder {
+    color: #cc4b37; }
 
-.grid-padding-x > .cell {
-  padding-right: 0.625rem;
-  padding-left: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-x > .cell {
-      padding-right: 0.9375rem;
-      padding-left: 0.9375rem; } }
+.is-invalid-label {
+  color: #cc4b37; }
 
-.small-up-1 > .cell {
-  width: 100%; }
+.form-error {
+  display: none;
+  margin-top: -0.5rem;
+  margin-bottom: 1rem;
+  font-size: 0.75rem;
+  font-weight: bold;
+  color: #cc4b37; }
+  .form-error.is-visible {
+    display: block; }
 
-.small-up-2 > .cell {
-  width: 50%; }
+div,
+dl,
+dt,
+dd,
+ul,
+ol,
+li,
+h1,
+h2,
+h3,
+h4,
+h5,
+h6,
+pre,
+form,
+p,
+blockquote,
+th,
+td {
+  margin: 0;
+  padding: 0; }
 
-.small-up-3 > .cell {
-  width: 33.33333%; }
+p {
+  margin-bottom: 1rem;
+  font-size: inherit;
+  line-height: 1.6;
+  text-rendering: optimizeLegibility; }
 
-.small-up-4 > .cell {
-  width: 25%; }
+em,
+i {
+  font-style: italic;
+  line-height: inherit; }
 
-.small-up-5 > .cell {
-  width: 20%; }
+strong,
+b {
+  font-weight: bold;
+  line-height: inherit; }
 
-.small-up-6 > .cell {
-  width: 16.66667%; }
+small {
+  font-size: 80%;
+  line-height: inherit; }
 
-.small-up-7 > .cell {
-  width: 14.28571%; }
+h1, .h1,
+h2, .h2,
+h3, .h3,
+h4, .h4,
+h5, .h5,
+h6, .h6 {
+  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
+  font-style: normal;
+  font-weight: normal;
+  color: inherit;
+  text-rendering: optimizeLegibility; }
+  h1 small, .h1 small,
+  h2 small, .h2 small,
+  h3 small, .h3 small,
+  h4 small, .h4 small,
+  h5 small, .h5 small,
+  h6 small, .h6 small {
+    line-height: 0;
+    color: #cacaca; }
 
-.small-up-8 > .cell {
-  width: 12.5%; }
+h1, .h1 {
+  font-size: 1.5rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-up-1 > .cell {
-    width: 100%; }
-  .medium-up-2 > .cell {
-    width: 50%; }
-  .medium-up-3 > .cell {
-    width: 33.33333%; }
-  .medium-up-4 > .cell {
-    width: 25%; }
-  .medium-up-5 > .cell {
-    width: 20%; }
-  .medium-up-6 > .cell {
-    width: 16.66667%; }
-  .medium-up-7 > .cell {
-    width: 14.28571%; }
-  .medium-up-8 > .cell {
-    width: 12.5%; } }
+h2, .h2 {
+  font-size: 1.25rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-@media print, screen and (min-width: 64em) {
-  .large-up-1 > .cell {
-    width: 100%; }
-  .large-up-2 > .cell {
-    width: 50%; }
-  .large-up-3 > .cell {
-    width: 33.33333%; }
-  .large-up-4 > .cell {
-    width: 25%; }
-  .large-up-5 > .cell {
-    width: 20%; }
-  .large-up-6 > .cell {
-    width: 16.66667%; }
-  .large-up-7 > .cell {
-    width: 14.28571%; }
-  .large-up-8 > .cell {
-    width: 12.5%; } }
+h3, .h3 {
+  font-size: 1.1875rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-1 > .cell {
-  width: calc(100% - 1.25rem); }
+h4, .h4 {
+  font-size: 1.125rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-2 > .cell {
-  width: calc(50% - 1.25rem); }
+h5, .h5 {
+  font-size: 1.0625rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-3 > .cell {
-  width: calc(33.33333% - 1.25rem); }
+h6, .h6 {
+  font-size: 1rem;
+  line-height: 1.4;
+  margin-top: 0;
+  margin-bottom: 0.5rem; }
 
-.grid-margin-x.small-up-4 > .cell {
-  width: calc(25% - 1.25rem); }
+@media print, screen and (min-width: 40em) {
+  h1, .h1 {
+    font-size: 3rem; }
+  h2, .h2 {
+    font-size: 2.5rem; }
+  h3, .h3 {
+    font-size: 1.9375rem; }
+  h4, .h4 {
+    font-size: 1.5625rem; }
+  h5, .h5 {
+    font-size: 1.25rem; }
+  h6, .h6 {
+    font-size: 1rem; } }
 
-.grid-margin-x.small-up-5 > .cell {
-  width: calc(20% - 1.25rem); }
+a {
+  line-height: inherit;
+  color: #1779ba;
+  text-decoration: none;
+  cursor: pointer; }
+  a:hover, a:focus {
+    color: #1468a0; }
+  a img {
+    border: 0; }
 
-.grid-margin-x.small-up-6 > .cell {
-  width: calc(16.66667% - 1.25rem); }
+hr {
+  clear: both;
+  max-width: 75rem;
+  height: 0;
+  margin: 1.25rem auto;
+  border-top: 0;
+  border-right: 0;
+  border-bottom: 1px solid #cacaca;
+  border-left: 0; }
 
-.grid-margin-x.small-up-7 > .cell {
-  width: calc(14.28571% - 1.25rem); }
+ul,
+ol,
+dl {
+  margin-bottom: 1rem;
+  list-style-position: outside;
+  line-height: 1.6; }
 
-.grid-margin-x.small-up-8 > .cell {
-  width: calc(12.5% - 1.25rem); }
+li {
+  font-size: inherit; }
 
-@media print, screen and (min-width: 40em) {
-  .grid-margin-x.small-up-1 > .cell {
-    width: calc(100% - 1.25rem); }
-  .grid-margin-x.small-up-2 > .cell {
-    width: calc(50% - 1.25rem); }
-  .grid-margin-x.small-up-3 > .cell {
-    width: calc(33.33333% - 1.25rem); }
-  .grid-margin-x.small-up-4 > .cell {
-    width: calc(25% - 1.25rem); }
-  .grid-margin-x.small-up-5 > .cell {
-    width: calc(20% - 1.25rem); }
-  .grid-margin-x.small-up-6 > .cell {
-    width: calc(16.66667% - 1.25rem); }
-  .grid-margin-x.small-up-7 > .cell {
-    width: calc(14.28571% - 1.25rem); }
-  .grid-margin-x.small-up-8 > .cell {
-    width: calc(12.5% - 1.25rem); }
-  .grid-margin-x.medium-up-1 > .cell {
-    width: calc(100% - 1.875rem); }
-  .grid-margin-x.medium-up-2 > .cell {
-    width: calc(50% - 1.875rem); }
-  .grid-margin-x.medium-up-3 > .cell {
-    width: calc(33.33333% - 1.875rem); }
-  .grid-margin-x.medium-up-4 > .cell {
-    width: calc(25% - 1.875rem); }
-  .grid-margin-x.medium-up-5 > .cell {
-    width: calc(20% - 1.875rem); }
-  .grid-margin-x.medium-up-6 > .cell {
-    width: calc(16.66667% - 1.875rem); }
-  .grid-margin-x.medium-up-7 > .cell {
-    width: calc(14.28571% - 1.875rem); }
-  .grid-margin-x.medium-up-8 > .cell {
-    width: calc(12.5% - 1.875rem); } }
+ul {
+  margin-left: 1.25rem;
+  list-style-type: disc; }
 
-@media print, screen and (min-width: 64em) {
-  .grid-margin-x.large-up-1 > .cell {
-    width: calc(100% - 1.875rem); }
-  .grid-margin-x.large-up-2 > .cell {
-    width: calc(50% - 1.875rem); }
-  .grid-margin-x.large-up-3 > .cell {
-    width: calc(33.33333% - 1.875rem); }
-  .grid-margin-x.large-up-4 > .cell {
-    width: calc(25% - 1.875rem); }
-  .grid-margin-x.large-up-5 > .cell {
-    width: calc(20% - 1.875rem); }
-  .grid-margin-x.large-up-6 > .cell {
-    width: calc(16.66667% - 1.875rem); }
-  .grid-margin-x.large-up-7 > .cell {
-    width: calc(14.28571% - 1.875rem); }
-  .grid-margin-x.large-up-8 > .cell {
-    width: calc(12.5% - 1.875rem); } }
+ol {
+  margin-left: 1.25rem; }
 
-.small-margin-collapse {
-  margin-right: 0;
-  margin-left: 0; }
-  .small-margin-collapse > .cell {
-    margin-right: 0;
-    margin-left: 0; }
-  .small-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .small-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .small-margin-collapse > .small-3 {
-    width: 25%; }
-  .small-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .small-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .small-margin-collapse > .small-6 {
-    width: 50%; }
-  .small-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .small-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .small-margin-collapse > .small-9 {
-    width: 75%; }
-  .small-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .small-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .small-margin-collapse > .small-12 {
-    width: 100%; }
-  @media print, screen and (min-width: 40em) {
-    .small-margin-collapse > .medium-1 {
-      width: 8.33333%; }
-    .small-margin-collapse > .medium-2 {
-      width: 16.66667%; }
-    .small-margin-collapse > .medium-3 {
-      width: 25%; }
-    .small-margin-collapse > .medium-4 {
-      width: 33.33333%; }
-    .small-margin-collapse > .medium-5 {
-      width: 41.66667%; }
-    .small-margin-collapse > .medium-6 {
-      width: 50%; }
-    .small-margin-collapse > .medium-7 {
-      width: 58.33333%; }
-    .small-margin-collapse > .medium-8 {
-      width: 66.66667%; }
-    .small-margin-collapse > .medium-9 {
-      width: 75%; }
-    .small-margin-collapse > .medium-10 {
-      width: 83.33333%; }
-    .small-margin-collapse > .medium-11 {
-      width: 91.66667%; }
-    .small-margin-collapse > .medium-12 {
-      width: 100%; } }
-  @media print, screen and (min-width: 64em) {
-    .small-margin-collapse > .large-1 {
-      width: 8.33333%; }
-    .small-margin-collapse > .large-2 {
-      width: 16.66667%; }
-    .small-margin-collapse > .large-3 {
-      width: 25%; }
-    .small-margin-collapse > .large-4 {
-      width: 33.33333%; }
-    .small-margin-collapse > .large-5 {
-      width: 41.66667%; }
-    .small-margin-collapse > .large-6 {
-      width: 50%; }
-    .small-margin-collapse > .large-7 {
-      width: 58.33333%; }
-    .small-margin-collapse > .large-8 {
-      width: 66.66667%; }
-    .small-margin-collapse > .large-9 {
-      width: 75%; }
-    .small-margin-collapse > .large-10 {
-      width: 83.33333%; }
-    .small-margin-collapse > .large-11 {
-      width: 91.66667%; }
-    .small-margin-collapse > .large-12 {
-      width: 100%; } }
+ul ul, ol ul, ul ol, ol ol {
+  margin-left: 1.25rem;
+  margin-bottom: 0; }
 
-.small-padding-collapse {
-  margin-right: 0;
-  margin-left: 0; }
-  .small-padding-collapse > .cell {
-    padding-right: 0;
-    padding-left: 0; }
+dl {
+  margin-bottom: 1rem; }
+  dl dt {
+    margin-bottom: 0.3rem;
+    font-weight: bold; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .medium-margin-collapse > .cell {
-      margin-right: 0;
-      margin-left: 0; } }
-
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .small-3 {
-    width: 25%; }
-  .medium-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .small-6 {
-    width: 50%; }
-  .medium-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .small-9 {
-    width: 75%; }
-  .medium-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .small-12 {
-    width: 100%; } }
-
-@media print, screen and (min-width: 40em) {
-  .medium-margin-collapse > .medium-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .medium-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .medium-3 {
-    width: 25%; }
-  .medium-margin-collapse > .medium-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .medium-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .medium-6 {
-    width: 50%; }
-  .medium-margin-collapse > .medium-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .medium-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .medium-9 {
-    width: 75%; }
-  .medium-margin-collapse > .medium-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .medium-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .medium-12 {
-    width: 100%; } }
-
-@media print, screen and (min-width: 64em) {
-  .medium-margin-collapse > .large-1 {
-    width: 8.33333%; }
-  .medium-margin-collapse > .large-2 {
-    width: 16.66667%; }
-  .medium-margin-collapse > .large-3 {
-    width: 25%; }
-  .medium-margin-collapse > .large-4 {
-    width: 33.33333%; }
-  .medium-margin-collapse > .large-5 {
-    width: 41.66667%; }
-  .medium-margin-collapse > .large-6 {
-    width: 50%; }
-  .medium-margin-collapse > .large-7 {
-    width: 58.33333%; }
-  .medium-margin-collapse > .large-8 {
-    width: 66.66667%; }
-  .medium-margin-collapse > .large-9 {
-    width: 75%; }
-  .medium-margin-collapse > .large-10 {
-    width: 83.33333%; }
-  .medium-margin-collapse > .large-11 {
-    width: 91.66667%; }
-  .medium-margin-collapse > .large-12 {
-    width: 100%; } }
+blockquote {
+  margin: 0 0 1rem;
+  padding: 0.5625rem 1.25rem 0 1.1875rem;
+  border-left: 1px solid #cacaca; }
+  blockquote, blockquote p {
+    line-height: 1.6;
+    color: #8a8a8a; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-padding-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .medium-padding-collapse > .cell {
-      padding-right: 0;
-      padding-left: 0; } }
+cite {
+  display: block;
+  font-size: 0.8125rem;
+  color: #8a8a8a; }
+  cite:before {
+    content: "— "; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .large-margin-collapse > .cell {
-      margin-right: 0;
-      margin-left: 0; } }
+abbr, abbr[title] {
+  border-bottom: 1px dotted #0a0a0a;
+  cursor: help;
+  text-decoration: none; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .small-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .small-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .small-3 {
-    width: 25%; }
-  .large-margin-collapse > .small-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .small-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .small-6 {
-    width: 50%; }
-  .large-margin-collapse > .small-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .small-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .small-9 {
-    width: 75%; }
-  .large-margin-collapse > .small-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .small-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .small-12 {
-    width: 100%; } }
+figure {
+  margin: 0; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .medium-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .medium-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .medium-3 {
-    width: 25%; }
-  .large-margin-collapse > .medium-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .medium-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .medium-6 {
-    width: 50%; }
-  .large-margin-collapse > .medium-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .medium-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .medium-9 {
-    width: 75%; }
-  .large-margin-collapse > .medium-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .medium-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .medium-12 {
-    width: 100%; } }
+code {
+  padding: 0.125rem 0.3125rem 0.0625rem;
+  border: 1px solid #cacaca;
+  background-color: #e6e6e6;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  font-weight: normal;
+  color: #0a0a0a; }
 
-@media print, screen and (min-width: 64em) {
-  .large-margin-collapse > .large-1 {
-    width: 8.33333%; }
-  .large-margin-collapse > .large-2 {
-    width: 16.66667%; }
-  .large-margin-collapse > .large-3 {
-    width: 25%; }
-  .large-margin-collapse > .large-4 {
-    width: 33.33333%; }
-  .large-margin-collapse > .large-5 {
-    width: 41.66667%; }
-  .large-margin-collapse > .large-6 {
-    width: 50%; }
-  .large-margin-collapse > .large-7 {
-    width: 58.33333%; }
-  .large-margin-collapse > .large-8 {
-    width: 66.66667%; }
-  .large-margin-collapse > .large-9 {
-    width: 75%; }
-  .large-margin-collapse > .large-10 {
-    width: 83.33333%; }
-  .large-margin-collapse > .large-11 {
-    width: 91.66667%; }
-  .large-margin-collapse > .large-12 {
-    width: 100%; } }
+kbd {
+  margin: 0;
+  padding: 0.125rem 0.25rem 0;
+  background-color: #e6e6e6;
+  font-family: Consolas, "Liberation Mono", Courier, monospace;
+  color: #0a0a0a; }
 
-@media print, screen and (min-width: 64em) {
-  .large-padding-collapse {
-    margin-right: 0;
-    margin-left: 0; }
-    .large-padding-collapse > .cell {
-      padding-right: 0;
-      padding-left: 0; } }
+.subheader {
+  margin-top: 0.2rem;
+  margin-bottom: 0.5rem;
+  font-weight: normal;
+  line-height: 1.4;
+  color: #8a8a8a; }
 
-.small-offset-0 {
-  margin-left: 0%; }
+.lead {
+  font-size: 125%;
+  line-height: 1.6; }
 
-.grid-margin-x > .small-offset-0 {
-  margin-left: calc(0% + 0.625rem); }
+.stat {
+  font-size: 2.5rem;
+  line-height: 1; }
+  p + .stat {
+    margin-top: -1rem; }
 
-.small-offset-1 {
-  margin-left: 8.33333%; }
+ul.no-bullet, ol.no-bullet {
+  margin-left: 0;
+  list-style: none; }
 
-.grid-margin-x > .small-offset-1 {
-  margin-left: calc(8.33333% + 0.625rem); }
+.text-left {
+  text-align: left; }
 
-.small-offset-2 {
-  margin-left: 16.66667%; }
+.text-right {
+  text-align: right; }
 
-.grid-margin-x > .small-offset-2 {
-  margin-left: calc(16.66667% + 0.625rem); }
+.text-center {
+  text-align: center; }
 
-.small-offset-3 {
-  margin-left: 25%; }
+.text-justify {
+  text-align: justify; }
 
-.grid-margin-x > .small-offset-3 {
-  margin-left: calc(25% + 0.625rem); }
+@media print, screen and (min-width: 40em) {
+  .medium-text-left {
+    text-align: left; }
+  .medium-text-right {
+    text-align: right; }
+  .medium-text-center {
+    text-align: center; }
+  .medium-text-justify {
+    text-align: justify; } }
 
-.small-offset-4 {
-  margin-left: 33.33333%; }
+@media print, screen and (min-width: 64em) {
+  .large-text-left {
+    text-align: left; }
+  .large-text-right {
+    text-align: right; }
+  .large-text-center {
+    text-align: center; }
+  .large-text-justify {
+    text-align: justify; } }
 
-.grid-margin-x > .small-offset-4 {
-  margin-left: calc(33.33333% + 0.625rem); }
+.show-for-print {
+  display: none !important; }
 
-.small-offset-5 {
-  margin-left: 41.66667%; }
+@media print {
+  * {
+    background: transparent !important;
+    -webkit-box-shadow: none !important;
+            box-shadow: none !important;
+    color: black !important;
+    text-shadow: none !important; }
+  .show-for-print {
+    display: block !important; }
+  .hide-for-print {
+    display: none !important; }
+  table.show-for-print {
+    display: table !important; }
+  thead.show-for-print {
+    display: table-header-group !important; }
+  tbody.show-for-print {
+    display: table-row-group !important; }
+  tr.show-for-print {
+    display: table-row !important; }
+  td.show-for-print {
+    display: table-cell !important; }
+  th.show-for-print {
+    display: table-cell !important; }
+  a,
+  a:visited {
+    text-decoration: underline; }
+  a[href]:after {
+    content: " (" attr(href) ")"; }
+  .ir a:after,
+  a[href^='javascript:']:after,
+  a[href^='#']:after {
+    content: ''; }
+  abbr[title]:after {
+    content: " (" attr(title) ")"; }
+  pre,
+  blockquote {
+    border: 1px solid #8a8a8a;
+    page-break-inside: avoid; }
+  thead {
+    display: table-header-group; }
+  tr,
+  img {
+    page-break-inside: avoid; }
+  img {
+    max-width: 100% !important; }
+  @page {
+    margin: 0.5cm; }
+  p,
+  h2,
+  h3 {
+    orphans: 3;
+    widows: 3; }
+  h2,
+  h3 {
+    page-break-after: avoid; }
+  .print-break-inside {
+    page-break-inside: auto; } }
 
-.grid-margin-x > .small-offset-5 {
-  margin-left: calc(41.66667% + 0.625rem); }
+.grid-container {
+  padding-right: 0.625rem;
+  padding-left: 0.625rem;
+  max-width: 75rem;
+  margin-left: auto;
+  margin-right: auto; }
+  @media print, screen and (min-width: 40em) {
+    .grid-container {
+      padding-right: 0.9375rem;
+      padding-left: 0.9375rem; } }
+  .grid-container.fluid {
+    padding-right: 0.625rem;
+    padding-left: 0.625rem;
+    max-width: 100%;
+    margin-left: auto;
+    margin-right: auto; }
+    @media print, screen and (min-width: 40em) {
+      .grid-container.fluid {
+        padding-right: 0.9375rem;
+        padding-left: 0.9375rem; } }
+  .grid-container.full {
+    padding-right: 0;
+    padding-left: 0;
+    max-width: 100%;
+    margin-left: auto;
+    margin-right: auto; }
 
-.small-offset-6 {
-  margin-left: 50%; }
+.grid-x {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-orient: horizontal;
+  -webkit-box-direction: normal;
+  -webkit-flex-flow: row wrap;
+      -ms-flex-flow: row wrap;
+          flex-flow: row wrap; }
 
-.grid-margin-x > .small-offset-6 {
-  margin-left: calc(50% + 0.625rem); }
+.cell {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto;
+  min-height: 0px;
+  min-width: 0px;
+  width: 100%; }
+  .cell.auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
+  .cell.shrink {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
 
-.small-offset-7 {
-  margin-left: 58.33333%; }
+.grid-x > .auto {
+  width: auto; }
 
-.grid-margin-x > .small-offset-7 {
-  margin-left: calc(58.33333% + 0.625rem); }
+.grid-x > .shrink {
+  width: auto; }
 
-.small-offset-8 {
-  margin-left: 66.66667%; }
+.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
+  -webkit-flex-basis: auto;
+      -ms-flex-preferred-size: auto;
+          flex-basis: auto; }
 
-.grid-margin-x > .small-offset-8 {
-  margin-left: calc(66.66667% + 0.625rem); }
+@media print, screen and (min-width: 40em) {
+  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; } }
 
-.small-offset-9 {
-  margin-left: 75%; }
+@media print, screen and (min-width: 64em) {
+  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; } }
 
-.grid-margin-x > .small-offset-9 {
-  margin-left: calc(75% + 0.625rem); }
+.grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 0 auto;
+      -ms-flex: 0 0 auto;
+          flex: 0 0 auto; }
 
-.small-offset-10 {
-  margin-left: 83.33333%; }
+.grid-x > .small-1 {
+  width: 8.33333%; }
 
-.grid-margin-x > .small-offset-10 {
-  margin-left: calc(83.33333% + 0.625rem); }
+.grid-x > .small-2 {
+  width: 16.66667%; }
 
-.small-offset-11 {
-  margin-left: 91.66667%; }
+.grid-x > .small-3 {
+  width: 25%; }
 
-.grid-margin-x > .small-offset-11 {
-  margin-left: calc(91.66667% + 0.625rem); }
+.grid-x > .small-4 {
+  width: 33.33333%; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-offset-0 {
-    margin-left: 0%; }
-  .grid-margin-x > .medium-offset-0 {
-    margin-left: calc(0% + 0.9375rem); }
-  .medium-offset-1 {
-    margin-left: 8.33333%; }
-  .grid-margin-x > .medium-offset-1 {
-    margin-left: calc(8.33333% + 0.9375rem); }
-  .medium-offset-2 {
-    margin-left: 16.66667%; }
-  .grid-margin-x > .medium-offset-2 {
-    margin-left: calc(16.66667% + 0.9375rem); }
-  .medium-offset-3 {
-    margin-left: 25%; }
-  .grid-margin-x > .medium-offset-3 {
-    margin-left: calc(25% + 0.9375rem); }
-  .medium-offset-4 {
-    margin-left: 33.33333%; }
-  .grid-margin-x > .medium-offset-4 {
-    margin-left: calc(33.33333% + 0.9375rem); }
-  .medium-offset-5 {
-    margin-left: 41.66667%; }
-  .grid-margin-x > .medium-offset-5 {
-    margin-left: calc(41.66667% + 0.9375rem); }
-  .medium-offset-6 {
-    margin-left: 50%; }
-  .grid-margin-x > .medium-offset-6 {
-    margin-left: calc(50% + 0.9375rem); }
-  .medium-offset-7 {
-    margin-left: 58.33333%; }
-  .grid-margin-x > .medium-offset-7 {
-    margin-left: calc(58.33333% + 0.9375rem); }
-  .medium-offset-8 {
-    margin-left: 66.66667%; }
-  .grid-margin-x > .medium-offset-8 {
-    margin-left: calc(66.66667% + 0.9375rem); }
-  .medium-offset-9 {
-    margin-left: 75%; }
-  .grid-margin-x > .medium-offset-9 {
-    margin-left: calc(75% + 0.9375rem); }
-  .medium-offset-10 {
-    margin-left: 83.33333%; }
-  .grid-margin-x > .medium-offset-10 {
-    margin-left: calc(83.33333% + 0.9375rem); }
-  .medium-offset-11 {
-    margin-left: 91.66667%; }
-  .grid-margin-x > .medium-offset-11 {
-    margin-left: calc(91.66667% + 0.9375rem); } }
+.grid-x > .small-5 {
+  width: 41.66667%; }
 
-@media print, screen and (min-width: 64em) {
-  .large-offset-0 {
-    margin-left: 0%; }
-  .grid-margin-x > .large-offset-0 {
-    margin-left: calc(0% + 0.9375rem); }
-  .large-offset-1 {
-    margin-left: 8.33333%; }
-  .grid-margin-x > .large-offset-1 {
-    margin-left: calc(8.33333% + 0.9375rem); }
-  .large-offset-2 {
-    margin-left: 16.66667%; }
-  .grid-margin-x > .large-offset-2 {
-    margin-left: calc(16.66667% + 0.9375rem); }
-  .large-offset-3 {
-    margin-left: 25%; }
-  .grid-margin-x > .large-offset-3 {
-    margin-left: calc(25% + 0.9375rem); }
-  .large-offset-4 {
-    margin-left: 33.33333%; }
-  .grid-margin-x > .large-offset-4 {
-    margin-left: calc(33.33333% + 0.9375rem); }
-  .large-offset-5 {
-    margin-left: 41.66667%; }
-  .grid-margin-x > .large-offset-5 {
-    margin-left: calc(41.66667% + 0.9375rem); }
-  .large-offset-6 {
-    margin-left: 50%; }
-  .grid-margin-x > .large-offset-6 {
-    margin-left: calc(50% + 0.9375rem); }
-  .large-offset-7 {
-    margin-left: 58.33333%; }
-  .grid-margin-x > .large-offset-7 {
-    margin-left: calc(58.33333% + 0.9375rem); }
-  .large-offset-8 {
-    margin-left: 66.66667%; }
-  .grid-margin-x > .large-offset-8 {
-    margin-left: calc(66.66667% + 0.9375rem); }
-  .large-offset-9 {
-    margin-left: 75%; }
-  .grid-margin-x > .large-offset-9 {
-    margin-left: calc(75% + 0.9375rem); }
-  .large-offset-10 {
-    margin-left: 83.33333%; }
-  .grid-margin-x > .large-offset-10 {
-    margin-left: calc(83.33333% + 0.9375rem); }
-  .large-offset-11 {
-    margin-left: 91.66667%; }
-  .grid-margin-x > .large-offset-11 {
-    margin-left: calc(91.66667% + 0.9375rem); } }
+.grid-x > .small-6 {
+  width: 50%; }
 
-.grid-y {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-orient: vertical;
-  -webkit-box-direction: normal;
-  -webkit-flex-flow: column nowrap;
-      -ms-flex-flow: column nowrap;
-          flex-flow: column nowrap; }
-  .grid-y > .cell {
+.grid-x > .small-7 {
+  width: 58.33333%; }
+
+.grid-x > .small-8 {
+  width: 66.66667%; }
+
+.grid-x > .small-9 {
+  width: 75%; }
+
+.grid-x > .small-10 {
+  width: 83.33333%; }
+
+.grid-x > .small-11 {
+  width: 91.66667%; }
+
+.grid-x > .small-12 {
+  width: 100%; }
+
+@media print, screen and (min-width: 40em) {
+  .grid-x > .medium-auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px;
     width: auto; }
-  .grid-y > .auto {
-    height: auto; }
-  .grid-y > .shrink {
-    height: auto; }
-  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
-    -webkit-flex-basis: auto;
-        -ms-flex-preferred-size: auto;
-            flex-basis: auto; }
-  @media print, screen and (min-width: 40em) {
-    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
-      -webkit-flex-basis: auto;
-          -ms-flex-preferred-size: auto;
-              flex-basis: auto; } }
-  @media print, screen and (min-width: 64em) {
-    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
-      -webkit-flex-basis: auto;
-          -ms-flex-preferred-size: auto;
-              flex-basis: auto; } }
-  .grid-y > .small-1 {
-    height: 8.33333%; }
-  .grid-y > .small-2 {
-    height: 16.66667%; }
-  .grid-y > .small-3 {
-    height: 25%; }
-  .grid-y > .small-4 {
-    height: 33.33333%; }
-  .grid-y > .small-5 {
-    height: 41.66667%; }
-  .grid-y > .small-6 {
-    height: 50%; }
-  .grid-y > .small-7 {
-    height: 58.33333%; }
-  .grid-y > .small-8 {
-    height: 66.66667%; }
-  .grid-y > .small-9 {
-    height: 75%; }
-  .grid-y > .small-10 {
-    height: 83.33333%; }
-  .grid-y > .small-11 {
-    height: 91.66667%; }
-  .grid-y > .small-12 {
-    height: 100%; }
-  @media print, screen and (min-width: 40em) {
-    .grid-y > .medium-auto {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      height: auto; }
-    .grid-y > .medium-shrink {
-      height: auto; }
-    .grid-y > .medium-1 {
-      height: 8.33333%; }
-    .grid-y > .medium-2 {
-      height: 16.66667%; }
-    .grid-y > .medium-3 {
-      height: 25%; }
-    .grid-y > .medium-4 {
-      height: 33.33333%; }
-    .grid-y > .medium-5 {
-      height: 41.66667%; }
-    .grid-y > .medium-6 {
-      height: 50%; }
-    .grid-y > .medium-7 {
-      height: 58.33333%; }
-    .grid-y > .medium-8 {
-      height: 66.66667%; }
-    .grid-y > .medium-9 {
-      height: 75%; }
-    .grid-y > .medium-10 {
-      height: 83.33333%; }
-    .grid-y > .medium-11 {
-      height: 91.66667%; }
-    .grid-y > .medium-12 {
-      height: 100%; } }
-  @media print, screen and (min-width: 64em) {
-    .grid-y > .large-auto {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      height: auto; }
-    .grid-y > .large-shrink {
-      height: auto; }
-    .grid-y > .large-1 {
-      height: 8.33333%; }
-    .grid-y > .large-2 {
-      height: 16.66667%; }
-    .grid-y > .large-3 {
-      height: 25%; }
-    .grid-y > .large-4 {
-      height: 33.33333%; }
-    .grid-y > .large-5 {
-      height: 41.66667%; }
-    .grid-y > .large-6 {
-      height: 50%; }
-    .grid-y > .large-7 {
-      height: 58.33333%; }
-    .grid-y > .large-8 {
-      height: 66.66667%; }
-    .grid-y > .large-9 {
-      height: 75%; }
-    .grid-y > .large-10 {
-      height: 83.33333%; }
-    .grid-y > .large-11 {
-      height: 91.66667%; }
-    .grid-y > .large-12 {
-      height: 100%; } }
+  .grid-x > .medium-shrink, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-x > .medium-shrink {
+    width: auto; }
+  .grid-x > .medium-1 {
+    width: 8.33333%; }
+  .grid-x > .medium-2 {
+    width: 16.66667%; }
+  .grid-x > .medium-3 {
+    width: 25%; }
+  .grid-x > .medium-4 {
+    width: 33.33333%; }
+  .grid-x > .medium-5 {
+    width: 41.66667%; }
+  .grid-x > .medium-6 {
+    width: 50%; }
+  .grid-x > .medium-7 {
+    width: 58.33333%; }
+  .grid-x > .medium-8 {
+    width: 66.66667%; }
+  .grid-x > .medium-9 {
+    width: 75%; }
+  .grid-x > .medium-10 {
+    width: 83.33333%; }
+  .grid-x > .medium-11 {
+    width: 91.66667%; }
+  .grid-x > .medium-12 {
+    width: 100%; } }
 
-.grid-padding-y .grid-padding-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-y .grid-padding-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
+@media print, screen and (min-width: 64em) {
+  .grid-x > .large-auto {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px;
+    width: auto; }
+  .grid-x > .large-shrink, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-x > .large-shrink {
+    width: auto; }
+  .grid-x > .large-1 {
+    width: 8.33333%; }
+  .grid-x > .large-2 {
+    width: 16.66667%; }
+  .grid-x > .large-3 {
+    width: 25%; }
+  .grid-x > .large-4 {
+    width: 33.33333%; }
+  .grid-x > .large-5 {
+    width: 41.66667%; }
+  .grid-x > .large-6 {
+    width: 50%; }
+  .grid-x > .large-7 {
+    width: 58.33333%; }
+  .grid-x > .large-8 {
+    width: 66.66667%; }
+  .grid-x > .large-9 {
+    width: 75%; }
+  .grid-x > .large-10 {
+    width: 83.33333%; }
+  .grid-x > .large-11 {
+    width: 91.66667%; }
+  .grid-x > .large-12 {
+    width: 100%; } }
 
-.grid-padding-y > .cell {
-  padding-top: 0.625rem;
-  padding-bottom: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-padding-y > .cell {
-      padding-top: 0.9375rem;
-      padding-bottom: 0.9375rem; } }
+.grid-margin-x:not(.grid-x) > .cell {
+  width: auto; }
 
-.grid-margin-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
-  .grid-margin-y > .cell {
-    height: calc(100% - 1.25rem);
-    margin-top: 0.625rem;
-    margin-bottom: 0.625rem; }
+.grid-margin-y:not(.grid-y) > .cell {
+  height: auto; }
+
+.grid-margin-x {
+  margin-left: -0.625rem;
+  margin-right: -0.625rem; }
   @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .cell {
-      height: calc(100% - 1.875rem);
-      margin-top: 0.9375rem;
-      margin-bottom: 0.9375rem; } }
-  .grid-margin-y > .auto {
-    height: auto; }
-  .grid-margin-y > .shrink {
-    height: auto; }
-  .grid-margin-y > .small-1 {
-    height: calc(8.33333% - 1.25rem); }
-  .grid-margin-y > .small-2 {
-    height: calc(16.66667% - 1.25rem); }
-  .grid-margin-y > .small-3 {
-    height: calc(25% - 1.25rem); }
-  .grid-margin-y > .small-4 {
-    height: calc(33.33333% - 1.25rem); }
-  .grid-margin-y > .small-5 {
-    height: calc(41.66667% - 1.25rem); }
-  .grid-margin-y > .small-6 {
-    height: calc(50% - 1.25rem); }
-  .grid-margin-y > .small-7 {
-    height: calc(58.33333% - 1.25rem); }
-  .grid-margin-y > .small-8 {
-    height: calc(66.66667% - 1.25rem); }
-  .grid-margin-y > .small-9 {
-    height: calc(75% - 1.25rem); }
-  .grid-margin-y > .small-10 {
-    height: calc(83.33333% - 1.25rem); }
-  .grid-margin-y > .small-11 {
-    height: calc(91.66667% - 1.25rem); }
-  .grid-margin-y > .small-12 {
-    height: calc(100% - 1.25rem); }
+    .grid-margin-x {
+      margin-left: -0.9375rem;
+      margin-right: -0.9375rem; } }
+  .grid-margin-x > .cell {
+    width: calc(100% - 1.25rem);
+    margin-left: 0.625rem;
+    margin-right: 0.625rem; }
   @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .auto {
-      height: auto; }
-    .grid-margin-y > .shrink {
-      height: auto; }
-    .grid-margin-y > .small-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .small-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .small-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .small-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .small-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .small-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .small-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .small-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .small-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .small-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .small-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .small-12 {
-      height: calc(100% - 1.875rem); }
-    .grid-margin-y > .medium-auto {
-      height: auto; }
-    .grid-margin-y > .medium-shrink {
-      height: auto; }
-    .grid-margin-y > .medium-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .medium-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .medium-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .medium-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .medium-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .medium-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .medium-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .medium-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .medium-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .medium-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .medium-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .medium-12 {
-      height: calc(100% - 1.875rem); } }
+    .grid-margin-x > .cell {
+      width: calc(100% - 1.875rem);
+      margin-left: 0.9375rem;
+      margin-right: 0.9375rem; } }
+  .grid-margin-x > .auto {
+    width: auto; }
+  .grid-margin-x > .shrink {
+    width: auto; }
+  .grid-margin-x > .small-1 {
+    width: calc(8.33333% - 1.25rem); }
+  .grid-margin-x > .small-2 {
+    width: calc(16.66667% - 1.25rem); }
+  .grid-margin-x > .small-3 {
+    width: calc(25% - 1.25rem); }
+  .grid-margin-x > .small-4 {
+    width: calc(33.33333% - 1.25rem); }
+  .grid-margin-x > .small-5 {
+    width: calc(41.66667% - 1.25rem); }
+  .grid-margin-x > .small-6 {
+    width: calc(50% - 1.25rem); }
+  .grid-margin-x > .small-7 {
+    width: calc(58.33333% - 1.25rem); }
+  .grid-margin-x > .small-8 {
+    width: calc(66.66667% - 1.25rem); }
+  .grid-margin-x > .small-9 {
+    width: calc(75% - 1.25rem); }
+  .grid-margin-x > .small-10 {
+    width: calc(83.33333% - 1.25rem); }
+  .grid-margin-x > .small-11 {
+    width: calc(91.66667% - 1.25rem); }
+  .grid-margin-x > .small-12 {
+    width: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-x > .auto {
+      width: auto; }
+    .grid-margin-x > .shrink {
+      width: auto; }
+    .grid-margin-x > .small-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .small-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .small-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .small-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .small-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .small-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .small-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .small-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .small-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .small-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .small-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .small-12 {
+      width: calc(100% - 1.875rem); }
+    .grid-margin-x > .medium-auto {
+      width: auto; }
+    .grid-margin-x > .medium-shrink {
+      width: auto; }
+    .grid-margin-x > .medium-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .medium-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .medium-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .medium-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .medium-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .medium-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .medium-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .medium-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .medium-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .medium-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .medium-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .medium-12 {
+      width: calc(100% - 1.875rem); } }
   @media print, screen and (min-width: 64em) {
-    .grid-margin-y > .large-auto {
-      height: auto; }
-    .grid-margin-y > .large-shrink {
-      height: auto; }
-    .grid-margin-y > .large-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .large-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .large-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .large-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .large-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .large-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .large-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .large-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .large-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .large-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .large-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .large-12 {
-      height: calc(100% - 1.875rem); } }
+    .grid-margin-x > .large-auto {
+      width: auto; }
+    .grid-margin-x > .large-shrink {
+      width: auto; }
+    .grid-margin-x > .large-1 {
+      width: calc(8.33333% - 1.875rem); }
+    .grid-margin-x > .large-2 {
+      width: calc(16.66667% - 1.875rem); }
+    .grid-margin-x > .large-3 {
+      width: calc(25% - 1.875rem); }
+    .grid-margin-x > .large-4 {
+      width: calc(33.33333% - 1.875rem); }
+    .grid-margin-x > .large-5 {
+      width: calc(41.66667% - 1.875rem); }
+    .grid-margin-x > .large-6 {
+      width: calc(50% - 1.875rem); }
+    .grid-margin-x > .large-7 {
+      width: calc(58.33333% - 1.875rem); }
+    .grid-margin-x > .large-8 {
+      width: calc(66.66667% - 1.875rem); }
+    .grid-margin-x > .large-9 {
+      width: calc(75% - 1.875rem); }
+    .grid-margin-x > .large-10 {
+      width: calc(83.33333% - 1.875rem); }
+    .grid-margin-x > .large-11 {
+      width: calc(91.66667% - 1.875rem); }
+    .grid-margin-x > .large-12 {
+      width: calc(100% - 1.875rem); } }
 
-.grid-frame {
-  overflow: hidden;
-  position: relative;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch;
-  width: 100vw; }
+.grid-padding-x .grid-padding-x {
+  margin-right: -0.625rem;
+  margin-left: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-x .grid-padding-x {
+      margin-right: -0.9375rem;
+      margin-left: -0.9375rem; } }
 
-.cell .grid-frame {
+.grid-container:not(.full) > .grid-padding-x {
+  margin-right: -0.625rem;
+  margin-left: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-container:not(.full) > .grid-padding-x {
+      margin-right: -0.9375rem;
+      margin-left: -0.9375rem; } }
+
+.grid-padding-x > .cell {
+  padding-right: 0.625rem;
+  padding-left: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-x > .cell {
+      padding-right: 0.9375rem;
+      padding-left: 0.9375rem; } }
+
+.small-up-1 > .cell {
   width: 100%; }
 
-.cell-block {
-  overflow-x: auto;
-  max-width: 100%;
-  -webkit-overflow-scrolling: touch;
-  -ms-overflow-stype: -ms-autohiding-scrollbar; }
+.small-up-2 > .cell {
+  width: 50%; }
 
-.cell-block-y {
-  overflow-y: auto;
-  max-height: 100%;
-  -webkit-overflow-scrolling: touch;
-  -ms-overflow-stype: -ms-autohiding-scrollbar; }
+.small-up-3 > .cell {
+  width: 33.33333%; }
 
-.cell-block-container {
-  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;
-  max-height: 100%; }
-  .cell-block-container > .grid-x {
-    max-height: 100%;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap; }
+.small-up-4 > .cell {
+  width: 25%; }
+
+.small-up-5 > .cell {
+  width: 20%; }
+
+.small-up-6 > .cell {
+  width: 16.66667%; }
+
+.small-up-7 > .cell {
+  width: 14.28571%; }
+
+.small-up-8 > .cell {
+  width: 12.5%; }
 
 @media print, screen and (min-width: 40em) {
-  .medium-grid-frame {
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    width: 100vw; }
-  .cell .medium-grid-frame {
+  .medium-up-1 > .cell {
     width: 100%; }
-  .medium-cell-block {
-    overflow-x: auto;
-    max-width: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; }
-  .medium-cell-block-container {
-    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;
-    max-height: 100%; }
-    .medium-cell-block-container > .grid-x {
-      max-height: 100%;
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap; }
-  .medium-cell-block-y {
-    overflow-y: auto;
-    max-height: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; } }
+  .medium-up-2 > .cell {
+    width: 50%; }
+  .medium-up-3 > .cell {
+    width: 33.33333%; }
+  .medium-up-4 > .cell {
+    width: 25%; }
+  .medium-up-5 > .cell {
+    width: 20%; }
+  .medium-up-6 > .cell {
+    width: 16.66667%; }
+  .medium-up-7 > .cell {
+    width: 14.28571%; }
+  .medium-up-8 > .cell {
+    width: 12.5%; } }
 
 @media print, screen and (min-width: 64em) {
-  .large-grid-frame {
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    width: 100vw; }
-  .cell .large-grid-frame {
+  .large-up-1 > .cell {
     width: 100%; }
-  .large-cell-block {
-    overflow-x: auto;
-    max-width: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; }
-  .large-cell-block-container {
-    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;
-    max-height: 100%; }
-    .large-cell-block-container > .grid-x {
-      max-height: 100%;
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap; }
-  .large-cell-block-y {
-    overflow-y: auto;
-    max-height: 100%;
-    -webkit-overflow-scrolling: touch;
-    -ms-overflow-stype: -ms-autohiding-scrollbar; } }
+  .large-up-2 > .cell {
+    width: 50%; }
+  .large-up-3 > .cell {
+    width: 33.33333%; }
+  .large-up-4 > .cell {
+    width: 25%; }
+  .large-up-5 > .cell {
+    width: 20%; }
+  .large-up-6 > .cell {
+    width: 16.66667%; }
+  .large-up-7 > .cell {
+    width: 14.28571%; }
+  .large-up-8 > .cell {
+    width: 12.5%; } }
 
-.grid-y.grid-frame {
-  width: auto;
-  overflow: hidden;
-  position: relative;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch;
-  height: 100vh; }
+.grid-margin-x.small-up-1 > .cell {
+  width: calc(100% - 1.25rem); }
 
-@media print, screen and (min-width: 40em) {
-  .grid-y.medium-grid-frame {
-    width: auto;
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    height: 100vh; } }
+.grid-margin-x.small-up-2 > .cell {
+  width: calc(50% - 1.25rem); }
 
-@media print, screen and (min-width: 64em) {
-  .grid-y.large-grid-frame {
-    width: auto;
-    overflow: hidden;
-    position: relative;
-    -webkit-flex-wrap: nowrap;
-        -ms-flex-wrap: nowrap;
-            flex-wrap: nowrap;
-    -webkit-box-align: stretch;
-    -webkit-align-items: stretch;
-        -ms-flex-align: stretch;
-            align-items: stretch;
-    height: 100vh; } }
+.grid-margin-x.small-up-3 > .cell {
+  width: calc(33.33333% - 1.25rem); }
 
-.cell .grid-y.grid-frame {
-  height: 100%; }
+.grid-margin-x.small-up-4 > .cell {
+  width: calc(25% - 1.25rem); }
 
-@media print, screen and (min-width: 40em) {
-  .cell .grid-y.medium-grid-frame {
-    height: 100%; } }
+.grid-margin-x.small-up-5 > .cell {
+  width: calc(20% - 1.25rem); }
 
-@media print, screen and (min-width: 64em) {
-  .cell .grid-y.large-grid-frame {
-    height: 100%; } }
+.grid-margin-x.small-up-6 > .cell {
+  width: calc(16.66667% - 1.25rem); }
 
-.grid-margin-y {
-  margin-top: -0.625rem;
-  margin-bottom: -0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y {
-      margin-top: -0.9375rem;
-      margin-bottom: -0.9375rem; } }
-  .grid-margin-y > .cell {
-    height: calc(100% - 1.25rem);
-    margin-top: 0.625rem;
-    margin-bottom: 0.625rem; }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .cell {
-      height: calc(100% - 1.875rem);
-      margin-top: 0.9375rem;
-      margin-bottom: 0.9375rem; } }
-  .grid-margin-y > .auto {
-    height: auto; }
-  .grid-margin-y > .shrink {
-    height: auto; }
-  .grid-margin-y > .small-1 {
-    height: calc(8.33333% - 1.25rem); }
-  .grid-margin-y > .small-2 {
-    height: calc(16.66667% - 1.25rem); }
-  .grid-margin-y > .small-3 {
-    height: calc(25% - 1.25rem); }
-  .grid-margin-y > .small-4 {
-    height: calc(33.33333% - 1.25rem); }
-  .grid-margin-y > .small-5 {
-    height: calc(41.66667% - 1.25rem); }
-  .grid-margin-y > .small-6 {
-    height: calc(50% - 1.25rem); }
-  .grid-margin-y > .small-7 {
-    height: calc(58.33333% - 1.25rem); }
-  .grid-margin-y > .small-8 {
-    height: calc(66.66667% - 1.25rem); }
-  .grid-margin-y > .small-9 {
-    height: calc(75% - 1.25rem); }
-  .grid-margin-y > .small-10 {
-    height: calc(83.33333% - 1.25rem); }
-  .grid-margin-y > .small-11 {
-    height: calc(91.66667% - 1.25rem); }
-  .grid-margin-y > .small-12 {
-    height: calc(100% - 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-margin-y > .auto {
-      height: auto; }
-    .grid-margin-y > .shrink {
-      height: auto; }
-    .grid-margin-y > .small-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .small-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .small-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .small-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .small-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .small-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .small-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .small-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .small-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .small-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .small-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .small-12 {
-      height: calc(100% - 1.875rem); }
-    .grid-margin-y > .medium-auto {
-      height: auto; }
-    .grid-margin-y > .medium-shrink {
-      height: auto; }
-    .grid-margin-y > .medium-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .medium-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .medium-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .medium-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .medium-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .medium-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .medium-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .medium-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .medium-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .medium-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .medium-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .medium-12 {
-      height: calc(100% - 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-margin-y > .large-auto {
-      height: auto; }
-    .grid-margin-y > .large-shrink {
-      height: auto; }
-    .grid-margin-y > .large-1 {
-      height: calc(8.33333% - 1.875rem); }
-    .grid-margin-y > .large-2 {
-      height: calc(16.66667% - 1.875rem); }
-    .grid-margin-y > .large-3 {
-      height: calc(25% - 1.875rem); }
-    .grid-margin-y > .large-4 {
-      height: calc(33.33333% - 1.875rem); }
-    .grid-margin-y > .large-5 {
-      height: calc(41.66667% - 1.875rem); }
-    .grid-margin-y > .large-6 {
-      height: calc(50% - 1.875rem); }
-    .grid-margin-y > .large-7 {
-      height: calc(58.33333% - 1.875rem); }
-    .grid-margin-y > .large-8 {
-      height: calc(66.66667% - 1.875rem); }
-    .grid-margin-y > .large-9 {
-      height: calc(75% - 1.875rem); }
-    .grid-margin-y > .large-10 {
-      height: calc(83.33333% - 1.875rem); }
-    .grid-margin-y > .large-11 {
-      height: calc(91.66667% - 1.875rem); }
-    .grid-margin-y > .large-12 {
-      height: calc(100% - 1.875rem); } }
+.grid-margin-x.small-up-7 > .cell {
+  width: calc(14.28571% - 1.25rem); }
 
-.grid-frame.grid-margin-y {
-  height: calc(100vh + 1.25rem); }
-  @media print, screen and (min-width: 40em) {
-    .grid-frame.grid-margin-y {
-      height: calc(100vh + 1.875rem); } }
-  @media print, screen and (min-width: 64em) {
-    .grid-frame.grid-margin-y {
-      height: calc(100vh + 1.875rem); } }
+.grid-margin-x.small-up-8 > .cell {
+  width: calc(12.5% - 1.25rem); }
 
 @media print, screen and (min-width: 40em) {
-  .grid-margin-y.medium-grid-frame {
-    height: calc(100vh + 1.875rem); } }
+  .grid-margin-x.small-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.small-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.small-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.small-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.small-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.small-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.small-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.small-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); }
+  .grid-margin-x.medium-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.medium-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.medium-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.medium-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.medium-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.medium-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.medium-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.medium-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); } }
 
 @media print, screen and (min-width: 64em) {
-  .grid-margin-y.large-grid-frame {
-    height: calc(100vh + 1.875rem); } }
-
-div,
-dl,
-dt,
-dd,
-ul,
-ol,
-li,
-h1,
-h2,
-h3,
-h4,
-h5,
-h6,
-pre,
-form,
-p,
-blockquote,
-th,
-td {
-  margin: 0;
-  padding: 0; }
-
-p {
-  margin-bottom: 1rem;
-  font-size: inherit;
-  line-height: 1.6;
-  text-rendering: optimizeLegibility; }
-
-em,
-i {
-  font-style: italic;
-  line-height: inherit; }
-
-strong,
-b {
-  font-weight: bold;
-  line-height: inherit; }
-
-small {
-  font-size: 80%;
-  line-height: inherit; }
-
-h1, .h1,
-h2, .h2,
-h3, .h3,
-h4, .h4,
-h5, .h5,
-h6, .h6 {
-  font-family: "Helvetica Neue", Helvetica, Roboto, Arial, sans-serif;
-  font-style: normal;
-  font-weight: normal;
-  color: inherit;
-  text-rendering: optimizeLegibility; }
-  h1 small, .h1 small,
-  h2 small, .h2 small,
-  h3 small, .h3 small,
-  h4 small, .h4 small,
-  h5 small, .h5 small,
-  h6 small, .h6 small {
-    line-height: 0;
-    color: #cacaca; }
-
-h1, .h1 {
-  font-size: 1.5rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
-
-h2, .h2 {
-  font-size: 1.25rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
-
-h3, .h3 {
-  font-size: 1.1875rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+  .grid-margin-x.large-up-1 > .cell {
+    width: calc(100% - 1.875rem); }
+  .grid-margin-x.large-up-2 > .cell {
+    width: calc(50% - 1.875rem); }
+  .grid-margin-x.large-up-3 > .cell {
+    width: calc(33.33333% - 1.875rem); }
+  .grid-margin-x.large-up-4 > .cell {
+    width: calc(25% - 1.875rem); }
+  .grid-margin-x.large-up-5 > .cell {
+    width: calc(20% - 1.875rem); }
+  .grid-margin-x.large-up-6 > .cell {
+    width: calc(16.66667% - 1.875rem); }
+  .grid-margin-x.large-up-7 > .cell {
+    width: calc(14.28571% - 1.875rem); }
+  .grid-margin-x.large-up-8 > .cell {
+    width: calc(12.5% - 1.875rem); } }
 
-h4, .h4 {
-  font-size: 1.125rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
-
-h5, .h5 {
-  font-size: 1.0625rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-margin-collapse {
+  margin-right: 0;
+  margin-left: 0; }
+  .small-margin-collapse > .cell {
+    margin-right: 0;
+    margin-left: 0; }
+  .small-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .small-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .small-margin-collapse > .small-3 {
+    width: 25%; }
+  .small-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .small-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .small-margin-collapse > .small-6 {
+    width: 50%; }
+  .small-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .small-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .small-margin-collapse > .small-9 {
+    width: 75%; }
+  .small-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .small-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .small-margin-collapse > .small-12 {
+    width: 100%; }
+  @media print, screen and (min-width: 40em) {
+    .small-margin-collapse > .medium-1 {
+      width: 8.33333%; }
+    .small-margin-collapse > .medium-2 {
+      width: 16.66667%; }
+    .small-margin-collapse > .medium-3 {
+      width: 25%; }
+    .small-margin-collapse > .medium-4 {
+      width: 33.33333%; }
+    .small-margin-collapse > .medium-5 {
+      width: 41.66667%; }
+    .small-margin-collapse > .medium-6 {
+      width: 50%; }
+    .small-margin-collapse > .medium-7 {
+      width: 58.33333%; }
+    .small-margin-collapse > .medium-8 {
+      width: 66.66667%; }
+    .small-margin-collapse > .medium-9 {
+      width: 75%; }
+    .small-margin-collapse > .medium-10 {
+      width: 83.33333%; }
+    .small-margin-collapse > .medium-11 {
+      width: 91.66667%; }
+    .small-margin-collapse > .medium-12 {
+      width: 100%; } }
+  @media print, screen and (min-width: 64em) {
+    .small-margin-collapse > .large-1 {
+      width: 8.33333%; }
+    .small-margin-collapse > .large-2 {
+      width: 16.66667%; }
+    .small-margin-collapse > .large-3 {
+      width: 25%; }
+    .small-margin-collapse > .large-4 {
+      width: 33.33333%; }
+    .small-margin-collapse > .large-5 {
+      width: 41.66667%; }
+    .small-margin-collapse > .large-6 {
+      width: 50%; }
+    .small-margin-collapse > .large-7 {
+      width: 58.33333%; }
+    .small-margin-collapse > .large-8 {
+      width: 66.66667%; }
+    .small-margin-collapse > .large-9 {
+      width: 75%; }
+    .small-margin-collapse > .large-10 {
+      width: 83.33333%; }
+    .small-margin-collapse > .large-11 {
+      width: 91.66667%; }
+    .small-margin-collapse > .large-12 {
+      width: 100%; } }
 
-h6, .h6 {
-  font-size: 1rem;
-  line-height: 1.4;
-  margin-top: 0;
-  margin-bottom: 0.5rem; }
+.small-padding-collapse {
+  margin-right: 0;
+  margin-left: 0; }
+  .small-padding-collapse > .cell {
+    padding-right: 0;
+    padding-left: 0; }
 
 @media print, screen and (min-width: 40em) {
-  h1, .h1 {
-    font-size: 3rem; }
-  h2, .h2 {
-    font-size: 2.5rem; }
-  h3, .h3 {
-    font-size: 1.9375rem; }
-  h4, .h4 {
-    font-size: 1.5625rem; }
-  h5, .h5 {
-    font-size: 1.25rem; }
-  h6, .h6 {
-    font-size: 1rem; } }
-
-a {
-  line-height: inherit;
-  color: #1779ba;
-  text-decoration: none;
-  cursor: pointer; }
-  a:hover, a:focus {
-    color: #1468a0; }
-  a img {
-    border: 0; }
-
-hr {
-  clear: both;
-  max-width: 75rem;
-  height: 0;
-  margin: 1.25rem auto;
-  border-top: 0;
-  border-right: 0;
-  border-bottom: 1px solid #cacaca;
-  border-left: 0; }
-
-ul,
-ol,
-dl {
-  margin-bottom: 1rem;
-  list-style-position: outside;
-  line-height: 1.6; }
-
-li {
-  font-size: inherit; }
+  .medium-margin-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .medium-margin-collapse > .cell {
+      margin-right: 0;
+      margin-left: 0; } }
 
-ul {
-  margin-left: 1.25rem;
-  list-style-type: disc; }
+@media print, screen and (min-width: 40em) {
+  .medium-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .small-3 {
+    width: 25%; }
+  .medium-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .small-6 {
+    width: 50%; }
+  .medium-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .small-9 {
+    width: 75%; }
+  .medium-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .small-12 {
+    width: 100%; } }
 
-ol {
-  margin-left: 1.25rem; }
+@media print, screen and (min-width: 40em) {
+  .medium-margin-collapse > .medium-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .medium-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .medium-3 {
+    width: 25%; }
+  .medium-margin-collapse > .medium-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .medium-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .medium-6 {
+    width: 50%; }
+  .medium-margin-collapse > .medium-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .medium-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .medium-9 {
+    width: 75%; }
+  .medium-margin-collapse > .medium-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .medium-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .medium-12 {
+    width: 100%; } }
 
-ul ul, ol ul, ul ol, ol ol {
-  margin-left: 1.25rem;
-  margin-bottom: 0; }
+@media print, screen and (min-width: 64em) {
+  .medium-margin-collapse > .large-1 {
+    width: 8.33333%; }
+  .medium-margin-collapse > .large-2 {
+    width: 16.66667%; }
+  .medium-margin-collapse > .large-3 {
+    width: 25%; }
+  .medium-margin-collapse > .large-4 {
+    width: 33.33333%; }
+  .medium-margin-collapse > .large-5 {
+    width: 41.66667%; }
+  .medium-margin-collapse > .large-6 {
+    width: 50%; }
+  .medium-margin-collapse > .large-7 {
+    width: 58.33333%; }
+  .medium-margin-collapse > .large-8 {
+    width: 66.66667%; }
+  .medium-margin-collapse > .large-9 {
+    width: 75%; }
+  .medium-margin-collapse > .large-10 {
+    width: 83.33333%; }
+  .medium-margin-collapse > .large-11 {
+    width: 91.66667%; }
+  .medium-margin-collapse > .large-12 {
+    width: 100%; } }
 
-dl {
-  margin-bottom: 1rem; }
-  dl dt {
-    margin-bottom: 0.3rem;
-    font-weight: bold; }
+@media print, screen and (min-width: 40em) {
+  .medium-padding-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .medium-padding-collapse > .cell {
+      padding-right: 0;
+      padding-left: 0; } }
 
-blockquote {
-  margin: 0 0 1rem;
-  padding: 0.5625rem 1.25rem 0 1.1875rem;
-  border-left: 1px solid #cacaca; }
-  blockquote, blockquote p {
-    line-height: 1.6;
-    color: #8a8a8a; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .large-margin-collapse > .cell {
+      margin-right: 0;
+      margin-left: 0; } }
 
-cite {
-  display: block;
-  font-size: 0.8125rem;
-  color: #8a8a8a; }
-  cite:before {
-    content: "— "; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .small-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .small-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .small-3 {
+    width: 25%; }
+  .large-margin-collapse > .small-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .small-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .small-6 {
+    width: 50%; }
+  .large-margin-collapse > .small-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .small-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .small-9 {
+    width: 75%; }
+  .large-margin-collapse > .small-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .small-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .small-12 {
+    width: 100%; } }
 
-abbr, abbr[title] {
-  border-bottom: 1px dotted #0a0a0a;
-  cursor: help;
-  text-decoration: none; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .medium-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .medium-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .medium-3 {
+    width: 25%; }
+  .large-margin-collapse > .medium-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .medium-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .medium-6 {
+    width: 50%; }
+  .large-margin-collapse > .medium-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .medium-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .medium-9 {
+    width: 75%; }
+  .large-margin-collapse > .medium-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .medium-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .medium-12 {
+    width: 100%; } }
 
-figure {
-  margin: 0; }
+@media print, screen and (min-width: 64em) {
+  .large-margin-collapse > .large-1 {
+    width: 8.33333%; }
+  .large-margin-collapse > .large-2 {
+    width: 16.66667%; }
+  .large-margin-collapse > .large-3 {
+    width: 25%; }
+  .large-margin-collapse > .large-4 {
+    width: 33.33333%; }
+  .large-margin-collapse > .large-5 {
+    width: 41.66667%; }
+  .large-margin-collapse > .large-6 {
+    width: 50%; }
+  .large-margin-collapse > .large-7 {
+    width: 58.33333%; }
+  .large-margin-collapse > .large-8 {
+    width: 66.66667%; }
+  .large-margin-collapse > .large-9 {
+    width: 75%; }
+  .large-margin-collapse > .large-10 {
+    width: 83.33333%; }
+  .large-margin-collapse > .large-11 {
+    width: 91.66667%; }
+  .large-margin-collapse > .large-12 {
+    width: 100%; } }
 
-code {
-  padding: 0.125rem 0.3125rem 0.0625rem;
-  border: 1px solid #cacaca;
-  background-color: #e6e6e6;
-  font-family: Consolas, "Liberation Mono", Courier, monospace;
-  font-weight: normal;
-  color: #0a0a0a; }
+@media print, screen and (min-width: 64em) {
+  .large-padding-collapse {
+    margin-right: 0;
+    margin-left: 0; }
+    .large-padding-collapse > .cell {
+      padding-right: 0;
+      padding-left: 0; } }
 
-kbd {
-  margin: 0;
-  padding: 0.125rem 0.25rem 0;
-  background-color: #e6e6e6;
-  font-family: Consolas, "Liberation Mono", Courier, monospace;
-  color: #0a0a0a; }
+.small-offset-0 {
+  margin-left: 0%; }
 
-.subheader {
-  margin-top: 0.2rem;
-  margin-bottom: 0.5rem;
-  font-weight: normal;
-  line-height: 1.4;
-  color: #8a8a8a; }
+.grid-margin-x > .small-offset-0 {
+  margin-left: calc(0% + 0.625rem); }
 
-.lead {
-  font-size: 125%;
-  line-height: 1.6; }
+.small-offset-1 {
+  margin-left: 8.33333%; }
 
-.stat {
-  font-size: 2.5rem;
-  line-height: 1; }
-  p + .stat {
-    margin-top: -1rem; }
+.grid-margin-x > .small-offset-1 {
+  margin-left: calc(8.33333% + 0.625rem); }
 
-ul.no-bullet, ol.no-bullet {
-  margin-left: 0;
-  list-style: none; }
+.small-offset-2 {
+  margin-left: 16.66667%; }
 
-.text-left {
-  text-align: left; }
+.grid-margin-x > .small-offset-2 {
+  margin-left: calc(16.66667% + 0.625rem); }
 
-.text-right {
-  text-align: right; }
+.small-offset-3 {
+  margin-left: 25%; }
 
-.text-center {
-  text-align: center; }
+.grid-margin-x > .small-offset-3 {
+  margin-left: calc(25% + 0.625rem); }
 
-.text-justify {
-  text-align: justify; }
+.small-offset-4 {
+  margin-left: 33.33333%; }
 
-@media print, screen and (min-width: 40em) {
-  .medium-text-left {
-    text-align: left; }
-  .medium-text-right {
-    text-align: right; }
-  .medium-text-center {
-    text-align: center; }
-  .medium-text-justify {
-    text-align: justify; } }
+.grid-margin-x > .small-offset-4 {
+  margin-left: calc(33.33333% + 0.625rem); }
 
-@media print, screen and (min-width: 64em) {
-  .large-text-left {
-    text-align: left; }
-  .large-text-right {
-    text-align: right; }
-  .large-text-center {
-    text-align: center; }
-  .large-text-justify {
-    text-align: justify; } }
+.small-offset-5 {
+  margin-left: 41.66667%; }
 
-.show-for-print {
-  display: none !important; }
+.grid-margin-x > .small-offset-5 {
+  margin-left: calc(41.66667% + 0.625rem); }
 
-@media print {
-  * {
-    background: transparent !important;
-    -webkit-box-shadow: none !important;
-            box-shadow: none !important;
-    color: black !important;
-    text-shadow: none !important; }
-  .show-for-print {
-    display: block !important; }
-  .hide-for-print {
-    display: none !important; }
-  table.show-for-print {
-    display: table !important; }
-  thead.show-for-print {
-    display: table-header-group !important; }
-  tbody.show-for-print {
-    display: table-row-group !important; }
-  tr.show-for-print {
-    display: table-row !important; }
-  td.show-for-print {
-    display: table-cell !important; }
-  th.show-for-print {
-    display: table-cell !important; }
-  a,
-  a:visited {
-    text-decoration: underline; }
-  a[href]:after {
-    content: " (" attr(href) ")"; }
-  .ir a:after,
-  a[href^='javascript:']:after,
-  a[href^='#']:after {
-    content: ''; }
-  abbr[title]:after {
-    content: " (" attr(title) ")"; }
-  pre,
-  blockquote {
-    border: 1px solid #8a8a8a;
-    page-break-inside: avoid; }
-  thead {
-    display: table-header-group; }
-  tr,
-  img {
-    page-break-inside: avoid; }
-  img {
-    max-width: 100% !important; }
-  @page {
-    margin: 0.5cm; }
-  p,
-  h2,
-  h3 {
-    orphans: 3;
-    widows: 3; }
-  h2,
-  h3 {
-    page-break-after: avoid; }
-  .print-break-inside {
-    page-break-inside: auto; } }
+.small-offset-6 {
+  margin-left: 50%; }
 
-[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],
-textarea {
-  display: block;
-  -webkit-box-sizing: border-box;
-          box-sizing: border-box;
-  width: 100%;
-  height: 2.4375rem;
-  margin: 0 0 1rem;
-  padding: 0.5rem;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  -webkit-box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
-          box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);
-  font-family: inherit;
-  font-size: 1rem;
-  font-weight: normal;
-  line-height: 1.5;
-  color: #0a0a0a;
-  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none; }
-  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,
-  textarea:focus {
-    outline: none;
-    border: 1px solid #8a8a8a;
-    background-color: #fefefe;
-    -webkit-box-shadow: 0 0 5px #cacaca;
-            box-shadow: 0 0 5px #cacaca;
-    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-
-textarea {
-  max-width: 100%; }
-  textarea[rows] {
-    height: auto; }
-
-input::-webkit-input-placeholder,
-textarea::-webkit-input-placeholder {
-  color: #cacaca; }
-
-input:-ms-input-placeholder,
-textarea:-ms-input-placeholder {
-  color: #cacaca; }
-
-input::placeholder,
-textarea::placeholder {
-  color: #cacaca; }
-
-input:disabled, input[readonly],
-textarea:disabled,
-textarea[readonly] {
-  background-color: #e6e6e6;
-  cursor: not-allowed; }
+.grid-margin-x > .small-offset-6 {
+  margin-left: calc(50% + 0.625rem); }
 
-[type='submit'],
-[type='button'] {
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none;
-  border-radius: 0; }
+.small-offset-7 {
+  margin-left: 58.33333%; }
 
-input[type='search'] {
-  -webkit-box-sizing: border-box;
-          box-sizing: border-box; }
+.grid-margin-x > .small-offset-7 {
+  margin-left: calc(58.33333% + 0.625rem); }
 
-[type='file'],
-[type='checkbox'],
-[type='radio'] {
-  margin: 0 0 1rem; }
+.small-offset-8 {
+  margin-left: 66.66667%; }
 
-[type='checkbox'] + label,
-[type='radio'] + label {
-  display: inline-block;
-  vertical-align: baseline;
-  margin-left: 0.5rem;
-  margin-right: 1rem;
-  margin-bottom: 0; }
-  [type='checkbox'] + label[for],
-  [type='radio'] + label[for] {
-    cursor: pointer; }
+.grid-margin-x > .small-offset-8 {
+  margin-left: calc(66.66667% + 0.625rem); }
 
-label > [type='checkbox'],
-label > [type='radio'] {
-  margin-right: 0.5rem; }
+.small-offset-9 {
+  margin-left: 75%; }
 
-[type='file'] {
-  width: 100%; }
+.grid-margin-x > .small-offset-9 {
+  margin-left: calc(75% + 0.625rem); }
 
-label {
-  display: block;
-  margin: 0;
-  font-size: 0.875rem;
-  font-weight: normal;
-  line-height: 1.8;
-  color: #0a0a0a; }
-  label.middle {
-    margin: 0 0 1rem;
-    padding: 0.5625rem 0; }
+.small-offset-10 {
+  margin-left: 83.33333%; }
 
-.help-text {
-  margin-top: -0.5rem;
-  font-size: 0.8125rem;
-  font-style: italic;
-  color: #0a0a0a; }
+.grid-margin-x > .small-offset-10 {
+  margin-left: calc(83.33333% + 0.625rem); }
 
-.input-group {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  width: 100%;
-  margin-bottom: 1rem;
-  -webkit-box-align: stretch;
-  -webkit-align-items: stretch;
-      -ms-flex-align: stretch;
-          align-items: stretch; }
-  .input-group > :first-child {
-    border-radius: 0 0 0 0; }
-  .input-group > :last-child > * {
-    border-radius: 0 0 0 0; }
+.small-offset-11 {
+  margin-left: 91.66667%; }
 
-.input-group-label, .input-group-field, .input-group-button, .input-group-button a,
-.input-group-button input,
-.input-group-button button,
-.input-group-button label {
-  margin: 0;
-  white-space: nowrap; }
+.grid-margin-x > .small-offset-11 {
+  margin-left: calc(91.66667% + 0.625rem); }
 
-.input-group-label {
-  padding: 0 1rem;
-  border: 1px solid #cacaca;
-  background: #e6e6e6;
-  color: #0a0a0a;
-  text-align: center;
-  white-space: nowrap;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto;
-  -webkit-box-align: center;
-  -webkit-align-items: center;
-      -ms-flex-align: center;
-          align-items: center; }
-  .input-group-label:first-child {
-    border-right: 0; }
-  .input-group-label:last-child {
-    border-left: 0; }
+@media print, screen and (min-width: 40em) {
+  .medium-offset-0 {
+    margin-left: 0%; }
+  .grid-margin-x > .medium-offset-0 {
+    margin-left: calc(0% + 0.9375rem); }
+  .medium-offset-1 {
+    margin-left: 8.33333%; }
+  .grid-margin-x > .medium-offset-1 {
+    margin-left: calc(8.33333% + 0.9375rem); }
+  .medium-offset-2 {
+    margin-left: 16.66667%; }
+  .grid-margin-x > .medium-offset-2 {
+    margin-left: calc(16.66667% + 0.9375rem); }
+  .medium-offset-3 {
+    margin-left: 25%; }
+  .grid-margin-x > .medium-offset-3 {
+    margin-left: calc(25% + 0.9375rem); }
+  .medium-offset-4 {
+    margin-left: 33.33333%; }
+  .grid-margin-x > .medium-offset-4 {
+    margin-left: calc(33.33333% + 0.9375rem); }
+  .medium-offset-5 {
+    margin-left: 41.66667%; }
+  .grid-margin-x > .medium-offset-5 {
+    margin-left: calc(41.66667% + 0.9375rem); }
+  .medium-offset-6 {
+    margin-left: 50%; }
+  .grid-margin-x > .medium-offset-6 {
+    margin-left: calc(50% + 0.9375rem); }
+  .medium-offset-7 {
+    margin-left: 58.33333%; }
+  .grid-margin-x > .medium-offset-7 {
+    margin-left: calc(58.33333% + 0.9375rem); }
+  .medium-offset-8 {
+    margin-left: 66.66667%; }
+  .grid-margin-x > .medium-offset-8 {
+    margin-left: calc(66.66667% + 0.9375rem); }
+  .medium-offset-9 {
+    margin-left: 75%; }
+  .grid-margin-x > .medium-offset-9 {
+    margin-left: calc(75% + 0.9375rem); }
+  .medium-offset-10 {
+    margin-left: 83.33333%; }
+  .grid-margin-x > .medium-offset-10 {
+    margin-left: calc(83.33333% + 0.9375rem); }
+  .medium-offset-11 {
+    margin-left: 91.66667%; }
+  .grid-margin-x > .medium-offset-11 {
+    margin-left: calc(91.66667% + 0.9375rem); } }
 
-.input-group-field {
-  border-radius: 0;
-  -webkit-box-flex: 1;
-  -webkit-flex: 1 1 0px;
-      -ms-flex: 1 1 0px;
-          flex: 1 1 0px;
-  height: auto;
-  min-width: 0; }
+@media print, screen and (min-width: 64em) {
+  .large-offset-0 {
+    margin-left: 0%; }
+  .grid-margin-x > .large-offset-0 {
+    margin-left: calc(0% + 0.9375rem); }
+  .large-offset-1 {
+    margin-left: 8.33333%; }
+  .grid-margin-x > .large-offset-1 {
+    margin-left: calc(8.33333% + 0.9375rem); }
+  .large-offset-2 {
+    margin-left: 16.66667%; }
+  .grid-margin-x > .large-offset-2 {
+    margin-left: calc(16.66667% + 0.9375rem); }
+  .large-offset-3 {
+    margin-left: 25%; }
+  .grid-margin-x > .large-offset-3 {
+    margin-left: calc(25% + 0.9375rem); }
+  .large-offset-4 {
+    margin-left: 33.33333%; }
+  .grid-margin-x > .large-offset-4 {
+    margin-left: calc(33.33333% + 0.9375rem); }
+  .large-offset-5 {
+    margin-left: 41.66667%; }
+  .grid-margin-x > .large-offset-5 {
+    margin-left: calc(41.66667% + 0.9375rem); }
+  .large-offset-6 {
+    margin-left: 50%; }
+  .grid-margin-x > .large-offset-6 {
+    margin-left: calc(50% + 0.9375rem); }
+  .large-offset-7 {
+    margin-left: 58.33333%; }
+  .grid-margin-x > .large-offset-7 {
+    margin-left: calc(58.33333% + 0.9375rem); }
+  .large-offset-8 {
+    margin-left: 66.66667%; }
+  .grid-margin-x > .large-offset-8 {
+    margin-left: calc(66.66667% + 0.9375rem); }
+  .large-offset-9 {
+    margin-left: 75%; }
+  .grid-margin-x > .large-offset-9 {
+    margin-left: calc(75% + 0.9375rem); }
+  .large-offset-10 {
+    margin-left: 83.33333%; }
+  .grid-margin-x > .large-offset-10 {
+    margin-left: calc(83.33333% + 0.9375rem); }
+  .large-offset-11 {
+    margin-left: 91.66667%; }
+  .grid-margin-x > .large-offset-11 {
+    margin-left: calc(91.66667% + 0.9375rem); } }
 
-.input-group-button {
-  padding-top: 0;
-  padding-bottom: 0;
-  text-align: center;
+.grid-y {
   display: -webkit-box;
   display: -webkit-flex;
   display: -ms-flexbox;
   display: flex;
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 0 auto;
-      -ms-flex: 0 0 auto;
-          flex: 0 0 auto; }
-  .input-group-button a,
-  .input-group-button input,
-  .input-group-button button,
-  .input-group-button label {
-    height: auto;
-    -webkit-align-self: stretch;
-        -ms-flex-item-align: stretch;
-                -ms-grid-row-align: stretch;
-            align-self: stretch;
-    padding-top: 0;
-    padding-bottom: 0;
-    font-size: 1rem; }
-
-fieldset {
-  margin: 0;
-  padding: 0;
-  border: 0; }
-
-legend {
-  max-width: 100%;
-  margin-bottom: 0.5rem; }
-
-.fieldset {
-  margin: 1.125rem 0;
-  padding: 1.25rem;
-  border: 1px solid #cacaca; }
-  .fieldset legend {
-    margin: 0;
-    margin-left: -0.1875rem;
-    padding: 0 0.1875rem; }
-
-select {
-  height: 2.4375rem;
-  margin: 0 0 1rem;
-  padding: 0.5rem;
-  -webkit-appearance: none;
-     -moz-appearance: none;
-          appearance: none;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  font-family: inherit;
-  font-size: 1rem;
-  font-weight: normal;
-  line-height: 1.5;
-  color: #0a0a0a;
-  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");
-  -webkit-background-origin: content-box;
-          background-origin: content-box;
-  background-position: right -1rem center;
-  background-repeat: no-repeat;
-  -webkit-background-size: 9px 6px;
-          background-size: 9px 6px;
-  padding-right: 1.5rem;
-  -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-  transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-  @media screen and (min-width: 0\0) {
-    select {
-      background-image: url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg=="); } }
-  select:focus {
-    outline: none;
-    border: 1px solid #8a8a8a;
-    background-color: #fefefe;
-    -webkit-box-shadow: 0 0 5px #cacaca;
-            box-shadow: 0 0 5px #cacaca;
-    -webkit-transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out;
-    transition: box-shadow 0.5s, border-color 0.25s ease-in-out, -webkit-box-shadow 0.5s; }
-  select:disabled {
-    background-color: #e6e6e6;
-    cursor: not-allowed; }
-  select::-ms-expand {
-    display: none; }
-  select[multiple] {
-    height: auto;
-    background-image: none; }
-
-.is-invalid-input:not(:focus) {
-  border-color: #cc4b37;
-  background-color: #f9ecea; }
-  .is-invalid-input:not(:focus)::-webkit-input-placeholder {
-    color: #cc4b37; }
-  .is-invalid-input:not(:focus):-ms-input-placeholder {
-    color: #cc4b37; }
-  .is-invalid-input:not(:focus)::placeholder {
-    color: #cc4b37; }
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-flow: column nowrap;
+      -ms-flex-flow: column nowrap;
+          flex-flow: column nowrap; }
+  .grid-y > .cell {
+    width: auto;
+    max-width: none; }
+  .grid-y > .auto {
+    height: auto; }
+  .grid-y > .shrink {
+    height: auto; }
+  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
+    -webkit-flex-basis: auto;
+        -ms-flex-preferred-size: auto;
+            flex-basis: auto; }
+  @media print, screen and (min-width: 40em) {
+    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
+      -webkit-flex-basis: auto;
+          -ms-flex-preferred-size: auto;
+              flex-basis: auto; } }
+  @media print, screen and (min-width: 64em) {
+    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
+      -webkit-flex-basis: auto;
+          -ms-flex-preferred-size: auto;
+              flex-basis: auto; } }
+  .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+  .grid-y > .small-1 {
+    height: 8.33333%; }
+  .grid-y > .small-2 {
+    height: 16.66667%; }
+  .grid-y > .small-3 {
+    height: 25%; }
+  .grid-y > .small-4 {
+    height: 33.33333%; }
+  .grid-y > .small-5 {
+    height: 41.66667%; }
+  .grid-y > .small-6 {
+    height: 50%; }
+  .grid-y > .small-7 {
+    height: 58.33333%; }
+  .grid-y > .small-8 {
+    height: 66.66667%; }
+  .grid-y > .small-9 {
+    height: 75%; }
+  .grid-y > .small-10 {
+    height: 83.33333%; }
+  .grid-y > .small-11 {
+    height: 91.66667%; }
+  .grid-y > .small-12 {
+    height: 100%; }
+  @media print, screen and (min-width: 40em) {
+    .grid-y > .medium-auto {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px;
+      height: auto; }
+    .grid-y > .medium-shrink, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto; }
+    .grid-y > .medium-shrink {
+      height: auto; }
+    .grid-y > .medium-1 {
+      height: 8.33333%; }
+    .grid-y > .medium-2 {
+      height: 16.66667%; }
+    .grid-y > .medium-3 {
+      height: 25%; }
+    .grid-y > .medium-4 {
+      height: 33.33333%; }
+    .grid-y > .medium-5 {
+      height: 41.66667%; }
+    .grid-y > .medium-6 {
+      height: 50%; }
+    .grid-y > .medium-7 {
+      height: 58.33333%; }
+    .grid-y > .medium-8 {
+      height: 66.66667%; }
+    .grid-y > .medium-9 {
+      height: 75%; }
+    .grid-y > .medium-10 {
+      height: 83.33333%; }
+    .grid-y > .medium-11 {
+      height: 91.66667%; }
+    .grid-y > .medium-12 {
+      height: 100%; } }
+  @media print, screen and (min-width: 64em) {
+    .grid-y > .large-auto {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px;
+      height: auto; }
+    .grid-y > .large-shrink, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto; }
+    .grid-y > .large-shrink {
+      height: auto; }
+    .grid-y > .large-1 {
+      height: 8.33333%; }
+    .grid-y > .large-2 {
+      height: 16.66667%; }
+    .grid-y > .large-3 {
+      height: 25%; }
+    .grid-y > .large-4 {
+      height: 33.33333%; }
+    .grid-y > .large-5 {
+      height: 41.66667%; }
+    .grid-y > .large-6 {
+      height: 50%; }
+    .grid-y > .large-7 {
+      height: 58.33333%; }
+    .grid-y > .large-8 {
+      height: 66.66667%; }
+    .grid-y > .large-9 {
+      height: 75%; }
+    .grid-y > .large-10 {
+      height: 83.33333%; }
+    .grid-y > .large-11 {
+      height: 91.66667%; }
+    .grid-y > .large-12 {
+      height: 100%; } }
 
-.is-invalid-label {
-  color: #cc4b37; }
+.grid-padding-y .grid-padding-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-y .grid-padding-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
 
-.form-error {
-  display: none;
-  margin-top: -0.5rem;
-  margin-bottom: 1rem;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #cc4b37; }
-  .form-error.is-visible {
-    display: block; }
+.grid-padding-y > .cell {
+  padding-top: 0.625rem;
+  padding-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-padding-y > .cell {
+      padding-top: 0.9375rem;
+      padding-bottom: 0.9375rem; } }
 
-.button {
-  display: inline-block;
-  vertical-align: middle;
-  margin: 0 0 1rem 0;
-  font-family: inherit;
-  padding: 0.85em 1em;
-  -webkit-appearance: none;
-  border: 1px solid transparent;
-  border-radius: 0;
-  -webkit-transition: background-color 0.25s ease-out, color 0.25s ease-out;
-  transition: background-color 0.25s ease-out, color 0.25s ease-out;
-  font-size: 0.9rem;
-  line-height: 1;
-  text-align: center;
-  cursor: pointer;
-  background-color: #1779ba;
-  color: #fefefe; }
-  [data-whatinput='mouse'] .button {
-    outline: 0; }
-  .button:hover, .button:focus {
-    background-color: #14679e;
-    color: #fefefe; }
-  .button.tiny {
-    font-size: 0.6rem; }
-  .button.small {
-    font-size: 0.75rem; }
-  .button.large {
-    font-size: 1.25rem; }
-  .button.expanded {
-    display: block;
-    width: 100%;
-    margin-right: 0;
-    margin-left: 0; }
-  .button.primary {
-    background-color: #1779ba;
-    color: #fefefe; }
-    .button.primary:hover, .button.primary:focus {
-      background-color: #126195;
-      color: #fefefe; }
-  .button.secondary {
-    background-color: #767676;
-    color: #fefefe; }
-    .button.secondary:hover, .button.secondary:focus {
-      background-color: #5e5e5e;
-      color: #fefefe; }
-  .button.success {
-    background-color: #3adb76;
-    color: #0a0a0a; }
-    .button.success:hover, .button.success:focus {
-      background-color: #22bb5b;
-      color: #0a0a0a; }
-  .button.warning {
-    background-color: #ffae00;
-    color: #0a0a0a; }
-    .button.warning:hover, .button.warning:focus {
-      background-color: #cc8b00;
-      color: #0a0a0a; }
-  .button.alert {
-    background-color: #cc4b37;
-    color: #fefefe; }
-    .button.alert:hover, .button.alert:focus {
-      background-color: #a53b2a;
-      color: #fefefe; }
-  .button.disabled, .button[disabled] {
-    opacity: 0.25;
-    cursor: not-allowed; }
-    .button.disabled, .button.disabled:hover, .button.disabled:focus, .button[disabled], .button[disabled]:hover, .button[disabled]:focus {
-      background-color: #1779ba;
-      color: #fefefe; }
-    .button.disabled.primary, .button[disabled].primary {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.primary, .button.disabled.primary:hover, .button.disabled.primary:focus, .button[disabled].primary, .button[disabled].primary:hover, .button[disabled].primary:focus {
-        background-color: #1779ba;
-        color: #fefefe; }
-    .button.disabled.secondary, .button[disabled].secondary {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.secondary, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary, .button[disabled].secondary:hover, .button[disabled].secondary:focus {
-        background-color: #767676;
-        color: #fefefe; }
-    .button.disabled.success, .button[disabled].success {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.success, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success, .button[disabled].success:hover, .button[disabled].success:focus {
-        background-color: #3adb76;
-        color: #0a0a0a; }
-    .button.disabled.warning, .button[disabled].warning {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.warning, .button.disabled.warning:hover, .button.disabled.warning:focus, .button[disabled].warning, .button[disabled].warning:hover, .button[disabled].warning:focus {
-        background-color: #ffae00;
-        color: #0a0a0a; }
-    .button.disabled.alert, .button[disabled].alert {
-      opacity: 0.25;
-      cursor: not-allowed; }
-      .button.disabled.alert, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert, .button[disabled].alert:hover, .button[disabled].alert:focus {
-        background-color: #cc4b37;
-        color: #fefefe; }
-  .button.hollow {
-    border: 1px solid #1779ba;
-    color: #1779ba; }
-    .button.hollow, .button.hollow:hover, .button.hollow:focus {
-      background-color: transparent; }
-    .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {
-      background-color: transparent; }
-    .button.hollow:hover, .button.hollow:focus {
-      border-color: #0c3d5d;
-      color: #0c3d5d; }
-      .button.hollow:hover.disabled, .button.hollow:hover[disabled], .button.hollow:focus.disabled, .button.hollow:focus[disabled] {
-        border: 1px solid #1779ba;
-        color: #1779ba; }
-    .button.hollow.primary {
-      border: 1px solid #1779ba;
-      color: #1779ba; }
-      .button.hollow.primary:hover, .button.hollow.primary:focus {
-        border-color: #0c3d5d;
-        color: #0c3d5d; }
-        .button.hollow.primary:hover.disabled, .button.hollow.primary:hover[disabled], .button.hollow.primary:focus.disabled, .button.hollow.primary:focus[disabled] {
-          border: 1px solid #1779ba;
-          color: #1779ba; }
-    .button.hollow.secondary {
-      border: 1px solid #767676;
-      color: #767676; }
-      .button.hollow.secondary:hover, .button.hollow.secondary:focus {
-        border-color: #3b3b3b;
-        color: #3b3b3b; }
-        .button.hollow.secondary:hover.disabled, .button.hollow.secondary:hover[disabled], .button.hollow.secondary:focus.disabled, .button.hollow.secondary:focus[disabled] {
-          border: 1px solid #767676;
-          color: #767676; }
-    .button.hollow.success {
-      border: 1px solid #3adb76;
-      color: #3adb76; }
-      .button.hollow.success:hover, .button.hollow.success:focus {
-        border-color: #157539;
-        color: #157539; }
-        .button.hollow.success:hover.disabled, .button.hollow.success:hover[disabled], .button.hollow.success:focus.disabled, .button.hollow.success:focus[disabled] {
-          border: 1px solid #3adb76;
-          color: #3adb76; }
-    .button.hollow.warning {
-      border: 1px solid #ffae00;
-      color: #ffae00; }
-      .button.hollow.warning:hover, .button.hollow.warning:focus {
-        border-color: #805700;
-        color: #805700; }
-        .button.hollow.warning:hover.disabled, .button.hollow.warning:hover[disabled], .button.hollow.warning:focus.disabled, .button.hollow.warning:focus[disabled] {
-          border: 1px solid #ffae00;
-          color: #ffae00; }
-    .button.hollow.alert {
-      border: 1px solid #cc4b37;
-      color: #cc4b37; }
-      .button.hollow.alert:hover, .button.hollow.alert:focus {
-        border-color: #67251a;
-        color: #67251a; }
-        .button.hollow.alert:hover.disabled, .button.hollow.alert:hover[disabled], .button.hollow.alert:focus.disabled, .button.hollow.alert:focus[disabled] {
-          border: 1px solid #cc4b37;
-          color: #cc4b37; }
-  .button.clear {
-    border: 1px solid #1779ba;
-    color: #1779ba; }
-    .button.clear, .button.clear:hover, .button.clear:focus {
-      background-color: transparent; }
-    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {
-      background-color: transparent; }
-    .button.clear:hover, .button.clear:focus {
-      border-color: #0c3d5d;
-      color: #0c3d5d; }
-      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {
-        border: 1px solid #1779ba;
-        color: #1779ba; }
-    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {
-      border-color: transparent; }
-    .button.clear.primary {
-      border: 1px solid #1779ba;
-      color: #1779ba; }
-      .button.clear.primary:hover, .button.clear.primary:focus {
-        border-color: #0c3d5d;
-        color: #0c3d5d; }
-        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
-          border: 1px solid #1779ba;
-          color: #1779ba; }
-      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.secondary {
-      border: 1px solid #767676;
-      color: #767676; }
-      .button.clear.secondary:hover, .button.clear.secondary:focus {
-        border-color: #3b3b3b;
-        color: #3b3b3b; }
-        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
-          border: 1px solid #767676;
-          color: #767676; }
-      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.success {
-      border: 1px solid #3adb76;
-      color: #3adb76; }
-      .button.clear.success:hover, .button.clear.success:focus {
-        border-color: #157539;
-        color: #157539; }
-        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
-          border: 1px solid #3adb76;
-          color: #3adb76; }
-      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.warning {
-      border: 1px solid #ffae00;
-      color: #ffae00; }
-      .button.clear.warning:hover, .button.clear.warning:focus {
-        border-color: #805700;
-        color: #805700; }
-        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
-          border: 1px solid #ffae00;
-          color: #ffae00; }
-      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
-        border-color: transparent; }
-    .button.clear.alert {
-      border: 1px solid #cc4b37;
-      color: #cc4b37; }
-      .button.clear.alert:hover, .button.clear.alert:focus {
-        border-color: #67251a;
-        color: #67251a; }
-        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
-          border: 1px solid #cc4b37;
-          color: #cc4b37; }
-      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
-        border-color: transparent; }
-  .button.dropdown::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.4em;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #fefefe transparent transparent;
-    position: relative;
-    top: 0.4em;
-    display: inline-block;
-    float: right;
-    margin-left: 1em; }
-  .button.dropdown.hollow::after {
-    border-top-color: #1779ba; }
-  .button.dropdown.hollow.primary::after {
-    border-top-color: #1779ba; }
-  .button.dropdown.hollow.secondary::after {
-    border-top-color: #767676; }
-  .button.dropdown.hollow.success::after {
-    border-top-color: #3adb76; }
-  .button.dropdown.hollow.warning::after {
-    border-top-color: #ffae00; }
-  .button.dropdown.hollow.alert::after {
-    border-top-color: #cc4b37; }
-  .button.arrow-only::after {
-    top: -0.1em;
-    float: none;
-    margin-left: 0; }
-
-a.button:hover, a.button:focus {
-  text-decoration: none; }
-
-.accordion {
-  margin-left: 0;
-  background: #fefefe;
-  list-style-type: none; }
-  .accordion[disabled] .accordion-title {
-    cursor: not-allowed; }
-
-.accordion-item:first-child > :first-child {
-  border-radius: 0 0 0 0; }
-
-.accordion-item:last-child > :last-child {
-  border-radius: 0 0 0 0; }
-
-.accordion-title {
-  position: relative;
-  display: block;
-  padding: 1.25rem 1rem;
-  border: 1px solid #e6e6e6;
-  border-bottom: 0;
-  font-size: 0.75rem;
-  line-height: 1;
-  color: #1779ba; }
-  :last-child:not(.is-active) > .accordion-title {
-    border-bottom: 1px solid #e6e6e6;
-    border-radius: 0 0 0 0; }
-  .accordion-title:hover, .accordion-title:focus {
-    background-color: #e6e6e6; }
-  .accordion-title::before {
-    position: absolute;
-    top: 50%;
-    right: 1rem;
-    margin-top: -0.5rem;
-    content: '+'; }
-  .is-active > .accordion-title::before {
-    content: '\2013'; }
-
-.accordion-content {
-  display: none;
-  padding: 1rem;
-  border: 1px solid #e6e6e6;
-  border-bottom: 0;
-  background-color: #fefefe;
-  color: #0a0a0a; }
-  :last-child > .accordion-content:last-child {
-    border-bottom: 1px solid #e6e6e6; }
-
-.accordion-menu li {
-  width: 100%; }
-
-.accordion-menu a {
-  padding: 0.7rem 1rem; }
-
-.accordion-menu .is-accordion-submenu a {
-  padding: 0.7rem 1rem; }
-
-.accordion-menu .nested.is-accordion-submenu {
-  margin-right: 0;
-  margin-left: 1rem; }
-
-.accordion-menu.align-right .nested.is-accordion-submenu {
-  margin-right: 1rem;
-  margin-left: 0; }
-
-.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {
-  position: relative; }
-  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    position: absolute;
-    top: 50%;
-    margin-top: -3px;
-    right: 1rem; }
-
-.accordion-menu.align-left .is-accordion-submenu-parent > a::after {
-  left: auto;
-  right: 1rem; }
-
-.accordion-menu.align-right .is-accordion-submenu-parent > a::after {
-  right: auto;
-  left: 1rem; }
-
-.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {
-  -webkit-transform: rotate(180deg);
-      -ms-transform: rotate(180deg);
-          transform: rotate(180deg);
-  -webkit-transform-origin: 50% 50%;
-      -ms-transform-origin: 50% 50%;
-          transform-origin: 50% 50%; }
-
-.is-accordion-submenu-parent {
-  position: relative; }
-
-.has-submenu-toggle > a {
-  margin-right: 40px; }
-
-.submenu-toggle {
-  position: absolute;
-  top: 0;
-  right: 0;
-  cursor: pointer;
-  width: 40px;
-  height: 40px; }
-  .submenu-toggle::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    top: 0;
-    bottom: 0;
-    margin: auto; }
-
-.submenu-toggle[aria-expanded='true']::after {
-  -webkit-transform: scaleY(-1);
-      -ms-transform: scaleY(-1);
-          transform: scaleY(-1);
-  -webkit-transform-origin: 50% 50%;
-      -ms-transform-origin: 50% 50%;
-          transform-origin: 50% 50%; }
-
-.submenu-toggle-text {
-  position: absolute !important;
-  width: 1px;
-  height: 1px;
-  padding: 0;
-  overflow: hidden;
-  clip: rect(0, 0, 0, 0);
-  white-space: nowrap;
-  -webkit-clip-path: inset(50%);
-          clip-path: inset(50%);
-  border: 0; }
-
-.badge {
-  display: inline-block;
-  min-width: 2.1em;
-  padding: 0.3em;
-  border-radius: 50%;
-  font-size: 0.6rem;
-  text-align: center;
-  background: #1779ba;
-  color: #fefefe; }
-  .badge.primary {
-    background: #1779ba;
-    color: #fefefe; }
-  .badge.secondary {
-    background: #767676;
-    color: #fefefe; }
-  .badge.success {
-    background: #3adb76;
-    color: #0a0a0a; }
-  .badge.warning {
-    background: #ffae00;
-    color: #0a0a0a; }
-  .badge.alert {
-    background: #cc4b37;
-    color: #fefefe; }
-
-.breadcrumbs {
-  margin: 0 0 1rem 0;
-  list-style: none; }
-  .breadcrumbs::before, .breadcrumbs::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .breadcrumbs::after {
-    clear: both; }
-  .breadcrumbs li {
-    float: left;
-    font-size: 0.6875rem;
-    color: #0a0a0a;
-    cursor: default;
-    text-transform: uppercase; }
-    .breadcrumbs li:not(:last-child)::after {
-      position: relative;
-      margin: 0 0.75rem;
-      opacity: 1;
-      content: "/";
-      color: #cacaca; }
-  .breadcrumbs a {
-    color: #1779ba; }
-    .breadcrumbs a:hover {
-      text-decoration: underline; }
-  .breadcrumbs .disabled {
-    color: #cacaca;
-    cursor: not-allowed; }
+.grid-margin-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
+  .grid-margin-y > .cell {
+    height: calc(100% - 1.25rem);
+    margin-top: 0.625rem;
+    margin-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .cell {
+      height: calc(100% - 1.875rem);
+      margin-top: 0.9375rem;
+      margin-bottom: 0.9375rem; } }
+  .grid-margin-y > .auto {
+    height: auto; }
+  .grid-margin-y > .shrink {
+    height: auto; }
+  .grid-margin-y > .small-1 {
+    height: calc(8.33333% - 1.25rem); }
+  .grid-margin-y > .small-2 {
+    height: calc(16.66667% - 1.25rem); }
+  .grid-margin-y > .small-3 {
+    height: calc(25% - 1.25rem); }
+  .grid-margin-y > .small-4 {
+    height: calc(33.33333% - 1.25rem); }
+  .grid-margin-y > .small-5 {
+    height: calc(41.66667% - 1.25rem); }
+  .grid-margin-y > .small-6 {
+    height: calc(50% - 1.25rem); }
+  .grid-margin-y > .small-7 {
+    height: calc(58.33333% - 1.25rem); }
+  .grid-margin-y > .small-8 {
+    height: calc(66.66667% - 1.25rem); }
+  .grid-margin-y > .small-9 {
+    height: calc(75% - 1.25rem); }
+  .grid-margin-y > .small-10 {
+    height: calc(83.33333% - 1.25rem); }
+  .grid-margin-y > .small-11 {
+    height: calc(91.66667% - 1.25rem); }
+  .grid-margin-y > .small-12 {
+    height: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .auto {
+      height: auto; }
+    .grid-margin-y > .shrink {
+      height: auto; }
+    .grid-margin-y > .small-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .small-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .small-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .small-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .small-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .small-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .small-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .small-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .small-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .small-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .small-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .small-12 {
+      height: calc(100% - 1.875rem); }
+    .grid-margin-y > .medium-auto {
+      height: auto; }
+    .grid-margin-y > .medium-shrink {
+      height: auto; }
+    .grid-margin-y > .medium-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .medium-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .medium-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .medium-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .medium-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .medium-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .medium-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .medium-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .medium-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .medium-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .medium-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .medium-12 {
+      height: calc(100% - 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-margin-y > .large-auto {
+      height: auto; }
+    .grid-margin-y > .large-shrink {
+      height: auto; }
+    .grid-margin-y > .large-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .large-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .large-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .large-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .large-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .large-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .large-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .large-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .large-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .large-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .large-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .large-12 {
+      height: calc(100% - 1.875rem); } }
 
-.button-group {
-  margin-bottom: 1rem;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
+.grid-frame {
+  overflow: hidden;
+  position: relative;
   -webkit-flex-wrap: nowrap;
       -ms-flex-wrap: nowrap;
           flex-wrap: nowrap;
   -webkit-box-align: stretch;
   -webkit-align-items: stretch;
       -ms-flex-align: stretch;
-          align-items: stretch; }
-  .button-group::before, .button-group::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .button-group::after {
-    clear: both; }
-  .button-group .button {
-    margin: 0;
-    margin-right: 1px;
-    margin-bottom: 1px;
-    font-size: 0.9rem;
-    -webkit-box-flex: 0;
-    -webkit-flex: 0 0 auto;
-        -ms-flex: 0 0 auto;
-            flex: 0 0 auto; }
-    .button-group .button:last-child {
-      margin-right: 0; }
-  .button-group.tiny .button {
-    font-size: 0.6rem; }
-  .button-group.small .button {
-    font-size: 0.75rem; }
-  .button-group.large .button {
-    font-size: 1.25rem; }
-  .button-group.expanded .button {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-  .button-group.primary .button {
-    background-color: #1779ba;
-    color: #fefefe; }
-    .button-group.primary .button:hover, .button-group.primary .button:focus {
-      background-color: #126195;
-      color: #fefefe; }
-  .button-group.secondary .button {
-    background-color: #767676;
-    color: #fefefe; }
-    .button-group.secondary .button:hover, .button-group.secondary .button:focus {
-      background-color: #5e5e5e;
-      color: #fefefe; }
-  .button-group.success .button {
-    background-color: #3adb76;
-    color: #0a0a0a; }
-    .button-group.success .button:hover, .button-group.success .button:focus {
-      background-color: #22bb5b;
-      color: #0a0a0a; }
-  .button-group.warning .button {
-    background-color: #ffae00;
-    color: #0a0a0a; }
-    .button-group.warning .button:hover, .button-group.warning .button:focus {
-      background-color: #cc8b00;
-      color: #0a0a0a; }
-  .button-group.alert .button {
-    background-color: #cc4b37;
-    color: #fefefe; }
-    .button-group.alert .button:hover, .button-group.alert .button:focus {
-      background-color: #a53b2a;
-      color: #fefefe; }
-  .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium {
-    -webkit-flex-wrap: wrap;
-        -ms-flex-wrap: wrap;
-            flex-wrap: wrap; }
-    .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {
-      -webkit-box-flex: 0;
-      -webkit-flex: 0 0 100%;
-          -ms-flex: 0 0 100%;
-              flex: 0 0 100%; }
-      .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {
-        margin-bottom: 0; }
-  @media print, screen and (min-width: 40em) {
-    .button-group.stacked-for-small .button {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      margin-bottom: 0; } }
-  @media print, screen and (min-width: 64em) {
-    .button-group.stacked-for-medium .button {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px;
-      margin-bottom: 0; } }
-  @media screen and (max-width: 39.9375em) {
-    .button-group.stacked-for-small.expanded {
-      display: block; }
-      .button-group.stacked-for-small.expanded .button {
-        display: block;
-        margin-right: 0; } }
-
-.callout {
-  position: relative;
-  margin: 0 0 1rem 0;
-  padding: 1rem;
-  border: 1px solid rgba(10, 10, 10, 0.25);
-  border-radius: 0;
-  background-color: white;
-  color: #0a0a0a; }
-  .callout > :first-child {
-    margin-top: 0; }
-  .callout > :last-child {
-    margin-bottom: 0; }
-  .callout.primary {
-    background-color: #d7ecfa;
-    color: #0a0a0a; }
-  .callout.secondary {
-    background-color: #eaeaea;
-    color: #0a0a0a; }
-  .callout.success {
-    background-color: #e1faea;
-    color: #0a0a0a; }
-  .callout.warning {
-    background-color: #fff3d9;
-    color: #0a0a0a; }
-  .callout.alert {
-    background-color: #f7e4e1;
-    color: #0a0a0a; }
-  .callout.small {
-    padding-top: 0.5rem;
-    padding-right: 0.5rem;
-    padding-bottom: 0.5rem;
-    padding-left: 0.5rem; }
-  .callout.large {
-    padding-top: 3rem;
-    padding-right: 3rem;
-    padding-bottom: 3rem;
-    padding-left: 3rem; }
-
-.card {
-  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-grow: 1;
-      -ms-flex-positive: 1;
-          flex-grow: 1;
-  margin-bottom: 1rem;
-  border: 1px solid #e6e6e6;
-  border-radius: 0;
-  background: #fefefe;
-  -webkit-box-shadow: none;
-          box-shadow: none;
-  overflow: hidden;
-  color: #0a0a0a; }
-  .card > :last-child {
-    margin-bottom: 0; }
-
-.card-divider {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 1 auto;
-      -ms-flex: 0 1 auto;
-          flex: 0 1 auto;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  padding: 1rem;
-  background: #e6e6e6; }
-  .card-divider > :last-child {
-    margin-bottom: 0; }
-
-.card-section {
-  -webkit-box-flex: 1;
-  -webkit-flex: 1 0 auto;
-      -ms-flex: 1 0 auto;
-          flex: 1 0 auto;
-  padding: 1rem; }
-  .card-section > :last-child {
-    margin-bottom: 0; }
+          align-items: stretch;
+  width: 100vw; }
 
-.card-image {
-  min-height: 1px; }
+.cell .grid-frame {
+  width: 100%; }
 
-.close-button {
-  position: absolute;
-  color: #8a8a8a;
-  cursor: pointer; }
-  [data-whatinput='mouse'] .close-button {
-    outline: 0; }
-  .close-button:hover, .close-button:focus {
-    color: #0a0a0a; }
-  .close-button.small {
-    right: 0.66rem;
-    top: 0.33em;
-    font-size: 1.5em;
-    line-height: 1; }
-  .close-button, .close-button.medium {
-    right: 1rem;
-    top: 0.5rem;
-    font-size: 2em;
-    line-height: 1; }
+.cell-block {
+  overflow-x: auto;
+  max-width: 100%;
+  -webkit-overflow-scrolling: touch;
+  -ms-overflow-style: -ms-autohiding-scrollbar; }
 
-.menu {
-  padding: 0;
-  margin: 0;
-  list-style: none;
-  position: relative;
+.cell-block-y {
+  overflow-y: auto;
+  max-height: 100%;
+  min-height: 100%;
+  -webkit-overflow-scrolling: touch;
+  -ms-overflow-style: -ms-autohiding-scrollbar; }
+
+.cell-block-container {
   display: -webkit-box;
   display: -webkit-flex;
   display: -ms-flexbox;
   display: flex;
-  -webkit-flex-wrap: wrap;
-      -ms-flex-wrap: wrap;
-          flex-wrap: wrap; }
-  [data-whatinput='mouse'] .menu li {
-    outline: 0; }
-  .menu a,
-  .menu .button {
-    line-height: 1;
-    text-decoration: none;
-    display: block;
-    padding: 0.7rem 1rem; }
-  .menu input,
-  .menu select,
-  .menu a,
-  .menu button {
-    margin-bottom: 0; }
-  .menu input {
-    display: inline-block; }
-  .menu, .menu.horizontal {
-    -webkit-flex-wrap: wrap;
-        -ms-flex-wrap: wrap;
-            flex-wrap: wrap;
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-direction: row;
-        -ms-flex-direction: row;
-            flex-direction: row; }
-  .menu.vertical {
+  -webkit-box-orient: vertical;
+  -webkit-box-direction: normal;
+  -webkit-flex-direction: column;
+      -ms-flex-direction: column;
+          flex-direction: column;
+  max-height: 100%; }
+  .cell-block-container > .grid-x {
+    max-height: 100%;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap; }
+
+@media print, screen and (min-width: 40em) {
+  .medium-grid-frame {
+    overflow: hidden;
+    position: relative;
     -webkit-flex-wrap: nowrap;
         -ms-flex-wrap: nowrap;
             flex-wrap: nowrap;
-    -webkit-box-orient: vertical;
-    -webkit-box-direction: normal;
-    -webkit-flex-direction: column;
-        -ms-flex-direction: column;
-            flex-direction: column; }
-  .menu.expanded li {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-  .menu.simple {
-    -webkit-box-align: center;
-    -webkit-align-items: center;
-        -ms-flex-align: center;
-            align-items: center; }
-    .menu.simple li + li {
-      margin-left: 1rem; }
-    .menu.simple a {
-      padding: 0; }
-  @media print, screen and (min-width: 40em) {
-    .menu.medium-horizontal {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap;
-      -webkit-box-orient: horizontal;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: row;
-          -ms-flex-direction: row;
-              flex-direction: row; }
-    .menu.medium-vertical {
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap;
-      -webkit-box-orient: vertical;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: column;
-          -ms-flex-direction: column;
-              flex-direction: column; }
-    .menu.medium-expanded li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; }
-    .menu.medium-simple li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; } }
-  @media print, screen and (min-width: 64em) {
-    .menu.large-horizontal {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap;
-      -webkit-box-orient: horizontal;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: row;
-          -ms-flex-direction: row;
-              flex-direction: row; }
-    .menu.large-vertical {
-      -webkit-flex-wrap: nowrap;
-          -ms-flex-wrap: nowrap;
-              flex-wrap: nowrap;
-      -webkit-box-orient: vertical;
-      -webkit-box-direction: normal;
-      -webkit-flex-direction: column;
-          -ms-flex-direction: column;
-              flex-direction: column; }
-    .menu.large-expanded li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; }
-    .menu.large-simple li {
-      -webkit-box-flex: 1;
-      -webkit-flex: 1 1 0px;
-          -ms-flex: 1 1 0px;
-              flex: 1 1 0px; } }
-  .menu.nested {
-    margin-right: 0;
-    margin-left: 1rem; }
-  .menu.icons a {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex; }
-  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    width: 100vw; }
+  .cell .medium-grid-frame {
+    width: 100%; }
+  .medium-cell-block {
+    overflow-x: auto;
+    max-width: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; }
+  .medium-cell-block-container {
     display: -webkit-box;
     display: -webkit-flex;
     display: -ms-flexbox;
-    display: flex; }
-  .menu.icon-left li a {
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: row nowrap;
-        -ms-flex-flow: row nowrap;
-            flex-flow: row nowrap; }
-    .menu.icon-left li a img,
-    .menu.icon-left li a i,
-    .menu.icon-left li a svg {
-      margin-right: 0.25rem; }
-  .menu.icon-right li a {
-    -webkit-box-orient: horizontal;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: row nowrap;
-        -ms-flex-flow: row nowrap;
-            flex-flow: row nowrap; }
-    .menu.icon-right li a img,
-    .menu.icon-right li a i,
-    .menu.icon-right li a svg {
-      margin-left: 0.25rem; }
-  .menu.icon-top li a {
-    -webkit-box-orient: vertical;
-    -webkit-box-direction: normal;
-    -webkit-flex-flow: column nowrap;
-        -ms-flex-flow: column nowrap;
-            flex-flow: column nowrap; }
-    .menu.icon-top li a img,
-    .menu.icon-top li a i,
-    .menu.icon-top li a svg {
-      -webkit-align-self: stretch;
-          -ms-flex-item-align: stretch;
-                  -ms-grid-row-align: stretch;
-              align-self: stretch;
-      margin-bottom: 0.25rem;
-      text-align: center; }
-  .menu.icon-bottom li a {
+    display: flex;
     -webkit-box-orient: vertical;
     -webkit-box-direction: normal;
-    -webkit-flex-flow: column nowrap;
-        -ms-flex-flow: column nowrap;
-            flex-flow: column nowrap; }
-    .menu.icon-bottom li a img,
-    .menu.icon-bottom li a i,
-    .menu.icon-bottom li a svg {
-      -webkit-align-self: stretch;
-          -ms-flex-item-align: stretch;
-                  -ms-grid-row-align: stretch;
-              align-self: stretch;
-      margin-bottom: 0.25rem;
-      text-align: center; }
-  .menu .is-active > a {
-    background: #1779ba;
-    color: #fefefe; }
-  .menu .active > a {
-    background: #1779ba;
-    color: #fefefe; }
-  .menu.align-left {
-    -webkit-box-pack: start;
-    -webkit-justify-content: flex-start;
-        -ms-flex-pack: start;
-            justify-content: flex-start; }
-  .menu.align-right li {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex;
-    -webkit-box-pack: end;
-    -webkit-justify-content: flex-end;
-        -ms-flex-pack: end;
-            justify-content: flex-end; }
-    .menu.align-right li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
-  .menu.align-right.vertical li {
-    display: block;
-    text-align: right; }
-    .menu.align-right.vertical li .submenu li {
-      text-align: right; }
-  .menu.align-right .nested {
-    margin-right: 1rem;
-    margin-left: 0; }
-  .menu.align-center li {
-    display: -webkit-box;
-    display: -webkit-flex;
-    display: -ms-flexbox;
-    display: flex;
-    -webkit-box-pack: center;
-    -webkit-justify-content: center;
-        -ms-flex-pack: center;
-            justify-content: center; }
-    .menu.align-center li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
-  .menu .menu-text {
-    padding: 0.7rem 1rem;
-    font-weight: bold;
-    line-height: 1;
-    color: inherit; }
+    -webkit-flex-direction: column;
+        -ms-flex-direction: column;
+            flex-direction: column;
+    max-height: 100%; }
+    .medium-cell-block-container > .grid-x {
+      max-height: 100%;
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap; }
+  .medium-cell-block-y {
+    overflow-y: auto;
+    max-height: 100%;
+    min-height: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; } }
 
-.menu-centered > .menu {
-  -webkit-box-pack: center;
-  -webkit-justify-content: center;
-      -ms-flex-pack: center;
-          justify-content: center; }
-  .menu-centered > .menu li {
+@media print, screen and (min-width: 64em) {
+  .large-grid-frame {
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    width: 100vw; }
+  .cell .large-grid-frame {
+    width: 100%; }
+  .large-cell-block {
+    overflow-x: auto;
+    max-width: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; }
+  .large-cell-block-container {
     display: -webkit-box;
     display: -webkit-flex;
     display: -ms-flexbox;
     display: flex;
-    -webkit-box-pack: center;
-    -webkit-justify-content: center;
-        -ms-flex-pack: center;
-            justify-content: center; }
-    .menu-centered > .menu li .submenu li {
-      -webkit-box-pack: start;
-      -webkit-justify-content: flex-start;
-          -ms-flex-pack: start;
-              justify-content: flex-start; }
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: column;
+        -ms-flex-direction: column;
+            flex-direction: column;
+    max-height: 100%; }
+    .large-cell-block-container > .grid-x {
+      max-height: 100%;
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap; }
+  .large-cell-block-y {
+    overflow-y: auto;
+    max-height: 100%;
+    min-height: 100%;
+    -webkit-overflow-scrolling: touch;
+    -ms-overflow-style: -ms-autohiding-scrollbar; } }
 
-.no-js [data-responsive-menu] ul {
-  display: none; }
+.grid-y.grid-frame {
+  width: auto;
+  overflow: hidden;
+  position: relative;
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch;
+  height: 100vh; }
+
+@media print, screen and (min-width: 40em) {
+  .grid-y.medium-grid-frame {
+    width: auto;
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    height: 100vh; } }
+
+@media print, screen and (min-width: 64em) {
+  .grid-y.large-grid-frame {
+    width: auto;
+    overflow: hidden;
+    position: relative;
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-align: stretch;
+    -webkit-align-items: stretch;
+        -ms-flex-align: stretch;
+            align-items: stretch;
+    height: 100vh; } }
+
+.cell .grid-y.grid-frame {
+  height: 100%; }
+
+@media print, screen and (min-width: 40em) {
+  .cell .grid-y.medium-grid-frame {
+    height: 100%; } }
+
+@media print, screen and (min-width: 64em) {
+  .cell .grid-y.large-grid-frame {
+    height: 100%; } }
+
+.grid-margin-y {
+  margin-top: -0.625rem;
+  margin-bottom: -0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y {
+      margin-top: -0.9375rem;
+      margin-bottom: -0.9375rem; } }
+  .grid-margin-y > .cell {
+    height: calc(100% - 1.25rem);
+    margin-top: 0.625rem;
+    margin-bottom: 0.625rem; }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .cell {
+      height: calc(100% - 1.875rem);
+      margin-top: 0.9375rem;
+      margin-bottom: 0.9375rem; } }
+  .grid-margin-y > .auto {
+    height: auto; }
+  .grid-margin-y > .shrink {
+    height: auto; }
+  .grid-margin-y > .small-1 {
+    height: calc(8.33333% - 1.25rem); }
+  .grid-margin-y > .small-2 {
+    height: calc(16.66667% - 1.25rem); }
+  .grid-margin-y > .small-3 {
+    height: calc(25% - 1.25rem); }
+  .grid-margin-y > .small-4 {
+    height: calc(33.33333% - 1.25rem); }
+  .grid-margin-y > .small-5 {
+    height: calc(41.66667% - 1.25rem); }
+  .grid-margin-y > .small-6 {
+    height: calc(50% - 1.25rem); }
+  .grid-margin-y > .small-7 {
+    height: calc(58.33333% - 1.25rem); }
+  .grid-margin-y > .small-8 {
+    height: calc(66.66667% - 1.25rem); }
+  .grid-margin-y > .small-9 {
+    height: calc(75% - 1.25rem); }
+  .grid-margin-y > .small-10 {
+    height: calc(83.33333% - 1.25rem); }
+  .grid-margin-y > .small-11 {
+    height: calc(91.66667% - 1.25rem); }
+  .grid-margin-y > .small-12 {
+    height: calc(100% - 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-margin-y > .auto {
+      height: auto; }
+    .grid-margin-y > .shrink {
+      height: auto; }
+    .grid-margin-y > .small-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .small-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .small-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .small-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .small-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .small-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .small-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .small-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .small-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .small-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .small-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .small-12 {
+      height: calc(100% - 1.875rem); }
+    .grid-margin-y > .medium-auto {
+      height: auto; }
+    .grid-margin-y > .medium-shrink {
+      height: auto; }
+    .grid-margin-y > .medium-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .medium-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .medium-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .medium-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .medium-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .medium-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .medium-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .medium-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .medium-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .medium-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .medium-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .medium-12 {
+      height: calc(100% - 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-margin-y > .large-auto {
+      height: auto; }
+    .grid-margin-y > .large-shrink {
+      height: auto; }
+    .grid-margin-y > .large-1 {
+      height: calc(8.33333% - 1.875rem); }
+    .grid-margin-y > .large-2 {
+      height: calc(16.66667% - 1.875rem); }
+    .grid-margin-y > .large-3 {
+      height: calc(25% - 1.875rem); }
+    .grid-margin-y > .large-4 {
+      height: calc(33.33333% - 1.875rem); }
+    .grid-margin-y > .large-5 {
+      height: calc(41.66667% - 1.875rem); }
+    .grid-margin-y > .large-6 {
+      height: calc(50% - 1.875rem); }
+    .grid-margin-y > .large-7 {
+      height: calc(58.33333% - 1.875rem); }
+    .grid-margin-y > .large-8 {
+      height: calc(66.66667% - 1.875rem); }
+    .grid-margin-y > .large-9 {
+      height: calc(75% - 1.875rem); }
+    .grid-margin-y > .large-10 {
+      height: calc(83.33333% - 1.875rem); }
+    .grid-margin-y > .large-11 {
+      height: calc(91.66667% - 1.875rem); }
+    .grid-margin-y > .large-12 {
+      height: calc(100% - 1.875rem); } }
+
+.grid-frame.grid-margin-y {
+  height: calc(100vh + 1.25rem); }
+  @media print, screen and (min-width: 40em) {
+    .grid-frame.grid-margin-y {
+      height: calc(100vh + 1.875rem); } }
+  @media print, screen and (min-width: 64em) {
+    .grid-frame.grid-margin-y {
+      height: calc(100vh + 1.875rem); } }
+
+@media print, screen and (min-width: 40em) {
+  .grid-margin-y.medium-grid-frame {
+    height: calc(100vh + 1.875rem); } }
 
-.menu-icon {
-  position: relative;
-  display: inline-block;
-  vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer; }
-  .menu-icon::after {
-    position: absolute;
-    top: 0;
-    left: 0;
-    display: block;
-    width: 100%;
-    height: 2px;
-    background: #fefefe;
-    -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
-            box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
-    content: ''; }
-  .menu-icon:hover::after {
-    background: #cacaca;
-    -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
-            box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }
+@media print, screen and (min-width: 64em) {
+  .grid-margin-y.large-grid-frame {
+    height: calc(100vh + 1.875rem); } }
 
-.menu-icon.dark {
-  position: relative;
+.button {
   display: inline-block;
   vertical-align: middle;
-  width: 20px;
-  height: 16px;
-  cursor: pointer; }
-  .menu-icon.dark::after {
-    position: absolute;
-    top: 0;
-    left: 0;
+  margin: 0 0 1rem 0;
+  padding: 0.85em 1em;
+  border: 1px solid transparent;
+  border-radius: 0;
+  -webkit-transition: background-color 0.25s ease-out, color 0.25s ease-out;
+  transition: background-color 0.25s ease-out, color 0.25s ease-out;
+  font-family: inherit;
+  font-size: 0.9rem;
+  -webkit-appearance: none;
+  line-height: 1;
+  text-align: center;
+  cursor: pointer;
+  background-color: #1779ba;
+  color: #fefefe; }
+  [data-whatinput='mouse'] .button {
+    outline: 0; }
+  .button:hover, .button:focus {
+    background-color: #14679e;
+    color: #fefefe; }
+  .button.tiny {
+    font-size: 0.6rem; }
+  .button.small {
+    font-size: 0.75rem; }
+  .button.large {
+    font-size: 1.25rem; }
+  .button.expanded {
     display: block;
     width: 100%;
-    height: 2px;
-    background: #0a0a0a;
-    -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-            box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
-    content: ''; }
-  .menu-icon.dark:hover::after {
-    background: #8a8a8a;
-    -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
-            box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }
-
-.is-drilldown {
-  position: relative;
-  overflow: hidden; }
-  .is-drilldown li {
-    display: block; }
-  .is-drilldown.animate-height {
-    -webkit-transition: height 0.5s;
-    transition: height 0.5s; }
-
-.drilldown a {
-  padding: 0.7rem 1rem;
-  background: #fefefe; }
-
-.drilldown .is-drilldown-submenu {
-  position: absolute;
-  top: 0;
-  left: 100%;
-  z-index: -1;
-  width: 100%;
-  background: #fefefe;
-  -webkit-transition: -webkit-transform 0.15s linear;
-  transition: -webkit-transform 0.15s linear;
-  transition: transform 0.15s linear;
-  transition: transform 0.15s linear, -webkit-transform 0.15s linear; }
-  .drilldown .is-drilldown-submenu.is-active {
-    z-index: 1;
-    display: block;
-    -webkit-transform: translateX(-100%);
-        -ms-transform: translateX(-100%);
-            transform: translateX(-100%); }
-  .drilldown .is-drilldown-submenu.is-closing {
-    -webkit-transform: translateX(100%);
-        -ms-transform: translateX(100%);
-            transform: translateX(100%); }
-  .drilldown .is-drilldown-submenu a {
-    padding: 0.7rem 1rem; }
-
-.drilldown .nested.is-drilldown-submenu {
-  margin-right: 0;
-  margin-left: 0; }
-
-.drilldown .drilldown-submenu-cover-previous {
-  min-height: 100%; }
-
-.drilldown .is-drilldown-submenu-parent > a {
-  position: relative; }
-  .drilldown .is-drilldown-submenu-parent > a::after {
-    position: absolute;
-    top: 50%;
-    margin-top: -6px;
-    right: 1rem;
+    margin-right: 0;
+    margin-left: 0; }
+  .button.primary {
+    background-color: #1779ba;
+    color: #fefefe; }
+    .button.primary:hover, .button.primary:focus {
+      background-color: #126195;
+      color: #fefefe; }
+  .button.secondary {
+    background-color: #767676;
+    color: #fefefe; }
+    .button.secondary:hover, .button.secondary:focus {
+      background-color: #5e5e5e;
+      color: #fefefe; }
+  .button.success {
+    background-color: #3adb76;
+    color: #0a0a0a; }
+    .button.success:hover, .button.success:focus {
+      background-color: #22bb5b;
+      color: #0a0a0a; }
+  .button.warning {
+    background-color: #ffae00;
+    color: #0a0a0a; }
+    .button.warning:hover, .button.warning:focus {
+      background-color: #cc8b00;
+      color: #0a0a0a; }
+  .button.alert {
+    background-color: #cc4b37;
+    color: #fefefe; }
+    .button.alert:hover, .button.alert:focus {
+      background-color: #a53b2a;
+      color: #fefefe; }
+  .button.disabled, .button[disabled] {
+    opacity: 0.25;
+    cursor: not-allowed; }
+    .button.disabled, .button.disabled:hover, .button.disabled:focus, .button[disabled], .button[disabled]:hover, .button[disabled]:focus {
+      background-color: #1779ba;
+      color: #fefefe; }
+    .button.disabled.primary, .button[disabled].primary {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.primary, .button.disabled.primary:hover, .button.disabled.primary:focus, .button[disabled].primary, .button[disabled].primary:hover, .button[disabled].primary:focus {
+        background-color: #1779ba;
+        color: #fefefe; }
+    .button.disabled.secondary, .button[disabled].secondary {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.secondary, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary, .button[disabled].secondary:hover, .button[disabled].secondary:focus {
+        background-color: #767676;
+        color: #fefefe; }
+    .button.disabled.success, .button[disabled].success {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.success, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success, .button[disabled].success:hover, .button[disabled].success:focus {
+        background-color: #3adb76;
+        color: #0a0a0a; }
+    .button.disabled.warning, .button[disabled].warning {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.warning, .button.disabled.warning:hover, .button.disabled.warning:focus, .button[disabled].warning, .button[disabled].warning:hover, .button[disabled].warning:focus {
+        background-color: #ffae00;
+        color: #0a0a0a; }
+    .button.disabled.alert, .button[disabled].alert {
+      opacity: 0.25;
+      cursor: not-allowed; }
+      .button.disabled.alert, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert, .button[disabled].alert:hover, .button[disabled].alert:focus {
+        background-color: #cc4b37;
+        color: #fefefe; }
+  .button.hollow {
+    border: 1px solid #1779ba;
+    color: #1779ba; }
+    .button.hollow, .button.hollow:hover, .button.hollow:focus {
+      background-color: transparent; }
+    .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {
+      background-color: transparent; }
+    .button.hollow:hover, .button.hollow:focus {
+      border-color: #0c3d5d;
+      color: #0c3d5d; }
+      .button.hollow:hover.disabled, .button.hollow:hover[disabled], .button.hollow:focus.disabled, .button.hollow:focus[disabled] {
+        border: 1px solid #1779ba;
+        color: #1779ba; }
+    .button.hollow.primary {
+      border: 1px solid #1779ba;
+      color: #1779ba; }
+      .button.hollow.primary:hover, .button.hollow.primary:focus {
+        border-color: #0c3d5d;
+        color: #0c3d5d; }
+        .button.hollow.primary:hover.disabled, .button.hollow.primary:hover[disabled], .button.hollow.primary:focus.disabled, .button.hollow.primary:focus[disabled] {
+          border: 1px solid #1779ba;
+          color: #1779ba; }
+    .button.hollow.secondary {
+      border: 1px solid #767676;
+      color: #767676; }
+      .button.hollow.secondary:hover, .button.hollow.secondary:focus {
+        border-color: #3b3b3b;
+        color: #3b3b3b; }
+        .button.hollow.secondary:hover.disabled, .button.hollow.secondary:hover[disabled], .button.hollow.secondary:focus.disabled, .button.hollow.secondary:focus[disabled] {
+          border: 1px solid #767676;
+          color: #767676; }
+    .button.hollow.success {
+      border: 1px solid #3adb76;
+      color: #3adb76; }
+      .button.hollow.success:hover, .button.hollow.success:focus {
+        border-color: #157539;
+        color: #157539; }
+        .button.hollow.success:hover.disabled, .button.hollow.success:hover[disabled], .button.hollow.success:focus.disabled, .button.hollow.success:focus[disabled] {
+          border: 1px solid #3adb76;
+          color: #3adb76; }
+    .button.hollow.warning {
+      border: 1px solid #ffae00;
+      color: #ffae00; }
+      .button.hollow.warning:hover, .button.hollow.warning:focus {
+        border-color: #805700;
+        color: #805700; }
+        .button.hollow.warning:hover.disabled, .button.hollow.warning:hover[disabled], .button.hollow.warning:focus.disabled, .button.hollow.warning:focus[disabled] {
+          border: 1px solid #ffae00;
+          color: #ffae00; }
+    .button.hollow.alert {
+      border: 1px solid #cc4b37;
+      color: #cc4b37; }
+      .button.hollow.alert:hover, .button.hollow.alert:focus {
+        border-color: #67251a;
+        color: #67251a; }
+        .button.hollow.alert:hover.disabled, .button.hollow.alert:hover[disabled], .button.hollow.alert:focus.disabled, .button.hollow.alert:focus[disabled] {
+          border: 1px solid #cc4b37;
+          color: #cc4b37; }
+  .button.clear {
+    border: 1px solid #1779ba;
+    color: #1779ba; }
+    .button.clear, .button.clear:hover, .button.clear:focus {
+      background-color: transparent; }
+    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {
+      background-color: transparent; }
+    .button.clear:hover, .button.clear:focus {
+      border-color: #0c3d5d;
+      color: #0c3d5d; }
+      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {
+        border: 1px solid #1779ba;
+        color: #1779ba; }
+    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {
+      border-color: transparent; }
+    .button.clear.primary {
+      border: 1px solid #1779ba;
+      color: #1779ba; }
+      .button.clear.primary:hover, .button.clear.primary:focus {
+        border-color: #0c3d5d;
+        color: #0c3d5d; }
+        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
+          border: 1px solid #1779ba;
+          color: #1779ba; }
+      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.secondary {
+      border: 1px solid #767676;
+      color: #767676; }
+      .button.clear.secondary:hover, .button.clear.secondary:focus {
+        border-color: #3b3b3b;
+        color: #3b3b3b; }
+        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
+          border: 1px solid #767676;
+          color: #767676; }
+      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.success {
+      border: 1px solid #3adb76;
+      color: #3adb76; }
+      .button.clear.success:hover, .button.clear.success:focus {
+        border-color: #157539;
+        color: #157539; }
+        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
+          border: 1px solid #3adb76;
+          color: #3adb76; }
+      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.warning {
+      border: 1px solid #ffae00;
+      color: #ffae00; }
+      .button.clear.warning:hover, .button.clear.warning:focus {
+        border-color: #805700;
+        color: #805700; }
+        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
+          border: 1px solid #ffae00;
+          color: #ffae00; }
+      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {
+        border-color: transparent; }
+    .button.clear.alert {
+      border: 1px solid #cc4b37;
+      color: #cc4b37; }
+      .button.clear.alert:hover, .button.clear.alert:focus {
+        border-color: #67251a;
+        color: #67251a; }
+        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
+          border: 1px solid #cc4b37;
+          color: #cc4b37; }
+      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {
+        border-color: transparent; }
+  .button.dropdown::after {
     display: block;
     width: 0;
     height: 0;
-    border: inset 6px;
+    border: inset 0.4em;
     content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; }
-
-.drilldown.align-left .is-drilldown-submenu-parent > a::after {
-  left: auto;
-  right: 1rem;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba; }
-
-.drilldown.align-right .is-drilldown-submenu-parent > a::after {
-  right: auto;
-  left: 1rem;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent; }
-
-.drilldown .js-drilldown-back > a::before {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent;
-  border-left-width: 0;
-  display: inline-block;
-  vertical-align: middle;
-  margin-right: 0.75rem;
-  border-left-width: 0; }
-
-.dropdown-pane {
-  position: absolute;
-  z-index: 10;
-  width: 300px;
-  padding: 1rem;
-  visibility: hidden;
-  display: none;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  font-size: 1rem; }
-  .dropdown-pane.is-opening {
-    display: block; }
-  .dropdown-pane.is-open {
-    visibility: visible;
-    display: block; }
-
-.dropdown-pane.tiny {
-  width: 100px; }
-
-.dropdown-pane.small {
-  width: 200px; }
-
-.dropdown-pane.large {
-  width: 400px; }
-
-.dropdown.menu > li.opens-left > .is-dropdown-submenu {
-  top: 100%;
-  right: 0;
-  left: auto; }
-
-.dropdown.menu > li.opens-right > .is-dropdown-submenu {
-  top: 100%;
-  right: auto;
-  left: 0; }
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #fefefe transparent transparent;
+    position: relative;
+    top: 0.4em;
+    display: inline-block;
+    float: right;
+    margin-left: 1em; }
+  .button.dropdown.hollow::after, .button.dropdown.clear::after {
+    border-top-color: #1779ba; }
+  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {
+    border-top-color: #1779ba; }
+  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {
+    border-top-color: #767676; }
+  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {
+    border-top-color: #3adb76; }
+  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {
+    border-top-color: #ffae00; }
+  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {
+    border-top-color: #cc4b37; }
+  .button.arrow-only::after {
+    top: -0.1em;
+    float: none;
+    margin-left: 0; }
 
-.dropdown.menu > li.is-dropdown-submenu-parent > a {
-  position: relative;
-  padding-right: 1.5rem; }
+a.button:hover, a.button:focus {
+  text-decoration: none; }
 
-.dropdown.menu > li.is-dropdown-submenu-parent > a::after {
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-bottom-width: 0;
-  border-top-style: solid;
-  border-color: #1779ba transparent transparent;
-  right: 5px;
-  left: auto;
-  margin-top: -3px; }
+.button-group {
+  margin-bottom: 1rem;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap;
+  -webkit-box-align: stretch;
+  -webkit-align-items: stretch;
+      -ms-flex-align: stretch;
+          align-items: stretch; }
+  .button-group::before, .button-group::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .button-group::after {
+    clear: both; }
+  .button-group .button {
+    margin: 0;
+    margin-right: 1px;
+    margin-bottom: 1px;
+    font-size: 0.9rem;
+    -webkit-box-flex: 0;
+    -webkit-flex: 0 0 auto;
+        -ms-flex: 0 0 auto;
+            flex: 0 0 auto; }
+    .button-group .button:last-child {
+      margin-right: 0; }
+  .button-group.tiny .button {
+    font-size: 0.6rem; }
+  .button-group.small .button {
+    font-size: 0.75rem; }
+  .button-group.large .button {
+    font-size: 1.25rem; }
+  .button-group.expanded .button {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
+  .button-group.primary .button {
+    background-color: #1779ba;
+    color: #fefefe; }
+    .button-group.primary .button:hover, .button-group.primary .button:focus {
+      background-color: #126195;
+      color: #fefefe; }
+  .button-group.secondary .button {
+    background-color: #767676;
+    color: #fefefe; }
+    .button-group.secondary .button:hover, .button-group.secondary .button:focus {
+      background-color: #5e5e5e;
+      color: #fefefe; }
+  .button-group.success .button {
+    background-color: #3adb76;
+    color: #0a0a0a; }
+    .button-group.success .button:hover, .button-group.success .button:focus {
+      background-color: #22bb5b;
+      color: #0a0a0a; }
+  .button-group.warning .button {
+    background-color: #ffae00;
+    color: #0a0a0a; }
+    .button-group.warning .button:hover, .button-group.warning .button:focus {
+      background-color: #cc8b00;
+      color: #0a0a0a; }
+  .button-group.alert .button {
+    background-color: #cc4b37;
+    color: #fefefe; }
+    .button-group.alert .button:hover, .button-group.alert .button:focus {
+      background-color: #a53b2a;
+      color: #fefefe; }
+  .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium {
+    -webkit-flex-wrap: wrap;
+        -ms-flex-wrap: wrap;
+            flex-wrap: wrap; }
+    .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 100%;
+          -ms-flex: 0 0 100%;
+              flex: 0 0 100%; }
+      .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {
+        margin-bottom: 0; }
+    .button-group.stacked.expanded .button, .button-group.stacked-for-small.expanded .button, .button-group.stacked-for-medium.expanded .button {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; }
+  @media print, screen and (min-width: 40em) {
+    .button-group.stacked-for-small .button {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto;
+      margin-bottom: 0; } }
+  @media print, screen and (min-width: 64em) {
+    .button-group.stacked-for-medium .button {
+      -webkit-box-flex: 0;
+      -webkit-flex: 0 0 auto;
+          -ms-flex: 0 0 auto;
+              flex: 0 0 auto;
+      margin-bottom: 0; } }
+  @media screen and (max-width: 39.99875em) {
+    .button-group.stacked-for-small.expanded {
+      display: block; }
+      .button-group.stacked-for-small.expanded .button {
+        display: block;
+        margin-right: 0; } }
+  @media screen and (max-width: 63.99875em) {
+    .button-group.stacked-for-medium.expanded {
+      display: block; }
+      .button-group.stacked-for-medium.expanded .button {
+        display: block;
+        margin-right: 0; } }
 
-.dropdown.menu a {
-  padding: 0.7rem 1rem; }
-  [data-whatinput='mouse'] .dropdown.menu a {
+.close-button {
+  position: absolute;
+  color: #8a8a8a;
+  cursor: pointer; }
+  [data-whatinput='mouse'] .close-button {
     outline: 0; }
+  .close-button:hover, .close-button:focus {
+    color: #0a0a0a; }
+  .close-button.small {
+    right: 0.66rem;
+    top: 0.33em;
+    font-size: 1.5em;
+    line-height: 1; }
+  .close-button, .close-button.medium {
+    right: 1rem;
+    top: 0.5rem;
+    font-size: 2em;
+    line-height: 1; }
 
-.dropdown.menu .is-active > a {
-  background: transparent;
-  color: #1779ba; }
-
-.no-js .dropdown.menu ul {
-  display: none; }
-
-.dropdown.menu .nested.is-dropdown-submenu {
-  margin-right: 0;
-  margin-left: 0; }
-
-.dropdown.menu.vertical > li .is-dropdown-submenu {
-  top: 0; }
-
-.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {
-  right: 100%;
-  left: auto;
-  top: 0; }
-
-.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {
-  right: auto;
-  left: 100%; }
-
-.dropdown.menu.vertical > li > a::after {
-  right: 14px; }
+.label {
+  display: inline-block;
+  padding: 0.33333rem 0.5rem;
+  border-radius: 0;
+  font-size: 0.8rem;
+  line-height: 1;
+  white-space: nowrap;
+  cursor: default;
+  background: #1779ba;
+  color: #fefefe; }
+  .label.primary {
+    background: #1779ba;
+    color: #fefefe; }
+  .label.secondary {
+    background: #767676;
+    color: #fefefe; }
+  .label.success {
+    background: #3adb76;
+    color: #0a0a0a; }
+  .label.warning {
+    background: #ffae00;
+    color: #0a0a0a; }
+  .label.alert {
+    background: #cc4b37;
+    color: #fefefe; }
 
-.dropdown.menu.vertical > li.opens-left > a::after {
-  right: auto;
-  left: 5px;
-  display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-left-width: 0;
-  border-right-style: solid;
-  border-color: transparent #1779ba transparent transparent; }
+.progress {
+  height: 1rem;
+  margin-bottom: 1rem;
+  border-radius: 0;
+  background-color: #cacaca; }
+  .progress.primary .progress-meter {
+    background-color: #1779ba; }
+  .progress.secondary .progress-meter {
+    background-color: #767676; }
+  .progress.success .progress-meter {
+    background-color: #3adb76; }
+  .progress.warning .progress-meter {
+    background-color: #ffae00; }
+  .progress.alert .progress-meter {
+    background-color: #cc4b37; }
 
-.dropdown.menu.vertical > li.opens-right > a::after {
+.progress-meter {
+  position: relative;
   display: block;
-  width: 0;
-  height: 0;
-  border: inset 6px;
-  content: '';
-  border-right-width: 0;
-  border-left-style: solid;
-  border-color: transparent transparent transparent #1779ba; }
+  width: 0%;
+  height: 100%;
+  background-color: #1779ba; }
 
-@media print, screen and (min-width: 40em) {
-  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {
-    top: 100%;
-    right: 0;
-    left: auto; }
-  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
-    top: 100%;
-    right: auto;
-    left: 0; }
-  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {
-    position: relative;
-    padding-right: 1.5rem; }
-  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    right: 5px;
-    left: auto;
-    margin-top: -3px; }
-  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {
-    top: 0; }
-  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto;
-    top: 0; }
-  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
-  .dropdown.menu.medium-vertical > li > a::after {
-    right: 14px; }
-  .dropdown.menu.medium-vertical > li.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .dropdown.menu.medium-vertical > li.opens-right > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; } }
+.progress-meter-text {
+  position: absolute;
+  top: 50%;
+  left: 50%;
+  -webkit-transform: translate(-50%, -50%);
+      -ms-transform: translate(-50%, -50%);
+          transform: translate(-50%, -50%);
+  margin: 0;
+  font-size: 0.75rem;
+  font-weight: bold;
+  color: #fefefe;
+  white-space: nowrap; }
 
-@media print, screen and (min-width: 64em) {
-  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {
-    top: 100%;
-    right: 0;
-    left: auto; }
-  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {
-    top: 100%;
-    right: auto;
-    left: 0; }
-  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {
-    position: relative;
-    padding-right: 1.5rem; }
-  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #1779ba transparent transparent;
-    right: 5px;
-    left: auto;
-    margin-top: -3px; }
-  .dropdown.menu.large-vertical > li .is-dropdown-submenu {
-    top: 0; }
-  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto;
-    top: 0; }
-  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
-  .dropdown.menu.large-vertical > li > a::after {
-    right: 14px; }
-  .dropdown.menu.large-vertical > li.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .dropdown.menu.large-vertical > li.opens-right > a::after {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; } }
+.slider {
+  position: relative;
+  height: 0.5rem;
+  margin-top: 1.25rem;
+  margin-bottom: 2.25rem;
+  background-color: #e6e6e6;
+  cursor: pointer;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none;
+  -ms-touch-action: none;
+      touch-action: none; }
 
-.dropdown.menu.align-right .is-dropdown-submenu.first-sub {
-  top: 100%;
-  right: 0;
-  left: auto; }
+.slider-fill {
+  position: absolute;
+  top: 0;
+  left: 0;
+  display: inline-block;
+  max-width: 100%;
+  height: 0.5rem;
+  background-color: #cacaca;
+  -webkit-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out; }
+  .slider-fill.is-dragging {
+    -webkit-transition: all 0s linear;
+    transition: all 0s linear; }
 
-.is-dropdown-menu.vertical {
-  width: 100px; }
-  .is-dropdown-menu.vertical.align-right {
-    float: right; }
+.slider-handle {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%);
+  left: 0;
+  z-index: 1;
+  display: inline-block;
+  width: 1.4rem;
+  height: 1.4rem;
+  border-radius: 0;
+  background-color: #1779ba;
+  -webkit-transition: all 0.2s ease-in-out;
+  transition: all 0.2s ease-in-out;
+  -ms-touch-action: manipulation;
+      touch-action: manipulation; }
+  [data-whatinput='mouse'] .slider-handle {
+    outline: 0; }
+  .slider-handle:hover {
+    background-color: #14679e; }
+  .slider-handle.is-dragging {
+    -webkit-transition: all 0s linear;
+    transition: all 0s linear; }
 
-.is-dropdown-submenu-parent {
-  position: relative; }
-  .is-dropdown-submenu-parent a::after {
+.slider.disabled,
+.slider[disabled] {
+  opacity: 0.25;
+  cursor: not-allowed; }
+
+.slider.vertical {
+  display: inline-block;
+  width: 0.5rem;
+  height: 12.5rem;
+  margin: 0 1.25rem;
+  -webkit-transform: scale(1, -1);
+      -ms-transform: scale(1, -1);
+          transform: scale(1, -1); }
+  .slider.vertical .slider-fill {
+    top: 0;
+    width: 0.5rem;
+    max-height: 100%; }
+  .slider.vertical .slider-handle {
     position: absolute;
-    top: 50%;
-    right: 5px;
-    left: auto;
-    margin-top: -6px; }
-  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {
-    top: 100%;
-    left: auto; }
-  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {
-    right: 100%;
-    left: auto; }
-  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {
-    right: auto;
-    left: 100%; }
+    top: 0;
+    left: 50%;
+    width: 1.4rem;
+    height: 1.4rem;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
 
-.is-dropdown-submenu {
+.switch {
+  height: 2rem;
+  position: relative;
+  margin-bottom: 1rem;
+  outline: 0;
+  font-size: 0.875rem;
+  font-weight: bold;
+  color: #fefefe;
+  -webkit-user-select: none;
+     -moz-user-select: none;
+      -ms-user-select: none;
+          user-select: none; }
+
+.switch-input {
   position: absolute;
-  top: 0;
-  left: 100%;
-  z-index: 1;
-  display: none;
-  min-width: 200px;
-  border: 1px solid #cacaca;
-  background: #fefefe; }
-  .dropdown .is-dropdown-submenu a {
-    padding: 0.7rem 1rem; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {
-    right: 14px; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {
-    right: auto;
-    left: 5px;
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #1779ba transparent transparent; }
-  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {
+  margin-bottom: 0;
+  opacity: 0; }
+
+.switch-paddle {
+  position: relative;
+  display: block;
+  width: 4rem;
+  height: 2rem;
+  border-radius: 0;
+  background: #cacaca;
+  -webkit-transition: all 0.25s ease-out;
+  transition: all 0.25s ease-out;
+  font-weight: inherit;
+  color: inherit;
+  cursor: pointer; }
+  input + .switch-paddle {
+    margin: 0; }
+  .switch-paddle::after {
+    position: absolute;
+    top: 0.25rem;
+    left: 0.25rem;
     display: block;
-    width: 0;
-    height: 0;
-    border: inset 6px;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #1779ba; }
-  .is-dropdown-submenu .is-dropdown-submenu {
-    margin-top: -1px; }
-  .is-dropdown-submenu > li {
-    width: 100%; }
-  .is-dropdown-submenu.js-dropdown-active {
+    width: 1.5rem;
+    height: 1.5rem;
+    -webkit-transform: translate3d(0, 0, 0);
+            transform: translate3d(0, 0, 0);
+    border-radius: 0;
+    background: #fefefe;
+    -webkit-transition: all 0.25s ease-out;
+    transition: all 0.25s ease-out;
+    content: ''; }
+  input:checked ~ .switch-paddle {
+    background: #1779ba; }
+    input:checked ~ .switch-paddle::after {
+      left: 2.25rem; }
+  [data-whatinput='mouse'] input:focus ~ .switch-paddle {
+    outline: 0; }
+
+.switch-active, .switch-inactive {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%); }
+
+.switch-active {
+  left: 8%;
+  display: none; }
+  input:checked + label > .switch-active {
+    display: block; }
+
+.switch-inactive {
+  right: 15%; }
+  input:checked + label > .switch-inactive {
+    display: none; }
+
+.switch.tiny {
+  height: 1.5rem; }
+  .switch.tiny .switch-paddle {
+    width: 3rem;
+    height: 1.5rem;
+    font-size: 0.625rem; }
+  .switch.tiny .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 1rem;
+    height: 1rem; }
+  .switch.tiny input:checked ~ .switch-paddle::after {
+    left: 1.75rem; }
+
+.switch.small {
+  height: 1.75rem; }
+  .switch.small .switch-paddle {
+    width: 3.5rem;
+    height: 1.75rem;
+    font-size: 0.75rem; }
+  .switch.small .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 1.25rem;
+    height: 1.25rem; }
+  .switch.small input:checked ~ .switch-paddle::after {
+    left: 2rem; }
+
+.switch.large {
+  height: 2.5rem; }
+  .switch.large .switch-paddle {
+    width: 5rem;
+    height: 2.5rem;
+    font-size: 1rem; }
+  .switch.large .switch-paddle::after {
+    top: 0.25rem;
+    left: 0.25rem;
+    width: 2rem;
+    height: 2rem; }
+  .switch.large input:checked ~ .switch-paddle::after {
+    left: 2.75rem; }
+
+table {
+  border-collapse: collapse;
+  width: 100%;
+  margin-bottom: 1rem;
+  border-radius: 0; }
+  thead,
+  tbody,
+  tfoot {
+    border: 1px solid #f1f1f1;
+    background-color: #fefefe; }
+  caption {
+    padding: 0.5rem 0.625rem 0.625rem;
+    font-weight: bold; }
+  thead {
+    background: #f8f8f8;
+    color: #0a0a0a; }
+  tfoot {
+    background: #f1f1f1;
+    color: #0a0a0a; }
+  thead tr,
+  tfoot tr {
+    background: transparent; }
+  thead th,
+  thead td,
+  tfoot th,
+  tfoot td {
+    padding: 0.5rem 0.625rem 0.625rem;
+    font-weight: bold;
+    text-align: left; }
+  tbody th,
+  tbody td {
+    padding: 0.5rem 0.625rem 0.625rem; }
+  tbody tr:nth-child(even) {
+    border-bottom: 0;
+    background-color: #f1f1f1; }
+  table.unstriped tbody {
+    background-color: #fefefe; }
+    table.unstriped tbody tr {
+      border-bottom: 0;
+      border-bottom: 1px solid #f1f1f1;
+      background-color: #fefefe; }
+
+@media screen and (max-width: 63.99875em) {
+  table.stack thead {
+    display: none; }
+  table.stack tfoot {
+    display: none; }
+  table.stack tr,
+  table.stack th,
+  table.stack td {
     display: block; }
+  table.stack td {
+    border-top: 0; } }
 
-.responsive-embed,
-.flex-video {
-  position: relative;
-  height: 0;
-  margin-bottom: 1rem;
-  padding-bottom: 75%;
-  overflow: hidden; }
-  .responsive-embed iframe,
-  .responsive-embed object,
-  .responsive-embed embed,
-  .responsive-embed video,
-  .flex-video iframe,
-  .flex-video object,
-  .flex-video embed,
-  .flex-video video {
-    position: absolute;
-    top: 0;
-    left: 0;
-    width: 100%;
-    height: 100%; }
-  .responsive-embed.widescreen,
-  .flex-video.widescreen {
-    padding-bottom: 56.25%; }
+table.scroll {
+  display: block;
+  width: 100%;
+  overflow-x: auto; }
 
-.label {
+table.hover thead tr:hover {
+  background-color: #f3f3f3; }
+
+table.hover tfoot tr:hover {
+  background-color: #ececec; }
+
+table.hover tbody tr:hover {
+  background-color: #f9f9f9; }
+
+table.hover:not(.unstriped) tr:nth-of-type(even):hover {
+  background-color: #ececec; }
+
+.table-scroll {
+  overflow-x: auto; }
+
+.badge {
   display: inline-block;
-  padding: 0.33333rem 0.5rem;
-  border-radius: 0;
-  font-size: 0.8rem;
-  line-height: 1;
-  white-space: nowrap;
-  cursor: default;
+  min-width: 2.1em;
+  padding: 0.3em;
+  border-radius: 50%;
+  font-size: 0.6rem;
+  text-align: center;
   background: #1779ba;
   color: #fefefe; }
-  .label.primary {
+  .badge.primary {
     background: #1779ba;
     color: #fefefe; }
-  .label.secondary {
+  .badge.secondary {
     background: #767676;
     color: #fefefe; }
-  .label.success {
+  .badge.success {
     background: #3adb76;
     color: #0a0a0a; }
-  .label.warning {
+  .badge.warning {
     background: #ffae00;
     color: #0a0a0a; }
-  .label.alert {
+  .badge.alert {
     background: #cc4b37;
-    color: #fefefe; }
-
-.media-object {
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  margin-bottom: 1rem;
-  -webkit-flex-wrap: nowrap;
-      -ms-flex-wrap: nowrap;
-          flex-wrap: nowrap; }
-  .media-object img {
-    max-width: none; }
-  @media screen and (max-width: 39.9375em) {
-    .media-object.stack-for-small {
-      -webkit-flex-wrap: wrap;
-          -ms-flex-wrap: wrap;
-              flex-wrap: wrap; } }
-  @media screen and (max-width: 39.9375em) {
-    .media-object.stack-for-small .media-object-section {
-      padding: 0;
-      padding-bottom: 1rem;
-      -webkit-flex-basis: 100%;
-          -ms-flex-preferred-size: 100%;
-              flex-basis: 100%;
-      max-width: 100%; }
-      .media-object.stack-for-small .media-object-section img {
-        width: 100%; } }
-
-.media-object-section {
-  -webkit-box-flex: 0;
-  -webkit-flex: 0 1 auto;
-      -ms-flex: 0 1 auto;
-          flex: 0 1 auto; }
-  .media-object-section:first-child {
-    padding-right: 1rem; }
-  .media-object-section:last-child:not(:nth-child(2)) {
-    padding-left: 1rem; }
-  .media-object-section > :last-child {
-    margin-bottom: 0; }
-  .media-object-section.main-section {
-    -webkit-box-flex: 1;
-    -webkit-flex: 1 1 0px;
-        -ms-flex: 1 1 0px;
-            flex: 1 1 0px; }
-
-.is-off-canvas-open {
-  overflow: hidden; }
-
-.js-off-canvas-overlay {
-  position: absolute;
-  top: 0;
-  left: 0;
-  z-index: 11;
-  width: 100%;
-  height: 100%;
-  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
-  transition: opacity 0.5s ease, visibility 0.5s ease;
-  background: rgba(254, 254, 254, 0.25);
-  opacity: 0;
-  visibility: hidden;
-  overflow: hidden; }
-  .js-off-canvas-overlay.is-visible {
-    opacity: 1;
-    visibility: visible; }
-  .js-off-canvas-overlay.is-closable {
-    cursor: pointer; }
-  .js-off-canvas-overlay.is-overlay-absolute {
-    position: absolute; }
-  .js-off-canvas-overlay.is-overlay-fixed {
-    position: fixed; }
-
-.off-canvas-wrapper {
-  position: relative;
-  overflow: hidden; }
-
-.off-canvas {
-  position: fixed;
-  z-index: 12;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  background: #e6e6e6; }
-  [data-whatinput='mouse'] .off-canvas {
-    outline: 0; }
-  .off-canvas.is-transition-push {
-    z-index: 12; }
-  .off-canvas.is-closed {
-    visibility: hidden; }
-  .off-canvas.is-transition-overlap {
-    z-index: 13; }
-    .off-canvas.is-transition-overlap.is-open {
-      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
-              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
-  .off-canvas.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
-
-.off-canvas-absolute {
-  position: absolute;
-  z-index: 12;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  background: #e6e6e6; }
-  [data-whatinput='mouse'] .off-canvas-absolute {
-    outline: 0; }
-  .off-canvas-absolute.is-transition-push {
-    z-index: 12; }
-  .off-canvas-absolute.is-closed {
-    visibility: hidden; }
-  .off-canvas-absolute.is-transition-overlap {
-    z-index: 13; }
-    .off-canvas-absolute.is-transition-overlap.is-open {
-      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
-              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
-  .off-canvas-absolute.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
-
-.position-left {
-  top: 0;
-  left: 0;
-  height: 100%;
-  overflow-y: auto;
-  width: 250px;
-  -webkit-transform: translateX(-250px);
-      -ms-transform: translateX(-250px);
-          transform: translateX(-250px); }
-  .off-canvas-content .off-canvas.position-left {
-    -webkit-transform: translateX(-250px);
-        -ms-transform: translateX(-250px);
-            transform: translateX(-250px); }
-    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-left.has-transition-push {
-    -webkit-transform: translateX(250px);
-        -ms-transform: translateX(250px);
-            transform: translateX(250px); }
-  .position-left.is-transition-push {
-    -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }
-
-.position-right {
-  top: 0;
-  right: 0;
-  height: 100%;
-  overflow-y: auto;
-  width: 250px;
-  -webkit-transform: translateX(250px);
-      -ms-transform: translateX(250px);
-          transform: translateX(250px); }
-  .off-canvas-content .off-canvas.position-right {
-    -webkit-transform: translateX(250px);
-        -ms-transform: translateX(250px);
-            transform: translateX(250px); }
-    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-right.has-transition-push {
-    -webkit-transform: translateX(-250px);
-        -ms-transform: translateX(-250px);
-            transform: translateX(-250px); }
-  .position-right.is-transition-push {
-    -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }
+    color: #fefefe; }
 
-.position-top {
-  top: 0;
-  left: 0;
-  width: 100%;
-  overflow-x: auto;
-  height: 250px;
-  -webkit-transform: translateY(-250px);
-      -ms-transform: translateY(-250px);
-          transform: translateY(-250px); }
-  .off-canvas-content .off-canvas.position-top {
-    -webkit-transform: translateY(-250px);
-        -ms-transform: translateY(-250px);
-            transform: translateY(-250px); }
-    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-top.has-transition-push {
-    -webkit-transform: translateY(250px);
-        -ms-transform: translateY(250px);
-            transform: translateY(250px); }
-  .position-top.is-transition-push {
-    -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }
+.breadcrumbs {
+  margin: 0 0 1rem 0;
+  list-style: none; }
+  .breadcrumbs::before, .breadcrumbs::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .breadcrumbs::after {
+    clear: both; }
+  .breadcrumbs li {
+    float: left;
+    font-size: 0.6875rem;
+    color: #0a0a0a;
+    cursor: default;
+    text-transform: uppercase; }
+    .breadcrumbs li:not(:last-child)::after {
+      position: relative;
+      margin: 0 0.75rem;
+      opacity: 1;
+      content: "/";
+      color: #cacaca; }
+  .breadcrumbs a {
+    color: #1779ba; }
+    .breadcrumbs a:hover {
+      text-decoration: underline; }
+  .breadcrumbs .disabled {
+    color: #cacaca;
+    cursor: not-allowed; }
 
-.position-bottom {
-  bottom: 0;
-  left: 0;
-  width: 100%;
-  overflow-x: auto;
-  height: 250px;
-  -webkit-transform: translateY(250px);
-      -ms-transform: translateY(250px);
-          transform: translateY(250px); }
-  .off-canvas-content .off-canvas.position-bottom {
-    -webkit-transform: translateY(250px);
-        -ms-transform: translateY(250px);
-            transform: translateY(250px); }
-    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {
-      -webkit-transform: translate(0, 0);
-          -ms-transform: translate(0, 0);
-              transform: translate(0, 0); }
-  .off-canvas-content.is-open-bottom.has-transition-push {
-    -webkit-transform: translateY(-250px);
-        -ms-transform: translateY(-250px);
-            transform: translateY(-250px); }
-  .position-bottom.is-transition-push {
-    -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25);
-            box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }
+.callout {
+  position: relative;
+  margin: 0 0 1rem 0;
+  padding: 1rem;
+  border: 1px solid rgba(10, 10, 10, 0.25);
+  border-radius: 0;
+  background-color: white;
+  color: #0a0a0a; }
+  .callout > :first-child {
+    margin-top: 0; }
+  .callout > :last-child {
+    margin-bottom: 0; }
+  .callout.primary {
+    background-color: #d7ecfa;
+    color: #0a0a0a; }
+  .callout.secondary {
+    background-color: #eaeaea;
+    color: #0a0a0a; }
+  .callout.success {
+    background-color: #e1faea;
+    color: #0a0a0a; }
+  .callout.warning {
+    background-color: #fff3d9;
+    color: #0a0a0a; }
+  .callout.alert {
+    background-color: #f7e4e1;
+    color: #0a0a0a; }
+  .callout.small {
+    padding-top: 0.5rem;
+    padding-right: 0.5rem;
+    padding-bottom: 0.5rem;
+    padding-left: 0.5rem; }
+  .callout.large {
+    padding-top: 3rem;
+    padding-right: 3rem;
+    padding-bottom: 3rem;
+    padding-left: 3rem; }
 
-.off-canvas-content {
-  -webkit-transform: none;
-      -ms-transform: none;
-          transform: none;
-  -webkit-transition: -webkit-transform 0.5s ease;
-  transition: -webkit-transform 0.5s ease;
-  transition: transform 0.5s ease;
-  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden; }
-  .off-canvas-content.has-transition-push {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
-  .off-canvas-content .off-canvas.is-open {
-    -webkit-transform: translate(0, 0);
-        -ms-transform: translate(0, 0);
-            transform: translate(0, 0); }
+.card {
+  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-grow: 1;
+      -ms-flex-positive: 1;
+          flex-grow: 1;
+  margin-bottom: 1rem;
+  border: 1px solid #e6e6e6;
+  border-radius: 0;
+  background: #fefefe;
+  -webkit-box-shadow: none;
+          box-shadow: none;
+  overflow: hidden;
+  color: #0a0a0a; }
+  .card > :last-child {
+    margin-bottom: 0; }
 
-@media print, screen and (min-width: 40em) {
-  .position-left.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-left.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-left.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-left {
-      margin-left: 250px; }
-    .position-left.reveal-for-medium ~ .off-canvas-content {
-      margin-left: 250px; }
-  .position-right.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-right.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-right.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-right {
-      margin-right: 250px; }
-    .position-right.reveal-for-medium ~ .off-canvas-content {
-      margin-right: 250px; }
-  .position-top.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-top.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-top.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-top {
-      margin-top: 250px; }
-    .position-top.reveal-for-medium ~ .off-canvas-content {
-      margin-top: 250px; }
-  .position-bottom.reveal-for-medium {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-bottom.reveal-for-medium .close-button {
-      display: none; }
-    .off-canvas-content .position-bottom.reveal-for-medium {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-bottom {
-      margin-bottom: 250px; }
-    .position-bottom.reveal-for-medium ~ .off-canvas-content {
-      margin-bottom: 250px; } }
+.card-divider {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 1 auto;
+      -ms-flex: 0 1 auto;
+          flex: 0 1 auto;
+  padding: 1rem;
+  background: #e6e6e6; }
+  .card-divider > :last-child {
+    margin-bottom: 0; }
+
+.card-section {
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 0 auto;
+      -ms-flex: 1 0 auto;
+          flex: 1 0 auto;
+  padding: 1rem; }
+  .card-section > :last-child {
+    margin-bottom: 0; }
 
-@media print, screen and (min-width: 64em) {
-  .position-left.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-left.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-left.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-left {
-      margin-left: 250px; }
-    .position-left.reveal-for-large ~ .off-canvas-content {
-      margin-left: 250px; }
-  .position-right.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-right.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-right.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-right {
-      margin-right: 250px; }
-    .position-right.reveal-for-large ~ .off-canvas-content {
-      margin-right: 250px; }
-  .position-top.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
-    visibility: visible; }
-    .position-top.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-top.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-top {
-      margin-top: 250px; }
-    .position-top.reveal-for-large ~ .off-canvas-content {
-      margin-top: 250px; }
-  .position-bottom.reveal-for-large {
-    -webkit-transform: none;
-        -ms-transform: none;
-            transform: none;
-    z-index: 12;
-    -webkit-transition: none;
-    transition: none;
+.card-image {
+  min-height: 1px; }
+
+.dropdown-pane {
+  position: absolute;
+  z-index: 10;
+  display: none;
+  width: 300px;
+  padding: 1rem;
+  visibility: hidden;
+  border: 1px solid #cacaca;
+  border-radius: 0;
+  background-color: #fefefe;
+  font-size: 1rem; }
+  .dropdown-pane.is-opening {
+    display: block; }
+  .dropdown-pane.is-open {
+    display: block;
     visibility: visible; }
-    .position-bottom.reveal-for-large .close-button {
-      display: none; }
-    .off-canvas-content .position-bottom.reveal-for-large {
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas-content.has-reveal-bottom {
-      margin-bottom: 250px; }
-    .position-bottom.reveal-for-large ~ .off-canvas-content {
-      margin-bottom: 250px; } }
 
-@media print, screen and (min-width: 40em) {
-  .off-canvas.in-canvas-for-medium {
-    visibility: visible;
-    height: auto;
-    position: static;
-    background: inherit;
-    width: inherit;
-    overflow: inherit;
-    -webkit-transition: inherit;
-    transition: inherit; }
-    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {
-      -webkit-box-shadow: none;
-              box-shadow: none;
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas.in-canvas-for-medium .close-button {
-      display: none; } }
+.dropdown-pane.tiny {
+  width: 100px; }
+
+.dropdown-pane.small {
+  width: 200px; }
+
+.dropdown-pane.large {
+  width: 400px; }
+
+.pagination {
+  margin-left: 0;
+  margin-bottom: 1rem; }
+  .pagination::before, .pagination::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .pagination::after {
+    clear: both; }
+  .pagination li {
+    margin-right: 0.0625rem;
+    border-radius: 0;
+    font-size: 0.875rem;
+    display: none; }
+    .pagination li:last-child, .pagination li:first-child {
+      display: inline-block; }
+    @media print, screen and (min-width: 40em) {
+      .pagination li {
+        display: inline-block; } }
+  .pagination a,
+  .pagination button {
+    display: block;
+    padding: 0.1875rem 0.625rem;
+    border-radius: 0;
+    color: #0a0a0a; }
+    .pagination a:hover,
+    .pagination button:hover {
+      background: #e6e6e6; }
+  .pagination .current {
+    padding: 0.1875rem 0.625rem;
+    background: #1779ba;
+    color: #fefefe;
+    cursor: default; }
+  .pagination .disabled {
+    padding: 0.1875rem 0.625rem;
+    color: #cacaca;
+    cursor: not-allowed; }
+    .pagination .disabled:hover {
+      background: transparent; }
+  .pagination .ellipsis::after {
+    padding: 0.1875rem 0.625rem;
+    content: '\2026';
+    color: #0a0a0a; }
+
+.pagination-previous a::before,
+.pagination-previous.disabled::before {
+  display: inline-block;
+  margin-right: 0.5rem;
+  content: '\00ab'; }
+
+.pagination-next a::after,
+.pagination-next.disabled::after {
+  display: inline-block;
+  margin-left: 0.5rem;
+  content: '\00bb'; }
+
+.has-tip {
+  position: relative;
+  display: inline-block;
+  border-bottom: dotted 1px #8a8a8a;
+  font-weight: bold;
+  cursor: help; }
+
+.tooltip {
+  position: absolute;
+  top: calc(100% + 0.6495rem);
+  z-index: 1200;
+  max-width: 10rem;
+  padding: 0.75rem;
+  border-radius: 0;
+  background-color: #0a0a0a;
+  font-size: 80%;
+  color: #fefefe; }
+  .tooltip::before {
+    position: absolute; }
+  .tooltip.bottom::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-top-width: 0;
+    border-bottom-style: solid;
+    border-color: transparent transparent #0a0a0a;
+    bottom: 100%; }
+  .tooltip.bottom.align-center::before {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+  .tooltip.top::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #0a0a0a transparent transparent;
+    top: 100%;
+    bottom: auto; }
+  .tooltip.top.align-center::before {
+    left: 50%;
+    -webkit-transform: translateX(-50%);
+        -ms-transform: translateX(-50%);
+            transform: translateX(-50%); }
+  .tooltip.left::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #0a0a0a;
+    left: 100%; }
+  .tooltip.left.align-center::before {
+    bottom: auto;
+    top: 50%;
+    -webkit-transform: translateY(-50%);
+        -ms-transform: translateY(-50%);
+            transform: translateY(-50%); }
+  .tooltip.right::before {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 0.75rem;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #0a0a0a transparent transparent;
+    right: 100%;
+    left: auto; }
+  .tooltip.right.align-center::before {
+    bottom: auto;
+    top: 50%;
+    -webkit-transform: translateY(-50%);
+        -ms-transform: translateY(-50%);
+            transform: translateY(-50%); }
+  .tooltip.align-top::before {
+    bottom: auto;
+    top: 10%; }
+  .tooltip.align-bottom::before {
+    bottom: 10%;
+    top: auto; }
+  .tooltip.align-left::before {
+    left: 10%;
+    right: auto; }
+  .tooltip.align-right::before {
+    left: auto;
+    right: 10%; }
+
+.accordion {
+  margin-left: 0;
+  background: #fefefe;
+  list-style-type: none; }
+  .accordion[disabled] .accordion-title {
+    cursor: not-allowed; }
 
-@media print, screen and (min-width: 64em) {
-  .off-canvas.in-canvas-for-large {
-    visibility: visible;
-    height: auto;
-    position: static;
-    background: inherit;
-    width: inherit;
-    overflow: inherit;
-    -webkit-transition: inherit;
-    transition: inherit; }
-    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {
-      -webkit-box-shadow: none;
-              box-shadow: none;
-      -webkit-transform: none;
-          -ms-transform: none;
-              transform: none; }
-    .off-canvas.in-canvas-for-large .close-button {
-      display: none; } }
+.accordion-item:first-child > :first-child {
+  border-radius: 0 0 0 0; }
+
+.accordion-item:last-child > :last-child {
+  border-radius: 0 0 0 0; }
+
+.accordion-title {
+  position: relative;
+  display: block;
+  padding: 1.25rem 1rem;
+  border: 1px solid #e6e6e6;
+  border-bottom: 0;
+  font-size: 0.75rem;
+  line-height: 1;
+  color: #1779ba; }
+  :last-child:not(.is-active) > .accordion-title {
+    border-bottom: 1px solid #e6e6e6;
+    border-radius: 0 0 0 0; }
+  .accordion-title:hover, .accordion-title:focus {
+    background-color: #e6e6e6; }
+  .accordion-title::before {
+    position: absolute;
+    top: 50%;
+    right: 1rem;
+    margin-top: -0.5rem;
+    content: '+'; }
+  .is-active > .accordion-title::before {
+    content: '\2013'; }
+
+.accordion-content {
+  display: none;
+  padding: 1rem;
+  border: 1px solid #e6e6e6;
+  border-bottom: 0;
+  background-color: #fefefe;
+  color: #0a0a0a; }
+  :last-child > .accordion-content:last-child {
+    border-bottom: 1px solid #e6e6e6; }
+
+.media-object {
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  margin-bottom: 1rem;
+  -webkit-flex-wrap: nowrap;
+      -ms-flex-wrap: nowrap;
+          flex-wrap: nowrap; }
+  .media-object img {
+    max-width: none; }
+  @media screen and (max-width: 39.99875em) {
+    .media-object.stack-for-small {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap; } }
+
+.media-object-section {
+  -webkit-box-flex: 0;
+  -webkit-flex: 0 1 auto;
+      -ms-flex: 0 1 auto;
+          flex: 0 1 auto; }
+  .media-object-section:first-child {
+    padding-right: 1rem; }
+  .media-object-section:last-child:not(:nth-child(2)) {
+    padding-left: 1rem; }
+  .media-object-section > :last-child {
+    margin-bottom: 0; }
+  @media screen and (max-width: 39.99875em) {
+    .stack-for-small .media-object-section {
+      padding: 0;
+      padding-bottom: 1rem;
+      -webkit-flex-basis: 100%;
+          -ms-flex-preferred-size: 100%;
+              flex-basis: 100%;
+      max-width: 100%; }
+      .stack-for-small .media-object-section img {
+        width: 100%; } }
+  .media-object-section.main-section {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
 
 .orbit {
   position: relative; }
@@ -4491,7 +3552,8 @@ a.button:hover, a.button:focus {
   overflow: hidden; }
 
 .orbit-slide {
-  width: 100%; }
+  width: 100%;
+  position: absolute; }
   .orbit-slide.no-motionui.is-active {
     top: 0;
     left: 0; }
@@ -4502,760 +3564,1458 @@ a.button:hover, a.button:focus {
 .orbit-image {
   width: 100%;
   max-width: 100%;
-  margin: 0; }
+  margin: 0; }
+
+.orbit-caption {
+  position: absolute;
+  bottom: 0;
+  width: 100%;
+  margin-bottom: 0;
+  padding: 1rem;
+  background-color: rgba(10, 10, 10, 0.5);
+  color: #fefefe; }
+
+.orbit-previous, .orbit-next {
+  position: absolute;
+  top: 50%;
+  -webkit-transform: translateY(-50%);
+      -ms-transform: translateY(-50%);
+          transform: translateY(-50%);
+  z-index: 10;
+  padding: 1rem;
+  color: #fefefe; }
+  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
+    outline: 0; }
+  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {
+    background-color: rgba(10, 10, 10, 0.5); }
+
+.orbit-previous {
+  left: 0; }
+
+.orbit-next {
+  left: auto;
+  right: 0; }
+
+.orbit-bullets {
+  position: relative;
+  margin-top: 0.8rem;
+  margin-bottom: 0.8rem;
+  text-align: center; }
+  [data-whatinput='mouse'] .orbit-bullets {
+    outline: 0; }
+  .orbit-bullets button {
+    width: 1.2rem;
+    height: 1.2rem;
+    margin: 0.1rem;
+    border-radius: 50%;
+    background-color: #cacaca; }
+    .orbit-bullets button:hover {
+      background-color: #8a8a8a; }
+    .orbit-bullets button.is-active {
+      background-color: #8a8a8a; }
+
+.responsive-embed,
+.flex-video {
+  position: relative;
+  height: 0;
+  margin-bottom: 1rem;
+  padding-bottom: 75%;
+  overflow: hidden; }
+  .responsive-embed iframe,
+  .responsive-embed object,
+  .responsive-embed embed,
+  .responsive-embed video,
+  .flex-video iframe,
+  .flex-video object,
+  .flex-video embed,
+  .flex-video video {
+    position: absolute;
+    top: 0;
+    left: 0;
+    width: 100%;
+    height: 100%; }
+  .responsive-embed.widescreen,
+  .flex-video.widescreen {
+    padding-bottom: 56.25%; }
+
+.tabs {
+  margin: 0;
+  border: 1px solid #e6e6e6;
+  background: #fefefe;
+  list-style-type: none; }
+  .tabs::before, .tabs::after {
+    display: table;
+    content: ' ';
+    -webkit-flex-basis: 0;
+        -ms-flex-preferred-size: 0;
+            flex-basis: 0;
+    -webkit-box-ordinal-group: 2;
+    -webkit-order: 1;
+        -ms-flex-order: 1;
+            order: 1; }
+  .tabs::after {
+    clear: both; }
+
+.tabs.vertical > li {
+  display: block;
+  float: none;
+  width: auto; }
+
+.tabs.simple > li > a {
+  padding: 0; }
+  .tabs.simple > li > a:hover {
+    background: transparent; }
+
+.tabs.primary {
+  background: #1779ba; }
+  .tabs.primary > li > a {
+    color: #fefefe; }
+    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
+      background: #1673b1; }
+
+.tabs-title {
+  float: left; }
+  .tabs-title > a {
+    display: block;
+    padding: 1.25rem 1.5rem;
+    font-size: 0.75rem;
+    line-height: 1;
+    color: #1779ba; }
+    [data-whatinput='mouse'] .tabs-title > a {
+      outline: 0; }
+    .tabs-title > a:hover {
+      background: #fefefe;
+      color: #1468a0; }
+    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {
+      background: #e6e6e6;
+      color: #1779ba; }
+
+.tabs-content {
+  border: 1px solid #e6e6e6;
+  border-top: 0;
+  background: #fefefe;
+  color: #0a0a0a;
+  -webkit-transition: all 0.5s ease;
+  transition: all 0.5s ease; }
+
+.tabs-content.vertical {
+  border: 1px solid #e6e6e6;
+  border-left: 0; }
+
+.tabs-panel {
+  display: none;
+  padding: 1rem; }
+  .tabs-panel.is-active {
+    display: block; }
+
+.thumbnail {
+  display: inline-block;
+  max-width: 100%;
+  margin-bottom: 1rem;
+  border: 4px solid #fefefe;
+  border-radius: 0;
+  -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
+          box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
+  line-height: 0; }
 
-.orbit-caption {
-  position: absolute;
-  bottom: 0;
-  width: 100%;
-  margin-bottom: 0;
-  padding: 1rem;
-  background-color: rgba(10, 10, 10, 0.5);
-  color: #fefefe; }
+a.thumbnail {
+  -webkit-transition: -webkit-box-shadow 200ms ease-out;
+  transition: -webkit-box-shadow 200ms ease-out;
+  transition: box-shadow 200ms ease-out;
+  transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; }
+  a.thumbnail:hover, a.thumbnail:focus {
+    -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
+            box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }
+  a.thumbnail image {
+    -webkit-box-shadow: none;
+            box-shadow: none; }
 
-.orbit-previous, .orbit-next {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%);
-  z-index: 10;
-  padding: 1rem;
-  color: #fefefe; }
-  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {
+.menu {
+  padding: 0;
+  margin: 0;
+  list-style: none;
+  position: relative;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-flex-wrap: wrap;
+      -ms-flex-wrap: wrap;
+          flex-wrap: wrap; }
+  [data-whatinput='mouse'] .menu li {
     outline: 0; }
-  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {
-    background-color: rgba(10, 10, 10, 0.5); }
+  .menu a,
+  .menu .button {
+    line-height: 1;
+    text-decoration: none;
+    display: block;
+    padding: 0.7rem 1rem; }
+  .menu input,
+  .menu select,
+  .menu a,
+  .menu button {
+    margin-bottom: 0; }
+  .menu input {
+    display: inline-block; }
+  .menu, .menu.horizontal {
+    -webkit-flex-wrap: wrap;
+        -ms-flex-wrap: wrap;
+            flex-wrap: wrap;
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: row;
+        -ms-flex-direction: row;
+            flex-direction: row; }
+  .menu.vertical {
+    -webkit-flex-wrap: nowrap;
+        -ms-flex-wrap: nowrap;
+            flex-wrap: nowrap;
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-direction: column;
+        -ms-flex-direction: column;
+            flex-direction: column; }
+  .menu.expanded li {
+    -webkit-box-flex: 1;
+    -webkit-flex: 1 1 0px;
+        -ms-flex: 1 1 0px;
+            flex: 1 1 0px; }
+  .menu.simple {
+    -webkit-box-align: center;
+    -webkit-align-items: center;
+        -ms-flex-align: center;
+            align-items: center; }
+    .menu.simple li + li {
+      margin-left: 1rem; }
+    .menu.simple a {
+      padding: 0; }
+  @media print, screen and (min-width: 40em) {
+    .menu.medium-horizontal {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap;
+      -webkit-box-orient: horizontal;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: row;
+          -ms-flex-direction: row;
+              flex-direction: row; }
+    .menu.medium-vertical {
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap;
+      -webkit-box-orient: vertical;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: column;
+          -ms-flex-direction: column;
+              flex-direction: column; }
+    .menu.medium-expanded li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; }
+    .menu.medium-simple li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; } }
+  @media print, screen and (min-width: 64em) {
+    .menu.large-horizontal {
+      -webkit-flex-wrap: wrap;
+          -ms-flex-wrap: wrap;
+              flex-wrap: wrap;
+      -webkit-box-orient: horizontal;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: row;
+          -ms-flex-direction: row;
+              flex-direction: row; }
+    .menu.large-vertical {
+      -webkit-flex-wrap: nowrap;
+          -ms-flex-wrap: nowrap;
+              flex-wrap: nowrap;
+      -webkit-box-orient: vertical;
+      -webkit-box-direction: normal;
+      -webkit-flex-direction: column;
+          -ms-flex-direction: column;
+              flex-direction: column; }
+    .menu.large-expanded li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; }
+    .menu.large-simple li {
+      -webkit-box-flex: 1;
+      -webkit-flex: 1 1 0px;
+          -ms-flex: 1 1 0px;
+              flex: 1 1 0px; } }
+  .menu.nested {
+    margin-right: 0;
+    margin-left: 1rem; }
+  .menu.icons a {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex; }
+  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex; }
+  .menu.icon-left li a {
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: row nowrap;
+        -ms-flex-flow: row nowrap;
+            flex-flow: row nowrap; }
+    .menu.icon-left li a img,
+    .menu.icon-left li a i,
+    .menu.icon-left li a svg {
+      margin-right: 0.25rem; }
+  .menu.icon-right li a {
+    -webkit-box-orient: horizontal;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: row nowrap;
+        -ms-flex-flow: row nowrap;
+            flex-flow: row nowrap; }
+    .menu.icon-right li a img,
+    .menu.icon-right li a i,
+    .menu.icon-right li a svg {
+      margin-left: 0.25rem; }
+  .menu.icon-top li a {
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: column nowrap;
+        -ms-flex-flow: column nowrap;
+            flex-flow: column nowrap; }
+    .menu.icon-top li a img,
+    .menu.icon-top li a i,
+    .menu.icon-top li a svg {
+      -webkit-align-self: stretch;
+          -ms-flex-item-align: stretch;
+              align-self: stretch;
+      margin-bottom: 0.25rem;
+      text-align: center; }
+  .menu.icon-bottom li a {
+    -webkit-box-orient: vertical;
+    -webkit-box-direction: normal;
+    -webkit-flex-flow: column nowrap;
+        -ms-flex-flow: column nowrap;
+            flex-flow: column nowrap; }
+    .menu.icon-bottom li a img,
+    .menu.icon-bottom li a i,
+    .menu.icon-bottom li a svg {
+      -webkit-align-self: stretch;
+          -ms-flex-item-align: stretch;
+              align-self: stretch;
+      margin-bottom: 0.25rem;
+      text-align: center; }
+  .menu .is-active > a {
+    background: #1779ba;
+    color: #fefefe; }
+  .menu .active > a {
+    background: #1779ba;
+    color: #fefefe; }
+  .menu.align-left {
+    -webkit-box-pack: start;
+    -webkit-justify-content: flex-start;
+        -ms-flex-pack: start;
+            justify-content: flex-start; }
+  .menu.align-right li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: end;
+    -webkit-justify-content: flex-end;
+        -ms-flex-pack: end;
+            justify-content: flex-end; }
+    .menu.align-right li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
+  .menu.align-right.vertical li {
+    display: block;
+    text-align: right; }
+    .menu.align-right.vertical li .submenu li {
+      text-align: right; }
+  .menu.align-right .nested {
+    margin-right: 1rem;
+    margin-left: 0; }
+  .menu.align-center li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: center;
+    -webkit-justify-content: center;
+        -ms-flex-pack: center;
+            justify-content: center; }
+    .menu.align-center li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
+  .menu .menu-text {
+    padding: 0.7rem 1rem;
+    font-weight: bold;
+    line-height: 1;
+    color: inherit; }
 
-.orbit-previous {
-  left: 0; }
+.menu-centered > .menu {
+  -webkit-box-pack: center;
+  -webkit-justify-content: center;
+      -ms-flex-pack: center;
+          justify-content: center; }
+  .menu-centered > .menu li {
+    display: -webkit-box;
+    display: -webkit-flex;
+    display: -ms-flexbox;
+    display: flex;
+    -webkit-box-pack: center;
+    -webkit-justify-content: center;
+        -ms-flex-pack: center;
+            justify-content: center; }
+    .menu-centered > .menu li .submenu li {
+      -webkit-box-pack: start;
+      -webkit-justify-content: flex-start;
+          -ms-flex-pack: start;
+              justify-content: flex-start; }
 
-.orbit-next {
-  left: auto;
-  right: 0; }
+.no-js [data-responsive-menu] ul {
+  display: none; }
 
-.orbit-bullets {
+.menu-icon {
   position: relative;
-  margin-top: 0.8rem;
-  margin-bottom: 0.8rem;
-  text-align: center; }
-  [data-whatinput='mouse'] .orbit-bullets {
-    outline: 0; }
-  .orbit-bullets button {
-    width: 1.2rem;
-    height: 1.2rem;
-    margin: 0.1rem;
-    border-radius: 50%;
-    background-color: #cacaca; }
-    .orbit-bullets button:hover {
-      background-color: #8a8a8a; }
-    .orbit-bullets button.is-active {
-      background-color: #8a8a8a; }
-
-.pagination {
-  margin-left: 0;
-  margin-bottom: 1rem; }
-  .pagination::before, .pagination::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .pagination::after {
-    clear: both; }
-  .pagination li {
-    margin-right: 0.0625rem;
-    border-radius: 0;
-    font-size: 0.875rem;
-    display: none; }
-    .pagination li:last-child, .pagination li:first-child {
-      display: inline-block; }
-    @media print, screen and (min-width: 40em) {
-      .pagination li {
-        display: inline-block; } }
-  .pagination a,
-  .pagination button {
-    display: block;
-    padding: 0.1875rem 0.625rem;
-    border-radius: 0;
-    color: #0a0a0a; }
-    .pagination a:hover,
-    .pagination button:hover {
-      background: #e6e6e6; }
-  .pagination .current {
-    padding: 0.1875rem 0.625rem;
-    background: #1779ba;
-    color: #fefefe;
-    cursor: default; }
-  .pagination .disabled {
-    padding: 0.1875rem 0.625rem;
-    color: #cacaca;
-    cursor: not-allowed; }
-    .pagination .disabled:hover {
-      background: transparent; }
-  .pagination .ellipsis::after {
-    padding: 0.1875rem 0.625rem;
-    content: '\2026';
-    color: #0a0a0a; }
-
-.pagination-previous a::before,
-.pagination-previous.disabled::before {
-  display: inline-block;
-  margin-right: 0.5rem;
-  content: '\00ab'; }
-
-.pagination-next a::after,
-.pagination-next.disabled::after {
   display: inline-block;
-  margin-left: 0.5rem;
-  content: '\00bb'; }
-
-.progress {
-  height: 1rem;
-  margin-bottom: 1rem;
-  border-radius: 0;
-  background-color: #cacaca; }
-  .progress.primary .progress-meter {
-    background-color: #1779ba; }
-  .progress.secondary .progress-meter {
-    background-color: #767676; }
-  .progress.success .progress-meter {
-    background-color: #3adb76; }
-  .progress.warning .progress-meter {
-    background-color: #ffae00; }
-  .progress.alert .progress-meter {
-    background-color: #cc4b37; }
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
+  cursor: pointer; }
+  .menu-icon::after {
+    position: absolute;
+    top: 0;
+    left: 0;
+    display: block;
+    width: 100%;
+    height: 2px;
+    background: #fefefe;
+    -webkit-box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+            box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;
+    content: ''; }
+  .menu-icon:hover::after {
+    background: #cacaca;
+    -webkit-box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca;
+            box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }
 
-.progress-meter {
+.menu-icon.dark {
   position: relative;
-  display: block;
-  width: 0%;
-  height: 100%;
-  background-color: #1779ba; }
+  display: inline-block;
+  vertical-align: middle;
+  width: 20px;
+  height: 16px;
+  cursor: pointer; }
+  .menu-icon.dark::after {
+    position: absolute;
+    top: 0;
+    left: 0;
+    display: block;
+    width: 100%;
+    height: 2px;
+    background: #0a0a0a;
+    -webkit-box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
+            box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;
+    content: ''; }
+  .menu-icon.dark:hover::after {
+    background: #8a8a8a;
+    -webkit-box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a;
+            box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }
 
-.progress-meter-text {
-  position: absolute;
-  top: 50%;
-  left: 50%;
-  -webkit-transform: translate(-50%, -50%);
-      -ms-transform: translate(-50%, -50%);
-          transform: translate(-50%, -50%);
-  position: absolute;
-  margin: 0;
-  font-size: 0.75rem;
-  font-weight: bold;
-  color: #fefefe;
-  white-space: nowrap; }
+.accordion-menu li {
+  width: 100%; }
 
-.slider {
-  position: relative;
-  height: 0.5rem;
-  margin-top: 1.25rem;
-  margin-bottom: 2.25rem;
-  background-color: #e6e6e6;
-  cursor: pointer;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none;
-  -ms-touch-action: none;
-      touch-action: none; }
+.accordion-menu a {
+  padding: 0.7rem 1rem; }
 
-.slider-fill {
-  position: absolute;
-  top: 0;
-  left: 0;
-  display: inline-block;
-  max-width: 100%;
-  height: 0.5rem;
-  background-color: #cacaca;
-  -webkit-transition: all 0.2s ease-in-out;
-  transition: all 0.2s ease-in-out; }
-  .slider-fill.is-dragging {
-    -webkit-transition: all 0s linear;
-    transition: all 0s linear; }
+.accordion-menu .is-accordion-submenu a {
+  padding: 0.7rem 1rem; }
 
-.slider-handle {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%);
-  left: 0;
-  z-index: 1;
-  display: inline-block;
-  width: 1.4rem;
-  height: 1.4rem;
-  border-radius: 0;
-  background-color: #1779ba;
-  -webkit-transition: all 0.2s ease-in-out;
-  transition: all 0.2s ease-in-out;
-  -ms-touch-action: manipulation;
-      touch-action: manipulation; }
-  [data-whatinput='mouse'] .slider-handle {
-    outline: 0; }
-  .slider-handle:hover {
-    background-color: #14679e; }
-  .slider-handle.is-dragging {
-    -webkit-transition: all 0s linear;
-    transition: all 0s linear; }
+.accordion-menu .nested.is-accordion-submenu {
+  margin-right: 0;
+  margin-left: 1rem; }
 
-.slider.disabled,
-.slider[disabled] {
-  opacity: 0.25;
-  cursor: not-allowed; }
+.accordion-menu.align-right .nested.is-accordion-submenu {
+  margin-right: 1rem;
+  margin-left: 0; }
 
-.slider.vertical {
-  display: inline-block;
-  width: 0.5rem;
-  height: 12.5rem;
-  margin: 0 1.25rem;
-  -webkit-transform: scale(1, -1);
-      -ms-transform: scale(1, -1);
-          transform: scale(1, -1); }
-  .slider.vertical .slider-fill {
-    top: 0;
-    width: 0.5rem;
-    max-height: 100%; }
-  .slider.vertical .slider-handle {
+.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {
+  position: relative; }
+  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
     position: absolute;
-    top: 0;
-    left: 50%;
-    width: 1.4rem;
-    height: 1.4rem;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
+    top: 50%;
+    margin-top: -3px;
+    right: 1rem; }
 
-.sticky-container {
+.accordion-menu.align-left .is-accordion-submenu-parent > a::after {
+  right: 1rem;
+  left: auto; }
+
+.accordion-menu.align-right .is-accordion-submenu-parent > a::after {
+  right: auto;
+  left: 1rem; }
+
+.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {
+  -webkit-transform: rotate(180deg);
+      -ms-transform: rotate(180deg);
+          transform: rotate(180deg);
+  -webkit-transform-origin: 50% 50%;
+      -ms-transform-origin: 50% 50%;
+          transform-origin: 50% 50%; }
+
+.is-accordion-submenu-parent {
   position: relative; }
 
-.sticky {
-  position: relative;
-  z-index: 0;
-  -webkit-transform: translate3d(0, 0, 0);
-          transform: translate3d(0, 0, 0); }
+.has-submenu-toggle > a {
+  margin-right: 40px; }
 
-.sticky.is-stuck {
-  position: fixed;
-  z-index: 5;
-  width: 100%; }
-  .sticky.is-stuck.is-at-top {
-    top: 0; }
-  .sticky.is-stuck.is-at-bottom {
-    bottom: 0; }
+.submenu-toggle {
+  position: absolute;
+  top: 0;
+  right: 0;
+  width: 40px;
+  height: 40px;
+  cursor: pointer; }
+  .submenu-toggle::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    top: 0;
+    bottom: 0;
+    margin: auto; }
 
-.sticky.is-anchored {
-  position: relative;
-  right: auto;
-  left: auto; }
-  .sticky.is-anchored.is-at-bottom {
-    bottom: 0; }
+.submenu-toggle[aria-expanded='true']::after {
+  -webkit-transform: scaleY(-1);
+      -ms-transform: scaleY(-1);
+          transform: scaleY(-1);
+  -webkit-transform-origin: 50% 50%;
+      -ms-transform-origin: 50% 50%;
+          transform-origin: 50% 50%; }
+
+.submenu-toggle-text {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  padding: 0;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
+  white-space: nowrap;
+  border: 0; }
 
-body.is-reveal-open {
+.is-drilldown {
+  position: relative;
   overflow: hidden; }
+  .is-drilldown li {
+    display: block; }
+  .is-drilldown.animate-height {
+    -webkit-transition: height 0.5s;
+    transition: height 0.5s; }
 
-html.is-reveal-open,
-html.is-reveal-open body {
-  min-height: 100%;
-  overflow: hidden;
-  position: fixed;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none; }
+.drilldown a {
+  padding: 0.7rem 1rem;
+  background: #fefefe; }
 
-.reveal-overlay {
-  position: fixed;
+.drilldown .is-drilldown-submenu {
+  position: absolute;
   top: 0;
-  right: 0;
-  bottom: 0;
-  left: 0;
-  z-index: 1005;
-  display: none;
-  background-color: rgba(10, 10, 10, 0.45);
-  overflow-y: scroll; }
+  left: 100%;
+  z-index: -1;
+  width: 100%;
+  background: #fefefe;
+  -webkit-transition: -webkit-transform 0.15s linear;
+  transition: -webkit-transform 0.15s linear;
+  transition: transform 0.15s linear;
+  transition: transform 0.15s linear, -webkit-transform 0.15s linear; }
+  .drilldown .is-drilldown-submenu.is-active {
+    z-index: 1;
+    display: block;
+    -webkit-transform: translateX(-100%);
+        -ms-transform: translateX(-100%);
+            transform: translateX(-100%); }
+  .drilldown .is-drilldown-submenu.is-closing {
+    -webkit-transform: translateX(100%);
+        -ms-transform: translateX(100%);
+            transform: translateX(100%); }
+  .drilldown .is-drilldown-submenu a {
+    padding: 0.7rem 1rem; }
 
-.reveal {
-  z-index: 1006;
-  -webkit-backface-visibility: hidden;
-          backface-visibility: hidden;
-  display: none;
-  padding: 1rem;
-  border: 1px solid #cacaca;
-  border-radius: 0;
-  background-color: #fefefe;
-  position: relative;
-  top: 100px;
-  margin-right: auto;
-  margin-left: auto;
-  overflow-y: auto; }
-  [data-whatinput='mouse'] .reveal {
-    outline: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal {
-      min-height: 0; } }
-  .reveal .column {
-    min-width: 0; }
-  .reveal > :last-child {
-    margin-bottom: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal {
-      width: 600px;
-      max-width: 75rem; } }
-  .reveal.collapse {
-    padding: 0; }
-  @media print, screen and (min-width: 40em) {
-    .reveal.tiny {
-      width: 30%;
-      max-width: 75rem; } }
-  @media print, screen and (min-width: 40em) {
-    .reveal.small {
-      width: 50%;
-      max-width: 75rem; } }
-  @media print, screen and (min-width: 40em) {
-    .reveal.large {
-      width: 90%;
-      max-width: 75rem; } }
-  .reveal.full {
-    top: 0;
-    left: 0;
-    width: 100%;
-    max-width: none;
-    height: 100%;
-    height: 100vh;
-    min-height: 100vh;
-    margin-left: 0;
-    border: 0;
-    border-radius: 0; }
-  @media screen and (max-width: 39.9375em) {
-    .reveal {
-      top: 0;
-      left: 0;
-      width: 100%;
-      max-width: none;
-      height: 100%;
-      height: 100vh;
-      min-height: 100vh;
-      margin-left: 0;
-      border: 0;
-      border-radius: 0; } }
-  .reveal.without-overlay {
-    position: fixed; }
+.drilldown .nested.is-drilldown-submenu {
+  margin-right: 0;
+  margin-left: 0; }
+
+.drilldown .drilldown-submenu-cover-previous {
+  min-height: 100%; }
+
+.drilldown .is-drilldown-submenu-parent > a {
+  position: relative; }
+  .drilldown .is-drilldown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba;
+    position: absolute;
+    top: 50%;
+    margin-top: -6px;
+    right: 1rem; }
+
+.drilldown.align-left .is-drilldown-submenu-parent > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba;
+  right: 1rem;
+  left: auto; }
+
+.drilldown.align-right .is-drilldown-submenu-parent > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  right: auto;
+  left: 1rem; }
 
-.switch {
-  height: 2rem;
-  position: relative;
-  margin-bottom: 1rem;
-  outline: 0;
-  font-size: 0.875rem;
-  font-weight: bold;
-  color: #fefefe;
-  -webkit-user-select: none;
-     -moz-user-select: none;
-      -ms-user-select: none;
-          user-select: none; }
+.drilldown .js-drilldown-back > a::before {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  display: inline-block;
+  vertical-align: middle;
+  margin-right: 0.75rem; }
 
-.switch-input {
-  position: absolute;
-  margin-bottom: 0;
-  opacity: 0; }
+.dropdown.menu > li.opens-left > .is-dropdown-submenu {
+  top: 100%;
+  right: 0;
+  left: auto; }
 
-.switch-paddle {
+.dropdown.menu > li.opens-right > .is-dropdown-submenu {
+  top: 100%;
+  right: auto;
+  left: 0; }
+
+.dropdown.menu > li.is-dropdown-submenu-parent > a {
   position: relative;
+  padding-right: 1.5rem; }
+
+.dropdown.menu > li.is-dropdown-submenu-parent > a::after {
   display: block;
-  width: 4rem;
-  height: 2rem;
-  border-radius: 0;
-  background: #cacaca;
-  -webkit-transition: all 0.25s ease-out;
-  transition: all 0.25s ease-out;
-  font-weight: inherit;
-  color: inherit;
-  cursor: pointer; }
-  input + .switch-paddle {
-    margin: 0; }
-  .switch-paddle::after {
-    position: absolute;
-    top: 0.25rem;
-    left: 0.25rem;
-    display: block;
-    width: 1.5rem;
-    height: 1.5rem;
-    -webkit-transform: translate3d(0, 0, 0);
-            transform: translate3d(0, 0, 0);
-    border-radius: 0;
-    background: #fefefe;
-    -webkit-transition: all 0.25s ease-out;
-    transition: all 0.25s ease-out;
-    content: ''; }
-  input:checked ~ .switch-paddle {
-    background: #1779ba; }
-    input:checked ~ .switch-paddle::after {
-      left: 2.25rem; }
-  [data-whatinput='mouse'] input:focus ~ .switch-paddle {
-    outline: 0; }
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-bottom-width: 0;
+  border-top-style: solid;
+  border-color: #1779ba transparent transparent;
+  right: 5px;
+  left: auto;
+  margin-top: -3px; }
 
-.switch-active, .switch-inactive {
-  position: absolute;
-  top: 50%;
-  -webkit-transform: translateY(-50%);
-      -ms-transform: translateY(-50%);
-          transform: translateY(-50%); }
+[data-whatinput='mouse'] .dropdown.menu a {
+  outline: 0; }
 
-.switch-active {
-  left: 8%;
+.dropdown.menu > li > a {
+  padding: 0.7rem 1rem; }
+
+.dropdown.menu > li.is-active > a {
+  background: transparent;
+  color: #1779ba; }
+
+.no-js .dropdown.menu ul {
   display: none; }
-  input:checked + label > .switch-active {
-    display: block; }
 
-.switch-inactive {
-  right: 15%; }
-  input:checked + label > .switch-inactive {
-    display: none; }
+.dropdown.menu .nested.is-dropdown-submenu {
+  margin-right: 0;
+  margin-left: 0; }
 
-.switch.tiny {
-  height: 1.5rem; }
-  .switch.tiny .switch-paddle {
-    width: 3rem;
-    height: 1.5rem;
-    font-size: 0.625rem; }
-  .switch.tiny .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 1rem;
-    height: 1rem; }
-  .switch.tiny input:checked ~ .switch-paddle::after {
-    left: 1.75rem; }
+.dropdown.menu.vertical > li .is-dropdown-submenu {
+  top: 0; }
+
+.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {
+  top: 0;
+  right: 100%;
+  left: auto; }
+
+.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {
+  right: auto;
+  left: 100%; }
+
+.dropdown.menu.vertical > li > a::after {
+  right: 14px; }
+
+.dropdown.menu.vertical > li.opens-left > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-left-width: 0;
+  border-right-style: solid;
+  border-color: transparent #1779ba transparent transparent;
+  right: auto;
+  left: 5px; }
+
+.dropdown.menu.vertical > li.opens-right > a::after {
+  display: block;
+  width: 0;
+  height: 0;
+  border: inset 6px;
+  content: '';
+  border-right-width: 0;
+  border-left-style: solid;
+  border-color: transparent transparent transparent #1779ba; }
+
+@media print, screen and (min-width: 40em) {
+  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {
+    top: 100%;
+    right: 0;
+    left: auto; }
+  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {
+    top: 100%;
+    right: auto;
+    left: 0; }
+  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {
+    position: relative;
+    padding-right: 1.5rem; }
+  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    right: 5px;
+    left: auto;
+    margin-top: -3px; }
+  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {
+    top: 0; }
+  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {
+    top: 0;
+    right: 100%;
+    left: auto; }
+  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
+  .dropdown.menu.medium-vertical > li > a::after {
+    right: 14px; }
+  .dropdown.menu.medium-vertical > li.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .dropdown.menu.medium-vertical > li.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; } }
+
+@media print, screen and (min-width: 64em) {
+  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {
+    top: 100%;
+    right: 0;
+    left: auto; }
+  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {
+    top: 100%;
+    right: auto;
+    left: 0; }
+  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {
+    position: relative;
+    padding-right: 1.5rem; }
+  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-bottom-width: 0;
+    border-top-style: solid;
+    border-color: #1779ba transparent transparent;
+    right: 5px;
+    left: auto;
+    margin-top: -3px; }
+  .dropdown.menu.large-vertical > li .is-dropdown-submenu {
+    top: 0; }
+  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {
+    top: 0;
+    right: 100%;
+    left: auto; }
+  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
+  .dropdown.menu.large-vertical > li > a::after {
+    right: 14px; }
+  .dropdown.menu.large-vertical > li.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .dropdown.menu.large-vertical > li.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; } }
 
-.switch.small {
-  height: 1.75rem; }
-  .switch.small .switch-paddle {
-    width: 3.5rem;
-    height: 1.75rem;
-    font-size: 0.75rem; }
-  .switch.small .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 1.25rem;
-    height: 1.25rem; }
-  .switch.small input:checked ~ .switch-paddle::after {
-    left: 2rem; }
+.dropdown.menu.align-right .is-dropdown-submenu.first-sub {
+  top: 100%;
+  right: 0;
+  left: auto; }
 
-.switch.large {
-  height: 2.5rem; }
-  .switch.large .switch-paddle {
-    width: 5rem;
-    height: 2.5rem;
-    font-size: 1rem; }
-  .switch.large .switch-paddle::after {
-    top: 0.25rem;
-    left: 0.25rem;
-    width: 2rem;
-    height: 2rem; }
-  .switch.large input:checked ~ .switch-paddle::after {
-    left: 2.75rem; }
+.is-dropdown-menu.vertical {
+  width: 100px; }
+  .is-dropdown-menu.vertical.align-right {
+    float: right; }
 
-table {
-  border-collapse: collapse;
-  width: 100%;
-  margin-bottom: 1rem;
-  border-radius: 0; }
-  table thead,
-  table tbody,
-  table tfoot {
-    border: 1px solid #f1f1f1;
-    background-color: #fefefe; }
-  table caption {
-    padding: 0.5rem 0.625rem 0.625rem;
-    font-weight: bold; }
-  table thead {
-    background: #f8f8f8;
-    color: #0a0a0a; }
-  table tfoot {
-    background: #f1f1f1;
-    color: #0a0a0a; }
-  table thead tr,
-  table tfoot tr {
-    background: transparent; }
-  table thead th,
-  table thead td,
-  table tfoot th,
-  table tfoot td {
-    padding: 0.5rem 0.625rem 0.625rem;
-    font-weight: bold;
-    text-align: left; }
-  table tbody th,
-  table tbody td {
-    padding: 0.5rem 0.625rem 0.625rem; }
-  table tbody tr:nth-child(even) {
-    border-bottom: 0;
-    background-color: #f1f1f1; }
-  table.unstriped tbody {
-    background-color: #fefefe; }
-    table.unstriped tbody tr {
-      border-bottom: 0;
-      border-bottom: 1px solid #f1f1f1;
-      background-color: #fefefe; }
+.is-dropdown-submenu-parent {
+  position: relative; }
+  .is-dropdown-submenu-parent a::after {
+    position: absolute;
+    top: 50%;
+    right: 5px;
+    left: auto;
+    margin-top: -6px; }
+  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {
+    top: 100%;
+    left: auto; }
+  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {
+    right: 100%;
+    left: auto; }
+  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {
+    right: auto;
+    left: 100%; }
 
-@media screen and (max-width: 63.9375em) {
-  table.stack thead {
-    display: none; }
-  table.stack tfoot {
-    display: none; }
-  table.stack tr,
-  table.stack th,
-  table.stack td {
+.is-dropdown-submenu {
+  position: absolute;
+  top: 0;
+  left: 100%;
+  z-index: 1;
+  display: none;
+  min-width: 200px;
+  border: 1px solid #cacaca;
+  background: #fefefe; }
+  .dropdown .is-dropdown-submenu a {
+    padding: 0.7rem 1rem; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {
+    right: 14px; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-left-width: 0;
+    border-right-style: solid;
+    border-color: transparent #1779ba transparent transparent;
+    right: auto;
+    left: 5px; }
+  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {
+    display: block;
+    width: 0;
+    height: 0;
+    border: inset 6px;
+    content: '';
+    border-right-width: 0;
+    border-left-style: solid;
+    border-color: transparent transparent transparent #1779ba; }
+  .is-dropdown-submenu .is-dropdown-submenu {
+    margin-top: -1px; }
+  .is-dropdown-submenu > li {
+    width: 100%; }
+  .is-dropdown-submenu.js-dropdown-active {
     display: block; }
-  table.stack td {
-    border-top: 0; } }
 
-table.scroll {
-  display: block;
+.is-off-canvas-open {
+  overflow: hidden; }
+
+.js-off-canvas-overlay {
+  position: absolute;
+  top: 0;
+  left: 0;
+  z-index: 11;
   width: 100%;
-  overflow-x: auto; }
+  height: 100%;
+  -webkit-transition: opacity 0.5s ease, visibility 0.5s ease;
+  transition: opacity 0.5s ease, visibility 0.5s ease;
+  background: rgba(254, 254, 254, 0.25);
+  opacity: 0;
+  visibility: hidden;
+  overflow: hidden; }
+  .js-off-canvas-overlay.is-visible {
+    opacity: 1;
+    visibility: visible; }
+  .js-off-canvas-overlay.is-closable {
+    cursor: pointer; }
+  .js-off-canvas-overlay.is-overlay-absolute {
+    position: absolute; }
+  .js-off-canvas-overlay.is-overlay-fixed {
+    position: fixed; }
 
-table.hover thead tr:hover {
-  background-color: #f3f3f3; }
+.off-canvas-wrapper {
+  position: relative;
+  overflow: hidden; }
 
-table.hover tfoot tr:hover {
-  background-color: #ececec; }
+.off-canvas {
+  position: fixed;
+  z-index: 12;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  background: #e6e6e6; }
+  [data-whatinput='mouse'] .off-canvas {
+    outline: 0; }
+  .off-canvas.is-transition-push {
+    z-index: 12; }
+  .off-canvas.is-closed {
+    visibility: hidden; }
+  .off-canvas.is-transition-overlap {
+    z-index: 13; }
+    .off-canvas.is-transition-overlap.is-open {
+      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
+              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
+  .off-canvas.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-table.hover tbody tr:hover {
-  background-color: #f9f9f9; }
+.off-canvas-absolute {
+  position: absolute;
+  z-index: 12;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  background: #e6e6e6; }
+  [data-whatinput='mouse'] .off-canvas-absolute {
+    outline: 0; }
+  .off-canvas-absolute.is-transition-push {
+    z-index: 12; }
+  .off-canvas-absolute.is-closed {
+    visibility: hidden; }
+  .off-canvas-absolute.is-transition-overlap {
+    z-index: 13; }
+    .off-canvas-absolute.is-transition-overlap.is-open {
+      -webkit-box-shadow: 0 0 10px rgba(10, 10, 10, 0.7);
+              box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }
+  .off-canvas-absolute.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-table.hover:not(.unstriped) tr:nth-of-type(even):hover {
-  background-color: #ececec; }
+.position-left {
+  top: 0;
+  left: 0;
+  height: 100%;
+  overflow-y: auto;
+  width: 250px;
+  -webkit-transform: translateX(-250px);
+      -ms-transform: translateX(-250px);
+          transform: translateX(-250px); }
+  .off-canvas-content .off-canvas.position-left {
+    -webkit-transform: translateX(-250px);
+        -ms-transform: translateX(-250px);
+            transform: translateX(-250px); }
+    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-left.has-transition-push {
+    -webkit-transform: translateX(250px);
+        -ms-transform: translateX(250px);
+            transform: translateX(250px); }
+  .position-left.is-transition-push {
+    -webkit-box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }
+
+.position-right {
+  top: 0;
+  right: 0;
+  height: 100%;
+  overflow-y: auto;
+  width: 250px;
+  -webkit-transform: translateX(250px);
+      -ms-transform: translateX(250px);
+          transform: translateX(250px); }
+  .off-canvas-content .off-canvas.position-right {
+    -webkit-transform: translateX(250px);
+        -ms-transform: translateX(250px);
+            transform: translateX(250px); }
+    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-right.has-transition-push {
+    -webkit-transform: translateX(-250px);
+        -ms-transform: translateX(-250px);
+            transform: translateX(-250px); }
+  .position-right.is-transition-push {
+    -webkit-box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }
 
-.table-scroll {
-  overflow-x: auto; }
-  .table-scroll table {
-    width: auto; }
+.position-top {
+  top: 0;
+  left: 0;
+  width: 100%;
+  overflow-x: auto;
+  height: 250px;
+  -webkit-transform: translateY(-250px);
+      -ms-transform: translateY(-250px);
+          transform: translateY(-250px); }
+  .off-canvas-content .off-canvas.position-top {
+    -webkit-transform: translateY(-250px);
+        -ms-transform: translateY(-250px);
+            transform: translateY(-250px); }
+    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-top.has-transition-push {
+    -webkit-transform: translateY(250px);
+        -ms-transform: translateY(250px);
+            transform: translateY(250px); }
+  .position-top.is-transition-push {
+    -webkit-box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }
 
-.tabs {
-  margin: 0;
-  border: 1px solid #e6e6e6;
-  background: #fefefe;
-  list-style-type: none; }
-  .tabs::before, .tabs::after {
-    display: table;
-    content: ' ';
-    -webkit-flex-basis: 0;
-        -ms-flex-preferred-size: 0;
-            flex-basis: 0;
-    -webkit-box-ordinal-group: 2;
-    -webkit-order: 1;
-        -ms-flex-order: 1;
-            order: 1; }
-  .tabs::after {
-    clear: both; }
+.position-bottom {
+  bottom: 0;
+  left: 0;
+  width: 100%;
+  overflow-x: auto;
+  height: 250px;
+  -webkit-transform: translateY(250px);
+      -ms-transform: translateY(250px);
+          transform: translateY(250px); }
+  .off-canvas-content .off-canvas.position-bottom {
+    -webkit-transform: translateY(250px);
+        -ms-transform: translateY(250px);
+            transform: translateY(250px); }
+    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {
+      -webkit-transform: translate(0, 0);
+          -ms-transform: translate(0, 0);
+              transform: translate(0, 0); }
+  .off-canvas-content.is-open-bottom.has-transition-push {
+    -webkit-transform: translateY(-250px);
+        -ms-transform: translateY(-250px);
+            transform: translateY(-250px); }
+  .position-bottom.is-transition-push {
+    -webkit-box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25);
+            box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }
 
-.tabs.vertical > li {
-  display: block;
-  float: none;
-  width: auto; }
+.off-canvas-content {
+  -webkit-transform: none;
+      -ms-transform: none;
+          transform: none;
+  -webkit-transition: -webkit-transform 0.5s ease;
+  transition: -webkit-transform 0.5s ease;
+  transition: transform 0.5s ease;
+  transition: transform 0.5s ease, -webkit-transform 0.5s ease;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden; }
+  .off-canvas-content.has-transition-push {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
+  .off-canvas-content .off-canvas.is-open {
+    -webkit-transform: translate(0, 0);
+        -ms-transform: translate(0, 0);
+            transform: translate(0, 0); }
 
-.tabs.simple > li > a {
-  padding: 0; }
-  .tabs.simple > li > a:hover {
-    background: transparent; }
+@media print, screen and (min-width: 40em) {
+  .position-left.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-left.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-left.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-left {
+      margin-left: 250px; }
+    .position-left.reveal-for-medium ~ .off-canvas-content {
+      margin-left: 250px; }
+  .position-right.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-right.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-right.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-right {
+      margin-right: 250px; }
+    .position-right.reveal-for-medium ~ .off-canvas-content {
+      margin-right: 250px; }
+  .position-top.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-top.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-top.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-top {
+      margin-top: 250px; }
+    .position-top.reveal-for-medium ~ .off-canvas-content {
+      margin-top: 250px; }
+  .position-bottom.reveal-for-medium {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-bottom.reveal-for-medium .close-button {
+      display: none; }
+    .off-canvas-content .position-bottom.reveal-for-medium {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-bottom {
+      margin-bottom: 250px; }
+    .position-bottom.reveal-for-medium ~ .off-canvas-content {
+      margin-bottom: 250px; } }
 
-.tabs.primary {
-  background: #1779ba; }
-  .tabs.primary > li > a {
-    color: #fefefe; }
-    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {
-      background: #1673b1; }
+@media print, screen and (min-width: 64em) {
+  .position-left.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-left.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-left.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-left {
+      margin-left: 250px; }
+    .position-left.reveal-for-large ~ .off-canvas-content {
+      margin-left: 250px; }
+  .position-right.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-right.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-right.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-right {
+      margin-right: 250px; }
+    .position-right.reveal-for-large ~ .off-canvas-content {
+      margin-right: 250px; }
+  .position-top.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-top.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-top.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-top {
+      margin-top: 250px; }
+    .position-top.reveal-for-large ~ .off-canvas-content {
+      margin-top: 250px; }
+  .position-bottom.reveal-for-large {
+    -webkit-transform: none;
+        -ms-transform: none;
+            transform: none;
+    z-index: 12;
+    -webkit-transition: none;
+    transition: none;
+    visibility: visible; }
+    .position-bottom.reveal-for-large .close-button {
+      display: none; }
+    .off-canvas-content .position-bottom.reveal-for-large {
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas-content.has-reveal-bottom {
+      margin-bottom: 250px; }
+    .position-bottom.reveal-for-large ~ .off-canvas-content {
+      margin-bottom: 250px; } }
 
-.tabs-title {
-  float: left; }
-  .tabs-title > a {
-    display: block;
-    padding: 1.25rem 1.5rem;
-    font-size: 0.75rem;
-    line-height: 1;
-    color: #1779ba; }
-    .tabs-title > a:hover {
-      background: #fefefe;
-      color: #1468a0; }
-    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {
-      background: #e6e6e6;
-      color: #1779ba; }
+@media print, screen and (min-width: 40em) {
+  .off-canvas.in-canvas-for-medium {
+    visibility: visible;
+    height: auto;
+    position: static;
+    background: none;
+    width: auto;
+    overflow: visible;
+    -webkit-transition: none;
+    transition: none; }
+    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {
+      -webkit-box-shadow: none;
+              box-shadow: none;
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas.in-canvas-for-medium .close-button {
+      display: none; } }
 
-.tabs-content {
-  border: 1px solid #e6e6e6;
-  border-top: 0;
-  background: #fefefe;
-  color: #0a0a0a;
-  -webkit-transition: all 0.5s ease;
-  transition: all 0.5s ease; }
+@media print, screen and (min-width: 64em) {
+  .off-canvas.in-canvas-for-large {
+    visibility: visible;
+    height: auto;
+    position: static;
+    background: none;
+    width: auto;
+    overflow: visible;
+    -webkit-transition: none;
+    transition: none; }
+    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {
+      -webkit-box-shadow: none;
+              box-shadow: none;
+      -webkit-transform: none;
+          -ms-transform: none;
+              transform: none; }
+    .off-canvas.in-canvas-for-large .close-button {
+      display: none; } }
 
-.tabs-content.vertical {
-  border: 1px solid #e6e6e6;
-  border-left: 0; }
+html.is-reveal-open {
+  position: fixed;
+  width: 100%;
+  overflow-y: hidden; }
+  html.is-reveal-open.zf-has-scroll {
+    overflow-y: scroll; }
+  html.is-reveal-open body {
+    overflow-y: hidden; }
 
-.tabs-panel {
+.reveal-overlay {
+  position: fixed;
+  top: 0;
+  right: 0;
+  bottom: 0;
+  left: 0;
+  z-index: 1005;
   display: none;
-  padding: 1rem; }
-  .tabs-panel.is-active {
-    display: block; }
+  background-color: rgba(10, 10, 10, 0.45);
+  overflow-y: auto; }
 
-.thumbnail {
-  display: inline-block;
-  max-width: 100%;
-  margin-bottom: 1rem;
-  border: solid 4px #fefefe;
+.reveal {
+  z-index: 1006;
+  -webkit-backface-visibility: hidden;
+          backface-visibility: hidden;
+  display: none;
+  padding: 1rem;
+  border: 1px solid #cacaca;
   border-radius: 0;
-  -webkit-box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-          box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);
-  line-height: 0; }
-
-a.thumbnail {
-  -webkit-transition: -webkit-box-shadow 200ms ease-out;
-  transition: -webkit-box-shadow 200ms ease-out;
-  transition: box-shadow 200ms ease-out;
-  transition: box-shadow 200ms ease-out, -webkit-box-shadow 200ms ease-out; }
-  a.thumbnail:hover, a.thumbnail:focus {
-    -webkit-box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5);
-            box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }
-  a.thumbnail image {
-    -webkit-box-shadow: none;
-            box-shadow: none; }
-
-.title-bar {
-  padding: 0.5rem;
-  background: #0a0a0a;
-  color: #fefefe;
-  display: -webkit-box;
-  display: -webkit-flex;
-  display: -ms-flexbox;
-  display: flex;
-  -webkit-box-pack: start;
-  -webkit-justify-content: flex-start;
-      -ms-flex-pack: start;
-          justify-content: flex-start;
-  -webkit-box-align: center;
-  -webkit-align-items: center;
-      -ms-flex-align: center;
-          align-items: center; }
-  .title-bar .menu-icon {
-    margin-left: 0.25rem;
-    margin-right: 0.25rem; }
-
-.title-bar-left,
-.title-bar-right {
-  -webkit-box-flex: 1;
-  -webkit-flex: 1 1 0px;
-      -ms-flex: 1 1 0px;
-          flex: 1 1 0px; }
-
-.title-bar-right {
-  text-align: right; }
-
-.title-bar-title {
-  display: inline-block;
-  vertical-align: middle;
-  font-weight: bold; }
-
-.has-tip {
+  background-color: #fefefe;
   position: relative;
-  display: inline-block;
-  border-bottom: dotted 1px #8a8a8a;
-  font-weight: bold;
-  cursor: help; }
-
-.tooltip {
-  position: absolute;
-  top: calc(100% + 0.6495rem);
-  z-index: 1200;
-  max-width: 10rem;
-  padding: 0.75rem;
-  border-radius: 0;
-  background-color: #0a0a0a;
-  font-size: 80%;
-  color: #fefefe; }
-  .tooltip::before {
-    position: absolute; }
-  .tooltip.bottom::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-top-width: 0;
-    border-bottom-style: solid;
-    border-color: transparent transparent #0a0a0a;
-    bottom: 100%; }
-  .tooltip.bottom.align-center::before {
-    left: 50%;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
-  .tooltip.top::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-bottom-width: 0;
-    border-top-style: solid;
-    border-color: #0a0a0a transparent transparent;
-    top: 100%;
-    bottom: auto; }
-  .tooltip.top.align-center::before {
-    left: 50%;
-    -webkit-transform: translateX(-50%);
-        -ms-transform: translateX(-50%);
-            transform: translateX(-50%); }
-  .tooltip.left::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-right-width: 0;
-    border-left-style: solid;
-    border-color: transparent transparent transparent #0a0a0a;
-    left: 100%; }
-  .tooltip.left.align-center::before {
-    bottom: auto;
-    top: 50%;
-    -webkit-transform: translateY(-50%);
-        -ms-transform: translateY(-50%);
-            transform: translateY(-50%); }
-  .tooltip.right::before {
-    display: block;
-    width: 0;
-    height: 0;
-    border: inset 0.75rem;
-    content: '';
-    border-left-width: 0;
-    border-right-style: solid;
-    border-color: transparent #0a0a0a transparent transparent;
-    right: 100%;
-    left: auto; }
-  .tooltip.right.align-center::before {
-    bottom: auto;
-    top: 50%;
-    -webkit-transform: translateY(-50%);
-        -ms-transform: translateY(-50%);
-            transform: translateY(-50%); }
-  .tooltip.align-top::before {
-    bottom: auto;
-    top: 10%; }
-  .tooltip.align-bottom::before {
-    bottom: 10%;
-    top: auto; }
-  .tooltip.align-left::before {
-    left: 10%;
-    right: auto; }
-  .tooltip.align-right::before {
-    left: auto;
-    right: 10%; }
+  top: 100px;
+  margin-right: auto;
+  margin-left: auto;
+  overflow-y: auto; }
+  [data-whatinput='mouse'] .reveal {
+    outline: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal {
+      min-height: 0; } }
+  .reveal .column {
+    min-width: 0; }
+  .reveal > :last-child {
+    margin-bottom: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal {
+      width: 600px;
+      max-width: 75rem; } }
+  .reveal.collapse {
+    padding: 0; }
+  @media print, screen and (min-width: 40em) {
+    .reveal.tiny {
+      width: 30%;
+      max-width: 75rem; } }
+  @media print, screen and (min-width: 40em) {
+    .reveal.small {
+      width: 50%;
+      max-width: 75rem; } }
+  @media print, screen and (min-width: 40em) {
+    .reveal.large {
+      width: 90%;
+      max-width: 75rem; } }
+  .reveal.full {
+    top: 0;
+    right: 0;
+    bottom: 0;
+    left: 0;
+    width: 100%;
+    max-width: none;
+    height: 100%;
+    min-height: 100%;
+    margin-left: 0;
+    border: 0;
+    border-radius: 0; }
+  @media screen and (max-width: 39.99875em) {
+    .reveal {
+      top: 0;
+      right: 0;
+      bottom: 0;
+      left: 0;
+      width: 100%;
+      max-width: none;
+      height: 100%;
+      min-height: 100%;
+      margin-left: 0;
+      border: 0;
+      border-radius: 0; } }
+  .reveal.without-overlay {
+    position: fixed; }
+
+.sticky-container {
+  position: relative; }
+
+.sticky {
+  position: relative;
+  z-index: 0;
+  -webkit-transform: translate3d(0, 0, 0);
+          transform: translate3d(0, 0, 0); }
+
+.sticky.is-stuck {
+  position: fixed;
+  z-index: 5;
+  width: 100%; }
+  .sticky.is-stuck.is-at-top {
+    top: 0; }
+  .sticky.is-stuck.is-at-bottom {
+    bottom: 0; }
+
+.sticky.is-anchored {
+  position: relative;
+  right: auto;
+  left: auto; }
+  .sticky.is-anchored.is-at-bottom {
+    bottom: 0; }
+
+.title-bar {
+  padding: 0.5rem;
+  background: #0a0a0a;
+  color: #fefefe;
+  display: -webkit-box;
+  display: -webkit-flex;
+  display: -ms-flexbox;
+  display: flex;
+  -webkit-box-pack: start;
+  -webkit-justify-content: flex-start;
+      -ms-flex-pack: start;
+          justify-content: flex-start;
+  -webkit-box-align: center;
+  -webkit-align-items: center;
+      -ms-flex-align: center;
+          align-items: center; }
+  .title-bar .menu-icon {
+    margin-left: 0.25rem;
+    margin-right: 0.25rem; }
+
+.title-bar-left,
+.title-bar-right {
+  -webkit-box-flex: 1;
+  -webkit-flex: 1 1 0px;
+      -ms-flex: 1 1 0px;
+          flex: 1 1 0px; }
+
+.title-bar-right {
+  text-align: right; }
+
+.title-bar-title {
+  display: inline-block;
+  vertical-align: middle;
+  font-weight: bold; }
 
 .top-bar {
   display: -webkit-box;
@@ -5312,7 +5072,7 @@ a.thumbnail {
             -ms-flex: 0 1 auto;
                 flex: 0 1 auto;
         margin-left: auto; } }
-  @media screen and (max-width: 63.9375em) {
+  @media screen and (max-width: 63.99875em) {
     .top-bar.stacked-for-medium {
       -webkit-flex-wrap: wrap;
           -ms-flex-wrap: wrap;
@@ -5324,7 +5084,7 @@ a.thumbnail {
             -ms-flex: 0 0 100%;
                 flex: 0 0 100%;
         max-width: 100%; } }
-  @media screen and (max-width: 74.9375em) {
+  @media screen and (max-width: 74.99875em) {
     .top-bar.stacked-for-large {
       -webkit-flex-wrap: wrap;
           -ms-flex-wrap: wrap;
@@ -5351,99 +5111,6 @@ a.thumbnail {
       -ms-flex: 0 0 auto;
           flex: 0 0 auto; }
 
-.hide {
-  display: none !important; }
-
-.invisible {
-  visibility: hidden; }
-
-@media screen and (max-width: 39.9375em) {
-  .hide-for-small-only {
-    display: none !important; } }
-
-@media screen and (max-width: 0em), screen and (min-width: 40em) {
-  .show-for-small-only {
-    display: none !important; } }
-
-@media print, screen and (min-width: 40em) {
-  .hide-for-medium {
-    display: none !important; } }
-
-@media screen and (max-width: 39.9375em) {
-  .show-for-medium {
-    display: none !important; } }
-
-@media screen and (min-width: 40em) and (max-width: 63.9375em) {
-  .hide-for-medium-only {
-    display: none !important; } }
-
-@media screen and (max-width: 39.9375em), screen and (min-width: 64em) {
-  .show-for-medium-only {
-    display: none !important; } }
-
-@media print, screen and (min-width: 64em) {
-  .hide-for-large {
-    display: none !important; } }
-
-@media screen and (max-width: 63.9375em) {
-  .show-for-large {
-    display: none !important; } }
-
-@media screen and (min-width: 64em) and (max-width: 74.9375em) {
-  .hide-for-large-only {
-    display: none !important; } }
-
-@media screen and (max-width: 63.9375em), screen and (min-width: 75em) {
-  .show-for-large-only {
-    display: none !important; } }
-
-.show-for-sr,
-.show-on-focus {
-  position: absolute !important;
-  width: 1px;
-  height: 1px;
-  padding: 0;
-  overflow: hidden;
-  clip: rect(0, 0, 0, 0);
-  white-space: nowrap;
-  -webkit-clip-path: inset(50%);
-          clip-path: inset(50%);
-  border: 0; }
-
-.show-on-focus:active, .show-on-focus:focus {
-  position: static !important;
-  width: auto;
-  height: auto;
-  overflow: visible;
-  clip: auto;
-  white-space: normal;
-  -webkit-clip-path: none;
-          clip-path: none; }
-
-.show-for-landscape,
-.hide-for-portrait {
-  display: block !important; }
-  @media screen and (orientation: landscape) {
-    .show-for-landscape,
-    .hide-for-portrait {
-      display: block !important; } }
-  @media screen and (orientation: portrait) {
-    .show-for-landscape,
-    .hide-for-portrait {
-      display: none !important; } }
-
-.hide-for-landscape,
-.show-for-portrait {
-  display: none !important; }
-  @media screen and (orientation: landscape) {
-    .hide-for-landscape,
-    .show-for-portrait {
-      display: none !important; } }
-  @media screen and (orientation: portrait) {
-    .hide-for-landscape,
-    .show-for-portrait {
-      display: block !important; } }
-
 .float-left {
   float: left !important; }
 
@@ -5469,6 +5136,12 @@ a.thumbnail {
 .clearfix::after {
   clear: both; }
 
+.align-left {
+  -webkit-box-pack: start;
+  -webkit-justify-content: flex-start;
+      -ms-flex-pack: start;
+          justify-content: flex-start; }
+
 .align-right {
   -webkit-box-pack: end;
   -webkit-justify-content: flex-end;
@@ -5492,6 +5165,12 @@ a.thumbnail {
       -ms-flex-pack: distribute;
           justify-content: space-around; }
 
+.align-left.vertical.menu > li > a {
+  -webkit-box-pack: start;
+  -webkit-justify-content: flex-start;
+      -ms-flex-pack: start;
+          justify-content: flex-start; }
+
 .align-right.vertical.menu > li > a {
   -webkit-box-pack: end;
   -webkit-justify-content: flex-end;
@@ -5535,7 +5214,6 @@ a.thumbnail {
 .align-self-middle {
   -webkit-align-self: center;
       -ms-flex-item-align: center;
-              -ms-grid-row-align: center;
           align-self: center; }
 
 .align-stretch {
@@ -5547,7 +5225,6 @@ a.thumbnail {
 .align-self-stretch {
   -webkit-align-self: stretch;
       -ms-flex-item-align: stretch;
-              -ms-grid-row-align: stretch;
           align-self: stretch; }
 
 .align-center-middle {
@@ -5807,4 +5484,93 @@ a.thumbnail {
         -ms-flex-direction: column-reverse;
             flex-direction: column-reverse; } }
 
+.hide {
+  display: none !important; }
+
+.invisible {
+  visibility: hidden; }
+
+@media screen and (max-width: 39.99875em) {
+  .hide-for-small-only {
+    display: none !important; } }
+
+@media screen and (max-width: 0em), screen and (min-width: 40em) {
+  .show-for-small-only {
+    display: none !important; } }
+
+@media print, screen and (min-width: 40em) {
+  .hide-for-medium {
+    display: none !important; } }
+
+@media screen and (max-width: 39.99875em) {
+  .show-for-medium {
+    display: none !important; } }
+
+@media screen and (min-width: 40em) and (max-width: 63.99875em) {
+  .hide-for-medium-only {
+    display: none !important; } }
+
+@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {
+  .show-for-medium-only {
+    display: none !important; } }
+
+@media print, screen and (min-width: 64em) {
+  .hide-for-large {
+    display: none !important; } }
+
+@media screen and (max-width: 63.99875em) {
+  .show-for-large {
+    display: none !important; } }
+
+@media screen and (min-width: 64em) and (max-width: 74.99875em) {
+  .hide-for-large-only {
+    display: none !important; } }
+
+@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {
+  .show-for-large-only {
+    display: none !important; } }
+
+.show-for-sr,
+.show-on-focus {
+  position: absolute !important;
+  width: 1px;
+  height: 1px;
+  padding: 0;
+  overflow: hidden;
+  clip: rect(0, 0, 0, 0);
+  white-space: nowrap;
+  border: 0; }
+
+.show-on-focus:active, .show-on-focus:focus {
+  position: static !important;
+  width: auto;
+  height: auto;
+  overflow: visible;
+  clip: auto;
+  white-space: normal; }
+
+.show-for-landscape,
+.hide-for-portrait {
+  display: block !important; }
+  @media screen and (orientation: landscape) {
+    .show-for-landscape,
+    .hide-for-portrait {
+      display: block !important; } }
+  @media screen and (orientation: portrait) {
+    .show-for-landscape,
+    .hide-for-portrait {
+      display: none !important; } }
+
+.hide-for-landscape,
+.show-for-portrait {
+  display: none !important; }
+  @media screen and (orientation: landscape) {
+    .hide-for-landscape,
+    .show-for-portrait {
+      display: none !important; } }
+  @media screen and (orientation: portrait) {
+    .hide-for-landscape,
+    .show-for-portrait {
+      display: block !important; } }
+
 /*# sourceMappingURL=foundation.css.map */
diff --git a/dist/css/foundation.css.map b/dist/css/foundation.css.map
new file mode 100644 (file)
index 0000000..7f44ac1
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.css","../scss/foundation.scss","../scss/util/_breakpoint.scss","../scss/components/_reveal.scss","../scss/vendor/normalize.scss","../scss/_global.scss","../scss/util/_unit.scss","../scss/util/_mixins.scss","../scss/forms/_text.scss","../scss/forms/_checkbox.scss","../scss/forms/_label.scss","../scss/forms/_help-text.scss","../scss/forms/_input-group.scss","../scss/forms/_fieldset.scss","../scss/forms/_select.scss","../scss/forms/_error.scss","../scss/typography/_base.scss","../scss/typography/_helpers.scss","../scss/typography/_alignment.scss","../scss/typography/_print.scss","../scss/xy-grid/_classes.scss","../scss/xy-grid/_gutters.scss","../scss/xy-grid/_grid.scss","../scss/xy-grid/_cell.scss","../scss/xy-grid/_layout.scss","../scss/xy-grid/_collapse.scss","../scss/xy-grid/_position.scss","../scss/xy-grid/_frame.scss","../scss/components/_button.scss","../scss/components/_button-group.scss","../scss/components/_close-button.scss","../scss/components/_label.scss","../scss/components/_progress-bar.scss","../scss/forms/_progress.scss","../scss/components/_slider.scss","../scss/forms/_range.scss","../scss/components/_switch.scss","../scss/components/_table.scss","../scss/util/_color.scss","../scss/components/_badge.scss","../scss/components/_breadcrumbs.scss","../scss/components/_callout.scss","../scss/components/_card.scss","../scss/components/_dropdown.scss","../scss/components/_pagination.scss","../scss/components/_tooltip.scss","../scss/components/_accordion.scss","../scss/components/_media-object.scss","../scss/components/_orbit.scss","../scss/components/_responsive-embed.scss","../scss/util/_math.scss","../scss/components/_tabs.scss","../scss/components/_thumbnail.scss","../scss/components/_menu.scss","../scss/components/_menu-icon.scss","../scss/components/_accordion-menu.scss","../scss/components/_drilldown.scss","../scss/components/_dropdown-menu.scss","../scss/components/_off-canvas.scss","../scss/components/_sticky.scss","../scss/components/_title-bar.scss","../scss/components/_top-bar.scss","../scss/components/_float.scss","../scss/components/_flex.scss","../scss/util/_flex.scss","../scss/components/_visibility.scss"],"names":[],"mappings":"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,EAAA;;ArB6ElD;EsBxIJ;ID4DE,WADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,YADoD,EAAA,ECzDrD;;AtBsIG;EsBxIJ;ID4DE,WADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,UADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,gBADoD,EAAA;EC3DtD;ID4DE,YADoD,EAAA,ECzDrD;;AAFD;ED4DE,2BADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,0BADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,gCADgH,EAAA;;AC3DlH;ED4DE,4BADgH,EAAA;;ArB6E9G;EsBxIJ;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,6BADgH,EAAA;EC3DlH;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,6BADgH,EAAA,ECzDjH;;AtBsIG;EsBxIJ;ID4DE,4BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,2BADgH,EAAA;EC3DlH;ID4DE,iCADg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A;;ANoO3B;EMpOF,uCAA6B,EAAA;;ANgO3B;EMhOF,gBAA6B,EAAA;;ANoO3B;EMpOF,iCAA6B,EAAA;;ANgO3B;EMhOF,sBAA6B,EAAA;;ANoO3B;EMpOF,uCAA6B,EAAA;;ANgO3B;EMhOF,sBAA6B,EAAA;;ANoO3B;EMpOF,uCAA6B,EAAA;;ANgO3B;EMhOF,gBAA6B,EAAA;;ANoO3B;EMpOF,iCAA6B,EAAA;;ANgO3B;EMhOF,sBAA6B,EAAA;;ANoO3B;EMpOF,uCAA6B,EAAA;;ANgO3B;EMhOF,sBAA6B,EAAA;;ANoO3B;EMpOF,uCAA6B,EAAA;;AxByI3B;EkBuFA;IMhOF,eAA6B,EAAA;ENoO3B;IMpOF,iCAA6B,EAAA;ENgO3B;IMhOF,qBAA6B,EAAA;ENoO3B;IMpOF,uCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA,ENsO1B;;AlB7FD;EkBuFA;IMhOF,eAA6B,EAAA;ENoO3B;IMpOF,iCAA6B,EAAA;ENgO3B;IMhOF,qBAA6B,EAAA;ENoO3B;IMpOF,uCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,wCAA6B,EAAA;ENgO3B;IMhOF,gBAA6B,EAAA;ENoO3B;IMpOF,kCAA6B,EAAA;ENgO3B;IMhOF,sBAA6B,EAAA;ENoO3B;IMpOF,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AA,ED6G1D;EArCP;IG/BE,YAAmB,EAAA;EHmCrB;IG/BE,YAAmB,EAAA;EHuCnB;IGnCA,gCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,2BADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,iCADgH,EAAA;EHoChH;IGnCA,4BADgH,EAAA;ErB6E9G;IkBrDJ;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,6BADgH,EAAA;IHwBlH;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,6BADgH,EAAA,EHsC/G;ElBuCC;IkBrDJ;MG/BE,YAAmB,EAAA;IHmCrB;MG/BE,YAAmB,EAAA;IHuCnB;MGnCA,iCADgH,EAAA;IHoChH;MGnCA,kCADgH,EAAA;IHoChH;MGnCA,4BADgH,EAAA;IH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DkB;MAyDlB,wBAzDkB;UAyDlB,oBAzDkB,EAAA;;AD6EhB;ECpCF,yBAxCgB;EAwChB,2BAxCgB;MAwChB,sBAxCgB;UAwChB,mBAxCgB,EAAA;;ADgFd;ECxBF,0BAxDgB;MAwDhB,2BAxDgB;UAwDhB,kBAxDgB,EAAA;;AD4Ed;ECpCF,0BAvCkB;EAuClB,4BAvCkB;MAuClB,uBAvCkB;UAuClB,oBAvCkB,EAAA;;AD+EhB;ECxBF,2BAvDkB;MAuDlB,4BAvDkB;UAuDlB,mBAvDkB,EAAA;;ADqFlB;EC/CA,wBAnDkB;EAmDlB,+BAnDkB;MAmDlB,qBAnDkB;UAmDlB,uBAnDkB;EAoDlB,yBAxCgB;EAwChB,2BAxCgB;MAwChB,sBAxCgB;UAwChB,mBAxCgB;EDwFd,6BAAqB;MAArB,0BAAqB;UAArB,qBAAqB,EAAA;;AAMnB;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;AACZ;EChCJ,4BD+BgB;EC/BhB,gBD+BgB;MC/BhB,iBD+BgB;UC/BhB,QD+BgB,EAAA;;A7DyDZ;E6DxDA;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/BhB,iBD+BgB;YC/BhB,QD+BgB,EAAA;EACZ;IChCJ,4BD+BgB;IC/BhB,gBD+BgB;QC/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","file":"foundation.css","sourcesContent":["@charset \"UTF-8\";\n/**\n * Foundation for Sites by ZURB\n * Version 6.5.3\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n@media print, screen and (min-width: 40em) {\n  .reveal, .reveal.tiny, .reveal.small, .reveal.large {\n    right: auto;\n    left: auto;\n    margin: 0 auto; } }\n\n/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\nhtml {\n  line-height: 1.15;\n  -webkit-text-size-adjust: 100%; }\n\nbody {\n  margin: 0; }\n\nh1 {\n  font-size: 2em;\n  margin: 0.67em 0; }\n\nhr {\n  box-sizing: content-box;\n  height: 0;\n  overflow: visible; }\n\npre {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\na {\n  background-color: transparent; }\n\nabbr[title] {\n  border-bottom: none;\n  text-decoration: underline;\n  text-decoration: underline dotted; }\n\nb,\nstrong {\n  font-weight: bolder; }\n\ncode,\nkbd,\nsamp {\n  font-family: monospace, monospace;\n  font-size: 1em; }\n\nsmall {\n  font-size: 80%; }\n\nsub,\nsup {\n  font-size: 75%;\n  line-height: 0;\n  position: relative;\n  vertical-align: baseline; }\n\nsub {\n  bottom: -0.25em; }\n\nsup {\n  top: -0.5em; }\n\nimg {\n  border-style: none; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit;\n  font-size: 100%;\n  line-height: 1.15;\n  margin: 0; }\n\nbutton,\ninput {\n  overflow: visible; }\n\nbutton,\nselect {\n  text-transform: none; }\n\nbutton,\n[type=\"button\"],\n[type=\"reset\"],\n[type=\"submit\"] {\n  -webkit-appearance: button; }\n\nbutton::-moz-focus-inner,\n[type=\"button\"]::-moz-focus-inner,\n[type=\"reset\"]::-moz-focus-inner,\n[type=\"submit\"]::-moz-focus-inner {\n  border-style: none;\n  padding: 0; }\n\nbutton:-moz-focusring,\n[type=\"button\"]:-moz-focusring,\n[type=\"reset\"]:-moz-focusring,\n[type=\"submit\"]:-moz-focusring {\n  outline: 1px dotted ButtonText; }\n\nfieldset {\n  padding: 0.35em 0.75em 0.625em; }\n\nlegend {\n  box-sizing: border-box;\n  color: inherit;\n  display: table;\n  max-width: 100%;\n  padding: 0;\n  white-space: normal; }\n\nprogress {\n  vertical-align: baseline; }\n\ntextarea {\n  overflow: auto; }\n\n[type=\"checkbox\"],\n[type=\"radio\"] {\n  box-sizing: border-box;\n  padding: 0; }\n\n[type=\"number\"]::-webkit-inner-spin-button,\n[type=\"number\"]::-webkit-outer-spin-button {\n  height: auto; }\n\n[type=\"search\"] {\n  -webkit-appearance: textfield;\n  outline-offset: -2px; }\n\n[type=\"search\"]::-webkit-search-decoration {\n  -webkit-appearance: none; }\n\n::-webkit-file-upload-button {\n  -webkit-appearance: button;\n  font: inherit; }\n\ndetails {\n  display: block; }\n\nsummary {\n  display: list-item; }\n\ntemplate {\n  display: none; }\n\n[hidden] {\n  display: none; }\n\n.foundation-mq {\n  font-family: \"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em\"; }\n\nhtml {\n  box-sizing: border-box;\n  font-size: 100%; }\n\n*,\n*::before,\n*::after {\n  box-sizing: inherit; }\n\nbody {\n  margin: 0;\n  padding: 0;\n  background: #fefefe;\n  font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  -webkit-font-smoothing: antialiased;\n  -moz-osx-font-smoothing: grayscale; }\n\nimg {\n  display: inline-block;\n  vertical-align: middle;\n  max-width: 100%;\n  height: auto;\n  -ms-interpolation-mode: bicubic; }\n\ntextarea {\n  height: auto;\n  min-height: 50px;\n  border-radius: 0; }\n\nselect {\n  box-sizing: border-box;\n  width: 100%;\n  border-radius: 0; }\n\n.map_canvas img,\n.map_canvas embed,\n.map_canvas object,\n.mqa-display img,\n.mqa-display embed,\n.mqa-display object {\n  max-width: none !important; }\n\nbutton {\n  padding: 0;\n  appearance: none;\n  border: 0;\n  border-radius: 0;\n  background: transparent;\n  line-height: 1;\n  cursor: auto; }\n  [data-whatinput='mouse'] button {\n    outline: 0; }\n\npre {\n  overflow: auto; }\n\nbutton,\ninput,\noptgroup,\nselect,\ntextarea {\n  font-family: inherit; }\n\n.is-visible {\n  display: block !important; }\n\n.is-hidden {\n  display: none !important; }\n\n[type='text'], [type='password'], [type='date'], [type='datetime'], [type='datetime-local'], [type='month'], [type='week'], [type='email'], [type='number'], [type='search'], [type='tel'], [type='time'], [type='url'], [type='color'],\ntextarea {\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  box-shadow: inset 0 1px 2px rgba(10, 10, 10, 0.1);\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out;\n  appearance: none; }\n  [type='text']:focus, [type='password']:focus, [type='date']:focus, [type='datetime']:focus, [type='datetime-local']:focus, [type='month']:focus, [type='week']:focus, [type='email']:focus, [type='number']:focus, [type='search']:focus, [type='tel']:focus, [type='time']:focus, [type='url']:focus, [type='color']:focus,\n  textarea:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n\ntextarea {\n  max-width: 100%; }\n  textarea[rows] {\n    height: auto; }\n\ninput:disabled, input[readonly],\ntextarea:disabled,\ntextarea[readonly] {\n  background-color: #e6e6e6;\n  cursor: not-allowed; }\n\n[type='submit'],\n[type='button'] {\n  appearance: none;\n  border-radius: 0; }\n\ninput[type='search'] {\n  box-sizing: border-box; }\n\n::placeholder {\n  color: #cacaca; }\n\n[type='file'],\n[type='checkbox'],\n[type='radio'] {\n  margin: 0 0 1rem; }\n\n[type='checkbox'] + label,\n[type='radio'] + label {\n  display: inline-block;\n  vertical-align: baseline;\n  margin-left: 0.5rem;\n  margin-right: 1rem;\n  margin-bottom: 0; }\n  [type='checkbox'] + label[for],\n  [type='radio'] + label[for] {\n    cursor: pointer; }\n\nlabel > [type='checkbox'],\nlabel > [type='radio'] {\n  margin-right: 0.5rem; }\n\n[type='file'] {\n  width: 100%; }\n\nlabel {\n  display: block;\n  margin: 0;\n  font-size: 0.875rem;\n  font-weight: normal;\n  line-height: 1.8;\n  color: #0a0a0a; }\n  label.middle {\n    margin: 0 0 1rem;\n    padding: 0.5625rem 0; }\n\n.help-text {\n  margin-top: -0.5rem;\n  font-size: 0.8125rem;\n  font-style: italic;\n  color: #0a0a0a; }\n\n.input-group {\n  display: flex;\n  width: 100%;\n  margin-bottom: 1rem;\n  align-items: stretch; }\n  .input-group > :first-child, .input-group > :first-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n  .input-group > :last-child, .input-group > :last-child.input-group-button > * {\n    border-radius: 0 0 0 0; }\n\n.input-group-label, .input-group-field, .input-group-button, .input-group-button a,\n.input-group-button input,\n.input-group-button button,\n.input-group-button label {\n  margin: 0;\n  white-space: nowrap; }\n\n.input-group-label {\n  padding: 0 1rem;\n  border: 1px solid #cacaca;\n  background: #e6e6e6;\n  color: #0a0a0a;\n  text-align: center;\n  white-space: nowrap;\n  display: flex;\n  flex: 0 0 auto;\n  align-items: center; }\n  .input-group-label:first-child {\n    border-right: 0; }\n  .input-group-label:last-child {\n    border-left: 0; }\n\n.input-group-field {\n  border-radius: 0;\n  flex: 1 1 0px;\n  min-width: 0; }\n\n.input-group-button {\n  padding-top: 0;\n  padding-bottom: 0;\n  text-align: center;\n  display: flex;\n  flex: 0 0 auto; }\n  .input-group-button a,\n  .input-group-button input,\n  .input-group-button button,\n  .input-group-button label {\n    align-self: stretch;\n    height: auto;\n    padding-top: 0;\n    padding-bottom: 0;\n    font-size: 1rem; }\n\nfieldset {\n  margin: 0;\n  padding: 0;\n  border: 0; }\n\nlegend {\n  max-width: 100%;\n  margin-bottom: 0.5rem; }\n\n.fieldset {\n  margin: 1.125rem 0;\n  padding: 1.25rem;\n  border: 1px solid #cacaca; }\n  .fieldset legend {\n    margin: 0;\n    margin-left: -0.1875rem;\n    padding: 0 0.1875rem; }\n\nselect {\n  height: 2.4375rem;\n  margin: 0 0 1rem;\n  padding: 0.5rem;\n  appearance: none;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-family: inherit;\n  font-size: 1rem;\n  font-weight: normal;\n  line-height: 1.5;\n  color: #0a0a0a;\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>\");\n  background-origin: content-box;\n  background-position: right -1rem center;\n  background-repeat: no-repeat;\n  background-size: 9px 6px;\n  padding-right: 1.5rem;\n  transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  @media screen and (min-width: 0\\0) {\n    select {\n      background-image: url(\"data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==\"); } }\n  select:focus {\n    outline: none;\n    border: 1px solid #8a8a8a;\n    background-color: #fefefe;\n    box-shadow: 0 0 5px #cacaca;\n    transition: box-shadow 0.5s, border-color 0.25s ease-in-out; }\n  select:disabled {\n    background-color: #e6e6e6;\n    cursor: not-allowed; }\n  select::-ms-expand {\n    display: none; }\n  select[multiple] {\n    height: auto;\n    background-image: none; }\n\n.is-invalid-input:not(:focus) {\n  border-color: #cc4b37;\n  background-color: #f9ecea; }\n  .is-invalid-input:not(:focus)::placeholder {\n    color: #cc4b37; }\n\n.is-invalid-label {\n  color: #cc4b37; }\n\n.form-error {\n  display: none;\n  margin-top: -0.5rem;\n  margin-bottom: 1rem;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #cc4b37; }\n  .form-error.is-visible {\n    display: block; }\n\ndiv,\ndl,\ndt,\ndd,\nul,\nol,\nli,\nh1,\nh2,\nh3,\nh4,\nh5,\nh6,\npre,\nform,\np,\nblockquote,\nth,\ntd {\n  margin: 0;\n  padding: 0; }\n\np {\n  margin-bottom: 1rem;\n  font-size: inherit;\n  line-height: 1.6;\n  text-rendering: optimizeLegibility; }\n\nem,\ni {\n  font-style: italic;\n  line-height: inherit; }\n\nstrong,\nb {\n  font-weight: bold;\n  line-height: inherit; }\n\nsmall {\n  font-size: 80%;\n  line-height: inherit; }\n\nh1, .h1,\nh2, .h2,\nh3, .h3,\nh4, .h4,\nh5, .h5,\nh6, .h6 {\n  font-family: \"Helvetica Neue\", Helvetica, Roboto, Arial, sans-serif;\n  font-style: normal;\n  font-weight: normal;\n  color: inherit;\n  text-rendering: optimizeLegibility; }\n  h1 small, .h1 small,\n  h2 small, .h2 small,\n  h3 small, .h3 small,\n  h4 small, .h4 small,\n  h5 small, .h5 small,\n  h6 small, .h6 small {\n    line-height: 0;\n    color: #cacaca; }\n\nh1, .h1 {\n  font-size: 1.5rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh2, .h2 {\n  font-size: 1.25rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh3, .h3 {\n  font-size: 1.1875rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh4, .h4 {\n  font-size: 1.125rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh5, .h5 {\n  font-size: 1.0625rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\nh6, .h6 {\n  font-size: 1rem;\n  line-height: 1.4;\n  margin-top: 0;\n  margin-bottom: 0.5rem; }\n\n@media print, screen and (min-width: 40em) {\n  h1, .h1 {\n    font-size: 3rem; }\n  h2, .h2 {\n    font-size: 2.5rem; }\n  h3, .h3 {\n    font-size: 1.9375rem; }\n  h4, .h4 {\n    font-size: 1.5625rem; }\n  h5, .h5 {\n    font-size: 1.25rem; }\n  h6, .h6 {\n    font-size: 1rem; } }\n\na {\n  line-height: inherit;\n  color: #1779ba;\n  text-decoration: none;\n  cursor: pointer; }\n  a:hover, a:focus {\n    color: #1468a0; }\n  a img {\n    border: 0; }\n\nhr {\n  clear: both;\n  max-width: 75rem;\n  height: 0;\n  margin: 1.25rem auto;\n  border-top: 0;\n  border-right: 0;\n  border-bottom: 1px solid #cacaca;\n  border-left: 0; }\n\nul,\nol,\ndl {\n  margin-bottom: 1rem;\n  list-style-position: outside;\n  line-height: 1.6; }\n\nli {\n  font-size: inherit; }\n\nul {\n  margin-left: 1.25rem;\n  list-style-type: disc; }\n\nol {\n  margin-left: 1.25rem; }\n\nul ul, ol ul, ul ol, ol ol {\n  margin-left: 1.25rem;\n  margin-bottom: 0; }\n\ndl {\n  margin-bottom: 1rem; }\n  dl dt {\n    margin-bottom: 0.3rem;\n    font-weight: bold; }\n\nblockquote {\n  margin: 0 0 1rem;\n  padding: 0.5625rem 1.25rem 0 1.1875rem;\n  border-left: 1px solid #cacaca; }\n  blockquote, blockquote p {\n    line-height: 1.6;\n    color: #8a8a8a; }\n\ncite {\n  display: block;\n  font-size: 0.8125rem;\n  color: #8a8a8a; }\n  cite:before {\n    content: \"— \"; }\n\nabbr, abbr[title] {\n  border-bottom: 1px dotted #0a0a0a;\n  cursor: help;\n  text-decoration: none; }\n\nfigure {\n  margin: 0; }\n\ncode {\n  padding: 0.125rem 0.3125rem 0.0625rem;\n  border: 1px solid #cacaca;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  font-weight: normal;\n  color: #0a0a0a; }\n\nkbd {\n  margin: 0;\n  padding: 0.125rem 0.25rem 0;\n  background-color: #e6e6e6;\n  font-family: Consolas, \"Liberation Mono\", Courier, monospace;\n  color: #0a0a0a; }\n\n.subheader {\n  margin-top: 0.2rem;\n  margin-bottom: 0.5rem;\n  font-weight: normal;\n  line-height: 1.4;\n  color: #8a8a8a; }\n\n.lead {\n  font-size: 125%;\n  line-height: 1.6; }\n\n.stat {\n  font-size: 2.5rem;\n  line-height: 1; }\n  p + .stat {\n    margin-top: -1rem; }\n\nul.no-bullet, ol.no-bullet {\n  margin-left: 0;\n  list-style: none; }\n\n.text-left {\n  text-align: left; }\n\n.text-right {\n  text-align: right; }\n\n.text-center {\n  text-align: center; }\n\n.text-justify {\n  text-align: justify; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-text-left {\n    text-align: left; }\n  .medium-text-right {\n    text-align: right; }\n  .medium-text-center {\n    text-align: center; }\n  .medium-text-justify {\n    text-align: justify; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-text-left {\n    text-align: left; }\n  .large-text-right {\n    text-align: right; }\n  .large-text-center {\n    text-align: center; }\n  .large-text-justify {\n    text-align: justify; } }\n\n.show-for-print {\n  display: none !important; }\n\n@media print {\n  * {\n    background: transparent !important;\n    box-shadow: none !important;\n    color: black !important;\n    text-shadow: none !important; }\n  .show-for-print {\n    display: block !important; }\n  .hide-for-print {\n    display: none !important; }\n  table.show-for-print {\n    display: table !important; }\n  thead.show-for-print {\n    display: table-header-group !important; }\n  tbody.show-for-print {\n    display: table-row-group !important; }\n  tr.show-for-print {\n    display: table-row !important; }\n  td.show-for-print {\n    display: table-cell !important; }\n  th.show-for-print {\n    display: table-cell !important; }\n  a,\n  a:visited {\n    text-decoration: underline; }\n  a[href]:after {\n    content: \" (\" attr(href) \")\"; }\n  .ir a:after,\n  a[href^='javascript:']:after,\n  a[href^='#']:after {\n    content: ''; }\n  abbr[title]:after {\n    content: \" (\" attr(title) \")\"; }\n  pre,\n  blockquote {\n    border: 1px solid #8a8a8a;\n    page-break-inside: avoid; }\n  thead {\n    display: table-header-group; }\n  tr,\n  img {\n    page-break-inside: avoid; }\n  img {\n    max-width: 100% !important; }\n  @page {\n    margin: 0.5cm; }\n  p,\n  h2,\n  h3 {\n    orphans: 3;\n    widows: 3; }\n  h2,\n  h3 {\n    page-break-after: avoid; }\n  .print-break-inside {\n    page-break-inside: auto; } }\n\n.grid-container {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem;\n  max-width: 75rem;\n  margin-left: auto;\n  margin-right: auto; }\n  @media print, screen and (min-width: 40em) {\n    .grid-container {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n  .grid-container.fluid {\n    padding-right: 0.625rem;\n    padding-left: 0.625rem;\n    max-width: 100%;\n    margin-left: auto;\n    margin-right: auto; }\n    @media print, screen and (min-width: 40em) {\n      .grid-container.fluid {\n        padding-right: 0.9375rem;\n        padding-left: 0.9375rem; } }\n  .grid-container.full {\n    padding-right: 0;\n    padding-left: 0;\n    max-width: 100%;\n    margin-left: auto;\n    margin-right: auto; }\n\n.grid-x {\n  display: flex;\n  flex-flow: row wrap; }\n\n.cell {\n  flex: 0 0 auto;\n  min-height: 0px;\n  min-width: 0px;\n  width: 100%; }\n  .cell.auto {\n    flex: 1 1 0px; }\n  .cell.shrink {\n    flex: 0 0 auto; }\n\n.grid-x > .auto {\n  width: auto; }\n\n.grid-x > .shrink {\n  width: auto; }\n\n.grid-x > .small-shrink, .grid-x > .small-full, .grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {\n  flex-basis: auto; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-x > .medium-shrink, .grid-x > .medium-full, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {\n    flex-basis: auto; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-x > .large-shrink, .grid-x > .large-full, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {\n    flex-basis: auto; } }\n\n.grid-x > .small-1, .grid-x > .small-2, .grid-x > .small-3, .grid-x > .small-4, .grid-x > .small-5, .grid-x > .small-6, .grid-x > .small-7, .grid-x > .small-8, .grid-x > .small-9, .grid-x > .small-10, .grid-x > .small-11, .grid-x > .small-12 {\n  flex: 0 0 auto; }\n\n.grid-x > .small-1 {\n  width: 8.33333%; }\n\n.grid-x > .small-2 {\n  width: 16.66667%; }\n\n.grid-x > .small-3 {\n  width: 25%; }\n\n.grid-x > .small-4 {\n  width: 33.33333%; }\n\n.grid-x > .small-5 {\n  width: 41.66667%; }\n\n.grid-x > .small-6 {\n  width: 50%; }\n\n.grid-x > .small-7 {\n  width: 58.33333%; }\n\n.grid-x > .small-8 {\n  width: 66.66667%; }\n\n.grid-x > .small-9 {\n  width: 75%; }\n\n.grid-x > .small-10 {\n  width: 83.33333%; }\n\n.grid-x > .small-11 {\n  width: 91.66667%; }\n\n.grid-x > .small-12 {\n  width: 100%; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-x > .medium-auto {\n    flex: 1 1 0px;\n    width: auto; }\n  .grid-x > .medium-shrink, .grid-x > .medium-1, .grid-x > .medium-2, .grid-x > .medium-3, .grid-x > .medium-4, .grid-x > .medium-5, .grid-x > .medium-6, .grid-x > .medium-7, .grid-x > .medium-8, .grid-x > .medium-9, .grid-x > .medium-10, .grid-x > .medium-11, .grid-x > .medium-12 {\n    flex: 0 0 auto; }\n  .grid-x > .medium-shrink {\n    width: auto; }\n  .grid-x > .medium-1 {\n    width: 8.33333%; }\n  .grid-x > .medium-2 {\n    width: 16.66667%; }\n  .grid-x > .medium-3 {\n    width: 25%; }\n  .grid-x > .medium-4 {\n    width: 33.33333%; }\n  .grid-x > .medium-5 {\n    width: 41.66667%; }\n  .grid-x > .medium-6 {\n    width: 50%; }\n  .grid-x > .medium-7 {\n    width: 58.33333%; }\n  .grid-x > .medium-8 {\n    width: 66.66667%; }\n  .grid-x > .medium-9 {\n    width: 75%; }\n  .grid-x > .medium-10 {\n    width: 83.33333%; }\n  .grid-x > .medium-11 {\n    width: 91.66667%; }\n  .grid-x > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-x > .large-auto {\n    flex: 1 1 0px;\n    width: auto; }\n  .grid-x > .large-shrink, .grid-x > .large-1, .grid-x > .large-2, .grid-x > .large-3, .grid-x > .large-4, .grid-x > .large-5, .grid-x > .large-6, .grid-x > .large-7, .grid-x > .large-8, .grid-x > .large-9, .grid-x > .large-10, .grid-x > .large-11, .grid-x > .large-12 {\n    flex: 0 0 auto; }\n  .grid-x > .large-shrink {\n    width: auto; }\n  .grid-x > .large-1 {\n    width: 8.33333%; }\n  .grid-x > .large-2 {\n    width: 16.66667%; }\n  .grid-x > .large-3 {\n    width: 25%; }\n  .grid-x > .large-4 {\n    width: 33.33333%; }\n  .grid-x > .large-5 {\n    width: 41.66667%; }\n  .grid-x > .large-6 {\n    width: 50%; }\n  .grid-x > .large-7 {\n    width: 58.33333%; }\n  .grid-x > .large-8 {\n    width: 66.66667%; }\n  .grid-x > .large-9 {\n    width: 75%; }\n  .grid-x > .large-10 {\n    width: 83.33333%; }\n  .grid-x > .large-11 {\n    width: 91.66667%; }\n  .grid-x > .large-12 {\n    width: 100%; } }\n\n.grid-margin-x:not(.grid-x) > .cell {\n  width: auto; }\n\n.grid-margin-y:not(.grid-y) > .cell {\n  height: auto; }\n\n.grid-margin-x {\n  margin-left: -0.625rem;\n  margin-right: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x {\n      margin-left: -0.9375rem;\n      margin-right: -0.9375rem; } }\n  .grid-margin-x > .cell {\n    width: calc(100% - 1.25rem);\n    margin-left: 0.625rem;\n    margin-right: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x > .cell {\n      width: calc(100% - 1.875rem);\n      margin-left: 0.9375rem;\n      margin-right: 0.9375rem; } }\n  .grid-margin-x > .auto {\n    width: auto; }\n  .grid-margin-x > .shrink {\n    width: auto; }\n  .grid-margin-x > .small-1 {\n    width: calc(8.33333% - 1.25rem); }\n  .grid-margin-x > .small-2 {\n    width: calc(16.66667% - 1.25rem); }\n  .grid-margin-x > .small-3 {\n    width: calc(25% - 1.25rem); }\n  .grid-margin-x > .small-4 {\n    width: calc(33.33333% - 1.25rem); }\n  .grid-margin-x > .small-5 {\n    width: calc(41.66667% - 1.25rem); }\n  .grid-margin-x > .small-6 {\n    width: calc(50% - 1.25rem); }\n  .grid-margin-x > .small-7 {\n    width: calc(58.33333% - 1.25rem); }\n  .grid-margin-x > .small-8 {\n    width: calc(66.66667% - 1.25rem); }\n  .grid-margin-x > .small-9 {\n    width: calc(75% - 1.25rem); }\n  .grid-margin-x > .small-10 {\n    width: calc(83.33333% - 1.25rem); }\n  .grid-margin-x > .small-11 {\n    width: calc(91.66667% - 1.25rem); }\n  .grid-margin-x > .small-12 {\n    width: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-x > .auto {\n      width: auto; }\n    .grid-margin-x > .shrink {\n      width: auto; }\n    .grid-margin-x > .small-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .small-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .small-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .small-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .small-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .small-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .small-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .small-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .small-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .small-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .small-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .small-12 {\n      width: calc(100% - 1.875rem); }\n    .grid-margin-x > .medium-auto {\n      width: auto; }\n    .grid-margin-x > .medium-shrink {\n      width: auto; }\n    .grid-margin-x > .medium-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .medium-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .medium-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .medium-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .medium-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .medium-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .medium-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .medium-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .medium-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .medium-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .medium-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .medium-12 {\n      width: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-x > .large-auto {\n      width: auto; }\n    .grid-margin-x > .large-shrink {\n      width: auto; }\n    .grid-margin-x > .large-1 {\n      width: calc(8.33333% - 1.875rem); }\n    .grid-margin-x > .large-2 {\n      width: calc(16.66667% - 1.875rem); }\n    .grid-margin-x > .large-3 {\n      width: calc(25% - 1.875rem); }\n    .grid-margin-x > .large-4 {\n      width: calc(33.33333% - 1.875rem); }\n    .grid-margin-x > .large-5 {\n      width: calc(41.66667% - 1.875rem); }\n    .grid-margin-x > .large-6 {\n      width: calc(50% - 1.875rem); }\n    .grid-margin-x > .large-7 {\n      width: calc(58.33333% - 1.875rem); }\n    .grid-margin-x > .large-8 {\n      width: calc(66.66667% - 1.875rem); }\n    .grid-margin-x > .large-9 {\n      width: calc(75% - 1.875rem); }\n    .grid-margin-x > .large-10 {\n      width: calc(83.33333% - 1.875rem); }\n    .grid-margin-x > .large-11 {\n      width: calc(91.66667% - 1.875rem); }\n    .grid-margin-x > .large-12 {\n      width: calc(100% - 1.875rem); } }\n\n.grid-padding-x .grid-padding-x {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-x .grid-padding-x {\n      margin-right: -0.9375rem;\n      margin-left: -0.9375rem; } }\n\n.grid-container:not(.full) > .grid-padding-x {\n  margin-right: -0.625rem;\n  margin-left: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-container:not(.full) > .grid-padding-x {\n      margin-right: -0.9375rem;\n      margin-left: -0.9375rem; } }\n\n.grid-padding-x > .cell {\n  padding-right: 0.625rem;\n  padding-left: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-x > .cell {\n      padding-right: 0.9375rem;\n      padding-left: 0.9375rem; } }\n\n.small-up-1 > .cell {\n  width: 100%; }\n\n.small-up-2 > .cell {\n  width: 50%; }\n\n.small-up-3 > .cell {\n  width: 33.33333%; }\n\n.small-up-4 > .cell {\n  width: 25%; }\n\n.small-up-5 > .cell {\n  width: 20%; }\n\n.small-up-6 > .cell {\n  width: 16.66667%; }\n\n.small-up-7 > .cell {\n  width: 14.28571%; }\n\n.small-up-8 > .cell {\n  width: 12.5%; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-up-1 > .cell {\n    width: 100%; }\n  .medium-up-2 > .cell {\n    width: 50%; }\n  .medium-up-3 > .cell {\n    width: 33.33333%; }\n  .medium-up-4 > .cell {\n    width: 25%; }\n  .medium-up-5 > .cell {\n    width: 20%; }\n  .medium-up-6 > .cell {\n    width: 16.66667%; }\n  .medium-up-7 > .cell {\n    width: 14.28571%; }\n  .medium-up-8 > .cell {\n    width: 12.5%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-up-1 > .cell {\n    width: 100%; }\n  .large-up-2 > .cell {\n    width: 50%; }\n  .large-up-3 > .cell {\n    width: 33.33333%; }\n  .large-up-4 > .cell {\n    width: 25%; }\n  .large-up-5 > .cell {\n    width: 20%; }\n  .large-up-6 > .cell {\n    width: 16.66667%; }\n  .large-up-7 > .cell {\n    width: 14.28571%; }\n  .large-up-8 > .cell {\n    width: 12.5%; } }\n\n.grid-margin-x.small-up-1 > .cell {\n  width: calc(100% - 1.25rem); }\n\n.grid-margin-x.small-up-2 > .cell {\n  width: calc(50% - 1.25rem); }\n\n.grid-margin-x.small-up-3 > .cell {\n  width: calc(33.33333% - 1.25rem); }\n\n.grid-margin-x.small-up-4 > .cell {\n  width: calc(25% - 1.25rem); }\n\n.grid-margin-x.small-up-5 > .cell {\n  width: calc(20% - 1.25rem); }\n\n.grid-margin-x.small-up-6 > .cell {\n  width: calc(16.66667% - 1.25rem); }\n\n.grid-margin-x.small-up-7 > .cell {\n  width: calc(14.28571% - 1.25rem); }\n\n.grid-margin-x.small-up-8 > .cell {\n  width: calc(12.5% - 1.25rem); }\n\n@media print, screen and (min-width: 40em) {\n  .grid-margin-x.small-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.small-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.small-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.small-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.small-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.small-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.small-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.small-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); }\n  .grid-margin-x.medium-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.medium-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.medium-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.medium-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.medium-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.medium-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.medium-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.medium-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-margin-x.large-up-1 > .cell {\n    width: calc(100% - 1.875rem); }\n  .grid-margin-x.large-up-2 > .cell {\n    width: calc(50% - 1.875rem); }\n  .grid-margin-x.large-up-3 > .cell {\n    width: calc(33.33333% - 1.875rem); }\n  .grid-margin-x.large-up-4 > .cell {\n    width: calc(25% - 1.875rem); }\n  .grid-margin-x.large-up-5 > .cell {\n    width: calc(20% - 1.875rem); }\n  .grid-margin-x.large-up-6 > .cell {\n    width: calc(16.66667% - 1.875rem); }\n  .grid-margin-x.large-up-7 > .cell {\n    width: calc(14.28571% - 1.875rem); }\n  .grid-margin-x.large-up-8 > .cell {\n    width: calc(12.5% - 1.875rem); } }\n\n.small-margin-collapse {\n  margin-right: 0;\n  margin-left: 0; }\n  .small-margin-collapse > .cell {\n    margin-right: 0;\n    margin-left: 0; }\n  .small-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .small-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .small-margin-collapse > .small-3 {\n    width: 25%; }\n  .small-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .small-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .small-margin-collapse > .small-6 {\n    width: 50%; }\n  .small-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .small-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .small-margin-collapse > .small-9 {\n    width: 75%; }\n  .small-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .small-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .small-margin-collapse > .small-12 {\n    width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .small-margin-collapse > .medium-1 {\n      width: 8.33333%; }\n    .small-margin-collapse > .medium-2 {\n      width: 16.66667%; }\n    .small-margin-collapse > .medium-3 {\n      width: 25%; }\n    .small-margin-collapse > .medium-4 {\n      width: 33.33333%; }\n    .small-margin-collapse > .medium-5 {\n      width: 41.66667%; }\n    .small-margin-collapse > .medium-6 {\n      width: 50%; }\n    .small-margin-collapse > .medium-7 {\n      width: 58.33333%; }\n    .small-margin-collapse > .medium-8 {\n      width: 66.66667%; }\n    .small-margin-collapse > .medium-9 {\n      width: 75%; }\n    .small-margin-collapse > .medium-10 {\n      width: 83.33333%; }\n    .small-margin-collapse > .medium-11 {\n      width: 91.66667%; }\n    .small-margin-collapse > .medium-12 {\n      width: 100%; } }\n  @media print, screen and (min-width: 64em) {\n    .small-margin-collapse > .large-1 {\n      width: 8.33333%; }\n    .small-margin-collapse > .large-2 {\n      width: 16.66667%; }\n    .small-margin-collapse > .large-3 {\n      width: 25%; }\n    .small-margin-collapse > .large-4 {\n      width: 33.33333%; }\n    .small-margin-collapse > .large-5 {\n      width: 41.66667%; }\n    .small-margin-collapse > .large-6 {\n      width: 50%; }\n    .small-margin-collapse > .large-7 {\n      width: 58.33333%; }\n    .small-margin-collapse > .large-8 {\n      width: 66.66667%; }\n    .small-margin-collapse > .large-9 {\n      width: 75%; }\n    .small-margin-collapse > .large-10 {\n      width: 83.33333%; }\n    .small-margin-collapse > .large-11 {\n      width: 91.66667%; }\n    .small-margin-collapse > .large-12 {\n      width: 100%; } }\n\n.small-padding-collapse {\n  margin-right: 0;\n  margin-left: 0; }\n  .small-padding-collapse > .cell {\n    padding-right: 0;\n    padding-left: 0; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-margin-collapse > .cell {\n      margin-right: 0;\n      margin-left: 0; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .small-3 {\n    width: 25%; }\n  .medium-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .small-6 {\n    width: 50%; }\n  .medium-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .small-9 {\n    width: 75%; }\n  .medium-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .small-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-margin-collapse > .medium-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .medium-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .medium-3 {\n    width: 25%; }\n  .medium-margin-collapse > .medium-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .medium-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .medium-6 {\n    width: 50%; }\n  .medium-margin-collapse > .medium-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .medium-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .medium-9 {\n    width: 75%; }\n  .medium-margin-collapse > .medium-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .medium-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .medium-margin-collapse > .large-1 {\n    width: 8.33333%; }\n  .medium-margin-collapse > .large-2 {\n    width: 16.66667%; }\n  .medium-margin-collapse > .large-3 {\n    width: 25%; }\n  .medium-margin-collapse > .large-4 {\n    width: 33.33333%; }\n  .medium-margin-collapse > .large-5 {\n    width: 41.66667%; }\n  .medium-margin-collapse > .large-6 {\n    width: 50%; }\n  .medium-margin-collapse > .large-7 {\n    width: 58.33333%; }\n  .medium-margin-collapse > .large-8 {\n    width: 66.66667%; }\n  .medium-margin-collapse > .large-9 {\n    width: 75%; }\n  .medium-margin-collapse > .large-10 {\n    width: 83.33333%; }\n  .medium-margin-collapse > .large-11 {\n    width: 91.66667%; }\n  .medium-margin-collapse > .large-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 40em) {\n  .medium-padding-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .medium-padding-collapse > .cell {\n      padding-right: 0;\n      padding-left: 0; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .large-margin-collapse > .cell {\n      margin-right: 0;\n      margin-left: 0; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .small-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .small-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .small-3 {\n    width: 25%; }\n  .large-margin-collapse > .small-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .small-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .small-6 {\n    width: 50%; }\n  .large-margin-collapse > .small-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .small-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .small-9 {\n    width: 75%; }\n  .large-margin-collapse > .small-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .small-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .small-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .medium-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .medium-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .medium-3 {\n    width: 25%; }\n  .large-margin-collapse > .medium-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .medium-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .medium-6 {\n    width: 50%; }\n  .large-margin-collapse > .medium-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .medium-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .medium-9 {\n    width: 75%; }\n  .large-margin-collapse > .medium-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .medium-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .medium-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-margin-collapse > .large-1 {\n    width: 8.33333%; }\n  .large-margin-collapse > .large-2 {\n    width: 16.66667%; }\n  .large-margin-collapse > .large-3 {\n    width: 25%; }\n  .large-margin-collapse > .large-4 {\n    width: 33.33333%; }\n  .large-margin-collapse > .large-5 {\n    width: 41.66667%; }\n  .large-margin-collapse > .large-6 {\n    width: 50%; }\n  .large-margin-collapse > .large-7 {\n    width: 58.33333%; }\n  .large-margin-collapse > .large-8 {\n    width: 66.66667%; }\n  .large-margin-collapse > .large-9 {\n    width: 75%; }\n  .large-margin-collapse > .large-10 {\n    width: 83.33333%; }\n  .large-margin-collapse > .large-11 {\n    width: 91.66667%; }\n  .large-margin-collapse > .large-12 {\n    width: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-padding-collapse {\n    margin-right: 0;\n    margin-left: 0; }\n    .large-padding-collapse > .cell {\n      padding-right: 0;\n      padding-left: 0; } }\n\n.small-offset-0 {\n  margin-left: 0%; }\n\n.grid-margin-x > .small-offset-0 {\n  margin-left: calc(0% + 0.625rem); }\n\n.small-offset-1 {\n  margin-left: 8.33333%; }\n\n.grid-margin-x > .small-offset-1 {\n  margin-left: calc(8.33333% + 0.625rem); }\n\n.small-offset-2 {\n  margin-left: 16.66667%; }\n\n.grid-margin-x > .small-offset-2 {\n  margin-left: calc(16.66667% + 0.625rem); }\n\n.small-offset-3 {\n  margin-left: 25%; }\n\n.grid-margin-x > .small-offset-3 {\n  margin-left: calc(25% + 0.625rem); }\n\n.small-offset-4 {\n  margin-left: 33.33333%; }\n\n.grid-margin-x > .small-offset-4 {\n  margin-left: calc(33.33333% + 0.625rem); }\n\n.small-offset-5 {\n  margin-left: 41.66667%; }\n\n.grid-margin-x > .small-offset-5 {\n  margin-left: calc(41.66667% + 0.625rem); }\n\n.small-offset-6 {\n  margin-left: 50%; }\n\n.grid-margin-x > .small-offset-6 {\n  margin-left: calc(50% + 0.625rem); }\n\n.small-offset-7 {\n  margin-left: 58.33333%; }\n\n.grid-margin-x > .small-offset-7 {\n  margin-left: calc(58.33333% + 0.625rem); }\n\n.small-offset-8 {\n  margin-left: 66.66667%; }\n\n.grid-margin-x > .small-offset-8 {\n  margin-left: calc(66.66667% + 0.625rem); }\n\n.small-offset-9 {\n  margin-left: 75%; }\n\n.grid-margin-x > .small-offset-9 {\n  margin-left: calc(75% + 0.625rem); }\n\n.small-offset-10 {\n  margin-left: 83.33333%; }\n\n.grid-margin-x > .small-offset-10 {\n  margin-left: calc(83.33333% + 0.625rem); }\n\n.small-offset-11 {\n  margin-left: 91.66667%; }\n\n.grid-margin-x > .small-offset-11 {\n  margin-left: calc(91.66667% + 0.625rem); }\n\n@media print, screen and (min-width: 40em) {\n  .medium-offset-0 {\n    margin-left: 0%; }\n  .grid-margin-x > .medium-offset-0 {\n    margin-left: calc(0% + 0.9375rem); }\n  .medium-offset-1 {\n    margin-left: 8.33333%; }\n  .grid-margin-x > .medium-offset-1 {\n    margin-left: calc(8.33333% + 0.9375rem); }\n  .medium-offset-2 {\n    margin-left: 16.66667%; }\n  .grid-margin-x > .medium-offset-2 {\n    margin-left: calc(16.66667% + 0.9375rem); }\n  .medium-offset-3 {\n    margin-left: 25%; }\n  .grid-margin-x > .medium-offset-3 {\n    margin-left: calc(25% + 0.9375rem); }\n  .medium-offset-4 {\n    margin-left: 33.33333%; }\n  .grid-margin-x > .medium-offset-4 {\n    margin-left: calc(33.33333% + 0.9375rem); }\n  .medium-offset-5 {\n    margin-left: 41.66667%; }\n  .grid-margin-x > .medium-offset-5 {\n    margin-left: calc(41.66667% + 0.9375rem); }\n  .medium-offset-6 {\n    margin-left: 50%; }\n  .grid-margin-x > .medium-offset-6 {\n    margin-left: calc(50% + 0.9375rem); }\n  .medium-offset-7 {\n    margin-left: 58.33333%; }\n  .grid-margin-x > .medium-offset-7 {\n    margin-left: calc(58.33333% + 0.9375rem); }\n  .medium-offset-8 {\n    margin-left: 66.66667%; }\n  .grid-margin-x > .medium-offset-8 {\n    margin-left: calc(66.66667% + 0.9375rem); }\n  .medium-offset-9 {\n    margin-left: 75%; }\n  .grid-margin-x > .medium-offset-9 {\n    margin-left: calc(75% + 0.9375rem); }\n  .medium-offset-10 {\n    margin-left: 83.33333%; }\n  .grid-margin-x > .medium-offset-10 {\n    margin-left: calc(83.33333% + 0.9375rem); }\n  .medium-offset-11 {\n    margin-left: 91.66667%; }\n  .grid-margin-x > .medium-offset-11 {\n    margin-left: calc(91.66667% + 0.9375rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .large-offset-0 {\n    margin-left: 0%; }\n  .grid-margin-x > .large-offset-0 {\n    margin-left: calc(0% + 0.9375rem); }\n  .large-offset-1 {\n    margin-left: 8.33333%; }\n  .grid-margin-x > .large-offset-1 {\n    margin-left: calc(8.33333% + 0.9375rem); }\n  .large-offset-2 {\n    margin-left: 16.66667%; }\n  .grid-margin-x > .large-offset-2 {\n    margin-left: calc(16.66667% + 0.9375rem); }\n  .large-offset-3 {\n    margin-left: 25%; }\n  .grid-margin-x > .large-offset-3 {\n    margin-left: calc(25% + 0.9375rem); }\n  .large-offset-4 {\n    margin-left: 33.33333%; }\n  .grid-margin-x > .large-offset-4 {\n    margin-left: calc(33.33333% + 0.9375rem); }\n  .large-offset-5 {\n    margin-left: 41.66667%; }\n  .grid-margin-x > .large-offset-5 {\n    margin-left: calc(41.66667% + 0.9375rem); }\n  .large-offset-6 {\n    margin-left: 50%; }\n  .grid-margin-x > .large-offset-6 {\n    margin-left: calc(50% + 0.9375rem); }\n  .large-offset-7 {\n    margin-left: 58.33333%; }\n  .grid-margin-x > .large-offset-7 {\n    margin-left: calc(58.33333% + 0.9375rem); }\n  .large-offset-8 {\n    margin-left: 66.66667%; }\n  .grid-margin-x > .large-offset-8 {\n    margin-left: calc(66.66667% + 0.9375rem); }\n  .large-offset-9 {\n    margin-left: 75%; }\n  .grid-margin-x > .large-offset-9 {\n    margin-left: calc(75% + 0.9375rem); }\n  .large-offset-10 {\n    margin-left: 83.33333%; }\n  .grid-margin-x > .large-offset-10 {\n    margin-left: calc(83.33333% + 0.9375rem); }\n  .large-offset-11 {\n    margin-left: 91.66667%; }\n  .grid-margin-x > .large-offset-11 {\n    margin-left: calc(91.66667% + 0.9375rem); } }\n\n.grid-y {\n  display: flex;\n  flex-flow: column nowrap; }\n  .grid-y > .cell {\n    width: auto;\n    max-width: none; }\n  .grid-y > .auto {\n    height: auto; }\n  .grid-y > .shrink {\n    height: auto; }\n  .grid-y > .small-shrink, .grid-y > .small-full, .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {\n    flex-basis: auto; }\n  @media print, screen and (min-width: 40em) {\n    .grid-y > .medium-shrink, .grid-y > .medium-full, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {\n      flex-basis: auto; } }\n  @media print, screen and (min-width: 64em) {\n    .grid-y > .large-shrink, .grid-y > .large-full, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {\n      flex-basis: auto; } }\n  .grid-y > .small-1, .grid-y > .small-2, .grid-y > .small-3, .grid-y > .small-4, .grid-y > .small-5, .grid-y > .small-6, .grid-y > .small-7, .grid-y > .small-8, .grid-y > .small-9, .grid-y > .small-10, .grid-y > .small-11, .grid-y > .small-12 {\n    flex: 0 0 auto; }\n  .grid-y > .small-1 {\n    height: 8.33333%; }\n  .grid-y > .small-2 {\n    height: 16.66667%; }\n  .grid-y > .small-3 {\n    height: 25%; }\n  .grid-y > .small-4 {\n    height: 33.33333%; }\n  .grid-y > .small-5 {\n    height: 41.66667%; }\n  .grid-y > .small-6 {\n    height: 50%; }\n  .grid-y > .small-7 {\n    height: 58.33333%; }\n  .grid-y > .small-8 {\n    height: 66.66667%; }\n  .grid-y > .small-9 {\n    height: 75%; }\n  .grid-y > .small-10 {\n    height: 83.33333%; }\n  .grid-y > .small-11 {\n    height: 91.66667%; }\n  .grid-y > .small-12 {\n    height: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .grid-y > .medium-auto {\n      flex: 1 1 0px;\n      height: auto; }\n    .grid-y > .medium-shrink, .grid-y > .medium-1, .grid-y > .medium-2, .grid-y > .medium-3, .grid-y > .medium-4, .grid-y > .medium-5, .grid-y > .medium-6, .grid-y > .medium-7, .grid-y > .medium-8, .grid-y > .medium-9, .grid-y > .medium-10, .grid-y > .medium-11, .grid-y > .medium-12 {\n      flex: 0 0 auto; }\n    .grid-y > .medium-shrink {\n      height: auto; }\n    .grid-y > .medium-1 {\n      height: 8.33333%; }\n    .grid-y > .medium-2 {\n      height: 16.66667%; }\n    .grid-y > .medium-3 {\n      height: 25%; }\n    .grid-y > .medium-4 {\n      height: 33.33333%; }\n    .grid-y > .medium-5 {\n      height: 41.66667%; }\n    .grid-y > .medium-6 {\n      height: 50%; }\n    .grid-y > .medium-7 {\n      height: 58.33333%; }\n    .grid-y > .medium-8 {\n      height: 66.66667%; }\n    .grid-y > .medium-9 {\n      height: 75%; }\n    .grid-y > .medium-10 {\n      height: 83.33333%; }\n    .grid-y > .medium-11 {\n      height: 91.66667%; }\n    .grid-y > .medium-12 {\n      height: 100%; } }\n  @media print, screen and (min-width: 64em) {\n    .grid-y > .large-auto {\n      flex: 1 1 0px;\n      height: auto; }\n    .grid-y > .large-shrink, .grid-y > .large-1, .grid-y > .large-2, .grid-y > .large-3, .grid-y > .large-4, .grid-y > .large-5, .grid-y > .large-6, .grid-y > .large-7, .grid-y > .large-8, .grid-y > .large-9, .grid-y > .large-10, .grid-y > .large-11, .grid-y > .large-12 {\n      flex: 0 0 auto; }\n    .grid-y > .large-shrink {\n      height: auto; }\n    .grid-y > .large-1 {\n      height: 8.33333%; }\n    .grid-y > .large-2 {\n      height: 16.66667%; }\n    .grid-y > .large-3 {\n      height: 25%; }\n    .grid-y > .large-4 {\n      height: 33.33333%; }\n    .grid-y > .large-5 {\n      height: 41.66667%; }\n    .grid-y > .large-6 {\n      height: 50%; }\n    .grid-y > .large-7 {\n      height: 58.33333%; }\n    .grid-y > .large-8 {\n      height: 66.66667%; }\n    .grid-y > .large-9 {\n      height: 75%; }\n    .grid-y > .large-10 {\n      height: 83.33333%; }\n    .grid-y > .large-11 {\n      height: 91.66667%; }\n    .grid-y > .large-12 {\n      height: 100%; } }\n\n.grid-padding-y .grid-padding-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-y .grid-padding-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n\n.grid-padding-y > .cell {\n  padding-top: 0.625rem;\n  padding-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-padding-y > .cell {\n      padding-top: 0.9375rem;\n      padding-bottom: 0.9375rem; } }\n\n.grid-margin-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n  .grid-margin-y > .cell {\n    height: calc(100% - 1.25rem);\n    margin-top: 0.625rem;\n    margin-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .cell {\n      height: calc(100% - 1.875rem);\n      margin-top: 0.9375rem;\n      margin-bottom: 0.9375rem; } }\n  .grid-margin-y > .auto {\n    height: auto; }\n  .grid-margin-y > .shrink {\n    height: auto; }\n  .grid-margin-y > .small-1 {\n    height: calc(8.33333% - 1.25rem); }\n  .grid-margin-y > .small-2 {\n    height: calc(16.66667% - 1.25rem); }\n  .grid-margin-y > .small-3 {\n    height: calc(25% - 1.25rem); }\n  .grid-margin-y > .small-4 {\n    height: calc(33.33333% - 1.25rem); }\n  .grid-margin-y > .small-5 {\n    height: calc(41.66667% - 1.25rem); }\n  .grid-margin-y > .small-6 {\n    height: calc(50% - 1.25rem); }\n  .grid-margin-y > .small-7 {\n    height: calc(58.33333% - 1.25rem); }\n  .grid-margin-y > .small-8 {\n    height: calc(66.66667% - 1.25rem); }\n  .grid-margin-y > .small-9 {\n    height: calc(75% - 1.25rem); }\n  .grid-margin-y > .small-10 {\n    height: calc(83.33333% - 1.25rem); }\n  .grid-margin-y > .small-11 {\n    height: calc(91.66667% - 1.25rem); }\n  .grid-margin-y > .small-12 {\n    height: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .auto {\n      height: auto; }\n    .grid-margin-y > .shrink {\n      height: auto; }\n    .grid-margin-y > .small-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .small-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .small-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .small-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .small-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .small-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .small-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .small-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .small-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .small-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .small-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .small-12 {\n      height: calc(100% - 1.875rem); }\n    .grid-margin-y > .medium-auto {\n      height: auto; }\n    .grid-margin-y > .medium-shrink {\n      height: auto; }\n    .grid-margin-y > .medium-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .medium-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .medium-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .medium-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .medium-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .medium-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .medium-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .medium-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .medium-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .medium-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .medium-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .medium-12 {\n      height: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-y > .large-auto {\n      height: auto; }\n    .grid-margin-y > .large-shrink {\n      height: auto; }\n    .grid-margin-y > .large-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .large-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .large-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .large-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .large-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .large-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .large-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .large-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .large-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .large-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .large-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .large-12 {\n      height: calc(100% - 1.875rem); } }\n\n.grid-frame {\n  overflow: hidden;\n  position: relative;\n  flex-wrap: nowrap;\n  align-items: stretch;\n  width: 100vw; }\n\n.cell .grid-frame {\n  width: 100%; }\n\n.cell-block {\n  overflow-x: auto;\n  max-width: 100%;\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar; }\n\n.cell-block-y {\n  overflow-y: auto;\n  max-height: 100%;\n  min-height: 100%;\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar; }\n\n.cell-block-container {\n  display: flex;\n  flex-direction: column;\n  max-height: 100%; }\n  .cell-block-container > .grid-x {\n    max-height: 100%;\n    flex-wrap: nowrap; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-grid-frame {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    width: 100vw; }\n  .cell .medium-grid-frame {\n    width: 100%; }\n  .medium-cell-block {\n    overflow-x: auto;\n    max-width: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; }\n  .medium-cell-block-container {\n    display: flex;\n    flex-direction: column;\n    max-height: 100%; }\n    .medium-cell-block-container > .grid-x {\n      max-height: 100%;\n      flex-wrap: nowrap; }\n  .medium-cell-block-y {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-grid-frame {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    width: 100vw; }\n  .cell .large-grid-frame {\n    width: 100%; }\n  .large-cell-block {\n    overflow-x: auto;\n    max-width: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; }\n  .large-cell-block-container {\n    display: flex;\n    flex-direction: column;\n    max-height: 100%; }\n    .large-cell-block-container > .grid-x {\n      max-height: 100%;\n      flex-wrap: nowrap; }\n  .large-cell-block-y {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n    -webkit-overflow-scrolling: touch;\n    -ms-overflow-style: -ms-autohiding-scrollbar; } }\n\n.grid-y.grid-frame {\n  width: auto;\n  overflow: hidden;\n  position: relative;\n  flex-wrap: nowrap;\n  align-items: stretch;\n  height: 100vh; }\n\n@media print, screen and (min-width: 40em) {\n  .grid-y.medium-grid-frame {\n    width: auto;\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    height: 100vh; } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-y.large-grid-frame {\n    width: auto;\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n    height: 100vh; } }\n\n.cell .grid-y.grid-frame {\n  height: 100%; }\n\n@media print, screen and (min-width: 40em) {\n  .cell .grid-y.medium-grid-frame {\n    height: 100%; } }\n\n@media print, screen and (min-width: 64em) {\n  .cell .grid-y.large-grid-frame {\n    height: 100%; } }\n\n.grid-margin-y {\n  margin-top: -0.625rem;\n  margin-bottom: -0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y {\n      margin-top: -0.9375rem;\n      margin-bottom: -0.9375rem; } }\n  .grid-margin-y > .cell {\n    height: calc(100% - 1.25rem);\n    margin-top: 0.625rem;\n    margin-bottom: 0.625rem; }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .cell {\n      height: calc(100% - 1.875rem);\n      margin-top: 0.9375rem;\n      margin-bottom: 0.9375rem; } }\n  .grid-margin-y > .auto {\n    height: auto; }\n  .grid-margin-y > .shrink {\n    height: auto; }\n  .grid-margin-y > .small-1 {\n    height: calc(8.33333% - 1.25rem); }\n  .grid-margin-y > .small-2 {\n    height: calc(16.66667% - 1.25rem); }\n  .grid-margin-y > .small-3 {\n    height: calc(25% - 1.25rem); }\n  .grid-margin-y > .small-4 {\n    height: calc(33.33333% - 1.25rem); }\n  .grid-margin-y > .small-5 {\n    height: calc(41.66667% - 1.25rem); }\n  .grid-margin-y > .small-6 {\n    height: calc(50% - 1.25rem); }\n  .grid-margin-y > .small-7 {\n    height: calc(58.33333% - 1.25rem); }\n  .grid-margin-y > .small-8 {\n    height: calc(66.66667% - 1.25rem); }\n  .grid-margin-y > .small-9 {\n    height: calc(75% - 1.25rem); }\n  .grid-margin-y > .small-10 {\n    height: calc(83.33333% - 1.25rem); }\n  .grid-margin-y > .small-11 {\n    height: calc(91.66667% - 1.25rem); }\n  .grid-margin-y > .small-12 {\n    height: calc(100% - 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-margin-y > .auto {\n      height: auto; }\n    .grid-margin-y > .shrink {\n      height: auto; }\n    .grid-margin-y > .small-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .small-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .small-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .small-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .small-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .small-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .small-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .small-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .small-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .small-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .small-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .small-12 {\n      height: calc(100% - 1.875rem); }\n    .grid-margin-y > .medium-auto {\n      height: auto; }\n    .grid-margin-y > .medium-shrink {\n      height: auto; }\n    .grid-margin-y > .medium-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .medium-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .medium-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .medium-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .medium-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .medium-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .medium-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .medium-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .medium-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .medium-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .medium-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .medium-12 {\n      height: calc(100% - 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-margin-y > .large-auto {\n      height: auto; }\n    .grid-margin-y > .large-shrink {\n      height: auto; }\n    .grid-margin-y > .large-1 {\n      height: calc(8.33333% - 1.875rem); }\n    .grid-margin-y > .large-2 {\n      height: calc(16.66667% - 1.875rem); }\n    .grid-margin-y > .large-3 {\n      height: calc(25% - 1.875rem); }\n    .grid-margin-y > .large-4 {\n      height: calc(33.33333% - 1.875rem); }\n    .grid-margin-y > .large-5 {\n      height: calc(41.66667% - 1.875rem); }\n    .grid-margin-y > .large-6 {\n      height: calc(50% - 1.875rem); }\n    .grid-margin-y > .large-7 {\n      height: calc(58.33333% - 1.875rem); }\n    .grid-margin-y > .large-8 {\n      height: calc(66.66667% - 1.875rem); }\n    .grid-margin-y > .large-9 {\n      height: calc(75% - 1.875rem); }\n    .grid-margin-y > .large-10 {\n      height: calc(83.33333% - 1.875rem); }\n    .grid-margin-y > .large-11 {\n      height: calc(91.66667% - 1.875rem); }\n    .grid-margin-y > .large-12 {\n      height: calc(100% - 1.875rem); } }\n\n.grid-frame.grid-margin-y {\n  height: calc(100vh + 1.25rem); }\n  @media print, screen and (min-width: 40em) {\n    .grid-frame.grid-margin-y {\n      height: calc(100vh + 1.875rem); } }\n  @media print, screen and (min-width: 64em) {\n    .grid-frame.grid-margin-y {\n      height: calc(100vh + 1.875rem); } }\n\n@media print, screen and (min-width: 40em) {\n  .grid-margin-y.medium-grid-frame {\n    height: calc(100vh + 1.875rem); } }\n\n@media print, screen and (min-width: 64em) {\n  .grid-margin-y.large-grid-frame {\n    height: calc(100vh + 1.875rem); } }\n\n.button {\n  display: inline-block;\n  vertical-align: middle;\n  margin: 0 0 1rem 0;\n  padding: 0.85em 1em;\n  border: 1px solid transparent;\n  border-radius: 0;\n  transition: background-color 0.25s ease-out, color 0.25s ease-out;\n  font-family: inherit;\n  font-size: 0.9rem;\n  -webkit-appearance: none;\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n  background-color: #1779ba;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .button {\n    outline: 0; }\n  .button:hover, .button:focus {\n    background-color: #14679e;\n    color: #fefefe; }\n  .button.tiny {\n    font-size: 0.6rem; }\n  .button.small {\n    font-size: 0.75rem; }\n  .button.large {\n    font-size: 1.25rem; }\n  .button.expanded {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0; }\n  .button.primary {\n    background-color: #1779ba;\n    color: #fefefe; }\n    .button.primary:hover, .button.primary:focus {\n      background-color: #126195;\n      color: #fefefe; }\n  .button.secondary {\n    background-color: #767676;\n    color: #fefefe; }\n    .button.secondary:hover, .button.secondary:focus {\n      background-color: #5e5e5e;\n      color: #fefefe; }\n  .button.success {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n    .button.success:hover, .button.success:focus {\n      background-color: #22bb5b;\n      color: #0a0a0a; }\n  .button.warning {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n    .button.warning:hover, .button.warning:focus {\n      background-color: #cc8b00;\n      color: #0a0a0a; }\n  .button.alert {\n    background-color: #cc4b37;\n    color: #fefefe; }\n    .button.alert:hover, .button.alert:focus {\n      background-color: #a53b2a;\n      color: #fefefe; }\n  .button.disabled, .button[disabled] {\n    opacity: 0.25;\n    cursor: not-allowed; }\n    .button.disabled, .button.disabled:hover, .button.disabled:focus, .button[disabled], .button[disabled]:hover, .button[disabled]:focus {\n      background-color: #1779ba;\n      color: #fefefe; }\n    .button.disabled.primary, .button[disabled].primary {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.primary, .button.disabled.primary:hover, .button.disabled.primary:focus, .button[disabled].primary, .button[disabled].primary:hover, .button[disabled].primary:focus {\n        background-color: #1779ba;\n        color: #fefefe; }\n    .button.disabled.secondary, .button[disabled].secondary {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.secondary, .button.disabled.secondary:hover, .button.disabled.secondary:focus, .button[disabled].secondary, .button[disabled].secondary:hover, .button[disabled].secondary:focus {\n        background-color: #767676;\n        color: #fefefe; }\n    .button.disabled.success, .button[disabled].success {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.success, .button.disabled.success:hover, .button.disabled.success:focus, .button[disabled].success, .button[disabled].success:hover, .button[disabled].success:focus {\n        background-color: #3adb76;\n        color: #0a0a0a; }\n    .button.disabled.warning, .button[disabled].warning {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.warning, .button.disabled.warning:hover, .button.disabled.warning:focus, .button[disabled].warning, .button[disabled].warning:hover, .button[disabled].warning:focus {\n        background-color: #ffae00;\n        color: #0a0a0a; }\n    .button.disabled.alert, .button[disabled].alert {\n      opacity: 0.25;\n      cursor: not-allowed; }\n      .button.disabled.alert, .button.disabled.alert:hover, .button.disabled.alert:focus, .button[disabled].alert, .button[disabled].alert:hover, .button[disabled].alert:focus {\n        background-color: #cc4b37;\n        color: #fefefe; }\n  .button.hollow {\n    border: 1px solid #1779ba;\n    color: #1779ba; }\n    .button.hollow, .button.hollow:hover, .button.hollow:focus {\n      background-color: transparent; }\n    .button.hollow.disabled, .button.hollow.disabled:hover, .button.hollow.disabled:focus, .button.hollow[disabled], .button.hollow[disabled]:hover, .button.hollow[disabled]:focus {\n      background-color: transparent; }\n    .button.hollow:hover, .button.hollow:focus {\n      border-color: #0c3d5d;\n      color: #0c3d5d; }\n      .button.hollow:hover.disabled, .button.hollow:hover[disabled], .button.hollow:focus.disabled, .button.hollow:focus[disabled] {\n        border: 1px solid #1779ba;\n        color: #1779ba; }\n    .button.hollow.primary {\n      border: 1px solid #1779ba;\n      color: #1779ba; }\n      .button.hollow.primary:hover, .button.hollow.primary:focus {\n        border-color: #0c3d5d;\n        color: #0c3d5d; }\n        .button.hollow.primary:hover.disabled, .button.hollow.primary:hover[disabled], .button.hollow.primary:focus.disabled, .button.hollow.primary:focus[disabled] {\n          border: 1px solid #1779ba;\n          color: #1779ba; }\n    .button.hollow.secondary {\n      border: 1px solid #767676;\n      color: #767676; }\n      .button.hollow.secondary:hover, .button.hollow.secondary:focus {\n        border-color: #3b3b3b;\n        color: #3b3b3b; }\n        .button.hollow.secondary:hover.disabled, .button.hollow.secondary:hover[disabled], .button.hollow.secondary:focus.disabled, .button.hollow.secondary:focus[disabled] {\n          border: 1px solid #767676;\n          color: #767676; }\n    .button.hollow.success {\n      border: 1px solid #3adb76;\n      color: #3adb76; }\n      .button.hollow.success:hover, .button.hollow.success:focus {\n        border-color: #157539;\n        color: #157539; }\n        .button.hollow.success:hover.disabled, .button.hollow.success:hover[disabled], .button.hollow.success:focus.disabled, .button.hollow.success:focus[disabled] {\n          border: 1px solid #3adb76;\n          color: #3adb76; }\n    .button.hollow.warning {\n      border: 1px solid #ffae00;\n      color: #ffae00; }\n      .button.hollow.warning:hover, .button.hollow.warning:focus {\n        border-color: #805700;\n        color: #805700; }\n        .button.hollow.warning:hover.disabled, .button.hollow.warning:hover[disabled], .button.hollow.warning:focus.disabled, .button.hollow.warning:focus[disabled] {\n          border: 1px solid #ffae00;\n          color: #ffae00; }\n    .button.hollow.alert {\n      border: 1px solid #cc4b37;\n      color: #cc4b37; }\n      .button.hollow.alert:hover, .button.hollow.alert:focus {\n        border-color: #67251a;\n        color: #67251a; }\n        .button.hollow.alert:hover.disabled, .button.hollow.alert:hover[disabled], .button.hollow.alert:focus.disabled, .button.hollow.alert:focus[disabled] {\n          border: 1px solid #cc4b37;\n          color: #cc4b37; }\n  .button.clear {\n    border: 1px solid #1779ba;\n    color: #1779ba; }\n    .button.clear, .button.clear:hover, .button.clear:focus {\n      background-color: transparent; }\n    .button.clear.disabled, .button.clear.disabled:hover, .button.clear.disabled:focus, .button.clear[disabled], .button.clear[disabled]:hover, .button.clear[disabled]:focus {\n      background-color: transparent; }\n    .button.clear:hover, .button.clear:focus {\n      border-color: #0c3d5d;\n      color: #0c3d5d; }\n      .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus.disabled, .button.clear:focus[disabled] {\n        border: 1px solid #1779ba;\n        color: #1779ba; }\n    .button.clear, .button.clear.disabled, .button.clear[disabled], .button.clear:hover, .button.clear:hover.disabled, .button.clear:hover[disabled], .button.clear:focus, .button.clear:focus.disabled, .button.clear:focus[disabled] {\n      border-color: transparent; }\n    .button.clear.primary {\n      border: 1px solid #1779ba;\n      color: #1779ba; }\n      .button.clear.primary:hover, .button.clear.primary:focus {\n        border-color: #0c3d5d;\n        color: #0c3d5d; }\n        .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {\n          border: 1px solid #1779ba;\n          color: #1779ba; }\n      .button.clear.primary, .button.clear.primary.disabled, .button.clear.primary[disabled], .button.clear.primary:hover, .button.clear.primary:hover.disabled, .button.clear.primary:hover[disabled], .button.clear.primary:focus, .button.clear.primary:focus.disabled, .button.clear.primary:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.secondary {\n      border: 1px solid #767676;\n      color: #767676; }\n      .button.clear.secondary:hover, .button.clear.secondary:focus {\n        border-color: #3b3b3b;\n        color: #3b3b3b; }\n        .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {\n          border: 1px solid #767676;\n          color: #767676; }\n      .button.clear.secondary, .button.clear.secondary.disabled, .button.clear.secondary[disabled], .button.clear.secondary:hover, .button.clear.secondary:hover.disabled, .button.clear.secondary:hover[disabled], .button.clear.secondary:focus, .button.clear.secondary:focus.disabled, .button.clear.secondary:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.success {\n      border: 1px solid #3adb76;\n      color: #3adb76; }\n      .button.clear.success:hover, .button.clear.success:focus {\n        border-color: #157539;\n        color: #157539; }\n        .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {\n          border: 1px solid #3adb76;\n          color: #3adb76; }\n      .button.clear.success, .button.clear.success.disabled, .button.clear.success[disabled], .button.clear.success:hover, .button.clear.success:hover.disabled, .button.clear.success:hover[disabled], .button.clear.success:focus, .button.clear.success:focus.disabled, .button.clear.success:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.warning {\n      border: 1px solid #ffae00;\n      color: #ffae00; }\n      .button.clear.warning:hover, .button.clear.warning:focus {\n        border-color: #805700;\n        color: #805700; }\n        .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {\n          border: 1px solid #ffae00;\n          color: #ffae00; }\n      .button.clear.warning, .button.clear.warning.disabled, .button.clear.warning[disabled], .button.clear.warning:hover, .button.clear.warning:hover.disabled, .button.clear.warning:hover[disabled], .button.clear.warning:focus, .button.clear.warning:focus.disabled, .button.clear.warning:focus[disabled] {\n        border-color: transparent; }\n    .button.clear.alert {\n      border: 1px solid #cc4b37;\n      color: #cc4b37; }\n      .button.clear.alert:hover, .button.clear.alert:focus {\n        border-color: #67251a;\n        color: #67251a; }\n        .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {\n          border: 1px solid #cc4b37;\n          color: #cc4b37; }\n      .button.clear.alert, .button.clear.alert.disabled, .button.clear.alert[disabled], .button.clear.alert:hover, .button.clear.alert:hover.disabled, .button.clear.alert:hover[disabled], .button.clear.alert:focus, .button.clear.alert:focus.disabled, .button.clear.alert:focus[disabled] {\n        border-color: transparent; }\n  .button.dropdown::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.4em;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #fefefe transparent transparent;\n    position: relative;\n    top: 0.4em;\n    display: inline-block;\n    float: right;\n    margin-left: 1em; }\n  .button.dropdown.hollow::after, .button.dropdown.clear::after {\n    border-top-color: #1779ba; }\n  .button.dropdown.hollow.primary::after, .button.dropdown.clear.primary::after {\n    border-top-color: #1779ba; }\n  .button.dropdown.hollow.secondary::after, .button.dropdown.clear.secondary::after {\n    border-top-color: #767676; }\n  .button.dropdown.hollow.success::after, .button.dropdown.clear.success::after {\n    border-top-color: #3adb76; }\n  .button.dropdown.hollow.warning::after, .button.dropdown.clear.warning::after {\n    border-top-color: #ffae00; }\n  .button.dropdown.hollow.alert::after, .button.dropdown.clear.alert::after {\n    border-top-color: #cc4b37; }\n  .button.arrow-only::after {\n    top: -0.1em;\n    float: none;\n    margin-left: 0; }\n\na.button:hover, a.button:focus {\n  text-decoration: none; }\n\n.button-group {\n  margin-bottom: 1rem;\n  display: flex;\n  flex-wrap: nowrap;\n  align-items: stretch; }\n  .button-group::before, .button-group::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .button-group::after {\n    clear: both; }\n  .button-group .button {\n    margin: 0;\n    margin-right: 1px;\n    margin-bottom: 1px;\n    font-size: 0.9rem;\n    flex: 0 0 auto; }\n    .button-group .button:last-child {\n      margin-right: 0; }\n  .button-group.tiny .button {\n    font-size: 0.6rem; }\n  .button-group.small .button {\n    font-size: 0.75rem; }\n  .button-group.large .button {\n    font-size: 1.25rem; }\n  .button-group.expanded .button {\n    flex: 1 1 0px; }\n  .button-group.primary .button {\n    background-color: #1779ba;\n    color: #fefefe; }\n    .button-group.primary .button:hover, .button-group.primary .button:focus {\n      background-color: #126195;\n      color: #fefefe; }\n  .button-group.secondary .button {\n    background-color: #767676;\n    color: #fefefe; }\n    .button-group.secondary .button:hover, .button-group.secondary .button:focus {\n      background-color: #5e5e5e;\n      color: #fefefe; }\n  .button-group.success .button {\n    background-color: #3adb76;\n    color: #0a0a0a; }\n    .button-group.success .button:hover, .button-group.success .button:focus {\n      background-color: #22bb5b;\n      color: #0a0a0a; }\n  .button-group.warning .button {\n    background-color: #ffae00;\n    color: #0a0a0a; }\n    .button-group.warning .button:hover, .button-group.warning .button:focus {\n      background-color: #cc8b00;\n      color: #0a0a0a; }\n  .button-group.alert .button {\n    background-color: #cc4b37;\n    color: #fefefe; }\n    .button-group.alert .button:hover, .button-group.alert .button:focus {\n      background-color: #a53b2a;\n      color: #fefefe; }\n  .button-group.stacked, .button-group.stacked-for-small, .button-group.stacked-for-medium {\n    flex-wrap: wrap; }\n    .button-group.stacked .button, .button-group.stacked-for-small .button, .button-group.stacked-for-medium .button {\n      flex: 0 0 100%; }\n      .button-group.stacked .button:last-child, .button-group.stacked-for-small .button:last-child, .button-group.stacked-for-medium .button:last-child {\n        margin-bottom: 0; }\n    .button-group.stacked.expanded .button, .button-group.stacked-for-small.expanded .button, .button-group.stacked-for-medium.expanded .button {\n      flex: 1 1 0px; }\n  @media print, screen and (min-width: 40em) {\n    .button-group.stacked-for-small .button {\n      flex: 0 0 auto;\n      margin-bottom: 0; } }\n  @media print, screen and (min-width: 64em) {\n    .button-group.stacked-for-medium .button {\n      flex: 0 0 auto;\n      margin-bottom: 0; } }\n  @media screen and (max-width: 39.99875em) {\n    .button-group.stacked-for-small.expanded {\n      display: block; }\n      .button-group.stacked-for-small.expanded .button {\n        display: block;\n        margin-right: 0; } }\n  @media screen and (max-width: 63.99875em) {\n    .button-group.stacked-for-medium.expanded {\n      display: block; }\n      .button-group.stacked-for-medium.expanded .button {\n        display: block;\n        margin-right: 0; } }\n\n.close-button {\n  position: absolute;\n  color: #8a8a8a;\n  cursor: pointer; }\n  [data-whatinput='mouse'] .close-button {\n    outline: 0; }\n  .close-button:hover, .close-button:focus {\n    color: #0a0a0a; }\n  .close-button.small {\n    right: 0.66rem;\n    top: 0.33em;\n    font-size: 1.5em;\n    line-height: 1; }\n  .close-button, .close-button.medium {\n    right: 1rem;\n    top: 0.5rem;\n    font-size: 2em;\n    line-height: 1; }\n\n.label {\n  display: inline-block;\n  padding: 0.33333rem 0.5rem;\n  border-radius: 0;\n  font-size: 0.8rem;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n  background: #1779ba;\n  color: #fefefe; }\n  .label.primary {\n    background: #1779ba;\n    color: #fefefe; }\n  .label.secondary {\n    background: #767676;\n    color: #fefefe; }\n  .label.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .label.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .label.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.progress {\n  height: 1rem;\n  margin-bottom: 1rem;\n  border-radius: 0;\n  background-color: #cacaca; }\n  .progress.primary .progress-meter {\n    background-color: #1779ba; }\n  .progress.secondary .progress-meter {\n    background-color: #767676; }\n  .progress.success .progress-meter {\n    background-color: #3adb76; }\n  .progress.warning .progress-meter {\n    background-color: #ffae00; }\n  .progress.alert .progress-meter {\n    background-color: #cc4b37; }\n\n.progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: #1779ba; }\n\n.progress-meter-text {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: #fefefe;\n  white-space: nowrap; }\n\n.slider {\n  position: relative;\n  height: 0.5rem;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n  background-color: #e6e6e6;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none; }\n\n.slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n  display: inline-block;\n  max-width: 100%;\n  height: 0.5rem;\n  background-color: #cacaca;\n  transition: all 0.2s ease-in-out; }\n  .slider-fill.is-dragging {\n    transition: all 0s linear; }\n\n.slider-handle {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  left: 0;\n  z-index: 1;\n  display: inline-block;\n  width: 1.4rem;\n  height: 1.4rem;\n  border-radius: 0;\n  background-color: #1779ba;\n  transition: all 0.2s ease-in-out;\n  touch-action: manipulation; }\n  [data-whatinput='mouse'] .slider-handle {\n    outline: 0; }\n  .slider-handle:hover {\n    background-color: #14679e; }\n  .slider-handle.is-dragging {\n    transition: all 0s linear; }\n\n.slider.disabled,\n.slider[disabled] {\n  opacity: 0.25;\n  cursor: not-allowed; }\n\n.slider.vertical {\n  display: inline-block;\n  width: 0.5rem;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1); }\n  .slider.vertical .slider-fill {\n    top: 0;\n    width: 0.5rem;\n    max-height: 100%; }\n  .slider.vertical .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: 1.4rem;\n    height: 1.4rem;\n    transform: translateX(-50%); }\n\n.switch {\n  height: 2rem;\n  position: relative;\n  margin-bottom: 1rem;\n  outline: 0;\n  font-size: 0.875rem;\n  font-weight: bold;\n  color: #fefefe;\n  user-select: none; }\n\n.switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0; }\n\n.switch-paddle {\n  position: relative;\n  display: block;\n  width: 4rem;\n  height: 2rem;\n  border-radius: 0;\n  background: #cacaca;\n  transition: all 0.25s ease-out;\n  font-weight: inherit;\n  color: inherit;\n  cursor: pointer; }\n  input + .switch-paddle {\n    margin: 0; }\n  .switch-paddle::after {\n    position: absolute;\n    top: 0.25rem;\n    left: 0.25rem;\n    display: block;\n    width: 1.5rem;\n    height: 1.5rem;\n    transform: translate3d(0, 0, 0);\n    border-radius: 0;\n    background: #fefefe;\n    transition: all 0.25s ease-out;\n    content: ''; }\n  input:checked ~ .switch-paddle {\n    background: #1779ba; }\n    input:checked ~ .switch-paddle::after {\n      left: 2.25rem; }\n  [data-whatinput='mouse'] input:focus ~ .switch-paddle {\n    outline: 0; }\n\n.switch-active, .switch-inactive {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%); }\n\n.switch-active {\n  left: 8%;\n  display: none; }\n  input:checked + label > .switch-active {\n    display: block; }\n\n.switch-inactive {\n  right: 15%; }\n  input:checked + label > .switch-inactive {\n    display: none; }\n\n.switch.tiny {\n  height: 1.5rem; }\n  .switch.tiny .switch-paddle {\n    width: 3rem;\n    height: 1.5rem;\n    font-size: 0.625rem; }\n  .switch.tiny .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 1rem;\n    height: 1rem; }\n  .switch.tiny input:checked ~ .switch-paddle::after {\n    left: 1.75rem; }\n\n.switch.small {\n  height: 1.75rem; }\n  .switch.small .switch-paddle {\n    width: 3.5rem;\n    height: 1.75rem;\n    font-size: 0.75rem; }\n  .switch.small .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 1.25rem;\n    height: 1.25rem; }\n  .switch.small input:checked ~ .switch-paddle::after {\n    left: 2rem; }\n\n.switch.large {\n  height: 2.5rem; }\n  .switch.large .switch-paddle {\n    width: 5rem;\n    height: 2.5rem;\n    font-size: 1rem; }\n  .switch.large .switch-paddle::after {\n    top: 0.25rem;\n    left: 0.25rem;\n    width: 2rem;\n    height: 2rem; }\n  .switch.large input:checked ~ .switch-paddle::after {\n    left: 2.75rem; }\n\ntable {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: 1rem;\n  border-radius: 0; }\n  thead,\n  tbody,\n  tfoot {\n    border: 1px solid #f1f1f1;\n    background-color: #fefefe; }\n  caption {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold; }\n  thead {\n    background: #f8f8f8;\n    color: #0a0a0a; }\n  tfoot {\n    background: #f1f1f1;\n    color: #0a0a0a; }\n  thead tr,\n  tfoot tr {\n    background: transparent; }\n  thead th,\n  thead td,\n  tfoot th,\n  tfoot td {\n    padding: 0.5rem 0.625rem 0.625rem;\n    font-weight: bold;\n    text-align: left; }\n  tbody th,\n  tbody td {\n    padding: 0.5rem 0.625rem 0.625rem; }\n  tbody tr:nth-child(even) {\n    border-bottom: 0;\n    background-color: #f1f1f1; }\n  table.unstriped tbody {\n    background-color: #fefefe; }\n    table.unstriped tbody tr {\n      border-bottom: 0;\n      border-bottom: 1px solid #f1f1f1;\n      background-color: #fefefe; }\n\n@media screen and (max-width: 63.99875em) {\n  table.stack thead {\n    display: none; }\n  table.stack tfoot {\n    display: none; }\n  table.stack tr,\n  table.stack th,\n  table.stack td {\n    display: block; }\n  table.stack td {\n    border-top: 0; } }\n\ntable.scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto; }\n\ntable.hover thead tr:hover {\n  background-color: #f3f3f3; }\n\ntable.hover tfoot tr:hover {\n  background-color: #ececec; }\n\ntable.hover tbody tr:hover {\n  background-color: #f9f9f9; }\n\ntable.hover:not(.unstriped) tr:nth-of-type(even):hover {\n  background-color: #ececec; }\n\n.table-scroll {\n  overflow-x: auto; }\n\n.badge {\n  display: inline-block;\n  min-width: 2.1em;\n  padding: 0.3em;\n  border-radius: 50%;\n  font-size: 0.6rem;\n  text-align: center;\n  background: #1779ba;\n  color: #fefefe; }\n  .badge.primary {\n    background: #1779ba;\n    color: #fefefe; }\n  .badge.secondary {\n    background: #767676;\n    color: #fefefe; }\n  .badge.success {\n    background: #3adb76;\n    color: #0a0a0a; }\n  .badge.warning {\n    background: #ffae00;\n    color: #0a0a0a; }\n  .badge.alert {\n    background: #cc4b37;\n    color: #fefefe; }\n\n.breadcrumbs {\n  margin: 0 0 1rem 0;\n  list-style: none; }\n  .breadcrumbs::before, .breadcrumbs::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .breadcrumbs::after {\n    clear: both; }\n  .breadcrumbs li {\n    float: left;\n    font-size: 0.6875rem;\n    color: #0a0a0a;\n    cursor: default;\n    text-transform: uppercase; }\n    .breadcrumbs li:not(:last-child)::after {\n      position: relative;\n      margin: 0 0.75rem;\n      opacity: 1;\n      content: \"/\";\n      color: #cacaca; }\n  .breadcrumbs a {\n    color: #1779ba; }\n    .breadcrumbs a:hover {\n      text-decoration: underline; }\n  .breadcrumbs .disabled {\n    color: #cacaca;\n    cursor: not-allowed; }\n\n.callout {\n  position: relative;\n  margin: 0 0 1rem 0;\n  padding: 1rem;\n  border: 1px solid rgba(10, 10, 10, 0.25);\n  border-radius: 0;\n  background-color: white;\n  color: #0a0a0a; }\n  .callout > :first-child {\n    margin-top: 0; }\n  .callout > :last-child {\n    margin-bottom: 0; }\n  .callout.primary {\n    background-color: #d7ecfa;\n    color: #0a0a0a; }\n  .callout.secondary {\n    background-color: #eaeaea;\n    color: #0a0a0a; }\n  .callout.success {\n    background-color: #e1faea;\n    color: #0a0a0a; }\n  .callout.warning {\n    background-color: #fff3d9;\n    color: #0a0a0a; }\n  .callout.alert {\n    background-color: #f7e4e1;\n    color: #0a0a0a; }\n  .callout.small {\n    padding-top: 0.5rem;\n    padding-right: 0.5rem;\n    padding-bottom: 0.5rem;\n    padding-left: 0.5rem; }\n  .callout.large {\n    padding-top: 3rem;\n    padding-right: 3rem;\n    padding-bottom: 3rem;\n    padding-left: 3rem; }\n\n.card {\n  display: flex;\n  flex-direction: column;\n  flex-grow: 1;\n  margin-bottom: 1rem;\n  border: 1px solid #e6e6e6;\n  border-radius: 0;\n  background: #fefefe;\n  box-shadow: none;\n  overflow: hidden;\n  color: #0a0a0a; }\n  .card > :last-child {\n    margin-bottom: 0; }\n\n.card-divider {\n  display: flex;\n  flex: 0 1 auto;\n  padding: 1rem;\n  background: #e6e6e6; }\n  .card-divider > :last-child {\n    margin-bottom: 0; }\n\n.card-section {\n  flex: 1 0 auto;\n  padding: 1rem; }\n  .card-section > :last-child {\n    margin-bottom: 0; }\n\n.card-image {\n  min-height: 1px; }\n\n.dropdown-pane {\n  position: absolute;\n  z-index: 10;\n  display: none;\n  width: 300px;\n  padding: 1rem;\n  visibility: hidden;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  font-size: 1rem; }\n  .dropdown-pane.is-opening {\n    display: block; }\n  .dropdown-pane.is-open {\n    display: block;\n    visibility: visible; }\n\n.dropdown-pane.tiny {\n  width: 100px; }\n\n.dropdown-pane.small {\n  width: 200px; }\n\n.dropdown-pane.large {\n  width: 400px; }\n\n.pagination {\n  margin-left: 0;\n  margin-bottom: 1rem; }\n  .pagination::before, .pagination::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .pagination::after {\n    clear: both; }\n  .pagination li {\n    margin-right: 0.0625rem;\n    border-radius: 0;\n    font-size: 0.875rem;\n    display: none; }\n    .pagination li:last-child, .pagination li:first-child {\n      display: inline-block; }\n    @media print, screen and (min-width: 40em) {\n      .pagination li {\n        display: inline-block; } }\n  .pagination a,\n  .pagination button {\n    display: block;\n    padding: 0.1875rem 0.625rem;\n    border-radius: 0;\n    color: #0a0a0a; }\n    .pagination a:hover,\n    .pagination button:hover {\n      background: #e6e6e6; }\n  .pagination .current {\n    padding: 0.1875rem 0.625rem;\n    background: #1779ba;\n    color: #fefefe;\n    cursor: default; }\n  .pagination .disabled {\n    padding: 0.1875rem 0.625rem;\n    color: #cacaca;\n    cursor: not-allowed; }\n    .pagination .disabled:hover {\n      background: transparent; }\n  .pagination .ellipsis::after {\n    padding: 0.1875rem 0.625rem;\n    content: '\\2026';\n    color: #0a0a0a; }\n\n.pagination-previous a::before,\n.pagination-previous.disabled::before {\n  display: inline-block;\n  margin-right: 0.5rem;\n  content: '\\00ab'; }\n\n.pagination-next a::after,\n.pagination-next.disabled::after {\n  display: inline-block;\n  margin-left: 0.5rem;\n  content: '\\00bb'; }\n\n.has-tip {\n  position: relative;\n  display: inline-block;\n  border-bottom: dotted 1px #8a8a8a;\n  font-weight: bold;\n  cursor: help; }\n\n.tooltip {\n  position: absolute;\n  top: calc(100% + 0.6495rem);\n  z-index: 1200;\n  max-width: 10rem;\n  padding: 0.75rem;\n  border-radius: 0;\n  background-color: #0a0a0a;\n  font-size: 80%;\n  color: #fefefe; }\n  .tooltip::before {\n    position: absolute; }\n  .tooltip.bottom::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent #0a0a0a;\n    bottom: 100%; }\n  .tooltip.bottom.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.top::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #0a0a0a transparent transparent;\n    top: 100%;\n    bottom: auto; }\n  .tooltip.top.align-center::before {\n    left: 50%;\n    transform: translateX(-50%); }\n  .tooltip.left::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #0a0a0a;\n    left: 100%; }\n  .tooltip.left.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.right::before {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 0.75rem;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #0a0a0a transparent transparent;\n    right: 100%;\n    left: auto; }\n  .tooltip.right.align-center::before {\n    bottom: auto;\n    top: 50%;\n    transform: translateY(-50%); }\n  .tooltip.align-top::before {\n    bottom: auto;\n    top: 10%; }\n  .tooltip.align-bottom::before {\n    bottom: 10%;\n    top: auto; }\n  .tooltip.align-left::before {\n    left: 10%;\n    right: auto; }\n  .tooltip.align-right::before {\n    left: auto;\n    right: 10%; }\n\n.accordion {\n  margin-left: 0;\n  background: #fefefe;\n  list-style-type: none; }\n  .accordion[disabled] .accordion-title {\n    cursor: not-allowed; }\n\n.accordion-item:first-child > :first-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-item:last-child > :last-child {\n  border-radius: 0 0 0 0; }\n\n.accordion-title {\n  position: relative;\n  display: block;\n  padding: 1.25rem 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  font-size: 0.75rem;\n  line-height: 1;\n  color: #1779ba; }\n  :last-child:not(.is-active) > .accordion-title {\n    border-bottom: 1px solid #e6e6e6;\n    border-radius: 0 0 0 0; }\n  .accordion-title:hover, .accordion-title:focus {\n    background-color: #e6e6e6; }\n  .accordion-title::before {\n    position: absolute;\n    top: 50%;\n    right: 1rem;\n    margin-top: -0.5rem;\n    content: '+'; }\n  .is-active > .accordion-title::before {\n    content: '\\2013'; }\n\n.accordion-content {\n  display: none;\n  padding: 1rem;\n  border: 1px solid #e6e6e6;\n  border-bottom: 0;\n  background-color: #fefefe;\n  color: #0a0a0a; }\n  :last-child > .accordion-content:last-child {\n    border-bottom: 1px solid #e6e6e6; }\n\n.media-object {\n  display: flex;\n  margin-bottom: 1rem;\n  flex-wrap: nowrap; }\n  .media-object img {\n    max-width: none; }\n  @media screen and (max-width: 39.99875em) {\n    .media-object.stack-for-small {\n      flex-wrap: wrap; } }\n\n.media-object-section {\n  flex: 0 1 auto; }\n  .media-object-section:first-child {\n    padding-right: 1rem; }\n  .media-object-section:last-child:not(:nth-child(2)) {\n    padding-left: 1rem; }\n  .media-object-section > :last-child {\n    margin-bottom: 0; }\n  @media screen and (max-width: 39.99875em) {\n    .stack-for-small .media-object-section {\n      padding: 0;\n      padding-bottom: 1rem;\n      flex-basis: 100%;\n      max-width: 100%; }\n      .stack-for-small .media-object-section img {\n        width: 100%; } }\n  .media-object-section.main-section {\n    flex: 1 1 0px; }\n\n.orbit {\n  position: relative; }\n\n.orbit-container {\n  position: relative;\n  height: 0;\n  margin: 0;\n  list-style: none;\n  overflow: hidden; }\n\n.orbit-slide {\n  width: 100%;\n  position: absolute; }\n  .orbit-slide.no-motionui.is-active {\n    top: 0;\n    left: 0; }\n\n.orbit-figure {\n  margin: 0; }\n\n.orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0; }\n\n.orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: 1rem;\n  background-color: rgba(10, 10, 10, 0.5);\n  color: #fefefe; }\n\n.orbit-previous, .orbit-next {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n  z-index: 10;\n  padding: 1rem;\n  color: #fefefe; }\n  [data-whatinput='mouse'] .orbit-previous, [data-whatinput='mouse'] .orbit-next {\n    outline: 0; }\n  .orbit-previous:hover, .orbit-next:hover, .orbit-previous:active, .orbit-next:active, .orbit-previous:focus, .orbit-next:focus {\n    background-color: rgba(10, 10, 10, 0.5); }\n\n.orbit-previous {\n  left: 0; }\n\n.orbit-next {\n  left: auto;\n  right: 0; }\n\n.orbit-bullets {\n  position: relative;\n  margin-top: 0.8rem;\n  margin-bottom: 0.8rem;\n  text-align: center; }\n  [data-whatinput='mouse'] .orbit-bullets {\n    outline: 0; }\n  .orbit-bullets button {\n    width: 1.2rem;\n    height: 1.2rem;\n    margin: 0.1rem;\n    border-radius: 50%;\n    background-color: #cacaca; }\n    .orbit-bullets button:hover {\n      background-color: #8a8a8a; }\n    .orbit-bullets button.is-active {\n      background-color: #8a8a8a; }\n\n.responsive-embed,\n.flex-video {\n  position: relative;\n  height: 0;\n  margin-bottom: 1rem;\n  padding-bottom: 75%;\n  overflow: hidden; }\n  .responsive-embed iframe,\n  .responsive-embed object,\n  .responsive-embed embed,\n  .responsive-embed video,\n  .flex-video iframe,\n  .flex-video object,\n  .flex-video embed,\n  .flex-video video {\n    position: absolute;\n    top: 0;\n    left: 0;\n    width: 100%;\n    height: 100%; }\n  .responsive-embed.widescreen,\n  .flex-video.widescreen {\n    padding-bottom: 56.25%; }\n\n.tabs {\n  margin: 0;\n  border: 1px solid #e6e6e6;\n  background: #fefefe;\n  list-style-type: none; }\n  .tabs::before, .tabs::after {\n    display: table;\n    content: ' ';\n    flex-basis: 0;\n    order: 1; }\n  .tabs::after {\n    clear: both; }\n\n.tabs.vertical > li {\n  display: block;\n  float: none;\n  width: auto; }\n\n.tabs.simple > li > a {\n  padding: 0; }\n  .tabs.simple > li > a:hover {\n    background: transparent; }\n\n.tabs.primary {\n  background: #1779ba; }\n  .tabs.primary > li > a {\n    color: #fefefe; }\n    .tabs.primary > li > a:hover, .tabs.primary > li > a:focus {\n      background: #1673b1; }\n\n.tabs-title {\n  float: left; }\n  .tabs-title > a {\n    display: block;\n    padding: 1.25rem 1.5rem;\n    font-size: 0.75rem;\n    line-height: 1;\n    color: #1779ba; }\n    [data-whatinput='mouse'] .tabs-title > a {\n      outline: 0; }\n    .tabs-title > a:hover {\n      background: #fefefe;\n      color: #1468a0; }\n    .tabs-title > a:focus, .tabs-title > a[aria-selected='true'] {\n      background: #e6e6e6;\n      color: #1779ba; }\n\n.tabs-content {\n  border: 1px solid #e6e6e6;\n  border-top: 0;\n  background: #fefefe;\n  color: #0a0a0a;\n  transition: all 0.5s ease; }\n\n.tabs-content.vertical {\n  border: 1px solid #e6e6e6;\n  border-left: 0; }\n\n.tabs-panel {\n  display: none;\n  padding: 1rem; }\n  .tabs-panel.is-active {\n    display: block; }\n\n.thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: 1rem;\n  border: 4px solid #fefefe;\n  border-radius: 0;\n  box-shadow: 0 0 0 1px rgba(10, 10, 10, 0.2);\n  line-height: 0; }\n\na.thumbnail {\n  transition: box-shadow 200ms ease-out; }\n  a.thumbnail:hover, a.thumbnail:focus {\n    box-shadow: 0 0 6px 1px rgba(23, 121, 186, 0.5); }\n  a.thumbnail image {\n    box-shadow: none; }\n\n.menu {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n  display: flex;\n  flex-wrap: wrap; }\n  [data-whatinput='mouse'] .menu li {\n    outline: 0; }\n  .menu a,\n  .menu .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: 0.7rem 1rem; }\n  .menu input,\n  .menu select,\n  .menu a,\n  .menu button {\n    margin-bottom: 0; }\n  .menu input {\n    display: inline-block; }\n  .menu, .menu.horizontal {\n    flex-wrap: wrap;\n    flex-direction: row; }\n  .menu.vertical {\n    flex-wrap: nowrap;\n    flex-direction: column; }\n  .menu.expanded li {\n    flex: 1 1 0px; }\n  .menu.simple {\n    align-items: center; }\n    .menu.simple li + li {\n      margin-left: 1rem; }\n    .menu.simple a {\n      padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .menu.medium-horizontal {\n      flex-wrap: wrap;\n      flex-direction: row; }\n    .menu.medium-vertical {\n      flex-wrap: nowrap;\n      flex-direction: column; }\n    .menu.medium-expanded li {\n      flex: 1 1 0px; }\n    .menu.medium-simple li {\n      flex: 1 1 0px; } }\n  @media print, screen and (min-width: 64em) {\n    .menu.large-horizontal {\n      flex-wrap: wrap;\n      flex-direction: row; }\n    .menu.large-vertical {\n      flex-wrap: nowrap;\n      flex-direction: column; }\n    .menu.large-expanded li {\n      flex: 1 1 0px; }\n    .menu.large-simple li {\n      flex: 1 1 0px; } }\n  .menu.nested {\n    margin-right: 0;\n    margin-left: 1rem; }\n  .menu.icons a {\n    display: flex; }\n  .menu.icon-top a, .menu.icon-right a, .menu.icon-bottom a, .menu.icon-left a {\n    display: flex; }\n  .menu.icon-left li a {\n    flex-flow: row nowrap; }\n    .menu.icon-left li a img,\n    .menu.icon-left li a i,\n    .menu.icon-left li a svg {\n      margin-right: 0.25rem; }\n  .menu.icon-right li a {\n    flex-flow: row nowrap; }\n    .menu.icon-right li a img,\n    .menu.icon-right li a i,\n    .menu.icon-right li a svg {\n      margin-left: 0.25rem; }\n  .menu.icon-top li a {\n    flex-flow: column nowrap; }\n    .menu.icon-top li a img,\n    .menu.icon-top li a i,\n    .menu.icon-top li a svg {\n      align-self: stretch;\n      margin-bottom: 0.25rem;\n      text-align: center; }\n  .menu.icon-bottom li a {\n    flex-flow: column nowrap; }\n    .menu.icon-bottom li a img,\n    .menu.icon-bottom li a i,\n    .menu.icon-bottom li a svg {\n      align-self: stretch;\n      margin-bottom: 0.25rem;\n      text-align: center; }\n  .menu .is-active > a {\n    background: #1779ba;\n    color: #fefefe; }\n  .menu .active > a {\n    background: #1779ba;\n    color: #fefefe; }\n  .menu.align-left {\n    justify-content: flex-start; }\n  .menu.align-right li {\n    display: flex;\n    justify-content: flex-end; }\n    .menu.align-right li .submenu li {\n      justify-content: flex-start; }\n  .menu.align-right.vertical li {\n    display: block;\n    text-align: right; }\n    .menu.align-right.vertical li .submenu li {\n      text-align: right; }\n  .menu.align-right .nested {\n    margin-right: 1rem;\n    margin-left: 0; }\n  .menu.align-center li {\n    display: flex;\n    justify-content: center; }\n    .menu.align-center li .submenu li {\n      justify-content: flex-start; }\n  .menu .menu-text {\n    padding: 0.7rem 1rem;\n    font-weight: bold;\n    line-height: 1;\n    color: inherit; }\n\n.menu-centered > .menu {\n  justify-content: center; }\n  .menu-centered > .menu li {\n    display: flex;\n    justify-content: center; }\n    .menu-centered > .menu li .submenu li {\n      justify-content: flex-start; }\n\n.no-js [data-responsive-menu] ul {\n  display: none; }\n\n.menu-icon {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #fefefe;\n    box-shadow: 0 7px 0 #fefefe, 0 14px 0 #fefefe;\n    content: ''; }\n  .menu-icon:hover::after {\n    background: #cacaca;\n    box-shadow: 0 7px 0 #cacaca, 0 14px 0 #cacaca; }\n\n.menu-icon.dark {\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: 20px;\n  height: 16px;\n  cursor: pointer; }\n  .menu-icon.dark::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n    display: block;\n    width: 100%;\n    height: 2px;\n    background: #0a0a0a;\n    box-shadow: 0 7px 0 #0a0a0a, 0 14px 0 #0a0a0a;\n    content: ''; }\n  .menu-icon.dark:hover::after {\n    background: #8a8a8a;\n    box-shadow: 0 7px 0 #8a8a8a, 0 14px 0 #8a8a8a; }\n\n.accordion-menu li {\n  width: 100%; }\n\n.accordion-menu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .is-accordion-submenu a {\n  padding: 0.7rem 1rem; }\n\n.accordion-menu .nested.is-accordion-submenu {\n  margin-right: 0;\n  margin-left: 1rem; }\n\n.accordion-menu.align-right .nested.is-accordion-submenu {\n  margin-right: 1rem;\n  margin-left: 0; }\n\n.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n  position: relative; }\n  .accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle) > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    position: absolute;\n    top: 50%;\n    margin-top: -3px;\n    right: 1rem; }\n\n.accordion-menu.align-left .is-accordion-submenu-parent > a::after {\n  right: 1rem;\n  left: auto; }\n\n.accordion-menu.align-right .is-accordion-submenu-parent > a::after {\n  right: auto;\n  left: 1rem; }\n\n.accordion-menu .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n  transform: rotate(180deg);\n  transform-origin: 50% 50%; }\n\n.is-accordion-submenu-parent {\n  position: relative; }\n\n.has-submenu-toggle > a {\n  margin-right: 40px; }\n\n.submenu-toggle {\n  position: absolute;\n  top: 0;\n  right: 0;\n  width: 40px;\n  height: 40px;\n  cursor: pointer; }\n  .submenu-toggle::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    top: 0;\n    bottom: 0;\n    margin: auto; }\n\n.submenu-toggle[aria-expanded='true']::after {\n  transform: scaleY(-1);\n  transform-origin: 50% 50%; }\n\n.submenu-toggle-text {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  white-space: nowrap;\n  border: 0; }\n\n.is-drilldown {\n  position: relative;\n  overflow: hidden; }\n  .is-drilldown li {\n    display: block; }\n  .is-drilldown.animate-height {\n    transition: height 0.5s; }\n\n.drilldown a {\n  padding: 0.7rem 1rem;\n  background: #fefefe; }\n\n.drilldown .is-drilldown-submenu {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  z-index: -1;\n  width: 100%;\n  background: #fefefe;\n  transition: transform 0.15s linear; }\n  .drilldown .is-drilldown-submenu.is-active {\n    z-index: 1;\n    display: block;\n    transform: translateX(-100%); }\n  .drilldown .is-drilldown-submenu.is-closing {\n    transform: translateX(100%); }\n  .drilldown .is-drilldown-submenu a {\n    padding: 0.7rem 1rem; }\n\n.drilldown .nested.is-drilldown-submenu {\n  margin-right: 0;\n  margin-left: 0; }\n\n.drilldown .drilldown-submenu-cover-previous {\n  min-height: 100%; }\n\n.drilldown .is-drilldown-submenu-parent > a {\n  position: relative; }\n  .drilldown .is-drilldown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba;\n    position: absolute;\n    top: 50%;\n    margin-top: -6px;\n    right: 1rem; }\n\n.drilldown.align-left .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba;\n  right: 1rem;\n  left: auto; }\n\n.drilldown.align-right .is-drilldown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  right: auto;\n  left: 1rem; }\n\n.drilldown .js-drilldown-back > a::before {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  display: inline-block;\n  vertical-align: middle;\n  margin-right: 0.75rem; }\n\n.dropdown.menu > li.opens-left > .is-dropdown-submenu {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.dropdown.menu > li.opens-right > .is-dropdown-submenu {\n  top: 100%;\n  right: auto;\n  left: 0; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a {\n  position: relative;\n  padding-right: 1.5rem; }\n\n.dropdown.menu > li.is-dropdown-submenu-parent > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-bottom-width: 0;\n  border-top-style: solid;\n  border-color: #1779ba transparent transparent;\n  right: 5px;\n  left: auto;\n  margin-top: -3px; }\n\n[data-whatinput='mouse'] .dropdown.menu a {\n  outline: 0; }\n\n.dropdown.menu > li > a {\n  padding: 0.7rem 1rem; }\n\n.dropdown.menu > li.is-active > a {\n  background: transparent;\n  color: #1779ba; }\n\n.no-js .dropdown.menu ul {\n  display: none; }\n\n.dropdown.menu .nested.is-dropdown-submenu {\n  margin-right: 0;\n  margin-left: 0; }\n\n.dropdown.menu.vertical > li .is-dropdown-submenu {\n  top: 0; }\n\n.dropdown.menu.vertical > li.opens-left > .is-dropdown-submenu {\n  top: 0;\n  right: 100%;\n  left: auto; }\n\n.dropdown.menu.vertical > li.opens-right > .is-dropdown-submenu {\n  right: auto;\n  left: 100%; }\n\n.dropdown.menu.vertical > li > a::after {\n  right: 14px; }\n\n.dropdown.menu.vertical > li.opens-left > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-left-width: 0;\n  border-right-style: solid;\n  border-color: transparent #1779ba transparent transparent;\n  right: auto;\n  left: 5px; }\n\n.dropdown.menu.vertical > li.opens-right > a::after {\n  display: block;\n  width: 0;\n  height: 0;\n  border: inset 6px;\n  content: '';\n  border-right-width: 0;\n  border-left-style: solid;\n  border-color: transparent transparent transparent #1779ba; }\n\n@media print, screen and (min-width: 40em) {\n  .dropdown.menu.medium-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.medium-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem; }\n  .dropdown.menu.medium-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    right: 5px;\n    left: auto;\n    margin-top: -3px; }\n  .dropdown.menu.medium-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.medium-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.medium-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.medium-vertical > li > a::after {\n    right: 14px; }\n  .dropdown.menu.medium-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.medium-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; } }\n\n@media print, screen and (min-width: 64em) {\n  .dropdown.menu.large-horizontal > li.opens-left > .is-dropdown-submenu {\n    top: 100%;\n    right: 0;\n    left: auto; }\n  .dropdown.menu.large-horizontal > li.opens-right > .is-dropdown-submenu {\n    top: 100%;\n    right: auto;\n    left: 0; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a {\n    position: relative;\n    padding-right: 1.5rem; }\n  .dropdown.menu.large-horizontal > li.is-dropdown-submenu-parent > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: #1779ba transparent transparent;\n    right: 5px;\n    left: auto;\n    margin-top: -3px; }\n  .dropdown.menu.large-vertical > li .is-dropdown-submenu {\n    top: 0; }\n  .dropdown.menu.large-vertical > li.opens-left > .is-dropdown-submenu {\n    top: 0;\n    right: 100%;\n    left: auto; }\n  .dropdown.menu.large-vertical > li.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n  .dropdown.menu.large-vertical > li > a::after {\n    right: 14px; }\n  .dropdown.menu.large-vertical > li.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .dropdown.menu.large-vertical > li.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; } }\n\n.dropdown.menu.align-right .is-dropdown-submenu.first-sub {\n  top: 100%;\n  right: 0;\n  left: auto; }\n\n.is-dropdown-menu.vertical {\n  width: 100px; }\n  .is-dropdown-menu.vertical.align-right {\n    float: right; }\n\n.is-dropdown-submenu-parent {\n  position: relative; }\n  .is-dropdown-submenu-parent a::after {\n    position: absolute;\n    top: 50%;\n    right: 5px;\n    left: auto;\n    margin-top: -6px; }\n  .is-dropdown-submenu-parent.opens-inner > .is-dropdown-submenu {\n    top: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-left > .is-dropdown-submenu {\n    right: 100%;\n    left: auto; }\n  .is-dropdown-submenu-parent.opens-right > .is-dropdown-submenu {\n    right: auto;\n    left: 100%; }\n\n.is-dropdown-submenu {\n  position: absolute;\n  top: 0;\n  left: 100%;\n  z-index: 1;\n  display: none;\n  min-width: 200px;\n  border: 1px solid #cacaca;\n  background: #fefefe; }\n  .dropdown .is-dropdown-submenu a {\n    padding: 0.7rem 1rem; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent > a::after {\n    right: 14px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-left > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent #1779ba transparent transparent;\n    right: auto;\n    left: 5px; }\n  .is-dropdown-submenu .is-dropdown-submenu-parent.opens-right > a::after {\n    display: block;\n    width: 0;\n    height: 0;\n    border: inset 6px;\n    content: '';\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent #1779ba; }\n  .is-dropdown-submenu .is-dropdown-submenu {\n    margin-top: -1px; }\n  .is-dropdown-submenu > li {\n    width: 100%; }\n  .is-dropdown-submenu.js-dropdown-active {\n    display: block; }\n\n.is-off-canvas-open {\n  overflow: hidden; }\n\n.js-off-canvas-overlay {\n  position: absolute;\n  top: 0;\n  left: 0;\n  z-index: 11;\n  width: 100%;\n  height: 100%;\n  transition: opacity 0.5s ease, visibility 0.5s ease;\n  background: rgba(254, 254, 254, 0.25);\n  opacity: 0;\n  visibility: hidden;\n  overflow: hidden; }\n  .js-off-canvas-overlay.is-visible {\n    opacity: 1;\n    visibility: visible; }\n  .js-off-canvas-overlay.is-closable {\n    cursor: pointer; }\n  .js-off-canvas-overlay.is-overlay-absolute {\n    position: absolute; }\n  .js-off-canvas-overlay.is-overlay-fixed {\n    position: fixed; }\n\n.off-canvas-wrapper {\n  position: relative;\n  overflow: hidden; }\n\n.off-canvas {\n  position: fixed;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas {\n    outline: 0; }\n  .off-canvas.is-transition-push {\n    z-index: 12; }\n  .off-canvas.is-closed {\n    visibility: hidden; }\n  .off-canvas.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n.off-canvas-absolute {\n  position: absolute;\n  z-index: 12;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden;\n  background: #e6e6e6; }\n  [data-whatinput='mouse'] .off-canvas-absolute {\n    outline: 0; }\n  .off-canvas-absolute.is-transition-push {\n    z-index: 12; }\n  .off-canvas-absolute.is-closed {\n    visibility: hidden; }\n  .off-canvas-absolute.is-transition-overlap {\n    z-index: 13; }\n    .off-canvas-absolute.is-transition-overlap.is-open {\n      box-shadow: 0 0 10px rgba(10, 10, 10, 0.7); }\n  .off-canvas-absolute.is-open {\n    transform: translate(0, 0); }\n\n.position-left {\n  top: 0;\n  left: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(-250px); }\n  .off-canvas-content .off-canvas.position-left {\n    transform: translateX(-250px); }\n    .off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-left.has-transition-push {\n    transform: translateX(250px); }\n  .position-left.is-transition-push {\n    box-shadow: inset -13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-right {\n  top: 0;\n  right: 0;\n  height: 100%;\n  overflow-y: auto;\n  width: 250px;\n  transform: translateX(250px); }\n  .off-canvas-content .off-canvas.position-right {\n    transform: translateX(250px); }\n    .off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-right.has-transition-push {\n    transform: translateX(-250px); }\n  .position-right.is-transition-push {\n    box-shadow: inset 13px 0 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-top {\n  top: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(-250px); }\n  .off-canvas-content .off-canvas.position-top {\n    transform: translateY(-250px); }\n    .off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-top.has-transition-push {\n    transform: translateY(250px); }\n  .position-top.is-transition-push {\n    box-shadow: inset 0 -13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.position-bottom {\n  bottom: 0;\n  left: 0;\n  width: 100%;\n  overflow-x: auto;\n  height: 250px;\n  transform: translateY(250px); }\n  .off-canvas-content .off-canvas.position-bottom {\n    transform: translateY(250px); }\n    .off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open {\n      transform: translate(0, 0); }\n  .off-canvas-content.is-open-bottom.has-transition-push {\n    transform: translateY(-250px); }\n  .position-bottom.is-transition-push {\n    box-shadow: inset 0 13px 20px -13px rgba(10, 10, 10, 0.25); }\n\n.off-canvas-content {\n  transform: none;\n  transition: transform 0.5s ease;\n  backface-visibility: hidden; }\n  .off-canvas-content.has-transition-push {\n    transform: translate(0, 0); }\n  .off-canvas-content .off-canvas.is-open {\n    transform: translate(0, 0); }\n\n@media print, screen and (min-width: 40em) {\n  .position-left.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-medium ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-medium ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-medium ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-medium {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-medium .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-medium {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-medium ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 64em) {\n  .position-left.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-left.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-left.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-left {\n      margin-left: 250px; }\n    .position-left.reveal-for-large ~ .off-canvas-content {\n      margin-left: 250px; }\n  .position-right.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-right.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-right.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-right {\n      margin-right: 250px; }\n    .position-right.reveal-for-large ~ .off-canvas-content {\n      margin-right: 250px; }\n  .position-top.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-top.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-top.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-top {\n      margin-top: 250px; }\n    .position-top.reveal-for-large ~ .off-canvas-content {\n      margin-top: 250px; }\n  .position-bottom.reveal-for-large {\n    transform: none;\n    z-index: 12;\n    transition: none;\n    visibility: visible; }\n    .position-bottom.reveal-for-large .close-button {\n      display: none; }\n    .off-canvas-content .position-bottom.reveal-for-large {\n      transform: none; }\n    .off-canvas-content.has-reveal-bottom {\n      margin-bottom: 250px; }\n    .position-bottom.reveal-for-large ~ .off-canvas-content {\n      margin-bottom: 250px; } }\n\n@media print, screen and (min-width: 40em) {\n  .off-canvas.in-canvas-for-medium {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-medium.position-left, .off-canvas.in-canvas-for-medium.position-right, .off-canvas.in-canvas-for-medium.position-top, .off-canvas.in-canvas-for-medium.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-medium .close-button {\n      display: none; } }\n\n@media print, screen and (min-width: 64em) {\n  .off-canvas.in-canvas-for-large {\n    visibility: visible;\n    height: auto;\n    position: static;\n    background: none;\n    width: auto;\n    overflow: visible;\n    transition: none; }\n    .off-canvas.in-canvas-for-large.position-left, .off-canvas.in-canvas-for-large.position-right, .off-canvas.in-canvas-for-large.position-top, .off-canvas.in-canvas-for-large.position-bottom {\n      box-shadow: none;\n      transform: none; }\n    .off-canvas.in-canvas-for-large .close-button {\n      display: none; } }\n\nhtml.is-reveal-open {\n  position: fixed;\n  width: 100%;\n  overflow-y: hidden; }\n  html.is-reveal-open.zf-has-scroll {\n    overflow-y: scroll; }\n  html.is-reveal-open body {\n    overflow-y: hidden; }\n\n.reveal-overlay {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: 1005;\n  display: none;\n  background-color: rgba(10, 10, 10, 0.45);\n  overflow-y: auto; }\n\n.reveal {\n  z-index: 1006;\n  backface-visibility: hidden;\n  display: none;\n  padding: 1rem;\n  border: 1px solid #cacaca;\n  border-radius: 0;\n  background-color: #fefefe;\n  position: relative;\n  top: 100px;\n  margin-right: auto;\n  margin-left: auto;\n  overflow-y: auto; }\n  [data-whatinput='mouse'] .reveal {\n    outline: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      min-height: 0; } }\n  .reveal .column {\n    min-width: 0; }\n  .reveal > :last-child {\n    margin-bottom: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal {\n      width: 600px;\n      max-width: 75rem; } }\n  .reveal.collapse {\n    padding: 0; }\n  @media print, screen and (min-width: 40em) {\n    .reveal.tiny {\n      width: 30%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.small {\n      width: 50%;\n      max-width: 75rem; } }\n  @media print, screen and (min-width: 40em) {\n    .reveal.large {\n      width: 90%;\n      max-width: 75rem; } }\n  .reveal.full {\n    top: 0;\n    right: 0;\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    max-width: none;\n    height: 100%;\n    min-height: 100%;\n    margin-left: 0;\n    border: 0;\n    border-radius: 0; }\n  @media screen and (max-width: 39.99875em) {\n    .reveal {\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      width: 100%;\n      max-width: none;\n      height: 100%;\n      min-height: 100%;\n      margin-left: 0;\n      border: 0;\n      border-radius: 0; } }\n  .reveal.without-overlay {\n    position: fixed; }\n\n.sticky-container {\n  position: relative; }\n\n.sticky {\n  position: relative;\n  z-index: 0;\n  transform: translate3d(0, 0, 0); }\n\n.sticky.is-stuck {\n  position: fixed;\n  z-index: 5;\n  width: 100%; }\n  .sticky.is-stuck.is-at-top {\n    top: 0; }\n  .sticky.is-stuck.is-at-bottom {\n    bottom: 0; }\n\n.sticky.is-anchored {\n  position: relative;\n  right: auto;\n  left: auto; }\n  .sticky.is-anchored.is-at-bottom {\n    bottom: 0; }\n\n.title-bar {\n  padding: 0.5rem;\n  background: #0a0a0a;\n  color: #fefefe;\n  display: flex;\n  justify-content: flex-start;\n  align-items: center; }\n  .title-bar .menu-icon {\n    margin-left: 0.25rem;\n    margin-right: 0.25rem; }\n\n.title-bar-left,\n.title-bar-right {\n  flex: 1 1 0px; }\n\n.title-bar-right {\n  text-align: right; }\n\n.title-bar-title {\n  display: inline-block;\n  vertical-align: middle;\n  font-weight: bold; }\n\n.top-bar {\n  display: flex;\n  flex-wrap: nowrap;\n  justify-content: space-between;\n  align-items: center;\n  padding: 0.5rem;\n  flex-wrap: wrap; }\n  .top-bar,\n  .top-bar ul {\n    background-color: #e6e6e6; }\n  .top-bar input {\n    max-width: 200px;\n    margin-right: 1rem; }\n  .top-bar .input-group-field {\n    width: 100%;\n    margin-right: 0; }\n  .top-bar input.button {\n    width: auto; }\n  .top-bar .top-bar-left,\n  .top-bar .top-bar-right {\n    flex: 0 0 100%;\n    max-width: 100%; }\n  @media print, screen and (min-width: 40em) {\n    .top-bar {\n      flex-wrap: nowrap; }\n      .top-bar .top-bar-left {\n        flex: 1 1 auto;\n        margin-right: auto; }\n      .top-bar .top-bar-right {\n        flex: 0 1 auto;\n        margin-left: auto; } }\n  @media screen and (max-width: 63.99875em) {\n    .top-bar.stacked-for-medium {\n      flex-wrap: wrap; }\n      .top-bar.stacked-for-medium .top-bar-left,\n      .top-bar.stacked-for-medium .top-bar-right {\n        flex: 0 0 100%;\n        max-width: 100%; } }\n  @media screen and (max-width: 74.99875em) {\n    .top-bar.stacked-for-large {\n      flex-wrap: wrap; }\n      .top-bar.stacked-for-large .top-bar-left,\n      .top-bar.stacked-for-large .top-bar-right {\n        flex: 0 0 100%;\n        max-width: 100%; } }\n\n.top-bar-title {\n  flex: 0 0 auto;\n  margin: 0.5rem 1rem 0.5rem 0; }\n\n.top-bar-left,\n.top-bar-right {\n  flex: 0 0 auto; }\n\n.float-left {\n  float: left !important; }\n\n.float-right {\n  float: right !important; }\n\n.float-center {\n  display: block;\n  margin-right: auto;\n  margin-left: auto; }\n\n.clearfix::before, .clearfix::after {\n  display: table;\n  content: ' ';\n  flex-basis: 0;\n  order: 1; }\n\n.clearfix::after {\n  clear: both; }\n\n.align-left {\n  justify-content: flex-start; }\n\n.align-right {\n  justify-content: flex-end; }\n\n.align-center {\n  justify-content: center; }\n\n.align-justify {\n  justify-content: space-between; }\n\n.align-spaced {\n  justify-content: space-around; }\n\n.align-left.vertical.menu > li > a {\n  justify-content: flex-start; }\n\n.align-right.vertical.menu > li > a {\n  justify-content: flex-end; }\n\n.align-center.vertical.menu > li > a {\n  justify-content: center; }\n\n.align-top {\n  align-items: flex-start; }\n\n.align-self-top {\n  align-self: flex-start; }\n\n.align-bottom {\n  align-items: flex-end; }\n\n.align-self-bottom {\n  align-self: flex-end; }\n\n.align-middle {\n  align-items: center; }\n\n.align-self-middle {\n  align-self: center; }\n\n.align-stretch {\n  align-items: stretch; }\n\n.align-self-stretch {\n  align-self: stretch; }\n\n.align-center-middle {\n  justify-content: center;\n  align-items: center;\n  align-content: center; }\n\n.small-order-1 {\n  order: 1; }\n\n.small-order-2 {\n  order: 2; }\n\n.small-order-3 {\n  order: 3; }\n\n.small-order-4 {\n  order: 4; }\n\n.small-order-5 {\n  order: 5; }\n\n.small-order-6 {\n  order: 6; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-order-1 {\n    order: 1; }\n  .medium-order-2 {\n    order: 2; }\n  .medium-order-3 {\n    order: 3; }\n  .medium-order-4 {\n    order: 4; }\n  .medium-order-5 {\n    order: 5; }\n  .medium-order-6 {\n    order: 6; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-order-1 {\n    order: 1; }\n  .large-order-2 {\n    order: 2; }\n  .large-order-3 {\n    order: 3; }\n  .large-order-4 {\n    order: 4; }\n  .large-order-5 {\n    order: 5; }\n  .large-order-6 {\n    order: 6; } }\n\n.flex-container {\n  display: flex; }\n\n.flex-child-auto {\n  flex: 1 1 auto; }\n\n.flex-child-grow {\n  flex: 1 0 auto; }\n\n.flex-child-shrink {\n  flex: 0 1 auto; }\n\n.flex-dir-row {\n  flex-direction: row; }\n\n.flex-dir-row-reverse {\n  flex-direction: row-reverse; }\n\n.flex-dir-column {\n  flex-direction: column; }\n\n.flex-dir-column-reverse {\n  flex-direction: column-reverse; }\n\n@media print, screen and (min-width: 40em) {\n  .medium-flex-container {\n    display: flex; }\n  .medium-flex-child-auto {\n    flex: 1 1 auto; }\n  .medium-flex-child-grow {\n    flex: 1 0 auto; }\n  .medium-flex-child-shrink {\n    flex: 0 1 auto; }\n  .medium-flex-dir-row {\n    flex-direction: row; }\n  .medium-flex-dir-row-reverse {\n    flex-direction: row-reverse; }\n  .medium-flex-dir-column {\n    flex-direction: column; }\n  .medium-flex-dir-column-reverse {\n    flex-direction: column-reverse; } }\n\n@media print, screen and (min-width: 64em) {\n  .large-flex-container {\n    display: flex; }\n  .large-flex-child-auto {\n    flex: 1 1 auto; }\n  .large-flex-child-grow {\n    flex: 1 0 auto; }\n  .large-flex-child-shrink {\n    flex: 0 1 auto; }\n  .large-flex-dir-row {\n    flex-direction: row; }\n  .large-flex-dir-row-reverse {\n    flex-direction: row-reverse; }\n  .large-flex-dir-column {\n    flex-direction: column; }\n  .large-flex-dir-column-reverse {\n    flex-direction: column-reverse; } }\n\n.hide {\n  display: none !important; }\n\n.invisible {\n  visibility: hidden; }\n\n@media screen and (max-width: 39.99875em) {\n  .hide-for-small-only {\n    display: none !important; } }\n\n@media screen and (max-width: 0em), screen and (min-width: 40em) {\n  .show-for-small-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 40em) {\n  .hide-for-medium {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em) {\n  .show-for-medium {\n    display: none !important; } }\n\n@media screen and (min-width: 40em) and (max-width: 63.99875em) {\n  .hide-for-medium-only {\n    display: none !important; } }\n\n@media screen and (max-width: 39.99875em), screen and (min-width: 64em) {\n  .show-for-medium-only {\n    display: none !important; } }\n\n@media print, screen and (min-width: 64em) {\n  .hide-for-large {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em) {\n  .show-for-large {\n    display: none !important; } }\n\n@media screen and (min-width: 64em) and (max-width: 74.99875em) {\n  .hide-for-large-only {\n    display: none !important; } }\n\n@media screen and (max-width: 63.99875em), screen and (min-width: 75em) {\n  .show-for-large-only {\n    display: none !important; } }\n\n.show-for-sr,\n.show-on-focus {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0, 0, 0, 0);\n  white-space: nowrap;\n  border: 0; }\n\n.show-on-focus:active, .show-on-focus:focus {\n  position: static !important;\n  width: auto;\n  height: auto;\n  overflow: visible;\n  clip: auto;\n  white-space: normal; }\n\n.show-for-landscape,\n.hide-for-portrait {\n  display: block !important; }\n  @media screen and (orientation: landscape) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: block !important; } }\n  @media screen and (orientation: portrait) {\n    .show-for-landscape,\n    .hide-for-portrait {\n      display: none !important; } }\n\n.hide-for-landscape,\n.show-for-portrait {\n  display: none !important; }\n  @media screen and (orientation: landscape) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: none !important; } }\n  @media screen and (orientation: portrait) {\n    .hide-for-landscape,\n    .show-for-portrait {\n      display: block !important; } }\n","/**\n * Foundation for Sites by ZURB\n * Version 6.5.3\n * foundation.zurb.com\n * Licensed under MIT Open Source\n */\n\n// Dependencies\n@import 'vendor/normalize';\n@import '../_vendor/sassy-lists/stylesheets/helpers/missing-dependencies';\n@import '../_vendor/sassy-lists/stylesheets/helpers/true';\n@import '../_vendor/sassy-lists/stylesheets/functions/contain';\n@import '../_vendor/sassy-lists/stylesheets/functions/purge';\n@import '../_vendor/sassy-lists/stylesheets/functions/remove';\n@import '../_vendor/sassy-lists/stylesheets/functions/replace';\n@import '../_vendor/sassy-lists/stylesheets/functions/to-list';\n\n// --- Settings ---\n// import your own `settings` here or\n// import and modify the default settings through\n// @import 'settings/settings';\n\n// --- Components ---\n// Utilities\n@import 'util/util';\n// Global styles\n@import 'global';\n@import 'forms/forms';\n@import 'typography/typography';\n\n// Grids\n@import 'grid/grid';\n@import 'xy-grid/xy-grid';\n// Generic components\n@import 'components/button';\n@import 'components/button-group';\n@import 'components/close-button';\n@import 'components/label';\n@import 'components/progress-bar';\n@import 'components/slider';\n@import 'components/switch';\n@import 'components/table';\n// Basic components\n@import 'components/badge';\n@import 'components/breadcrumbs';\n@import 'components/callout';\n@import 'components/card';\n@import 'components/dropdown';\n@import 'components/pagination';\n@import 'components/tooltip';\n\n// Containers\n@import 'components/accordion';\n@import 'components/media-object';\n@import 'components/orbit';\n@import 'components/responsive-embed';\n@import 'components/tabs';\n@import 'components/thumbnail';\n// Menu-based containers\n@import 'components/menu';\n@import 'components/menu-icon';\n@import 'components/accordion-menu';\n@import 'components/drilldown';\n@import 'components/dropdown-menu';\n\n// Layout components\n@import 'components/off-canvas';\n@import 'components/reveal';\n@import 'components/sticky';\n@import 'components/title-bar';\n@import 'components/top-bar';\n\n// Helpers\n@import 'components/float';\n@import 'components/flex';\n@import 'components/visibility';\n@import 'prototype/prototype';\n\n\n@mixin foundation-everything(\n  $flex: true,\n  $prototype: false\n) {\n  @if $flex {\n    $global-flexbox: true !global;\n  }\n\n  // Global styles\n  @include foundation-global-styles;\n  @include foundation-forms;\n  @include foundation-typography;\n\n  // Grids\n  @if not $flex {\n    @include foundation-grid;\n  }\n  @else {\n    @if $xy-grid {\n      @include foundation-xy-grid-classes;\n    }\n    @else {\n      @include foundation-flex-grid;\n    }\n  }\n\n  // Generic components\n  @include foundation-button;\n  @include foundation-button-group;\n  @include foundation-close-button;\n  @include foundation-label;\n  @include foundation-progress-bar;\n  @include foundation-slider;\n  @include foundation-switch;\n  @include foundation-table;\n  // Basic components\n  @include foundation-badge;\n  @include foundation-breadcrumbs;\n  @include foundation-callout;\n  @include foundation-card;\n  @include foundation-dropdown;\n  @include foundation-pagination;\n  @include foundation-tooltip;\n\n  // Containers\n  @include foundation-accordion;\n  @include foundation-media-object;\n  @include foundation-orbit;\n  @include foundation-responsive-embed;\n  @include foundation-tabs;\n  @include foundation-thumbnail;\n  // Menu-based containers\n  @include foundation-menu;\n  @include foundation-menu-icon;\n  @include foundation-accordion-menu;\n  @include foundation-drilldown-menu;\n  @include foundation-dropdown-menu;\n\n  // Layout components\n  @include foundation-off-canvas;\n  @include foundation-reveal;\n  @include foundation-sticky;\n  @include foundation-title-bar;\n  @include foundation-top-bar;\n\n  // Helpers\n  @include foundation-float-classes;\n  @if $flex { @include foundation-flex-classes; }\n  @include foundation-visibility-classes;\n  @if $prototype { @include foundation-prototype-classes; }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group breakpoints\n////\n\n/// A list of named breakpoints. You can use these with the `breakpoint()` mixin to quickly create media queries.\n/// @type Map\n$breakpoints: (\n  small: 0,\n  medium: 640px,\n  large: 1024px,\n  xlarge: 1200px,\n  xxlarge: 1440px,\n) !default;\n\n/// The largest named breakpoint in which to include print as a media type\n/// @type Keyword\n$print-breakpoint: large !default;\n\n$-zf-zero-breakpoint: small !default;\n\n$-zf-breakpoints-keys: map-to-list($breakpoints, 'keys');\n\n@if nth(map-values($breakpoints), 1) != 0 {\n  @error 'The first key in the $breakpoints map must have a value of \"0\".';\n}\n@else {\n  $-zf-zero-breakpoint: nth(map-keys($breakpoints), 1);\n}\n\n/// All of the names in this list will be output as classes in your CSS, like `.small-12`, `.medium-6`, and so on. Each value in this list must also be in the `$breakpoints` map.\n/// @type List\n$breakpoint-classes: (small medium large) !default;\n\n/// Generates a media query string matching the input value. Refer to the documentation for the `breakpoint()` mixin to see what the possible inputs are.\n///\n/// @param {Keyword|Number} $val [small] - Breakpoint name, or px, rem, or em value to process.\n@function breakpoint($val: $-zf-zero-breakpoint) {\n  // Size or keyword\n  $bp: nth($val, 1);\n  // Value for max-width media queries\n  $bp-max: 0;\n  // Direction of media query (up, down, or only)\n  $dir: if(length($val) > 1, nth($val, 2), up);\n  // Eventual output\n  $str: '';\n  // Is it a named media query?\n  $named: false;\n\n  // Orientation media queries have a unique syntax\n  @if $bp == 'landscape' or $bp == 'portrait' {\n    @return '(orientation: #{$bp})';\n  }\n  @else if $bp == 'retina' {\n    @return '(-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi)';\n  }\n\n  // Try to pull a named breakpoint out of the $breakpoints map\n  @if type-of($bp) == 'string' {\n    @if map-has-key($breakpoints, $bp) {\n      @if $dir == 'only' or $dir == 'down' {\n        $bp-max: -zf-map-next($breakpoints, $bp);\n      }\n\n      $bp: map-get($breakpoints, $bp);\n      $named: true;\n    }\n    @else {\n      $bp: 0;\n      @warn 'breakpoint(): \"#{$val}\" is not defined in your $breakpoints setting.';\n    }\n  }\n\n  // Convert any pixel, rem, or unitless value to em\n  $bp: -zf-bp-to-em($bp);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/zurb/foundation-sites/issues/11313\n  @if $bp-max {\n    $bp-max: -zf-bp-to-em($bp-max) - .00125;\n  }\n\n  // Conditions to skip media query creation\n  // - It's a named breakpoint that resolved to \"0 down\" or \"0 up\"\n  // - It's a numeric breakpoint that resolved to \"0 \" + anything\n  @if $bp > 0em or $dir == 'only' or $dir == 'down' {\n    // `only` ranges use the format `(min-width: n) and (max-width: n)`\n    @if $dir == 'only' {\n      // Only named media queries can have an \"only\" range\n      @if $named == true {\n        // Only use \"min-width\" if the floor is greater than 0\n        @if $bp > 0em {\n          $str: $str + '(min-width: #{$bp})';\n\n          // Only add \"and\" to the media query if there's a ceiling\n          @if $bp-max != null {\n            $str: $str + ' and ';\n          }\n        }\n\n        // Only use \"max-width\" if there's a ceiling\n        @if $bp-max != null {\n          $str: $str + '(max-width: #{$bp-max})';\n        }\n      }\n      @else {\n        @warn 'breakpoint(): Only named media queries can have an `only` range.';\n      }\n    }\n\n    // `down` ranges use the format `(max-width: n)`\n    @else if $dir == 'down' {\n      $max: if($named, $bp-max, $bp);\n\n      // Skip media query creation if input value is exactly \"0 down\",\n      // unless the function was called as \"small down\", in which case it's just \"small only\"\n      @if $named or $bp > 0em {\n        @if $max != null {\n          $str: $str + '(max-width: #{$max})';\n        }\n      }\n    }\n\n    // `up` ranges use the format `(min-width: n)`\n    @else if $bp > 0em {\n      $str: $str + '(min-width: #{$bp})';\n    }\n  }\n\n  @return $str;\n}\n\n/// Wraps a media query around the content you put inside the mixin. This mixin accepts a number of values:\n///  - If a string is passed, the mixin will look for it in the `$breakpoints` map, and use a media query there.\n///  - If a pixel value is passed, it will be converted to an em value using `$global-font-size` as the base.\n///  - If a rem value is passed, the unit will be changed to em.\n///  - If an em value is passed, the value will be used as-is.\n///\n/// @param {Keyword|Number} $value - Breakpoint name, or px, rem, or em value to process.\n///\n/// @output If the breakpoint is \"0px and larger\", outputs the content as-is. Otherwise, outputs the content wrapped in a media query.\n@mixin breakpoint($value) {\n  $str: breakpoint($value);\n  $bp: index($-zf-breakpoints-keys, $value);\n  $pbp: index($-zf-breakpoints-keys, $print-breakpoint);\n\n  $old-zf-size: null;\n\n  // Make breakpoint size available as a variable\n  @if global-variable-exists(-zf-size) {\n    $old-zf-size: $-zf-size;\n  }\n  $-zf-size: nth($value, 1) !global; // get the first value to account for `only` and `down` keywords\n\n  // If $str is still an empty string, no media query is needed\n  @if $str == '' {\n    @content;\n  }\n\n  // Otherwise, wrap the content in a media query\n  @else {\n    // For named breakpoints less than or equal to $print-breakpoint, add print to the media types\n    @if $bp != null and $bp <= $pbp {\n      @media print, screen and #{$str} {\n        @content;\n       }\n    }\n    @else {\n      @media screen and #{$str} {\n        @content;\n      }\n    }\n  }\n\n  $-zf-size: $old-zf-size !global;\n}\n\n/// Converts the breakpoints map to a URL-encoded string, like this: `key1=value1&key2=value2`. The value is then dropped into the CSS for a special `<meta>` tag, which is read by the Foundation JavaScript. This is how we transfer values from Sass to JavaScript, so they can be defined in one place.\n/// @access private\n///\n/// @param {Map} $map - Map to convert.\n///\n/// @returns {String} A string containing the map's contents.\n@function -zf-bp-serialize($map) {\n  $str: '';\n  @each $key, $value in $map {\n    $str: $str + $key + '=' + -zf-bp-to-em($value) + '&';\n  }\n  $str: str-slice($str, 1, -2);\n\n  @return $str;\n}\n\n/// Find the next key in a map.\n/// @access private\n///\n/// @param {Map} $map - Map to traverse.\n/// @param {Mixed} $key - Key to use as a starting point.\n///\n/// @returns {Mixed} The value for the key after `$key`, if `$key` was found. If `$key` was not found, or `$key` was the last value in the map, returns `null`.\n@function -zf-map-next($map, $key) {\n\n  // Store the keys of the map as a list\n  $values: map-keys($map);\n\n  $i: 0;\n\n  // If the Key Exists, Get the index of the key within the map and add 1 to it for the next breakpoint in the map\n  @if (map-has-key($map, $key)) {\n    $i: index($values, $key) + 1;\n  }\n\n  // If the key doesn't exist, or it's the last key in the map, return null\n  @if ($i > length($map) or $i == 0) {\n    @return null;\n  }\n  // Otherwise, return the value\n  @else {\n    @return map-get($map, nth($values, $i));\n  }\n\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $key - Key to use as last breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-breakpoints-less-than($key) {\n  $list: ();\n  $found_key: false;\n\n  @each $name in $-zf-breakpoints-keys {\n    @if ($name == $key) {\n      $found_key: true;\n    }\n    @if not $found_key {\n      $list: append($list, $name);\n    }\n  }\n  @return $list;\n}\n\n/// Return a list of our named breakpoints less than $key. Useful for dealing with\n/// responsive gutters for the grid.\n/// @access private\n///\n/// @param {String} $breakpoint - a named or non-named breakpoint.\n///\n/// @returns {Array} The list of breakpoints up to and. If $key is auto, returns breakpoints above the zero\n@function -zf-closest-named-breakpoint($breakpoint) {\n  $last: $-zf-zero-breakpoint;\n  $found: false;\n\n  $value: unitless-calc($breakpoint, 1px);\n  @each $key, $val in $breakpoints {\n    @if not $found {\n      @if unitless-calc($val) > $value {\n        $found: true;\n      } @else {\n        $last: $key;\n      }\n    }\n  }\n\n  @return $last;\n}\n\n/// Get a value for a breakpoint from a responsive config map or single value.\n/// - If the config is a single value, return it regardless of `$value`.\n/// - If the config is a map and has the key `$value`, the exact breakpoint value is returned.\n/// - If the config is a map and does *not* have the breakpoint, the value matching the next lowest breakpoint in the config map is returned.\n/// @access private\n///\n/// @param {Number|Map} $map - Responsive config map or single value.\n/// @param {Keyword} $value - Breakpoint name to use.\n///\n/// @return {Mixed} The corresponding breakpoint value.\n@function -zf-get-bp-val($map, $value) {\n  // If the given map is a single value, return it\n  @if type-of($map) == 'number' {\n    @return $map;\n  }\n\n\n  // Check if the breakpoint name exists globally\n  @if not map-has-key($breakpoints, $value) {\n    @if type-of($value) == 'number' {\n      $value: -zf-closest-named-breakpoint($value);\n    } @else {\n      @return null;\n    }\n  }\n  // Check if the breakpoint name exists in the local config map\n  @else if map-has-key($map, $value) {\n    // If it does, just return the value\n    @return map-get($map, $value);\n  }\n  // Otherwise, find the next lowest breakpoint and return that value\n  @else {\n    $anchor: null;\n    $found: false;\n\n    @each $key, $val in $breakpoints {\n      @if not $found {\n        @if map-has-key($map, $key) {\n          $anchor: $key;\n        }\n        @if $key == $value {\n          $found: true;\n        }\n      }\n    }\n\n    @return map-get($map, $anchor);\n  }\n}\n\n$small-up: '';\n$small-only: '';\n\n@if map-has-key($breakpoints, small) {\n  $small-up: screen;\n  $small-only: unquote('screen and #{breakpoint(small only)}');\n}\n\n$medium-up: '';\n$medium-only: '';\n\n@if map-has-key($breakpoints, medium) {\n  $medium-up: unquote('screen and #{breakpoint(medium)}');\n  $medium-only: unquote('screen and #{breakpoint(medium only)}');\n}\n\n$large-up: '';\n$large-only: '';\n\n@if map-has-key($breakpoints, large) {\n  $large-up: unquote('screen and #{breakpoint(large)}');\n  $large-only: unquote('screen and #{breakpoint(large only)}');\n}\n\n$xlarge-up: '';\n$xlarge-only: '';\n\n@if map-has-key($breakpoints, xlarge) {\n  $xlarge-up: unquote('screen and #{breakpoint(xlarge)}');\n  $xlarge-only: unquote('screen and #{breakpoint(xlarge only)}');\n}\n\n$xxlarge-up: '';\n\n@if map-has-key($breakpoints, xxlarge) {\n  $xxlarge-up: unquote('screen and #{breakpoint(xxlarge)}');\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group reveal\n////\n\n/// Default background color of a modal.\n/// @type Color\n$reveal-background: $white !default;\n\n/// Default width of a modal, with no class applied.\n/// @type Number\n$reveal-width: 600px !default;\n\n/// Default maximum width of a modal.\n/// @type Number\n$reveal-max-width: $global-width !default;\n\n/// Default padding inside a modal.\n/// @type Number\n$reveal-padding: $global-padding !default;\n\n/// Default border around a modal.\n/// @type Number\n$reveal-border: 1px solid $medium-gray !default;\n\n/// Default radius for modal.\n/// @type Number\n$reveal-radius: $global-radius !default;\n\n/// z-index for modals. The overlay uses this value, while the modal itself uses this value plus one.\n/// @type Number\n$reveal-zindex: 1005 !default;\n\n/// Background color of modal overlays.\n/// @type Color\n$reveal-overlay-background: rgba($black, 0.45) !default;\n\n\n// Placeholder selector for medium-and-up modals\n// Prevents duplicate CSS when defining multiple Reveal sizes\n// This should be in the same breakpoint then `@mixin reveal-modal-width`\n@include breakpoint(medium) {\n  %reveal-centered {\n    right: auto;\n    left: auto;\n    margin: 0 auto;\n  }\n}\n\n\n/// Adds styles for a modal overlay.\n/// @param {Color} $background [$reveal-overlay-background] - Background color of the overlay.\n@mixin reveal-overlay($background: $reveal-overlay-background) {\n  position: fixed;\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n  z-index: $reveal-zindex;\n\n  display: none;\n  background-color: $background;\n  overflow-y: auto;\n}\n\n/// Adds base styles for a modal.\n@mixin reveal-modal-base {\n  @include disable-mouse-outline;\n  z-index: $reveal-zindex + 1;\n  // Workaround android browser z-index bug\n  backface-visibility: hidden;\n\n  display: none;\n  padding: $reveal-padding;\n\n  border: $reveal-border;\n  border-radius: $reveal-radius;\n  background-color: $reveal-background;\n\n  @include breakpoint(medium) {\n    min-height: 0;\n  }\n\n  // Make sure rows don't have a min-width on them\n  .column {\n    min-width: 0;\n  }\n\n  // Strip margins from the last item in the modal\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adjusts the width of a modal.\n/// @param {Number} $width - Width of the modal. Generally a percentage.\n/// @param {Number} $max-width [$reveal-max-width] - Maximum width of the modal.\n@mixin reveal-modal-width(\n  $width: $reveal-width,\n  $max-width: $reveal-max-width\n) {\n  // Extends must be made outside of breakpoints for compatibility with newer Sass versions (libsass v3.5)\n  @extend %reveal-centered;\n  @include breakpoint(medium) {\n    width: $width;\n    max-width: $max-width;\n  }\n}\n\n/// Creates a full-screen modal, which stretches the full width and height of the window.\n@mixin reveal-modal-fullscreen {\n  top: 0;\n  right: 0;\n  bottom: 0;\n  left: 0;\n\n  width: 100%;\n  max-width: none;\n  height: 100%;\n  min-height: 100%;\n  margin-left: 0;\n\n  border: 0;\n  border-radius: 0;\n}\n\n@mixin foundation-reveal {\n\n  /// Disables the scroll when Reveal is shown to prevent the background from shifting\n  html.is-reveal-open {\n    position: fixed;\n    width: 100%;\n    overflow-y: hidden;\n\n    &.zf-has-scroll {\n      overflow-y: scroll;\n    }\n\n    body { // sass-lint:disable-line no-qualifying-elements\n      overflow-y: hidden;\n    }\n  }\n\n  // Overlay\n  .reveal-overlay {\n    @include reveal-overlay;\n  }\n\n  // Modal container\n  .reveal {\n    @include reveal-modal-base;\n    @include reveal-modal-width($reveal-width);\n    position: relative;\n    top: 100px;\n    margin-right: auto;\n    margin-left: auto;\n    overflow-y: auto;\n\n    // Remove padding\n    &.collapse {\n      padding: 0;\n    }\n\n    // Sizing classes\n    &.tiny  { @include reveal-modal-width(30%); }\n    &.small { @include reveal-modal-width(50%); }\n    &.large { @include reveal-modal-width(90%); }\n\n    // Full-screen mode\n    &.full {\n      @include reveal-modal-fullscreen;\n    }\n\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include reveal-modal-fullscreen;\n    }\n\n    &.without-overlay {\n      position: fixed;\n    }\n  }\n}\n","@mixin foundation-normalize() {\n  /*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */\n\n  // Document\n  // ==========================================================================\n\n  // 1. Correct the line height in all browsers.\n  // 2. Prevent adjustments of font size after orientation changes in iOS.\n\n  html {\n    line-height: 1.15; // 1\n    -webkit-text-size-adjust: 100%; // 2\n  }\n\n  // Sections\n  // ==========================================================================\n\n  // Remove the margin in all browsers.\n\n  body {\n    margin: 0;\n  }\n\n  // Correct the font size and margin on `h1` elements within `section` and\n  // `article` contexts in Chrome, Firefox, and Safari.\n\n  h1 {\n    font-size: 2em;\n    margin: 0.67em 0;\n  }\n\n  // Grouping content\n  // ==========================================================================\n\n  // 1. Add the correct box sizing in Firefox.\n  // 2. Show the overflow in Edge and IE.\n\n  hr {\n    box-sizing: content-box; // 1\n    height: 0; // 1\n    overflow: visible; // 2\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  pre {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Text-level semantics\n  // ==========================================================================\n\n  // Remove the gray background on active links in IE 10.\n\n  a {\n    background-color: transparent;\n  }\n\n  // 1. Remove the bottom border in Chrome 57-\n  // 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.\n\n  abbr[title] {\n    border-bottom: none; // 1\n    text-decoration: underline; // 2\n    text-decoration: underline dotted; // 2\n  }\n\n  // Add the correct font weight in Chrome, Edge, and Safari.\n\n  b,\n  strong {\n    font-weight: bolder;\n  }\n\n  // 1. Correct the inheritance and scaling of font size in all browsers.\n  // 2. Correct the odd `em` font sizing in all browsers.\n\n  code,\n  kbd,\n  samp {\n    font-family: monospace, monospace; // 1\n    font-size: 1em; // 2\n  }\n\n  // Add the correct font size in all browsers.\n\n  small {\n    font-size: 80%;\n  }\n\n  // Prevent `sub` and `sup` elements from affecting the line height in\n  // all browsers.\n\n  sub,\n  sup {\n    font-size: 75%;\n    line-height: 0;\n    position: relative;\n    vertical-align: baseline;\n  }\n\n  sub {\n    bottom: -0.25em;\n  }\n\n  sup {\n    top: -0.5em;\n  }\n\n  // Embedded content\n  // ==========================================================================\n\n  // Remove the border on images inside links in IE 10.\n\n  img {\n    border-style: none;\n  }\n\n  // Forms\n  // ==========================================================================\n\n  // 1. Change the font styles in all browsers.\n  // 2. Remove the margin in Firefox and Safari.\n\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit; // 1\n    font-size: 100%; // 1\n    line-height: 1.15; // 1\n    margin: 0; // 2\n  }\n\n  // Show the overflow in IE.\n  // 1. Show the overflow in Edge.\n\n  button,\n  input { // 1\n    overflow: visible;\n  }\n\n  // Remove the inheritance of text transform in Edge, Firefox, and IE.\n  // 1. Remove the inheritance of text transform in Firefox.\n\n  button,\n  select { // 1\n    text-transform: none;\n  }\n\n  // Correct the inability to style clickable types in iOS and Safari.\n\n  button,\n  [type=\"button\"],\n  [type=\"reset\"],\n  [type=\"submit\"] {\n    -webkit-appearance: button;\n  }\n\n  // Remove the inner border and padding in Firefox.\n\n  button::-moz-focus-inner,\n  [type=\"button\"]::-moz-focus-inner,\n  [type=\"reset\"]::-moz-focus-inner,\n  [type=\"submit\"]::-moz-focus-inner {\n    border-style: none;\n    padding: 0;\n  }\n\n  // Restore the focus styles unset by the previous rule.\n\n  button:-moz-focusring,\n  [type=\"button\"]:-moz-focusring,\n  [type=\"reset\"]:-moz-focusring,\n  [type=\"submit\"]:-moz-focusring {\n    outline: 1px dotted ButtonText;\n  }\n\n  // Correct the padding in Firefox.\n\n  fieldset {\n    padding: 0.35em 0.75em 0.625em;\n  }\n\n  // 1. Correct the text wrapping in Edge and IE.\n  // 2. Correct the color inheritance from `fieldset` elements in IE.\n  // 3. Remove the padding so developers are not caught out when they zero out\n  //    `fieldset` elements in all browsers.\n\n  legend {\n    box-sizing: border-box; // 1\n    color: inherit; // 2\n    display: table; // 1\n    max-width: 100%; // 1\n    padding: 0; // 3\n    white-space: normal; // 1\n  }\n\n  // Add the correct vertical alignment in Chrome, Firefox, and Opera.\n\n  progress {\n    vertical-align: baseline;\n  }\n\n  // Remove the default vertical scrollbar in IE 10+.\n\n  textarea {\n    overflow: auto;\n  }\n\n  // 1. Add the correct box sizing in IE 10.\n  // 2. Remove the padding in IE 10.\n\n  [type=\"checkbox\"],\n  [type=\"radio\"] {\n    box-sizing: border-box; // 1\n    padding: 0; // 2\n  }\n\n  // Correct the cursor style of increment and decrement buttons in Chrome.\n\n  [type=\"number\"]::-webkit-inner-spin-button,\n  [type=\"number\"]::-webkit-outer-spin-button {\n    height: auto;\n  }\n\n  // 1. Correct the odd appearance in Chrome and Safari.\n  // 2. Correct the outline style in Safari.\n\n  [type=\"search\"] {\n    -webkit-appearance: textfield; // 1\n    outline-offset: -2px; // 2\n  }\n\n  // Remove the inner padding in Chrome and Safari on macOS.\n\n  [type=\"search\"]::-webkit-search-decoration {\n    -webkit-appearance: none;\n  }\n\n  // 1. Correct the inability to style clickable types in iOS and Safari.\n  // 2. Change font properties to `inherit` in Safari.\n\n  ::-webkit-file-upload-button {\n    -webkit-appearance: button; // 1\n    font: inherit; // 2\n  }\n\n  // Interactive\n  // ==========================================================================\n\n  // Add the correct display in Edge, IE 10+, and Firefox.\n\n  details {\n    display: block;\n  }\n\n  // Add the correct display in all browsers.\n\n  summary {\n    display: list-item;\n  }\n\n  // Misc\n  // ==========================================================================\n\n  // Add the correct display in IE 10+.\n\n  template {\n    display: none;\n  }\n\n  // Add the correct display in IE 10.\n\n  [hidden] {\n    display: none;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-color-literals, no-qualifying-elements\n\n////\n/// @group global\n////\n\n@import 'util/util';\n\n/// Font size attribute applied to `<html>` and `<body>`. We use 100% by default so the value is inherited from the user's browser settings.\n/// @type Number\n$global-font-size: 100% !default;\n\n/// Global width of your site. Used by the grid to determine row width.\n/// @type Number\n$global-width: rem-calc(1200) !default;\n\n/// Default line height for all type. `$global-lineheight` is 24px while `$global-font-size` is 16px\n/// @type Number\n$global-lineheight: 1.5 !default;\n\n/// Colors used for buttons, callouts, links, etc. There must always be a color called `primary`.\n/// @type Map\n$foundation-palette: (\n  primary: #1779ba,\n  secondary: #767676,\n  success: #3adb76,\n  warning: #ffae00,\n  alert: #cc4b37,\n) !default;\n\n/// Color used for light gray UI items.\n/// @type Color\n$light-gray: #e6e6e6 !default;\n\n/// Color used for medium gray UI items.\n/// @type Color\n$medium-gray: #cacaca !default;\n\n/// Color used for dark gray UI items.\n/// @type Color\n$dark-gray: #8a8a8a !default;\n\n/// Color used for black ui items.\n/// @type Color\n$black: #0a0a0a !default;\n\n/// Color used for white ui items.\n/// @type Color\n$white: #fefefe !default;\n\n/// Background color of the body.\n/// @type Color\n$body-background: $white !default;\n\n/// Text color of the body.\n/// @type Color\n$body-font-color: $black !default;\n\n/// Font stack of the body.\n/// @type List\n$body-font-family: 'Helvetica Neue', Helvetica, Roboto, Arial, sans-serif !default;\n\n/// Set to `true` to enable antialiased type, using the `-webkit-font-smoothing` and `-moz-osx-font-smoothing` CSS properties.\n/// @type Boolean\n$body-antialiased: true !default;\n\n/// Global value used for margin on components.\n/// @type Number\n$global-margin: 1rem !default;\n\n/// Global value used for padding on components.\n/// @type Number\n$global-padding: 1rem !default;\n\n/// Global value used for positioning on components.\n/// @type Number\n$global-position: 1rem !default;\n\n/// Global font weight used for normal type.\n/// @type Keyword | Number\n$global-weight-normal: normal !default;\n\n/// Global font weight used for bold type.\n/// @type Keyword | Number\n$global-weight-bold: bold !default;\n\n/// Global value used for all elements that have a border radius.\n/// @type Number\n$global-radius: 0 !default;\n\n/// Global value used for all menu styles. Can be overwritten at individual menu component level.\n/// @type Number\n$global-menu-padding: 0.7rem 1rem !default;\n\n/// Global value used for all menu styles. Nested margin for submenu.\n$global-menu-nested-margin: 1rem !default;\n\n/// Sets the text direction of the CSS. Can be either `ltr` or `rtl`.\n/// @type Keyword\n$global-text-direction: ltr !default;\n\n/// Enables flexbox for components that support it.\n/// @type Boolean\n$global-flexbox: true !default;\n\n/// Enabled responsive breakpoints for prototypes if applicable\n/// @type Boolean\n$global-prototype-breakpoints: false !default;\n\n/// Button cursor's value, `auto` by default\n/// @type Keyword\n$global-button-cursor: auto !default;\n\n@if not map-has-key($foundation-palette, primary) {\n  @error 'In $foundation-palette, you must have a color named \"primary\".';\n}\n\n// Internal variables used for text direction\n$global-left: if($global-text-direction == rtl, right, left);\n$global-right: if($global-text-direction == rtl, left, right);\n\n// Internal variable that contains the flex justifying options\n$-zf-flex-justify: -zf-flex-justify($global-text-direction);\n\n/// Global tolerance for color pick contrast.\n/// @type Number\n$global-color-pick-contrast-tolerance: 0 !default;\n\n// Internal variables used for colors\n@include add-foundation-colors;\n\n@mixin foundation-global-styles {\n  @include foundation-normalize;\n\n  // These styles are applied to a <meta> tag, which is read by the Foundation JavaScript\n  .foundation-mq {\n    font-family: '#{-zf-bp-serialize($breakpoints)}';\n  }\n\n  html {\n    box-sizing: border-box;\n    font-size: $global-font-size;\n  }\n\n  // Set box-sizing globally to handle padding and border widths\n  *,\n  *::before,\n  *::after {\n    box-sizing: inherit;\n  }\n\n  // Default body styles\n  body {\n    margin: 0;\n    padding: 0;\n\n    background: $body-background;\n\n    font-family: $body-font-family;\n    font-weight: $global-weight-normal;\n    line-height: $global-lineheight;\n    color: $body-font-color;\n\n    @if ($body-antialiased) {\n      -webkit-font-smoothing: antialiased; // sass-lint:disable-line no-vendor-prefixes\n      -moz-osx-font-smoothing: grayscale; // sass-lint:disable-line no-vendor-prefixes\n    }\n  }\n\n  img {\n    // Get rid of gap under images by making them display: inline-block; by default\n    display: inline-block;\n    vertical-align: middle;\n\n    // Grid defaults to get images and embeds to work properly\n    max-width: 100%;\n    height: auto;\n    -ms-interpolation-mode: bicubic;\n  }\n\n  // Make sure textarea takes on height automatically\n  textarea {\n    height: auto;\n    min-height: 50px;\n    border-radius: $global-radius;\n  }\n\n  // Make select elements are 100% width by default\n  select {\n    box-sizing: border-box;\n    width: 100%;\n    border-radius: $global-radius;\n  }\n\n  // Styles Google Maps and MapQuest embeds properly\n  // sass-lint:disable-line no-ids\n  .map_canvas,\n  .mqa-display {\n    img,\n    embed,\n    object {\n      max-width: none !important;\n    }\n  }\n\n  // Reset <button> styles created by most browsers\n  button {\n    @include disable-mouse-outline;\n    padding: 0;\n    appearance: none;\n    border: 0;\n    border-radius: $global-radius;\n    background: transparent;\n    line-height: 1;\n    cursor: $global-button-cursor;\n  }\n\n  // Prevent text overflow on pre\n  pre {\n    overflow: auto;\n  }\n\n  // Make reset inherit font-family instead of settings sans-serif\n  button,\n  input,\n  optgroup,\n  select,\n  textarea {\n    font-family: inherit;\n  }\n\n  // Internal classes to show/hide elements in JavaScript\n  .is-visible {\n    display: block !important;\n  }\n\n  .is-hidden {\n    display: none !important;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n$global-font-size: 100% !default;\n\n/// Removes the unit (e.g. px, em, rem) from a value, returning the number only.\n///\n/// @param {Number} $num - Number to strip unit from.\n///\n/// @returns {Number} The same number, sans unit.\n@function strip-unit($num) {\n  @return $num / ($num * 0 + 1);\n}\n\n/// Converts one or more pixel values into matching rem values.\n///\n/// @param {Number|List} $values - One or more values to convert. Be sure to separate them with spaces and not commas. If you need to convert a comma-separated list, wrap the list in parentheses.\n/// @param {Number} $base [null] - The base value to use when calculating the `rem`. If you're using Foundation out of the box, this is 16px. If this parameter is `null`, the function will reference the `$global-font-size` variable as the base.\n///\n/// @returns {List} A list of converted values.\n@function rem-calc($values, $base: null) {\n  $rem-values: ();\n  $count: length($values);\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // If the base font size is a %, then multiply it by 16px\n  // This is because 100% font size = 16px in most all browsers\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  // Using rem as base allows correct scaling\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if $count == 1 {\n    @return -zf-to-rem($values, $base);\n  }\n\n  @for $i from 1 through $count {\n    $rem-values: append($rem-values, -zf-to-rem(nth($values, $i), $base));\n  }\n\n  @return $rem-values;\n}\n\n// Converts a unitless, pixel, or rem value to em, for use in breakpoints.\n@function -zf-bp-to-em($value) {\n  // Pixel and unitless values are converted to rems\n  @if unit($value) == 'px' or unitless($value) {\n    $value: rem-calc($value, $base: 16px);\n  }\n\n  // Then the value is converted to ems\n  @return strip-unit($value) * 1em;\n}\n\n/// Converts a pixel value to matching rem value. *Any* value passed, regardless of unit, is assumed to be a pixel value. By default, the base pixel value used to calculate the rem value is taken from the `$global-font-size` variable.\n/// @access private\n///\n/// @param {Number} $value - Pixel value to convert.\n/// @param {Number} $base [null] - Base for pixel conversion.\n///\n/// @returns {Number} A number in rems, calculated based on the given value and the base pixel value. rem values are passed through as is.\n@function -zf-to-rem($value, $base: null) {\n  // Check if the value is a number\n  @if type-of($value) != 'number' {\n    @warn inspect($value) + ' was passed to rem-calc(), which is not a number.';\n    @return $value;\n  }\n\n  // Transform em into rem if someone hands over 'em's\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * 1rem;\n  }\n\n  // Calculate rem if units for $value is not rem or em\n  @if unit($value) != 'rem' {\n    $value: strip-unit($value) / strip-unit($base) * 1rem;\n  }\n\n  // Turn 0rem into 0\n  @if $value == 0rem {\n    $value: 0;\n  }\n\n  @return $value;\n}\n\n/// Converts a pixel, percentage, rem or em value to a unitless value based on a given font size. Ideal for working out unitless line heights.\n///\n/// @param {Number} $value - Value to convert to a unitless line height\n/// @param {Number} $base - The font size to use to work out the line height - defaults to $global-font-size\n///\n/// @return {Number} - Unitless number\n@function unitless-calc($value, $base: null) {\n\n  // If no base is defined, defer to the global font size\n  @if $base == null {\n    $base: $global-font-size;\n  }\n\n  // First, lets convert our $base to pixels\n\n  // If the base font size is a %, then multiply it by 16px\n  @if unit($base) == '%' {\n    $base: ($base / 100%) * 16px;\n  }\n\n  @if unit($base) == 'rem' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  @if unit($base) == 'em' {\n    $base: strip-unit($base) * 16px;\n  }\n\n  // Now let's convert our value to pixels too\n  @if unit($value) == '%' {\n    $value: ($value / 100%) * $base;\n  }\n\n  @if unit($value) == 'rem' {\n    $value: strip-unit($value) * $base;\n  }\n\n  @if unit($value) == 'em' {\n    $value: strip-unit($value) * $base;\n  }\n\n  // 'px'\n  @if unit($value) == 'px' {\n    @return strip-unit($value) / strip-unit($base);\n  }\n\n  // assume that line-heights greater than 10 are meant to be absolute in 'px'\n  @if unitless($value) and ($value > 10) {\n    @return $value / strip-unit($base);\n  }\n\n  @return $value;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Creates an inner box-shadow for only one side\n///\n/// @param {Keyword} $side - Side the shadow is supposed to appear. Can be `top`, `left`, `right` or `bottom`.\n/// @param {Number} $size - Width for the target side.\n/// @param {Color} $color - Color of the shadow.\n@mixin inner-side-shadow(\n  $side: bottom,\n  $size: 20px,\n  $color: rgba($black, 0.25)\n) {\n\n  $helper: round($size * 0.65);\n\n  @if ($side == top) {\n    box-shadow: inset 0 $helper $size (-1)*$helper $color;\n  } @else if ($side == left) {\n    box-shadow: inset $helper 0 $size (-1)*$helper $color;\n  } @else if ($side == right) {\n    box-shadow: inset (-1)*$helper 0 $size (-1)*$helper $color;\n  } @else if ($side == bottom) {\n    box-shadow: inset 0 (-1)*$helper $size (-1)*$helper $color;\n  }\n}\n\n/// Creates a CSS triangle, which can be used for dropdown arrows, dropdown pips, and more. Use this mixin inside a `&::before` or `&::after` selector, to attach the triangle to an existing element.\n///\n/// @param {Number} $triangle-size - Width of the triangle.\n/// @param {Color} $triangle-color - Color of the triangle.\n/// @param {Keyword} $triangle-direction - Direction the triangle points. Can be `up`, `right`, `down`, or `left`.\n@mixin css-triangle(\n  $triangle-size,\n  $triangle-color,\n  $triangle-direction\n) {\n  display: block;\n  width: 0;\n  height: 0;\n\n  border: inset $triangle-size;\n\n  content: '';\n\n  @if ($triangle-direction == down) {\n    border-bottom-width: 0;\n    border-top-style: solid;\n    border-color: $triangle-color transparent transparent;\n  }\n  @if ($triangle-direction == up) {\n    border-top-width: 0;\n    border-bottom-style: solid;\n    border-color: transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == right) {\n    border-right-width: 0;\n    border-left-style: solid;\n    border-color: transparent transparent transparent $triangle-color;\n  }\n  @if ($triangle-direction == left) {\n    border-left-width: 0;\n    border-right-style: solid;\n    border-color: transparent $triangle-color transparent transparent;\n  }\n}\n\n/// Creates a menu icon with a set width, height, number of bars, and colors. The mixin uses the height of the icon and the weight of the bars to determine spacing. <div class=\"docs-example-burger\"></div>\n///\n/// @param {Color} $color [$black] - Color to use for the icon.\n/// @param {Color} $color-hover [$dark-gray] - Color to use when the icon is hovered over.\n/// @param {Number} $width [20px] - Width of the icon.\n/// @param {Number} $height [16px] - Height of the icon.\n/// @param {Number} $weight [2px] - Height of individual bars in the icon.\n/// @param {Number} $bars [3] - Number of bars in the icon.\n@mixin hamburger(\n  $color: $black,\n  $color-hover: $dark-gray,\n  $width: 20px,\n  $height: 16px,\n  $weight: 2px,\n  $bars: 3\n) {\n  // box-shadow CSS output\n  $shadow: ();\n  $hover-shadow: ();\n\n  // Spacing between bars is calculated based on the total height of the icon and the weight of each bar\n  $spacing: ($height - ($weight * $bars)) / ($bars - 1);\n\n  @if unit($spacing) == 'px' {\n    $spacing: floor($spacing);\n  }\n\n  @for $i from 2 through $bars {\n    $offset: ($weight + $spacing) * ($i - 1);\n    $shadow: append($shadow, 0 $offset 0 $color, comma);\n  }\n\n  // Icon container\n  position: relative;\n  display: inline-block;\n  vertical-align: middle;\n  width: $width;\n  height: $height;\n  cursor: pointer;\n\n  // Icon bars\n  &::after {\n    position: absolute;\n    top: 0;\n    left: 0;\n\n    display: block;\n    width: 100%;\n    height: $weight;\n\n    background: $color;\n    box-shadow: $shadow;\n\n    content: '';\n  }\n\n  // Hover state\n  @if $color-hover {\n    // Generate CSS\n    @for $i from 2 through $bars {\n      $offset: ($weight + $spacing) * ($i - 1);\n      $hover-shadow: append($hover-shadow, 0 $offset 0 $color-hover, comma);\n    }\n\n    &:hover::after {\n      background: $color-hover;\n      box-shadow: $hover-shadow;\n    }\n  }\n}\n\n/// Adds a downward-facing triangle as a background image to an element. The image is formatted as an SVG, making it easy to change the color. Because Internet Explorer doesn't support encoded SVGs as background images, a PNG fallback is also included.\n/// There are two PNG fallbacks: a black triangle and a white triangle. The one used depends on the lightness of the input color.\n///\n/// @param {Color} $color [$black] - Color to use for the triangle.\n@mixin background-triangle($color: $black) {\n  $rgb: 'rgb%28#{round(red($color))}, #{round(green($color))}, #{round(blue($color))}%29';\n\n  background-image: url(\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: #{$rgb}'></polygon></svg>\");\n\n  @media screen and (min-width:0\\0) {\n    @if lightness($color) < 60% {\n      // White triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==');\n    }\n    @else {\n      // Black triangle\n      background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAMBJREFUeNrEllsOhCAMRVszC9IlzU7KCmVHTJsoMWYMUtpyv9BgbuXQB5ZSdgBYYY4ycgBivk8KYFsQMfMiTTBP4o3nUzCKzOabLJbLy2/g31evGkAginR4/ZegKH5qX3bJCscA3t0x3kgO5tQFyhhFf50xRqFLbyMUNJQzgyjGS/wgCpvKqkRBpuWrE4V9d+1E4dPUXqIg107SQOE/2DRQxMwTDygIInVDET9T3lCoj/6j/VCmGjZOl2lKpZ8AAwDQP7zIimDGFQAAAABJRU5ErkJggg==');\n    }\n  }\n}\n\n/// Applies the micro clearfix hack popularized by Nicolas Gallagher. Include this mixin on a container if its children are all floated, to give the container a proper height.\n/// The clearfix is augmented with specific styles to prevent borders in flexbox environments\n/// @link http://nicolasgallagher.com/micro-clearfix-hack/ Micro Clearfix Hack\n/// @link http://danisadesigner.com/blog/flexbox-clear-fix-pseudo-elements/ Flexbox fix\n@mixin clearfix {\n  &::before,\n  &::after {\n    display: table;\n    content: ' ';\n\n    @if $global-flexbox {\n      flex-basis: 0;\n      order: 1;\n    }\n  }\n\n  &::after {\n    clear: both;\n  }\n}\n\n/// Adds CSS for a \"quantity query\" selector that automatically sizes elements based on how many there are inside a container.\n/// @link http://alistapart.com/article/quantity-queries-for-css Quantity Queries for CSS\n///\n/// @param {Number} $max - Maximum number of items to detect. The higher this number is, the more CSS that's required to cover each number of items.\n/// @param {Keyword} $elem [li] - Tag to use for sibling selectors.\n@mixin auto-width($max, $elem: li) {\n  @for $i from 2 through $max {\n    &:nth-last-child(#{$i}):first-child,\n    &:nth-last-child(#{$i}):first-child ~ #{$elem} {\n      width: percentage(1 / $i);\n    }\n  }\n}\n\n/// Removes the focus ring around an element when a mouse input is detected.\n@mixin disable-mouse-outline {\n  [data-whatinput='mouse'] & {\n    outline: 0;\n  }\n}\n\n/// Makes an element visually hidden, but still accessible to keyboards and assistive devices.\n/// @link http://snook.ca/archives/html_and_css/hiding-content-for-accessibility Hiding Content for Accessibility\n/// @link http://hugogiraudel.com/2016/10/13/css-hide-and-seek/\n@mixin element-invisible {\n  position: absolute !important;\n  width: 1px;\n  height: 1px;\n  padding: 0;\n  overflow: hidden;\n  clip: rect(0,0,0,0);\n  white-space: nowrap;\n  border: 0;\n}\n\n/// Reverses the CSS output created by the `element-invisible()` mixin.\n@mixin element-invisible-off {\n  position: static !important;\n  width: auto;\n  height: auto;\n  overflow: visible;\n  clip: auto;\n  white-space: normal;\n}\n\n/// Vertically centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin vertical-center {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Horizontally centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin horizontal-center {\n  position: absolute;\n  left: 50%;\n  transform: translateX(-50%);\n}\n\n/// Absolutely centers the element inside of its first non-static parent,\n/// @link http://www.sitepoint.com/centering-with-sass/ Centering With Sass\n@mixin absolute-center {\n  position: absolute;\n  top: 50%;\n  left: 50%;\n  transform: translate(-50%, -50%);\n}\n\n/// Iterates through breakpoints defined in `$breakpoint-classes` and prints the CSS inside the mixin at each breakpoint's media query. Use this with the grid, or any other component that has responsive classes.\n///\n/// @param {Boolean} $small [true] - If `false`, the mixin will skip the `small` breakpoint. Use this with components that don't prefix classes with `small-`, only `medium-` and up.\n/// @param {Boolean} $auto-insert-breakpoints [true] - If `false`, the mixin will iterate over breakpoints without doing the media query itself. Useful for more complex media query generation as in the margin grid.\n@mixin -zf-each-breakpoint($small: true, $auto-insert-breakpoints: true) {\n  $list: $breakpoint-classes;\n\n  @if not $small {\n    $list: sl-remove($list, $-zf-zero-breakpoint);\n  }\n\n  @each $name in $list {\n    $old-zf-size: null;\n    @if global-variable-exists(-zf-size) {\n      $old-zf-size: $-zf-size;\n    }\n    $-zf-size: $name !global;\n\n    @if $auto-insert-breakpoints {\n      @include breakpoint($name) {\n        @content;\n      }\n    }\n    @else {\n      @content;\n    }\n\n    $-zf-size: $old-zf-size !global;\n  }\n}\n\n/// Generate the `@content` passed to the mixin with a value `$-zf-bp-value` related to a breakpoint, depending on the `$name` parameter:\n/// - For a single value, `$-zf-bp-value` is this value.\n/// - For a breakpoint name, `$-zf-bp-value` is the corresponding breakpoint value in `$map`.\n/// - For \"auto\", `$-zf-bp-value` is the corresponding breakpoint value in `$map` and is passed to `@content`, which is made responsive for each breakpoint of `$map`.\n/// @param {Number|Array|Keyword} $name [auto] - Single value, breakpoint name, or list of breakpoint names to use. \"auto\" by default.\n/// @param {Number|Map} $map - Map of breakpoints and values or single value to use.\n@mixin -zf-breakpoint-value(\n  $name: auto,\n  $map: null\n) {\n  @if $name == auto and type-of($map) == 'map' {\n    // \"auto\"\n    @each $k, $v in $map {\n      @include breakpoint($k) {\n        @include -zf-breakpoint-value($v, $map) {\n          @content;\n        }\n      }\n    }\n  }\n  @else {\n    // breakpoint name\n    @if type-of($name) == 'string' {\n      $name: -zf-get-bp-val($map, $name);\n    }\n\n    // breakpoint value\n    $-zf-bp-value: $name !global;\n    @content;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Font color of text inputs.\n/// @type Color\n$input-color: $black !default;\n\n/// Font color of placeholder text within text inputs.\n/// @type Color\n$input-placeholder-color: $medium-gray !default;\n\n/// Font family of text inputs.\n/// @type Font\n$input-font-family: inherit !default;\n\n/// Font size of text inputs.\n/// @type Number\n$input-font-size: rem-calc(16) !default;\n\n/// Font weight of text inputs.\n/// @type Keyword\n$input-font-weight: $global-weight-normal !default;\n\n/// Line height of text inputs.\n/// @type Keyword\n$input-line-height: $global-lineheight !default;\n\n/// Background color of text inputs.\n/// @type Color\n$input-background: $white !default;\n\n/// Background color of focused of text inputs.\n/// @type Color\n$input-background-focus: $white !default;\n\n/// Background color of disabled text inputs.\n/// @type Color\n$input-background-disabled: $light-gray !default;\n\n/// Border around text inputs.\n/// @type Border\n$input-border: 1px solid $medium-gray !default;\n\n/// Border around focused text inputs.\n/// @type Color\n$input-border-focus: 1px solid $dark-gray !default;\n\n/// Padding of text inputs.\n/// @type Color\n$input-padding: $form-spacing / 2 !default;\n\n/// Box shadow inside text inputs when not focused.\n/// @type Shadow\n$input-shadow: inset 0 1px 2px rgba($black, 0.1) !default;\n\n/// Box shadow outside text inputs when focused.\n/// @type Shadow\n$input-shadow-focus: 0 0 5px $medium-gray !default;\n\n/// Cursor to use when hovering over a disabled text input.\n/// @type Cursor\n$input-cursor-disabled: not-allowed !default;\n\n/// Properties to transition on text inputs.\n/// @type Transition\n$input-transition: box-shadow 0.5s, border-color 0.25s ease-in-out !default;\n\n/// Enables the up/down buttons that Chrome and Firefox add to `<input type='number'>` elements.\n/// @type Boolean\n$input-number-spinners: true !default;\n\n/// Radius for text inputs.\n/// @type Border\n$input-radius: $global-radius !default;\n\n/// Border radius for form buttons, defaulted to global-radius.\n/// @type Number\n$form-button-radius: $global-radius !default;\n\n@mixin form-element {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  display: block;\n  box-sizing: border-box;\n  width: 100%;\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  border: $input-border;\n  border-radius: $input-radius;\n  background-color: $input-background;\n  box-shadow: $input-shadow;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n}\n\n@mixin foundation-form-text {\n  // Text inputs\n  #{text-inputs()},\n  textarea {\n    @include form-element;\n    appearance: none;\n  }\n\n  // Text areas\n  textarea {\n    max-width: 100%;\n\n    &[rows] {\n      height: auto;\n    }\n  }\n\n  input,\n  textarea {\n    // Disabled/readonly state\n    &:disabled,\n    &[readonly] {\n      background-color: $input-background-disabled;\n      cursor: $input-cursor-disabled;\n    }\n  }\n\n  // Reset styles on button-like inputs\n  [type='submit'],\n  [type='button'] {\n    appearance: none;\n    border-radius: $form-button-radius;\n  }\n\n  // Reset Normalize setting content-box to search elements\n  input[type='search'] { // sass-lint:disable-line no-qualifying-elements\n    box-sizing: border-box;\n  }\n\n  // Number input styles\n  [type='number'] {\n    @if not $input-number-spinners {\n      -moz-appearance: textfield; // sass-lint:disable-line no-vendor-prefixes\n\n      &::-webkit-inner-spin-button,\n      &::-webkit-outer-spin-button {\n        -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n        margin: 0;\n      }\n    }\n  }\n\n  // Placeholder text\n  ::placeholder {\n    color: $input-placeholder-color;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n@mixin foundation-form-checkbox {\n  [type='file'],\n  [type='checkbox'],\n  [type='radio'] {\n    margin: 0 0 $form-spacing;\n  }\n\n  // Styles for input/label siblings\n  [type='checkbox'] + label,\n  [type='radio'] + label {\n    display: inline-block;\n    vertical-align: baseline;\n\n    margin-#{$global-left}: $form-spacing * 0.5;\n    margin-#{$global-right}: $form-spacing;\n    margin-bottom: 0;\n\n    &[for] {\n      cursor: pointer;\n    }\n  }\n\n  // Styles for inputs inside labels\n  label > [type='checkbox'],\n  label > [type='radio'] {\n    margin-#{$global-right}: $form-spacing * 0.5;\n  }\n\n  // Normalize file input width\n  [type='file'] {\n    width: 100%;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color for form labels.\n/// @type Color\n$form-label-color: $black !default;\n\n/// Font size for form labels.\n/// @type Number\n$form-label-font-size: rem-calc(14) !default;\n\n/// Font weight for form labels.\n/// @type Keyword\n$form-label-font-weight: $global-weight-normal !default;\n\n/// Line height for form labels. The higher the number, the more space between the label and its input field.\n/// @type Number\n$form-label-line-height: 1.8 !default;\n\n@mixin form-label {\n  display: block;\n  margin: 0;\n\n  font-size: $form-label-font-size;\n  font-weight: $form-label-font-weight;\n  line-height: $form-label-line-height;\n  color: $form-label-color;\n}\n\n@mixin form-label-middle {\n  $input-border-width: get-border-value($input-border, width);\n\n  margin: 0 0 $form-spacing;\n  padding: ($form-spacing / 2 + rem-calc($input-border-width)) 0;\n}\n\n@mixin foundation-form-label {\n  label {\n    @include form-label;\n\n    &.middle {\n      @include form-label-middle;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default color for help text.\n/// @type Color\n$helptext-color: $black !default;\n\n/// Default font size for help text.\n/// @type Number\n$helptext-font-size: rem-calc(13) !default;\n\n/// Default font style for help text.\n/// @type Keyword\n$helptext-font-style: italic !default;\n\n@mixin foundation-form-helptext {\n  .help-text {\n    $margin-top: ($form-spacing * 0.5) * -1;\n\n    margin-top: $margin-top;\n    font-size: $helptext-font-size;\n    font-style: $helptext-font-style;\n    color: $helptext-color;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Color of labels prefixed to an input.\n/// @type Color\n$input-prefix-color: $black !default;\n\n/// Background color of labels prefixed to an input.\n/// @type Color\n$input-prefix-background: $light-gray !default;\n\n/// Border around labels prefixed to an input.\n/// @type Border\n$input-prefix-border: 1px solid $medium-gray !default;\n\n/// Left/right padding of an pre/postfixed input label\n$input-prefix-padding: 1rem !default;\n\n@mixin foundation-form-prepostfix {\n  $height: ($input-font-size * $input-line-height) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  .input-group {\n    display: if($global-flexbox, flex, table);\n    width: 100%;\n    margin-bottom: $form-spacing;\n\n    @if $global-flexbox {\n      align-items: stretch;\n    }\n\n    > :first-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, 0 $input-radius $input-radius 0, $input-radius 0 0 $input-radius);\n      }\n    }\n\n    > :last-child {\n      &, &.input-group-button > * {\n        border-radius: if($global-text-direction == rtl, $input-radius 0 0 $input-radius, 0 $input-radius $input-radius 0);\n      }\n    }\n  }\n\n  %input-group-child {\n    margin: 0;\n    white-space: nowrap;\n\n    @if not $global-flexbox {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n\n  .input-group-label {\n    @extend %input-group-child;\n    padding: 0 $input-prefix-padding;\n    border: $input-prefix-border;\n    background: $input-prefix-background;\n\n    color: $input-prefix-color;\n    text-align: center;\n    white-space: nowrap;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n      align-items: center;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    @if has-value($input-prefix-border) {\n      &:first-child {\n        border-#{$global-right}: 0;\n      }\n\n      &:last-child {\n        border-#{$global-left}: 0;\n      }\n    }\n  }\n\n  .input-group-field {\n    @extend %input-group-child;\n    border-radius: 0;\n\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n      min-width: 0;\n    }\n  }\n\n  .input-group-button {\n    @extend %input-group-child;\n    padding-top: 0;\n    padding-bottom: 0;\n    text-align: center;\n\n    @if $global-flexbox {\n      display: flex;\n      flex: 0 0 auto;\n    }\n    @else {\n      width: 1%;\n      height: 100%;\n    }\n\n    a,\n    input,\n    button,\n    label {\n      @extend %input-group-child;\n\n      @if $global-flexbox {\n        align-self: stretch;\n        height: auto;\n      }\n      @else {\n        height: $height;\n      }\n      padding-top: 0;\n      padding-bottom: 0;\n      font-size: $input-font-size;\n    }\n  }\n\n  // Specificity bump needed to prevent override by buttons\n  @if not $global-flexbox {\n    .input-group {\n      .input-group-button {\n        display: table-cell;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Default border around custom fieldsets.\n/// @type Border\n$fieldset-border: 1px solid $medium-gray !default;\n\n/// Default padding inside custom fieldsets.\n/// @type Number\n$fieldset-padding: rem-calc(20) !default;\n\n/// Default margin around custom fieldsets.\n/// @type Number\n$fieldset-margin: rem-calc(18 0) !default;\n\n/// Default padding between the legend text and fieldset border.\n/// @type Number\n$legend-padding: rem-calc(0 3) !default;\n\n@mixin fieldset {\n  margin: $fieldset-margin;\n  padding: $fieldset-padding;\n  border: $fieldset-border;\n\n  legend {\n    // Covers up the fieldset's border to create artificial padding\n    margin: 0;\n    margin-#{$global-left}: rem-calc(-3);\n    padding: $legend-padding;\n  }\n}\n\n@mixin foundation-form-fieldset {\n  fieldset {\n    margin: 0;\n    padding: 0;\n    border: 0;\n  }\n\n  legend {\n    max-width: 100%;\n    margin-bottom: $form-spacing * 0.5;\n  }\n\n  .fieldset {\n    @include fieldset;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group forms\n////\n\n/// Background color for select menus.\n/// @type Color\n$select-background: $white !default;\n\n/// Color of the dropdown triangle inside select menus. Set to `transparent` to remove it entirely.\n/// @type Color\n$select-triangle-color: $dark-gray !default;\n\n/// Default radius for select menus.\n/// @type Color\n$select-radius: $global-radius !default;\n\n@mixin form-select {\n  $height: ($input-font-size * unitless-calc($input-line-height)) + (get-side($input-padding, 'top') + get-side($input-padding, 'bottom')) - rem-calc(1);\n\n  height: $height;\n  margin: 0 0 $form-spacing;\n  padding: $input-padding;\n\n  appearance: none;\n  border: $input-border;\n  border-radius: $select-radius;\n  background-color: $select-background;\n\n  font-family: $input-font-family;\n  font-size: $input-font-size;\n  font-weight: $input-font-weight;\n  line-height: $input-line-height;\n  color: $input-color;\n\n  @if $select-triangle-color != transparent {\n    @include background-triangle($select-triangle-color);\n    background-origin: content-box;\n    background-position: $global-right (-$form-spacing) center;\n    background-repeat: no-repeat;\n    background-size: 9px 6px;\n\n    padding-#{$global-right}: ($form-spacing * 1.5);\n  }\n\n  @if has-value($input-transition) {\n    transition: $input-transition;\n  }\n\n  // Focus state\n  &:focus {\n    outline: none;\n    border: $input-border-focus;\n    background-color: $input-background-focus;\n    box-shadow: $input-shadow-focus;\n\n    @if has-value($input-transition) {\n      transition: $input-transition;\n    }\n  }\n\n  // Disabled state\n  &:disabled {\n    background-color: $input-background-disabled;\n    cursor: $input-cursor-disabled;\n  }\n\n  // Hide the dropdown arrow shown in newer IE versions\n  &::-ms-expand {\n    display: none;\n  }\n\n  &[multiple] {\n    height: auto;\n    background-image: none;\n  }\n}\n\n@mixin foundation-form-select {\n  select {\n    @include form-select;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group abide\n////\n\n/// Sets if error styles should be added to inputs.\n/// @type Boolean\n$abide-inputs: true !default;\n\n/// Sets if error styles should be added to labels.\n/// @type Boolean\n$abide-labels: true !default;\n\n/// Background color to use for invalid text inputs.\n/// @type Color\n$input-background-invalid: get-color(alert) !default;\n\n/// Color to use for labels of invalid inputs.\n/// @type Color\n$form-label-color-invalid: get-color(alert) !default;\n\n/// Default font color for form error text.\n/// @type Color\n$input-error-color: get-color(alert) !default;\n\n/// Default font size for form error text.\n/// @type Number\n$input-error-font-size: rem-calc(12) !default;\n\n/// Default font weight for form error text.\n/// @type Keyword\n$input-error-font-weight: $global-weight-bold !default;\n\n/// Styles the background and border of an input field to have an error state.\n///\n/// @param {Color} $background [$alert-color] - Color to use for the background and border.\n/// @param {Number} $background-lighten [10%] - Lightness level of the background color.\n@mixin form-input-error(\n  $background: $input-background-invalid,\n  $background-lighten: 10%\n) {\n  &:not(:focus) {\n    border-color: $background;\n    background-color: mix($background, $white, $background-lighten);\n\n    &::placeholder {\n      color: $background;\n    }\n  }\n}\n\n/// Adds error styles to a form element, using the values in the settings file.\n@mixin form-error {\n  display: none;\n  margin-top: $form-spacing * -0.5;\n  margin-bottom: $form-spacing;\n\n  font-size: $input-error-font-size;\n  font-weight: $input-error-font-weight;\n  color: $input-error-color;\n}\n\n@mixin foundation-form-error {\n  @if $abide-inputs {\n    // Error class for invalid inputs\n    .is-invalid-input {\n      @include form-input-error;\n    }\n  }\n\n  @if $abide-labels {\n    // Error class for labels of invalid outputs\n    .is-invalid-label {\n      color: $form-label-color-invalid;\n    }\n  }\n\n  // Form error element\n  .form-error {\n    @include form-error;\n\n    &.is-visible {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group typography-base\n////\n\n// Base Typography\n// - - - - - - - - - - - - - - -\n// These are styles applied to basic HTML tags, including:\n//   - Paragraphs <p>\n//   - Bold/italics <b> <strong> <i> <em>\n//   - Small text <small>\n//   - Headings <h1>-<h6>\n//   - Anchors <a>\n//   - Dividers <hr>\n//   - Lists <ul> <ol> <dl>\n//   - Blockquotes <blockquote>\n//   - Code blocks <code>\n//   - Abbreviations <abbr>\n//   - Citations <cite>\n//   - Keystrokes <kbd>\n\n/// Font family for header elements.\n/// @type String | List\n$header-font-family: $body-font-family !default;\n\n/// Font weight of headers.\n/// @type String\n$header-font-weight: $global-weight-normal !default;\n\n/// Font style (e.g. italicized) of headers.\n/// @type String\n$header-font-style: normal !default;\n\n/// Font stack used for elements that use monospaced type, such as code samples\n/// @type String | List\n$font-family-monospace: Consolas, 'Liberation Mono', Courier, monospace !default;\n\n/// Color of headers.\n/// @type Color\n$header-color: inherit !default;\n\n/// Line height of headers.\n/// @type Number\n$header-lineheight: 1.4 !default;\n\n/// Bottom margin of headers.\n/// @type Number\n$header-margin-bottom: 0.5rem !default;\n\n/// Styles for headings at various screen sizes. Each key is a breakpoint, and each value is a map of heading styles.\n/// @type Map\n$header-styles: (\n  small: (\n    'h1': ('font-size': 24),\n    'h2': ('font-size': 20),\n    'h3': ('font-size': 19),\n    'h4': ('font-size': 18),\n    'h5': ('font-size': 17),\n    'h6': ('font-size': 16),\n  ),\n  medium: (\n    'h1': ('font-size': 48),\n    'h2': ('font-size': 40),\n    'h3': ('font-size': 31),\n    'h4': ('font-size': 25),\n    'h5': ('font-size': 20),\n    'h6': ('font-size': 16),\n  ),\n) !default;\n\n// $header-styles map is built from $header-sizes in order to ensure downward compatibility\n// when $header-sizes is depreciated, $header-styles needs to get !default values like settings.scss\n@function build_from_header-sizes($header-sizes) {\n  @warn 'Note, that $header-sizes has been replaced with $header-styles. $header-sizes still works, but it is going to be depreciated.';\n  $header-styles: ();\n  @each $size, $headers in $header-sizes {\n    $header-map: ();\n    @each $header, $font-size in $headers {\n      $header-map: map-merge($header-map, ($header: ('font-size': $font-size)));\n    }\n    $header-styles: map-merge($header-styles, ($size: $header-map));\n  }\n  @return $header-styles;\n}\n\n// If it exists $headers-sizes is used to build $header-styles. See the documentation.\n@if variable-exists(header-sizes) {\n  $header-styles: build_from_header-sizes($header-sizes);\n}\n\n/// Text rendering method of headers.\n/// @type String\n$header-text-rendering: optimizeLegibility !default;\n\n/// Font size of `<small>` elements.\n/// @type Number\n$small-font-size: 80% !default;\n\n/// Color of `<small>` elements when placed inside headers.\n/// @type Color\n$header-small-font-color: $medium-gray !default;\n\n/// Line height of text inside `<p>` elements.\n/// @type Number\n$paragraph-lineheight: 1.6 !default;\n\n/// Bottom margin of paragraphs.\n/// @type Number\n$paragraph-margin-bottom: 1rem !default;\n\n/// Text rendering method for paragraph text.\n/// @type String\n$paragraph-text-rendering: optimizeLegibility !default;\n\n/// Text color of code samples.\n/// @type Color\n$code-color: $black !default;\n\n/// Font family of code samples.\n/// @type String | List\n$code-font-family: $font-family-monospace !default;\n\n/// Font weight of text in code samples.\n/// @type String\n$code-font-weight: $global-weight-normal !default;\n\n/// Background color of code samples.\n/// @type Color\n$code-background: $light-gray !default;\n\n/// Border around code samples.\n/// @type List\n$code-border: 1px solid $medium-gray !default;\n\n/// Padding around text of code samples.\n/// @type Number | List\n$code-padding: rem-calc(2 5 1) !default;\n\n/// Default color for links.\n/// @type Color\n$anchor-color: $primary-color !default;\n\n/// Default color for links on hover.\n/// @type Color\n$anchor-color-hover: scale-color($anchor-color, $lightness: -14%) !default;\n\n/// Default text decoration for links.\n/// @type String\n$anchor-text-decoration: none !default;\n\n/// Default text decoration for links on hover.\n/// @type String\n$anchor-text-decoration-hover: none !default;\n\n/// Maximum width of a divider.\n/// @type Number\n$hr-width: $global-width !default;\n\n/// Default border for a divider.\n/// @type List\n$hr-border: 1px solid $medium-gray !default;\n\n/// Default margin for a divider.\n/// @type Number | List\n$hr-margin: rem-calc(20) auto !default;\n\n/// Line height for items in a list.\n/// @type Number\n$list-lineheight: $paragraph-lineheight !default;\n\n/// Bottom margin for items in a list.\n/// @type Number\n$list-margin-bottom: $paragraph-margin-bottom !default;\n\n/// Bullet type to use for unordered lists (e.g., `square`, `circle`, `disc`).\n/// @type String\n$list-style-type: disc !default;\n\n/// Positioning for bullets on unordered list items.\n/// @type String\n$list-style-position: outside !default;\n\n/// Left (or right) margin for lists.\n/// @type Number\n$list-side-margin: 1.25rem !default;\n\n/// Left (or right) margin for a list inside a list.\n/// @type Number\n$list-nested-side-margin: 1.25rem !default;\n\n/// Bottom margin for `<dl>` elements.\n/// @type Number\n$defnlist-margin-bottom: 1rem !default;\n\n/// Font weight for `<dt>` elements.\n/// @type String\n$defnlist-term-weight: $global-weight-bold !default;\n\n/// Spacing between `<dt>` and `<dd>` elements.\n/// @type Number\n$defnlist-term-margin-bottom: 0.3rem !default;\n\n/// Text color of `<blockquote>` elements.\n/// @type Color\n$blockquote-color: $dark-gray !default;\n\n/// Padding inside a `<blockquote>` element.\n/// @type Number | List\n$blockquote-padding: rem-calc(9 20 0 19) !default;\n\n/// Side border for `<blockquote>` elements.\n/// @type List\n$blockquote-border: 1px solid $medium-gray !default;\n\n/// Font size for `<cite>` elements.\n/// @type Number\n$cite-font-size: rem-calc(13) !default;\n\n/// Text color for `<cite>` elements.\n/// @type Color\n$cite-color: $dark-gray !default;\n\n/// Pseudo content for `<cite>` elements.\n/// @type String\n$cite-pseudo-content: '\\2014 \\0020' !default;\n\n/// Font family for `<kbd>` elements.\n/// @type String | List\n$keystroke-font: $font-family-monospace !default;\n\n/// Text color for `<kbd>` elements.\n/// @type Color\n$keystroke-color: $black !default;\n\n/// Background color for `<kbd>` elements.\n/// @type Color\n$keystroke-background: $light-gray !default;\n\n/// Padding for `<kbd>` elements.\n/// @type Number | List\n$keystroke-padding: rem-calc(2 4 0) !default;\n\n/// Border radius for `<kbd>` elements.\n/// @type Number | List\n$keystroke-radius: $global-radius !default;\n\n/// Bottom border style for `<abbr>` elements.\n/// @type List\n$abbr-underline: 1px dotted $black !default;\n\n@mixin foundation-typography-base {\n  // Typography resets\n  div,\n  dl,\n  dt,\n  dd,\n  ul,\n  ol,\n  li,\n  h1,\n  h2,\n  h3,\n  h4,\n  h5,\n  h6,\n  pre,\n  form,\n  p,\n  blockquote,\n  th,\n  td {\n    margin: 0;\n    padding: 0;\n  }\n\n  // Paragraphs\n  p {\n    margin-bottom: $paragraph-margin-bottom;\n\n    font-size: inherit;\n    line-height: $paragraph-lineheight;\n    text-rendering: $paragraph-text-rendering;\n  }\n\n  // Emphasized text\n  em,\n  i {\n    font-style: italic;\n    line-height: inherit;\n  }\n\n  // Strong text\n  strong,\n  b {\n    font-weight: $global-weight-bold;\n    line-height: inherit;\n  }\n\n  // Small text\n  small {\n    font-size: $small-font-size;\n    line-height: inherit;\n  }\n\n  // Headings\n  h1, .h1,\n  h2, .h2,\n  h3, .h3,\n  h4, .h4,\n  h5, .h5,\n  h6, .h6 {\n    font-family: $header-font-family;\n    font-style: $header-font-style;\n    font-weight: $header-font-weight;\n    color: $header-color;\n    text-rendering: $header-text-rendering;\n\n    small {\n      line-height: 0;\n      color: $header-small-font-color;\n    }\n  }\n\n  // Heading styles\n  @each $size, $headers in $header-styles {\n    @include breakpoint($size) {\n      @each $header, $header-defs in $headers {\n        $font-size-temp: 1rem;\n        #{$header}, .#{$header} {\n\n          @if map-has-key($header-defs, font-size) {\n            $font-size-temp: rem-calc(map-get($header-defs, font-size));\n            font-size: $font-size-temp;\n          } @else if map-has-key($header-defs, fs) {\n            $font-size-temp: rem-calc(map-get($header-defs, fs));\n            font-size: $font-size-temp;\n          } @else if $size == $-zf-zero-breakpoint {\n            font-size: $font-size-temp;\n          }\n          @if map-has-key($header-defs, line-height) {\n            line-height: unitless-calc(map-get($header-defs, line-height), $font-size-temp);\n          } @else if map-has-key($header-defs, lh) {\n            line-height: unitless-calc(map-get($header-defs, lh), $font-size-temp);\n          } @else if $size == $-zf-zero-breakpoint {\n            line-height: unitless-calc($header-lineheight, $font-size-temp);\n          }\n\n          @if map-has-key($header-defs, margin-top) {\n            margin-top: rem-calc(map-get($header-defs, margin-top));\n          } @else if map-has-key($header-defs, mt) {\n            margin-top: rem-calc(map-get($header-defs, mt));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-top: 0;\n          }\n          @if map-has-key($header-defs, margin-bottom) {\n            margin-bottom: rem-calc(map-get($header-defs, margin-bottom));\n          } @else if map-has-key($header-defs, mb) {\n            margin-bottom: rem-calc(map-get($header-defs, mb));\n          } @else if $size == $-zf-zero-breakpoint {\n            margin-bottom: rem-calc($header-margin-bottom);\n          }\n        }\n      }\n    }\n  }\n\n  // Links\n  a {\n    line-height: inherit;\n    color: $anchor-color;\n    text-decoration: $anchor-text-decoration;\n\n    cursor: pointer;\n\n    &:hover,\n    &:focus {\n      color: $anchor-color-hover;\n      @if $anchor-text-decoration-hover != $anchor-text-decoration {\n        text-decoration: $anchor-text-decoration-hover;\n      }\n    }\n\n    img {\n      border: 0;\n    }\n  }\n\n  // Horizontal rule\n  hr {\n    clear: both;\n\n    max-width: $hr-width;\n    height: 0;\n    margin: $hr-margin;\n\n    border-top: 0;\n    border-right: 0;\n    border-bottom: $hr-border;\n    border-left: 0;\n  }\n\n  // Lists\n  ul,\n  ol,\n  dl {\n    margin-bottom: $list-margin-bottom;\n    list-style-position: $list-style-position;\n    line-height: $list-lineheight;\n  }\n\n  // List items\n  li {\n    font-size: inherit;\n  }\n\n  // Unordered lists\n  ul {\n    margin-#{$global-left}: $list-side-margin;\n    list-style-type: $list-style-type;\n  }\n\n  // Ordered lists\n  ol {\n    margin-#{$global-left}: $list-side-margin;\n  }\n\n  // Nested unordered/ordered lists\n  ul, ol {\n    & & {\n      margin-#{$global-left}: $list-nested-side-margin;\n      margin-bottom: 0;\n    }\n  }\n\n  // Definition lists\n  dl {\n    margin-bottom: $defnlist-margin-bottom;\n\n    dt {\n      margin-bottom: $defnlist-term-margin-bottom;\n      font-weight: $defnlist-term-weight;\n    }\n  }\n\n  // Blockquotes\n  blockquote {\n    margin: 0 0 $paragraph-margin-bottom;\n    padding: $blockquote-padding;\n    border-#{$global-left}: $blockquote-border;\n\n    &, p {\n      line-height: $paragraph-lineheight;\n      color: $blockquote-color;\n    }\n  }\n\n  // Citations\n  cite {\n    display: block;\n    font-size: $cite-font-size;\n    color: $cite-color;\n\n    &:before {\n      content: $cite-pseudo-content;\n    }\n  }\n\n  // Abbreviations\n  abbr, abbr[title] {\n    border-bottom: $abbr-underline;\n    cursor: help;\n    text-decoration: none;\n  }\n\n  // Figures\n  figure {\n    margin: 0;\n  }\n\n  // Code\n  code {\n    padding: $code-padding;\n\n    border: $code-border;\n    background-color: $code-background;\n\n    font-family: $code-font-family;\n    font-weight: $code-font-weight;\n    color: $code-color;\n  }\n\n  // Keystrokes\n  kbd {\n    margin: 0;\n    padding: $keystroke-padding;\n\n    background-color: $keystroke-background;\n\n    font-family: $keystroke-font;\n    color: $keystroke-color;\n\n    @if has-value($keystroke-radius) {\n      border-radius: $keystroke-radius;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group typography-helpers\n////\n\n/// Default font size for lead paragraphs.\n/// @type Number\n$lead-font-size: $global-font-size * 1.25 !default;\n\n/// Default line height for lead paragraphs.\n/// @type String\n$lead-lineheight: 1.6 !default;\n\n/// Default line height for subheaders.\n/// @type Number\n$subheader-lineheight: 1.4 !default;\n\n/// Default font color for subheaders.\n/// @type Color\n$subheader-color: $dark-gray !default;\n\n/// Default font weight for subheaders.\n/// @type String\n$subheader-font-weight: $global-weight-normal !default;\n\n/// Default top margin for subheaders.\n/// @type Number\n$subheader-margin-top: 0.2rem !default;\n\n/// Default bottom margin for subheaders.\n/// @type Number\n$subheader-margin-bottom: 0.5rem !default;\n\n/// Default font size for statistic numbers.\n/// @type Number\n$stat-font-size: 2.5rem !default;\n\n@mixin foundation-typography-helpers {\n  // Use to create a subheading under a main header\n  // Make sure you pair the two elements in a <header> element, like this:\n  // <header>\n  //   <h1>Heading</h1>\n  //   <h2>Subheading</h2>\n  // </header>\n  .subheader {\n    margin-top: $subheader-margin-top;\n    margin-bottom: $subheader-margin-bottom;\n\n    font-weight: $subheader-font-weight;\n    line-height: $subheader-lineheight;\n    color: $subheader-color;\n  }\n\n  // Use to style an introductory lead, deck, blurb, etc.\n  .lead {\n    font-size: $lead-font-size;\n    line-height: $lead-lineheight;\n  }\n\n  // Use to style a large number to display a statistic\n  .stat {\n    font-size: $stat-font-size;\n    line-height: 1;\n\n    p + & {\n      margin-top: -1rem;\n    }\n  }\n\n  ul, ol {\n    // Use to remove numbers from ordered list & bullets from unordered list\n    &.no-bullet {\n      margin-#{$global-left}: 0;\n      list-style: none;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@mixin foundation-text-alignment {\n  @each $size in $breakpoint-classes {\n    @include breakpoint($size) {\n      @each $align in (left, right, center, justify) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-text-#{$align} {\n            text-align: $align;\n          }\n        }\n        @else {\n          .text-#{$align} {\n            text-align: $align;\n          }\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// If `true`, all elements will have transparent backgrounds when printed, to save on ink.\n/// @type Boolean\n/// @group global\n$print-transparent-backgrounds: true !default;\n\n/// If `true`, displays next to all links their \"href\" when printed.\n/// @type Boolean\n/// @group global\n$print-hrefs: true !default;\n\n// sass-lint:disable-all\n\n@mixin foundation-print-styles {\n  .show-for-print { display: none !important; }\n\n  @media print {\n    * {\n      @if $print-transparent-backgrounds {\n        background: transparent !important;\n      }\n\n      box-shadow: none !important;\n\n      color: black !important; // Black prints faster: h5bp.com/s\n      text-shadow: none !important;\n    }\n\n    .show-for-print { display: block !important; }\n    .hide-for-print { display: none !important; }\n\n    table.show-for-print { display: table !important; }\n    thead.show-for-print { display: table-header-group !important; }\n    tbody.show-for-print { display: table-row-group !important; }\n    tr.show-for-print { display: table-row !important; }\n    td.show-for-print { display: table-cell !important; }\n    th.show-for-print { display: table-cell !important; }\n\n    // Display the URL of a link after the text\n    a,\n    a:visited { text-decoration: underline;}\n    @if $print-hrefs {\n      a[href]:after { content: ' (' attr(href) ')'; }\n    }\n\n    // Don't display the URL for images or JavaScript/internal links\n    .ir a:after,\n    a[href^='javascript:']:after,\n    a[href^='#']:after { content: ''; }\n\n    // Display what an abbreviation stands for after the text\n    abbr[title]:after { content: ' (' attr(title) ')'; }\n\n    // Prevent page breaks in the middle of a blockquote or preformatted text block\n    pre,\n    blockquote {\n      border: 1px solid $dark-gray;\n      page-break-inside: avoid;\n    }\n\n    // h5bp.com/t\n    thead { display: table-header-group; }\n\n    tr,\n    img { page-break-inside: avoid; }\n\n    img { max-width: 100% !important; }\n\n    @page { margin: 0.5cm; }\n\n    p,\n    h2,\n    h3 {\n      orphans: 3;\n      widows: 3;\n    }\n\n    // Avoid page breaks after a heading\n    h2,\n    h3 { page-break-after: avoid; }\n\n    // Helper to re-allow page breaks in the middle of certain elements (e.g. pre, blockquote, tr)\n    .print-break-inside {\n      page-break-inside: auto;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n// Margin Grid classes\n@mixin xy-base-grid-classes {\n\n  // Grid Container\n  .grid-container {\n    @include xy-grid-container;\n\n    &.fluid {\n      @include xy-grid-container(100%);\n    }\n\n    &.full {\n      @include xy-grid-container(100%, 0);\n    }\n  }\n\n  // Base grid styles\n  .grid-x {\n    @include xy-grid;\n  }\n\n  .cell {\n    @include xy-cell-base();\n    @include xy-cell-static($grid-columns, false, $gutter-type: padding);\n\n    &.auto {\n      @include xy-cell-base(auto);\n    }\n\n    &.shrink {\n      @include xy-cell-base(shrink);\n    }\n\n  }\n  .grid-x {\n    > .auto {\n      @include xy-cell-static(auto, false);\n    }\n\n    > .shrink {\n      @include xy-cell-static(shrink, false);\n    }\n  }\n\n  // Auto width\n  @include -zf-each-breakpoint() {\n    // This is a bit of a hack/workaround, see these issues & PRs for the backstory:\n    // https://github.com/zurb/foundation-sites/issues/10244\n    // https://github.com/zurb/foundation-sites/pull/10222 and\n    // https://github.com/zurb/foundation-sites/pull/10164\n    .grid-x {\n      $str: \"> .#{$-zf-size}-shrink, > .#{$-zf-size}-full\";\n      @for $i from 1 through $grid-columns {\n        $str: $str + \", > .#{$-zf-size}-#{$i}\"\n      }\n      #{$str} {\n        flex-basis: auto;\n      }\n    }\n  }\n\n  @include -zf-each-breakpoint() {\n    // Responsive \"auto\" modifier\n    @if not($-zf-size == small) {\n      .grid-x > .#{$-zf-size}-auto {\n        @include xy-cell-base(auto);\n        @include xy-cell-static(auto, false);\n      }\n    }\n\n    %-xy-cell-base-shrink-horizontal-#{$-zf-size} {\n      @include xy-cell-base(shrink);\n    }\n\n    // Responsive \"shrink\" modifier\n    @if not($-zf-size == small) {\n      .grid-x > .#{$-zf-size}-shrink {\n        @extend %-xy-cell-base-shrink-horizontal-#{$-zf-size};\n        @include xy-cell-static(shrink, false);\n      }\n    }\n\n    // Responsive width modifiers\n    @for $i from 1 through $grid-columns {\n      // Sizing (percentage)\n      .grid-x > .#{$-zf-size}-#{$i} {\n        @extend %-xy-cell-base-shrink-horizontal-#{$-zf-size};\n        @include xy-cell-static($i, false, $gutter-type: padding);\n      }\n    }\n  }\n\n  // Reset width when using `.grid-margin-x` not on `.grid-x`\n  .grid-margin-x:not(.grid-x) > .cell {\n    width: auto;\n  }\n\n  // Reset height when using `.grid-margin-y` not on `.grid-y`\n  .grid-margin-y:not(.grid-y) > .cell {\n    height: auto;\n  }\n}\n\n@mixin -xy-breakpoint-cell-classes($class-breakpoint, $gutter-breakpoint, $vertical) {\n  $prefix: if($class-breakpoint == $-zf-zero-breakpoint, '', '#{$class-breakpoint}-');\n  > .#{$prefix}auto {\n    @include xy-cell-static(auto, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n  }\n\n  > .#{$prefix}shrink {\n    @include xy-cell-static(shrink, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n  }\n\n  @for $i from 1 through $grid-columns {\n    // Sizing (percentage)\n    $classname: if($vertical, '.#{$class-breakpoint}-#{$i}', '.#{$class-breakpoint}-#{$i}');\n\n    > #{$classname} {\n      @include xy-cell-static($i, false, $breakpoint: $gutter-breakpoint, $vertical: $vertical);\n    }\n  }\n}\n\n// Margin Grid classes\n@mixin xy-margin-grid-classes(\n  $gutter-position: left right,\n  $vertical: false,\n  $wrapping-selector: '.grid-margin-x'\n){\n  #{$wrapping-selector} {\n    @include xy-gutters($negative: true, $gutter-position: $gutter-position);\n\n    // Base cell styles\n    > .cell {\n      @include xy-cell-static($vertical: $vertical);\n    }\n\n    // base styles need to all be before the auto and shrink styles\n    @include -zf-each-breakpoint() {\n      @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size) and $-zf-size != $-zf-zero-breakpoint) {\n        > .cell {\n          @include xy-cell-static($breakpoint: $-zf-size, $vertical: $vertical);\n        }\n      }\n    }\n\n    @include -zf-each-breakpoint() {\n\n      // This is purely for responsive gutters - the margin grid has to go back and adjust widths (or heights)\n      // for all prior breakpoints.\n      // As their gutter is defined with their width/height, even breakpoint without a new margin must be\n      // generated to not having their width/height overrided by re-adjusted smaller breakpoints.\n      @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size)) {\n        @each $bp in -zf-breakpoints-less-than($-zf-size) {\n          @include -xy-breakpoint-cell-classes($bp, $-zf-size, $vertical);\n        }\n      }\n\n      @include -xy-breakpoint-cell-classes($-zf-size, $-zf-size, $vertical);\n    }\n  }\n}\n\n// Padding Grid classes\n@mixin xy-padding-grid-classes {\n  .grid-padding-x {\n\n    // Negative margin for nested grids\n    .grid-padding-x {\n      @include xy-gutters($negative: true);\n    }\n\n    // Negative margin for grids within `grid-container/grid-container.fluid`\n    // This allows margin and padding grids to line up with eachother\n    .grid-container:not(.full) > & {\n      @include xy-gutters($negative: true);\n    }\n\n    // Base cell styles\n    > .cell {\n      @include xy-gutters($gutters: $grid-padding-gutters, $gutter-type: padding);\n    }\n  }\n}\n\n// Block Grid classes\n@mixin xy-block-grid-classes($margin-grid: true, $padding-grid: true) {\n  @if $padding-grid {\n    @include -zf-each-breakpoint {\n      @for $i from 1 through $xy-block-grid-max {\n        .#{$-zf-size}-up-#{$i} {\n          @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: padding, $breakpoint: $-zf-size);\n        }\n      }\n    }\n  }\n\n  @if $margin-grid {\n    @include -zf-each-breakpoint {\n      @for $i from 1 through $xy-block-grid-max {\n        // This is purely for responsive gutters - the margin grid has to go back and adjust widths (or heights)\n        // for prior breakpoints based on the responsive gutter.\n        @if(type-of($grid-margin-gutters) == 'map' and map-has-key($grid-margin-gutters, $-zf-size)) {\n          @each $bp in -zf-breakpoints-less-than($-zf-size) {\n            @if(map-has-key($grid-margin-gutters, $bp)) {\n              .grid-margin-x.#{$bp}-up-#{$i} {\n                @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: margin, $breakpoint: $-zf-size);\n              }\n            }\n          }\n        }\n      }\n      @for $i from 1 through $xy-block-grid-max {\n        .grid-margin-x.#{$-zf-size}-up-#{$i} {\n          @include xy-grid-layout($n: $i, $selector: '.cell', $gutter-output: false, $gutter-type: margin, $breakpoint: $-zf-size);\n        }\n      }\n    }\n  }\n}\n\n// Collapse classes\n@mixin xy-collapse-grid-classes($margin-grid: true, $padding-grid: true) {\n  @each $bp in $breakpoint-classes {\n    @if $margin-grid {\n      .#{$bp}-margin-collapse {\n        @include xy-grid-collapse($gutter-type: margin, $min-breakpoint: $bp);\n      }\n    }\n\n    @if $padding-grid {\n      .#{$bp}-padding-collapse {\n        @include xy-grid-collapse($gutter-type: padding, $min-breakpoint: $bp);\n      }\n    }\n  }\n}\n\n// Offset classes\n@mixin xy-offset-cell-classes {\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $grid-columns {\n      // Offsets\n      $o: $i - 1;\n\n      .#{$-zf-size}-offset-#{$o} {\n        @include xy-cell-offset($o, $gutters: $grid-padding-gutters, $gutter-type: padding, $breakpoint: $-zf-size);\n      }\n\n      .grid-margin-x > .#{$-zf-size}-offset-#{$o} {\n        @include xy-cell-offset($o, $breakpoint: $-zf-size);\n      }\n    }\n  }\n}\n\n// Vertical Grid classes\n@mixin xy-vertical-grid-classes(\n  $margin-grid: true,\n  $padding-grid: true\n) {\n\n  @include -zf-each-breakpoint() {\n    @if not($-zf-size == small) {\n    }\n  }\n\n  .grid-y {\n    @include xy-grid(vertical, false);\n\n\n    > .cell {\n      @include xy-cell-reset();\n    }\n\n    > .auto {\n      @include xy-cell-static(auto, false, $vertical: true);\n    }\n\n    > .shrink {\n      @include xy-cell-static(shrink, false, $vertical: true);\n    }\n\n\n    @include -zf-each-breakpoint() {\n      // This is a bit of a hack/workaround, see these issues and PRs for the backstory:\n      // https://github.com/zurb/foundation-sites/issues/10244\n      // https://github.com/zurb/foundation-sites/pull/10222 and\n      // https://github.com/zurb/foundation-sites/pull/10164\n      $str: \"> .#{$-zf-size}-shrink, > .#{$-zf-size}-full\";\n      @for $i from 1 through $grid-columns {\n        $str: $str + \", > .#{$-zf-size}-#{$i}\"\n      }\n      #{$str} {\n        flex-basis: auto;\n      }\n    }\n\n    @include -zf-each-breakpoint() {\n      // Responsive \"auto\" modifier\n      @if not($-zf-size == small) {\n        > .#{$-zf-size}-auto {\n          @include xy-cell-base(auto);\n          @include xy-cell-static(auto, false, $breakpoint: $-zf-size, $vertical: true);\n        }\n      }\n\n      %-xy-cell-base-shrink-vertical-#{$-zf-size} {\n        @include xy-cell-base(shrink);\n      }\n\n      // Responsive \"shrink\" modifier\n      @if not($-zf-size == small) {\n        > .#{$-zf-size}-shrink {\n          @extend %-xy-cell-base-shrink-vertical-#{$-zf-size};\n          @include xy-cell-static(shrink, false, $breakpoint: $-zf-size, $vertical: true);\n        }\n      }\n\n      // Responsive width modifiers\n      @for $i from 1 through $grid-columns {\n        // Sizing (percentage)\n        > .#{$-zf-size}-#{$i} {\n          @extend %-xy-cell-base-shrink-vertical-#{$-zf-size};\n          @include xy-cell-static($i, false, $vertical: true, $gutter-type: padding);\n        }\n      }\n\n    }\n  }\n\n  @if $padding-grid {\n    .grid-padding-y {\n      // Negative margin for nested grids\n      .grid-padding-y {\n        @include xy-gutters($negative: true, $gutter-position: top bottom);\n      }\n\n      // Base cell styles\n      > .cell {\n        @include xy-gutters($gutters: $grid-padding-gutters, $gutter-type: padding, $gutter-position: top bottom);\n      }\n    }\n  }\n\n  @if $margin-grid {\n    @include xy-margin-grid-classes(top bottom, true, '.grid-margin-y');\n  }\n\n}\n\n@mixin xy-frame-grid-classes($vertical-grid: true, $margin-grid: true) {\n  // Framed grid styles\n  .grid-frame {\n    @include xy-grid-frame;\n  }\n\n  .cell .grid-frame {\n    width: 100%; // Same as include with $nested, but with less css\n  }\n\n  .cell-block {\n    @include xy-cell-block();\n  }\n\n  .cell-block-y {\n    @include xy-cell-block(true);\n  }\n\n\n  .cell-block-container {\n    @include xy-cell-block-container();\n  }\n\n\n  @include -zf-each-breakpoint(false) {\n\n    .#{$-zf-size}-grid-frame {\n      @include xy-grid-frame;\n    }\n\n    .cell .#{$-zf-size}-grid-frame {\n      width: 100%; // Same as include with $nested, but with less css\n    }\n\n    .#{$-zf-size}-cell-block {\n      @include xy-cell-block();\n    }\n\n    .#{$-zf-size}-cell-block-container {\n      @include xy-cell-block-container();\n    }\n\n    .#{$-zf-size}-cell-block-y {\n      @include xy-cell-block(true);\n    }\n  }\n\n  @if $vertical-grid {\n    .grid-y {\n      &.grid-frame {\n        width: auto;\n        @include xy-grid-frame(true);\n      }\n\n      @include -zf-each-breakpoint(false) {\n        &.#{$-zf-size}-grid-frame {\n          width: auto;\n          @include xy-grid-frame(true);\n        }\n\n      }\n    }\n    .cell {\n      .grid-y.grid-frame {\n        height: 100%; // Same as include with $nested, but with less css\n      }\n      @include -zf-each-breakpoint(false) {\n        .grid-y.#{$-zf-size}-grid-frame {\n          height: 100%; // Same as include with $nested, but with less css\n        }\n      }\n    }\n  }\n  @if $margin-grid {\n    @include xy-margin-grid-classes(top bottom, true, '.grid-margin-y');\n    .grid-frame.grid-margin-y {\n      @include xy-grid-frame(true, false, $grid-margin-gutters, $include-base: false);\n    }\n    @include -zf-each-breakpoint(false) {\n      .grid-margin-y.#{$-zf-size}-grid-frame {\n        @include xy-grid-frame(true, false, $grid-margin-gutters, $-zf-size, false);\n      }\n    }\n  }\n}\n\n// Final classes\n@mixin foundation-xy-grid-classes(\n  $base-grid: true,\n  $margin-grid: true,\n  $padding-grid: true,\n  $block-grid: true,\n  $collapse: true,\n  $offset: true,\n  $vertical-grid: true,\n  $frame-grid: true\n) {\n\n  // Base grid styles\n  @if($base-grid) {\n    @include xy-base-grid-classes();\n  }\n\n  // Margin grid\n  @if($margin-grid) {\n    @include xy-margin-grid-classes();\n  }\n\n  // Padding grid\n  @if($padding-grid) {\n    @include xy-padding-grid-classes();\n  }\n\n  // Block grid\n  @if($block-grid) {\n    @include xy-block-grid-classes($margin-grid, $padding-grid);\n  }\n\n  // Collapse gutters\n  @if($collapse) {\n    @include xy-collapse-grid-classes($margin-grid, $padding-grid);\n  }\n\n  // Offset gutters\n  @if($offset) {\n    @include xy-offset-cell-classes();\n  }\n\n  // Vertical grid\n  @if($vertical-grid) {\n    @include xy-vertical-grid-classes($margin-grid, $padding-grid);\n  }\n\n  @if ($frame-grid) {\n    @include xy-frame-grid-classes($vertical-grid, $margin-grid)\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Create gutters for a cell/container.\n///\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts either margin or padding.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {Boolean} $negative [false] - Whether to apply the gutter as a negative value. Commonly used for nested grids.\n@mixin xy-gutters(\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $negative: false\n) {\n  $operator: if($negative, '-', '');\n\n  // If we have declared negative gutters, force type to `margin.\n  $gutter-type: if($negative, 'margin', $gutter-type);\n\n  // Output our margin gutters.\n  @if (type-of($gutters) == 'map') {\n    @include -zf-breakpoint-value(auto, $gutters) {\n      $gutter: rem-calc($-zf-bp-value) / 2;\n\n      // Loop through each gutter position\n      @each $value in $gutter-position {\n        #{$gutter-type}-#{$value}: unquote(\"#{$operator}#{$gutter}\");\n      }\n    }\n  }\n  @else if (type-of($gutters) == 'number') {\n    $gutter: rem-calc($gutters) / 2;\n\n    // Loop through each gutter position\n    @each $value in $gutter-position {\n      #{$gutter-type}-#{$value}: unquote(\"#{$operator}#{$gutter}\");\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Creates a max width container, designed to house your grid content.\n///\n/// @param {Number} $width [$grid-container] - a width to limit the container to.\n/// @param {Number} $padding [$grid-container-padding] - paddings of the container.\n@mixin xy-grid-container(\n  $width: $grid-container,\n  $padding: $grid-container-padding\n) {\n  @include xy-gutters($gutters: $padding, $gutter-type: padding);\n\n  max-width: $width;\n  margin-left: auto;\n  margin-right: auto;\n}\n\n/// Creates a container for your flex cells.\n///\n/// @param {Keyword} $direction [horizontal] - Either horizontal or vertical direction of cells within.\n/// @param {Boolean} $wrap [true] - If the cells within should wrap or not.\n@mixin xy-grid(\n  $direction: horizontal,\n  $wrap: true\n) {\n  $direction: if($direction == 'horizontal', row, column);\n  $wrap: if($wrap, wrap, nowrap);\n\n  display: flex;\n  flex-flow: $direction $wrap;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Calculate the percentage size of a cell.\n///\n/// @param {Number|List} $size [$grid-columns] - Size to make the cell. You can pass a value in multiple formats, such as `6`, `50%`, `1 of 2` or `1/3`.\n@function xy-cell-size(\n  $size: $grid-columns\n) {\n  // Parsing percents, decimals, n of n and number counts\n  @if type-of($size) == 'number' {\n    @if unit($size) == '%' {\n      $size: $size;\n    }\n    @else if $size < 1 {\n      $size: percentage($size);\n    }\n    @else {\n      $size: percentage($size / $grid-columns);\n    }\n  }\n\n  // Parsing \"n of n\" or \"n/n\" expressions\n  @else if type-of($size) == 'list' {\n    @if length($size) != 3 {\n      @error 'Wrong syntax for xy-cell-size(). Use the format \"n of n\" or \"n/n\".';\n    }\n    @else {\n      $size: percentage(nth($size, 1) / nth($size, 3));\n    }\n  }\n  // Anything else is incorrect\n  @else {\n    @error 'Wrong syntax for xy-cell-size(). Use a number, decimal, percentage, or \"n of n\" / \"n/n\".';\n  }\n\n  @return $size;\n}\n\n/// Sets base flex properties for cells.\n///\n/// @param {Keyword} $size [full] - The size of your cell. Accepts `full`, `auto`, `shrink` or `grow`.\n@mixin xy-cell-base($size: full) {\n  @if($size == 'full') {\n    // This is the base style, all others inherit from it\n    flex: 0 0 auto;\n    min-height: 0px;\n    min-width: 0px;\n  }\n  @else if ($size == 'auto') {\n    flex: 1 1 0px; // sass-lint:disable-line zero-unit\n  }\n  @else if ($size == 'shrink') {\n    flex: 0 0 auto;\n  }\n  @else if ($size == 'grow') {\n    flex: 1 0 auto;\n  }\n}\n\n/// Resets a cells width (or height if vertical is true) as well as strips its gutters.\n///\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-reset($vertical: true) {\n  $direction: if($vertical == true, width, height);\n  #{$direction}: auto;\n  max-#{$direction}: none;\n}\n\n// Sets our cell widths or heights depending on gutter type.\n@mixin -xy-cell-properties($size, $margin-gutter, $vertical) {\n  $direction: if($vertical == true, height, width);\n  @if($size == 'full') {\n    $val: if($margin-gutter == 0, 100%, calc(100% - #{rem-calc($margin-gutter)}));\n    #{$direction}: $val;\n  }\n  @else if ($size == 'auto') {\n    #{$direction}: auto;\n    $val: if($margin-gutter == 0, 100%, calc(100% - #{rem-calc($margin-gutter)}));\n  }\n  @else if ($size == 'shrink') {\n    #{$direction}: auto;\n  }\n  @else {\n    $val: if($margin-gutter == 0, #{xy-cell-size($size)}, calc(#{xy-cell-size($size)} - #{rem-calc($margin-gutter)}));\n    #{$direction}: $val;\n  }\n}\n\n/// Creates a cell for your grid.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (default) for 100% width, `auto` to use up available space and `shrink` to use up only required space.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Map or single value for gutters.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell(\n  $size: full,\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $breakpoint: null,\n  $vertical: false\n) {\n  $bp-is-fallback: false;\n\n  @if($breakpoint == null) {\n    // If `$bp-size` is available then use this, otherwise revert to the smallest bp.\n    @if(variable-exists(-zf-size) and type-of($-zf-size) != 'number') and $-zf-size != null {\n      $breakpoint: $-zf-size;\n    }\n    @else {\n      $breakpoint: $-zf-zero-breakpoint;\n      $bp-is-fallback: true;\n    }\n  }\n\n  // Get the gutter for the given breakpoint/value.\n  $gutter: -zf-get-bp-val($gutters, $breakpoint);\n  // If the breakpoint is a fallback, use a fallback gutter as well\n  @if ($bp-is-fallback == true and $gutter == null) {\n    $gutter: 0;\n  }\n\n  @if($gutter != null) {\n    // Base flex properties\n    @include xy-cell-base($size);\n\n    @if($gutter-type == 'margin') {\n      @include -xy-cell-properties($size, $gutter, $vertical);\n    }\n    @else {\n      @include -xy-cell-properties($size, 0, $vertical);\n    }\n\n    @if $gutter-output {\n      @include xy-gutters($gutter, $gutter-type, $gutter-position);\n    }\n  }\n  @else {\n    @warn 'xy-cell: no gutters were found in `$gutters` for \"$breakpoint: #{$breakpoint}\", cell was not generated`'\n  }\n}\n\n/// Creates a single breakpoint sized grid. Used to generate our grid classes.\n///\n/// @param {Keyword|Number} $size [full] - The size of your cell. Can be `full` (default) for 100% width, `auto` to use up available space and `shrink` to use up only required space.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from. If using with the `breakpoint()` mixin this will be set automatically unless manually entered.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-cell-static(\n  $size: full,\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $breakpoint: $-zf-zero-breakpoint,\n  $vertical: false\n) {\n\n  $gutter: -zf-get-bp-val($gutters, $breakpoint);\n  $gutter-position: if($vertical == true, top bottom, left right);\n\n  @if($gutter-type == 'margin') {\n    @include -xy-cell-properties($size, $gutter, $vertical);\n  }\n  @else {\n    @include -xy-cell-properties($size, 0, $vertical);\n  }\n\n  // If we want to output the gutters\n  @if($gutter-output) {\n    // TODO: Figure out if we need to pass breakpoint in here too.\n    @include xy-gutters($gutter, $gutter-type, $gutter-position);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Sizes child elements so that `$n` number of items appear on each row.\n///\n/// @param {Number} $n - Number of elements to display per row.\n/// @param {String} $selector ['.cell'] - Selector(s) to use for child elements.\n/// @param {Boolean} $gutter-output [true] - Whether or not to output gutters\n/// @param {Number|Map} $gutters [$grid-margin-gutters] - Map or single value for gutters.\n/// @param {Keyword} $gutter-type [margin] - Type of gutter to output. Accepts `margin` or `padding`.\n/// @param {List} $gutter-position [right left] - The position to apply gutters to. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {String} $breakpoint [null] - The breakpoint to use for the cell generation.\n/// @param {Boolean} $vertical [false] - Set to true to output vertical (height) styles rather than widths.\n@mixin xy-grid-layout(\n  $n,\n  $selector: '.cell',\n  $gutter-output: true,\n  $gutters: $grid-margin-gutters,\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $breakpoint: null,\n  $vertical: false\n) {\n  $size: percentage(1/$n);\n\n  & > #{$selector} {\n    @include xy-cell($size, $gutter-output, $gutters, $gutter-type, $gutter-position, $breakpoint, $vertical);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Collapses the grid a cells within it.\n///\n/// @param {String} $selector [.cell] - The child element to remove the gutter from.\n/// @param {Keyword} $gutter-type [margin] - The type of gutter to remove.\n/// @param {List} $gutter-position [right left] - The positions to remove gutters from. Accepts `top`, `bottom`, `left`, `right` in any combination.\n/// @param {Keyword} $min-breakpoint [$-zf-zero-breakpoint] - Minimum breakpoint in `$breakpoint-classes` for which to collapse the gutter.\n@mixin xy-grid-collapse(\n  $selector: '.cell',\n  $gutter-type: margin,\n  $gutter-position: right left,\n  $min-breakpoint: $-zf-zero-breakpoint\n) {\n  // First, lets negate any margins on the top level\n  @if ($gutter-type == 'margin') {\n\n    @include breakpoint($min-breakpoint) {\n      @each $value in $gutter-position {\n        margin-#{$value}: 0;\n      }\n\n      > #{$selector} {\n        @each $value in $gutter-position {\n          margin-#{$value}: 0;\n        }\n      }\n    }\n\n    $excluded-bps: -zf-breakpoints-less-than($min-breakpoint);\n\n    // Output new widths to not include gutters\n    @each $bp in $breakpoint-classes {\n      @if(sl-contain($excluded-bps, $bp)) {\n        @include breakpoint($min-breakpoint) {\n          @for $i from 1 through $grid-columns {\n            // Sizing (percentage)\n            > .#{$bp}-#{$i} {\n              @include xy-cell-static($i, $gutter-output: false, $gutter-type: padding);\n            }\n          }\n        }\n      } @else {\n        @include breakpoint($bp) {\n          @for $i from 1 through $grid-columns {\n            // Sizing (percentage)\n            > .#{$bp}-#{$i} {\n              @include xy-cell-static($i, $gutter-output: false, $gutter-type: padding);\n            }\n          }\n        }\n      }\n    }\n  }\n  @else {\n\n    @include breakpoint($min-breakpoint) {\n      @each $value in $gutter-position {\n        margin-#{$value}: 0;\n      }\n\n      > #{$selector} {\n        @each $value in $gutter-position {\n          padding-#{$value}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group xy-grid\n////\n\n/// Offsets a column to the right/bottom by `$n` columns.\n///\n/// @param {Number|List} $n - Size to offset by. You can pass in any value accepted by the `zf-cell()` mixin, such as `6`, `50%`, or `1 of 2`.\n/// @param {Number|Map} $gutters [$grid-margin-gutters] Map of gutters or single value to use for responsive gutters.\n/// @param {Keyword} $gutter-type [margin] The type of gutter to use. Can be `margin` or `padding`\n/// @param {Number|Array|Keyword} $breakpoint [$-zf-zero-breakpoint] - Single value, breakpoint name, or list of breakpoint names to use for `$gutters`. See `-zf-breakpoint-value()`.\n/// @param {Boolean} $vertical [false] Sets the direction of the offset. If set to true will apply margin-top instead.\n@mixin xy-cell-offset(\n $n,\n $gutters: $grid-margin-gutters,\n $gutter-type: margin,\n $breakpoint: $-zf-zero-breakpoint,\n $vertical: false\n) {\n  $direction: if($vertical, 'top', $global-left);\n\n  @include -zf-breakpoint-value($breakpoint, $gutters) {\n    $gutter: rem-calc($-zf-bp-value) / 2;\n    $gutter-margin: if($gutter-type == 'margin', $gutter, 0);\n    $size: if($gutter-margin == 0, #{xy-cell-size($n)}, calc(#{xy-cell-size($n)} + #{$gutter-margin}));\n\n    margin-#{$direction}: #{$size};\n  }\n}\n","/// Modifies a grid to give it \"frame\" behavior (no overflow, no wrap, stretch behavior)\n///\n/// @param {Boolean} $vertical [false] - Is grid vertical or horizontal. Should match grid.\n/// @param {Boolean} $nested [false] - Is grid nested or not. If nested is true this sets the frame to 100% height, otherwise will be 100vh.\n/// @param {Number|Map} $gutters [null] - Map or single value for gutters.\n/// @param {String} $breakpoint [null] - The name of the breakpoint size in your gutters map to get the size from.\n/// @param {Boolean} $include-base [true] - Include the base styles that don't vary per breakpoint.\n@mixin xy-grid-frame(\n  $vertical: false,\n  $nested: false,\n  $gutters: null,\n  $breakpoint: null,\n  $include-base: true\n) {\n\n  @if $include-base {\n    overflow: hidden;\n    position: relative;\n    flex-wrap: nowrap;\n    align-items: stretch;\n  }\n\n  @if $breakpoint == null and type-of($gutters) == 'map' {\n    @include -zf-each-breakpoint() {\n      @include xy-grid-frame($vertical, $nested, $gutters, $-zf-size, false);\n    }\n  } @else {\n    // Get our gutters if applicable\n    $gutter: -zf-get-bp-val($gutters, $breakpoint);\n\n    // If we have a gutter, add it to the width/height\n    @if $gutter {\n      @if $vertical == true {\n        $unit: if($nested == true, 100%, 100vh);\n        $gutter: rem-calc($gutter);\n        height: calc(#{$unit} + #{$gutter});\n      } @else {\n        $unit: if($nested == true, 100%, 100vw);\n        $gutter: rem-calc($gutter);\n        width: calc(#{$unit} + #{$gutter});\n      }\n    }\n    @else {\n      @if $vertical == true {\n        height: if($nested == true, 100%, 100vh);\n      } @else {\n        width: if($nested == true, 100%, 100vw);\n      }\n    }\n  }\n}\n\n/// Modifies a cell to give it \"block\" behavior (overflow auto, inertial scrolling)\n///\n/// @param {Boolean} $vertical [false] - Is grid vertical or horizontal. Should match grid.\n@mixin xy-cell-block(\n  $vertical: false\n) {\n  $property: if($vertical == true, 'overflow-y', 'overflow-x');\n\n  @if $vertical == true {\n    overflow-y: auto;\n    max-height: 100%;\n    min-height: 100%;\n  } @else {\n    overflow-x: auto;\n    max-width: 100%;\n  }\n\n  -webkit-overflow-scrolling: touch;\n  -ms-overflow-style: -ms-autohiding-scrollbar;\n}\n\n/// Container for inside a grid frame containing multiple blocks. Typically used\n/// as a modifier for a `.cell` to allow the cell to pass along flex sizing\n/// constraints / from parents to children.\n@mixin xy-cell-block-container() {\n  display: flex;\n  flex-direction: column;\n  max-height: 100%;\n\n  > .grid-x {\n    max-height: 100%;\n    flex-wrap: nowrap;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group button\n////\n\n/// Font family for button elements.\n/// @type Font\n$button-font-family: inherit !default;\n\n/// Padding inside buttons.\n/// @type List\n$button-padding: 0.85em 1em !default;\n\n/// Margin around buttons.\n/// @type List\n$button-margin: 0 0 $global-margin 0 !default;\n\n/// Default fill for buttons. Can either be `solid` or `hollow`.\n/// @type Keyword\n$button-fill: solid !default;\n\n/// Default background color for buttons.\n/// @type Color\n$button-background: $primary-color !default;\n\n/// Background color on hover for buttons.\n/// @type Color\n$button-background-hover: scale-color($button-background, $lightness: -15%) !default;\n\n/// Font color for buttons.\n/// @type List\n$button-color: $white !default;\n\n/// Alternative font color for buttons.\n/// @type List\n$button-color-alt: $black !default;\n\n/// Border radius for buttons, defaulted to global-radius.\n/// @type Number\n$button-radius: $global-radius !default;\n\n/// Border width for hollow outline buttons\n/// @type Number\n$button-hollow-border-width: 1px !default;\n\n/// Sizes for buttons.\n/// @type Map\n$button-sizes: (\n  tiny: 0.6rem,\n  small: 0.75rem,\n  default: 0.9rem,\n  large: 1.25rem,\n) !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$button-palette: $foundation-palette !default;\n\n/// opacity for a disabled button.\n/// @type List\n$button-opacity-disabled: 0.25 !default;\n\n/// Background color lightness on hover for buttons.\n/// @type Number\n$button-background-hover-lightness: -20% !default;\n\n/// Color lightness on hover for hollow buttons.\n/// @type Number\n$button-hollow-hover-lightness: -50% !default;\n\n// Internal: flip from margin-right to margin-left for defaults\n@if $global-text-direction == 'rtl' {\n  $button-margin: 0 0 $global-margin $global-margin !default;\n}\n\n/// transitions for buttons.\n/// @type List\n$button-transition: background-color 0.25s ease-out, color 0.25s ease-out !default;\n\n/// Additional responsive classes for .expanded\n/// @type Boolean\n$button-responsive-expanded: false !default;\n\n// TODO: Document button-base() mixin\n@mixin button-base {\n  @include disable-mouse-outline;\n  display: inline-block;\n  vertical-align: middle;\n  margin: $button-margin;\n\n  @if (type-of($button-padding) == 'map') {\n    @each $size, $padding in $button-padding {\n      @include breakpoint($size) {\n        padding: $padding;\n      }\n    }\n  }\n  @else {\n    padding: $button-padding;\n  }\n\n  border: 1px solid transparent;\n  border-radius: $button-radius;\n  transition: $button-transition;\n  font-family: $button-font-family;\n  font-size: map-get($button-sizes, default);\n  -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n  line-height: 1;\n  text-align: center;\n  cursor: pointer;\n}\n\n/// Expands a button to make it full-width.\n/// @param {Boolean} $expand [true] - Set to `true` to enable the expand behavior. Set to `false` to reverse this behavior.\n@mixin button-expand($expand: true) {\n  @if $expand {\n    display: block;\n    width: 100%;\n    margin-right: 0;\n    margin-left: 0;\n  }\n  @else {\n    display: inline-block;\n    width: auto;\n    margin: $button-margin;\n  }\n}\n\n/// Sets the visual style of a button.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n@mixin button-style(\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $background-hover-lightness: $button-background-hover-lightness\n) {\n  @if $color == auto {\n    $color: color-pick-contrast($background, ($button-color, $button-color-alt));\n  }\n\n  @if $background-hover == auto {\n    $background-hover: scale-color($background, $lightness: $background-hover-lightness);\n  }\n\n  background-color: $background;\n  color: $color;\n\n  &:hover, &:focus {\n    background-color: $background-hover;\n    color: $color;\n  }\n}\n\n/// Removes background fill on hover and focus for hollow buttons.\n@mixin button-hollow {\n  &,\n  &:hover,\n  &:focus {\n    background-color: transparent;\n  }\n\n  &.disabled,\n  &[disabled] {\n    &,\n    &:hover, &:focus {\n      background-color: transparent;\n    }\n  }\n}\n\n@mixin button-hollow-style(\n  $color: $button-background,\n  $hover-lightness: $button-hollow-hover-lightness,\n  $border-width: $button-hollow-border-width\n) {\n  $color-hover: scale-color($color, $lightness: $hover-lightness);\n\n  border: $border-width solid $color;\n  color: $color;\n\n  &:hover, &:focus {\n    border-color: $color-hover;\n    color: $color-hover;\n    &.disabled,\n    &[disabled] {\n      border: $border-width solid $color;\n      color: $color;\n    }\n  }\n}\n\n/// Adds disabled styles to a button by fading the element, reseting the cursor, and disabling pointer events.\n/// @param {Color} $background [$button-background] - Background color of the disabled button.\n/// @param {Color} $color [$button-color] - Text color of the disabled button. Set to `auto` to have the mixin automatically generate a color based on the background color.\n@mixin button-disabled(\n  $background: $button-background,\n  $color: $button-color\n) {\n  @if $color == auto {\n    $color: color-pick-contrast($background, ($button-color, $button-color-alt));\n  }\n\n  opacity: $button-opacity-disabled;\n  cursor: not-allowed;\n\n  &, &:hover, &:focus {\n    background-color: $background;\n    color: $color;\n  }\n}\n\n/// Adds a dropdown arrow to a button.\n/// @param {Number} $size [0.4em] - Size of the arrow. We recommend using an `em` value so the triangle scales when used inside different sizes of buttons.\n/// @param {Color} $color [white] - Color of the arrow.\n/// @param {Number} $offset [$button-padding] - Distance between the arrow and the text of the button. Defaults to whatever the right padding of a button is.\n@mixin button-dropdown(\n  $size: 0.4em,\n  $color: $white,\n  $offset: get-side($button-padding, right)\n) {\n  &::after {\n    @include css-triangle($size, $color, down);\n    position: relative;\n    top: 0.4em; // Aligns the arrow with the text of the button\n\n    display: inline-block;\n    float: #{$global-right};\n    margin-#{$global-left}: $offset;\n  }\n}\n\n/// Adds all styles for a button. For more granular control over styles, use the individual button mixins.\n/// @param {Boolean} $expand [false] - Set to `true` to make the button full-width.\n/// @param {Color} $background [$button-background] - Background color of the button.\n/// @param {Color} $background-hover [$button-background-hover] - Background color of the button on hover. Set to `auto` to have the mixin automatically generate a hover color.\n/// @param {Color} $color [$button-color] - Text color of the button. Set to `auto` to automatically generate a color based on the background color.\n/// @param {Keyword} $style [solid] - Set to `hollow` to create a hollow button. The color defined in `$background` will be used as the primary color of the button.\n@mixin button(\n  $expand: false,\n  $background: $button-background,\n  $background-hover: $button-background-hover,\n  $color: $button-color,\n  $style: $button-fill\n) {\n  @include button-base;\n\n  @if $style == solid {\n    @include button-style($background, $background-hover, $color);\n  }\n  @else if $style == hollow {\n    @include button-hollow;\n    @include button-hollow-style($background);\n  }\n\n  @if $expand {\n    @include button-expand;\n  }\n}\n\n@mixin foundation-button {\n  .button {\n    @include button;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} {\n        font-size: $value;\n      }\n    }\n\n    &.expanded { @include button-expand; }\n\n    @if $button-responsive-expanded {\n      @each $size in $breakpoint-classes {\n        @include breakpoint(#{$size} only) {\n          &.#{$size}-only-expanded {\n            @include button-expand;\n          }\n        }\n        @if $size != $-zf-zero-breakpoint {\n          @include breakpoint(#{$size} down) {\n            &.#{$size}-down-expanded {\n              @include button-expand;\n            }\n          }\n\n          @include breakpoint(#{$size}) {\n            &.#{$size}-expanded {\n              @include button-expand;\n            }\n          }\n        }\n      }\n    }\n\n    // Colors\n    @each $name, $color in $button-palette {\n      @if $button-fill != hollow {\n        &.#{$name} {\n          @include button-style($color, auto, auto);\n        }\n      }\n      @else {\n        &.#{$name} {\n          @include button-hollow-style($color);\n        }\n\n        &.#{$name}.dropdown::after {\n          border-top-color: $color;\n        }\n      }\n    }\n\n    // Disabled style\n    &.disabled,\n    &[disabled] {\n      @include button-disabled;\n\n      @each $name, $color in $button-palette {\n        &.#{$name} {\n          @include button-disabled($color, auto);\n        }\n      }\n    }\n\n    // Hollow style\n    @if $button-fill != hollow {\n      &.hollow {\n        @include button-hollow;\n        @include button-hollow-style;\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-hollow-style($color);\n          }\n        }\n      }\n    }\n\n    // Clear style\n    @if $button-fill != clear {\n      &.clear {\n        @include button-hollow;\n        @include button-hollow-style;\n\n        &, &:hover, &:focus {\n          &, &.disabled, &[disabled] {\n            border-color: transparent;\n          }\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            @include button-hollow-style($color);\n\n            &, &:hover,\n            &:focus {\n              &,\n              &.disabled,\n              &[disabled] {\n                border-color: transparent;\n              }\n            }\n          }\n        }\n      }\n    }\n\n    // Dropdown arrow\n    &.dropdown {\n      @include button-dropdown;\n\n      @if $button-fill == hollow {\n        &::after {\n          border-top-color: $button-background;\n        }\n      }\n\n      &.hollow, &.clear {\n        &::after {\n          border-top-color: $button-background;\n        }\n\n        @each $name, $color in $button-palette {\n          &.#{$name} {\n            &::after {\n              border-top-color: $color;\n            }\n          }\n        }\n      }\n    }\n\n    // Button with dropdown arrow only\n    &.arrow-only::after {\n      top: -0.1em;\n      float: none;\n      margin-#{$global-left}: 0;\n    }\n  }\n\n  a.button { // sass-lint:disable-line no-qualifying-elements\n    &:hover,\n    &:focus {\n      text-decoration: none;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group button-group\n////\n\n/// Margin for button groups.\n/// @type Number\n$buttongroup-margin: 1rem !default;\n\n/// Margin between buttons in a button group.\n/// @type Number\n$buttongroup-spacing: 1px !default;\n\n/// Selector for the buttons inside a button group.\n/// @type String\n$buttongroup-child-selector: '.button' !default;\n\n/// Maximum number of buttons that can be in an even-width button group. (Only needed when $global-flexbox: false;)\n/// @type Number\n$buttongroup-expand-max: 6 !default;\n\n/// Determines if $button-radius is applied to each button or the button group as a whole. Use $global-radius in _settings.scss to change radius.\n/// @type Boolean\n$buttongroup-radius-on-each: true !default;\n\n/// Add styles for a button group container.\n/// @param {String} $child-selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group(\n  $child-selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing\n) {\n  @include clearfix;\n  margin-bottom: $buttongroup-margin;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    align-items: stretch;\n  }\n  @else {\n    font-size: 0;\n  }\n\n  #{$child-selector} {\n    margin: 0;\n    margin-#{$global-right}: $spacing;\n    margin-bottom: $spacing;\n    font-size: map-get($button-sizes, default);\n\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n\n    &:last-child {\n      margin-#{$global-right}: 0;\n    }\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $button-radius;\n        border-bottom-#{$global-left}-radius: $button-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $button-radius;\n        border-bottom-#{$global-right}-radius: $button-radius;\n      }\n    }\n\n  }\n}\n\n/// Creates a full-width button group, making each button equal width.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside a button group.\n/// @param {Number} $spacing [$buttongroup-spacing] - Spacing between buttons in a button group.\n@mixin button-group-expand(\n  $selector: $buttongroup-child-selector,\n  $spacing: $buttongroup-spacing,\n  $count: null\n) {\n  @if not $global-flexbox {\n    margin-#{$global-right}: -$spacing;\n\n    &::before,\n    &::after {\n      display: none;\n    }\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n    @else {\n      // One child\n      &:first-child {\n        &:last-child {\n          width: calc(100% - #{$spacing});\n        }\n      }\n\n      // Two or more childreen\n      @for $i from 2 through $buttongroup-expand-max {\n        &:first-child:nth-last-child(#{$i}) {\n          &, &:first-child:nth-last-child(#{$i}) ~ #{$selector} {\n            display: inline-block;\n            width: calc(#{percentage(1 / $i)} - #{$spacing});\n            margin-#{$global-right}: $spacing;\n\n            &:last-child {\n              margin-#{$global-right}: $spacing * -$buttongroup-expand-max;\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n/// Stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-stack(\n  $selector: $buttongroup-child-selector\n) {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n  }\n\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 100%;\n    }\n    @else {\n      width: 100%;\n    }\n\n    &:last-child {\n      margin-bottom: 0;\n    }\n\n\n    @if not $buttongroup-radius-on-each {\n      border-radius: 0;\n\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: $global-radius;\n      }\n\n      &:last-child {\n        margin-bottom: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n      }\n    }\n\n  }\n}\n\n/// Un-stacks the buttons in a button group.\n/// @param {String} $selector [$buttongroup-child-selector] - Selector for the buttons inside the button group.\n@mixin button-group-unstack(\n  $selector: $buttongroup-child-selector\n) {\n  #{$selector} {\n    @if $global-flexbox {\n      flex: 0 0 auto;\n    }\n    @else {\n      width: auto;\n    }\n    margin-bottom: 0;\n\n    @if not $buttongroup-radius-on-each {\n      &:first-child {\n        border-top-#{$global-left}-radius: $global-radius;\n        border-top-#{$global-right}-radius: 0;\n        border-bottom-#{$global-left}-radius: $global-radius;\n      }\n\n      &:last-child {\n        border-top-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-right}-radius: $global-radius;\n        border-bottom-#{$global-left}-radius: 0;\n      }\n    }\n\n  }\n}\n\n@mixin foundation-button-group {\n  .button-group {\n    @include button-group;\n\n    // Sizes\n    @each $size, $value in map-remove($button-sizes, default) {\n      &.#{$size} #{$buttongroup-child-selector} {\n        font-size: $value;\n      }\n    }\n\n    // Even-width Group\n    &.expanded {\n      @include button-group-expand;\n    }\n\n    // Colors\n    @each $name, $color in $button-palette {\n      @if $button-fill != hollow {\n        &.#{$name} #{$buttongroup-child-selector} {\n          @include button-style($color, auto, auto);\n        }\n      }\n      @else {\n        &.#{$name} #{$buttongroup-child-selector} {\n          @include button-hollow;\n          @include button-hollow-style($color);\n        }\n      }\n    }\n\n    &.stacked,\n    &.stacked-for-small,\n    &.stacked-for-medium {\n      @include button-group-stack;\n\n      &.expanded {\n        @include button-group-expand;\n      }\n    }\n\n    &.stacked-for-small {\n      @include breakpoint(medium) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-medium {\n      @include breakpoint(large) {\n        @include button-group-unstack;\n      }\n    }\n\n    &.stacked-for-small.expanded {\n      @include breakpoint(small only) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n\n    &.stacked-for-medium.expanded {\n      @include breakpoint(medium down) {\n        display: block;\n\n        #{$buttongroup-child-selector} {\n          display: block;\n          margin-#{$global-right}: 0;\n        }\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group close-button\n////\n\n/// Default position of the close button. The first value should be `right` or `left`, and the second value should be `top` or `bottom`.\n/// @type List\n$closebutton-position: right top !default;\n\n/// Right (or left) offset(s) for a close button.\n/// @type Number|Map\n$closebutton-offset-horizontal: (\n  small: 0.66rem,\n  medium: 1rem,\n) !default;\n\n/// Top (or bottom) offset(s) for a close button.\n/// @type Number|Map\n$closebutton-offset-vertical: (\n  small: 0.33em,\n  medium: 0.5rem,\n) !default;\n\n/// Default font size(s) of the close button.\n/// @type Number|Map\n$closebutton-size: (\n  small: 1.5em,\n  medium: 2em,\n) !default;\n\n/// The line-height of the close button. It affects the spacing of the element.\n/// @type Number\n$closebutton-lineheight: 1 !default;\n\n/// Default color of the close button.\n/// @type Color\n$closebutton-color: $dark-gray !default;\n\n/// Default color of the close button when being hovered on.\n/// @type Color\n$closebutton-color-hover: $black !default;\n\n\n/// Get the size and position for a close button. If the input value is a number, the number is returned. If the input value is a config map and the map has the key `$size`, the value is returned.\n///\n/// @param {Number|Map} $value - A number or map that represents the size or position value(s) of the close button.\n/// @param {Keyword} $size - The size of the close button to use.\n///\n/// @return {Number} The given number or the value found in the map.\n@function -zf-get-size-val($value, $size) {\n  // Check if the value is a number\n  @if type-of($value) == 'number' {\n    // If it is, just return the number\n    @return $value;\n  }\n\n  // Check if the size name exists in the value map\n  @else if map-has-key($value, $size) {\n    // If it does, return the value\n    @return map-get($value, $size);\n  }\n}\n\n/// Sets the size and position of a close button.\n/// @param {Keyword} $size [medium] - The size to use. Set to `small` to create a small close button. The 'medium' values defined in `$closebutton-*` variables will be used as the default size and position of the close button.\n@mixin close-button-size($size) {\n  $x: nth($closebutton-position, 1);\n  $y: nth($closebutton-position, 2);\n\n  #{$x}: -zf-get-size-val($closebutton-offset-horizontal, $size);\n  #{$y}: -zf-get-size-val($closebutton-offset-vertical, $size);\n  font-size: -zf-get-size-val($closebutton-size, $size);\n  line-height: -zf-get-size-val($closebutton-lineheight, $size);\n}\n\n/// Adds styles for a close button, using the styles in the settings variables.\n@mixin close-button {\n  $x: nth($closebutton-position, 1);\n  $y: nth($closebutton-position, 2);\n\n  @include disable-mouse-outline;\n  position: absolute;\n  color: $closebutton-color;\n  cursor: pointer;\n\n  &:hover,\n  &:focus {\n    color: $closebutton-color-hover;\n  }\n}\n\n@mixin foundation-close-button {\n  .close-button {\n    @include close-button;\n\n    &.small { @include close-button-size(small) }\n    &, &.medium { @include close-button-size(medium) }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group label\n////\n\n/// Default background color for labels.\n/// @type Color\n$label-background: $primary-color !default;\n\n/// Default text color for labels.\n/// @type Color\n$label-color: $white !default;\n\n/// Alternate text color for labels.\n/// @type Color\n$label-color-alt: $black !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$label-palette: $foundation-palette !default;\n\n/// Default font size for labels.\n/// @type Number\n$label-font-size: 0.8rem !default;\n\n/// Default padding inside labels.\n/// @type Number\n$label-padding: 0.33333rem 0.5rem !default;\n\n/// Default radius of labels.\n/// @type Number\n$label-radius: $global-radius !default;\n\n/// Generates base styles for a label.\n@mixin label {\n  display: inline-block;\n  padding: $label-padding;\n\n  border-radius: $label-radius;\n\n  font-size: $label-font-size;\n  line-height: 1;\n  white-space: nowrap;\n  cursor: default;\n}\n\n@mixin foundation-label {\n  .label {\n    @include label;\n\n    background: $label-background;\n    color: $label-color;\n\n    @each $name, $color in $label-palette {\n      &.#{$name} {\n        background: $color;\n        color: color-pick-contrast($color, ($label-color, $label-color-alt));\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// Adds styles for a progress bar container.\n@mixin progress-container {\n  height: $progress-height;\n  margin-bottom: $progress-margin-bottom;\n  border-radius: $progress-radius;\n  background-color: $progress-background;\n}\n\n/// Adds styles for the inner meter of a progress bar.\n@mixin progress-meter {\n  position: relative;\n  display: block;\n  width: 0%;\n  height: 100%;\n  background-color: $progress-meter-background;\n\n  @if has-value($progress-radius) {\n    border-radius: $global-radius;\n  }\n}\n\n/// Adds styles for text in the progress meter.\n@mixin progress-meter-text {\n  @include absolute-center;\n  margin: 0;\n  font-size: 0.75rem;\n  font-weight: bold;\n  color: $white;\n  white-space: nowrap;\n\n  @if has-value($progress-radius) {\n    border-radius: $progress-radius;\n  }\n}\n\n@mixin foundation-progress-bar {\n  // Progress bar\n  .progress {\n    @include progress-container;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        .progress-meter {\n          background-color: $color;\n        }\n      }\n    }\n  }\n\n  // Inner meter\n  .progress-meter {\n    @include progress-meter;\n  }\n\n  // Inner meter text\n  .progress-meter-text {\n    @include progress-meter-text;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group progress-bar\n////\n\n/// Height of a progress bar.\n/// @type Number\n$progress-height: 1rem !default;\n\n/// Background color of a progress bar.\n/// @type Color\n$progress-background: $medium-gray !default;\n\n/// Bottom margin of a progress bar.\n/// @type Number\n$progress-margin-bottom: $global-margin !default;\n\n/// Default color of a progress bar's meter.\n/// @type Color\n$progress-meter-background: $primary-color !default;\n\n/// Default radius of a progress bar.\n/// @type Number\n$progress-radius: $global-radius !default;\n\n@mixin foundation-progress-element {\n  progress {\n    display: block;\n    width: 100%;\n    height: $progress-height;\n    margin-bottom: $progress-margin-bottom;\n\n    appearance: none;\n\n    @if has-value($progress-radius) {\n      border-radius: $progress-radius;\n    }\n\n    // For Firefox\n    border: 0;\n    background: $progress-background;\n\n    &::-webkit-progress-bar {\n      background: $progress-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    &::-webkit-progress-value {\n      background: $progress-meter-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    &::-moz-progress-bar {\n      background: $progress-meter-background;\n\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n    }\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        // Internet Explorer sets the fill with color\n        color: $color;\n\n        &::-webkit-progress-value {\n          background: $color;\n        }\n\n        &::-moz-progress-bar {\n          background: $color;\n        }\n      }\n    }\n\n    // For IE and Edge\n    &::-ms-fill { // sass-lint:disable-line no-vendor-prefixes\n      @if has-value($progress-radius) {\n        border-radius: $progress-radius;\n      }\n\n      border: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// [TODO] Check how plugin confirms disabled or vertical status\n// [TODO] Check if transition: all; is necessary\n\n////\n/// @group slider\n////\n\n/// Default slider width of a vertical slider. (Doesn't apply to the native slider.)\n/// @type Number\n$slider-width-vertical: 0.5rem !default;\n\n/// Transition properties to apply to the slider handle and fill. (Doesn't apply to the native slider.)\n/// @type Transition\n$slider-transition: all 0.2s ease-in-out !default;\n\n/// Adds the general styles for sliders.\n@mixin slider-container {\n  position: relative;\n  height: $slider-height;\n  margin-top: 1.25rem;\n  margin-bottom: 2.25rem;\n\n  background-color: $slider-background;\n  cursor: pointer;\n  user-select: none;\n  touch-action: none;\n}\n\n/// Adds the general styles for active fill for sliders.\n@mixin slider-fill {\n  position: absolute;\n  top: 0;\n  left: 0;\n\n  display: inline-block;\n  max-width: 100%;\n  height: $slider-height;\n\n  background-color: $slider-fill-background;\n  transition: $slider-transition;\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n/// Adds the general styles for the slider handles.\n@mixin slider-handle {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  left: 0;\n  z-index: 1;\n\n  display: inline-block;\n  width: $slider-handle-width;\n  height: $slider-handle-height;\n\n  border-radius: $slider-radius;\n  background-color: $slider-handle-background;\n  transition: $slider-transition;\n  touch-action: manipulation;\n\n  &:hover {\n    background-color: scale-color($slider-handle-background, $lightness: -15%);\n  }\n\n  &.is-dragging {\n    transition: all 0s linear;\n  }\n}\n\n@mixin slider-disabled {\n  opacity: $slider-opacity-disabled;\n  cursor: not-allowed;\n}\n\n@mixin slider-vertical {\n  display: inline-block;\n  width: $slider-width-vertical;\n  height: 12.5rem;\n  margin: 0 1.25rem;\n  transform: scale(1, -1);\n\n  .slider-fill {\n    top: 0;\n    width: $slider-width-vertical;\n    max-height: 100%;\n  }\n\n  .slider-handle {\n    position: absolute;\n    top: 0;\n    left: 50%;\n    width: $slider-handle-height;\n    height: $slider-handle-width;\n    transform: translateX(-50%);\n  }\n}\n\n@mixin foundation-slider {\n  // Container\n  .slider {\n    @include slider-container;\n  }\n\n  // Fill area\n  .slider-fill {\n    @include slider-fill;\n  }\n\n  // Draggable handle\n  .slider-handle {\n    @include slider-handle;\n  }\n\n  // Disabled state\n  .slider.disabled,\n  .slider[disabled] {\n    @include slider-disabled;\n  }\n\n  // Vertical slider\n  .slider.vertical {\n    @include slider-vertical;\n  }\n\n  // RTL support\n  @if $global-text-direction == rtl {\n    .slider:not(.vertical) {\n      transform: scale(-1, 1);\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group slider\n////\n\n/// Default height of the slider.\n/// @type Number\n$slider-height: 0.5rem !default;\n\n/// Default background color of the slider's track.\n/// @type Color\n$slider-background: $light-gray !default;\n\n/// Default color of the active fill color of the slider.\n/// @type Color\n$slider-fill-background: $medium-gray !default;\n\n/// Default height of the handle of the slider.\n/// @type Number\n$slider-handle-height: 1.4rem !default;\n\n/// Default width of the handle of the slider.\n/// @type Number\n$slider-handle-width: 1.4rem !default;\n\n/// Default color of the handle for the slider.\n/// @type Color\n$slider-handle-background: $primary-color !default;\n\n/// Default fade amount of a disabled slider.\n/// @type Number\n$slider-opacity-disabled: 0.25 !default;\n\n/// Default radius for slider.\n/// @type Number\n$slider-radius: $global-radius !default;\n\n@mixin foundation-range-input {\n  input[type='range'] {  // sass-lint:disable-line no-qualifying-elements\n    $margin: ($slider-handle-height - $slider-height) / 2;\n\n    display: block;\n    width: 100%;\n    height: auto;\n    margin-top: $margin;\n    margin-bottom: $margin;\n\n    appearance: none;\n    border: 0;\n    line-height: 1;\n    cursor: pointer;\n\n    @if has-value($slider-radius) {\n      border-radius: $slider-radius;\n    }\n\n    &:focus {\n      outline: 0;\n    }\n\n    &[disabled] {\n      opacity: $slider-opacity-disabled;\n    }\n\n    // sass-lint:disable no-vendor-prefix\n\n    // Chrome/Safari\n    &::-webkit-slider-runnable-track {\n      height: $slider-height;\n      background: $slider-background;\n    }\n\n    &::-webkit-slider-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      margin-top: -$margin;\n\n      -webkit-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    // Firefox\n    &::-moz-range-track {\n      height: $slider-height;\n      -moz-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-background;\n    }\n\n    &::-moz-range-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      margin-top: -$margin;\n\n      -moz-appearance: none; // sass-lint:disable-line no-vendor-prefixes\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    // Internet Explorer\n    &::-ms-track {\n      height: $slider-height;\n\n      border: 0;\n      border-top: $margin solid $body-background;\n      border-bottom: $margin solid $body-background;\n      background: $slider-background;\n\n      overflow: visible;\n      color: transparent;\n    }\n\n    &::-ms-thumb {\n      width: $slider-handle-width;\n      height: $slider-handle-height;\n      border: 0;\n      background: $slider-handle-background;\n\n      @if has-value($slider-radius) {\n        border-radius: $slider-radius;\n      }\n    }\n\n    &::-ms-fill-lower {\n      background: $slider-fill-background;\n    }\n\n    &::-ms-fill-upper {\n      background: $slider-background;\n    }\n\n    @at-root {\n      output {\n        vertical-align: middle;\n        margin-left: 0.5em;\n        line-height: $slider-handle-height;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group switch\n////\n\n/// Background color of a switch.\n/// @type Color\n$switch-background: $medium-gray !default;\n\n/// Background active color of a switch.\n/// @type Color\n$switch-background-active: $primary-color !default;\n\n/// Height of a switch, with no class applied.\n/// @type Number\n$switch-height: 2rem !default;\n\n/// Height of a switch with .tiny class.\n/// @type Number\n$switch-height-tiny: 1.5rem !default;\n\n/// Height of a switch with .small class.\n/// @type Number\n$switch-height-small: 1.75rem !default;\n\n/// Height of a switch with .large class.\n/// @type Number\n$switch-height-large: 2.5rem !default;\n\n/// Border radius of the switch\n/// @type Number\n$switch-radius: $global-radius !default;\n\n/// border around a modal.\n/// @type Number\n$switch-margin: $global-margin !default;\n\n/// Background color for the switch container and paddle.\n/// @type Color\n$switch-paddle-background: $white !default;\n\n/// Spacing between a switch paddle and the edge of the body.\n/// @type Number\n$switch-paddle-offset: 0.25rem !default;\n\n/// border radius of the switch paddle\n/// @type Number\n$switch-paddle-radius: $global-radius !default;\n\n/// switch transition.\n/// @type Number\n$switch-paddle-transition: all 0.25s ease-out !default;\n\n// make them variables\n// ask about accessibility on label\n// change class name for text\n\n/// Adds styles for a switch container. Apply this to a container class.\n@mixin switch-container {\n  position: relative;\n  margin-bottom: $switch-margin;\n  outline: 0;\n\n  // These properties cascade down to the switch text\n  font-size: rem-calc(14);\n  font-weight: bold;\n  color: $white;\n\n  user-select: none;\n}\n\n/// Adds styles for a switch input. Apply this to an `<input>` within a switch.\n@mixin switch-input {\n  position: absolute;\n  margin-bottom: 0;\n  opacity: 0;\n}\n\n/// Adds styles for the background and paddle of a switch. Apply this to a `<label>` within a switch.\n@mixin switch-paddle {\n  $switch-width: $switch-height * 2;\n  $paddle-height: $switch-height - ($switch-paddle-offset * 2);\n  $paddle-width: $switch-height - ($switch-paddle-offset * 2);\n  $paddle-active-offest: $switch-width - $paddle-width - $switch-paddle-offset;\n\n  position: relative;\n  display: block;\n  width: $switch-width;\n  height: $switch-height;\n\n  border-radius: $switch-radius;\n  background: $switch-background;\n  transition: $switch-paddle-transition;\n\n  // Resetting these <label> presets so type styles cascade down\n  font-weight: inherit;\n  color: inherit;\n\n  cursor: pointer;\n\n  // Needed to override specificity\n  input + & {\n    margin: 0;\n  }\n\n  // The paddle itself\n  &::after {\n    position: absolute;\n    top: $switch-paddle-offset;\n    #{$global-left}: $switch-paddle-offset;\n\n    display: block;\n    width: $paddle-width;\n    height: $paddle-height;\n\n    transform: translate3d(0, 0, 0);\n    border-radius: $switch-paddle-radius;\n    background: $switch-paddle-background;\n    transition: $switch-paddle-transition;\n    content: '';\n  }\n\n  // Change the visual style when the switch is active\n  input:checked ~ & {\n    background: $switch-background-active;\n\n    &::after {\n      #{$global-left}: $paddle-active-offest;\n    }\n  }\n\n  input:focus ~ & {\n    @include disable-mouse-outline;\n  }\n}\n\n/// Adds base styles for active/inactive text inside a switch. Apply this to text elements inside the switch `<label>`.\n@mixin switch-text {\n  position: absolute;\n  top: 50%;\n  transform: translateY(-50%);\n}\n\n/// Adds styles for the active state text within a switch.\n@mixin switch-text-active {\n  #{$global-left}: 8%;\n  display: none;\n\n  input:checked + label > & {\n    display: block;\n  }\n}\n\n/// Adds styles for the inactive state text within a switch.\n@mixin switch-text-inactive {\n  #{$global-right}: 15%;\n\n  input:checked + label > & {\n    display: none;\n  }\n}\n\n/// Changes the size of a switch by modifying the size of the body and paddle. Apply this to a switch container.\n/// @param {Number} $font-size [1rem] - Font size of label text within the switch.\n/// @param {Number} $switch-height [2rem] - Height of the switch body.\n/// @param {Number} $paddle-offset [0.25rem] - Spacing between the switch paddle and the edge of the switch body.\n@mixin switch-size(\n  $font-size: 1rem,\n  $switch-height: 2rem,\n  $paddle-offset: 0.25rem\n) {\n\n  $switch-width: $switch-height * 2;\n  $paddle-width: $switch-height - ($paddle-offset * 2);\n  $paddle-height: $switch-height - ($paddle-offset * 2);\n  $paddle-active-offest: $switch-width - $paddle-width - $paddle-offset;\n\n  height: $switch-height;\n\n  .switch-paddle {\n    width: $switch-width;\n    height: $switch-height;\n    font-size: $font-size;\n  }\n\n  .switch-paddle::after {\n    top: $paddle-offset;\n    #{$global-left}: $paddle-offset;\n    width: $paddle-width;\n    height: $paddle-height;\n  }\n\n  input:checked ~ .switch-paddle::after {\n    #{$global-left}: $paddle-active-offest;\n  }\n}\n\n@mixin foundation-switch {\n  // Container class\n  .switch {\n    height: $switch-height;\n    @include switch-container;\n  }\n\n  // <input> element\n  .switch-input {\n    @include switch-input;\n  }\n\n  // <label> element\n  .switch-paddle {\n    @include switch-paddle;\n  }\n\n  // Base label text styles\n  %switch-text {\n    @include switch-text;\n  }\n\n  // Active label text styles\n  .switch-active {\n    @extend %switch-text;\n    @include switch-text-active;\n  }\n\n  // Inactive label text styles\n  .switch-inactive {\n    @extend %switch-text;\n    @include switch-text-inactive;\n  }\n\n  // Switch sizes\n  .switch.tiny {\n    @include switch-size(rem-calc(10), $switch-height-tiny, $switch-paddle-offset);\n  }\n\n  .switch.small {\n    @include switch-size(rem-calc(12), $switch-height-small, $switch-paddle-offset);\n  }\n\n  .switch.large {\n    @include switch-size(rem-calc(16), $switch-height-large, $switch-paddle-offset);\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n// sass-lint:disable no-qualifying-elements\n\n////\n/// @group table\n////\n\n/// Default color for table background.\n/// @type Color\n$table-background: $white  !default;\n\n/// Default scale for darkening the striped table rows and the table border.\n/// @type Number\n$table-color-scale: 5% !default;\n\n/// Default style for table border.\n/// @type List\n$table-border: 1px solid smart-scale($table-background, $table-color-scale) !default;\n\n/// Default padding for table.\n/// @type Number\n$table-padding: rem-calc(8 10 10) !default;\n\n/// Default scale for darkening the table rows on hover.\n/// @type Number\n$table-hover-scale: 2% !default;\n\n/// Default color of standard rows on hover.\n/// @type List\n$table-row-hover: darken($table-background, $table-hover-scale) !default;\n\n/// Default color of striped rows on hover.\n/// @type List\n$table-row-stripe-hover: darken($table-background, $table-color-scale + $table-hover-scale) !default;\n\n/// If `true`, tables are striped by default and an .unstriped class is created. If `false`, a .striped class is created.\n/// @type Boolean\n$table-is-striped: true !default;\n\n/// Default background color for striped rows.\n/// @type Color\n$table-striped-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default value for showing the stripe on rows of the tables, excluding the header and footer. If even, the even rows will have a background color. If odd, the odd rows will have a background color. If empty, or any other value, the table rows will have no striping.\n/// @type Keyword\n$table-stripe: even !default;\n\n/// Default color for header background.\n/// @type Color\n$table-head-background: smart-scale($table-background, $table-color-scale / 2) !default;\n\n/// Default color of header rows on hover.\n/// @type List\n$table-head-row-hover: darken($table-head-background, $table-hover-scale) !default;\n\n/// Default color for footer background.\n/// @type Color\n$table-foot-background: smart-scale($table-background, $table-color-scale) !default;\n\n/// Default color of footer rows on hover.\n/// @type List\n$table-foot-row-hover: darken($table-foot-background, $table-hover-scale) !default;\n\n/// Default font color for header.\n/// @type Color\n$table-head-font-color: $body-font-color !default;\n\n/// Default font color for footer.\n/// @type Color\n$table-foot-font-color: $body-font-color !default;\n\n/// Default value for showing the header when using stacked tables.\n/// @type Boolean\n$show-header-for-stacked: false !default;\n\n/// Breakpoint at which stacked table switches from mobile to desktop view.\n/// @type Breakpoint\n$table-stack-breakpoint: medium !default;\n\n@mixin -zf-table-stripe($stripe: $table-stripe) {\n  tr {\n    // If stripe is set to even, darken the even rows.\n    @if $stripe == even {\n      &:nth-child(even) {\n        border-bottom: 0;\n        background-color: $table-striped-background;\n      }\n    }\n\n    // If stripe is set to odd, darken the odd rows.\n    @else if $stripe == odd {\n      &:nth-child(odd) {\n        background-color: $table-striped-background;\n      }\n    }\n  }\n}\n\n@mixin -zf-table-unstripe() {\n  tr {\n    border-bottom: 0;\n    border-bottom: $table-border;\n    background-color: $table-background;\n  }\n}\n\n@mixin -zf-table-children-styles($stripe: $table-stripe, $is-striped: $table-is-striped) {\n  thead,\n  tbody,\n  tfoot {\n    border: $table-border;\n    background-color: $table-background;\n  }\n\n  // Caption\n  caption {\n    padding: $table-padding;\n    font-weight: $global-weight-bold;\n  }\n\n  // Table head\n  thead {\n    background: $table-head-background;\n    color: $table-head-font-color;\n  }\n\n  // Table foot\n  tfoot {\n    background: $table-foot-background;\n    color: $table-foot-font-color;\n  }\n\n  // Table head and foot\n  thead,\n  tfoot {\n    // Rows within head and foot\n    tr {\n      background: transparent;\n    }\n\n    // Cells within head and foot\n    th,\n    td {\n      padding: $table-padding;\n      font-weight: $global-weight-bold;\n      text-align: #{$global-left};\n    }\n  }\n\n  // Table rows\n  tbody {\n    th,\n    td {\n      padding: $table-padding;\n    }\n  }\n\n  // If tables are striped\n  @if $is-striped == true {\n    tbody {\n      @include -zf-table-stripe($stripe);\n    }\n\n    &.unstriped {\n      tbody {\n        @include -zf-table-unstripe();\n        background-color: $table-background;\n      }\n    }\n  }\n\n  // If tables are not striped\n  @else if $is-striped == false {\n    tbody {\n      @include -zf-table-unstripe();\n    }\n\n    &.striped {\n      tbody {\n        @include -zf-table-stripe($stripe);\n      }\n    }\n  }\n}\n\n/// Adds the general styles for tables.\n/// @param {Keyword} $stripe [$table-stripe] - Uses keywords even, odd, or none to darken rows of the table. The default value is even.\n@mixin table(\n  $stripe: $table-stripe,\n  $nest: false\n) {\n  border-collapse: collapse;\n  width: 100%;\n  margin-bottom: $global-margin;\n  border-radius: $global-radius;\n\n  @if $nest {\n    @include -zf-table-children-styles($stripe);\n  }\n  @else {\n    @at-root {\n      @include -zf-table-children-styles($stripe);\n    }\n  }\n}\n\n/// Adds the ability to horizontally scroll the table when the content overflows horizontally.\n@mixin table-scroll {\n  display: block;\n  width: 100%;\n  overflow-x: auto;\n}\n\n/// Slightly darkens the table rows on hover.\n@mixin table-hover {\n  thead tr {\n    //Darkens the table header rows on hover.\n    &:hover {\n      background-color: $table-head-row-hover;\n    }\n  }\n\n  tfoot tr {\n    //Darkens the table footer rows on hover.\n    &:hover {\n      background-color: $table-foot-row-hover;\n    }\n  }\n\n  tbody tr {\n    //Darkens the non-striped table rows on hover.\n    &:hover {\n      background-color: $table-row-hover;\n    }\n  }\n\n  @if $table-is-striped == true {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &:not(.unstriped) tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &:not(.unstriped) tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n\n  @else if $table-is-striped == false {\n    // Darkens the even striped table rows.\n    @if($table-stripe == even) {\n      &.striped tr:nth-of-type(even):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n\n    // Darkens the odd striped table rows.\n    @else if($table-stripe == odd) {\n      &.striped tr:nth-of-type(odd):hover {\n        background-color: $table-row-stripe-hover;\n      }\n    }\n  }\n}\n\n/// Adds styles for a stacked table. Useful for small-screen layouts.\n/// @param {Boolean} $header [$show-header-for-stacked] - Show the first th of header when stacked.\n@mixin table-stack($header: $show-header-for-stacked) {\n  @if $header {\n    thead {\n      th {\n        display: block;\n      }\n    }\n  }\n  @else {\n    thead {\n      display: none;\n    }\n  }\n\n  tfoot {\n    display: none;\n  }\n\n  tr,\n  th,\n  td {\n    display: block;\n  }\n\n  td {\n    border-top: 0;\n  }\n}\n\n@mixin foundation-table($nest: false) {\n  table {\n    @include table($nest: $nest);\n  }\n\n  table.stack {\n    @include breakpoint($table-stack-breakpoint down) {\n      @include table-stack;\n    }\n  }\n\n  table.scroll {\n    @include table-scroll;\n  }\n\n  table.hover {\n    @include table-hover;\n  }\n\n  .table-scroll {\n    overflow-x: auto;\n\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@import 'math';\n\n$contrast-warnings: true !default;\n\n////\n/// @group functions\n////\n\n/// Checks the luminance of `$color`.\n///\n/// @param {Color} $color - Color to check the luminance of.\n///\n/// @returns {Number} The luminance of `$color`.\n@function color-luminance($color) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#relativeluminancedef\n  $rgba: red($color), green($color), blue($color);\n  $rgba2: ();\n\n  @for $i from 1 through 3 {\n    $rgb: nth($rgba, $i);\n    $rgb: $rgb / 255;\n\n    $rgb: if($rgb < 0.03928, $rgb / 12.92, pow(($rgb + 0.055) / 1.055, 2.4));\n\n    $rgba2: append($rgba2, $rgb);\n  }\n\n  @return 0.2126 * nth($rgba2, 1) + 0.7152 * nth($rgba2, 2) + 0.0722 * nth($rgba2, 3);\n}\n\n/// Checks the contrast ratio of two colors.\n///\n/// @param {Color} $color1 - First color to compare.\n/// @param {Color} $color2 - Second color to compare.\n///\n/// @returns {Number} The contrast ratio of the compared colors.\n@function color-contrast($color1, $color2) {\n  // Adapted from: https://github.com/LeaVerou/contrast-ratio/blob/gh-pages/color.js\n  // Formula: http://www.w3.org/TR/2008/REC-WCAG20-20081211/#contrast-ratiodef\n  $luminance1: color-luminance($color1) + 0.05;\n  $luminance2: color-luminance($color2) + 0.05;\n  $ratio: $luminance1 / $luminance2;\n\n  @if $luminance2 > $luminance1 {\n    $ratio: 1 / $ratio;\n  }\n\n  $ratio: round($ratio * 10) / 10;\n\n  @return $ratio;\n}\n\n/// Checks the luminance of `$base`, and returns the color from `$colors` (list of colors) that has the most contrast.\n///\n/// @param {Color} $base - Color to check luminance.\n/// @param {List} $colors [($white, $black)] - Colors to compare.\n/// @param {Number} $tolerance [$global-color-pick-contrast-tolerance] - Contrast tolerance.\n///\n/// @returns {Color} the color from `$colors` (list of colors) that has the most contrast.\n@function color-pick-contrast($base, $colors: ($white, $black), $tolerance: $global-color-pick-contrast-tolerance) {\n  $contrast: color-contrast($base, nth($colors, 1));\n  $best: nth($colors, 1);\n\n  @for $i from 2 through length($colors) {\n    $current-contrast: color-contrast($base, nth($colors, $i));\n    @if ($current-contrast - $contrast > $tolerance) {\n      $contrast: color-contrast($base, nth($colors, $i));\n      $best: nth($colors, $i);\n    }\n  }\n\n  @if ($contrast-warnings and $contrast < 3) {\n    @warn \"Contrast ratio of #{$best} on #{$base} is pretty bad, just #{$contrast}\";\n  }\n\n  @return $best;\n}\n\n/// Scales a color to be darker if it's light, or lighter if it's dark. Use this function to tint a color appropriate to its lightness.\n///\n/// @param {Color} $color - Color to scale.\n/// @param {Percentage} $scale [5%] - Amount to scale up or down.\n/// @param {Percentage} $threshold [40%] - Threshold of lightness to check against.\n///\n/// @returns {Color} A scaled color.\n@function smart-scale($color, $scale: 5%, $threshold: 40%) {\n  @if lightness($color) > $threshold {\n    $scale: -$scale;\n  }\n  @return scale-color($color, $lightness: $scale);\n}\n\n/// Get color from foundation-palette\n///\n/// @param {key} color key from foundation-palette\n///\n/// @returns {Color} color from foundation-palette\n@function get-color($key) {\n  @if map-has-key($foundation-palette, $key) {\n    @return map-get($foundation-palette, $key);\n  }\n  @else {\n    @error 'given $key is not available in $foundation-palette';\n  }\n}\n\n/// Transfers the colors in the `$foundation-palette` map into variables, such as `$primary-color` and `$secondary-color`. Call this mixin below the Global section of your settings file to properly migrate your codebase.\n@mixin add-foundation-colors() {\n  @if map-has-key($foundation-palette, primary) {\n    $primary-color: map-get($foundation-palette, primary) !global;\n  } @else {\n    $primary-color: #1779ba !global;\n  }\n  @if map-has-key($foundation-palette, secondary) {\n    $secondary-color: map-get($foundation-palette, secondary) !global;\n  } @else {\n    $secondary-color: #767676 !global;\n  }\n  @if map-has-key($foundation-palette, success) {\n    $success-color: map-get($foundation-palette, success) !global;\n  } @else {\n    $success-color: #3adb76 !global;\n  }\n  @if map-has-key($foundation-palette, warning) {\n    $warning-color: map-get($foundation-palette, warning) !global;\n  } @else {\n    $warning-color: #ffae00 !global;\n  }\n  @if map-has-key($foundation-palette, alert) {\n    $alert-color: map-get($foundation-palette, alert) !global;\n  } @else {\n    $alert-color: #cc4b37 !global;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group badge\n////\n\n/// Default background color for badges.\n/// @type Color\n$badge-background: $primary-color !default;\n\n/// Default text color for badges.\n/// @type Color\n$badge-color: $white !default;\n\n/// Alternate text color for badges.\n/// @type Color\n$badge-color-alt: $black !default;\n\n/// Coloring classes. A map of classes to output in your CSS, like `.secondary`, `.success`, and so on.\n/// @type Map\n$badge-palette: $foundation-palette !default;\n\n/// Default padding inside badges.\n/// @type Number\n$badge-padding: 0.3em !default;\n\n/// Minimum width of a badge.\n/// @type Number\n$badge-minwidth: 2.1em !default;\n\n/// Default font size for badges.\n/// @type Number\n$badge-font-size: 0.6rem !default;\n\n/// Generates the base styles for a badge.\n@mixin badge {\n  display: inline-block;\n  min-width: $badge-minwidth;\n  padding: $badge-padding;\n\n  border-radius: 50%;\n\n  font-size: $badge-font-size;\n  text-align: center;\n}\n\n@mixin foundation-badge {\n  .badge {\n    @include badge;\n\n    background: $badge-background;\n    color: $badge-color;\n\n    @each $name, $color in $badge-palette {\n      &.#{$name} {\n        background: $color;\n        color: color-pick-contrast($color, ($badge-color, $badge-color-alt));\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group breadcrumbs\n////\n\n/// Margin around a breadcrumbs container.\n/// @type Number\n$breadcrumbs-margin: 0 0 $global-margin 0 !default;\n\n/// Font size of breadcrumb links.\n/// @type Number\n$breadcrumbs-item-font-size: rem-calc(11) !default;\n\n/// Color of breadcrumb links.\n/// @type Color\n$breadcrumbs-item-color: $primary-color !default;\n\n/// Color of the active breadcrumb link.\n/// @type Color\n$breadcrumbs-item-color-current: $black !default;\n\n/// Opacity of disabled breadcrumb links.\n/// @type Number\n$breadcrumbs-item-color-disabled: $medium-gray !default;\n\n/// Margin between breadcrumb items.\n/// @type Number\n$breadcrumbs-item-margin: 0.75rem !default;\n\n/// If `true`, makes breadcrumb links uppercase.\n/// @type Boolean\n$breadcrumbs-item-uppercase: true !default;\n\n/// If `true`, adds a seperator between breadcrumb links.\n/// @type Boolean\n$breadcrumbs-item-separator: true !default;\n\n// If it exists $breadcrumbs-item-slash is used to build $breadcrumbs-item-separator. See the documentation.\n@if variable-exists(breadcrumbs-item-slash) {\n  $breadcrumbs-item-separator: $breadcrumbs-item-slash;\n}\n\n/// Used character for the breadcrumb separator.\n/// @type Content\n$breadcrumbs-item-separator-item: '/' !default;\n\n/// Used character for the breadcrumb separator in rtl mode.\n/// @type Content\n$breadcrumbs-item-separator-item-rtl: '\\\\' !default;\n\n/// Color of breadcrumb item.\n/// @type Color\n$breadcrumbs-item-separator-color: $medium-gray !default;\n\n// If it exists $breadcrumbs-item-slash-color is used to build $breadcrumbs-item-separator-color. See the documentation.\n@if variable-exists(breadcrumbs-item-slash-color) {\n  $breadcrumbs-item-separator-color: $breadcrumbs-item-slash-color;\n}\n\n/// Adds styles for a breadcrumbs container, along with the styles for the `<li>` and `<a>` elements inside of it.\n@mixin breadcrumbs-container {\n  @include clearfix;\n  margin: $breadcrumbs-margin;\n  list-style: none;\n\n  // Item wrapper\n  li {\n    float: #{$global-left};\n\n    font-size: $breadcrumbs-item-font-size;\n    color: $breadcrumbs-item-color-current;\n    cursor: default;\n\n    @if $breadcrumbs-item-uppercase {\n      text-transform: uppercase;\n    }\n\n    @if $breadcrumbs-item-separator {\n      // Need to escape the backslash\n      $separator: if($global-text-direction == 'ltr', $breadcrumbs-item-separator-item, $breadcrumbs-item-separator-item-rtl);\n\n      &:not(:last-child) {\n        &::after {\n          position: relative;\n          margin: 0 $breadcrumbs-item-margin;\n          opacity: 1;\n          content: $separator;\n          color: $breadcrumbs-item-separator-color;\n        }\n      }\n    }\n    @else {\n      margin-#{$global-right}: $breadcrumbs-item-margin;\n    }\n  }\n\n  // Page links\n  a {\n    color: $breadcrumbs-item-color;\n\n    &:hover {\n      text-decoration: underline;\n    }\n  }\n}\n\n@mixin foundation-breadcrumbs {\n  .breadcrumbs {\n    @include breadcrumbs-container;\n\n    .disabled {\n      color: $breadcrumbs-item-color-disabled;\n      cursor: not-allowed;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group callout\n////\n\n/// Default background color.\n/// @type Color\n$callout-background: $white !default;\n\n/// Default fade value for callout backgrounds.\n/// @type Number\n$callout-background-fade: 85% !default;\n\n/// Default border style for callouts.\n/// @type List\n$callout-border: 1px solid rgba($black, 0.25) !default;\n\n/// Default bottom margin for callouts.\n/// @type Number\n$callout-margin: 0 0 1rem 0 !default;\n\n/// Default inner padding for callouts.\n/// @type Number\n$callout-padding: 1rem !default;\n\n/// Default font color for callouts.\n/// @type Color\n$callout-font-color: $body-font-color !default;\n\n/// Default font color for callouts, if the callout has a dark background.\n/// @type Color\n$callout-font-color-alt: $body-background !default;\n\n/// Default border radius for callouts.\n/// @type Color\n$callout-radius: $global-radius !default;\n\n/// Amount to tint links used within colored panels. Set to `false` to disable this feature.\n/// @type Number | Boolean\n$callout-link-tint: 30% !default;\n\n/// Adds basic styles for a callout, including padding and margin.\n@mixin callout-base() {\n  position: relative;\n  margin: $callout-margin;\n  padding: $callout-padding;\n\n  border: $callout-border;\n  border-radius: $callout-radius;\n\n  // Respect the padding, fool.\n  > :first-child {\n    margin-top: 0;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Generate quick styles for a callout using a single color as a baseline.\n/// @param {Color} $color [$callout-background] - Color to use.\n@mixin callout-style($color: $callout-background) {\n  $background: scale-color($color, $lightness: $callout-background-fade);\n\n  background-color: $background;\n  color: color-pick-contrast($background, ($callout-font-color, $callout-font-color-alt));\n}\n\n@mixin callout-size($padding) {\n  padding-top: $padding;\n  padding-right: $padding;\n  padding-bottom: $padding;\n  padding-left: $padding;\n}\n\n\n/// Adds styles for a callout.\n/// @param {Color} $color [$callout-background] - Color to use.\n@mixin callout($color: $callout-background) {\n  @include callout-base;\n  @include callout-style($color);\n}\n\n@mixin foundation-callout {\n  .callout {\n    @include callout;\n\n    @each $name, $color in $foundation-palette {\n      &.#{$name} {\n        @include callout-style($color);\n      }\n    }\n\n    &.small {\n      @include callout-size(0.5rem);\n    }\n\n    &.large {\n      @include callout-size(3rem);\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group card\n////\n\n/// Default background color.\n/// @type Color\n$card-background: $white !default;\n\n/// Default font color for cards.\n/// @type Color\n$card-font-color: $body-font-color !default;\n\n/// Default background.\n/// @type Color\n$card-divider-background: $light-gray !default;\n\n/// Default border style.\n/// @type List\n$card-border: 1px solid $light-gray !default;\n\n/// Default card shadow.\n/// @type List\n$card-shadow: none !default;\n\n/// Default border radius.\n/// @type List\n$card-border-radius: $global-radius !default;\n\n/// Default padding.\n/// @type Number\n$card-padding: $global-padding !default;\n\n/// Default bottom margin.\n/// @type number\n$card-margin-bottom: $global-margin !default;\n\n/// Adds styles for a card container.\n/// @param {Color} $background - Background color of the card.\n/// @param {Color} $color - font color of the card.\n/// @param {Number} $margin - Bottom margin of the card.\n/// @param {List} $border - Border around the card.\n/// @param {List} $radius - border radius of the card.\n/// @param {List} $shadow - box shadow of the card.\n@mixin card-container(\n  $background: $card-background,\n  $color: $card-font-color,\n  $margin: $card-margin-bottom,\n  $border: $card-border,\n  $radius: $card-border-radius,\n  $shadow: $card-shadow\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex-direction: column;\n    flex-grow: 1;\n  }\n\n  margin-bottom: $margin;\n\n  border: $border;\n  border-radius: $radius;\n\n  background: $background;\n  box-shadow: $shadow;\n\n  overflow: hidden;\n  color: $color;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card divider.\n@mixin card-divider(\n  $background: $card-divider-background,\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    display: flex;\n    flex: 0 1 auto;\n  }\n\n  padding: $padding;\n  background: $background;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n/// Adds styles for a card section.\n@mixin card-section(\n  $padding: $card-padding\n) {\n  @if $global-flexbox {\n    flex: 1 0 auto;\n  }\n\n  padding: $padding;\n\n  & > :last-child {\n    margin-bottom: 0;\n  }\n}\n\n@mixin foundation-card {\n  .card {\n    @include card-container;\n  }\n\n  .card-divider {\n    @include card-divider;\n  }\n\n  .card-section {\n    @include card-section;\n  }\n\n  // For IE 11 - Flexbug\n  // https://github.com/philipwalton/flexbugs/issues/75\n  .card-image {\n    min-height: 1px;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown\n////\n\n/// Padding for dropdown panes.\n/// @type List\n$dropdown-padding: 1rem !default;\n\n/// Background for dropdown panes.\n/// @type Color\n$dropdown-background: $body-background !default;\n\n/// Border for dropdown panes.\n/// @type List\n$dropdown-border: 1px solid $medium-gray !default;\n\n/// Font size for dropdown panes.\n/// @type List\n$dropdown-font-size: 1rem !default;\n\n/// Width for dropdown panes.\n/// @type Number\n$dropdown-width: 300px !default;\n\n/// Border radius dropdown panes.\n/// @type Number\n$dropdown-radius: $global-radius !default;\n\n/// Sizes for dropdown panes. Each size is a CSS class you can apply.\n/// @type Map\n$dropdown-sizes: (\n  tiny: 100px,\n  small: 200px,\n  large: 400px,\n) !default;\n\n/// Applies styles for a basic dropdown.\n@mixin dropdown-container {\n  position: absolute;\n  z-index: 10;\n\n  display: none;\n\n  width: $dropdown-width;\n  padding: $dropdown-padding;\n\n  visibility: hidden;\n  border: $dropdown-border;\n  border-radius: $dropdown-radius;\n  background-color: $dropdown-background;\n\n  font-size: $dropdown-font-size;\n\n\n  // Allow an intermittent state to do positioning before making visible.\n  &.is-opening {\n    display: block;\n  }\n\n  &.is-open {\n    display: block;\n    visibility: visible;\n  }\n}\n\n@mixin foundation-dropdown {\n  .dropdown-pane {\n    @include dropdown-container;\n  }\n\n  @each $name, $size in $dropdown-sizes {\n    .dropdown-pane {\n      &.#{$name} {\n        width: $size;\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group pagination\n////\n\n/// Font size of pagination items.\n/// @type Number\n$pagination-font-size: rem-calc(14) !default;\n\n/// Default bottom margin of the pagination object.\n/// @type Number\n$pagination-margin-bottom: $global-margin !default;\n\n/// Text color of pagination items.\n/// @type Color\n$pagination-item-color: $black !default;\n\n/// Padding inside of pagination items.\n/// @type Number\n$pagination-item-padding: rem-calc(3 10) !default;\n\n/// Right margin to separate pagination items.\n/// @type Number\n$pagination-item-spacing: rem-calc(1) !default;\n\n/// Default radius for pagination items.\n/// @type Number\n$pagination-radius: $global-radius !default;\n\n/// Background color of pagination items on hover.\n/// @type Color\n$pagination-item-background-hover: $light-gray !default;\n\n/// Background color of pagination item for the current page.\n/// @type Color\n$pagination-item-background-current: $primary-color !default;\n\n/// Text color of the pagination item for the current page.\n/// @type Color\n$pagination-item-color-current: $white !default;\n\n/// Text color of a disabled pagination item.\n/// @type Color\n$pagination-item-color-disabled: $medium-gray !default;\n\n/// Color of the ellipsis in a pagination menu.\n/// @type Color\n$pagination-ellipsis-color: $black !default;\n\n/// If `false`, don't display page number links on mobile, only next/previous links\n/// and optionally current page number.\n/// @type Boolean\n$pagination-mobile-items: false !default;\n\n/// If `true`, display the current page number on mobile even if `$pagination-mobile-items` is set to `false`.\n/// This parameter will only override the visibility setting of the current item for `$pagination-mobile-items: false;`,\n/// it will not affect the current page number visibility when `$pagination-mobile-items` is set to `true`.\n/// @type Boolean\n$pagination-mobile-current-item: false !default;\n\n/// If `true`, arrows are added to the next and previous links of pagination.\n/// @type Boolean\n$pagination-arrows: true !default;\n\n/// Adds styles for a pagination container. Apply this to a `<ul>`.\n@mixin pagination-container (\n  $margin-bottom: $pagination-margin-bottom,\n  $font-size: $pagination-font-size,\n  $spacing: $pagination-item-spacing,\n  $radius: $pagination-radius,\n  $color: $pagination-item-color,\n  $padding: $pagination-item-padding,\n  $background-hover: $pagination-item-background-hover\n) {\n  @include clearfix;\n  margin-#{$global-left}: 0;\n  margin-bottom: $margin-bottom;\n\n  // List item\n  li {\n    margin-#{$global-right}: $spacing;\n    border-radius: $radius;\n    font-size: $font-size;\n\n    @if $pagination-mobile-items {\n      display: inline-block;\n    }\n    @else {\n      display: none;\n\n      &:last-child,\n      &:first-child {\n        display: inline-block;\n      }\n\n      @if $pagination-mobile-current-item {\n        &.current {\n          display: inline-block;\n        }\n      }\n\n      @include breakpoint(medium) {\n        display: inline-block;\n      }\n    }\n  }\n\n  // Page links\n  a,\n  button {\n    display: block;\n    padding: $padding;\n    border-radius: $radius;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n    }\n  }\n}\n\n/// Adds styles for the current pagination item. Apply this to an `<a>`.\n@mixin pagination-item-current (\n  $padding: $pagination-item-padding,\n  $background-current: $pagination-item-background-current,\n  $color-current: $pagination-item-color-current\n) {\n  padding: $padding;\n  background: $background-current;\n  color: $color-current;\n  cursor: default;\n}\n\n/// Adds styles for a disabled pagination item. Apply this to an `<a>`.\n@mixin pagination-item-disabled (\n  $padding: $pagination-item-padding,\n  $color: $pagination-item-color-disabled\n) {\n  padding: $padding;\n  color: $color;\n  cursor: not-allowed;\n\n  &:hover {\n    background: transparent;\n  }\n}\n\n/// Adds styles for an ellipsis for use in a pagination list.\n@mixin pagination-ellipsis (\n  $padding: $pagination-item-padding,\n  $color: $pagination-ellipsis-color\n) {\n  padding: $padding;\n  content: '\\2026';\n  color: $color;\n}\n\n@mixin foundation-pagination {\n  .pagination {\n    @include pagination-container;\n\n    .current {\n      @include pagination-item-current;\n    }\n\n    .disabled {\n      @include pagination-item-disabled;\n    }\n\n    .ellipsis::after {\n      @include pagination-ellipsis;\n    }\n  }\n\n  @if $pagination-arrows {\n    .pagination-previous a::before,\n    .pagination-previous.disabled::before {\n      display: inline-block;\n      margin-#{$global-right}: 0.5rem;\n      content: '\\00ab';\n    }\n\n    .pagination-next a::after,\n    .pagination-next.disabled::after {\n      display: inline-block;\n      margin-#{$global-left}: 0.5rem;\n      content: '\\00bb';\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group tooltip\n////\n\n/// Default cursor of the defined term.\n/// @type Keyword\n$has-tip-cursor: help !default;\n\n/// Default font weight of the defined term.\n/// @type Keyword | Number\n$has-tip-font-weight: $global-weight-bold !default;\n\n/// Default border bottom of the defined term.\n/// @type List\n$has-tip-border-bottom: dotted 1px $dark-gray !default;\n\n/// Default color of the tooltip background.\n/// @type Color\n$tooltip-background-color: $black !default;\n\n/// Default color of the tooltip font.\n/// @type Color\n$tooltip-color: $white !default;\n\n/// Default padding of the tooltip background.\n/// @type Number\n$tooltip-padding: 0.75rem !default;\n\n/// Default max width for tooltips.\n/// @type Number\n$tooltip-max-width: 10rem !default;\n\n/// Default font size of the tooltip text. By default, we recommend a smaller font size than the body copy.\n/// @type Number\n$tooltip-font-size: $small-font-size !default;\n\n/// Default pip width for tooltips.\n/// @type Number\n$tooltip-pip-width: 0.75rem !default;\n\n/// Default pip height for tooltips. This is helpful for calculating the distance of the tooltip from the tooltip word.\n/// @type Number\n$tooltip-pip-height: $tooltip-pip-width * 0.866 !default;\n\n/// Default radius for tooltips.\n/// @type Number\n$tooltip-radius: $global-radius !default;\n\n@mixin has-tip {\n  position: relative;\n  display: inline-block;\n\n  border-bottom: $has-tip-border-bottom;\n  font-weight: $has-tip-font-weight;\n  cursor: $has-tip-cursor;\n}\n\n@mixin tooltip {\n  position: absolute;\n  top: calc(100% + #{$tooltip-pip-height});\n  z-index: 1200;\n\n  max-width: $tooltip-max-width;\n  padding: $tooltip-padding;\n\n  border-radius: $tooltip-radius;\n  background-color: $tooltip-background-color;\n  font-size: $tooltip-font-size;\n  color: $tooltip-color;\n\n  &::before {\n    position: absolute;\n  }\n\n  &.bottom {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, up);\n      bottom: 100%;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.top {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, down);\n      top: 100%;\n      bottom: auto;\n    }\n\n    &.align-center::before {\n      left: 50%;\n      transform: translateX(-50%);\n    }\n  }\n\n  &.left {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, right);\n      left: 100%;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.right {\n    &::before {\n      @include css-triangle($tooltip-pip-width, $tooltip-background-color, left);\n      right: 100%;\n      left: auto;\n    }\n\n    &.align-center::before {\n      bottom: auto;\n      top: 50%;\n      transform: translateY(-50%);\n    }\n  }\n\n  &.align-top::before {\n    bottom: auto;\n    top: 10%;\n  }\n\n  &.align-bottom::before {\n    bottom: 10%;\n    top: auto;\n  }\n\n  &.align-left::before {\n    left: 10%;\n    right: auto;\n  }\n\n  &.align-right::before {\n    left: auto;\n    right: 10%;\n  }\n}\n\n@mixin foundation-tooltip {\n  .has-tip {\n    @include has-tip;\n  }\n\n  .tooltip {\n    @include tooltip;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group accordion\n////\n\n/// Default background color of an accordion group.\n/// @type Color\n$accordion-background: $white !default;\n\n/// If `true`, adds plus and minus icons to the side of each accordion title.\n/// @type Boolean\n$accordion-plusminus: true !default;\n\n/// Font size of accordion titles.\n/// @type Number\n$accordion-title-font-size: rem-calc(12) !default;\n\n/// Default text color for items in a Menu.\n/// @type Color\n$accordion-item-color: $primary-color !default;\n\n/// Default background color on hover for items in a Menu.\n/// @type Color\n$accordion-item-background-hover: $light-gray !default;\n\n/// Default padding of an accordion item.\n/// @type Number | List\n$accordion-item-padding: 1.25rem 1rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$accordion-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$accordion-content-border: 1px solid $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$accordion-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$accordion-content-padding: 1rem !default;\n\n/// Adds styles for an accordion container. Apply this to the same element that gets `data-accordion`.\n@mixin accordion-container (\n  $background: $accordion-background\n) {\n  margin-#{$global-left}: 0;\n  background: $background;\n  list-style-type: none;\n\n  &[disabled] {\n    .accordion-title {\n      cursor: not-allowed;\n    }\n  }\n}\n\n/// Adds styles for the accordion item. Apply this to the list item within an accordion ul.\n@mixin accordion-item {\n  &:first-child > :first-child {\n    border-radius: $global-radius $global-radius 0 0;\n  }\n\n  &:last-child > :last-child {\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n}\n\n/// Adds styles for the title of an accordion item. Apply this to the link within an accordion item.\n@mixin accordion-title (\n  $padding: $accordion-item-padding,\n  $font-size: $accordion-title-font-size,\n  $color: $accordion-item-color,\n  $border: $accordion-content-border,\n  $background-hover: $accordion-item-background-hover\n) {\n  position: relative;\n  display: block;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n\n  font-size: $font-size;\n  line-height: 1;\n  color: $color;\n\n  :last-child:not(.is-active) > & {\n    border-bottom: $border;\n    border-radius: 0 0 $global-radius $global-radius;\n  }\n\n  &:hover,\n  &:focus {\n    background-color: $background-hover;\n  }\n\n  @if $accordion-plusminus {\n    &::before {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 1rem;\n      margin-top: -0.5rem;\n      content: '+';\n    }\n\n    .is-active > &::before {\n      content: '\\2013';\n    }\n  }\n}\n\n/// Adds styles for accordion content. Apply this to the content pane below an accordion item's title.\n@mixin accordion-content (\n  $padding: $accordion-content-padding,\n  $border: $accordion-content-border,\n  $background: $accordion-content-background,\n  $color: $accordion-content-color\n) {\n  display: none;\n  padding: $padding;\n\n  border: $border;\n  border-bottom: 0;\n  background-color: $background;\n\n  color: $color;\n\n  :last-child > &:last-child {\n    border-bottom: $border;\n  }\n}\n\n@mixin foundation-accordion {\n  .accordion {\n    @include accordion-container;\n  }\n\n  .accordion-item {\n    @include accordion-item;\n  }\n\n  .accordion-title {\n    @include accordion-title;\n  }\n\n  .accordion-content {\n    @include accordion-content;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group media-object\n////\n\n/// Bottom margin of a media object.\n/// @type Number\n$mediaobject-margin-bottom: $global-margin !default;\n\n/// Left and right padding on sections within a media object.\n/// @type Number\n$mediaobject-section-padding: $global-padding !default;\n\n/// Width of images within a media object, when the object is stacked vertically. Set to 'auto' to use the image's natural width.\n/// @type Number\n$mediaobject-image-width-stacked: 100% !default;\n\n/// Adds styles for a media object container.\n@mixin media-object-container {\n  display: if($global-flexbox, flex, block);\n  margin-bottom: $mediaobject-margin-bottom;\n\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n  }\n\n  img {\n    max-width: none;\n  }\n\n  @if $global-flexbox {\n    &.stack-for-#{$-zf-zero-breakpoint} {\n      @include breakpoint($-zf-zero-breakpoint only) {\n        flex-wrap: wrap;\n      }\n    }\n  }\n}\n\n/// Adds styles for sections within a media object.\n/// @param {Number} $padding [$mediaobject-section-padding] - Padding between sections.\n@mixin media-object-section($padding: $mediaobject-section-padding) {\n  @if $global-flexbox {\n    flex: 0 1 auto;\n  }\n  @else {\n    display: table-cell;\n    vertical-align: top;\n  }\n\n  &:first-child {\n    padding-#{$global-right}: $padding;\n  }\n\n  &:last-child:not(:nth-child(2)) {\n    padding-#{$global-left}: $padding;\n  }\n\n  > :last-child {\n    margin-bottom: 0;\n  }\n\n  .stack-for-#{$-zf-zero-breakpoint} & {\n    @include breakpoint($-zf-zero-breakpoint only) {\n      @include media-object-stack;\n    }\n  }\n\n  @if $global-flexbox {\n    &.main-section {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    &.middle {\n      vertical-align: middle;\n    }\n\n    &.bottom {\n      vertical-align: bottom;\n    }\n  }\n}\n\n/// Adds styles to stack sections of a media object. Apply this to the section elements, not the container.\n@mixin media-object-stack {\n  padding: 0;\n  padding-bottom: $mediaobject-section-padding;\n\n  @if $global-flexbox {\n    flex-basis: 100%;\n    max-width: 100%;\n  }\n  @else {\n    display: block;\n  }\n\n  img {\n    width: $mediaobject-image-width-stacked;\n  }\n}\n\n@mixin foundation-media-object {\n  .media-object {\n    @include media-object-container;\n  }\n\n  .media-object-section {\n    @include media-object-section;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group orbit\n////\n\n/// Default color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background: $medium-gray !default;\n\n/// Default active color for Orbit's bullets.\n/// @type Color\n$orbit-bullet-background-active: $dark-gray !default;\n\n/// Default diameter for Orbit's bullets.\n/// @type Number\n$orbit-bullet-diameter: 1.2rem !default;\n\n/// Default margin between Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin: 0.1rem !default;\n\n/// Default distance from slide region for Orbit's bullets.\n/// @type Number\n$orbit-bullet-margin-top: 0.8rem !default;\n\n/// Default bottom margin from Orbit's bullets to whatever content may lurk below it.\n/// @type Number\n$orbit-bullet-margin-bottom: 0.8rem !default;\n\n/// Default background color for Orbit's caption.\n/// @type Color\n$orbit-caption-background: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's caption.\n/// @type Number\n$orbit-caption-padding: 1rem !default;\n\n/// Default background color for Orbit's controls when hovered.\n/// @type Color\n$orbit-control-background-hover: rgba($black, 0.5) !default;\n\n/// Default padding for Orbit's controls.\n/// @type Number\n$orbit-control-padding: 1rem !default;\n\n/// Default z-index for Orbit's controls.\n/// @type Number\n$orbit-control-zindex: 10 !default;\n\n/// Adds styles for the outer Orbit wrapper. These styles are used on the `.orbit` class.\n@mixin orbit-wrapper {\n  position: relative;\n}\n\n/// Adds styles for the inner Orbit slide container. These styles are used on the `.orbit-container` class.\n@mixin orbit-container {\n  position: relative;\n  height: 0; // Prevent FOUC by not showing until JS sets height\n  margin: 0;\n  list-style: none;\n  overflow: hidden;\n}\n\n/// Adds styles for the individual slides of an Orbit slider. These styles are used on the `.orbit-slide` class.\n@mixin orbit-slide {\n  width: 100%;\n  position: absolute;\n\n  &.no-motionui {\n    &.is-active {\n      top: 0;\n      left: 0;\n    }\n  }\n}\n\n@mixin orbit-figure {\n  margin: 0;\n}\n\n/// Adds styles for a slide containing an image. These styles are used on the `.orbit-image` class.\n@mixin orbit-image {\n  width: 100%;\n  max-width: 100%;\n  margin: 0;\n}\n\n/// Adds styles for an orbit slide caption. These styles are used on the `.orbit-caption` class.\n@mixin orbit-caption {\n  position: absolute;\n  bottom: 0;\n  width: 100%;\n  margin-bottom: 0;\n  padding: $orbit-caption-padding;\n\n  background-color: $orbit-caption-background;\n  color: color-pick-contrast($orbit-caption-background);\n}\n\n/// Adds base styles for the next/previous buttons in an Orbit slider. These styles are shared between the `.orbit-next` and `.orbit-previous` classes in the default CSS.\n@mixin orbit-control {\n  @include disable-mouse-outline;\n  @include vertical-center;\n  z-index: $orbit-control-zindex;\n  padding: $orbit-control-padding;\n  color: $white;\n\n  &:hover,\n  &:active,\n  &:focus {\n    background-color: $orbit-control-background-hover;\n  }\n}\n\n/// Adds styles for the Orbit previous button. These styles are used on the `.orbit-previous` class.\n@mixin orbit-previous {\n  #{$global-left}: 0;\n}\n\n/// Adds styles for the Orbit next button. These styles are used on the `.orbit-next` class.\n@mixin orbit-next {\n  #{$global-left}: auto;\n  #{$global-right}: 0;\n}\n\n/// Adds styles for a container of Orbit bullets. /// Adds styles for the Orbit previous button. These styles are used on the `.orbit-bullets` class.\n@mixin orbit-bullets {\n  @include disable-mouse-outline;\n  position: relative;\n  margin-top: $orbit-bullet-margin-top;\n  margin-bottom: $orbit-bullet-margin-bottom;\n  text-align: center;\n\n  button {\n    width: $orbit-bullet-diameter;\n    height: $orbit-bullet-diameter;\n    margin: $orbit-bullet-margin;\n\n    border-radius: 50%;\n    background-color: $orbit-bullet-background;\n\n    &:hover {\n      background-color: $orbit-bullet-background-active;\n    }\n\n    &.is-active {\n      background-color: $orbit-bullet-background-active;\n    }\n  }\n}\n\n@mixin foundation-orbit {\n  .orbit {\n    @include orbit-wrapper;\n  }\n\n  .orbit-container {\n    @include orbit-container;\n  }\n\n  .orbit-slide {\n    @include orbit-slide;\n  }\n\n  .orbit-figure {\n    @include orbit-figure;\n  }\n\n  .orbit-image {\n    @include orbit-image;\n  }\n\n  .orbit-caption {\n    @include orbit-caption;\n  }\n\n  %orbit-control {\n    @include orbit-control;\n  }\n\n  .orbit-previous {\n    @extend %orbit-control;\n    @include orbit-previous;\n  }\n\n  .orbit-next {\n    @extend %orbit-control;\n    @include orbit-next;\n  }\n\n  .orbit-bullets {\n    @include orbit-bullets;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group responsive-embed\n////\n\n/// Margin below a responsive embed container.\n/// @type Number\n$responsive-embed-margin-bottom: rem-calc(16) !default;\n\n/// Aspect ratios used to determine padding-bottom of responsive embed containers.\n/// @type Map\n$responsive-embed-ratios: (\n  default: 4 by 3,\n  widescreen: 16 by 9,\n) !default;\n\n/// Creates a responsive embed container.\n/// @param {String|List} $ratio [default] - Ratio of the container. Can be a key from the `$responsive-embed-ratios` map or a list formatted as `x by y`.\n@mixin responsive-embed($ratio: default) {\n  @if type-of($ratio) == 'string' {\n    $ratio: map-get($responsive-embed-ratios, $ratio);\n  }\n  position: relative;\n  height: 0;\n  margin-bottom: $responsive-embed-margin-bottom;\n  padding-bottom: ratio-to-percentage($ratio);\n  overflow: hidden;\n\n  iframe,\n  object,\n  embed,\n  video {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 0;\n    width: 100%;\n    height: 100%;\n  }\n}\n\n@mixin foundation-responsive-embed {\n  .responsive-embed,\n  .flex-video {\n    @include responsive-embed($ratio: default);\n\n    $ratios: map-remove($responsive-embed-ratios,default);\n\n    @each $name, $ratio in $ratios {\n      &.#{$name} {\n        padding-bottom: ratio-to-percentage($ratio);\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group functions\n////\n\n/// Finds the greatest common divisor of two integers.\n///\n/// @param {Number} $a - First number to compare.\n/// @param {Number} $b - Second number to compare.\n///\n/// @returns {Number} The greatest common divisor.\n@function gcd($a, $b) {\n  // From: http://rosettacode.org/wiki/Greatest_common_divisor#JavaScript\n  @if ($b != 0) {\n    @return gcd($b, $a % $b);\n  }\n  @else {\n    @return abs($a);\n  }\n}\n\n/// Handles decimal exponents by trying to convert them into a fraction and then use a nth-root-algorithm for parts of the calculation\n///\n/// @param {Number} $base - The base number.\n/// @param {Number} $exponent - The exponent.\n///\n/// @returns {Number} The product of the exponentiation.\n@function pow($base, $exponent, $prec: 16) {\n  @if (floor($exponent) != $exponent) {\n    $prec2 : pow(10, $prec);\n    $exponent: round($exponent * $prec2);\n    $denominator: gcd($exponent, $prec2);\n    @return nth-root(pow($base, $exponent / $denominator), $prec2 / $denominator, $prec);\n  }\n\n  $value: $base;\n  @if $exponent > 1 {\n    @for $i from 2 through $exponent {\n      $value: $value * $base;\n    }\n  }\n  @else if $exponent < 1 {\n    @for $i from 0 through -$exponent {\n      $value: $value / $base;\n    }\n  }\n\n  @return $value;\n}\n\n@function nth-root($num, $n: 2, $prec: 12) {\n  // From: http://rosettacode.org/wiki/Nth_root#JavaScript\n  $x: 1;\n\n  @for $i from 0 through $prec {\n    $x: 1 / $n * (($n - 1) * $x + ($num / pow($x, $n - 1)));\n  }\n\n  @return $x;\n}\n\n/// Calculates the height as a percentage of the width for a given ratio.\n/// @param {List} $ratio - Ratio to use to calculate the height, formatted as `x by y`.\n/// @return {Number} A percentage value for the height relative to the width of a responsive container.\n@function ratio-to-percentage($ratio) {\n  $w: nth($ratio, 1);\n  $h: nth($ratio, 3);\n  @return $h / $w * 100%;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group tabs\n////\n\n/// Default margin of the tab bar.\n/// @type Number\n$tab-margin: 0 !default;\n\n/// Default background color of a tab bar.\n/// @type Color\n$tab-background: $white !default;\n\n/// Font color of tab item.\n/// @type Color\n$tab-color: $primary-color !default;\n\n/// Active background color of a tab bar.\n/// @type Color\n$tab-background-active: $light-gray !default;\n\n/// Active font color of tab item.\n/// @type Color\n$tab-active-color: $primary-color !default;\n\n/// Font size of tab items.\n/// @type Number\n$tab-item-font-size: rem-calc(12) !default;\n\n/// Default background color on hover for items in a Menu.\n$tab-item-background-hover: $white !default;\n\n/// Default padding of a tab item.\n/// @type Number\n$tab-item-padding: 1.25rem 1.5rem !default;\n\n/// Default background color of tab content.\n/// @type Color\n$tab-content-background: $white !default;\n\n/// Default border color of tab content.\n/// @type Color\n$tab-content-border: $light-gray !default;\n\n/// Default text color of tab content.\n/// @type Color\n$tab-content-color: $body-font-color !default;\n\n/// Default padding for tab content.\n/// @type Number | List\n$tab-content-padding: 1rem !default;\n\n/// Adds styles for a tab container. Apply this to a `<ul>`.\n@mixin tabs-container (\n  $margin: $tab-margin,\n  $background: $tab-background,\n  $border-color: $tab-content-border\n) {\n  @include clearfix;\n  margin: $margin;\n  border: 1px solid $border-color;\n  background: $background;\n  list-style-type: none;\n}\n\n/// Augments a tab container to have vertical tabs. Use this in conjunction with `tabs-container()`.\n@mixin tabs-container-vertical {\n  > li {\n    display: block;\n    float: none;\n    width: auto;\n  }\n}\n\n/// Adds styles for the links within a tab container. Apply this to the `<li>` elements inside a tab container.\n@mixin tabs-title (\n  $padding: $tab-item-padding,\n  $font-size: $tab-item-font-size,\n  $color: $tab-color,\n  $color-active: $tab-active-color,\n  $background-hover: $tab-item-background-hover,\n  $background-active: $tab-background-active\n) {\n  float: #{$global-left};\n\n  > a {\n    @include disable-mouse-outline;\n    display: block;\n    padding: $padding;\n    font-size: $font-size;\n    line-height: 1;\n    color: $color;\n\n    &:hover {\n      background: $background-hover;\n      color: scale-color($color, $lightness: -14%);\n    }\n\n    &:focus,\n    &[aria-selected='true'] {\n      background: $background-active;\n      color: $color-active;\n    }\n  }\n}\n\n/// Adds styles for the wrapper that surrounds a tab group's content panes.\n@mixin tabs-content (\n  $background: $tab-content-background,\n  $color: $tab-content-color,\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-top: 0;\n  background: $background;\n  color: $color;\n  transition: all 0.5s ease;\n}\n\n/// Augments a tab content container to have a vertical style, by shifting the border around. Use this in conjunction with `tabs-content()`.\n@mixin tabs-content-vertical (\n  $border-color: $tab-content-border\n) {\n  border: 1px solid $border-color;\n  border-#{$global-left}: 0;\n}\n\n/// Adds styles for an individual tab content panel within the tab content container.\n@mixin tabs-panel (\n  $padding: $tab-content-padding\n) {\n  display: none;\n  padding: $padding;\n\n  &.is-active {\n    display: block;\n  }\n}\n\n@mixin foundation-tabs {\n  .tabs {\n    @include tabs-container;\n  }\n\n  // Vertical\n  .tabs.vertical {\n    @include tabs-container-vertical;\n  }\n\n  // Simple\n  .tabs.simple {\n    > li > a {\n      padding: 0;\n\n      &:hover {\n        background: transparent;\n      }\n    }\n  }\n\n  // Primary color\n  .tabs.primary {\n    background: $primary-color;\n\n    > li > a {\n      color: color-pick-contrast($primary-color);\n\n      &:hover,\n      &:focus {\n        background: smart-scale($primary-color);\n      }\n    }\n  }\n\n  .tabs-title {\n    @include tabs-title;\n  }\n\n  .tabs-content {\n    @include tabs-content;\n  }\n\n  .tabs-content.vertical {\n    @include tabs-content-vertical;\n  }\n\n  .tabs-panel {\n    @include tabs-panel;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group thumbnail\n////\n\n/// Border around thumbnail images.\n/// @type Border\n$thumbnail-border: 4px solid $white !default;\n\n/// Bottom margin for thumbnail images.\n/// @type Length\n$thumbnail-margin-bottom: $global-margin !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow: 0 0 0 1px rgba($black, 0.2) !default;\n\n/// Box shadow under thumbnail images.\n/// @type Shadow\n$thumbnail-shadow-hover: 0 0 6px 1px rgba($primary-color, 0.5) !default;\n\n/// Transition proprties for thumbnail images.\n/// @type Transition\n$thumbnail-transition: box-shadow 200ms ease-out !default;\n\n/// Default radius for thumbnail images.\n/// @type Number\n$thumbnail-radius: $global-radius !default;\n\n/// Adds thumbnail styles to an element.\n@mixin thumbnail {\n  display: inline-block;\n  max-width: 100%;\n  margin-bottom: $thumbnail-margin-bottom;\n\n  border: $thumbnail-border;\n  border-radius: $thumbnail-radius;\n  box-shadow: $thumbnail-shadow;\n\n  line-height: 0;\n}\n\n@mixin thumbnail-link {\n  transition: $thumbnail-transition;\n\n  &:hover,\n  &:focus {\n    box-shadow: $thumbnail-shadow-hover;\n  }\n\n  image {\n    box-shadow: none;\n  }\n}\n\n@mixin foundation-thumbnail {\n  .thumbnail {\n    @include thumbnail;\n  }\n\n  a.thumbnail {\n    @include thumbnail-link;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group menu\n////\n\n/// Margin of a menu.\n/// @type Number\n$menu-margin: 0 !default;\n\n/// Left-hand margin of a nested menu.\n/// @type Number\n$menu-nested-margin: $global-menu-nested-margin !default;\n\n/// Padding for items in a pill menu.\n/// @type Number\n$menu-items-padding: $global-menu-padding !default;\n\n/// margin for items in a simple menu.\n/// @type Number\n$menu-simple-margin: 1rem !default;\n\n/// Text color of an active menu item.\n/// @type Color\n$menu-item-color-active: $white !default;\n\n/// Background color of an active menu item.\n/// @type Color\n$menu-item-background-active: get-color(primary) !default;\n\n/// Spacing between an icon and text in a menu item.\n/// @type Number\n$menu-icon-spacing: 0.25rem !default;\n\n/// Backward compatibility for menu state. If true, this duplicate `active` with `is-active`. \n/// But please note that `active` will be removed in upcoming versions.\n/// @type Boolean\n$menu-state-back-compat: true !default;\n\n/// Backward compatibility for menu centered. If true, this duplicate `.menu-centered > .menu` with `.menu.align-center`. \n/// But please note that `menu-centered` will be removed in upcoming versions.\n/// @type Boolean\n$menu-centered-back-compat: true !default;\n\n/// Backward compatibility for using `icon-*` classes without `.icons` classes\n/// But please note that this backward compatibility will be removed in upcoming versions.\n/// @type Boolean\n$menu-icons-back-compat: true !default;\n\n/// Creates the base styles for a Menu.\n@mixin menu-base {\n  padding: 0;\n  margin: 0;\n  list-style: none;\n  position: relative;\n\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: wrap;\n  }\n\n  li {\n    @include disable-mouse-outline;\n  }\n\n  a,\n  .button {\n    line-height: 1;\n    text-decoration: none;\n    display: block;\n    padding: $menu-items-padding;\n  }\n\n  // Reset styles of inner elements\n  input,\n  select,\n  a,\n  button {\n    margin-bottom: 0;\n  }\n\n  input {\n    display: inline-block;\n  }\n}\n\n/// Expands the items of a Menu, so each item is the same width.\n@mixin menu-expand {\n  @if $global-flexbox {\n    li {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n  }\n  @else {\n    display: table;\n    width: 100%;\n\n    > li {\n      display: table-cell;\n      vertical-align: middle;\n    }\n  }\n}\n\n/// Align menu items.\n@mixin menu-align($alignment) {\n  @if $alignment == left {\n    @if $global-flexbox {\n      justify-content: flex-start;\n    }\n    @else {\n      text-align: $global-left;\n    }\n  }\n  @else if $alignment == right {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: flex-end;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n\n      &.vertical li {\n        display: block;\n        text-align: $global-right;\n\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n    @else {\n      text-align: $global-right;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n\n      &.vertical {\n        .submenu li {\n          text-align: $global-right;\n        }\n      }\n    }\n  }\n  @else if $alignment == center {\n    @if $global-flexbox {\n      li {\n        display: flex;\n        justify-content: center;\n\n        .submenu li {\n          justify-content: flex-start;\n        }\n      }\n    }\n    @else {\n      text-align: center;\n\n      .submenu li {\n        text-align: $global-left;\n      }\n    }\n  }\n}\n\n/// Sets the direction of a Menu.\n/// @param {Keyword} $dir [horizontal] - Direction of the Menu. Can be `horizontal` or `vertical`.\n@mixin menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    @if $global-flexbox {\n      flex-wrap: wrap;\n      flex-direction: row;\n    }\n    @else {\n      li {\n        display: inline-block;\n      }\n    }\n  }\n  @else if $dir == vertical {\n    @if $global-flexbox {\n      flex-wrap: nowrap;\n      flex-direction: column;\n    }\n    @else {\n      li {\n        display: block;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for menu-direction() must be horizontal or vertical.';\n  }\n}\n\n/// Creates a simple Menu, which has no padding or hover state.\n/// @param {Keyword} $dir [$global-left] - Direction of the menu. This effects the side of the `<li>` that receives the margin.\n/// @param {Number} $margin [$menu-simple-margin] - The margin to apply to each `<li>`.\n@mixin menu-simple($dir: $global-left, $margin: $menu-simple-margin) {\n  @if $global-flexbox {\n    align-items: center;\n  }\n\n  li + li {\n    margin-#{$dir}: $margin;\n  }\n\n  a {\n    padding: 0;\n  }\n}\n\n/// Adds styles for a nested Menu, by adding `margin-left` to the menu.\n/// @param {Keyword|Number} $margin [$menu-nested-margin] - Length of the margin.\n/// @param {Keyword} $nested-alignment [left] - Alignment of the nested class\n@mixin menu-nested(\n  $margin: $menu-nested-margin,\n  $nested-alignment: left\n) {\n  @if $nested-alignment == right {\n    margin-#{$global-right}: $margin;\n    margin-#{$global-left}: 0;\n  }\n  @else {\n    margin-#{$global-right}: 0;\n    margin-#{$global-left}: $margin;\n  }\n\n}\n\n/// Adds basic styles for icons in menus.\n@mixin menu-icons() {\n  @if $global-flexbox {\n    a {\n      display: flex;\n    }\n  }\n  @else {\n    img,\n    i,\n    svg {\n      vertical-align: middle;\n\n      + span {\n        vertical-align: middle;\n      }\n    }\n  }\n}\n\n/// Adds position classes for icons within a menu.\n@mixin menu-icon-position($position: left, $spacing: $menu-icon-spacing) {\n  @if $position == left {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-right}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    li a {\n      @if $global-flexbox {\n        flex-flow: row nowrap;\n      }\n\n      img,\n      i,\n      svg {\n        margin-#{$global-left}: $spacing;\n\n        @if not $global-flexbox {\n          display: inline-block;\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: 0 auto $spacing;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    li a {\n      @if $global-flexbox {\n        flex-flow: column nowrap;\n      }\n      @else {\n        text-align: center;\n      }\n\n      img,\n      i,\n      svg {\n        @if not $global-flexbox {\n          display: block;\n          margin: $spacing auto 0;\n        }\n        @else {\n          align-self: stretch;\n          margin-bottom: $spacing;\n          text-align: center;\n        }\n      }\n    }\n  }\n}\n\n@mixin menu-text {\n  padding: $global-menu-padding;\n\n  font-weight: bold;\n  line-height: 1;\n  color: inherit;\n}\n\n@mixin menu-state-active {\n  background: $menu-item-background-active;\n  color: $menu-item-color-active;\n}\n\n@mixin foundation-menu {\n  .menu {\n    @include menu-base;\n\n    // Default orientation: horizontal\n    &, &.horizontal {\n      @include menu-direction(horizontal);\n    }\n\n    // Vertical orientation modifier\n    &.vertical {\n      @include menu-direction(vertical);\n    }\n\n    // Even-width modifier for horizontal orientation\n    &.expanded {\n      @include menu-expand;\n    }\n\n    // Simple\n    &.simple {\n      @include menu-simple;\n    }\n\n    // Breakpoint specific versions\n    @include -zf-each-breakpoint($small: false) {\n      &.#{$-zf-size}-horizontal {\n        @include menu-direction(horizontal);\n      }\n\n      &.#{$-zf-size}-vertical {\n        @include menu-direction(vertical);\n      }\n\n      &.#{$-zf-size}-expanded {\n        @include menu-expand;\n      }\n\n      &.#{$-zf-size}-simple {\n        @include menu-expand;\n      }\n    }\n\n    // Nesting\n    &.nested {\n      @include menu-nested;\n    }\n\n    // Icon Base Styles\n    &.icons {\n      @include menu-icons;\n    }\n\n    // Backward Compatibility for active state\n    @if $menu-icons-back-compat {\n      &.icon-top,\n      &.icon-right,\n      &.icon-bottom,\n      &.icon-left {\n        @include menu-icons;\n      }\n    }\n\n    // Icon Left\n    &.icon-left {\n      @include menu-icon-position(left);\n    }\n\n    // Icon Right\n    &.icon-right {\n      @include menu-icon-position(right);\n    }\n\n    // Icon Top\n    &.icon-top {\n      @include menu-icon-position(top);\n    }\n\n    // Icon Bottom\n    &.icon-bottom {\n      @include menu-icon-position(bottom);\n    }\n\n    // Active state\n    .is-active > a {\n      @include menu-state-active;\n    }\n    \n    // Backward Compatibility for active state\n    @if $menu-state-back-compat {\n      .active > a {\n        @include menu-state-active;\n      }\n    }\n\n    // Align left\n    &.align-#{$global-left} {\n      @include menu-align(left);\n    }\n\n    // Align right\n    &.align-#{$global-right} {\n      @include menu-align(right);\n\n      .nested {\n        @include menu-nested($nested-alignment: right);\n      }\n    }\n\n    // Align center\n    &.align-center {\n      @include menu-align(center);\n    }\n\n    .menu-text {\n      @include menu-text;\n    }\n  }\n\n  @if $menu-centered-back-compat {\n    .menu-centered {\n      > .menu {\n        @if $global-flexbox {\n          justify-content: center;\n        }\n        \n        @include menu-align(center);\n      }\n    }\n  }\n\n  // Prevent FOUC when using the Responsive Menu plugin\n  .no-js [data-responsive-menu] ul {\n    display: none;\n  }\n}\n","@mixin foundation-menu-icon {\n  .menu-icon {\n    @include hamburger($color: $titlebar-icon-color, $color-hover: $titlebar-icon-color-hover);\n  }\n\n  .menu-icon.dark {\n    @include hamburger;\n  }\n}\n","////\n/// @group accordion-menu\n////\n\n/// Sets accordion menu padding.\n/// @type Number\n$accordionmenu-padding: $global-menu-padding !default;\n\n/// Sets accordion menu nested margin\n/// @type Number\n$accordionmenu-nested-margin: $global-menu-nested-margin !default;\n\n/// Sets accordion menu submenu padding.\n/// @type Number\n$accordionmenu-submenu-padding: $accordionmenu-padding !default;\n\n/// Sets if accordion menus have the default arrow styles.\n/// @type Boolean\n$accordionmenu-arrows: true !default;\n\n/// Sets accordion menu arrow color if arrow is used.\n/// @type Color\n$accordionmenu-arrow-color: $primary-color !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-item-background: null !default;\n\n/// Sets accordion menu item border.\n/// @type Color\n$accordionmenu-border: null !default;\n\n/// Sets accordion menu item padding.\n/// @type Color\n$accordionmenu-submenu-toggle-background: null !default;\n\n/// Sets accordion menu item padding.\n/// @type List\n$accordion-submenu-toggle-border: $accordionmenu-border !default;\n\n/// Sets accordion menu submenu toggle background width.\n/// @type Number\n$accordionmenu-submenu-toggle-width: 40px !default;\n\n/// Sets accordion menu submenu toggle background height.\n/// @type Number\n$accordionmenu-submenu-toggle-height: $accordionmenu-submenu-toggle-width !default;\n\n/// Sets accordion menu arrow size if arrow is used.\n/// @type Length\n$accordionmenu-arrow-size: 6px !default;\n\n@mixin zf-accordion-menu-left-right-arrows {\n  .is-accordion-submenu-parent:not(.has-submenu-toggle) > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($accordionmenu-arrow-size, $accordionmenu-arrow-color, down);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * ($accordionmenu-arrow-size / 2);\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-accordion-submenu-parent > a::after {\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-accordion-submenu-parent > a::after {\n    right: auto;\n    left: 1rem;\n  }\n}\n@mixin foundation-accordion-menu {\n\n  .accordion-menu {\n    @if $accordionmenu-border {\n      border-bottom: $accordionmenu-border;\n    }\n\n    li {\n      @if $accordionmenu-border {\n        border-top: $accordionmenu-border;\n        border-right: $accordionmenu-border;\n        border-left: $accordionmenu-border;\n      }\n      width: 100%;\n    }\n\n    a {\n      @if $accordionmenu-item-background {\n        background: $accordionmenu-item-background;\n      }\n      padding: $accordionmenu-padding;\n    }\n\n    .is-accordion-submenu a {\n      padding: $accordionmenu-submenu-padding;\n    }\n\n    .nested.is-accordion-submenu {\n      @include menu-nested($accordionmenu-nested-margin);\n    }\n\n    &.align-#{$global-right} {\n      .nested.is-accordion-submenu {\n        @include menu-nested($accordionmenu-nested-margin, right);\n      }\n    }\n\n    @if $accordionmenu-arrows {\n      @include zf-accordion-menu-left-right-arrows;\n\n      .is-accordion-submenu-parent[aria-expanded='true'] > a::after {\n        transform: rotate(180deg);\n        transform-origin: 50% 50%;\n      }\n    }\n  }\n\n  .is-accordion-submenu li {\n    @if $accordionmenu-border {\n      border-right: 0;\n      border-left: 0;\n    }\n  }\n\n  .is-accordion-submenu-parent {\n    position: relative;\n  }\n\n  .has-submenu-toggle > a {\n    margin-#{$global-right}: $accordionmenu-submenu-toggle-width;\n  }\n\n  // Submenu toggle\n  .submenu-toggle {\n    position: absolute;\n    top: 0;\n    #{$global-right}: 0;\n\n    width: $accordionmenu-submenu-toggle-width;\n    height: $accordionmenu-submenu-toggle-height;\n\n    cursor: pointer;\n\n    border-#{$global-left}: $accordion-submenu-toggle-border;\n\n    @if $accordionmenu-submenu-toggle-background {\n      background: $accordionmenu-submenu-toggle-background;\n    }\n\n    // Add the arrow to the toggle\n    &::after {\n      @include css-triangle(6px, $accordionmenu-arrow-color, down);\n\n      top: 0;\n      bottom: 0;\n      margin: auto;\n    }\n  }\n\n  // Rotate the arrow when menu is open\n  .submenu-toggle[aria-expanded='true']::after {\n    transform: scaleY(-1);\n    transform-origin: 50% 50%;\n  }\n\n  .submenu-toggle-text {\n    @include element-invisible;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group drilldown\n////\n\n/// Transition property to use for animating menus.\n/// @type Transition\n$drilldown-transition: transform 0.15s linear !default;\n\n/// Adds arrows to drilldown items with submenus, as well as the back button.\n/// @type Boolean\n$drilldown-arrows: true !default;\n\n/// Sets drilldown menu item padding.\n/// @type Number\n$drilldown-padding: $global-menu-padding !default;\n\n/// Sets drilldown menu nested margin\n/// @type Number\n$drilldown-nested-margin: 0 !default;\n\n/// Background color for drilldown top level items.\n/// @type Color\n$drilldown-background: $white !default;\n\n/// Sets drilldown menu item padding in the submenu.\n/// @type Number\n$drilldown-submenu-padding: $drilldown-padding !default;\n\n/// Background color for drilldown submenus.\n/// @type Color\n$drilldown-submenu-background: $white !default;\n\n/// Sets drilldown arrow color if arrow is used.\n/// @type Color\n$drilldown-arrow-color: $primary-color !default;\n\n/// Sets drilldown arrow size if arrow is used.\n/// @type Length\n$drilldown-arrow-size: 6px !default;\n\n@mixin zf-drilldown-left-right-arrows {\n  .is-drilldown-submenu-parent > a {\n    position: relative;\n\n    &::after {\n      @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-right);\n      position: absolute;\n      top: 50%;\n      margin-top: -1 * $drilldown-arrow-size;\n      #{$global-right}: 1rem;\n    }\n  }\n\n  &.align-left .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n    right: 1rem;\n    left: auto;\n  }\n\n  &.align-right .is-drilldown-submenu-parent > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 1rem;\n  }\n\n}\n\n@mixin foundation-drilldown-menu {\n  // Applied to the Menu container\n  .is-drilldown {\n    position: relative;\n    overflow: hidden;\n\n    li {\n      display: block;\n    }\n\n    &.animate-height {\n      transition: height 0.5s;\n    }\n  }\n\n  // The top level <ul>\n  .drilldown {\n    a {\n      padding: $drilldown-padding;\n      background: $drilldown-background;\n    }\n\n    // Applied to submenu <ul>s\n    .is-drilldown-submenu {\n      position: absolute;\n      top: 0;\n      #{$global-left}: 100%;\n      z-index: -1;\n\n      width: 100%;\n      background: $drilldown-submenu-background;\n      transition: $drilldown-transition;\n\n      &.is-active {\n        z-index: 1;\n        display: block;\n        transform: translateX(if($global-text-direction == ltr, -100%, 100%));\n      }\n\n      &.is-closing {\n        transform: translateX(if($global-text-direction == ltr, 100%, -100%));\n      }\n\n      // Submenu item padding\n      a {\n        padding: $drilldown-submenu-padding;\n      }\n    }\n\n    .nested.is-drilldown-submenu {\n      @include menu-nested($drilldown-nested-margin);\n    }\n\n    .drilldown-submenu-cover-previous {\n      min-height: 100%;\n    }\n\n    @if $drilldown-arrows {\n      @include zf-drilldown-left-right-arrows;\n\n      .js-drilldown-back > a::before {\n        @include css-triangle($drilldown-arrow-size, $drilldown-arrow-color, $global-left);\n        display: inline-block;\n        vertical-align: middle;\n        margin-#{$global-right}: 0.75rem; // Creates space between the arrow and the text\n      }\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group dropdown-menu\n////\n\n/// Enables arrows for items with dropdown menus.\n/// @type Boolean\n$dropdownmenu-arrows: true !default;\n\n/// Sets dropdown menu arrow color if arrow is used.\n/// @type Color\n$dropdownmenu-arrow-color: $anchor-color !default;\n\n/// Sets dropdown menu arrow size if arrow is used.\n/// @type Length\n$dropdownmenu-arrow-size: 6px !default;\n\n/// Sets dropdown menu arrow padding for aligning the arrow correctly.\n/// @type Length\n$dropdownmenu-arrow-padding: 1.5rem !default;\n\n/// Minimum width of dropdown sub-menus.\n/// @type Length\n$dropdownmenu-min-width: 200px !default;\n\n/// Background color for top level items.\n/// @type Color\n$dropdownmenu-background: null !default;\n\n/// Background color for dropdowns.\n/// @type Color\n$dropdownmenu-submenu-background: $white !default;\n\n/// Padding for top level items.\n/// @type Number\n$dropdownmenu-padding: $global-menu-padding !default;\n\n/// Sets dropdown menu nested margin\n/// @type Number\n$dropdownmenu-nested-margin: 0 !default;\n\n/// Padding for sub-menu items.\n/// @type Number\n$dropdownmenu-submenu-padding: $dropdownmenu-padding !default;\n\n/// Border for dropdown sub-menus.\n/// @type List\n$dropdownmenu-border: 1px solid $medium-gray !default;\n\n// Border width for dropdown sub-menus.\n// Used to adjust top margin of a sub-menu if a border is used.\n// @type Length\n$dropdownmenu-border-width: nth($dropdownmenu-border, 1);\n\n/// Text color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-color-active: get-color(primary) !default;\n\n/// Background color of an active dropdown menu item. Explicit override for menu defaults\n/// @type Color\n$dropdown-menu-item-background-active: transparent !default;\n\n@mixin zf-dropdown-left-right-arrows {\n  > a::after {\n    #{$global-right}: 14px;\n  }\n\n  &.opens-left > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, left);\n    right: auto;\n    left: 5px;\n  }\n\n  &.opens-right > a::after {\n    @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, right);\n  }\n}\n\n@mixin dropdown-menu-direction($dir: horizontal) {\n  @if $dir == horizontal {\n    > li.opens-left { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n\n    > li.opens-right { // sass-lint:disable-line no-qualifying-elements\n      > .is-dropdown-submenu {\n        top: 100%;\n        right: auto;\n        left: 0;\n      }\n    }\n\n    @if $dropdownmenu-arrows {\n      > li.is-dropdown-submenu-parent > a { // sass-lint:disable-line no-qualifying-elements\n        position: relative;\n        padding-#{$global-right}: $dropdownmenu-arrow-padding;\n      }\n\n      > li.is-dropdown-submenu-parent > a::after { // sass-lint:disable-line no-qualifying-elements\n        @include css-triangle($dropdownmenu-arrow-size, $dropdownmenu-arrow-color, down);\n        #{$global-right}: 5px;\n        #{$global-left}: auto;\n        margin-top: -1 * ($dropdownmenu-arrow-size / 2);\n      }\n    }\n  }\n  @else if $dir == vertical {\n    > li {\n      .is-dropdown-submenu {\n        top: 0;\n      }\n\n      &.opens-left {\n        > .is-dropdown-submenu {\n          top: 0;\n          right: 100%;\n          left: auto;\n        }\n      }\n\n      &.opens-right {\n        > .is-dropdown-submenu {\n          right: auto;\n          left: 100%;\n        }\n      }\n\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n  }\n  @else {\n    @warn 'The direction used for dropdown-menu-direction() must be horizontal or vertical.';\n  }\n}\n\n@mixin foundation-dropdown-menu {\n  .dropdown.menu {\n    @include dropdown-menu-direction(horizontal);\n\n    a {\n      @include disable-mouse-outline;\n    }\n\n    // Top-level item\n    > li > a {\n      background: $dropdownmenu-background;\n      padding: $dropdownmenu-padding;\n    }\n\n    // Top-level item active state\n    > li.is-active > a {\n      background: $dropdown-menu-item-background-active;\n      color: $dropdown-menu-item-color-active;\n    }\n\n    .no-js & ul {\n      display: none;\n    }\n\n    .nested.is-dropdown-submenu {\n      @include menu-nested($dropdownmenu-nested-margin);\n    }\n\n    &.vertical {\n      @include dropdown-menu-direction(vertical);\n    }\n\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        @include breakpoint($size) {\n          &.#{$size}-horizontal {\n            @include dropdown-menu-direction(horizontal);\n          }\n\n          &.#{$size}-vertical {\n            @include dropdown-menu-direction(vertical);\n          }\n        }\n      }\n    }\n\n    &.align-right {\n      .is-dropdown-submenu.first-sub {\n        top: 100%;\n        right: 0;\n        left: auto;\n      }\n    }\n  }\n\n  .is-dropdown-menu.vertical {\n    width: 100px;\n\n    &.align-right {\n      float: right;\n    }\n  }\n\n  .is-dropdown-submenu-parent {\n    position: relative;\n\n    a::after {\n      position: absolute;\n      top: 50%;\n      #{$global-right}: 5px;\n      #{$global-left}: auto;\n      margin-top: -1 * $dropdownmenu-arrow-size;\n    }\n\n    &.opens-inner > .is-dropdown-submenu {\n\n      top: 100%;\n      @if $global-text-direction == 'rtl' {\n        right: auto;\n      }\n      @else {\n        left: auto;\n      }\n    }\n\n    &.opens-left > .is-dropdown-submenu {\n      right: 100%;\n      left: auto;\n    }\n\n    &.opens-right > .is-dropdown-submenu {\n      right: auto;\n      left: 100%;\n    }\n  }\n\n  .is-dropdown-submenu {\n    position: absolute;\n    top: 0;\n    #{$global-left}: 100%;\n    z-index: 1;\n\n    display: none;\n    min-width: $dropdownmenu-min-width;\n\n    border: $dropdownmenu-border;\n    background: $dropdownmenu-submenu-background;\n\n    .dropdown & a {\n      padding: $dropdownmenu-submenu-padding;\n    }\n\n    .is-dropdown-submenu-parent {\n      @if $dropdownmenu-arrows {\n        @include zf-dropdown-left-right-arrows;\n      }\n    }\n\n    @if (type-of($dropdownmenu-border-width) == 'number') {\n      .is-dropdown-submenu {\n        margin-top: (-$dropdownmenu-border-width);\n      }\n    }\n\n    > li {\n      width: 100%;\n    }\n\n    // [TODO] Cut back specificity\n    //&:not(.js-dropdown-nohover) > .is-dropdown-submenu-parent:hover > &, // why is this line needed? Opening is handled by JS and this causes some ugly flickering when the sub is re-positioned automatically...\n    &.js-dropdown-active {\n      display: block;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group off-canvas\n////\n\n/// Width map of a left/right off-canvas panel.\n/// @type Map\n$offcanvas-sizes: (\n  small: 250px,\n) !default;\n\n/// Height map of a top/bottom off-canvas panel.\n/// @type Map\n$offcanvas-vertical-sizes: (\n  small: 250px,\n) !default;\n\n/// Background color of an off-canvas panel.\n/// @type Color\n$offcanvas-background: $light-gray !default;\n\n/// Box shadow for the off-canvas overlap panel.\n/// @type Shadow\n$offcanvas-shadow: 0 0 10px rgba($black, 0.7) !default;\n\n/// Inner box shadow size for the off-canvas push panel.\n/// @type Number\n$offcanvas-inner-shadow-size: 20px !default;\n\n/// Inner box shadow color for the off-canvas push panel.\n/// @type Color\n$offcanvas-inner-shadow-color: rgba($black, 0.25) !default;\n\n/// Z-index of an off-canvas content overlay.\n/// @type Number\n$offcanvas-overlay-zindex: 11 !default;\n\n/// Z-index of an off-canvas panel with the `push` transition.\n/// @type Number\n$offcanvas-push-zindex: 12 !default;\n\n/// Z-index of an off-canvas panel with the `overlap` transition.\n/// @type Number\n$offcanvas-overlap-zindex: 13 !default;\n\n/// Z-index of an off-canvas panel using the `reveal-for-*` classes or mixin.\n/// @type Number\n$offcanvas-reveal-zindex: 12 !default;\n\n/// Length of the animation on an off-canvas panel.\n/// @type Number\n$offcanvas-transition-length: 0.5s !default;\n\n/// Timing function of the animation on an off-canvas panel.\n/// @type Keyword\n$offcanvas-transition-timing: ease !default;\n\n/// If `true`, a revealed off-canvas will be fixed-position, and scroll with the screen.\n/// @type Bool\n$offcanvas-fixed-reveal: true !default;\n\n/// Background color for the overlay that appears when an off-canvas panel is open.\n/// @type Color\n$offcanvas-exit-background: rgba($white, 0.25) !default;\n\n/// CSS class used for the main content area. The off-canvas mixins use this to target the page content.\n$maincontent-class: 'off-canvas-content' !default;\n\n/// Adds baseline styles for off-canvas. This CSS is required to make the other pieces work.\n@mixin off-canvas-basics {\n\n  /// Transform deprecated size settings into map & show warning\n  @if variable-exists(offcanvas-size) {\n    $offcanvas-sizes: (small: $offcanvas-size, medium: $offcanvas-size) !global;\n    @warn '$offcanvas-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-sizes instead';\n  }\n  @if variable-exists(offcanvas-vertical-size) {\n    $offcanvas-vertical-sizes: (small: $offcanvas-vertical-size, medium: $offcanvas-vertical-size) !global;\n    @warn '$offcanvas-vertical-size is deprecated and not used anymore! Please update your settings and use the map $offcanvas-vertical-sizes instead';\n  }\n\n  // Checks the z-indexes and increase them due to backwards compatibility.\n  // This is necessary because the overlay's z-index is new since v6.4 and may be identical to the user custom settings of the push z-index.\n  @if $offcanvas-push-zindex <= $offcanvas-overlay-zindex { $offcanvas-push-zindex: $offcanvas-overlay-zindex + 1 !global; }\n  @if $offcanvas-overlap-zindex <= $offcanvas-push-zindex { $offcanvas-overlap-zindex: $offcanvas-push-zindex + 1 !global; }\n  @if $offcanvas-reveal-zindex <= $offcanvas-overlay-zindex { $offcanvas-reveal-zindex: $offcanvas-overlay-zindex + 1 !global; }\n\n  // Hides overflow on body when an off-canvas panel is open.\n  .is-off-canvas-open {\n    overflow: hidden;\n  }\n\n  // Off-canvas overlay (generated by JavaScript)\n  .js-off-canvas-overlay {\n    position: absolute;\n    top: 0;\n    left: 0;\n    z-index: $offcanvas-overlay-zindex;\n\n    width: 100%;\n    height: 100%;\n\n    transition: opacity $offcanvas-transition-length $offcanvas-transition-timing, visibility $offcanvas-transition-length $offcanvas-transition-timing;\n\n    background: $offcanvas-exit-background;\n\n    opacity: 0;\n    visibility: hidden;\n\n    overflow: hidden;\n\n    &.is-visible {\n      opacity: 1;\n      visibility: visible;\n    }\n\n    &.is-closable {\n      cursor: pointer;\n    }\n\n    &.is-overlay-absolute {\n      position: absolute;\n    }\n\n    &.is-overlay-fixed {\n      position: fixed;\n    }\n  }\n}\n\n// Adds basic styles for an off-canvas wrapper.\n@mixin off-canvas-wrapper() {\n  position: relative;\n  overflow: hidden;\n}\n\n/// Adds basic styles for an off-canvas panel.\n@mixin off-canvas-base(\n  $background: $offcanvas-background,\n  $transition: $offcanvas-transition-length $offcanvas-transition-timing,\n  $fixed: true\n) {\n  @include disable-mouse-outline;\n\n  @if $fixed == true {\n    position: fixed;\n  }\n  @else {\n    position: absolute;\n  }\n\n  // Set the off-canvas z-index.\n  z-index: $offcanvas-push-zindex;\n\n  // Increase CSS specificity\n  &.is-transition-push {\n    z-index: $offcanvas-push-zindex;\n  }\n\n  transition: transform $transition;\n  backface-visibility: hidden;\n\n  background: $background;\n\n  // Hide inactive off-canvas within the content that have the same position\n  &.is-closed {\n    visibility: hidden;\n  }\n\n  // Overlap only styles.\n  &.is-transition-overlap {\n    z-index: $offcanvas-overlap-zindex;\n\n    &.is-open {\n      box-shadow: $offcanvas-shadow;\n    }\n  }\n\n  // Sets transform to 0 to show an off-canvas panel.\n  &.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles to position an off-canvas panel to the left/right/top/bottom.\n@mixin off-canvas-position(\n  $position: left,\n  $orientation: horizontal,\n  $sizes: if($orientation == horizontal, $offcanvas-sizes, $offcanvas-vertical-sizes)\n) {\n  @if $position == left {\n    top: 0;\n    left: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == right {\n    top: 0;\n    right: 0;\n    height: 100%;\n    overflow-y: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        width: $size;\n        transform: translateX($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateX($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateX(-$size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == top {\n    top: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY(-$size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY(-$size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY($size);\n          }\n        }\n      }\n    }\n  }\n  @else if $position == bottom {\n    bottom: 0;\n    left: 0;\n    width: 100%;\n    overflow-x: auto;\n\n    @each $name, $size in $sizes {\n      @include breakpoint($name) {\n        height: $size;\n        transform: translateY($size);\n      }\n    }\n\n    // Sets the position for nested off-canvas element\n    @at-root .#{$maincontent-class} .off-canvas.position-#{$position} {\n      @each $name, $size in $sizes {\n        @include breakpoint($name) {\n          transform: translateY($size);\n        }\n      }\n      &.is-transition-overlap.is-open {\n        transform: translate(0, 0);\n      }\n    }\n\n    // Sets the open position for the content\n    @at-root .#{$maincontent-class}.is-open-#{$position} {\n      &.has-transition-push {\n        @each $name, $size in $sizes {\n          @include breakpoint($name) {\n            transform: translateY(-$size);\n          }\n        }\n      }\n    }\n  }\n\n  // If $offcanvas-inner-shadow-size is set, add inner box-shadow.\n  // This mimics the off-canvas panel having a lower z-index, without having to have one.\n  @if $offcanvas-inner-shadow-size {\n    &.is-transition-push {\n      @if $position == left {\n        @include inner-side-shadow(right, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == right {\n        @include inner-side-shadow(left, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == top {\n        @include inner-side-shadow(bottom, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n      @else if $position == bottom {\n        @include inner-side-shadow(top, $offcanvas-inner-shadow-size, $offcanvas-inner-shadow-color);\n      }\n    }\n  }\n\n}\n\n/// Sets the styles for the content container.\n@mixin off-canvas-content() {\n  transform: none;\n  transition: transform $offcanvas-transition-length $offcanvas-transition-timing;\n  backface-visibility: hidden;\n\n  // Transform scope until the element is closed (makes sure transitionend gets triggered)\n  &.has-transition-push {\n    transform: translate(0, 0);\n  }\n\n  // Consider element & content, nested in another content\n  .off-canvas.is-open {\n    transform: translate(0, 0);\n  }\n}\n\n/// Adds styles that reveal an off-canvas panel.\n@mixin off-canvas-reveal(\n$position: left,\n$zindex: $offcanvas-reveal-zindex,\n$content: $maincontent-class,\n$breakpoint: small\n) {\n  transform: none;\n  z-index: $zindex;\n  transition: none;\n  visibility: visible;\n\n  @if not $offcanvas-fixed-reveal {\n    position: absolute;\n  }\n\n  .close-button {\n    display: none;\n  }\n\n  // Consider revealed element is nested in content\n  .#{$maincontent-class} & {\n    transform: none;\n  }\n\n  @at-root .#{$content}.has-reveal-#{$position} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n\n  // backwards compatibility (prior to v6.4)\n  & ~ .#{$content} {\n    margin-#{$position}: -zf-get-bp-val($offcanvas-sizes, $breakpoint);\n  }\n}\n\n/// Overrides the off-canvas styles\n@mixin in-canvas() {\n  visibility: visible;\n  height: auto;\n  position: static;\n  background: none;\n  width: auto;\n  overflow: visible;\n  transition: none;\n\n  // Increase CSS specificity\n  &.position-left,\n  &.position-right,\n  &.position-top,\n  &.position-bottom {\n    box-shadow: none;\n    transform: none;\n  }\n\n  .close-button {\n    display: none;\n  }\n}\n\n@mixin foundation-off-canvas {\n  @include off-canvas-basics;\n\n  // Off-canvas wrapper\n  .off-canvas-wrapper {\n    @include off-canvas-wrapper;\n  }\n\n  // Off-canvas container\n  .off-canvas {\n    @include off-canvas-base;\n\n    // Force position absolute for nested off-canvas because fixed doesn't work for push transition within the transform scope.\n    @at-root .#{$maincontent-class} & {\n      // NOTE: since overlap transition is currently forced if nested, there's no need to force position absolute until nested push transition is supported.\n      // position: absolute;\n    }\n  }\n\n  // Off-canvas container with absolute position\n  .off-canvas-absolute {\n    @include off-canvas-base($fixed: false);\n  }\n\n  // Off-canvas position classes\n  .position-left    { @include off-canvas-position(left,   horizontal); }\n  .position-right   { @include off-canvas-position(right,  horizontal); }\n  .position-top     { @include off-canvas-position(top,    vertical); }\n  .position-bottom  { @include off-canvas-position(bottom, vertical); }\n\n  .off-canvas-content {\n    @include off-canvas-content;\n  }\n\n  // Reveal off-canvas panel on larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .position-left.reveal-for-#{$name} {\n          @include off-canvas-reveal(left, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-right.reveal-for-#{$name} {\n          @include off-canvas-reveal(right, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-top.reveal-for-#{$name} {\n          @include off-canvas-reveal(top, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n\n        .position-bottom.reveal-for-#{$name} {\n          @include off-canvas-reveal(bottom, $offcanvas-reveal-zindex, $maincontent-class, $name);\n        }\n      }\n    }\n  }\n\n  // Move in-canvas for larger screens\n  @each $name, $value in $breakpoint-classes {\n    @if $name != $-zf-zero-breakpoint {\n      @include breakpoint($name) {\n        .off-canvas.in-canvas-for-#{$name} {\n          @include in-canvas;\n        }\n      }\n    }\n  }\n}\n\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n@mixin foundation-sticky {\n  .sticky-container {\n    position: relative;\n  }\n\n  .sticky {\n    position: relative;\n    z-index: 0;\n    transform: translate3d(0, 0, 0);\n  }\n\n  .sticky.is-stuck {\n    position: fixed;\n    z-index: 5;\n    width: 100%;\n\n    &.is-at-top {\n      top: 0;\n    }\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n\n  .sticky.is-anchored {\n    position: relative;\n    right: auto;\n    left: auto;\n\n    &.is-at-bottom {\n      bottom: 0;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group title-bar\n////\n\n/// Background color of a title bar.\n/// @type Color\n$titlebar-background: $black !default;\n\n/// Color of text inside a title bar.\n/// @type Color\n$titlebar-color: $white !default;\n\n/// Padding inside a title bar.\n/// @type Length\n$titlebar-padding: 0.5rem !default;\n\n/// Font weight of text inside a title bar.\n/// @type Weight\n$titlebar-text-font-weight: bold !default;\n\n/// Color of menu icons inside a title bar.\n/// @type Color\n$titlebar-icon-color: $white !default;\n\n/// Color of menu icons inside a title bar on hover.\n/// @type Color\n$titlebar-icon-color-hover: $medium-gray !default;\n\n/// Spacing between the menu icon and text inside a title bar.\n/// @type Length\n$titlebar-icon-spacing: 0.25rem !default;\n\n@mixin foundation-title-bar {\n  .title-bar {\n    padding: $titlebar-padding;\n    background: $titlebar-background;\n    color: $titlebar-color;\n\n    @if $global-flexbox {\n      display: flex;\n      justify-content: flex-start;\n      align-items: center;\n    }\n    @else {\n      @include clearfix;\n    }\n\n    .menu-icon {\n      margin-#{$global-left}: $titlebar-icon-spacing;\n      margin-#{$global-right}: $titlebar-icon-spacing;\n    }\n  }\n\n  @if $global-flexbox {\n    .title-bar-left,\n    .title-bar-right {\n      flex: 1 1 0px; // sass-lint:disable-line zero-unit\n    }\n\n    .title-bar-right {\n      text-align: right;\n    }\n  }\n  @else {\n    .title-bar-left {\n      float: left;\n    }\n\n    .title-bar-right {\n      float: right;\n      text-align: right;\n    }\n  }\n\n  .title-bar-title {\n    display: inline-block;\n    vertical-align: middle;\n    font-weight: $titlebar-text-font-weight;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group top-bar\n////\n\n/// Padding for the top bar.\n/// @type Number\n$topbar-padding: 0.5rem !default;\n\n/// Background color for the top bar. This color also cascades to menus within the top bar.\n/// @type Color\n$topbar-background: $light-gray !default;\n\n/// Background color submenus within the top bar. Usefull if $topbar-background is transparent.\n/// @type Color\n$topbar-submenu-background: $topbar-background !default;\n\n/// Spacing for the top bar title.\n/// @type Number\n$topbar-title-spacing: 0.5rem 1rem 0.5rem 0 !default;\n\n/// Maximum width of `<input>` elements inside the top bar.\n/// @type Number\n$topbar-input-width: 200px !default;\n\n/// Breakpoint at which top bar switches from mobile to desktop view.\n/// @type Breakpoint\n$topbar-unstack-breakpoint: medium !default;\n\n/// Adds styles for a top bar container.\n@mixin top-bar-container {\n  @if $global-flexbox {\n    display: flex;\n    flex-wrap: nowrap;\n    justify-content: space-between;\n    align-items: center;\n  }\n  @else {\n    @include clearfix;\n  }\n\n  padding: $topbar-padding;\n\n  &,\n  ul {\n    background-color: $topbar-background;\n  }\n\n  // Check if $topbar-background is differnt from $topbar-background-submenu\n  @if ($topbar-background != $topbar-submenu-background) {\n    ul ul {\n      background-color: $topbar-submenu-background;\n    }\n  }\n\n  // Restrain width of inputs by default to make them easier to arrange\n  input {\n    max-width: $topbar-input-width;\n    margin-#{$global-right}: 1rem;\n  }\n\n  // The above styles shouldn't apply to input group fields\n  .input-group-field {\n    width: 100%;\n    margin-#{$global-right}: 0;\n  }\n\n  input.button { // sass-lint:disable-line no-qualifying-elements\n    width: auto;\n  }\n}\n\n/// Makes sections of a top bar stack on top of each other.\n@mixin top-bar-stacked {\n  @if $global-flexbox {\n    flex-wrap: wrap;\n\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 100%;\n      max-width: 100%;\n    }\n  }\n  @else {\n    // Sub-sections\n    .top-bar-left,\n    .top-bar-right {\n      width: 100%;\n    }\n  }\n}\n\n/// Undoes the CSS applied by the `top-bar-stacked()` mixin.\n@mixin top-bar-unstack {\n  @if $global-flexbox {\n    flex-wrap: nowrap;\n\n    .top-bar-left {\n      flex: 1 1 auto;\n      margin-right: auto;\n    }\n\n    .top-bar-right {\n      flex: 0 1 auto;\n      margin-left: auto;\n    }\n  }\n  @else {\n    .top-bar-left,\n    .top-bar-right {\n      width: auto;\n    }\n  }\n}\n\n@mixin foundation-top-bar {\n  // Top bar container\n  .top-bar {\n    @include top-bar-container;\n\n    // Stack on small screens by default\n    @include top-bar-stacked;\n\n    @include breakpoint($topbar-unstack-breakpoint) {\n      @include top-bar-unstack;\n    }\n\n    // Generate classes for stacking on each screen size (defined in $breakpoint-classes)\n    @each $size in $breakpoint-classes {\n      @if $size != $-zf-zero-breakpoint {\n        &.stacked-for-#{$size} {\n          @include breakpoint($size down) {\n            @include top-bar-stacked;\n          }\n        }\n      }\n    }\n  }\n\n  // Sub-sections\n  @if $global-flexbox {\n    .top-bar-title {\n      flex: 0 0 auto;\n      margin: $topbar-title-spacing;\n    }\n\n    .top-bar-left,\n    .top-bar-right {\n      flex: 0 0 auto;\n    }\n  }\n  @else {\n    .top-bar-title {\n      display: inline-block;\n      float: left;\n      padding: $topbar-title-spacing;\n\n      .menu-icon {\n        bottom: 2px;\n      }\n    }\n\n    .top-bar-left {\n      float: left;\n    }\n\n    .top-bar-right {\n      float: right;\n    }\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group float\n////\n\n@mixin foundation-float-classes {\n  .float-left {\n    float: left !important;\n  }\n\n  .float-right {\n    float: right !important;\n  }\n\n  .float-center {\n    display: block;\n    margin-right: auto;\n    margin-left: auto;\n  }\n\n  .clearfix {\n    @include clearfix;\n  }\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n////\n/// @group Flexbox Utilities\n////\n//\n/// Default value for the count of source ordering`\n/// @type Number\n$flex-source-ordering-count: 6 !default;\n\n/// Quickly disable/enable Responsive breakpoints for Vanilla Flex Helpers.\n/// @type Boolean\n$flexbox-responsive-breakpoints: true !default;\n\n@mixin flex-helpers {\n  .flex-container {\n    @include flex;\n  }\n\n  .flex-child-auto {\n    flex: 1 1 auto;\n  }\n\n  .flex-child-grow {\n    flex: 1 0 auto;\n  }\n\n  .flex-child-shrink {\n    flex: 0 1 auto;\n  }\n\n  @each $dir, $prop in $-zf-flex-direction {\n    .flex-dir-#{$dir} {\n      @include flex-direction($prop);\n    }\n  }\n\n  @if ($flexbox-responsive-breakpoints) {\n    // Loop through Responsive Breakpoints\n    @each $size in $breakpoint-classes {\n      @include breakpoint($size) {\n        @if $size != $-zf-zero-breakpoint {\n          .#{$size}-flex-container {\n            @include flex;\n          }\n\n          .#{$size}-flex-child-auto {\n            flex: 1 1 auto;\n          }\n\n          .#{$size}-flex-child-grow {\n            flex: 1 0 auto;\n          }\n\n          .#{$size}-flex-child-shrink {\n            flex: 0 1 auto;\n          }\n\n          @each $dir, $prop in $-zf-flex-direction {\n            .#{$size}-flex-dir-#{$dir} {\n              @include flex-direction($prop);\n            }\n          }\n        }\n      }\n    }\n  }\n}\n\n@mixin foundation-flex-classes {\n  // Horizontal alignment using justify-content\n  @each $hdir, $prop in $-zf-flex-justify {\n    .align-#{$hdir} {\n      @include flex-align($x: $hdir);\n    }\n  }\n  \n  // Horizontal alignment Specifically for Vertical Menu\n  @each $hdir, $prop in map-remove($-zf-flex-justify, 'justify', 'spaced') {\n    .align-#{$hdir} {\n      &.vertical {\n        &.menu > li > a {\n          @include flex-align($x: $hdir);\n        }\n      }\n    }\n  }\n\n  // Vertical alignment using align-items and align-self\n  @each $vdir, $prop in $-zf-flex-align {\n    .align-#{$vdir} {\n      @include flex-align($y: $vdir);\n    }\n\n    .align-self-#{$vdir} {\n      @include flex-align-self($y: $vdir);\n    }\n  }\n\n  // Central alignment of content\n  .align-center-middle {\n    @include flex-align($x: center, $y: middle);\n    align-content: center;\n  }\n\n  // Source ordering\n  @include -zf-each-breakpoint {\n    @for $i from 1 through $flex-source-ordering-count {\n      .#{$-zf-size}-order-#{$i} {\n        @include flex-order($i);\n      }\n    }\n  }\n\n  // Vanilla Flexbox Helpers\n  @include flex-helpers;\n}\n","@function -zf-flex-justify($text-direction){\n  $-zf-flex-justify: (\n    'left': if($text-direction == rtl, flex-end, flex-start),\n    'right': if($text-direction == rtl, flex-start, flex-end),\n    'center': center,\n    'justify': space-between,\n    'spaced': space-around,\n  );\n\n  @return $-zf-flex-justify;\n}\n\n\n$-zf-flex-align: (\n  'top': flex-start,\n  'bottom': flex-end,\n  'middle': center,\n  'stretch': stretch,\n);\n\n$-zf-flex-direction: (\n  'row': row,\n  'row-reverse': row-reverse,\n  'column': column,\n  'column-reverse': column-reverse,\n);\n\n/// Enables flexbox by adding `display: flex` to the element.\n@mixin flex {\n  display: flex;\n}\n\n/// Horizontally or vertically aligns the items within a flex container.\n///\n/// @param {Keyword} $x [null] - Horizontal alignment to use. Can be `left`, `right`, `center`, `justify`, or `spaced`. Or, set it to `null` (the default) to not set horizontal alignment.\n/// @param {Keyword} $y [null] - Vertical alignment to use. Can be `top`, `bottom`, `middle`, or `stretch`. Or, set it to `null` (the default) to not set vertical alignment.\n@mixin flex-align($x: null, $y: null) {\n  @if $x {\n    @if map-has-key($-zf-flex-justify, $x) {\n      $x: map-get($-zf-flex-justify, $x);\n    }\n    @else {\n      @warn 'flex-grid-row-align(): #{$x} is not a valid value for horizontal alignment. Use left, right, center, justify, or spaced.';\n    }\n  }\n\n  @if $y {\n    @if map-has-key($-zf-flex-align, $y) {\n      $y: map-get($-zf-flex-align, $y);\n    }\n    @else {\n      @warn 'flex-grid-row-align(): #{$y} is not a valid value for vertical alignment. Use top, bottom, middle, or stretch.';\n    }\n  }\n\n  justify-content: $x;\n  align-items: $y;\n}\n\n/// Vertically align a single column within a flex row. Apply this mixin to a flex column.\n///\n/// @param {Keyword} $y [null] - Vertical alignment to use. Can be `top`, `bottom`, `middle`, or `stretch`. Or, set it to `null` (the default) to not set vertical alignment.\n@mixin flex-align-self($y: null) {\n  @if $y {\n    @if map-has-key($-zf-flex-align, $y) {\n      $y: map-get($-zf-flex-align, $y);\n    }\n    @else {\n      @warn 'flex-grid-column-align(): #{$y} is not a valid value for alignment. Use top, bottom, middle, or stretch.';\n    }\n  }\n\n  align-self: $y;\n}\n\n/// Changes the source order of a flex child. Children with lower numbers appear first in the layout.\n/// @param {Number} $order [0] - Order number to apply.\n@mixin flex-order($order: 0) {\n  order: $order;\n}\n\n/// Change flex-direction\n/// @param {Keyword} $direction [row] - Flex direction to use. Can be\n///   - row (default): same as text direction\n///   - row-reverse: opposite to text direction\n///   - column: same as row but top to bottom\n///   - column-reverse: same as row-reverse top to bottom\n@mixin flex-direction($direction: row) {\n  flex-direction: $direction;\n}\n","// Foundation for Sites by ZURB\n// foundation.zurb.com\n// Licensed under MIT Open Source\n\n/// Hide an element by default, only displaying it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for($size) {\n  $size: map-get($breakpoints, $size);\n  // Max value is 0.2px under the next breakpoint (0.02 / 16 = 0.00125).\n  // Use a precision under 1px to support browser zoom, but not to low to avoid rounding.\n  // See https://github.com/zurb/foundation-sites/issues/11313\n  $size: -zf-bp-to-em($size) - .00125;\n\n  @include breakpoint($size down) {\n    display: none !important;\n  }\n}\n\n/// Hide an element by default, only displaying it within a certain breakpoint.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin show-for-only($size) {\n  $lower-bound-size: map-get($breakpoints, $size);\n  $upper-bound-size: -zf-map-next($breakpoints, $size);\n\n  // more often than not this will be correct, just one time round the loop it won't so set in scope here\n  $lower-bound: -zf-bp-to-em($lower-bound-size) - .00125;\n  // test actual lower-bound-size, if 0 set it to 0em\n  @if strip-unit($lower-bound-size) == 0 {\n    $lower-bound: -zf-bp-to-em($lower-bound-size);\n  }\n\n  @if $upper-bound-size == null {\n    @media screen and (max-width: $lower-bound) {\n      display: none !important;\n    }\n  }\n  @else {\n    $upper-bound: -zf-bp-to-em($upper-bound-size);\n\n    @media screen and (max-width: $lower-bound), screen and (min-width: $upper-bound) {\n      display: none !important;\n    }\n  }\n}\n\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for($size) {\n  @include breakpoint($size) {\n    display: none !important;\n  }\n}\n\n/// Show an element by default, and hide it above a certain screen size.\n/// @param {Keyword} $size - Breakpoint to use. **Must be a breakpoint defined in `$breakpoints`.**\n@mixin hide-for-only($size) {\n  @include breakpoint($size only) {\n    display: none !important;\n  }\n}\n\n@mixin foundation-visibility-classes {\n  // Basic hiding classes\n  .hide {\n    display: none !important;\n  }\n\n  .invisible {\n    visibility: hidden;\n  }\n\n  // Responsive visibility classes\n  @each $size in $breakpoint-classes {\n    @if $size != $-zf-zero-breakpoint {\n      .hide-for-#{$size} {\n        @include hide-for($size);\n      }\n\n      .show-for-#{$size} {\n        @include show-for($size);\n      }\n    }\n\n    .hide-for-#{$size}-only {\n      @include hide-for-only($size);\n    }\n\n    .show-for-#{$size}-only {\n      @include show-for-only($size);\n    }\n  }\n\n  // Screen reader visibility classes\n  // Need a \"hide-for-sr\" class? Add aria-hidden='true' to the element\n  .show-for-sr,\n  .show-on-focus {\n    @include element-invisible;\n  }\n\n  // Only display the element when it's focused\n  .show-on-focus {\n    &:active,\n    &:focus {\n      @include element-invisible-off;\n    }\n  }\n\n  // Landscape and portrait visibility\n  .show-for-landscape,\n  .hide-for-portrait {\n    display: block !important;\n\n    @include breakpoint(landscape) {\n      display: block !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: none !important;\n    }\n  }\n\n  .hide-for-landscape,\n  .show-for-portrait {\n    display: none !important;\n\n    @include breakpoint(landscape) {\n      display: none !important;\n    }\n\n    @include breakpoint(portrait) {\n      display: block !important;\n    }\n  }\n}\n"]}
\ No newline at end of file
index 711f3a52942bcf1a074b8a507b56e208acab32b3..5a6c7f1e5dd6724276ac630cb3c2ea96df01cc0b 100644 (file)
@@ -1 +1,2 @@
-@charset "UTF-8";@media print,screen and (min-width:40em){.reveal,.reveal.large,.reveal.small,.reveal.tiny{right:auto;left:auto;margin:0 auto}}/*! normalize-scss | MIT/GPLv2 License | bit.ly/normalize-scss */html{font-family:sans-serif;line-height:1.15;-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%}body{margin:0}article,aside,footer,header,nav,section{display:block}h1{font-size:2em;margin:.67em 0}figcaption,figure{display:block}figure{margin:1em 40px}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}main{display:block}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent;-webkit-text-decoration-skip:objects}a:active,a:hover{outline-width:0}abbr[title]{border-bottom:none;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:inherit}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}dfn{font-style:italic}mark{background-color:#ff0;color:#000}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}audio,video{display:inline-block}audio:not([controls]){display:none;height:0}img{border-style:none}svg:not(:root){overflow:hidden}button,input,optgroup,select,textarea{font-family:sans-serif;font-size:100%;line-height:1.15;margin:0}button{overflow:visible}button,select{text-transform:none}[type=reset],[type=submit],button,html [type=button]{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}input{overflow:visible}[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-cancel-button,[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}fieldset{border:1px solid silver;margin:0 2px;padding:.35em .625em .75em}legend{-webkit-box-sizing:border-box;box-sizing:border-box;display:table;max-width:100%;padding:0;color:inherit;white-space:normal}progress{display:inline-block;vertical-align:baseline}textarea{overflow:auto}details{display:block}summary{display:list-item}menu{display:block}canvas{display:inline-block}template{display:none}[hidden]{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{-webkit-box-sizing:border-box;box-sizing:border-box;font-size:100%}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;padding:0;background:#fefefe;font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle;max-width:100%;height:auto;-ms-interpolation-mode:bicubic}textarea{height:auto;min-height:50px;border-radius:0}select{-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;border-radius:0}.map_canvas embed,.map_canvas img,.map_canvas object,.mqa-display embed,.mqa-display img,.mqa-display object{max-width:none!important}button{padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:0;background:0 0;line-height:1;cursor:auto}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}button,input,optgroup,select,textarea{font-family:inherit}.is-visible{display:block!important}.is-hidden{display:none!important}.grid-container{padding-right:.625rem;padding-left:.625rem;max-width:75rem;margin:0 auto}@media print,screen and (min-width:40em){.grid-container{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.fluid{padding-right:.625rem;padding-left:.625rem;max-width:100%;margin:0 auto}@media print,screen and (min-width:40em){.grid-container.fluid{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.full{padding-right:0;padding-left:0;max-width:100%;margin:0 auto}.grid-x{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row wrap;-ms-flex-flow:row wrap;flex-flow:row wrap}.cell{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;min-height:0;min-width:0;width:100%}.cell.auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.cell.shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.auto{width:auto}.grid-x>.shrink{width:auto}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9,.grid-x>.small-full,.grid-x>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-full,.grid-x>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-full,.grid-x>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-x>.small-1{width:8.33333%}.grid-x>.small-2{width:16.66667%}.grid-x>.small-3{width:25%}.grid-x>.small-4{width:33.33333%}.grid-x>.small-5{width:41.66667%}.grid-x>.small-6{width:50%}.grid-x>.small-7{width:58.33333%}.grid-x>.small-8{width:66.66667%}.grid-x>.small-9{width:75%}.grid-x>.small-10{width:83.33333%}.grid-x>.small-11{width:91.66667%}.grid-x>.small-12{width:100%}@media print,screen and (min-width:40em){.grid-x>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;width:auto}.grid-x>.medium-1{width:8.33333%}.grid-x>.medium-2{width:16.66667%}.grid-x>.medium-3{width:25%}.grid-x>.medium-4{width:33.33333%}.grid-x>.medium-5{width:41.66667%}.grid-x>.medium-6{width:50%}.grid-x>.medium-7{width:58.33333%}.grid-x>.medium-8{width:66.66667%}.grid-x>.medium-9{width:75%}.grid-x>.medium-10{width:83.33333%}.grid-x>.medium-11{width:91.66667%}.grid-x>.medium-12{width:100%}}@media print,screen and (min-width:64em){.grid-x>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;width:auto}.grid-x>.large-1{width:8.33333%}.grid-x>.large-2{width:16.66667%}.grid-x>.large-3{width:25%}.grid-x>.large-4{width:33.33333%}.grid-x>.large-5{width:41.66667%}.grid-x>.large-6{width:50%}.grid-x>.large-7{width:58.33333%}.grid-x>.large-8{width:66.66667%}.grid-x>.large-9{width:75%}.grid-x>.large-10{width:83.33333%}.grid-x>.large-11{width:91.66667%}.grid-x>.large-12{width:100%}}.grid-margin-x:not(.grid-x)>.cell{width:auto}.grid-margin-y:not(.grid-y)>.cell{height:auto}.grid-margin-x{margin-left:-.625rem;margin-right:-.625rem}@media print,screen and (min-width:40em){.grid-margin-x{margin-left:-.9375rem;margin-right:-.9375rem}}.grid-margin-x>.cell{width:calc(100% - 1.25rem);margin-left:.625rem;margin-right:.625rem}@media print,screen and (min-width:40em){.grid-margin-x>.cell{width:calc(100% - 1.875rem);margin-left:.9375rem;margin-right:.9375rem}}.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.25rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.25rem)}.grid-margin-x>.small-3{width:calc(25% - 1.25rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.25rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.25rem)}.grid-margin-x>.small-6{width:calc(50% - 1.25rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.25rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.25rem)}.grid-margin-x>.small-9{width:calc(75% - 1.25rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.25rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.25rem)}.grid-margin-x>.small-12{width:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.small-3{width:calc(25% - 1.875rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.small-6{width:calc(50% - 1.875rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.small-9{width:calc(75% - 1.875rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.small-12{width:calc(100% - 1.875rem)}.grid-margin-x>.medium-auto{width:auto}.grid-margin-x>.medium-shrink{width:auto}.grid-margin-x>.medium-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.medium-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.medium-3{width:calc(25% - 1.875rem)}.grid-margin-x>.medium-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.medium-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.medium-6{width:calc(50% - 1.875rem)}.grid-margin-x>.medium-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.medium-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.medium-9{width:calc(75% - 1.875rem)}.grid-margin-x>.medium-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.medium-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.medium-12{width:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x>.large-auto{width:auto}.grid-margin-x>.large-shrink{width:auto}.grid-margin-x>.large-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.large-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.large-3{width:calc(25% - 1.875rem)}.grid-margin-x>.large-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.large-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.large-6{width:calc(50% - 1.875rem)}.grid-margin-x>.large-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.large-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.large-9{width:calc(75% - 1.875rem)}.grid-margin-x>.large-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.large-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.large-12{width:calc(100% - 1.875rem)}}.grid-padding-x .grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-padding-x .grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-container:not(.full)>.grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-container:not(.full)>.grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-padding-x>.cell{padding-right:.625rem;padding-left:.625rem}@media print,screen and (min-width:40em){.grid-padding-x>.cell{padding-right:.9375rem;padding-left:.9375rem}}.small-up-1>.cell{width:100%}.small-up-2>.cell{width:50%}.small-up-3>.cell{width:33.33333%}.small-up-4>.cell{width:25%}.small-up-5>.cell{width:20%}.small-up-6>.cell{width:16.66667%}.small-up-7>.cell{width:14.28571%}.small-up-8>.cell{width:12.5%}@media print,screen and (min-width:40em){.medium-up-1>.cell{width:100%}.medium-up-2>.cell{width:50%}.medium-up-3>.cell{width:33.33333%}.medium-up-4>.cell{width:25%}.medium-up-5>.cell{width:20%}.medium-up-6>.cell{width:16.66667%}.medium-up-7>.cell{width:14.28571%}.medium-up-8>.cell{width:12.5%}}@media print,screen and (min-width:64em){.large-up-1>.cell{width:100%}.large-up-2>.cell{width:50%}.large-up-3>.cell{width:33.33333%}.large-up-4>.cell{width:25%}.large-up-5>.cell{width:20%}.large-up-6>.cell{width:16.66667%}.large-up-7>.cell{width:14.28571%}.large-up-8>.cell{width:12.5%}}.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}.grid-margin-x.medium-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.medium-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.medium-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.medium-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.medium-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.medium-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.medium-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.medium-up-8>.cell{width:calc(12.5% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x.large-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.large-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.large-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.large-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.large-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.large-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.large-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.large-up-8>.cell{width:calc(12.5% - 1.875rem)}}.small-margin-collapse{margin-right:0;margin-left:0}.small-margin-collapse>.cell{margin-right:0;margin-left:0}.small-margin-collapse>.small-1{width:8.33333%}.small-margin-collapse>.small-2{width:16.66667%}.small-margin-collapse>.small-3{width:25%}.small-margin-collapse>.small-4{width:33.33333%}.small-margin-collapse>.small-5{width:41.66667%}.small-margin-collapse>.small-6{width:50%}.small-margin-collapse>.small-7{width:58.33333%}.small-margin-collapse>.small-8{width:66.66667%}.small-margin-collapse>.small-9{width:75%}.small-margin-collapse>.small-10{width:83.33333%}.small-margin-collapse>.small-11{width:91.66667%}.small-margin-collapse>.small-12{width:100%}@media print,screen and (min-width:40em){.small-margin-collapse>.medium-1{width:8.33333%}.small-margin-collapse>.medium-2{width:16.66667%}.small-margin-collapse>.medium-3{width:25%}.small-margin-collapse>.medium-4{width:33.33333%}.small-margin-collapse>.medium-5{width:41.66667%}.small-margin-collapse>.medium-6{width:50%}.small-margin-collapse>.medium-7{width:58.33333%}.small-margin-collapse>.medium-8{width:66.66667%}.small-margin-collapse>.medium-9{width:75%}.small-margin-collapse>.medium-10{width:83.33333%}.small-margin-collapse>.medium-11{width:91.66667%}.small-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.small-margin-collapse>.large-1{width:8.33333%}.small-margin-collapse>.large-2{width:16.66667%}.small-margin-collapse>.large-3{width:25%}.small-margin-collapse>.large-4{width:33.33333%}.small-margin-collapse>.large-5{width:41.66667%}.small-margin-collapse>.large-6{width:50%}.small-margin-collapse>.large-7{width:58.33333%}.small-margin-collapse>.large-8{width:66.66667%}.small-margin-collapse>.large-9{width:75%}.small-margin-collapse>.large-10{width:83.33333%}.small-margin-collapse>.large-11{width:91.66667%}.small-margin-collapse>.large-12{width:100%}}.small-padding-collapse{margin-right:0;margin-left:0}.small-padding-collapse>.cell{padding-right:0;padding-left:0}@media print,screen and (min-width:40em){.medium-margin-collapse{margin-right:0;margin-left:0}.medium-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:40em){.medium-margin-collapse>.small-1{width:8.33333%}.medium-margin-collapse>.small-2{width:16.66667%}.medium-margin-collapse>.small-3{width:25%}.medium-margin-collapse>.small-4{width:33.33333%}.medium-margin-collapse>.small-5{width:41.66667%}.medium-margin-collapse>.small-6{width:50%}.medium-margin-collapse>.small-7{width:58.33333%}.medium-margin-collapse>.small-8{width:66.66667%}.medium-margin-collapse>.small-9{width:75%}.medium-margin-collapse>.small-10{width:83.33333%}.medium-margin-collapse>.small-11{width:91.66667%}.medium-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:40em){.medium-margin-collapse>.medium-1{width:8.33333%}.medium-margin-collapse>.medium-2{width:16.66667%}.medium-margin-collapse>.medium-3{width:25%}.medium-margin-collapse>.medium-4{width:33.33333%}.medium-margin-collapse>.medium-5{width:41.66667%}.medium-margin-collapse>.medium-6{width:50%}.medium-margin-collapse>.medium-7{width:58.33333%}.medium-margin-collapse>.medium-8{width:66.66667%}.medium-margin-collapse>.medium-9{width:75%}.medium-margin-collapse>.medium-10{width:83.33333%}.medium-margin-collapse>.medium-11{width:91.66667%}.medium-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.medium-margin-collapse>.large-1{width:8.33333%}.medium-margin-collapse>.large-2{width:16.66667%}.medium-margin-collapse>.large-3{width:25%}.medium-margin-collapse>.large-4{width:33.33333%}.medium-margin-collapse>.large-5{width:41.66667%}.medium-margin-collapse>.large-6{width:50%}.medium-margin-collapse>.large-7{width:58.33333%}.medium-margin-collapse>.large-8{width:66.66667%}.medium-margin-collapse>.large-9{width:75%}.medium-margin-collapse>.large-10{width:83.33333%}.medium-margin-collapse>.large-11{width:91.66667%}.medium-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:40em){.medium-padding-collapse{margin-right:0;margin-left:0}.medium-padding-collapse>.cell{padding-right:0;padding-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse{margin-right:0;margin-left:0}.large-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse>.small-1{width:8.33333%}.large-margin-collapse>.small-2{width:16.66667%}.large-margin-collapse>.small-3{width:25%}.large-margin-collapse>.small-4{width:33.33333%}.large-margin-collapse>.small-5{width:41.66667%}.large-margin-collapse>.small-6{width:50%}.large-margin-collapse>.small-7{width:58.33333%}.large-margin-collapse>.small-8{width:66.66667%}.large-margin-collapse>.small-9{width:75%}.large-margin-collapse>.small-10{width:83.33333%}.large-margin-collapse>.small-11{width:91.66667%}.large-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.medium-1{width:8.33333%}.large-margin-collapse>.medium-2{width:16.66667%}.large-margin-collapse>.medium-3{width:25%}.large-margin-collapse>.medium-4{width:33.33333%}.large-margin-collapse>.medium-5{width:41.66667%}.large-margin-collapse>.medium-6{width:50%}.large-margin-collapse>.medium-7{width:58.33333%}.large-margin-collapse>.medium-8{width:66.66667%}.large-margin-collapse>.medium-9{width:75%}.large-margin-collapse>.medium-10{width:83.33333%}.large-margin-collapse>.medium-11{width:91.66667%}.large-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.large-1{width:8.33333%}.large-margin-collapse>.large-2{width:16.66667%}.large-margin-collapse>.large-3{width:25%}.large-margin-collapse>.large-4{width:33.33333%}.large-margin-collapse>.large-5{width:41.66667%}.large-margin-collapse>.large-6{width:50%}.large-margin-collapse>.large-7{width:58.33333%}.large-margin-collapse>.large-8{width:66.66667%}.large-margin-collapse>.large-9{width:75%}.large-margin-collapse>.large-10{width:83.33333%}.large-margin-collapse>.large-11{width:91.66667%}.large-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:64em){.large-padding-collapse{margin-right:0;margin-left:0}.large-padding-collapse>.cell{padding-right:0;padding-left:0}}.small-offset-0{margin-left:0}.grid-margin-x>.small-offset-0{margin-left:calc(0% + .625rem)}.small-offset-1{margin-left:8.33333%}.grid-margin-x>.small-offset-1{margin-left:calc(8.33333% + .625rem)}.small-offset-2{margin-left:16.66667%}.grid-margin-x>.small-offset-2{margin-left:calc(16.66667% + .625rem)}.small-offset-3{margin-left:25%}.grid-margin-x>.small-offset-3{margin-left:calc(25% + .625rem)}.small-offset-4{margin-left:33.33333%}.grid-margin-x>.small-offset-4{margin-left:calc(33.33333% + .625rem)}.small-offset-5{margin-left:41.66667%}.grid-margin-x>.small-offset-5{margin-left:calc(41.66667% + .625rem)}.small-offset-6{margin-left:50%}.grid-margin-x>.small-offset-6{margin-left:calc(50% + .625rem)}.small-offset-7{margin-left:58.33333%}.grid-margin-x>.small-offset-7{margin-left:calc(58.33333% + .625rem)}.small-offset-8{margin-left:66.66667%}.grid-margin-x>.small-offset-8{margin-left:calc(66.66667% + .625rem)}.small-offset-9{margin-left:75%}.grid-margin-x>.small-offset-9{margin-left:calc(75% + .625rem)}.small-offset-10{margin-left:83.33333%}.grid-margin-x>.small-offset-10{margin-left:calc(83.33333% + .625rem)}.small-offset-11{margin-left:91.66667%}.grid-margin-x>.small-offset-11{margin-left:calc(91.66667% + .625rem)}@media print,screen and (min-width:40em){.medium-offset-0{margin-left:0}.grid-margin-x>.medium-offset-0{margin-left:calc(0% + .9375rem)}.medium-offset-1{margin-left:8.33333%}.grid-margin-x>.medium-offset-1{margin-left:calc(8.33333% + .9375rem)}.medium-offset-2{margin-left:16.66667%}.grid-margin-x>.medium-offset-2{margin-left:calc(16.66667% + .9375rem)}.medium-offset-3{margin-left:25%}.grid-margin-x>.medium-offset-3{margin-left:calc(25% + .9375rem)}.medium-offset-4{margin-left:33.33333%}.grid-margin-x>.medium-offset-4{margin-left:calc(33.33333% + .9375rem)}.medium-offset-5{margin-left:41.66667%}.grid-margin-x>.medium-offset-5{margin-left:calc(41.66667% + .9375rem)}.medium-offset-6{margin-left:50%}.grid-margin-x>.medium-offset-6{margin-left:calc(50% + .9375rem)}.medium-offset-7{margin-left:58.33333%}.grid-margin-x>.medium-offset-7{margin-left:calc(58.33333% + .9375rem)}.medium-offset-8{margin-left:66.66667%}.grid-margin-x>.medium-offset-8{margin-left:calc(66.66667% + .9375rem)}.medium-offset-9{margin-left:75%}.grid-margin-x>.medium-offset-9{margin-left:calc(75% + .9375rem)}.medium-offset-10{margin-left:83.33333%}.grid-margin-x>.medium-offset-10{margin-left:calc(83.33333% + .9375rem)}.medium-offset-11{margin-left:91.66667%}.grid-margin-x>.medium-offset-11{margin-left:calc(91.66667% + .9375rem)}}@media print,screen and (min-width:64em){.large-offset-0{margin-left:0}.grid-margin-x>.large-offset-0{margin-left:calc(0% + .9375rem)}.large-offset-1{margin-left:8.33333%}.grid-margin-x>.large-offset-1{margin-left:calc(8.33333% + .9375rem)}.large-offset-2{margin-left:16.66667%}.grid-margin-x>.large-offset-2{margin-left:calc(16.66667% + .9375rem)}.large-offset-3{margin-left:25%}.grid-margin-x>.large-offset-3{margin-left:calc(25% + .9375rem)}.large-offset-4{margin-left:33.33333%}.grid-margin-x>.large-offset-4{margin-left:calc(33.33333% + .9375rem)}.large-offset-5{margin-left:41.66667%}.grid-margin-x>.large-offset-5{margin-left:calc(41.66667% + .9375rem)}.large-offset-6{margin-left:50%}.grid-margin-x>.large-offset-6{margin-left:calc(50% + .9375rem)}.large-offset-7{margin-left:58.33333%}.grid-margin-x>.large-offset-7{margin-left:calc(58.33333% + .9375rem)}.large-offset-8{margin-left:66.66667%}.grid-margin-x>.large-offset-8{margin-left:calc(66.66667% + .9375rem)}.large-offset-9{margin-left:75%}.grid-margin-x>.large-offset-9{margin-left:calc(75% + .9375rem)}.large-offset-10{margin-left:83.33333%}.grid-margin-x>.large-offset-10{margin-left:calc(83.33333% + .9375rem)}.large-offset-11{margin-left:91.66667%}.grid-margin-x>.large-offset-11{margin-left:calc(91.66667% + .9375rem)}}.grid-y{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.grid-y>.cell{width:auto}.grid-y>.auto{height:auto}.grid-y>.shrink{height:auto}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9,.grid-y>.small-full,.grid-y>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-full,.grid-y>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-full,.grid-y>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-y>.small-1{height:8.33333%}.grid-y>.small-2{height:16.66667%}.grid-y>.small-3{height:25%}.grid-y>.small-4{height:33.33333%}.grid-y>.small-5{height:41.66667%}.grid-y>.small-6{height:50%}.grid-y>.small-7{height:58.33333%}.grid-y>.small-8{height:66.66667%}.grid-y>.small-9{height:75%}.grid-y>.small-10{height:83.33333%}.grid-y>.small-11{height:91.66667%}.grid-y>.small-12{height:100%}@media print,screen and (min-width:40em){.grid-y>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.medium-shrink{height:auto}.grid-y>.medium-1{height:8.33333%}.grid-y>.medium-2{height:16.66667%}.grid-y>.medium-3{height:25%}.grid-y>.medium-4{height:33.33333%}.grid-y>.medium-5{height:41.66667%}.grid-y>.medium-6{height:50%}.grid-y>.medium-7{height:58.33333%}.grid-y>.medium-8{height:66.66667%}.grid-y>.medium-9{height:75%}.grid-y>.medium-10{height:83.33333%}.grid-y>.medium-11{height:91.66667%}.grid-y>.medium-12{height:100%}}@media print,screen and (min-width:64em){.grid-y>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.large-shrink{height:auto}.grid-y>.large-1{height:8.33333%}.grid-y>.large-2{height:16.66667%}.grid-y>.large-3{height:25%}.grid-y>.large-4{height:33.33333%}.grid-y>.large-5{height:41.66667%}.grid-y>.large-6{height:50%}.grid-y>.large-7{height:58.33333%}.grid-y>.large-8{height:66.66667%}.grid-y>.large-9{height:75%}.grid-y>.large-10{height:83.33333%}.grid-y>.large-11{height:91.66667%}.grid-y>.large-12{height:100%}}.grid-padding-y .grid-padding-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-padding-y .grid-padding-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-padding-y>.cell{padding-top:.625rem;padding-bottom:.625rem}@media print,screen and (min-width:40em){.grid-padding-y>.cell{padding-top:.9375rem;padding-bottom:.9375rem}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .grid-frame{width:100%}.cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.cell-block-container{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;max-height:100%}.cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}@media print,screen and (min-width:40em){.medium-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .medium-grid-frame{width:100%}.medium-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.medium-cell-block-container{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;max-height:100%}.medium-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.medium-cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}}@media print,screen and (min-width:64em){.large-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .large-grid-frame{width:100%}.large-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}.large-cell-block-container{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;max-height:100%}.large-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.large-cell-block-y{overflow-y:auto;max-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-stype:-ms-autohiding-scrollbar}}.grid-y.grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}@media print,screen and (min-width:40em){.grid-y.medium-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}@media print,screen and (min-width:64em){.grid-y.large-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}.cell .grid-y.grid-frame{height:100%}@media print,screen and (min-width:40em){.cell .grid-y.medium-grid-frame{height:100%}}@media print,screen and (min-width:64em){.cell .grid-y.large-grid-frame{height:100%}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame.grid-margin-y{height:calc(100vh + 1.25rem)}@media print,screen and (min-width:40em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:40em){.grid-margin-y.medium-grid-frame{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y.large-grid-frame{height:calc(100vh + 1.875rem)}}blockquote,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,li,ol,p,pre,td,th,ul{margin:0;padding:0}p{margin-bottom:1rem;font-size:inherit;line-height:1.6;text-rendering:optimizeLegibility}em,i{font-style:italic;line-height:inherit}b,strong{font-weight:700;line-height:inherit}small{font-size:80%;line-height:inherit}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-style:normal;font-weight:400;color:inherit;text-rendering:optimizeLegibility}.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small,h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{line-height:0;color:#cacaca}.h1,h1{font-size:1.5rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h2,h2{font-size:1.25rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h3,h3{font-size:1.1875rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h4,h4{font-size:1.125rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h5,h5{font-size:1.0625rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h6,h6{font-size:1rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}@media print,screen and (min-width:40em){.h1,h1{font-size:3rem}.h2,h2{font-size:2.5rem}.h3,h3{font-size:1.9375rem}.h4,h4{font-size:1.5625rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}}a{line-height:inherit;color:#1779ba;text-decoration:none;cursor:pointer}a:focus,a:hover{color:#1468a0}a img{border:0}hr{clear:both;max-width:75rem;height:0;margin:1.25rem auto;border-top:0;border-right:0;border-bottom:1px solid #cacaca;border-left:0}dl,ol,ul{margin-bottom:1rem;list-style-position:outside;line-height:1.6}li{font-size:inherit}ul{margin-left:1.25rem;list-style-type:disc}ol{margin-left:1.25rem}ol ol,ol ul,ul ol,ul ul{margin-left:1.25rem;margin-bottom:0}dl{margin-bottom:1rem}dl dt{margin-bottom:.3rem;font-weight:700}blockquote{margin:0 0 1rem;padding:.5625rem 1.25rem 0 1.1875rem;border-left:1px solid #cacaca}blockquote,blockquote p{line-height:1.6;color:#8a8a8a}cite{display:block;font-size:.8125rem;color:#8a8a8a}cite:before{content:"— "}abbr,abbr[title]{border-bottom:1px dotted #0a0a0a;cursor:help;text-decoration:none}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:400;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;color:#0a0a0a}.subheader{margin-top:.2rem;margin-bottom:.5rem;font-weight:400;line-height:1.4;color:#8a8a8a}.lead{font-size:125%;line-height:1.6}.stat{font-size:2.5rem;line-height:1}p+.stat{margin-top:-1rem}ol.no-bullet,ul.no-bullet{margin-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}@media print,screen and (min-width:40em){.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}}@media print,screen and (min-width:64em){.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}}.show-for-print{display:none!important}@media print{*{background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}.show-for-print{display:block!important}.hide-for-print{display:none!important}table.show-for-print{display:table!important}thead.show-for-print{display:table-header-group!important}tbody.show-for-print{display:table-row-group!important}tr.show-for-print{display:table-row!important}td.show-for-print{display:table-cell!important}th.show-for-print{display:table-cell!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}.ir a:after,a[href^='#']:after,a[href^='javascript:']:after{content:''}abbr[title]:after{content:" (" attr(title) ")"}blockquote,pre{border:1px solid #8a8a8a;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.print-break-inside{page-break-inside:auto}}[type=color],[type=date],[type=datetime-local],[type=datetime],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],textarea{display:block;-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;height:2.4375rem;margin:0 0 1rem;padding:.5rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;-webkit-box-shadow:inset 0 1px 2px rgba(10,10,10,.1);box-shadow:inset 0 1px 2px rgba(10,10,10,.1);font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s;-webkit-appearance:none;-moz-appearance:none;appearance:none}[type=color]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=datetime]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,textarea:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}textarea{max-width:100%}textarea[rows]{height:auto}input::-webkit-input-placeholder,textarea::-webkit-input-placeholder{color:#cacaca}input:-ms-input-placeholder,textarea:-ms-input-placeholder{color:#cacaca}input::placeholder,textarea::placeholder{color:#cacaca}input:disabled,input[readonly],textarea:disabled,textarea[readonly]{background-color:#e6e6e6;cursor:not-allowed}[type=button],[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}input[type=search]{-webkit-box-sizing:border-box;box-sizing:border-box}[type=checkbox],[type=file],[type=radio]{margin:0 0 1rem}[type=checkbox]+label,[type=radio]+label{display:inline-block;vertical-align:baseline;margin-left:.5rem;margin-right:1rem;margin-bottom:0}[type=checkbox]+label[for],[type=radio]+label[for]{cursor:pointer}label>[type=checkbox],label>[type=radio]{margin-right:.5rem}[type=file]{width:100%}label{display:block;margin:0;font-size:.875rem;font-weight:400;line-height:1.8;color:#0a0a0a}label.middle{margin:0 0 1rem;padding:.5625rem 0}.help-text{margin-top:-.5rem;font-size:.8125rem;font-style:italic;color:#0a0a0a}.input-group{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;width:100%;margin-bottom:1rem;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.input-group>:first-child{border-radius:0}.input-group>:last-child>*{border-radius:0}.input-group-button,.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label,.input-group-field,.input-group-label{margin:0;white-space:nowrap}.input-group-label{padding:0 1rem;border:1px solid #cacaca;background:#e6e6e6;color:#0a0a0a;text-align:center;white-space:nowrap;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.input-group-label:first-child{border-right:0}.input-group-label:last-child{border-left:0}.input-group-field{border-radius:0;-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto;min-width:0}.input-group-button{padding-top:0;padding-bottom:0;text-align:center;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label{height:auto;-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;padding-top:0;padding-bottom:0;font-size:1rem}fieldset{margin:0;padding:0;border:0}legend{max-width:100%;margin-bottom:.5rem}.fieldset{margin:1.125rem 0;padding:1.25rem;border:1px solid #cacaca}.fieldset legend{margin:0;margin-left:-.1875rem;padding:0 .1875rem}select{height:2.4375rem;margin:0 0 1rem;padding:.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");-webkit-background-origin:content-box;background-origin:content-box;background-position:right -1rem center;background-repeat:no-repeat;-webkit-background-size:9px 6px;background-size:9px 6px;padding-right:1.5rem;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}@media screen and (min-width:0\0){select{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==)}}select:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}select:disabled{background-color:#e6e6e6;cursor:not-allowed}select::-ms-expand{display:none}select[multiple]{height:auto;background-image:none}.is-invalid-input:not(:focus){border-color:#cc4b37;background-color:#f9ecea}.is-invalid-input:not(:focus)::-webkit-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus):-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::placeholder{color:#cc4b37}.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700;color:#cc4b37}.form-error.is-visible{display:block}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem 0;font-family:inherit;padding:.85em 1em;-webkit-appearance:none;border:1px solid transparent;border-radius:0;-webkit-transition:background-color .25s ease-out,color .25s ease-out;transition:background-color .25s ease-out,color .25s ease-out;font-size:.9rem;line-height:1;text-align:center;cursor:pointer;background-color:#1779ba;color:#fefefe}[data-whatinput=mouse] .button{outline:0}.button:focus,.button:hover{background-color:#14679e;color:#fefefe}.button.tiny{font-size:.6rem}.button.small{font-size:.75rem}.button.large{font-size:1.25rem}.button.expanded{display:block;width:100%;margin-right:0;margin-left:0}.button.primary{background-color:#1779ba;color:#fefefe}.button.primary:focus,.button.primary:hover{background-color:#126195;color:#fefefe}.button.secondary{background-color:#767676;color:#fefefe}.button.secondary:focus,.button.secondary:hover{background-color:#5e5e5e;color:#fefefe}.button.success{background-color:#3adb76;color:#0a0a0a}.button.success:focus,.button.success:hover{background-color:#22bb5b;color:#0a0a0a}.button.warning{background-color:#ffae00;color:#0a0a0a}.button.warning:focus,.button.warning:hover{background-color:#cc8b00;color:#0a0a0a}.button.alert{background-color:#cc4b37;color:#fefefe}.button.alert:focus,.button.alert:hover{background-color:#a53b2a;color:#fefefe}.button.disabled,.button[disabled]{opacity:.25;cursor:not-allowed}.button.disabled,.button.disabled:focus,.button.disabled:hover,.button[disabled],.button[disabled]:focus,.button[disabled]:hover{background-color:#1779ba;color:#fefefe}.button.disabled.primary,.button[disabled].primary{opacity:.25;cursor:not-allowed}.button.disabled.primary,.button.disabled.primary:focus,.button.disabled.primary:hover,.button[disabled].primary,.button[disabled].primary:focus,.button[disabled].primary:hover{background-color:#1779ba;color:#fefefe}.button.disabled.secondary,.button[disabled].secondary{opacity:.25;cursor:not-allowed}.button.disabled.secondary,.button.disabled.secondary:focus,.button.disabled.secondary:hover,.button[disabled].secondary,.button[disabled].secondary:focus,.button[disabled].secondary:hover{background-color:#767676;color:#fefefe}.button.disabled.success,.button[disabled].success{opacity:.25;cursor:not-allowed}.button.disabled.success,.button.disabled.success:focus,.button.disabled.success:hover,.button[disabled].success,.button[disabled].success:focus,.button[disabled].success:hover{background-color:#3adb76;color:#0a0a0a}.button.disabled.warning,.button[disabled].warning{opacity:.25;cursor:not-allowed}.button.disabled.warning,.button.disabled.warning:focus,.button.disabled.warning:hover,.button[disabled].warning,.button[disabled].warning:focus,.button[disabled].warning:hover{background-color:#ffae00;color:#0a0a0a}.button.disabled.alert,.button[disabled].alert{opacity:.25;cursor:not-allowed}.button.disabled.alert,.button.disabled.alert:focus,.button.disabled.alert:hover,.button[disabled].alert,.button[disabled].alert:focus,.button[disabled].alert:hover{background-color:#cc4b37;color:#fefefe}.button.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow.disabled,.button.hollow.disabled:focus,.button.hollow.disabled:hover,.button.hollow[disabled],.button.hollow[disabled]:focus,.button.hollow[disabled]:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow:focus.disabled,.button.hollow:focus[disabled],.button.hollow:hover.disabled,.button.hollow:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary:focus.disabled,.button.hollow.primary:focus[disabled],.button.hollow.primary:hover.disabled,.button.hollow.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.secondary:focus.disabled,.button.hollow.secondary:focus[disabled],.button.hollow.secondary:hover.disabled,.button.hollow.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.success:focus.disabled,.button.hollow.success:focus[disabled],.button.hollow.success:hover.disabled,.button.hollow.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.warning:focus.disabled,.button.hollow.warning:focus[disabled],.button.hollow.warning:hover.disabled,.button.hollow.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.button.hollow.alert:focus.disabled,.button.hollow.alert:focus[disabled],.button.hollow.alert:hover.disabled,.button.hollow.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear:focus,.button.clear:hover{background-color:transparent}.button.clear.disabled,.button.clear.disabled:focus,.button.clear.disabled:hover,.button.clear[disabled],.button.clear[disabled]:focus,.button.clear[disabled]:hover{background-color:transparent}.button.clear:focus,.button.clear:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover.disabled,.button.clear:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear.disabled,.button.clear:focus,.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover,.button.clear:hover.disabled,.button.clear:hover[disabled],.button.clear[disabled]{border-color:transparent}.button.clear.primary{border:1px solid #1779ba;color:#1779ba}.button.clear.primary:focus,.button.clear.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear.primary,.button.clear.primary.disabled,.button.clear.primary:focus,.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover,.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled],.button.clear.primary[disabled]{border-color:transparent}.button.clear.secondary{border:1px solid #767676;color:#767676}.button.clear.secondary:focus,.button.clear.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.clear.secondary,.button.clear.secondary.disabled,.button.clear.secondary:focus,.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover,.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled],.button.clear.secondary[disabled]{border-color:transparent}.button.clear.success{border:1px solid #3adb76;color:#3adb76}.button.clear.success:focus,.button.clear.success:hover{border-color:#157539;color:#157539}.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover.disabled,.button.clear.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.clear.success,.button.clear.success.disabled,.button.clear.success:focus,.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover,.button.clear.success:hover.disabled,.button.clear.success:hover[disabled],.button.clear.success[disabled]{border-color:transparent}.button.clear.warning{border:1px solid #ffae00;color:#ffae00}.button.clear.warning:focus,.button.clear.warning:hover{border-color:#805700;color:#805700}.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.clear.warning,.button.clear.warning.disabled,.button.clear.warning:focus,.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover,.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled],.button.clear.warning[disabled]{border-color:transparent}.button.clear.alert{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert:focus,.button.clear.alert:hover{border-color:#67251a;color:#67251a}.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert,.button.clear.alert.disabled,.button.clear.alert:focus,.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover,.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled],.button.clear.alert[disabled]{border-color:transparent}.button.dropdown::after{display:block;width:0;height:0;border:inset .4em;content:'';border-bottom-width:0;border-top-style:solid;border-color:#fefefe transparent transparent;position:relative;top:.4em;display:inline-block;float:right;margin-left:1em}.button.dropdown.hollow::after{border-top-color:#1779ba}.button.dropdown.hollow.primary::after{border-top-color:#1779ba}.button.dropdown.hollow.secondary::after{border-top-color:#767676}.button.dropdown.hollow.success::after{border-top-color:#3adb76}.button.dropdown.hollow.warning::after{border-top-color:#ffae00}.button.dropdown.hollow.alert::after{border-top-color:#cc4b37}.button.arrow-only::after{top:-.1em;float:none;margin-left:0}a.button:focus,a.button:hover{text-decoration:none}.accordion{margin-left:0;background:#fefefe;list-style-type:none}.accordion[disabled] .accordion-title{cursor:not-allowed}.accordion-item:first-child>:first-child{border-radius:0}.accordion-item:last-child>:last-child{border-radius:0}.accordion-title{position:relative;display:block;padding:1.25rem 1rem;border:1px solid #e6e6e6;border-bottom:0;font-size:.75rem;line-height:1;color:#1779ba}:last-child:not(.is-active)>.accordion-title{border-bottom:1px solid #e6e6e6;border-radius:0}.accordion-title:focus,.accordion-title:hover{background-color:#e6e6e6}.accordion-title::before{position:absolute;top:50%;right:1rem;margin-top:-.5rem;content:'+'}.is-active>.accordion-title::before{content:'\2013'}.accordion-content{display:none;padding:1rem;border:1px solid #e6e6e6;border-bottom:0;background-color:#fefefe;color:#0a0a0a}:last-child>.accordion-content:last-child{border-bottom:1px solid #e6e6e6}.accordion-menu li{width:100%}.accordion-menu a{padding:.7rem 1rem}.accordion-menu .is-accordion-submenu a{padding:.7rem 1rem}.accordion-menu .nested.is-accordion-submenu{margin-right:0;margin-left:1rem}.accordion-menu.align-right .nested.is-accordion-submenu{margin-right:1rem;margin-left:0}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a{position:relative}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;right:1rem}.accordion-menu.align-left .is-accordion-submenu-parent>a::after{left:auto;right:1rem}.accordion-menu.align-right .is-accordion-submenu-parent>a::after{right:auto;left:1rem}.accordion-menu .is-accordion-submenu-parent[aria-expanded=true]>a::after{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.is-accordion-submenu-parent{position:relative}.has-submenu-toggle>a{margin-right:40px}.submenu-toggle{position:absolute;top:0;right:0;cursor:pointer;width:40px;height:40px}.submenu-toggle::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;top:0;bottom:0;margin:auto}.submenu-toggle[aria-expanded=true]::after{-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.submenu-toggle-text{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center;background:#1779ba;color:#fefefe}.badge.primary{background:#1779ba;color:#fefefe}.badge.secondary{background:#767676;color:#fefefe}.badge.success{background:#3adb76;color:#0a0a0a}.badge.warning{background:#ffae00;color:#0a0a0a}.badge.alert{background:#cc4b37;color:#fefefe}.breadcrumbs{margin:0 0 1rem 0;list-style:none}.breadcrumbs::after,.breadcrumbs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.breadcrumbs::after{clear:both}.breadcrumbs li{float:left;font-size:.6875rem;color:#0a0a0a;cursor:default;text-transform:uppercase}.breadcrumbs li:not(:last-child)::after{position:relative;margin:0 .75rem;opacity:1;content:"/";color:#cacaca}.breadcrumbs a{color:#1779ba}.breadcrumbs a:hover{text-decoration:underline}.breadcrumbs .disabled{color:#cacaca;cursor:not-allowed}.button-group{margin-bottom:1rem;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.button-group::after,.button-group::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.button-group::after{clear:both}.button-group .button{margin:0;margin-right:1px;margin-bottom:1px;font-size:.9rem;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.button-group .button:last-child{margin-right:0}.button-group.tiny .button{font-size:.6rem}.button-group.small .button{font-size:.75rem}.button-group.large .button{font-size:1.25rem}.button-group.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.button-group.primary .button{background-color:#1779ba;color:#fefefe}.button-group.primary .button:focus,.button-group.primary .button:hover{background-color:#126195;color:#fefefe}.button-group.secondary .button{background-color:#767676;color:#fefefe}.button-group.secondary .button:focus,.button-group.secondary .button:hover{background-color:#5e5e5e;color:#fefefe}.button-group.success .button{background-color:#3adb76;color:#0a0a0a}.button-group.success .button:focus,.button-group.success .button:hover{background-color:#22bb5b;color:#0a0a0a}.button-group.warning .button{background-color:#ffae00;color:#0a0a0a}.button-group.warning .button:focus,.button-group.warning .button:hover{background-color:#cc8b00;color:#0a0a0a}.button-group.alert .button{background-color:#cc4b37;color:#fefefe}.button-group.alert .button:focus,.button-group.alert .button:hover{background-color:#a53b2a;color:#fefefe}.button-group.stacked,.button-group.stacked-for-medium,.button-group.stacked-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.button-group.stacked .button,.button-group.stacked-for-medium .button,.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%}.button-group.stacked .button:last-child,.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.button-group.stacked-for-small .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;margin-bottom:0}}@media print,screen and (min-width:64em){.button-group.stacked-for-medium .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;margin-bottom:0}}@media screen and (max-width:39.9375em){.button-group.stacked-for-small.expanded{display:block}.button-group.stacked-for-small.expanded .button{display:block;margin-right:0}}.callout{position:relative;margin:0 0 1rem 0;padding:1rem;border:1px solid rgba(10,10,10,.25);border-radius:0;background-color:#fff;color:#0a0a0a}.callout>:first-child{margin-top:0}.callout>:last-child{margin-bottom:0}.callout.primary{background-color:#d7ecfa;color:#0a0a0a}.callout.secondary{background-color:#eaeaea;color:#0a0a0a}.callout.success{background-color:#e1faea;color:#0a0a0a}.callout.warning{background-color:#fff3d9;color:#0a0a0a}.callout.alert{background-color:#f7e4e1;color:#0a0a0a}.callout.small{padding-top:.5rem;padding-right:.5rem;padding-bottom:.5rem;padding-left:.5rem}.callout.large{padding-top:3rem;padding-right:3rem;padding-bottom:3rem;padding-left:3rem}.card{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-grow:1;-ms-flex-positive:1;flex-grow:1;margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;color:#0a0a0a}.card>:last-child{margin-bottom:0}.card-divider{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;padding:1rem;background:#e6e6e6}.card-divider>:last-child{margin-bottom:0}.card-section{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto;padding:1rem}.card-section>:last-child{margin-bottom:0}.card-image{min-height:1px}.close-button{position:absolute;color:#8a8a8a;cursor:pointer}[data-whatinput=mouse] .close-button{outline:0}.close-button:focus,.close-button:hover{color:#0a0a0a}.close-button.small{right:.66rem;top:.33em;font-size:1.5em;line-height:1}.close-button,.close-button.medium{right:1rem;top:.5rem;font-size:2em;line-height:1}.menu{padding:0;margin:0;list-style:none;position:relative;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}[data-whatinput=mouse] .menu li{outline:0}.menu .button,.menu a{line-height:1;text-decoration:none;display:block;padding:.7rem 1rem}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu input{display:inline-block}.menu,.menu.horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.simple{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.menu.simple li+li{margin-left:1rem}.menu.simple a{padding:0}@media print,screen and (min-width:40em){.menu.medium-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.medium-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.medium-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.medium-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}@media print,screen and (min-width:64em){.menu.large-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.large-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.large-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.large-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}.menu.nested{margin-right:0;margin-left:1rem}.menu.icons a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-bottom a,.menu.icon-left a,.menu.icon-right a,.menu.icon-top a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-left li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-left li a i,.menu.icon-left li a img,.menu.icon-left li a svg{margin-right:.25rem}.menu.icon-right li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-right li a i,.menu.icon-right li a img,.menu.icon-right li a svg{margin-left:.25rem}.menu.icon-top li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-top li a i,.menu.icon-top li a img,.menu.icon-top li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu.icon-bottom li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-bottom li a i,.menu.icon-bottom li a img,.menu.icon-bottom li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu .is-active>a{background:#1779ba;color:#fefefe}.menu .active>a{background:#1779ba;color:#fefefe}.menu.align-left{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-right li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.menu.align-right li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-right.vertical li{display:block;text-align:right}.menu.align-right.vertical li .submenu li{text-align:right}.menu.align-right .nested{margin-right:1rem;margin-left:0}.menu.align-center li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu.align-center li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu .menu-text{padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered>.menu{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.no-js [data-responsive-menu] ul{display:none}.menu-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#fefefe;-webkit-box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:''}.menu-icon:hover::after{background:#cacaca;-webkit-box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.menu-icon.dark{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon.dark::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;-webkit-box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:''}.menu-icon.dark:hover::after{background:#8a8a8a;-webkit-box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a;box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a}.is-drilldown{position:relative;overflow:hidden}.is-drilldown li{display:block}.is-drilldown.animate-height{-webkit-transition:height .5s;transition:height .5s}.drilldown a{padding:.7rem 1rem;background:#fefefe}.drilldown .is-drilldown-submenu{position:absolute;top:0;left:100%;z-index:-1;width:100%;background:#fefefe;-webkit-transition:-webkit-transform .15s linear;transition:-webkit-transform .15s linear;transition:transform .15s linear;transition:transform .15s linear,-webkit-transform .15s linear}.drilldown .is-drilldown-submenu.is-active{z-index:1;display:block;-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%)}.drilldown .is-drilldown-submenu.is-closing{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%)}.drilldown .is-drilldown-submenu a{padding:.7rem 1rem}.drilldown .nested.is-drilldown-submenu{margin-right:0;margin-left:0}.drilldown .drilldown-submenu-cover-previous{min-height:100%}.drilldown .is-drilldown-submenu-parent>a{position:relative}.drilldown .is-drilldown-submenu-parent>a::after{position:absolute;top:50%;margin-top:-6px;right:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.drilldown.align-left .is-drilldown-submenu-parent>a::after{left:auto;right:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.drilldown.align-right .is-drilldown-submenu-parent>a::after{right:auto;left:1rem;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.drilldown .js-drilldown-back>a::before{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;border-left-width:0;display:inline-block;vertical-align:middle;margin-right:.75rem;border-left-width:0}.dropdown-pane{position:absolute;z-index:10;width:300px;padding:1rem;visibility:hidden;display:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-opening{display:block}.dropdown-pane.is-open{visibility:visible;display:block}.dropdown-pane.tiny{width:100px}.dropdown-pane.small{width:200px}.dropdown-pane.large{width:400px}.dropdown.menu>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu a{padding:.7rem 1rem}[data-whatinput=mouse] .dropdown.menu a{outline:0}.dropdown.menu .is-active>a{background:0 0;color:#1779ba}.no-js .dropdown.menu ul{display:none}.dropdown.menu .nested.is-dropdown-submenu{margin-right:0;margin-left:0}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.vertical>li>a::after{right:14px}.dropdown.menu.vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}@media print,screen and (min-width:40em){.dropdown.menu.medium-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.medium-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.medium-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.medium-vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.medium-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.medium-vertical>li>a::after{right:14px}.dropdown.menu.medium-vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.medium-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}@media print,screen and (min-width:64em){.dropdown.menu.large-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.large-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.large-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.large-vertical>li.opens-left>.is-dropdown-submenu{right:100%;left:auto;top:0}.dropdown.menu.large-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.large-vertical>li>a::after{right:14px}.dropdown.menu.large-vertical>li.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.dropdown.menu.large-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}.dropdown.menu.align-right .is-dropdown-submenu.first-sub{top:100%;right:0;left:auto}.is-dropdown-menu.vertical{width:100px}.is-dropdown-menu.vertical.align-right{float:right}.is-dropdown-submenu-parent{position:relative}.is-dropdown-submenu-parent a::after{position:absolute;top:50%;right:5px;left:auto;margin-top:-6px}.is-dropdown-submenu-parent.opens-inner>.is-dropdown-submenu{top:100%;left:auto}.is-dropdown-submenu-parent.opens-left>.is-dropdown-submenu{right:100%;left:auto}.is-dropdown-submenu-parent.opens-right>.is-dropdown-submenu{right:auto;left:100%}.is-dropdown-submenu{position:absolute;top:0;left:100%;z-index:1;display:none;min-width:200px;border:1px solid #cacaca;background:#fefefe}.dropdown .is-dropdown-submenu a{padding:.7rem 1rem}.is-dropdown-submenu .is-dropdown-submenu-parent>a::after{right:14px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left>a::after{right:auto;left:5px;display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.is-dropdown-submenu .is-dropdown-submenu{margin-top:-1px}.is-dropdown-submenu>li{width:100%}.is-dropdown-submenu.js-dropdown-active{display:block}.flex-video,.responsive-embed{position:relative;height:0;margin-bottom:1rem;padding-bottom:75%;overflow:hidden}.flex-video embed,.flex-video iframe,.flex-video object,.flex-video video,.responsive-embed embed,.responsive-embed iframe,.responsive-embed object,.responsive-embed video{position:absolute;top:0;left:0;width:100%;height:100%}.flex-video.widescreen,.responsive-embed.widescreen{padding-bottom:56.25%}.label{display:inline-block;padding:.33333rem .5rem;border-radius:0;font-size:.8rem;line-height:1;white-space:nowrap;cursor:default;background:#1779ba;color:#fefefe}.label.primary{background:#1779ba;color:#fefefe}.label.secondary{background:#767676;color:#fefefe}.label.success{background:#3adb76;color:#0a0a0a}.label.warning{background:#ffae00;color:#0a0a0a}.label.alert{background:#cc4b37;color:#fefefe}.media-object{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;margin-bottom:1rem;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.media-object img{max-width:none}@media screen and (max-width:39.9375em){.media-object.stack-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}}@media screen and (max-width:39.9375em){.media-object.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;-webkit-flex-basis:100%;-ms-flex-preferred-size:100%;flex-basis:100%;max-width:100%}.media-object.stack-for-small .media-object-section img{width:100%}}.media-object-section{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.media-object-section:first-child{padding-right:1rem}.media-object-section:last-child:not(:nth-child(2)){padding-left:1rem}.media-object-section>:last-child{margin-bottom:0}.media-object-section.main-section{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.is-off-canvas-open{overflow:hidden}.js-off-canvas-overlay{position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;-webkit-transition:opacity .5s ease,visibility .5s ease;transition:opacity .5s ease,visibility .5s ease;background:rgba(254,254,254,.25);opacity:0;visibility:hidden;overflow:hidden}.js-off-canvas-overlay.is-visible{opacity:1;visibility:visible}.js-off-canvas-overlay.is-closable{cursor:pointer}.js-off-canvas-overlay.is-overlay-absolute{position:absolute}.js-off-canvas-overlay.is-overlay-fixed{position:fixed}.off-canvas-wrapper{position:relative;overflow:hidden}.off-canvas{position:fixed;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-push{z-index:12}.off-canvas.is-closed{visibility:hidden}.off-canvas.is-transition-overlap{z-index:13}.off-canvas.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-absolute{position:absolute;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas-absolute{outline:0}.off-canvas-absolute.is-transition-push{z-index:12}.off-canvas-absolute.is-closed{visibility:hidden}.off-canvas-absolute.is-transition-overlap{z-index:13}.off-canvas-absolute.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas-absolute.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.position-left{top:0;left:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-left.has-transition-push{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.position-left.is-transition-push{-webkit-box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25)}.position-right{top:0;right:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-right.has-transition-push{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.position-right.is-transition-push{-webkit-box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25)}.position-top{top:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-top.has-transition-push{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.position-top.is-transition-push{-webkit-box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25)}.position-bottom{bottom:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-bottom.has-transition-push{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.position-bottom.is-transition-push{-webkit-box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25)}.off-canvas-content{-webkit-transform:none;-ms-transform:none;transform:none;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.off-canvas-content.has-transition-push{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content .off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}@media print,screen and (min-width:40em){.position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-medium .close-button{display:none}.off-canvas-content .position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-medium .close-button{display:none}.off-canvas-content .position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-medium .close-button{display:none}.off-canvas-content .position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-medium .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:64em){.position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-large .close-button{display:none}.off-canvas-content .position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-large .close-button{display:none}.off-canvas-content .position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-large .close-button{display:none}.off-canvas-content .position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-large .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:40em){.off-canvas.in-canvas-for-medium{visibility:visible;height:auto;position:static;background:inherit;width:inherit;overflow:inherit;-webkit-transition:inherit;transition:inherit}.off-canvas.in-canvas-for-medium.position-bottom,.off-canvas.in-canvas-for-medium.position-left,.off-canvas.in-canvas-for-medium.position-right,.off-canvas.in-canvas-for-medium.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-medium .close-button{display:none}}@media print,screen and (min-width:64em){.off-canvas.in-canvas-for-large{visibility:visible;height:auto;position:static;background:inherit;width:inherit;overflow:inherit;-webkit-transition:inherit;transition:inherit}.off-canvas.in-canvas-for-large.position-bottom,.off-canvas.in-canvas-for-large.position-left,.off-canvas.in-canvas-for-large.position-right,.off-canvas.in-canvas-for-large.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-large .close-button{display:none}}.orbit{position:relative}.orbit-container{position:relative;height:0;margin:0;list-style:none;overflow:hidden}.orbit-slide{width:100%}.orbit-slide.no-motionui.is-active{top:0;left:0}.orbit-figure{margin:0}.orbit-image{width:100%;max-width:100%;margin:0}.orbit-caption{position:absolute;bottom:0;width:100%;margin-bottom:0;padding:1rem;background-color:rgba(10,10,10,.5);color:#fefefe}.orbit-next,.orbit-previous{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);z-index:10;padding:1rem;color:#fefefe}[data-whatinput=mouse] .orbit-next,[data-whatinput=mouse] .orbit-previous{outline:0}.orbit-next:active,.orbit-next:focus,.orbit-next:hover,.orbit-previous:active,.orbit-previous:focus,.orbit-previous:hover{background-color:rgba(10,10,10,.5)}.orbit-previous{left:0}.orbit-next{left:auto;right:0}.orbit-bullets{position:relative;margin-top:.8rem;margin-bottom:.8rem;text-align:center}[data-whatinput=mouse] .orbit-bullets{outline:0}.orbit-bullets button{width:1.2rem;height:1.2rem;margin:.1rem;border-radius:50%;background-color:#cacaca}.orbit-bullets button:hover{background-color:#8a8a8a}.orbit-bullets button.is-active{background-color:#8a8a8a}.pagination{margin-left:0;margin-bottom:1rem}.pagination::after,.pagination::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.pagination::after{clear:both}.pagination li{margin-right:.0625rem;border-radius:0;font-size:.875rem;display:none}.pagination li:first-child,.pagination li:last-child{display:inline-block}@media print,screen and (min-width:40em){.pagination li{display:inline-block}}.pagination a,.pagination button{display:block;padding:.1875rem .625rem;border-radius:0;color:#0a0a0a}.pagination a:hover,.pagination button:hover{background:#e6e6e6}.pagination .current{padding:.1875rem .625rem;background:#1779ba;color:#fefefe;cursor:default}.pagination .disabled{padding:.1875rem .625rem;color:#cacaca;cursor:not-allowed}.pagination .disabled:hover{background:0 0}.pagination .ellipsis::after{padding:.1875rem .625rem;content:'\2026';color:#0a0a0a}.pagination-previous a::before,.pagination-previous.disabled::before{display:inline-block;margin-right:.5rem;content:'\00ab'}.pagination-next a::after,.pagination-next.disabled::after{display:inline-block;margin-left:.5rem;content:'\00bb'}.progress{height:1rem;margin-bottom:1rem;border-radius:0;background-color:#cacaca}.progress.primary .progress-meter{background-color:#1779ba}.progress.secondary .progress-meter{background-color:#767676}.progress.success .progress-meter{background-color:#3adb76}.progress.warning .progress-meter{background-color:#ffae00}.progress.alert .progress-meter{background-color:#cc4b37}.progress-meter{position:relative;display:block;width:0%;height:100%;background-color:#1779ba}.progress-meter-text{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);transform:translate(-50%,-50%);position:absolute;margin:0;font-size:.75rem;font-weight:700;color:#fefefe;white-space:nowrap}.slider{position:relative;height:.5rem;margin-top:1.25rem;margin-bottom:2.25rem;background-color:#e6e6e6;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none}.slider-fill{position:absolute;top:0;left:0;display:inline-block;max-width:100%;height:.5rem;background-color:#cacaca;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.slider-fill.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider-handle{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;-ms-touch-action:manipulation;touch-action:manipulation}[data-whatinput=mouse] .slider-handle{outline:0}.slider-handle:hover{background-color:#14679e}.slider-handle.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider.disabled,.slider[disabled]{opacity:.25;cursor:not-allowed}.slider.vertical{display:inline-block;width:.5rem;height:12.5rem;margin:0 1.25rem;-webkit-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scale(1,-1)}.slider.vertical .slider-fill{top:0;width:.5rem;max-height:100%}.slider.vertical .slider-handle{position:absolute;top:0;left:50%;width:1.4rem;height:1.4rem;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.sticky-container{position:relative}.sticky{position:relative;z-index:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.sticky.is-stuck{position:fixed;z-index:5;width:100%}.sticky.is-stuck.is-at-top{top:0}.sticky.is-stuck.is-at-bottom{bottom:0}.sticky.is-anchored{position:relative;right:auto;left:auto}.sticky.is-anchored.is-at-bottom{bottom:0}body.is-reveal-open{overflow:hidden}html.is-reveal-open,html.is-reveal-open body{min-height:100%;overflow:hidden;position:fixed;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;display:none;background-color:rgba(10,10,10,.45);overflow-y:scroll}.reveal{z-index:1006;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:none;padding:1rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;position:relative;top:100px;margin-right:auto;margin-left:auto;overflow-y:auto}[data-whatinput=mouse] .reveal{outline:0}@media print,screen and (min-width:40em){.reveal{min-height:0}}.reveal .column{min-width:0}.reveal>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.reveal{width:600px;max-width:75rem}}.reveal.collapse{padding:0}@media print,screen and (min-width:40em){.reveal.tiny{width:30%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.small{width:50%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.large{width:90%;max-width:75rem}}.reveal.full{top:0;left:0;width:100%;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}@media screen and (max-width:39.9375em){.reveal{top:0;left:0;width:100%;max-width:none;height:100%;height:100vh;min-height:100vh;margin-left:0;border:0;border-radius:0}}.reveal.without-overlay{position:fixed}.switch{height:2rem;position:relative;margin-bottom:1rem;outline:0;font-size:.875rem;font-weight:700;color:#fefefe;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.switch-input{position:absolute;margin-bottom:0;opacity:0}.switch-paddle{position:relative;display:block;width:4rem;height:2rem;border-radius:0;background:#cacaca;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;font-weight:inherit;color:inherit;cursor:pointer}input+.switch-paddle{margin:0}.switch-paddle::after{position:absolute;top:.25rem;left:.25rem;display:block;width:1.5rem;height:1.5rem;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);border-radius:0;background:#fefefe;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;content:''}input:checked~.switch-paddle{background:#1779ba}input:checked~.switch-paddle::after{left:2.25rem}[data-whatinput=mouse] input:focus~.switch-paddle{outline:0}.switch-active,.switch-inactive{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.switch-active{left:8%;display:none}input:checked+label>.switch-active{display:block}.switch-inactive{right:15%}input:checked+label>.switch-inactive{display:none}.switch.tiny{height:1.5rem}.switch.tiny .switch-paddle{width:3rem;height:1.5rem;font-size:.625rem}.switch.tiny .switch-paddle::after{top:.25rem;left:.25rem;width:1rem;height:1rem}.switch.tiny input:checked~.switch-paddle::after{left:1.75rem}.switch.small{height:1.75rem}.switch.small .switch-paddle{width:3.5rem;height:1.75rem;font-size:.75rem}.switch.small .switch-paddle::after{top:.25rem;left:.25rem;width:1.25rem;height:1.25rem}.switch.small input:checked~.switch-paddle::after{left:2rem}.switch.large{height:2.5rem}.switch.large .switch-paddle{width:5rem;height:2.5rem;font-size:1rem}.switch.large .switch-paddle::after{top:.25rem;left:.25rem;width:2rem;height:2rem}.switch.large input:checked~.switch-paddle::after{left:2.75rem}table{border-collapse:collapse;width:100%;margin-bottom:1rem;border-radius:0}table tbody,table tfoot,table thead{border:1px solid #f1f1f1;background-color:#fefefe}table caption{padding:.5rem .625rem .625rem;font-weight:700}table thead{background:#f8f8f8;color:#0a0a0a}table tfoot{background:#f1f1f1;color:#0a0a0a}table tfoot tr,table thead tr{background:0 0}table tfoot td,table tfoot th,table thead td,table thead th{padding:.5rem .625rem .625rem;font-weight:700;text-align:left}table tbody td,table tbody th{padding:.5rem .625rem .625rem}table tbody tr:nth-child(even){border-bottom:0;background-color:#f1f1f1}table.unstriped tbody{background-color:#fefefe}table.unstriped tbody tr{border-bottom:0;border-bottom:1px solid #f1f1f1;background-color:#fefefe}@media screen and (max-width:63.9375em){table.stack thead{display:none}table.stack tfoot{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}}table.scroll{display:block;width:100%;overflow-x:auto}table.hover thead tr:hover{background-color:#f3f3f3}table.hover tfoot tr:hover{background-color:#ececec}table.hover tbody tr:hover{background-color:#f9f9f9}table.hover:not(.unstriped) tr:nth-of-type(even):hover{background-color:#ececec}.table-scroll{overflow-x:auto}.table-scroll table{width:auto}.tabs{margin:0;border:1px solid #e6e6e6;background:#fefefe;list-style-type:none}.tabs::after,.tabs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.tabs::after{clear:both}.tabs.vertical>li{display:block;float:none;width:auto}.tabs.simple>li>a{padding:0}.tabs.simple>li>a:hover{background:0 0}.tabs.primary{background:#1779ba}.tabs.primary>li>a{color:#fefefe}.tabs.primary>li>a:focus,.tabs.primary>li>a:hover{background:#1673b1}.tabs-title{float:left}.tabs-title>a{display:block;padding:1.25rem 1.5rem;font-size:.75rem;line-height:1;color:#1779ba}.tabs-title>a:hover{background:#fefefe;color:#1468a0}.tabs-title>a:focus,.tabs-title>a[aria-selected=true]{background:#e6e6e6;color:#1779ba}.tabs-content{border:1px solid #e6e6e6;border-top:0;background:#fefefe;color:#0a0a0a;-webkit-transition:all .5s ease;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-left:0}.tabs-panel{display:none;padding:1rem}.tabs-panel.is-active{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:solid 4px #fefefe;border-radius:0;-webkit-box-shadow:0 0 0 1px rgba(10,10,10,.2);box-shadow:0 0 0 1px rgba(10,10,10,.2);line-height:0}a.thumbnail{-webkit-transition:-webkit-box-shadow .2s ease-out;transition:-webkit-box-shadow .2s ease-out;transition:box-shadow .2s ease-out;transition:box-shadow .2s ease-out,-webkit-box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{-webkit-box-shadow:0 0 6px 1px rgba(23,121,186,.5);box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{-webkit-box-shadow:none;box-shadow:none}.title-bar{padding:.5rem;background:#0a0a0a;color:#fefefe;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.title-bar .menu-icon{margin-left:.25rem;margin-right:.25rem}.title-bar-left,.title-bar-right{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.title-bar-right{text-align:right}.title-bar-title{display:inline-block;vertical-align:middle;font-weight:700}.has-tip{position:relative;display:inline-block;border-bottom:dotted 1px #8a8a8a;font-weight:700;cursor:help}.tooltip{position:absolute;top:calc(100% + .6495rem);z-index:1200;max-width:10rem;padding:.75rem;border-radius:0;background-color:#0a0a0a;font-size:80%;color:#fefefe}.tooltip::before{position:absolute}.tooltip.bottom::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;bottom:100%}.tooltip.bottom.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.top::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.top.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.left::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.right::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.tooltip.right.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.align-top::before{bottom:auto;top:10%}.tooltip.align-bottom::before{bottom:10%;top:auto}.tooltip.align-left::before{left:10%;right:auto}.tooltip.align-right::before{left:auto;right:10%}.top-bar{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;padding:.5rem;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar,.top-bar ul{background-color:#e6e6e6}.top-bar input{max-width:200px;margin-right:1rem}.top-bar .input-group-field{width:100%;margin-right:0}.top-bar input.button{width:auto}.top-bar .top-bar-left,.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}@media print,screen and (min-width:40em){.top-bar{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.top-bar .top-bar-left{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;margin-right:auto}.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;margin-left:auto}}@media screen and (max-width:63.9375em){.top-bar.stacked-for-medium{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}@media screen and (max-width:74.9375em){.top-bar.stacked-for-large{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-large .top-bar-left,.top-bar.stacked-for-large .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}.top-bar-title{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin:.5rem 1rem .5rem 0}.top-bar-left,.top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.hide{display:none!important}.invisible{visibility:hidden}@media screen and (max-width:39.9375em){.hide-for-small-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media print,screen and (min-width:40em){.hide-for-medium{display:none!important}}@media screen and (max-width:39.9375em){.show-for-medium{display:none!important}}@media screen and (min-width:40em) and (max-width:63.9375em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:39.9375em),screen and (min-width:64em){.show-for-medium-only{display:none!important}}@media print,screen and (min-width:64em){.hide-for-large{display:none!important}}@media screen and (max-width:63.9375em){.show-for-large{display:none!important}}@media screen and (min-width:64em) and (max-width:74.9375em){.hide-for-large-only{display:none!important}}@media screen and (max-width:63.9375em),screen and (min-width:75em){.show-for-large-only{display:none!important}}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;-webkit-clip-path:inset(50%);clip-path:inset(50%);border:0}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal;-webkit-clip-path:none;clip-path:none}.hide-for-portrait,.show-for-landscape{display:block!important}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}}.hide-for-landscape,.show-for-portrait{display:none!important}@media screen and (orientation:landscape){.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-landscape,.show-for-portrait{display:block!important}}.float-left{float:left!important}.float-right{float:right!important}.float-center{display:block;margin-right:auto;margin-left:auto}.clearfix::after,.clearfix::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.clearfix::after{clear:both}.align-right{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-justify{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between}.align-spaced{-webkit-justify-content:space-around;-ms-flex-pack:distribute;justify-content:space-around}.align-right.vertical.menu>li>a{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center.vertical.menu>li>a{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-top{-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start}.align-self-top{-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start}.align-bottom{-webkit-box-align:end;-webkit-align-items:flex-end;-ms-flex-align:end;align-items:flex-end}.align-self-bottom{-webkit-align-self:flex-end;-ms-flex-item-align:end;align-self:flex-end}.align-middle{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.align-self-middle{-webkit-align-self:center;-ms-flex-item-align:center;-ms-grid-row-align:center;align-self:center}.align-stretch{-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.align-self-stretch{-webkit-align-self:stretch;-ms-flex-item-align:stretch;-ms-grid-row-align:stretch;align-self:stretch}.align-center-middle{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-align-content:center;-ms-flex-line-pack:center;align-content:center}.small-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.small-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.small-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.small-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.small-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.small-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}@media print,screen and (min-width:40em){.medium-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.medium-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.medium-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.medium-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.medium-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.medium-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}@media print,screen and (min-width:64em){.large-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.large-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.large-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.large-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.large-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.large-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}.flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}@media print,screen and (min-width:40em){.medium-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.medium-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.medium-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.medium-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.medium-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.medium-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.medium-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.medium-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}@media print,screen and (min-width:64em){.large-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.large-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.large-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.large-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.large-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.large-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.large-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.large-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}
\ No newline at end of file
+@charset "UTF-8";@media print,screen and (min-width:40em){.reveal,.reveal.large,.reveal.small,.reveal.tiny{right:auto;left:auto;margin:0 auto}}/*! normalize.css v8.0.0 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}h1{font-size:2em;margin:.67em 0}hr{-webkit-box-sizing:content-box;box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{-webkit-box-sizing:border-box;box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{-webkit-box-sizing:border-box;box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}template{display:none}[hidden]{display:none}.foundation-mq{font-family:"small=0em&medium=40em&large=64em&xlarge=75em&xxlarge=90em"}html{-webkit-box-sizing:border-box;box-sizing:border-box;font-size:100%}*,::after,::before{-webkit-box-sizing:inherit;box-sizing:inherit}body{margin:0;padding:0;background:#fefefe;font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}img{display:inline-block;vertical-align:middle;max-width:100%;height:auto;-ms-interpolation-mode:bicubic}textarea{height:auto;min-height:50px;border-radius:0}select{-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;border-radius:0}.map_canvas embed,.map_canvas img,.map_canvas object,.mqa-display embed,.mqa-display img,.mqa-display object{max-width:none!important}button{padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;border-radius:0;background:0 0;line-height:1;cursor:auto}[data-whatinput=mouse] button{outline:0}pre{overflow:auto}button,input,optgroup,select,textarea{font-family:inherit}.is-visible{display:block!important}.is-hidden{display:none!important}[type=color],[type=date],[type=datetime-local],[type=datetime],[type=email],[type=month],[type=number],[type=password],[type=search],[type=tel],[type=text],[type=time],[type=url],[type=week],textarea{display:block;-webkit-box-sizing:border-box;box-sizing:border-box;width:100%;height:2.4375rem;margin:0 0 1rem;padding:.5rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;-webkit-box-shadow:inset 0 1px 2px rgba(10,10,10,.1);box-shadow:inset 0 1px 2px rgba(10,10,10,.1);font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s;-webkit-appearance:none;-moz-appearance:none;appearance:none}[type=color]:focus,[type=date]:focus,[type=datetime-local]:focus,[type=datetime]:focus,[type=email]:focus,[type=month]:focus,[type=number]:focus,[type=password]:focus,[type=search]:focus,[type=tel]:focus,[type=text]:focus,[type=time]:focus,[type=url]:focus,[type=week]:focus,textarea:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}textarea{max-width:100%}textarea[rows]{height:auto}input:disabled,input[readonly],textarea:disabled,textarea[readonly]{background-color:#e6e6e6;cursor:not-allowed}[type=button],[type=submit]{-webkit-appearance:none;-moz-appearance:none;appearance:none;border-radius:0}input[type=search]{-webkit-box-sizing:border-box;box-sizing:border-box}::-webkit-input-placeholder{color:#cacaca}:-ms-input-placeholder{color:#cacaca}::-ms-input-placeholder{color:#cacaca}::placeholder{color:#cacaca}[type=checkbox],[type=file],[type=radio]{margin:0 0 1rem}[type=checkbox]+label,[type=radio]+label{display:inline-block;vertical-align:baseline;margin-left:.5rem;margin-right:1rem;margin-bottom:0}[type=checkbox]+label[for],[type=radio]+label[for]{cursor:pointer}label>[type=checkbox],label>[type=radio]{margin-right:.5rem}[type=file]{width:100%}label{display:block;margin:0;font-size:.875rem;font-weight:400;line-height:1.8;color:#0a0a0a}label.middle{margin:0 0 1rem;padding:.5625rem 0}.help-text{margin-top:-.5rem;font-size:.8125rem;font-style:italic;color:#0a0a0a}.input-group{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;width:100%;margin-bottom:1rem;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.input-group>:first-child,.input-group>:first-child.input-group-button>*{border-radius:0}.input-group>:last-child,.input-group>:last-child.input-group-button>*{border-radius:0}.input-group-button,.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label,.input-group-field,.input-group-label{margin:0;white-space:nowrap}.input-group-label{padding:0 1rem;border:1px solid #cacaca;background:#e6e6e6;color:#0a0a0a;text-align:center;white-space:nowrap;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.input-group-label:first-child{border-right:0}.input-group-label:last-child{border-left:0}.input-group-field{border-radius:0;-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;min-width:0}.input-group-button{padding-top:0;padding-bottom:0;text-align:center;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.input-group-button a,.input-group-button button,.input-group-button input,.input-group-button label{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;height:auto;padding-top:0;padding-bottom:0;font-size:1rem}fieldset{margin:0;padding:0;border:0}legend{max-width:100%;margin-bottom:.5rem}.fieldset{margin:1.125rem 0;padding:1.25rem;border:1px solid #cacaca}.fieldset legend{margin:0;margin-left:-.1875rem;padding:0 .1875rem}select{height:2.4375rem;margin:0 0 1rem;padding:.5rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-family:inherit;font-size:1rem;font-weight:400;line-height:1.5;color:#0a0a0a;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' version='1.1' width='32' height='24' viewBox='0 0 32 24'><polygon points='0,0 32,0 16,24' style='fill: rgb%28138, 138, 138%29'></polygon></svg>");background-origin:content-box;background-position:right -1rem center;background-repeat:no-repeat;background-size:9px 6px;padding-right:1.5rem;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}@media screen and (min-width:0\0){select{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAYCAYAAACbU/80AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIpJREFUeNrEkckNgDAMBBfRkEt0ObRBBdsGXUDgmQfK4XhH2m8czQAAy27R3tsw4Qfe2x8uOO6oYLb6GlOor3GF+swURAOmUJ+RwtEJs9WvTGEYxBXqI1MQAZhCfUQKRzDMVj+TwrAIV6jvSUEkYAr1LSkcyTBb/V+KYfX7xAeusq3sLDtGH3kEGACPWIflNZfhRQAAAABJRU5ErkJggg==)}}select:focus{outline:0;border:1px solid #8a8a8a;background-color:#fefefe;-webkit-box-shadow:0 0 5px #cacaca;box-shadow:0 0 5px #cacaca;-webkit-transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:border-color .25s ease-in-out,-webkit-box-shadow .5s;transition:box-shadow .5s,border-color .25s ease-in-out;transition:box-shadow .5s,border-color .25s ease-in-out,-webkit-box-shadow .5s}select:disabled{background-color:#e6e6e6;cursor:not-allowed}select::-ms-expand{display:none}select[multiple]{height:auto;background-image:none}.is-invalid-input:not(:focus){border-color:#cc4b37;background-color:#f9ecea}.is-invalid-input:not(:focus)::-webkit-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus):-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::-ms-input-placeholder{color:#cc4b37}.is-invalid-input:not(:focus)::placeholder{color:#cc4b37}.is-invalid-label{color:#cc4b37}.form-error{display:none;margin-top:-.5rem;margin-bottom:1rem;font-size:.75rem;font-weight:700;color:#cc4b37}.form-error.is-visible{display:block}blockquote,dd,div,dl,dt,form,h1,h2,h3,h4,h5,h6,li,ol,p,pre,td,th,ul{margin:0;padding:0}p{margin-bottom:1rem;font-size:inherit;line-height:1.6;text-rendering:optimizeLegibility}em,i{font-style:italic;line-height:inherit}b,strong{font-weight:700;line-height:inherit}small{font-size:80%;line-height:inherit}.h1,.h2,.h3,.h4,.h5,.h6,h1,h2,h3,h4,h5,h6{font-family:"Helvetica Neue",Helvetica,Roboto,Arial,sans-serif;font-style:normal;font-weight:400;color:inherit;text-rendering:optimizeLegibility}.h1 small,.h2 small,.h3 small,.h4 small,.h5 small,.h6 small,h1 small,h2 small,h3 small,h4 small,h5 small,h6 small{line-height:0;color:#cacaca}.h1,h1{font-size:1.5rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h2,h2{font-size:1.25rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h3,h3{font-size:1.1875rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h4,h4{font-size:1.125rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h5,h5{font-size:1.0625rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}.h6,h6{font-size:1rem;line-height:1.4;margin-top:0;margin-bottom:.5rem}@media print,screen and (min-width:40em){.h1,h1{font-size:3rem}.h2,h2{font-size:2.5rem}.h3,h3{font-size:1.9375rem}.h4,h4{font-size:1.5625rem}.h5,h5{font-size:1.25rem}.h6,h6{font-size:1rem}}a{line-height:inherit;color:#1779ba;text-decoration:none;cursor:pointer}a:focus,a:hover{color:#1468a0}a img{border:0}hr{clear:both;max-width:75rem;height:0;margin:1.25rem auto;border-top:0;border-right:0;border-bottom:1px solid #cacaca;border-left:0}dl,ol,ul{margin-bottom:1rem;list-style-position:outside;line-height:1.6}li{font-size:inherit}ul{margin-left:1.25rem;list-style-type:disc}ol{margin-left:1.25rem}ol ol,ol ul,ul ol,ul ul{margin-left:1.25rem;margin-bottom:0}dl{margin-bottom:1rem}dl dt{margin-bottom:.3rem;font-weight:700}blockquote{margin:0 0 1rem;padding:.5625rem 1.25rem 0 1.1875rem;border-left:1px solid #cacaca}blockquote,blockquote p{line-height:1.6;color:#8a8a8a}cite{display:block;font-size:.8125rem;color:#8a8a8a}cite:before{content:"— "}abbr,abbr[title]{border-bottom:1px dotted #0a0a0a;cursor:help;text-decoration:none}figure{margin:0}code{padding:.125rem .3125rem .0625rem;border:1px solid #cacaca;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;font-weight:400;color:#0a0a0a}kbd{margin:0;padding:.125rem .25rem 0;background-color:#e6e6e6;font-family:Consolas,"Liberation Mono",Courier,monospace;color:#0a0a0a}.subheader{margin-top:.2rem;margin-bottom:.5rem;font-weight:400;line-height:1.4;color:#8a8a8a}.lead{font-size:125%;line-height:1.6}.stat{font-size:2.5rem;line-height:1}p+.stat{margin-top:-1rem}ol.no-bullet,ul.no-bullet{margin-left:0;list-style:none}.text-left{text-align:left}.text-right{text-align:right}.text-center{text-align:center}.text-justify{text-align:justify}@media print,screen and (min-width:40em){.medium-text-left{text-align:left}.medium-text-right{text-align:right}.medium-text-center{text-align:center}.medium-text-justify{text-align:justify}}@media print,screen and (min-width:64em){.large-text-left{text-align:left}.large-text-right{text-align:right}.large-text-center{text-align:center}.large-text-justify{text-align:justify}}.show-for-print{display:none!important}@media print{*{background:0 0!important;-webkit-box-shadow:none!important;box-shadow:none!important;color:#000!important;text-shadow:none!important}.show-for-print{display:block!important}.hide-for-print{display:none!important}table.show-for-print{display:table!important}thead.show-for-print{display:table-header-group!important}tbody.show-for-print{display:table-row-group!important}tr.show-for-print{display:table-row!important}td.show-for-print{display:table-cell!important}th.show-for-print{display:table-cell!important}a,a:visited{text-decoration:underline}a[href]:after{content:" (" attr(href) ")"}.ir a:after,a[href^='#']:after,a[href^='javascript:']:after{content:''}abbr[title]:after{content:" (" attr(title) ")"}blockquote,pre{border:1px solid #8a8a8a;page-break-inside:avoid}thead{display:table-header-group}img,tr{page-break-inside:avoid}img{max-width:100%!important}@page{margin:.5cm}h2,h3,p{orphans:3;widows:3}h2,h3{page-break-after:avoid}.print-break-inside{page-break-inside:auto}}.grid-container{padding-right:.625rem;padding-left:.625rem;max-width:75rem;margin-left:auto;margin-right:auto}@media print,screen and (min-width:40em){.grid-container{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.fluid{padding-right:.625rem;padding-left:.625rem;max-width:100%;margin-left:auto;margin-right:auto}@media print,screen and (min-width:40em){.grid-container.fluid{padding-right:.9375rem;padding-left:.9375rem}}.grid-container.full{padding-right:0;padding-left:0;max-width:100%;margin-left:auto;margin-right:auto}.grid-x{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row wrap;-ms-flex-flow:row wrap;flex-flow:row wrap}.cell{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;min-height:0;min-width:0;width:100%}.cell.auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.cell.shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.auto{width:auto}.grid-x>.shrink{width:auto}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9,.grid-x>.small-full,.grid-x>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-full,.grid-x>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-full,.grid-x>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-x>.small-1,.grid-x>.small-10,.grid-x>.small-11,.grid-x>.small-12,.grid-x>.small-2,.grid-x>.small-3,.grid-x>.small-4,.grid-x>.small-5,.grid-x>.small-6,.grid-x>.small-7,.grid-x>.small-8,.grid-x>.small-9{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.small-1{width:8.33333%}.grid-x>.small-2{width:16.66667%}.grid-x>.small-3{width:25%}.grid-x>.small-4{width:33.33333%}.grid-x>.small-5{width:41.66667%}.grid-x>.small-6{width:50%}.grid-x>.small-7{width:58.33333%}.grid-x>.small-8{width:66.66667%}.grid-x>.small-9{width:75%}.grid-x>.small-10{width:83.33333%}.grid-x>.small-11{width:91.66667%}.grid-x>.small-12{width:100%}@media print,screen and (min-width:40em){.grid-x>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.medium-1,.grid-x>.medium-10,.grid-x>.medium-11,.grid-x>.medium-12,.grid-x>.medium-2,.grid-x>.medium-3,.grid-x>.medium-4,.grid-x>.medium-5,.grid-x>.medium-6,.grid-x>.medium-7,.grid-x>.medium-8,.grid-x>.medium-9,.grid-x>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.medium-shrink{width:auto}.grid-x>.medium-1{width:8.33333%}.grid-x>.medium-2{width:16.66667%}.grid-x>.medium-3{width:25%}.grid-x>.medium-4{width:33.33333%}.grid-x>.medium-5{width:41.66667%}.grid-x>.medium-6{width:50%}.grid-x>.medium-7{width:58.33333%}.grid-x>.medium-8{width:66.66667%}.grid-x>.medium-9{width:75%}.grid-x>.medium-10{width:83.33333%}.grid-x>.medium-11{width:91.66667%}.grid-x>.medium-12{width:100%}}@media print,screen and (min-width:64em){.grid-x>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;width:auto}.grid-x>.large-1,.grid-x>.large-10,.grid-x>.large-11,.grid-x>.large-12,.grid-x>.large-2,.grid-x>.large-3,.grid-x>.large-4,.grid-x>.large-5,.grid-x>.large-6,.grid-x>.large-7,.grid-x>.large-8,.grid-x>.large-9,.grid-x>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-x>.large-shrink{width:auto}.grid-x>.large-1{width:8.33333%}.grid-x>.large-2{width:16.66667%}.grid-x>.large-3{width:25%}.grid-x>.large-4{width:33.33333%}.grid-x>.large-5{width:41.66667%}.grid-x>.large-6{width:50%}.grid-x>.large-7{width:58.33333%}.grid-x>.large-8{width:66.66667%}.grid-x>.large-9{width:75%}.grid-x>.large-10{width:83.33333%}.grid-x>.large-11{width:91.66667%}.grid-x>.large-12{width:100%}}.grid-margin-x:not(.grid-x)>.cell{width:auto}.grid-margin-y:not(.grid-y)>.cell{height:auto}.grid-margin-x{margin-left:-.625rem;margin-right:-.625rem}@media print,screen and (min-width:40em){.grid-margin-x{margin-left:-.9375rem;margin-right:-.9375rem}}.grid-margin-x>.cell{width:calc(100% - 1.25rem);margin-left:.625rem;margin-right:.625rem}@media print,screen and (min-width:40em){.grid-margin-x>.cell{width:calc(100% - 1.875rem);margin-left:.9375rem;margin-right:.9375rem}}.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.25rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.25rem)}.grid-margin-x>.small-3{width:calc(25% - 1.25rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.25rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.25rem)}.grid-margin-x>.small-6{width:calc(50% - 1.25rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.25rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.25rem)}.grid-margin-x>.small-9{width:calc(75% - 1.25rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.25rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.25rem)}.grid-margin-x>.small-12{width:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x>.auto{width:auto}.grid-margin-x>.shrink{width:auto}.grid-margin-x>.small-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.small-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.small-3{width:calc(25% - 1.875rem)}.grid-margin-x>.small-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.small-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.small-6{width:calc(50% - 1.875rem)}.grid-margin-x>.small-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.small-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.small-9{width:calc(75% - 1.875rem)}.grid-margin-x>.small-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.small-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.small-12{width:calc(100% - 1.875rem)}.grid-margin-x>.medium-auto{width:auto}.grid-margin-x>.medium-shrink{width:auto}.grid-margin-x>.medium-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.medium-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.medium-3{width:calc(25% - 1.875rem)}.grid-margin-x>.medium-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.medium-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.medium-6{width:calc(50% - 1.875rem)}.grid-margin-x>.medium-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.medium-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.medium-9{width:calc(75% - 1.875rem)}.grid-margin-x>.medium-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.medium-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.medium-12{width:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x>.large-auto{width:auto}.grid-margin-x>.large-shrink{width:auto}.grid-margin-x>.large-1{width:calc(8.33333% - 1.875rem)}.grid-margin-x>.large-2{width:calc(16.66667% - 1.875rem)}.grid-margin-x>.large-3{width:calc(25% - 1.875rem)}.grid-margin-x>.large-4{width:calc(33.33333% - 1.875rem)}.grid-margin-x>.large-5{width:calc(41.66667% - 1.875rem)}.grid-margin-x>.large-6{width:calc(50% - 1.875rem)}.grid-margin-x>.large-7{width:calc(58.33333% - 1.875rem)}.grid-margin-x>.large-8{width:calc(66.66667% - 1.875rem)}.grid-margin-x>.large-9{width:calc(75% - 1.875rem)}.grid-margin-x>.large-10{width:calc(83.33333% - 1.875rem)}.grid-margin-x>.large-11{width:calc(91.66667% - 1.875rem)}.grid-margin-x>.large-12{width:calc(100% - 1.875rem)}}.grid-padding-x .grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-padding-x .grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-container:not(.full)>.grid-padding-x{margin-right:-.625rem;margin-left:-.625rem}@media print,screen and (min-width:40em){.grid-container:not(.full)>.grid-padding-x{margin-right:-.9375rem;margin-left:-.9375rem}}.grid-padding-x>.cell{padding-right:.625rem;padding-left:.625rem}@media print,screen and (min-width:40em){.grid-padding-x>.cell{padding-right:.9375rem;padding-left:.9375rem}}.small-up-1>.cell{width:100%}.small-up-2>.cell{width:50%}.small-up-3>.cell{width:33.33333%}.small-up-4>.cell{width:25%}.small-up-5>.cell{width:20%}.small-up-6>.cell{width:16.66667%}.small-up-7>.cell{width:14.28571%}.small-up-8>.cell{width:12.5%}@media print,screen and (min-width:40em){.medium-up-1>.cell{width:100%}.medium-up-2>.cell{width:50%}.medium-up-3>.cell{width:33.33333%}.medium-up-4>.cell{width:25%}.medium-up-5>.cell{width:20%}.medium-up-6>.cell{width:16.66667%}.medium-up-7>.cell{width:14.28571%}.medium-up-8>.cell{width:12.5%}}@media print,screen and (min-width:64em){.large-up-1>.cell{width:100%}.large-up-2>.cell{width:50%}.large-up-3>.cell{width:33.33333%}.large-up-4>.cell{width:25%}.large-up-5>.cell{width:20%}.large-up-6>.cell{width:16.66667%}.large-up-7>.cell{width:14.28571%}.large-up-8>.cell{width:12.5%}}.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.25rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.25rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.25rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.25rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.25rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.25rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.25rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-x.small-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.small-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.small-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.small-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.small-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.small-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.small-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.small-up-8>.cell{width:calc(12.5% - 1.875rem)}.grid-margin-x.medium-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.medium-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.medium-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.medium-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.medium-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.medium-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.medium-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.medium-up-8>.cell{width:calc(12.5% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-x.large-up-1>.cell{width:calc(100% - 1.875rem)}.grid-margin-x.large-up-2>.cell{width:calc(50% - 1.875rem)}.grid-margin-x.large-up-3>.cell{width:calc(33.33333% - 1.875rem)}.grid-margin-x.large-up-4>.cell{width:calc(25% - 1.875rem)}.grid-margin-x.large-up-5>.cell{width:calc(20% - 1.875rem)}.grid-margin-x.large-up-6>.cell{width:calc(16.66667% - 1.875rem)}.grid-margin-x.large-up-7>.cell{width:calc(14.28571% - 1.875rem)}.grid-margin-x.large-up-8>.cell{width:calc(12.5% - 1.875rem)}}.small-margin-collapse{margin-right:0;margin-left:0}.small-margin-collapse>.cell{margin-right:0;margin-left:0}.small-margin-collapse>.small-1{width:8.33333%}.small-margin-collapse>.small-2{width:16.66667%}.small-margin-collapse>.small-3{width:25%}.small-margin-collapse>.small-4{width:33.33333%}.small-margin-collapse>.small-5{width:41.66667%}.small-margin-collapse>.small-6{width:50%}.small-margin-collapse>.small-7{width:58.33333%}.small-margin-collapse>.small-8{width:66.66667%}.small-margin-collapse>.small-9{width:75%}.small-margin-collapse>.small-10{width:83.33333%}.small-margin-collapse>.small-11{width:91.66667%}.small-margin-collapse>.small-12{width:100%}@media print,screen and (min-width:40em){.small-margin-collapse>.medium-1{width:8.33333%}.small-margin-collapse>.medium-2{width:16.66667%}.small-margin-collapse>.medium-3{width:25%}.small-margin-collapse>.medium-4{width:33.33333%}.small-margin-collapse>.medium-5{width:41.66667%}.small-margin-collapse>.medium-6{width:50%}.small-margin-collapse>.medium-7{width:58.33333%}.small-margin-collapse>.medium-8{width:66.66667%}.small-margin-collapse>.medium-9{width:75%}.small-margin-collapse>.medium-10{width:83.33333%}.small-margin-collapse>.medium-11{width:91.66667%}.small-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.small-margin-collapse>.large-1{width:8.33333%}.small-margin-collapse>.large-2{width:16.66667%}.small-margin-collapse>.large-3{width:25%}.small-margin-collapse>.large-4{width:33.33333%}.small-margin-collapse>.large-5{width:41.66667%}.small-margin-collapse>.large-6{width:50%}.small-margin-collapse>.large-7{width:58.33333%}.small-margin-collapse>.large-8{width:66.66667%}.small-margin-collapse>.large-9{width:75%}.small-margin-collapse>.large-10{width:83.33333%}.small-margin-collapse>.large-11{width:91.66667%}.small-margin-collapse>.large-12{width:100%}}.small-padding-collapse{margin-right:0;margin-left:0}.small-padding-collapse>.cell{padding-right:0;padding-left:0}@media print,screen and (min-width:40em){.medium-margin-collapse{margin-right:0;margin-left:0}.medium-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:40em){.medium-margin-collapse>.small-1{width:8.33333%}.medium-margin-collapse>.small-2{width:16.66667%}.medium-margin-collapse>.small-3{width:25%}.medium-margin-collapse>.small-4{width:33.33333%}.medium-margin-collapse>.small-5{width:41.66667%}.medium-margin-collapse>.small-6{width:50%}.medium-margin-collapse>.small-7{width:58.33333%}.medium-margin-collapse>.small-8{width:66.66667%}.medium-margin-collapse>.small-9{width:75%}.medium-margin-collapse>.small-10{width:83.33333%}.medium-margin-collapse>.small-11{width:91.66667%}.medium-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:40em){.medium-margin-collapse>.medium-1{width:8.33333%}.medium-margin-collapse>.medium-2{width:16.66667%}.medium-margin-collapse>.medium-3{width:25%}.medium-margin-collapse>.medium-4{width:33.33333%}.medium-margin-collapse>.medium-5{width:41.66667%}.medium-margin-collapse>.medium-6{width:50%}.medium-margin-collapse>.medium-7{width:58.33333%}.medium-margin-collapse>.medium-8{width:66.66667%}.medium-margin-collapse>.medium-9{width:75%}.medium-margin-collapse>.medium-10{width:83.33333%}.medium-margin-collapse>.medium-11{width:91.66667%}.medium-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.medium-margin-collapse>.large-1{width:8.33333%}.medium-margin-collapse>.large-2{width:16.66667%}.medium-margin-collapse>.large-3{width:25%}.medium-margin-collapse>.large-4{width:33.33333%}.medium-margin-collapse>.large-5{width:41.66667%}.medium-margin-collapse>.large-6{width:50%}.medium-margin-collapse>.large-7{width:58.33333%}.medium-margin-collapse>.large-8{width:66.66667%}.medium-margin-collapse>.large-9{width:75%}.medium-margin-collapse>.large-10{width:83.33333%}.medium-margin-collapse>.large-11{width:91.66667%}.medium-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:40em){.medium-padding-collapse{margin-right:0;margin-left:0}.medium-padding-collapse>.cell{padding-right:0;padding-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse{margin-right:0;margin-left:0}.large-margin-collapse>.cell{margin-right:0;margin-left:0}}@media print,screen and (min-width:64em){.large-margin-collapse>.small-1{width:8.33333%}.large-margin-collapse>.small-2{width:16.66667%}.large-margin-collapse>.small-3{width:25%}.large-margin-collapse>.small-4{width:33.33333%}.large-margin-collapse>.small-5{width:41.66667%}.large-margin-collapse>.small-6{width:50%}.large-margin-collapse>.small-7{width:58.33333%}.large-margin-collapse>.small-8{width:66.66667%}.large-margin-collapse>.small-9{width:75%}.large-margin-collapse>.small-10{width:83.33333%}.large-margin-collapse>.small-11{width:91.66667%}.large-margin-collapse>.small-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.medium-1{width:8.33333%}.large-margin-collapse>.medium-2{width:16.66667%}.large-margin-collapse>.medium-3{width:25%}.large-margin-collapse>.medium-4{width:33.33333%}.large-margin-collapse>.medium-5{width:41.66667%}.large-margin-collapse>.medium-6{width:50%}.large-margin-collapse>.medium-7{width:58.33333%}.large-margin-collapse>.medium-8{width:66.66667%}.large-margin-collapse>.medium-9{width:75%}.large-margin-collapse>.medium-10{width:83.33333%}.large-margin-collapse>.medium-11{width:91.66667%}.large-margin-collapse>.medium-12{width:100%}}@media print,screen and (min-width:64em){.large-margin-collapse>.large-1{width:8.33333%}.large-margin-collapse>.large-2{width:16.66667%}.large-margin-collapse>.large-3{width:25%}.large-margin-collapse>.large-4{width:33.33333%}.large-margin-collapse>.large-5{width:41.66667%}.large-margin-collapse>.large-6{width:50%}.large-margin-collapse>.large-7{width:58.33333%}.large-margin-collapse>.large-8{width:66.66667%}.large-margin-collapse>.large-9{width:75%}.large-margin-collapse>.large-10{width:83.33333%}.large-margin-collapse>.large-11{width:91.66667%}.large-margin-collapse>.large-12{width:100%}}@media print,screen and (min-width:64em){.large-padding-collapse{margin-right:0;margin-left:0}.large-padding-collapse>.cell{padding-right:0;padding-left:0}}.small-offset-0{margin-left:0}.grid-margin-x>.small-offset-0{margin-left:calc(0% + .625rem)}.small-offset-1{margin-left:8.33333%}.grid-margin-x>.small-offset-1{margin-left:calc(8.33333% + .625rem)}.small-offset-2{margin-left:16.66667%}.grid-margin-x>.small-offset-2{margin-left:calc(16.66667% + .625rem)}.small-offset-3{margin-left:25%}.grid-margin-x>.small-offset-3{margin-left:calc(25% + .625rem)}.small-offset-4{margin-left:33.33333%}.grid-margin-x>.small-offset-4{margin-left:calc(33.33333% + .625rem)}.small-offset-5{margin-left:41.66667%}.grid-margin-x>.small-offset-5{margin-left:calc(41.66667% + .625rem)}.small-offset-6{margin-left:50%}.grid-margin-x>.small-offset-6{margin-left:calc(50% + .625rem)}.small-offset-7{margin-left:58.33333%}.grid-margin-x>.small-offset-7{margin-left:calc(58.33333% + .625rem)}.small-offset-8{margin-left:66.66667%}.grid-margin-x>.small-offset-8{margin-left:calc(66.66667% + .625rem)}.small-offset-9{margin-left:75%}.grid-margin-x>.small-offset-9{margin-left:calc(75% + .625rem)}.small-offset-10{margin-left:83.33333%}.grid-margin-x>.small-offset-10{margin-left:calc(83.33333% + .625rem)}.small-offset-11{margin-left:91.66667%}.grid-margin-x>.small-offset-11{margin-left:calc(91.66667% + .625rem)}@media print,screen and (min-width:40em){.medium-offset-0{margin-left:0}.grid-margin-x>.medium-offset-0{margin-left:calc(0% + .9375rem)}.medium-offset-1{margin-left:8.33333%}.grid-margin-x>.medium-offset-1{margin-left:calc(8.33333% + .9375rem)}.medium-offset-2{margin-left:16.66667%}.grid-margin-x>.medium-offset-2{margin-left:calc(16.66667% + .9375rem)}.medium-offset-3{margin-left:25%}.grid-margin-x>.medium-offset-3{margin-left:calc(25% + .9375rem)}.medium-offset-4{margin-left:33.33333%}.grid-margin-x>.medium-offset-4{margin-left:calc(33.33333% + .9375rem)}.medium-offset-5{margin-left:41.66667%}.grid-margin-x>.medium-offset-5{margin-left:calc(41.66667% + .9375rem)}.medium-offset-6{margin-left:50%}.grid-margin-x>.medium-offset-6{margin-left:calc(50% + .9375rem)}.medium-offset-7{margin-left:58.33333%}.grid-margin-x>.medium-offset-7{margin-left:calc(58.33333% + .9375rem)}.medium-offset-8{margin-left:66.66667%}.grid-margin-x>.medium-offset-8{margin-left:calc(66.66667% + .9375rem)}.medium-offset-9{margin-left:75%}.grid-margin-x>.medium-offset-9{margin-left:calc(75% + .9375rem)}.medium-offset-10{margin-left:83.33333%}.grid-margin-x>.medium-offset-10{margin-left:calc(83.33333% + .9375rem)}.medium-offset-11{margin-left:91.66667%}.grid-margin-x>.medium-offset-11{margin-left:calc(91.66667% + .9375rem)}}@media print,screen and (min-width:64em){.large-offset-0{margin-left:0}.grid-margin-x>.large-offset-0{margin-left:calc(0% + .9375rem)}.large-offset-1{margin-left:8.33333%}.grid-margin-x>.large-offset-1{margin-left:calc(8.33333% + .9375rem)}.large-offset-2{margin-left:16.66667%}.grid-margin-x>.large-offset-2{margin-left:calc(16.66667% + .9375rem)}.large-offset-3{margin-left:25%}.grid-margin-x>.large-offset-3{margin-left:calc(25% + .9375rem)}.large-offset-4{margin-left:33.33333%}.grid-margin-x>.large-offset-4{margin-left:calc(33.33333% + .9375rem)}.large-offset-5{margin-left:41.66667%}.grid-margin-x>.large-offset-5{margin-left:calc(41.66667% + .9375rem)}.large-offset-6{margin-left:50%}.grid-margin-x>.large-offset-6{margin-left:calc(50% + .9375rem)}.large-offset-7{margin-left:58.33333%}.grid-margin-x>.large-offset-7{margin-left:calc(58.33333% + .9375rem)}.large-offset-8{margin-left:66.66667%}.grid-margin-x>.large-offset-8{margin-left:calc(66.66667% + .9375rem)}.large-offset-9{margin-left:75%}.grid-margin-x>.large-offset-9{margin-left:calc(75% + .9375rem)}.large-offset-10{margin-left:83.33333%}.grid-margin-x>.large-offset-10{margin-left:calc(83.33333% + .9375rem)}.large-offset-11{margin-left:91.66667%}.grid-margin-x>.large-offset-11{margin-left:calc(91.66667% + .9375rem)}}.grid-y{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.grid-y>.cell{width:auto;max-width:none}.grid-y>.auto{height:auto}.grid-y>.shrink{height:auto}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9,.grid-y>.small-full,.grid-y>.small-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}@media print,screen and (min-width:40em){.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-full,.grid-y>.medium-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}@media print,screen and (min-width:64em){.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-full,.grid-y>.large-shrink{-webkit-flex-basis:auto;-ms-flex-preferred-size:auto;flex-basis:auto}}.grid-y>.small-1,.grid-y>.small-10,.grid-y>.small-11,.grid-y>.small-12,.grid-y>.small-2,.grid-y>.small-3,.grid-y>.small-4,.grid-y>.small-5,.grid-y>.small-6,.grid-y>.small-7,.grid-y>.small-8,.grid-y>.small-9{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.small-1{height:8.33333%}.grid-y>.small-2{height:16.66667%}.grid-y>.small-3{height:25%}.grid-y>.small-4{height:33.33333%}.grid-y>.small-5{height:41.66667%}.grid-y>.small-6{height:50%}.grid-y>.small-7{height:58.33333%}.grid-y>.small-8{height:66.66667%}.grid-y>.small-9{height:75%}.grid-y>.small-10{height:83.33333%}.grid-y>.small-11{height:91.66667%}.grid-y>.small-12{height:100%}@media print,screen and (min-width:40em){.grid-y>.medium-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.medium-1,.grid-y>.medium-10,.grid-y>.medium-11,.grid-y>.medium-12,.grid-y>.medium-2,.grid-y>.medium-3,.grid-y>.medium-4,.grid-y>.medium-5,.grid-y>.medium-6,.grid-y>.medium-7,.grid-y>.medium-8,.grid-y>.medium-9,.grid-y>.medium-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.medium-shrink{height:auto}.grid-y>.medium-1{height:8.33333%}.grid-y>.medium-2{height:16.66667%}.grid-y>.medium-3{height:25%}.grid-y>.medium-4{height:33.33333%}.grid-y>.medium-5{height:41.66667%}.grid-y>.medium-6{height:50%}.grid-y>.medium-7{height:58.33333%}.grid-y>.medium-8{height:66.66667%}.grid-y>.medium-9{height:75%}.grid-y>.medium-10{height:83.33333%}.grid-y>.medium-11{height:91.66667%}.grid-y>.medium-12{height:100%}}@media print,screen and (min-width:64em){.grid-y>.large-auto{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px;height:auto}.grid-y>.large-1,.grid-y>.large-10,.grid-y>.large-11,.grid-y>.large-12,.grid-y>.large-2,.grid-y>.large-3,.grid-y>.large-4,.grid-y>.large-5,.grid-y>.large-6,.grid-y>.large-7,.grid-y>.large-8,.grid-y>.large-9,.grid-y>.large-shrink{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.grid-y>.large-shrink{height:auto}.grid-y>.large-1{height:8.33333%}.grid-y>.large-2{height:16.66667%}.grid-y>.large-3{height:25%}.grid-y>.large-4{height:33.33333%}.grid-y>.large-5{height:41.66667%}.grid-y>.large-6{height:50%}.grid-y>.large-7{height:58.33333%}.grid-y>.large-8{height:66.66667%}.grid-y>.large-9{height:75%}.grid-y>.large-10{height:83.33333%}.grid-y>.large-11{height:91.66667%}.grid-y>.large-12{height:100%}}.grid-padding-y .grid-padding-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-padding-y .grid-padding-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-padding-y>.cell{padding-top:.625rem;padding-bottom:.625rem}@media print,screen and (min-width:40em){.grid-padding-y>.cell{padding-top:.9375rem;padding-bottom:.9375rem}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .grid-frame{width:100%}.cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.cell-block-container{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;max-height:100%}.cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}@media print,screen and (min-width:40em){.medium-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .medium-grid-frame{width:100%}.medium-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.medium-cell-block-container{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;max-height:100%}.medium-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.medium-cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}}@media print,screen and (min-width:64em){.large-grid-frame{overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;width:100vw}.cell .large-grid-frame{width:100%}.large-cell-block{overflow-x:auto;max-width:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}.large-cell-block-container{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;max-height:100%}.large-cell-block-container>.grid-x{max-height:100%;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.large-cell-block-y{overflow-y:auto;max-height:100%;min-height:100%;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}}.grid-y.grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}@media print,screen and (min-width:40em){.grid-y.medium-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}@media print,screen and (min-width:64em){.grid-y.large-grid-frame{width:auto;overflow:hidden;position:relative;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch;height:100vh}}.cell .grid-y.grid-frame{height:100%}@media print,screen and (min-width:40em){.cell .grid-y.medium-grid-frame{height:100%}}@media print,screen and (min-width:64em){.cell .grid-y.large-grid-frame{height:100%}}.grid-margin-y{margin-top:-.625rem;margin-bottom:-.625rem}@media print,screen and (min-width:40em){.grid-margin-y{margin-top:-.9375rem;margin-bottom:-.9375rem}}.grid-margin-y>.cell{height:calc(100% - 1.25rem);margin-top:.625rem;margin-bottom:.625rem}@media print,screen and (min-width:40em){.grid-margin-y>.cell{height:calc(100% - 1.875rem);margin-top:.9375rem;margin-bottom:.9375rem}}.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.25rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.25rem)}.grid-margin-y>.small-3{height:calc(25% - 1.25rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.25rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.25rem)}.grid-margin-y>.small-6{height:calc(50% - 1.25rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.25rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.25rem)}.grid-margin-y>.small-9{height:calc(75% - 1.25rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.25rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.25rem)}.grid-margin-y>.small-12{height:calc(100% - 1.25rem)}@media print,screen and (min-width:40em){.grid-margin-y>.auto{height:auto}.grid-margin-y>.shrink{height:auto}.grid-margin-y>.small-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.small-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.small-3{height:calc(25% - 1.875rem)}.grid-margin-y>.small-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.small-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.small-6{height:calc(50% - 1.875rem)}.grid-margin-y>.small-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.small-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.small-9{height:calc(75% - 1.875rem)}.grid-margin-y>.small-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.small-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.small-12{height:calc(100% - 1.875rem)}.grid-margin-y>.medium-auto{height:auto}.grid-margin-y>.medium-shrink{height:auto}.grid-margin-y>.medium-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.medium-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.medium-3{height:calc(25% - 1.875rem)}.grid-margin-y>.medium-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.medium-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.medium-6{height:calc(50% - 1.875rem)}.grid-margin-y>.medium-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.medium-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.medium-9{height:calc(75% - 1.875rem)}.grid-margin-y>.medium-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.medium-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.medium-12{height:calc(100% - 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y>.large-auto{height:auto}.grid-margin-y>.large-shrink{height:auto}.grid-margin-y>.large-1{height:calc(8.33333% - 1.875rem)}.grid-margin-y>.large-2{height:calc(16.66667% - 1.875rem)}.grid-margin-y>.large-3{height:calc(25% - 1.875rem)}.grid-margin-y>.large-4{height:calc(33.33333% - 1.875rem)}.grid-margin-y>.large-5{height:calc(41.66667% - 1.875rem)}.grid-margin-y>.large-6{height:calc(50% - 1.875rem)}.grid-margin-y>.large-7{height:calc(58.33333% - 1.875rem)}.grid-margin-y>.large-8{height:calc(66.66667% - 1.875rem)}.grid-margin-y>.large-9{height:calc(75% - 1.875rem)}.grid-margin-y>.large-10{height:calc(83.33333% - 1.875rem)}.grid-margin-y>.large-11{height:calc(91.66667% - 1.875rem)}.grid-margin-y>.large-12{height:calc(100% - 1.875rem)}}.grid-frame.grid-margin-y{height:calc(100vh + 1.25rem)}@media print,screen and (min-width:40em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-frame.grid-margin-y{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:40em){.grid-margin-y.medium-grid-frame{height:calc(100vh + 1.875rem)}}@media print,screen and (min-width:64em){.grid-margin-y.large-grid-frame{height:calc(100vh + 1.875rem)}}.button{display:inline-block;vertical-align:middle;margin:0 0 1rem 0;padding:.85em 1em;border:1px solid transparent;border-radius:0;-webkit-transition:background-color .25s ease-out,color .25s ease-out;transition:background-color .25s ease-out,color .25s ease-out;font-family:inherit;font-size:.9rem;-webkit-appearance:none;line-height:1;text-align:center;cursor:pointer;background-color:#1779ba;color:#fefefe}[data-whatinput=mouse] .button{outline:0}.button:focus,.button:hover{background-color:#14679e;color:#fefefe}.button.tiny{font-size:.6rem}.button.small{font-size:.75rem}.button.large{font-size:1.25rem}.button.expanded{display:block;width:100%;margin-right:0;margin-left:0}.button.primary{background-color:#1779ba;color:#fefefe}.button.primary:focus,.button.primary:hover{background-color:#126195;color:#fefefe}.button.secondary{background-color:#767676;color:#fefefe}.button.secondary:focus,.button.secondary:hover{background-color:#5e5e5e;color:#fefefe}.button.success{background-color:#3adb76;color:#0a0a0a}.button.success:focus,.button.success:hover{background-color:#22bb5b;color:#0a0a0a}.button.warning{background-color:#ffae00;color:#0a0a0a}.button.warning:focus,.button.warning:hover{background-color:#cc8b00;color:#0a0a0a}.button.alert{background-color:#cc4b37;color:#fefefe}.button.alert:focus,.button.alert:hover{background-color:#a53b2a;color:#fefefe}.button.disabled,.button[disabled]{opacity:.25;cursor:not-allowed}.button.disabled,.button.disabled:focus,.button.disabled:hover,.button[disabled],.button[disabled]:focus,.button[disabled]:hover{background-color:#1779ba;color:#fefefe}.button.disabled.primary,.button[disabled].primary{opacity:.25;cursor:not-allowed}.button.disabled.primary,.button.disabled.primary:focus,.button.disabled.primary:hover,.button[disabled].primary,.button[disabled].primary:focus,.button[disabled].primary:hover{background-color:#1779ba;color:#fefefe}.button.disabled.secondary,.button[disabled].secondary{opacity:.25;cursor:not-allowed}.button.disabled.secondary,.button.disabled.secondary:focus,.button.disabled.secondary:hover,.button[disabled].secondary,.button[disabled].secondary:focus,.button[disabled].secondary:hover{background-color:#767676;color:#fefefe}.button.disabled.success,.button[disabled].success{opacity:.25;cursor:not-allowed}.button.disabled.success,.button.disabled.success:focus,.button.disabled.success:hover,.button[disabled].success,.button[disabled].success:focus,.button[disabled].success:hover{background-color:#3adb76;color:#0a0a0a}.button.disabled.warning,.button[disabled].warning{opacity:.25;cursor:not-allowed}.button.disabled.warning,.button.disabled.warning:focus,.button.disabled.warning:hover,.button[disabled].warning,.button[disabled].warning:focus,.button[disabled].warning:hover{background-color:#ffae00;color:#0a0a0a}.button.disabled.alert,.button[disabled].alert{opacity:.25;cursor:not-allowed}.button.disabled.alert,.button.disabled.alert:focus,.button.disabled.alert:hover,.button[disabled].alert,.button[disabled].alert:focus,.button[disabled].alert:hover{background-color:#cc4b37;color:#fefefe}.button.hollow{border:1px solid #1779ba;color:#1779ba}.button.hollow,.button.hollow:focus,.button.hollow:hover{background-color:transparent}.button.hollow.disabled,.button.hollow.disabled:focus,.button.hollow.disabled:hover,.button.hollow[disabled],.button.hollow[disabled]:focus,.button.hollow[disabled]:hover{background-color:transparent}.button.hollow:focus,.button.hollow:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow:focus.disabled,.button.hollow:focus[disabled],.button.hollow:hover.disabled,.button.hollow:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary{border:1px solid #1779ba;color:#1779ba}.button.hollow.primary:focus,.button.hollow.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.hollow.primary:focus.disabled,.button.hollow.primary:focus[disabled],.button.hollow.primary:hover.disabled,.button.hollow.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.hollow.secondary{border:1px solid #767676;color:#767676}.button.hollow.secondary:focus,.button.hollow.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.hollow.secondary:focus.disabled,.button.hollow.secondary:focus[disabled],.button.hollow.secondary:hover.disabled,.button.hollow.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.hollow.success{border:1px solid #3adb76;color:#3adb76}.button.hollow.success:focus,.button.hollow.success:hover{border-color:#157539;color:#157539}.button.hollow.success:focus.disabled,.button.hollow.success:focus[disabled],.button.hollow.success:hover.disabled,.button.hollow.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.hollow.warning{border:1px solid #ffae00;color:#ffae00}.button.hollow.warning:focus,.button.hollow.warning:hover{border-color:#805700;color:#805700}.button.hollow.warning:focus.disabled,.button.hollow.warning:focus[disabled],.button.hollow.warning:hover.disabled,.button.hollow.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.hollow.alert{border:1px solid #cc4b37;color:#cc4b37}.button.hollow.alert:focus,.button.hollow.alert:hover{border-color:#67251a;color:#67251a}.button.hollow.alert:focus.disabled,.button.hollow.alert:focus[disabled],.button.hollow.alert:hover.disabled,.button.hollow.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear:focus,.button.clear:hover{background-color:transparent}.button.clear.disabled,.button.clear.disabled:focus,.button.clear.disabled:hover,.button.clear[disabled],.button.clear[disabled]:focus,.button.clear[disabled]:hover{background-color:transparent}.button.clear:focus,.button.clear:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover.disabled,.button.clear:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear,.button.clear.disabled,.button.clear:focus,.button.clear:focus.disabled,.button.clear:focus[disabled],.button.clear:hover,.button.clear:hover.disabled,.button.clear:hover[disabled],.button.clear[disabled]{border-color:transparent}.button.clear.primary{border:1px solid #1779ba;color:#1779ba}.button.clear.primary:focus,.button.clear.primary:hover{border-color:#0c3d5d;color:#0c3d5d}.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled]{border:1px solid #1779ba;color:#1779ba}.button.clear.primary,.button.clear.primary.disabled,.button.clear.primary:focus,.button.clear.primary:focus.disabled,.button.clear.primary:focus[disabled],.button.clear.primary:hover,.button.clear.primary:hover.disabled,.button.clear.primary:hover[disabled],.button.clear.primary[disabled]{border-color:transparent}.button.clear.secondary{border:1px solid #767676;color:#767676}.button.clear.secondary:focus,.button.clear.secondary:hover{border-color:#3b3b3b;color:#3b3b3b}.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled]{border:1px solid #767676;color:#767676}.button.clear.secondary,.button.clear.secondary.disabled,.button.clear.secondary:focus,.button.clear.secondary:focus.disabled,.button.clear.secondary:focus[disabled],.button.clear.secondary:hover,.button.clear.secondary:hover.disabled,.button.clear.secondary:hover[disabled],.button.clear.secondary[disabled]{border-color:transparent}.button.clear.success{border:1px solid #3adb76;color:#3adb76}.button.clear.success:focus,.button.clear.success:hover{border-color:#157539;color:#157539}.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover.disabled,.button.clear.success:hover[disabled]{border:1px solid #3adb76;color:#3adb76}.button.clear.success,.button.clear.success.disabled,.button.clear.success:focus,.button.clear.success:focus.disabled,.button.clear.success:focus[disabled],.button.clear.success:hover,.button.clear.success:hover.disabled,.button.clear.success:hover[disabled],.button.clear.success[disabled]{border-color:transparent}.button.clear.warning{border:1px solid #ffae00;color:#ffae00}.button.clear.warning:focus,.button.clear.warning:hover{border-color:#805700;color:#805700}.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled]{border:1px solid #ffae00;color:#ffae00}.button.clear.warning,.button.clear.warning.disabled,.button.clear.warning:focus,.button.clear.warning:focus.disabled,.button.clear.warning:focus[disabled],.button.clear.warning:hover,.button.clear.warning:hover.disabled,.button.clear.warning:hover[disabled],.button.clear.warning[disabled]{border-color:transparent}.button.clear.alert{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert:focus,.button.clear.alert:hover{border-color:#67251a;color:#67251a}.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled]{border:1px solid #cc4b37;color:#cc4b37}.button.clear.alert,.button.clear.alert.disabled,.button.clear.alert:focus,.button.clear.alert:focus.disabled,.button.clear.alert:focus[disabled],.button.clear.alert:hover,.button.clear.alert:hover.disabled,.button.clear.alert:hover[disabled],.button.clear.alert[disabled]{border-color:transparent}.button.dropdown::after{display:block;width:0;height:0;border:inset .4em;content:'';border-bottom-width:0;border-top-style:solid;border-color:#fefefe transparent transparent;position:relative;top:.4em;display:inline-block;float:right;margin-left:1em}.button.dropdown.clear::after,.button.dropdown.hollow::after{border-top-color:#1779ba}.button.dropdown.clear.primary::after,.button.dropdown.hollow.primary::after{border-top-color:#1779ba}.button.dropdown.clear.secondary::after,.button.dropdown.hollow.secondary::after{border-top-color:#767676}.button.dropdown.clear.success::after,.button.dropdown.hollow.success::after{border-top-color:#3adb76}.button.dropdown.clear.warning::after,.button.dropdown.hollow.warning::after{border-top-color:#ffae00}.button.dropdown.clear.alert::after,.button.dropdown.hollow.alert::after{border-top-color:#cc4b37}.button.arrow-only::after{top:-.1em;float:none;margin-left:0}a.button:focus,a.button:hover{text-decoration:none}.button-group{margin-bottom:1rem;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.button-group::after,.button-group::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.button-group::after{clear:both}.button-group .button{margin:0;margin-right:1px;margin-bottom:1px;font-size:.9rem;-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.button-group .button:last-child{margin-right:0}.button-group.tiny .button{font-size:.6rem}.button-group.small .button{font-size:.75rem}.button-group.large .button{font-size:1.25rem}.button-group.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.button-group.primary .button{background-color:#1779ba;color:#fefefe}.button-group.primary .button:focus,.button-group.primary .button:hover{background-color:#126195;color:#fefefe}.button-group.secondary .button{background-color:#767676;color:#fefefe}.button-group.secondary .button:focus,.button-group.secondary .button:hover{background-color:#5e5e5e;color:#fefefe}.button-group.success .button{background-color:#3adb76;color:#0a0a0a}.button-group.success .button:focus,.button-group.success .button:hover{background-color:#22bb5b;color:#0a0a0a}.button-group.warning .button{background-color:#ffae00;color:#0a0a0a}.button-group.warning .button:focus,.button-group.warning .button:hover{background-color:#cc8b00;color:#0a0a0a}.button-group.alert .button{background-color:#cc4b37;color:#fefefe}.button-group.alert .button:focus,.button-group.alert .button:hover{background-color:#a53b2a;color:#fefefe}.button-group.stacked,.button-group.stacked-for-medium,.button-group.stacked-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.button-group.stacked .button,.button-group.stacked-for-medium .button,.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%}.button-group.stacked .button:last-child,.button-group.stacked-for-medium .button:last-child,.button-group.stacked-for-small .button:last-child{margin-bottom:0}.button-group.stacked-for-medium.expanded .button,.button-group.stacked-for-small.expanded .button,.button-group.stacked.expanded .button{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}@media print,screen and (min-width:40em){.button-group.stacked-for-small .button{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin-bottom:0}}@media print,screen and (min-width:64em){.button-group.stacked-for-medium .button{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin-bottom:0}}@media screen and (max-width:39.99875em){.button-group.stacked-for-small.expanded{display:block}.button-group.stacked-for-small.expanded .button{display:block;margin-right:0}}@media screen and (max-width:63.99875em){.button-group.stacked-for-medium.expanded{display:block}.button-group.stacked-for-medium.expanded .button{display:block;margin-right:0}}.close-button{position:absolute;color:#8a8a8a;cursor:pointer}[data-whatinput=mouse] .close-button{outline:0}.close-button:focus,.close-button:hover{color:#0a0a0a}.close-button.small{right:.66rem;top:.33em;font-size:1.5em;line-height:1}.close-button,.close-button.medium{right:1rem;top:.5rem;font-size:2em;line-height:1}.label{display:inline-block;padding:.33333rem .5rem;border-radius:0;font-size:.8rem;line-height:1;white-space:nowrap;cursor:default;background:#1779ba;color:#fefefe}.label.primary{background:#1779ba;color:#fefefe}.label.secondary{background:#767676;color:#fefefe}.label.success{background:#3adb76;color:#0a0a0a}.label.warning{background:#ffae00;color:#0a0a0a}.label.alert{background:#cc4b37;color:#fefefe}.progress{height:1rem;margin-bottom:1rem;border-radius:0;background-color:#cacaca}.progress.primary .progress-meter{background-color:#1779ba}.progress.secondary .progress-meter{background-color:#767676}.progress.success .progress-meter{background-color:#3adb76}.progress.warning .progress-meter{background-color:#ffae00}.progress.alert .progress-meter{background-color:#cc4b37}.progress-meter{position:relative;display:block;width:0%;height:100%;background-color:#1779ba}.progress-meter-text{position:absolute;top:50%;left:50%;-webkit-transform:translate(-50%,-50%);-ms-transform:translate(-50%,-50%);transform:translate(-50%,-50%);margin:0;font-size:.75rem;font-weight:700;color:#fefefe;white-space:nowrap}.slider{position:relative;height:.5rem;margin-top:1.25rem;margin-bottom:2.25rem;background-color:#e6e6e6;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-ms-touch-action:none;touch-action:none}.slider-fill{position:absolute;top:0;left:0;display:inline-block;max-width:100%;height:.5rem;background-color:#cacaca;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out}.slider-fill.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider-handle{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);left:0;z-index:1;display:inline-block;width:1.4rem;height:1.4rem;border-radius:0;background-color:#1779ba;-webkit-transition:all .2s ease-in-out;transition:all .2s ease-in-out;-ms-touch-action:manipulation;touch-action:manipulation}[data-whatinput=mouse] .slider-handle{outline:0}.slider-handle:hover{background-color:#14679e}.slider-handle.is-dragging{-webkit-transition:all 0s linear;transition:all 0s linear}.slider.disabled,.slider[disabled]{opacity:.25;cursor:not-allowed}.slider.vertical{display:inline-block;width:.5rem;height:12.5rem;margin:0 1.25rem;-webkit-transform:scale(1,-1);-ms-transform:scale(1,-1);transform:scale(1,-1)}.slider.vertical .slider-fill{top:0;width:.5rem;max-height:100%}.slider.vertical .slider-handle{position:absolute;top:0;left:50%;width:1.4rem;height:1.4rem;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.switch{height:2rem;position:relative;margin-bottom:1rem;outline:0;font-size:.875rem;font-weight:700;color:#fefefe;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.switch-input{position:absolute;margin-bottom:0;opacity:0}.switch-paddle{position:relative;display:block;width:4rem;height:2rem;border-radius:0;background:#cacaca;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;font-weight:inherit;color:inherit;cursor:pointer}input+.switch-paddle{margin:0}.switch-paddle::after{position:absolute;top:.25rem;left:.25rem;display:block;width:1.5rem;height:1.5rem;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0);border-radius:0;background:#fefefe;-webkit-transition:all .25s ease-out;transition:all .25s ease-out;content:''}input:checked~.switch-paddle{background:#1779ba}input:checked~.switch-paddle::after{left:2.25rem}[data-whatinput=mouse] input:focus~.switch-paddle{outline:0}.switch-active,.switch-inactive{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.switch-active{left:8%;display:none}input:checked+label>.switch-active{display:block}.switch-inactive{right:15%}input:checked+label>.switch-inactive{display:none}.switch.tiny{height:1.5rem}.switch.tiny .switch-paddle{width:3rem;height:1.5rem;font-size:.625rem}.switch.tiny .switch-paddle::after{top:.25rem;left:.25rem;width:1rem;height:1rem}.switch.tiny input:checked~.switch-paddle::after{left:1.75rem}.switch.small{height:1.75rem}.switch.small .switch-paddle{width:3.5rem;height:1.75rem;font-size:.75rem}.switch.small .switch-paddle::after{top:.25rem;left:.25rem;width:1.25rem;height:1.25rem}.switch.small input:checked~.switch-paddle::after{left:2rem}.switch.large{height:2.5rem}.switch.large .switch-paddle{width:5rem;height:2.5rem;font-size:1rem}.switch.large .switch-paddle::after{top:.25rem;left:.25rem;width:2rem;height:2rem}.switch.large input:checked~.switch-paddle::after{left:2.75rem}table{border-collapse:collapse;width:100%;margin-bottom:1rem;border-radius:0}tbody,tfoot,thead{border:1px solid #f1f1f1;background-color:#fefefe}caption{padding:.5rem .625rem .625rem;font-weight:700}thead{background:#f8f8f8;color:#0a0a0a}tfoot{background:#f1f1f1;color:#0a0a0a}tfoot tr,thead tr{background:0 0}tfoot td,tfoot th,thead td,thead th{padding:.5rem .625rem .625rem;font-weight:700;text-align:left}tbody td,tbody th{padding:.5rem .625rem .625rem}tbody tr:nth-child(even){border-bottom:0;background-color:#f1f1f1}table.unstriped tbody{background-color:#fefefe}table.unstriped tbody tr{border-bottom:0;border-bottom:1px solid #f1f1f1;background-color:#fefefe}@media screen and (max-width:63.99875em){table.stack thead{display:none}table.stack tfoot{display:none}table.stack td,table.stack th,table.stack tr{display:block}table.stack td{border-top:0}}table.scroll{display:block;width:100%;overflow-x:auto}table.hover thead tr:hover{background-color:#f3f3f3}table.hover tfoot tr:hover{background-color:#ececec}table.hover tbody tr:hover{background-color:#f9f9f9}table.hover:not(.unstriped) tr:nth-of-type(even):hover{background-color:#ececec}.table-scroll{overflow-x:auto}.badge{display:inline-block;min-width:2.1em;padding:.3em;border-radius:50%;font-size:.6rem;text-align:center;background:#1779ba;color:#fefefe}.badge.primary{background:#1779ba;color:#fefefe}.badge.secondary{background:#767676;color:#fefefe}.badge.success{background:#3adb76;color:#0a0a0a}.badge.warning{background:#ffae00;color:#0a0a0a}.badge.alert{background:#cc4b37;color:#fefefe}.breadcrumbs{margin:0 0 1rem 0;list-style:none}.breadcrumbs::after,.breadcrumbs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.breadcrumbs::after{clear:both}.breadcrumbs li{float:left;font-size:.6875rem;color:#0a0a0a;cursor:default;text-transform:uppercase}.breadcrumbs li:not(:last-child)::after{position:relative;margin:0 .75rem;opacity:1;content:"/";color:#cacaca}.breadcrumbs a{color:#1779ba}.breadcrumbs a:hover{text-decoration:underline}.breadcrumbs .disabled{color:#cacaca;cursor:not-allowed}.callout{position:relative;margin:0 0 1rem 0;padding:1rem;border:1px solid rgba(10,10,10,.25);border-radius:0;background-color:#fff;color:#0a0a0a}.callout>:first-child{margin-top:0}.callout>:last-child{margin-bottom:0}.callout.primary{background-color:#d7ecfa;color:#0a0a0a}.callout.secondary{background-color:#eaeaea;color:#0a0a0a}.callout.success{background-color:#e1faea;color:#0a0a0a}.callout.warning{background-color:#fff3d9;color:#0a0a0a}.callout.alert{background-color:#f7e4e1;color:#0a0a0a}.callout.small{padding-top:.5rem;padding-right:.5rem;padding-bottom:.5rem;padding-left:.5rem}.callout.large{padding-top:3rem;padding-right:3rem;padding-bottom:3rem;padding-left:3rem}.card{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-grow:1;-ms-flex-positive:1;flex-grow:1;margin-bottom:1rem;border:1px solid #e6e6e6;border-radius:0;background:#fefefe;-webkit-box-shadow:none;box-shadow:none;overflow:hidden;color:#0a0a0a}.card>:last-child{margin-bottom:0}.card-divider{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;padding:1rem;background:#e6e6e6}.card-divider>:last-child{margin-bottom:0}.card-section{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto;padding:1rem}.card-section>:last-child{margin-bottom:0}.card-image{min-height:1px}.dropdown-pane{position:absolute;z-index:10;display:none;width:300px;padding:1rem;visibility:hidden;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;font-size:1rem}.dropdown-pane.is-opening{display:block}.dropdown-pane.is-open{display:block;visibility:visible}.dropdown-pane.tiny{width:100px}.dropdown-pane.small{width:200px}.dropdown-pane.large{width:400px}.pagination{margin-left:0;margin-bottom:1rem}.pagination::after,.pagination::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.pagination::after{clear:both}.pagination li{margin-right:.0625rem;border-radius:0;font-size:.875rem;display:none}.pagination li:first-child,.pagination li:last-child{display:inline-block}@media print,screen and (min-width:40em){.pagination li{display:inline-block}}.pagination a,.pagination button{display:block;padding:.1875rem .625rem;border-radius:0;color:#0a0a0a}.pagination a:hover,.pagination button:hover{background:#e6e6e6}.pagination .current{padding:.1875rem .625rem;background:#1779ba;color:#fefefe;cursor:default}.pagination .disabled{padding:.1875rem .625rem;color:#cacaca;cursor:not-allowed}.pagination .disabled:hover{background:0 0}.pagination .ellipsis::after{padding:.1875rem .625rem;content:'\2026';color:#0a0a0a}.pagination-previous a::before,.pagination-previous.disabled::before{display:inline-block;margin-right:.5rem;content:'\00ab'}.pagination-next a::after,.pagination-next.disabled::after{display:inline-block;margin-left:.5rem;content:'\00bb'}.has-tip{position:relative;display:inline-block;border-bottom:dotted 1px #8a8a8a;font-weight:700;cursor:help}.tooltip{position:absolute;top:calc(100% + .6495rem);z-index:1200;max-width:10rem;padding:.75rem;border-radius:0;background-color:#0a0a0a;font-size:80%;color:#fefefe}.tooltip::before{position:absolute}.tooltip.bottom::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-top-width:0;border-bottom-style:solid;border-color:transparent transparent #0a0a0a;bottom:100%}.tooltip.bottom.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.top::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-bottom-width:0;border-top-style:solid;border-color:#0a0a0a transparent transparent;top:100%;bottom:auto}.tooltip.top.align-center::before{left:50%;-webkit-transform:translateX(-50%);-ms-transform:translateX(-50%);transform:translateX(-50%)}.tooltip.left::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #0a0a0a;left:100%}.tooltip.left.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.right::before{display:block;width:0;height:0;border:inset .75rem;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #0a0a0a transparent transparent;right:100%;left:auto}.tooltip.right.align-center::before{bottom:auto;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%)}.tooltip.align-top::before{bottom:auto;top:10%}.tooltip.align-bottom::before{bottom:10%;top:auto}.tooltip.align-left::before{left:10%;right:auto}.tooltip.align-right::before{left:auto;right:10%}.accordion{margin-left:0;background:#fefefe;list-style-type:none}.accordion[disabled] .accordion-title{cursor:not-allowed}.accordion-item:first-child>:first-child{border-radius:0}.accordion-item:last-child>:last-child{border-radius:0}.accordion-title{position:relative;display:block;padding:1.25rem 1rem;border:1px solid #e6e6e6;border-bottom:0;font-size:.75rem;line-height:1;color:#1779ba}:last-child:not(.is-active)>.accordion-title{border-bottom:1px solid #e6e6e6;border-radius:0}.accordion-title:focus,.accordion-title:hover{background-color:#e6e6e6}.accordion-title::before{position:absolute;top:50%;right:1rem;margin-top:-.5rem;content:'+'}.is-active>.accordion-title::before{content:'\2013'}.accordion-content{display:none;padding:1rem;border:1px solid #e6e6e6;border-bottom:0;background-color:#fefefe;color:#0a0a0a}:last-child>.accordion-content:last-child{border-bottom:1px solid #e6e6e6}.media-object{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;margin-bottom:1rem;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.media-object img{max-width:none}@media screen and (max-width:39.99875em){.media-object.stack-for-small{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}}.media-object-section{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.media-object-section:first-child{padding-right:1rem}.media-object-section:last-child:not(:nth-child(2)){padding-left:1rem}.media-object-section>:last-child{margin-bottom:0}@media screen and (max-width:39.99875em){.stack-for-small .media-object-section{padding:0;padding-bottom:1rem;-webkit-flex-basis:100%;-ms-flex-preferred-size:100%;flex-basis:100%;max-width:100%}.stack-for-small .media-object-section img{width:100%}}.media-object-section.main-section{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.orbit{position:relative}.orbit-container{position:relative;height:0;margin:0;list-style:none;overflow:hidden}.orbit-slide{width:100%;position:absolute}.orbit-slide.no-motionui.is-active{top:0;left:0}.orbit-figure{margin:0}.orbit-image{width:100%;max-width:100%;margin:0}.orbit-caption{position:absolute;bottom:0;width:100%;margin-bottom:0;padding:1rem;background-color:rgba(10,10,10,.5);color:#fefefe}.orbit-next,.orbit-previous{position:absolute;top:50%;-webkit-transform:translateY(-50%);-ms-transform:translateY(-50%);transform:translateY(-50%);z-index:10;padding:1rem;color:#fefefe}[data-whatinput=mouse] .orbit-next,[data-whatinput=mouse] .orbit-previous{outline:0}.orbit-next:active,.orbit-next:focus,.orbit-next:hover,.orbit-previous:active,.orbit-previous:focus,.orbit-previous:hover{background-color:rgba(10,10,10,.5)}.orbit-previous{left:0}.orbit-next{left:auto;right:0}.orbit-bullets{position:relative;margin-top:.8rem;margin-bottom:.8rem;text-align:center}[data-whatinput=mouse] .orbit-bullets{outline:0}.orbit-bullets button{width:1.2rem;height:1.2rem;margin:.1rem;border-radius:50%;background-color:#cacaca}.orbit-bullets button:hover{background-color:#8a8a8a}.orbit-bullets button.is-active{background-color:#8a8a8a}.flex-video,.responsive-embed{position:relative;height:0;margin-bottom:1rem;padding-bottom:75%;overflow:hidden}.flex-video embed,.flex-video iframe,.flex-video object,.flex-video video,.responsive-embed embed,.responsive-embed iframe,.responsive-embed object,.responsive-embed video{position:absolute;top:0;left:0;width:100%;height:100%}.flex-video.widescreen,.responsive-embed.widescreen{padding-bottom:56.25%}.tabs{margin:0;border:1px solid #e6e6e6;background:#fefefe;list-style-type:none}.tabs::after,.tabs::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.tabs::after{clear:both}.tabs.vertical>li{display:block;float:none;width:auto}.tabs.simple>li>a{padding:0}.tabs.simple>li>a:hover{background:0 0}.tabs.primary{background:#1779ba}.tabs.primary>li>a{color:#fefefe}.tabs.primary>li>a:focus,.tabs.primary>li>a:hover{background:#1673b1}.tabs-title{float:left}.tabs-title>a{display:block;padding:1.25rem 1.5rem;font-size:.75rem;line-height:1;color:#1779ba}[data-whatinput=mouse] .tabs-title>a{outline:0}.tabs-title>a:hover{background:#fefefe;color:#1468a0}.tabs-title>a:focus,.tabs-title>a[aria-selected=true]{background:#e6e6e6;color:#1779ba}.tabs-content{border:1px solid #e6e6e6;border-top:0;background:#fefefe;color:#0a0a0a;-webkit-transition:all .5s ease;transition:all .5s ease}.tabs-content.vertical{border:1px solid #e6e6e6;border-left:0}.tabs-panel{display:none;padding:1rem}.tabs-panel.is-active{display:block}.thumbnail{display:inline-block;max-width:100%;margin-bottom:1rem;border:4px solid #fefefe;border-radius:0;-webkit-box-shadow:0 0 0 1px rgba(10,10,10,.2);box-shadow:0 0 0 1px rgba(10,10,10,.2);line-height:0}a.thumbnail{-webkit-transition:-webkit-box-shadow .2s ease-out;transition:-webkit-box-shadow .2s ease-out;transition:box-shadow .2s ease-out;transition:box-shadow .2s ease-out,-webkit-box-shadow .2s ease-out}a.thumbnail:focus,a.thumbnail:hover{-webkit-box-shadow:0 0 6px 1px rgba(23,121,186,.5);box-shadow:0 0 6px 1px rgba(23,121,186,.5)}a.thumbnail image{-webkit-box-shadow:none;box-shadow:none}.menu{padding:0;margin:0;list-style:none;position:relative;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}[data-whatinput=mouse] .menu li{outline:0}.menu .button,.menu a{line-height:1;text-decoration:none;display:block;padding:.7rem 1rem}.menu a,.menu button,.menu input,.menu select{margin-bottom:0}.menu input{display:inline-block}.menu,.menu.horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.simple{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.menu.simple li+li{margin-left:1rem}.menu.simple a{padding:0}@media print,screen and (min-width:40em){.menu.medium-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.medium-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.medium-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.medium-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}@media print,screen and (min-width:64em){.menu.large-horizontal{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.menu.large-vertical{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.menu.large-expanded li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.menu.large-simple li{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}}.menu.nested{margin-right:0;margin-left:1rem}.menu.icons a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-bottom a,.menu.icon-left a,.menu.icon-right a,.menu.icon-top a{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.menu.icon-left li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-left li a i,.menu.icon-left li a img,.menu.icon-left li a svg{margin-right:.25rem}.menu.icon-right li a{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-flow:row nowrap;-ms-flex-flow:row nowrap;flex-flow:row nowrap}.menu.icon-right li a i,.menu.icon-right li a img,.menu.icon-right li a svg{margin-left:.25rem}.menu.icon-top li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-top li a i,.menu.icon-top li a img,.menu.icon-top li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu.icon-bottom li a{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-flow:column nowrap;-ms-flex-flow:column nowrap;flex-flow:column nowrap}.menu.icon-bottom li a i,.menu.icon-bottom li a img,.menu.icon-bottom li a svg{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch;margin-bottom:.25rem;text-align:center}.menu .is-active>a{background:#1779ba;color:#fefefe}.menu .active>a{background:#1779ba;color:#fefefe}.menu.align-left{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-right li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.menu.align-right li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu.align-right.vertical li{display:block;text-align:right}.menu.align-right.vertical li .submenu li{text-align:right}.menu.align-right .nested{margin-right:1rem;margin-left:0}.menu.align-center li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu.align-center li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.menu .menu-text{padding:.7rem 1rem;font-weight:700;line-height:1;color:inherit}.menu-centered>.menu{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.menu-centered>.menu li .submenu li{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.no-js [data-responsive-menu] ul{display:none}.menu-icon{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#fefefe;-webkit-box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;box-shadow:0 7px 0 #fefefe,0 14px 0 #fefefe;content:''}.menu-icon:hover::after{background:#cacaca;-webkit-box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca;box-shadow:0 7px 0 #cacaca,0 14px 0 #cacaca}.menu-icon.dark{position:relative;display:inline-block;vertical-align:middle;width:20px;height:16px;cursor:pointer}.menu-icon.dark::after{position:absolute;top:0;left:0;display:block;width:100%;height:2px;background:#0a0a0a;-webkit-box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;box-shadow:0 7px 0 #0a0a0a,0 14px 0 #0a0a0a;content:''}.menu-icon.dark:hover::after{background:#8a8a8a;-webkit-box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a;box-shadow:0 7px 0 #8a8a8a,0 14px 0 #8a8a8a}.accordion-menu li{width:100%}.accordion-menu a{padding:.7rem 1rem}.accordion-menu .is-accordion-submenu a{padding:.7rem 1rem}.accordion-menu .nested.is-accordion-submenu{margin-right:0;margin-left:1rem}.accordion-menu.align-right .nested.is-accordion-submenu{margin-right:1rem;margin-left:0}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a{position:relative}.accordion-menu .is-accordion-submenu-parent:not(.has-submenu-toggle)>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;position:absolute;top:50%;margin-top:-3px;right:1rem}.accordion-menu.align-left .is-accordion-submenu-parent>a::after{right:1rem;left:auto}.accordion-menu.align-right .is-accordion-submenu-parent>a::after{right:auto;left:1rem}.accordion-menu .is-accordion-submenu-parent[aria-expanded=true]>a::after{-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.is-accordion-submenu-parent{position:relative}.has-submenu-toggle>a{margin-right:40px}.submenu-toggle{position:absolute;top:0;right:0;width:40px;height:40px;cursor:pointer}.submenu-toggle::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;top:0;bottom:0;margin:auto}.submenu-toggle[aria-expanded=true]::after{-webkit-transform:scaleY(-1);-ms-transform:scaleY(-1);transform:scaleY(-1);-webkit-transform-origin:50% 50%;-ms-transform-origin:50% 50%;transform-origin:50% 50%}.submenu-toggle-text{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.is-drilldown{position:relative;overflow:hidden}.is-drilldown li{display:block}.is-drilldown.animate-height{-webkit-transition:height .5s;transition:height .5s}.drilldown a{padding:.7rem 1rem;background:#fefefe}.drilldown .is-drilldown-submenu{position:absolute;top:0;left:100%;z-index:-1;width:100%;background:#fefefe;-webkit-transition:-webkit-transform .15s linear;transition:-webkit-transform .15s linear;transition:transform .15s linear;transition:transform .15s linear,-webkit-transform .15s linear}.drilldown .is-drilldown-submenu.is-active{z-index:1;display:block;-webkit-transform:translateX(-100%);-ms-transform:translateX(-100%);transform:translateX(-100%)}.drilldown .is-drilldown-submenu.is-closing{-webkit-transform:translateX(100%);-ms-transform:translateX(100%);transform:translateX(100%)}.drilldown .is-drilldown-submenu a{padding:.7rem 1rem}.drilldown .nested.is-drilldown-submenu{margin-right:0;margin-left:0}.drilldown .drilldown-submenu-cover-previous{min-height:100%}.drilldown .is-drilldown-submenu-parent>a{position:relative}.drilldown .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;position:absolute;top:50%;margin-top:-6px;right:1rem}.drilldown.align-left .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba;right:1rem;left:auto}.drilldown.align-right .is-drilldown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:1rem}.drilldown .js-drilldown-back>a::before{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;display:inline-block;vertical-align:middle;margin-right:.75rem}.dropdown.menu>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}[data-whatinput=mouse] .dropdown.menu a{outline:0}.dropdown.menu>li>a{padding:.7rem 1rem}.dropdown.menu>li.is-active>a{background:0 0;color:#1779ba}.no-js .dropdown.menu ul{display:none}.dropdown.menu .nested.is-dropdown-submenu{margin-right:0;margin-left:0}.dropdown.menu.vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.vertical>li>a::after{right:14px}.dropdown.menu.vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}@media print,screen and (min-width:40em){.dropdown.menu.medium-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.medium-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.medium-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.medium-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.medium-vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.medium-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.medium-vertical>li>a::after{right:14px}.dropdown.menu.medium-vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.medium-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}@media print,screen and (min-width:64em){.dropdown.menu.large-horizontal>li.opens-left>.is-dropdown-submenu{top:100%;right:0;left:auto}.dropdown.menu.large-horizontal>li.opens-right>.is-dropdown-submenu{top:100%;right:auto;left:0}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a{position:relative;padding-right:1.5rem}.dropdown.menu.large-horizontal>li.is-dropdown-submenu-parent>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-bottom-width:0;border-top-style:solid;border-color:#1779ba transparent transparent;right:5px;left:auto;margin-top:-3px}.dropdown.menu.large-vertical>li .is-dropdown-submenu{top:0}.dropdown.menu.large-vertical>li.opens-left>.is-dropdown-submenu{top:0;right:100%;left:auto}.dropdown.menu.large-vertical>li.opens-right>.is-dropdown-submenu{right:auto;left:100%}.dropdown.menu.large-vertical>li>a::after{right:14px}.dropdown.menu.large-vertical>li.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.dropdown.menu.large-vertical>li.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}}.dropdown.menu.align-right .is-dropdown-submenu.first-sub{top:100%;right:0;left:auto}.is-dropdown-menu.vertical{width:100px}.is-dropdown-menu.vertical.align-right{float:right}.is-dropdown-submenu-parent{position:relative}.is-dropdown-submenu-parent a::after{position:absolute;top:50%;right:5px;left:auto;margin-top:-6px}.is-dropdown-submenu-parent.opens-inner>.is-dropdown-submenu{top:100%;left:auto}.is-dropdown-submenu-parent.opens-left>.is-dropdown-submenu{right:100%;left:auto}.is-dropdown-submenu-parent.opens-right>.is-dropdown-submenu{right:auto;left:100%}.is-dropdown-submenu{position:absolute;top:0;left:100%;z-index:1;display:none;min-width:200px;border:1px solid #cacaca;background:#fefefe}.dropdown .is-dropdown-submenu a{padding:.7rem 1rem}.is-dropdown-submenu .is-dropdown-submenu-parent>a::after{right:14px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-left>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-left-width:0;border-right-style:solid;border-color:transparent #1779ba transparent transparent;right:auto;left:5px}.is-dropdown-submenu .is-dropdown-submenu-parent.opens-right>a::after{display:block;width:0;height:0;border:inset 6px;content:'';border-right-width:0;border-left-style:solid;border-color:transparent transparent transparent #1779ba}.is-dropdown-submenu .is-dropdown-submenu{margin-top:-1px}.is-dropdown-submenu>li{width:100%}.is-dropdown-submenu.js-dropdown-active{display:block}.is-off-canvas-open{overflow:hidden}.js-off-canvas-overlay{position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;-webkit-transition:opacity .5s ease,visibility .5s ease;transition:opacity .5s ease,visibility .5s ease;background:rgba(254,254,254,.25);opacity:0;visibility:hidden;overflow:hidden}.js-off-canvas-overlay.is-visible{opacity:1;visibility:visible}.js-off-canvas-overlay.is-closable{cursor:pointer}.js-off-canvas-overlay.is-overlay-absolute{position:absolute}.js-off-canvas-overlay.is-overlay-fixed{position:fixed}.off-canvas-wrapper{position:relative;overflow:hidden}.off-canvas{position:fixed;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas{outline:0}.off-canvas.is-transition-push{z-index:12}.off-canvas.is-closed{visibility:hidden}.off-canvas.is-transition-overlap{z-index:13}.off-canvas.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-absolute{position:absolute;z-index:12;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden;background:#e6e6e6}[data-whatinput=mouse] .off-canvas-absolute{outline:0}.off-canvas-absolute.is-transition-push{z-index:12}.off-canvas-absolute.is-closed{visibility:hidden}.off-canvas-absolute.is-transition-overlap{z-index:13}.off-canvas-absolute.is-transition-overlap.is-open{-webkit-box-shadow:0 0 10px rgba(10,10,10,.7);box-shadow:0 0 10px rgba(10,10,10,.7)}.off-canvas-absolute.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.position-left{top:0;left:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.off-canvas-content .off-canvas.position-left.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-left.has-transition-push{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.position-left.is-transition-push{-webkit-box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset -13px 0 20px -13px rgba(10,10,10,.25)}.position-right{top:0;right:0;height:100%;overflow-y:auto;width:250px;-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right{-webkit-transform:translateX(250px);-ms-transform:translateX(250px);transform:translateX(250px)}.off-canvas-content .off-canvas.position-right.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-right.has-transition-push{-webkit-transform:translateX(-250px);-ms-transform:translateX(-250px);transform:translateX(-250px)}.position-right.is-transition-push{-webkit-box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25);box-shadow:inset 13px 0 20px -13px rgba(10,10,10,.25)}.position-top{top:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.off-canvas-content .off-canvas.position-top.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-top.has-transition-push{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.position-top.is-transition-push{-webkit-box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 -13px 20px -13px rgba(10,10,10,.25)}.position-bottom{bottom:0;left:0;width:100%;overflow-x:auto;height:250px;-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom{-webkit-transform:translateY(250px);-ms-transform:translateY(250px);transform:translateY(250px)}.off-canvas-content .off-canvas.position-bottom.is-transition-overlap.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content.is-open-bottom.has-transition-push{-webkit-transform:translateY(-250px);-ms-transform:translateY(-250px);transform:translateY(-250px)}.position-bottom.is-transition-push{-webkit-box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25);box-shadow:inset 0 13px 20px -13px rgba(10,10,10,.25)}.off-canvas-content{-webkit-transform:none;-ms-transform:none;transform:none;-webkit-transition:-webkit-transform .5s ease;transition:-webkit-transform .5s ease;transition:transform .5s ease;transition:transform .5s ease,-webkit-transform .5s ease;-webkit-backface-visibility:hidden;backface-visibility:hidden}.off-canvas-content.has-transition-push{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}.off-canvas-content .off-canvas.is-open{-webkit-transform:translate(0,0);-ms-transform:translate(0,0);transform:translate(0,0)}@media print,screen and (min-width:40em){.position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-medium .close-button{display:none}.off-canvas-content .position-left.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-medium~.off-canvas-content{margin-left:250px}.position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-medium .close-button{display:none}.off-canvas-content .position-right.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-medium~.off-canvas-content{margin-right:250px}.position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-medium .close-button{display:none}.off-canvas-content .position-top.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-medium~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-medium .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-medium{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-medium~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:64em){.position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-left.reveal-for-large .close-button{display:none}.off-canvas-content .position-left.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-left{margin-left:250px}.position-left.reveal-for-large~.off-canvas-content{margin-left:250px}.position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-right.reveal-for-large .close-button{display:none}.off-canvas-content .position-right.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-right{margin-right:250px}.position-right.reveal-for-large~.off-canvas-content{margin-right:250px}.position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-top.reveal-for-large .close-button{display:none}.off-canvas-content .position-top.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-top{margin-top:250px}.position-top.reveal-for-large~.off-canvas-content{margin-top:250px}.position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none;z-index:12;-webkit-transition:none;transition:none;visibility:visible}.position-bottom.reveal-for-large .close-button{display:none}.off-canvas-content .position-bottom.reveal-for-large{-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas-content.has-reveal-bottom{margin-bottom:250px}.position-bottom.reveal-for-large~.off-canvas-content{margin-bottom:250px}}@media print,screen and (min-width:40em){.off-canvas.in-canvas-for-medium{visibility:visible;height:auto;position:static;background:0 0;width:auto;overflow:visible;-webkit-transition:none;transition:none}.off-canvas.in-canvas-for-medium.position-bottom,.off-canvas.in-canvas-for-medium.position-left,.off-canvas.in-canvas-for-medium.position-right,.off-canvas.in-canvas-for-medium.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-medium .close-button{display:none}}@media print,screen and (min-width:64em){.off-canvas.in-canvas-for-large{visibility:visible;height:auto;position:static;background:0 0;width:auto;overflow:visible;-webkit-transition:none;transition:none}.off-canvas.in-canvas-for-large.position-bottom,.off-canvas.in-canvas-for-large.position-left,.off-canvas.in-canvas-for-large.position-right,.off-canvas.in-canvas-for-large.position-top{-webkit-box-shadow:none;box-shadow:none;-webkit-transform:none;-ms-transform:none;transform:none}.off-canvas.in-canvas-for-large .close-button{display:none}}html.is-reveal-open{position:fixed;width:100%;overflow-y:hidden}html.is-reveal-open.zf-has-scroll{overflow-y:scroll}html.is-reveal-open body{overflow-y:hidden}.reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1005;display:none;background-color:rgba(10,10,10,.45);overflow-y:auto}.reveal{z-index:1006;-webkit-backface-visibility:hidden;backface-visibility:hidden;display:none;padding:1rem;border:1px solid #cacaca;border-radius:0;background-color:#fefefe;position:relative;top:100px;margin-right:auto;margin-left:auto;overflow-y:auto}[data-whatinput=mouse] .reveal{outline:0}@media print,screen and (min-width:40em){.reveal{min-height:0}}.reveal .column{min-width:0}.reveal>:last-child{margin-bottom:0}@media print,screen and (min-width:40em){.reveal{width:600px;max-width:75rem}}.reveal.collapse{padding:0}@media print,screen and (min-width:40em){.reveal.tiny{width:30%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.small{width:50%;max-width:75rem}}@media print,screen and (min-width:40em){.reveal.large{width:90%;max-width:75rem}}.reveal.full{top:0;right:0;bottom:0;left:0;width:100%;max-width:none;height:100%;min-height:100%;margin-left:0;border:0;border-radius:0}@media screen and (max-width:39.99875em){.reveal{top:0;right:0;bottom:0;left:0;width:100%;max-width:none;height:100%;min-height:100%;margin-left:0;border:0;border-radius:0}}.reveal.without-overlay{position:fixed}.sticky-container{position:relative}.sticky{position:relative;z-index:0;-webkit-transform:translate3d(0,0,0);transform:translate3d(0,0,0)}.sticky.is-stuck{position:fixed;z-index:5;width:100%}.sticky.is-stuck.is-at-top{top:0}.sticky.is-stuck.is-at-bottom{bottom:0}.sticky.is-anchored{position:relative;right:auto;left:auto}.sticky.is-anchored.is-at-bottom{bottom:0}.title-bar{padding:.5rem;background:#0a0a0a;color:#fefefe;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.title-bar .menu-icon{margin-left:.25rem;margin-right:.25rem}.title-bar-left,.title-bar-right{-webkit-box-flex:1;-webkit-flex:1 1 0px;-ms-flex:1 1 0px;flex:1 1 0px}.title-bar-right{text-align:right}.title-bar-title{display:inline-block;vertical-align:middle;font-weight:700}.top-bar{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap;-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;padding:.5rem;-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar,.top-bar ul{background-color:#e6e6e6}.top-bar input{max-width:200px;margin-right:1rem}.top-bar .input-group-field{width:100%;margin-right:0}.top-bar input.button{width:auto}.top-bar .top-bar-left,.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}@media print,screen and (min-width:40em){.top-bar{-webkit-flex-wrap:nowrap;-ms-flex-wrap:nowrap;flex-wrap:nowrap}.top-bar .top-bar-left{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto;margin-right:auto}.top-bar .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto;margin-left:auto}}@media screen and (max-width:63.99875em){.top-bar.stacked-for-medium{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-medium .top-bar-left,.top-bar.stacked-for-medium .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}@media screen and (max-width:74.99875em){.top-bar.stacked-for-large{-webkit-flex-wrap:wrap;-ms-flex-wrap:wrap;flex-wrap:wrap}.top-bar.stacked-for-large .top-bar-left,.top-bar.stacked-for-large .top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 100%;-ms-flex:0 0 100%;flex:0 0 100%;max-width:100%}}.top-bar-title{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto;margin:.5rem 1rem .5rem 0}.top-bar-left,.top-bar-right{-webkit-box-flex:0;-webkit-flex:0 0 auto;-ms-flex:0 0 auto;flex:0 0 auto}.float-left{float:left!important}.float-right{float:right!important}.float-center{display:block;margin-right:auto;margin-left:auto}.clearfix::after,.clearfix::before{display:table;content:' ';-webkit-flex-basis:0;-ms-flex-preferred-size:0;flex-basis:0;-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.clearfix::after{clear:both}.align-left{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.align-right{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-justify{-webkit-box-pack:justify;-webkit-justify-content:space-between;-ms-flex-pack:justify;justify-content:space-between}.align-spaced{-webkit-justify-content:space-around;-ms-flex-pack:distribute;justify-content:space-around}.align-left.vertical.menu>li>a{-webkit-box-pack:start;-webkit-justify-content:flex-start;-ms-flex-pack:start;justify-content:flex-start}.align-right.vertical.menu>li>a{-webkit-box-pack:end;-webkit-justify-content:flex-end;-ms-flex-pack:end;justify-content:flex-end}.align-center.vertical.menu>li>a{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center}.align-top{-webkit-box-align:start;-webkit-align-items:flex-start;-ms-flex-align:start;align-items:flex-start}.align-self-top{-webkit-align-self:flex-start;-ms-flex-item-align:start;align-self:flex-start}.align-bottom{-webkit-box-align:end;-webkit-align-items:flex-end;-ms-flex-align:end;align-items:flex-end}.align-self-bottom{-webkit-align-self:flex-end;-ms-flex-item-align:end;align-self:flex-end}.align-middle{-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center}.align-self-middle{-webkit-align-self:center;-ms-flex-item-align:center;align-self:center}.align-stretch{-webkit-box-align:stretch;-webkit-align-items:stretch;-ms-flex-align:stretch;align-items:stretch}.align-self-stretch{-webkit-align-self:stretch;-ms-flex-item-align:stretch;align-self:stretch}.align-center-middle{-webkit-box-pack:center;-webkit-justify-content:center;-ms-flex-pack:center;justify-content:center;-webkit-box-align:center;-webkit-align-items:center;-ms-flex-align:center;align-items:center;-webkit-align-content:center;-ms-flex-line-pack:center;align-content:center}.small-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.small-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.small-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.small-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.small-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.small-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}@media print,screen and (min-width:40em){.medium-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.medium-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.medium-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.medium-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.medium-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.medium-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}@media print,screen and (min-width:64em){.large-order-1{-webkit-box-ordinal-group:2;-webkit-order:1;-ms-flex-order:1;order:1}.large-order-2{-webkit-box-ordinal-group:3;-webkit-order:2;-ms-flex-order:2;order:2}.large-order-3{-webkit-box-ordinal-group:4;-webkit-order:3;-ms-flex-order:3;order:3}.large-order-4{-webkit-box-ordinal-group:5;-webkit-order:4;-ms-flex-order:4;order:4}.large-order-5{-webkit-box-ordinal-group:6;-webkit-order:5;-ms-flex-order:5;order:5}.large-order-6{-webkit-box-ordinal-group:7;-webkit-order:6;-ms-flex-order:6;order:6}}.flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}@media print,screen and (min-width:40em){.medium-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.medium-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.medium-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.medium-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.medium-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.medium-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.medium-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.medium-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}@media print,screen and (min-width:64em){.large-flex-container{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex}.large-flex-child-auto{-webkit-box-flex:1;-webkit-flex:1 1 auto;-ms-flex:1 1 auto;flex:1 1 auto}.large-flex-child-grow{-webkit-box-flex:1;-webkit-flex:1 0 auto;-ms-flex:1 0 auto;flex:1 0 auto}.large-flex-child-shrink{-webkit-box-flex:0;-webkit-flex:0 1 auto;-ms-flex:0 1 auto;flex:0 1 auto}.large-flex-dir-row{-webkit-box-orient:horizontal;-webkit-box-direction:normal;-webkit-flex-direction:row;-ms-flex-direction:row;flex-direction:row}.large-flex-dir-row-reverse{-webkit-box-orient:horizontal;-webkit-box-direction:reverse;-webkit-flex-direction:row-reverse;-ms-flex-direction:row-reverse;flex-direction:row-reverse}.large-flex-dir-column{-webkit-box-orient:vertical;-webkit-box-direction:normal;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column}.large-flex-dir-column-reverse{-webkit-box-orient:vertical;-webkit-box-direction:reverse;-webkit-flex-direction:column-reverse;-ms-flex-direction:column-reverse;flex-direction:column-reverse}}.hide{display:none!important}.invisible{visibility:hidden}@media screen and (max-width:39.99875em){.hide-for-small-only{display:none!important}}@media screen and (max-width:0em),screen and (min-width:40em){.show-for-small-only{display:none!important}}@media print,screen and (min-width:40em){.hide-for-medium{display:none!important}}@media screen and (max-width:39.99875em){.show-for-medium{display:none!important}}@media screen and (min-width:40em) and (max-width:63.99875em){.hide-for-medium-only{display:none!important}}@media screen and (max-width:39.99875em),screen and (min-width:64em){.show-for-medium-only{display:none!important}}@media print,screen and (min-width:64em){.hide-for-large{display:none!important}}@media screen and (max-width:63.99875em){.show-for-large{display:none!important}}@media screen and (min-width:64em) and (max-width:74.99875em){.hide-for-large-only{display:none!important}}@media screen and (max-width:63.99875em),screen and (min-width:75em){.show-for-large-only{display:none!important}}.show-for-sr,.show-on-focus{position:absolute!important;width:1px;height:1px;padding:0;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.show-on-focus:active,.show-on-focus:focus{position:static!important;width:auto;height:auto;overflow:visible;clip:auto;white-space:normal}.hide-for-portrait,.show-for-landscape{display:block!important}@media screen and (orientation:landscape){.hide-for-portrait,.show-for-landscape{display:block!important}}@media screen and (orientation:portrait){.hide-for-portrait,.show-for-landscape{display:none!important}}.hide-for-landscape,.show-for-portrait{display:none!important}@media screen and (orientation:landscape){.hide-for-landscape,.show-for-portrait{display:none!important}}@media screen and (orientation:portrait){.hide-for-landscape,.show-for-portrait{display:block!important}}
+/*# sourceMappingURL=foundation.min.css.map */
diff --git a/dist/css/foundation.min.css.map b/dist/css/foundation.min.css.map
new file mode 100644 (file)
index 0000000..ec7f6a5
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.min.css"],"names":[],"mappings":"iBAOA,aAAc,4BACZ,QAAsC,cAAf,cAAd,aACP,MAAO,KACP,KAAM,KACN,OAAQ,EAAE,MAEd,4EACA,KACE,YAAa,KACb,yBAA0B,KAE5B,KACE,OAAQ,EAEV,GACE,UAAW,IACX,OAAQ,MAAO,EAEjB,GACE,mBAAoB,YACZ,WAAY,YACpB,OAAQ,EACR,SAAU,QAEZ,IACE,YAAa,SAAS,CAAE,UACxB,UAAW,IAEb,EACE,iBAAkB,YAEpB,YACE,cAAe,KACf,gBAAiB,UACjB,wBAAyB,UAAU,OAC3B,gBAAiB,UAAU,OAErC,EACA,OACE,YAAa,OAEf,KACA,IACA,KACE,YAAa,SAAS,CAAE,UACxB,UAAW,IAEb,MACE,UAAW,IAEb,IACA,IACE,UAAW,IACX,YAAa,EACb,SAAU,SACV,eAAgB,SAElB,IACE,OAAQ,OAEV,IACE,IAAK,MAEP,IACE,aAAc,KAEhB,OACA,MACA,SACA,OACA,SACE,YAAa,QACb,UAAW,KACX,YAAa,KACb,OAAQ,EAEV,OACA,MACE,SAAU,QAEZ,OACA,OACE,eAAgB,KAGlB,cACA,aACA,cAHA,OAIE,mBAAoB,OAGtB,gCACA,+BACA,gCAHA,yBAIE,aAAc,KACd,QAAS,EAGX,6BACA,4BACA,6BAHA,sBAIE,QAAS,IAAI,OAAO,WAEtB,SACE,QAAS,MAAO,MAAO,OAEzB,OACE,mBAAoB,WACZ,WAAY,WACpB,MAAO,QACP,QAAS,MACT,UAAW,KACX,QAAS,EACT,YAAa,OAEf,SACE,eAAgB,SAElB,SACE,SAAU,KAEZ,gBACA,aACE,mBAAoB,WACZ,WAAY,WACpB,QAAS,EAEX,yCACA,yCACE,OAAQ,KAEV,cACE,mBAAoB,UACpB,eAAgB,KAElB,yCACE,mBAAoB,KAEtB,6BACE,mBAAoB,OACpB,KAAM,QAER,QACE,QAAS,MAEX,QACE,QAAS,UAEX,SACE,QAAS,KAEX,SACE,QAAS,KAEX,eACE,YAAa,4DAEf,KACE,mBAAoB,WACZ,WAAY,WACpB,UAAW,KAEb,EAEA,QADA,SAEE,mBAAoB,QACZ,WAAY,QAEtB,KACE,OAAQ,EACR,QAAS,EACT,WAAY,QACZ,YAAa,gBAAgB,CAAE,SAAS,CAAE,MAAM,CAAE,KAAK,CAAE,WACzD,YAAa,IACb,YAAa,IACb,MAAO,QACP,uBAAwB,YACxB,wBAAyB,UAE3B,IACE,QAAS,aACT,eAAgB,OAChB,UAAW,KACX,OAAQ,KACR,uBAAwB,QAE1B,SACE,OAAQ,KACR,WAAY,KACZ,cAAe,EAEjB,OACE,mBAAoB,WACZ,WAAY,WACpB,MAAO,KACP,cAAe,EAGjB,kBADA,gBAEA,mBAEA,mBADA,iBAEA,oBACE,UAAW,eAEb,OACE,QAAS,EACT,mBAAoB,KACjB,gBAAiB,KACZ,WAAY,KACpB,OAAQ,EACR,cAAe,EACf,WAAY,IACZ,YAAa,EACb,OAAQ,KACR,8BACE,QAAS,EAEb,IACE,SAAU,KAEZ,OACA,MACA,SACA,OACA,SACE,YAAa,QAEf,YACE,QAAS,gBAEX,WACE,QAAS,eAE8M,aAAvL,YAAkC,sBAAnB,gBAA2E,aAA/B,aAA+C,cAA7H,gBAA8I,cAAiB,WAA9K,YAA4L,YAAe,WAA9F,YAC7G,SACE,QAAS,MACT,mBAAoB,WACZ,WAAY,WACpB,MAAO,KACP,OAAQ,UACR,OAAQ,EAAE,EAAE,KACZ,QAAS,MACT,OAAQ,IAAI,MAAM,QAClB,cAAe,EACf,iBAAkB,QAClB,mBAAoB,MAAM,EAAE,IAAI,IAAI,kBAC5B,WAAY,MAAM,EAAE,IAAI,IAAI,kBACpC,YAAa,QACb,UAAW,KACX,YAAa,IACb,YAAa,IACb,MAAO,QACP,mBAAoB,aAAa,KAAM,WAAW,CAAE,mBAAmB,IACvE,WAAY,aAAa,KAAM,WAAW,CAAE,mBAAmB,IAC/D,WAAY,WAAW,GAAI,CAAE,aAAa,KAAM,YAChD,WAAY,WAAW,GAAI,CAAE,aAAa,KAAM,WAAW,CAAE,mBAAmB,IAChF,mBAAoB,KACjB,gBAAiB,KACZ,WAAY,KACmR,mBAAzP,kBAA8C,4BAAzB,sBAAmG,mBAA3C,mBAAiE,oBAAvK,sBAA8L,oBAAuB,iBAA1O,kBAA8P,kBAAqB,iBAAlI,kBACjJ,eACE,QAAS,EACT,OAAQ,IAAI,MAAM,QAClB,iBAAkB,QAClB,mBAAoB,EAAE,EAAE,IAAI,QACpB,WAAY,EAAE,EAAE,IAAI,QAC5B,mBAAoB,aAAa,KAAM,WAAW,CAAE,mBAAmB,IACvE,WAAY,aAAa,KAAM,WAAW,CAAE,mBAAmB,IAC/D,WAAY,WAAW,GAAI,CAAE,aAAa,KAAM,YAChD,WAAY,WAAW,GAAI,CAAE,aAAa,KAAM,WAAW,CAAE,mBAAmB,IAEpF,SACE,UAAW,KACX,eACE,OAAQ,KAEZ,eAAgB,gBAChB,kBACA,mBACE,iBAAkB,QAClB,OAAQ,YAGV,cADA,cAEE,mBAAoB,KACjB,gBAAiB,KACZ,WAAY,KACpB,cAAe,EAEjB,mBACE,mBAAoB,WACZ,WAAY,WAEtB,4BACE,MAAO,QAET,uBACE,MAAO,QAET,wBACE,MAAO,QAET,cACE,MAAO,QAGT,gBADA,YAEA,aACE,OAAQ,EAAE,EAAE,KAEd,sBACA,mBACE,QAAS,aACT,eAAgB,SAChB,YAAa,MACb,aAAc,KACd,cAAe,EACf,2BACA,wBACE,OAAQ,QAEZ,sBACA,mBACE,aAAc,MAEhB,YACE,MAAO,KAET,MACE,QAAS,MACT,OAAQ,EACR,UAAW,QACX,YAAa,IACb,YAAa,IACb,MAAO,QACP,aACE,OAAQ,EAAE,EAAE,KACZ,QAAS,SAAU,EAEvB,WACE,WAAY,OACZ,UAAW,SACX,WAAY,OACZ,MAAO,QAET,aACE,QAAS,YACT,QAAS,aACT,QAAS,YACT,QAAS,KACT,MAAO,KACP,cAAe,KACf,kBAAmB,QACnB,oBAAqB,QACjB,eAAgB,QACZ,YAAa,QACrB,0BAA6B,+CAC3B,cAAe,EACjB,yBAA4B,8CAC1B,cAAe,EAEqB,oBAAqB,sBAE7D,2BADA,0BAEA,0BAHoB,mBAApB,mBAIE,OAAQ,EACR,YAAa,OAEf,mBACE,QAAS,EAAE,KACX,OAAQ,IAAI,MAAM,QAClB,WAAY,QACZ,MAAO,QACP,WAAY,OACZ,YAAa,OACb,QAAS,YACT,QAAS,aACT,QAAS,YACT,QAAS,KACT,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KAClB,kBAAmB,OACnB,oBAAqB,OACjB,eAAgB,OACZ,YAAa,OACrB,+BACE,aAAc,EAChB,8BACE,YAAa,EAEjB,mBACE,cAAe,EACf,iBAAkB,EAClB,aAAc,EAAE,EAAE,IACd,SAAU,EAAE,EAAE,IACV,KAAM,EAAE,EAAE,IAClB,UAAW,EAEb,oBACE,YAAa,EACb,eAAgB,EAChB,WAAY,OACZ,QAAS,YACT,QAAS,aACT,QAAS,YACT,QAAS,KACT,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KAClB,sBAEA,2BADA,0BAEA,0BACE,mBAAoB,QAChB,oBAAqB,QACjB,WAAY,QACpB,OAAQ,KACR,YAAa,EACb,eAAgB,EAChB,UAAW,KAEf,SACE,OAAQ,EACR,QAAS,EACT,OAAQ,EAEV,OACE,UAAW,KACX,cAAe,MAEjB,UACE,OAAQ,SAAS,EACjB,QAAS,QACT,OAAQ,IAAI,MAAM,QAClB,iBACE,OAAQ,EACR,YAAa,UACb,QAAS,EAAE,SAEf,OACE,OAAQ,UACR,OAAQ,EAAE,EAAE,KACZ,QAAS,MACT,mBAAoB,KACjB,gBAAiB,KACZ,WAAY,KACpB,OAAQ,IAAI,MAAM,QAClB,cAAe,EACf,iBAAkB,QAClB,YAAa,QACb,UAAW,KACX,YAAa,IACb,YAAa,IACb,MAAO,QACP,iBAAkB,uNAClB,kBAAmB,YACnB,oBAAqB,MAAM,MAAM,OACjC,kBAAmB,UACnB,gBAAiB,IAAI,IACrB,cAAe,OACf,mBAAoB,aAAa,KAAM,WAAW,CAAE,mBAAmB,IACvE,WAAY,aAAa,KAAM,WAAW,CAAE,mBAAmB,IAC/D,WAAY,WAAW,GAAI,CAAE,aAAa,KAAM,YAChD,WAAY,WAAW,GAAI,CAAE,aAAa,KAAM,WAAW,CAAE,mBAAmB,IAChF,kCACE,OACE,iBAAkB,qVACtB,aACE,QAAS,EACT,OAAQ,IAAI,MAAM,QAClB,iBAAkB,QAClB,mBAAoB,EAAE,EAAE,IAAI,QACpB,WAAY,EAAE,EAAE,IAAI,QAC5B,mBAAoB,aAAa,KAAM,WAAW,CAAE,mBAAmB,IACvE,WAAY,aAAa,KAAM,WAAW,CAAE,mBAAmB,IAC/D,WAAY,WAAW,GAAI,CAAE,aAAa,KAAM,YAChD,WAAY,WAAW,GAAI,CAAE,aAAa,KAAM,WAAW,CAAE,mBAAmB,IAClF,gBACE,iBAAkB,QAClB,OAAQ,YACV,mBACE,QAAS,KACX,iBACE,OAAQ,KACR,iBAAkB,KAEtB,8BACE,aAAc,QACd,iBAAkB,QAClB,yDACE,MAAO,QACT,oDACE,MAAO,QACT,qDACE,MAAO,QACT,2CACE,MAAO,QAEX,kBACE,MAAO,QAET,YACE,QAAS,KACT,WAAY,OACZ,cAAe,KACf,UAAW,OACX,YAAa,IACb,MAAO,QACP,uBACE,QAAS,MAkBb,WAbA,GAHA,IACA,GACA,GAYA,KAPA,GACA,GACA,GACA,GACA,GACA,GANA,GADA,GAUA,EAFA,IAKA,GADA,GAbA,GAeE,OAAQ,EACR,QAAS,EAEX,EACE,cAAe,KACf,UAAW,QACX,YAAa,IACb,eAAgB,mBAElB,GACA,EACE,WAAY,OACZ,YAAa,QAGf,EADA,OAEE,YAAa,IACb,YAAa,QAEf,MACE,UAAW,IACX,YAAa,QAEX,IACA,IACA,IACA,IACA,IACA,IALJ,GACA,GACA,GACA,GACA,GACA,GACE,YAAa,gBAAgB,CAAE,SAAS,CAAE,MAAM,CAAE,KAAK,CAAE,WACzD,WAAY,OACZ,YAAa,IACb,MAAO,QACP,eAAgB,mBACN,UACA,UACA,UACA,UACA,UACA,UALV,SACA,SACA,SACA,SACA,SACA,SACE,YAAa,EACb,MAAO,QAEP,IAAJ,GACE,UAAW,OACX,YAAa,IACb,WAAY,EACZ,cAAe,MAEb,IAAJ,GACE,UAAW,QACX,YAAa,IACb,WAAY,EACZ,cAAe,MAEb,IAAJ,GACE,UAAW,UACX,YAAa,IACb,WAAY,EACZ,cAAe,MAEb,IAAJ,GACE,UAAW,SACX,YAAa,IACb,WAAY,EACZ,cAAe,MAEb,IAAJ,GACE,UAAW,UACX,YAAa,IACb,WAAY,EACZ,cAAe,MAEb,IAAJ,GACE,UAAW,KACX,YAAa,IACb,WAAY,EACZ,cAAe,MAEjB,aAAc,4BACR,IAAJ,GACE,UAAW,KACT,IAAJ,GACE,UAAW,OACT,IAAJ,GACE,UAAW,UACT,IAAJ,GACE,UAAW,UACT,IAAJ,GACE,UAAW,QACT,IAAJ,GACE,UAAW,MAEf,EACE,YAAa,QACb,MAAO,QACP,gBAAiB,KACjB,OAAQ,QACC,QAAT,QACE,MAAO,QACT,MACE,OAAQ,EAEZ,GACE,MAAO,KACP,UAAW,MACX,OAAQ,EACR,OAAQ,QAAQ,KAChB,WAAY,EACZ,aAAc,EACd,cAAe,IAAI,MAAM,QACzB,YAAa,EAIf,GADA,GADA,GAGE,cAAe,KACf,oBAAqB,QACrB,YAAa,IAEf,GACE,UAAW,QAEb,GACE,YAAa,QACb,gBAAiB,KAEnB,GACE,YAAa,QAEM,MAAd,MAAO,MAAd,MACE,YAAa,QACb,cAAe,EAEjB,GACE,cAAe,KACf,MACE,cAAe,MACf,YAAa,IAEjB,WACE,OAAQ,EAAE,EAAE,KACZ,QAAS,SAAU,QAAQ,EAAE,UAC7B,YAAa,IAAI,MAAM,QACvB,WAAY,aACV,YAAa,IACb,MAAO,QAEX,KACE,QAAS,MACT,UAAW,SACX,MAAO,QACP,YACE,QAAS,KAEb,KAAM,YACJ,cAAe,IAAI,OAAO,QAC1B,OAAQ,KACR,gBAAiB,KAEnB,OACE,OAAQ,EAEV,KACE,QAAS,QAAS,SAAU,SAC5B,OAAQ,IAAI,MAAM,QAClB,iBAAkB,QAClB,YAAa,QAAQ,CAAE,iBAAiB,CAAE,OAAO,CAAE,UACnD,YAAa,IACb,MAAO,QAET,IACE,OAAQ,EACR,QAAS,QAAS,OAAQ,EAC1B,iBAAkB,QAClB,YAAa,QAAQ,CAAE,iBAAiB,CAAE,OAAO,CAAE,UACnD,MAAO,QAET,WACE,WAAY,MACZ,cAAe,MACf,YAAa,IACb,YAAa,IACb,MAAO,QAET,MACE,UAAW,KACX,YAAa,IAEf,MACE,UAAW,OACX,YAAa,EACb,QACE,WAAY,MAEF,aAAd,aACE,YAAa,EACb,WAAY,KAEd,WACE,WAAY,KAEd,YACE,WAAY,MAEd,aACE,WAAY,OAEd,cACE,WAAY,QAEd,aAAc,4BACZ,kBACE,WAAY,KACd,mBACE,WAAY,MACd,oBACE,WAAY,OACd,qBACE,WAAY,SAEhB,aAAc,4BACZ,iBACE,WAAY,KACd,kBACE,WAAY,MACd,mBACE,WAAY,OACd,oBACE,WAAY,SAEhB,gBACE,QAAS,eAEX,aACE,EACE,WAAY,cACZ,mBAAoB,eACZ,WAAY,eACpB,MAAO,eACP,YAAa,eACf,gBACE,QAAS,gBACX,gBACE,QAAS,eACX,qBACE,QAAS,gBACX,qBACE,QAAS,6BACX,qBACE,QAAS,0BACX,kBACE,QAAS,oBACX,kBACE,QAAS,qBACX,kBACE,QAAS,qBACX,EACA,UACE,gBAAiB,UACnB,cACE,QAAS,KAAK,WAAW,IAC3B,YAEA,mBADA,6BAEE,QAAS,GACX,kBACE,QAAS,KAAK,YAAY,IAE5B,WADA,IAEE,OAAQ,IAAI,MAAM,QAClB,kBAAmB,MACrB,MACE,QAAS,mBAEX,IADA,GAEE,kBAAmB,MACrB,IACE,UAAW,eACb,MACE,OAAQ,KAEV,GACA,GAFA,EAGE,QAAS,EACT,OAAQ,EACV,GACA,GACE,iBAAkB,MACpB,oBACE,kBAAmB,MAEvB,gBACE,cAAe,QACf,aAAc,QACd,UAAW,MACX,YAAa,KACb,aAAc,KACd,aAAc,4BACZ,gBACE,cAAe,SACf,aAAc,UAClB,sBACE,cAAe,QACf,aAAc,QACd,UAAW,KACX,YAAa,KACb,aAAc,KACd,aAAc,4BACZ,sBACE,cAAe,SACf,aAAc,UACpB,qBACE,cAAe,EACf,aAAc,EACd,UAAW,KACX,YAAa,KACb,aAAc,KAElB,QACE,QAAS,YACT,QAAS,aACT,QAAS,YACT,QAAS,KACT,mBAAoB,WACpB,sBAAuB,OACvB,kBAAmB,IAAI,KACnB,cAAe,IAAI,KACf,UAAW,IAAI,KAEzB,MACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KAClB,WAAY,EACZ,UAAW,EACX,MAAO,KACP,WACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,IACd,SAAU,EAAE,EAAE,IACV,KAAM,EAAE,EAAE,IACpB,aACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KAEtB,cACE,MAAO,KAET,gBACE,MAAO,KAEuC,iBAAoL,kBAAqB,kBAAqB,kBAA1M,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAvL,oBAAzB,sBACE,mBAAoB,KAChB,wBAAyB,KACrB,WAAY,KAEtB,aAAc,4BACsC,kBAA6L,mBAAsB,mBAAsB,mBAApN,kBAAqB,kBAAqB,kBAAqB,kBAAqB,kBAAqB,kBAAqB,kBAAqB,kBAAhM,qBAA1B,uBACE,mBAAoB,KAChB,wBAAyB,KACrB,WAAY,MAExB,aAAc,4BACoC,iBAAoL,kBAAqB,kBAAqB,kBAA1M,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAvL,oBAAzB,sBACE,mBAAoB,KAChB,wBAAyB,KACrB,WAAY,MAExB,iBAAoL,kBAAqB,kBAAqB,kBAA1M,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAC9J,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KAEpB,iBACE,MAAO,SAET,iBACE,MAAO,UAET,iBACE,MAAO,IAET,iBACE,MAAO,UAET,iBACE,MAAO,UAET,iBACE,MAAO,IAET,iBACE,MAAO,UAET,iBACE,MAAO,UAET,iBACE,MAAO,IAET,kBACE,MAAO,UAET,kBACE,MAAO,UAET,kBACE,MAAO,KAET,aAAc,4BACZ,qBACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,IACd,SAAU,EAAE,EAAE,IACV,KAAM,EAAE,EAAE,IAClB,MAAO,KACiB,kBAA6L,mBAAsB,mBAAsB,mBAApN,kBAAqB,kBAAqB,kBAAqB,kBAAqB,kBAAqB,kBAAqB,kBAAqB,kBAAlM,uBACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KACpB,uBACE,MAAO,KACT,kBACE,MAAO,SACT,kBACE,MAAO,UACT,kBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,UACT,kBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,UACT,kBACE,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,UACT,mBACE,MAAO,MAEX,aAAc,4BACZ,oBACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,IACd,SAAU,EAAE,EAAE,IACV,KAAM,EAAE,EAAE,IAClB,MAAO,KACgB,iBAAoL,kBAAqB,kBAAqB,kBAA1M,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAoB,iBAAzL,sBACE,iBAAkB,EAClB,aAAc,EAAE,EAAE,KACd,SAAU,EAAE,EAAE,KACV,KAAM,EAAE,EAAE,KACpB,sBACE,MAAO,KACT,iBACE,MAAO,SACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,iBACE,MAAO,UACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,iBACE,MAAO,UACT,iBACE,MAAO,UACT,iBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,UACT,kBACE,MAAO,MAEX,kCACE,MAAO,KAET,kCACE,OAAQ,KAEV,eACE,YAAa,SACb,aAAc,SACd,aAAc,4BACZ,eACE,YAAa,UACb,aAAc,WAClB,qBACE,MAAO,qBACP,YAAa,QACb,aAAc,QAChB,aAAc,4BACZ,qBACE,MAAO,sBACP,YAAa,SACb,aAAc,UAClB,qBACE,MAAO,KACT,uBACE,MAAO,KACT,wBACE,MAAO,yBACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,wBACE,MAAO,0BACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,wBACE,MAAO,0BACT,wBACE,MAAO,0BACT,wBACE,MAAO,oBACT,yBACE,MAAO,0BACT,yBACE,MAAO,0BACT,yBACE,MAAO,qBACT,aAAc,4BACZ,qBACE,MAAO,KACT,uBACE,MAAO,KACT,wBACE,MAAO,0BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,sBACT,4BACE,MAAO,KACT,8BACE,MAAO,KACT,yBACE,MAAO,0BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,qBACT,0BACE,MAAO,2BACT,0BACE,MAAO,2BACT,0BACE,MAAO,uBACX,aAAc,4BACZ,2BACE,MAAO,KACT,6BACE,MAAO,KACT,wBACE,MAAO,0BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,wBACE,MAAO,2BACT,wBACE,MAAO,2BACT,wBACE,MAAO,qBACT,yBACE,MAAO,2BACT,yBACE,MAAO,2BACT,yBACE,MAAO,uBAEb,gCACE,aAAc,SACd,YAAa,SACb,aAAc,4BACZ,gCACE,aAAc,UACd,YAAa,WAEnB,2CACE,aAAc,SACd,YAAa,SACb,aAAc,4BACZ,2CACE,aAAc,UACd,YAAa,WAEnB,sBACE,cAAe,QACf,aAAc,QACd,aAAc,4BACZ,sBACE,cAAe,SACf,aAAc,UAEpB,kBACE,MAAO,KAET,kBACE,MAAO,IAET,kBACE,MAAO,UAET,kBACE,MAAO,IAET,kBACE,MAAO,IAET,kBACE,MAAO,UAET,kBACE,MAAO,UAET,kBACE,MAAO,MAET,aAAc,4BACZ,mBACE,MAAO,KACT,mBACE,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,IACT,mBACE,MAAO,IACT,mBACE,MAAO,UACT,mBACE,MAAO,UACT,mBACE,MAAO,OAEX,aAAc,4BACZ,kBACE,MAAO,KACT,kBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,IACT,kBACE,MAAO,IACT,kBACE,MAAO,UACT,kBACE,MAAO,UACT,kBACE,MAAO,OAEX,gCACE,MAAO,qBAET,gCACE,MAAO,oBAET,gCACE,MAAO,0BAET,gCACE,MAAO,oBAET,gCACE,MAAO,oBAET,gCACE,MAAO,0BAET,gCACE,MAAO,0BAET,gCACE,MAAO,sBAET,aAAc,4BACZ,gCACE,MAAO,sBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,qBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,2BACT,gCACE,MAAO,uBACT,iCACE,MAAO,sBACT,iCACE,MAAO,qBACT,iCACE,MAAO,2BACT,iCACE,MAAO,qBACT,iCACE,MAAO,qBACT,iCACE,MAAO,2BACT,iCACE,MAAO,2BACT,iCACE,MAAO,wBAEX,aAAc,4BACZ,gCACE,MAAO,sBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,qBACT,gCACE,MAAO,qBACT,gCACE,MAAO,2BACT,gCACE,MAAO,2BACT,gCACE,MAAO,wBAEX,uBACE,aAAc,EACd,YAAa,EACb,6BACE,aAAc,EACd,YAAa,EACf,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,KACT,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MACX,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,MAEb,wBACE,aAAc,EACd,YAAa,EACb,8BACE,cAAe,EACf,aAAc,EAElB,aAAc,4BACZ,wBACE,aAAc,EACd,YAAa,EACb,8BACE,aAAc,EACd,YAAa,GAEnB,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,kCACE,MAAO,SACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,IACT,mCACE,MAAO,UACT,mCACE,MAAO,UACT,mCACE,MAAO,MAEX,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,yBACE,aAAc,EACd,YAAa,EACb,+BACE,cAAe,EACf,aAAc,GAEpB,aAAc,4BACZ,uBACE,aAAc,EACd,YAAa,EACb,6BACE,aAAc,EACd,YAAa,GAEnB,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,MAEX,aAAc,4BACZ,iCACE,MAAO,SACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,IACT,kCACE,MAAO,UACT,kCACE,MAAO,UACT,kCACE,MAAO,MAEX,aAAc,4BACZ,gCACE,MAAO,SACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,gCACE,MAAO,UACT,gCACE,MAAO,UACT,gCACE,MAAO,IACT,iCACE,MAAO,UACT,iCACE,MAAO,UACT,iCACE,MAAO,MAEX,aAAc,4BACZ,wBACE,aAAc,EACd,YAAa,EACb,8BACE,cAAe,EACf,aAAc,GAEpB,gBACE,YAAa,EAEf,+BACE,YAAa,mBAEf,gBACE,YAAa,SAEf,+BACE,YAAa,yBAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,IAEf,+BACE,YAAa,oBAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,IAEf,+BACE,YAAa,oBAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,UAEf,+BACE,YAAa,0BAEf,gBACE,YAAa,IAEf,+BACE,YAAa,oBAEf,iBACE,YAAa,UAEf,gCACE,YAAa,0BAEf,iBACE,YAAa,UAEf,gCACE,YAAa,0BAEf,aAAc,4BACZ,iBACE,YAAa,EACf,gCACE,YAAa,oBACf,iBACE,YAAa,SACf,gCACE,YAAa,0BACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,IACf,gCACE,YAAa,qBACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,IACf,gCACE,YAAa,qBACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,UACf,gCACE,YAAa,2BACf,iBACE,YAAa,IACf,gCACE,YAAa,qBACf,kBACE,YAAa,UACf,iCACE,YAAa,2BACf,kBACE,YAAa,UACf,iCACE,YAAa,4BAEjB,aAAc,4BACZ,gBACE,YAAa,EACf,+BACE,YAAa,oBACf,gBACE,YAAa,SACf,+BACE,YAAa,0BACf,gBACE,YAAa,UACf,+BACE,YAAa,2BACf,gBACE,YAAa,IACf,+BACE,YAAa,qBACf,gBACE,YAAa,UACf,+BACE,YAAa,2B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","file":"foundation.min.css","sourcesContent":[]}
\ No newline at end of file
diff --git a/dist/js/foundation.cjs.js b/dist/js/foundation.cjs.js
new file mode 100644 (file)
index 0000000..3d3ce0b
--- /dev/null
@@ -0,0 +1,11802 @@
+'use strict';
+
+Object.defineProperty(exports, '__esModule', { value: true });
+
+function _interopDefault (ex) { return (ex && (typeof ex === 'object') && 'default' in ex) ? ex['default'] : ex; }
+
+var $ = _interopDefault(require('jquery'));
+
+function _typeof(obj) {
+  if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
+    _typeof = function (obj) {
+      return typeof obj;
+    };
+  } else {
+    _typeof = function (obj) {
+      return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
+    };
+  }
+
+  return _typeof(obj);
+}
+
+function _classCallCheck(instance, Constructor) {
+  if (!(instance instanceof Constructor)) {
+    throw new TypeError("Cannot call a class as a 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);
+  }
+}
+
+function _createClass(Constructor, protoProps, staticProps) {
+  if (protoProps) _defineProperties(Constructor.prototype, protoProps);
+  if (staticProps) _defineProperties(Constructor, staticProps);
+  return Constructor;
+}
+
+function _inherits(subClass, superClass) {
+  if (typeof superClass !== "function" && superClass !== null) {
+    throw new TypeError("Super expression must either be null or a function");
+  }
+
+  subClass.prototype = Object.create(superClass && superClass.prototype, {
+    constructor: {
+      value: subClass,
+      writable: true,
+      configurable: true
+    }
+  });
+  if (superClass) _setPrototypeOf(subClass, superClass);
+}
+
+function _getPrototypeOf(o) {
+  _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
+    return o.__proto__ || Object.getPrototypeOf(o);
+  };
+  return _getPrototypeOf(o);
+}
+
+function _setPrototypeOf(o, p) {
+  _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
+    o.__proto__ = p;
+    return o;
+  };
+
+  return _setPrototypeOf(o, p);
+}
+
+function _assertThisInitialized(self) {
+  if (self === void 0) {
+    throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
+  }
+
+  return self;
+}
+
+function _possibleConstructorReturn(self, call) {
+  if (call && (typeof call === "object" || typeof call === "function")) {
+    return call;
+  }
+
+  return _assertThisInitialized(self);
+}
+
+function _superPropBase(object, property) {
+  while (!Object.prototype.hasOwnProperty.call(object, property)) {
+    object = _getPrototypeOf(object);
+    if (object === null) break;
+  }
+
+  return object;
+}
+
+function _get(target, property, receiver) {
+  if (typeof Reflect !== "undefined" && Reflect.get) {
+    _get = Reflect.get;
+  } else {
+    _get = function _get(target, property, receiver) {
+      var base = _superPropBase(target, property);
+
+      if (!base) return;
+      var desc = Object.getOwnPropertyDescriptor(base, property);
+
+      if (desc.get) {
+        return desc.get.call(receiver);
+      }
+
+      return desc.value;
+    };
+  }
+
+  return _get(target, property, receiver || target);
+}
+
+/**
+ * Returns a boolean for RTL support
+ */
+
+function rtl() {
+  return $('html').attr('dir') === 'rtl';
+}
+/**
+ * returns a random base-36 uid with namespacing
+ * @function
+ * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.
+ * @param {String} namespace - name of plugin to be incorporated in uid, optional.
+ * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.
+ * @returns {String} - unique id
+ */
+
+
+function GetYoDigits(length, namespace) {
+  length = length || 6;
+  return Math.round(Math.pow(36, length + 1) - Math.random() * Math.pow(36, length)).toString(36).slice(1) + (namespace ? "-".concat(namespace) : '');
+}
+/**
+ * Escape a string so it can be used as a regexp pattern
+ * @function
+ * @see https://stackoverflow.com/a/9310752/4317384
+ *
+ * @param {String} str - string to escape.
+ * @returns {String} - escaped string
+ */
+
+
+function RegExpEscape(str) {
+  return str.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
+}
+
+function transitionend($elem) {
+  var transitions = {
+    'transition': 'transitionend',
+    'WebkitTransition': 'webkitTransitionEnd',
+    'MozTransition': 'transitionend',
+    'OTransition': 'otransitionend'
+  };
+  var elem = document.createElement('div'),
+      end;
+
+  for (var t in transitions) {
+    if (typeof elem.style[t] !== 'undefined') {
+      end = transitions[t];
+    }
+  }
+
+  if (end) {
+    return end;
+  } else {
+    end = setTimeout(function () {
+      $elem.triggerHandler('transitionend', [$elem]);
+    }, 1);
+    return 'transitionend';
+  }
+}
+/**
+ * Return an event type to listen for window load.
+ *
+ * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.
+ * If `handler` is passed, attach it to the event on `$elem`.
+ * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.
+ * @function
+ *
+ * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.
+ * @param {Function} [] handler - function to attach to the event.
+ * @returns {String} - event type that should or will be triggered.
+ */
+
+
+function onLoad($elem, handler) {
+  var didLoad = document.readyState === 'complete';
+  var eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';
+
+  var cb = function cb() {
+    return $elem.triggerHandler(eventType);
+  };
+
+  if ($elem) {
+    if (handler) $elem.one(eventType, handler);
+    if (didLoad) setTimeout(cb);else $(window).one('load', cb);
+  }
+
+  return eventType;
+}
+/**
+ * Retuns an handler for the `mouseleave` that ignore disappeared mouses.
+ *
+ * If the mouse "disappeared" from the document (like when going on a browser UI element, See https://git.io/zf-11410),
+ * the event is ignored.
+ * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window
+ *   (like by switching to an other window with [Alt]+[Tab]).
+ * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document
+ *   outside of the element it left.
+ *
+ * @function
+ *
+ * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.
+ * @param {Object} [] options - object of options:
+ * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.
+ * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.
+ * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.
+ */
+
+
+function ignoreMousedisappear(handler) {
+  var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
+      _ref$ignoreLeaveWindo = _ref.ignoreLeaveWindow,
+      ignoreLeaveWindow = _ref$ignoreLeaveWindo === void 0 ? false : _ref$ignoreLeaveWindo,
+      _ref$ignoreReappear = _ref.ignoreReappear,
+      ignoreReappear = _ref$ignoreReappear === void 0 ? false : _ref$ignoreReappear;
+
+  return function leaveEventHandler(eLeave) {
+    for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
+      rest[_key - 1] = arguments[_key];
+    }
+
+    var callback = handler.bind.apply(handler, [this, eLeave].concat(rest)); // The mouse left: call the given callback if the mouse entered elsewhere
+
+    if (eLeave.relatedTarget !== null) {
+      return callback();
+    } // Otherwise, check if the mouse actually left the window.
+    // In firefox if the user switched between windows, the window sill have the focus by the time
+    // the event is triggered. We have to debounce the event to test this case.
+
+
+    setTimeout(function leaveEventDebouncer() {
+      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {
+        return callback();
+      } // Otherwise, wait for the mouse to reeapear outside of the element,
+
+
+      if (!ignoreReappear) {
+        $(document).one('mouseenter', function reenterEventHandler(eReenter) {
+          if (!$(eLeave.currentTarget).has(eReenter.target).length) {
+            // Fill where the mouse finally entered.
+            eLeave.relatedTarget = eReenter.target;
+            callback();
+          }
+        });
+      }
+    }, 0);
+  };
+}
+
+var foundation_core_utils = /*#__PURE__*/Object.freeze({
+  rtl: rtl,
+  GetYoDigits: GetYoDigits,
+  RegExpEscape: RegExpEscape,
+  transitionend: transitionend,
+  onLoad: onLoad,
+  ignoreMousedisappear: ignoreMousedisappear
+});
+
+// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license
+
+/* eslint-disable */
+
+window.matchMedia || (window.matchMedia = function () {
+
+  var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium
+
+  if (!styleMedia) {
+    var style = document.createElement('style'),
+        script = document.getElementsByTagName('script')[0],
+        info = null;
+    style.type = 'text/css';
+    style.id = 'matchmediajs-test';
+
+    if (!script) {
+      document.head.appendChild(style);
+    } else {
+      script.parentNode.insertBefore(style, script);
+    } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
+
+
+    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;
+    styleMedia = {
+      matchMedium: function matchMedium(media) {
+        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
+
+        if (style.styleSheet) {
+          style.styleSheet.cssText = text;
+        } else {
+          style.textContent = text;
+        } // Test if media query is true or false
+
+
+        return info.width === '1px';
+      }
+    };
+  }
+
+  return function (media) {
+    return {
+      matches: styleMedia.matchMedium(media || 'all'),
+      media: media || 'all'
+    };
+  };
+}());
+/* eslint-enable */
+
+var MediaQuery = {
+  queries: [],
+  current: '',
+
+  /**
+   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.
+   * @function
+   * @private
+   */
+  _init: function _init() {
+    var self = this;
+    var $meta = $('meta.foundation-mq');
+
+    if (!$meta.length) {
+      $('<meta class="foundation-mq">').appendTo(document.head);
+    }
+
+    var extractedStyles = $('.foundation-mq').css('font-family');
+    var namedQueries;
+    namedQueries = parseStyleToObject(extractedStyles);
+
+    for (var key in namedQueries) {
+      if (namedQueries.hasOwnProperty(key)) {
+        self.queries.push({
+          name: key,
+          value: "only screen and (min-width: ".concat(namedQueries[key], ")")
+        });
+      }
+    }
+
+    this.current = this._getCurrentSize();
+
+    this._watcher();
+  },
+
+  /**
+   * Checks if the screen is at least as wide as a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to check.
+   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.
+   */
+  atLeast: function atLeast(size) {
+    var query = this.get(size);
+
+    if (query) {
+      return window.matchMedia(query).matches;
+    }
+
+    return false;
+  },
+
+  /**
+   * Checks if the screen matches to a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.
+   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.
+   */
+  is: function is(size) {
+    size = size.trim().split(' ');
+
+    if (size.length > 1 && size[1] === 'only') {
+      if (size[0] === this._getCurrentSize()) return true;
+    } else {
+      return this.atLeast(size[0]);
+    }
+
+    return false;
+  },
+
+  /**
+   * Gets the media query of a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to get.
+   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.
+   */
+  get: function get(size) {
+    for (var i in this.queries) {
+      if (this.queries.hasOwnProperty(i)) {
+        var query = this.queries[i];
+        if (size === query.name) return query.value;
+      }
+    }
+
+    return null;
+  },
+
+  /**
+   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).
+   * @function
+   * @private
+   * @returns {String} Name of the current breakpoint.
+   */
+  _getCurrentSize: function _getCurrentSize() {
+    var matched;
+
+    for (var i = 0; i < this.queries.length; i++) {
+      var query = this.queries[i];
+
+      if (window.matchMedia(query.value).matches) {
+        matched = query;
+      }
+    }
+
+    if (_typeof(matched) === 'object') {
+      return matched.name;
+    } else {
+      return matched;
+    }
+  },
+
+  /**
+   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.
+   * @function
+   * @private
+   */
+  _watcher: function _watcher() {
+    var _this = this;
+
+    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {
+      var newSize = _this._getCurrentSize(),
+          currentSize = _this.current;
+
+      if (newSize !== currentSize) {
+        // Change the current media query
+        _this.current = newSize; // Broadcast the media query change on the window
+
+        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
+      }
+    });
+  }
+}; // Thank you: https://github.com/sindresorhus/query-string
+
+function parseStyleToObject(str) {
+  var styleObject = {};
+
+  if (typeof str !== 'string') {
+    return styleObject;
+  }
+
+  str = str.trim().slice(1, -1); // browsers re-quote string style values
+
+  if (!str) {
+    return styleObject;
+  }
+
+  styleObject = str.split('&').reduce(function (ret, param) {
+    var parts = param.replace(/\+/g, ' ').split('=');
+    var key = parts[0];
+    var val = parts[1];
+    key = decodeURIComponent(key); // missing `=` should be `null`:
+    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters
+
+    val = typeof val === 'undefined' ? null : decodeURIComponent(val);
+
+    if (!ret.hasOwnProperty(key)) {
+      ret[key] = val;
+    } else if (Array.isArray(ret[key])) {
+      ret[key].push(val);
+    } else {
+      ret[key] = [ret[key], val];
+    }
+
+    return ret;
+  }, {});
+  return styleObject;
+}
+
+var FOUNDATION_VERSION = '6.5.3'; // Global Foundation object
+// This is attached to the window, or used as a module for AMD/Browserify
+
+var Foundation = {
+  version: FOUNDATION_VERSION,
+
+  /**
+   * Stores initialized plugins.
+   */
+  _plugins: {},
+
+  /**
+   * Stores generated unique ids for plugin instances
+   */
+  _uuids: [],
+
+  /**
+   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.
+   * @param {Object} plugin - The constructor of the plugin.
+   */
+  plugin: function plugin(_plugin, name) {
+    // Object key to use when adding to global Foundation object
+    // Examples: Foundation.Reveal, Foundation.OffCanvas
+    var className = name || functionName(_plugin); // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin
+    // Examples: data-reveal, data-off-canvas
+
+    var attrName = hyphenate(className); // Add to the Foundation object and the plugins list (for reflowing)
+
+    this._plugins[attrName] = this[className] = _plugin;
+  },
+
+  /**
+   * @function
+   * Populates the _uuids array with pointers to each individual plugin instance.
+   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.
+   * Also fires the initialization event for each plugin, consolidating repetitive code.
+   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
+   * @param {String} name - the name of the plugin, passed as a camelCased string.
+   * @fires Plugin#init
+   */
+  registerPlugin: function registerPlugin(plugin, name) {
+    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();
+    plugin.uuid = GetYoDigits(6, pluginName);
+
+    if (!plugin.$element.attr("data-".concat(pluginName))) {
+      plugin.$element.attr("data-".concat(pluginName), plugin.uuid);
+    }
+
+    if (!plugin.$element.data('zfPlugin')) {
+      plugin.$element.data('zfPlugin', plugin);
+    }
+    /**
+     * Fires when the plugin has initialized.
+     * @event Plugin#init
+     */
+
+
+    plugin.$element.trigger("init.zf.".concat(pluginName));
+
+    this._uuids.push(plugin.uuid);
+
+    return;
+  },
+
+  /**
+   * @function
+   * Removes the plugins uuid from the _uuids array.
+   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.
+   * Also fires the destroyed event for the plugin, consolidating repetitive code.
+   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
+   * @fires Plugin#destroyed
+   */
+  unregisterPlugin: function unregisterPlugin(plugin) {
+    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));
+
+    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);
+
+    plugin.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin')
+    /**
+     * Fires when the plugin has been destroyed.
+     * @event Plugin#destroyed
+     */
+    .trigger("destroyed.zf.".concat(pluginName));
+
+    for (var prop in plugin) {
+      plugin[prop] = null; //clean up script to prep for garbage collection.
+    }
+
+    return;
+  },
+
+  /**
+   * @function
+   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.
+   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`
+   * @default If no argument is passed, reflow all currently active plugins.
+   */
+  reInit: function reInit(plugins) {
+    var isJQ = plugins instanceof $;
+
+    try {
+      if (isJQ) {
+        plugins.each(function () {
+          $(this).data('zfPlugin')._init();
+        });
+      } else {
+        var type = _typeof(plugins),
+            _this = this,
+            fns = {
+          'object': function object(plgs) {
+            plgs.forEach(function (p) {
+              p = hyphenate(p);
+              $('[data-' + p + ']').foundation('_init');
+            });
+          },
+          'string': function string() {
+            plugins = hyphenate(plugins);
+            $('[data-' + plugins + ']').foundation('_init');
+          },
+          'undefined': function undefined() {
+            this['object'](Object.keys(_this._plugins));
+          }
+        };
+
+        fns[type](plugins);
+      }
+    } catch (err) {
+      console.error(err);
+    } finally {
+      return plugins;
+    }
+  },
+
+  /**
+   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.
+   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.
+   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.
+   */
+  reflow: function reflow(elem, plugins) {
+    // If plugins is undefined, just grab everything
+    if (typeof plugins === 'undefined') {
+      plugins = Object.keys(this._plugins);
+    } // If plugins is a string, convert it to an array with one item
+    else if (typeof plugins === 'string') {
+        plugins = [plugins];
+      }
+
+    var _this = this; // Iterate through each plugin
+
+
+    $.each(plugins, function (i, name) {
+      // Get the current plugin
+      var plugin = _this._plugins[name]; // Localize the search to all elements inside elem, as well as elem itself, unless elem === document
+
+      var $elem = $(elem).find('[data-' + name + ']').addBack('[data-' + name + ']'); // For each plugin found, initialize it
+
+      $elem.each(function () {
+        var $el = $(this),
+            opts = {}; // Don't double-dip on plugins
+
+        if ($el.data('zfPlugin')) {
+          console.warn("Tried to initialize " + name + " on an element that already has a Foundation plugin.");
+          return;
+        }
+
+        if ($el.attr('data-options')) {
+          var thing = $el.attr('data-options').split(';').forEach(function (e, i) {
+            var opt = e.split(':').map(function (el) {
+              return el.trim();
+            });
+            if (opt[0]) opts[opt[0]] = parseValue(opt[1]);
+          });
+        }
+
+        try {
+          $el.data('zfPlugin', new plugin($(this), opts));
+        } catch (er) {
+          console.error(er);
+        } finally {
+          return;
+        }
+      });
+    });
+  },
+  getFnName: functionName,
+  addToJquery: function addToJquery($$$1) {
+    // TODO: consider not making this a jQuery function
+    // TODO: need way to reflow vs. re-initialize
+
+    /**
+     * The Foundation jQuery method.
+     * @param {String|Array} method - An action to perform on the current jQuery object.
+     */
+    var foundation = function foundation(method) {
+      var type = _typeof(method),
+          $noJS = $$$1('.no-js');
+
+      if ($noJS.length) {
+        $noJS.removeClass('no-js');
+      }
+
+      if (type === 'undefined') {
+        //needs to initialize the Foundation object, or an individual plugin.
+        MediaQuery._init();
+
+        Foundation.reflow(this);
+      } else if (type === 'string') {
+        //an individual method to invoke on a plugin or group of plugins
+        var args = Array.prototype.slice.call(arguments, 1); //collect all the arguments, if necessary
+
+        var plugClass = this.data('zfPlugin'); //determine the class of plugin
+
+        if (typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined') {
+          //make sure both the class and method exist
+          if (this.length === 1) {
+            //if there's only one, call it directly.
+            plugClass[method].apply(plugClass, args);
+          } else {
+            this.each(function (i, el) {
+              //otherwise loop through the jQuery collection and invoke the method on each
+              plugClass[method].apply($$$1(el).data('zfPlugin'), args);
+            });
+          }
+        } else {
+          //error for no class or no method
+          throw new ReferenceError("We're sorry, '" + method + "' is not an available method for " + (plugClass ? functionName(plugClass) : 'this element') + '.');
+        }
+      } else {
+        //error for invalid argument type
+        throw new TypeError("We're sorry, ".concat(type, " is not a valid parameter. You must use a string representing the method you wish to invoke."));
+      }
+
+      return this;
+    };
+
+    $$$1.fn.foundation = foundation;
+    return $$$1;
+  }
+};
+Foundation.util = {
+  /**
+   * Function for applying a debounce effect to a function call.
+   * @function
+   * @param {Function} func - Function to be called at end of timeout.
+   * @param {Number} delay - Time in ms to delay the call of `func`.
+   * @returns function
+   */
+  throttle: function throttle(func, delay) {
+    var timer = null;
+    return function () {
+      var context = this,
+          args = arguments;
+
+      if (timer === null) {
+        timer = setTimeout(function () {
+          func.apply(context, args);
+          timer = null;
+        }, delay);
+      }
+    };
+  }
+};
+window.Foundation = Foundation; // Polyfill for requestAnimationFrame
+
+(function () {
+  if (!Date.now || !window.Date.now) window.Date.now = Date.now = function () {
+    return new Date().getTime();
+  };
+  var vendors = ['webkit', 'moz'];
+
+  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {
+    var vp = vendors[i];
+    window.requestAnimationFrame = window[vp + 'RequestAnimationFrame'];
+    window.cancelAnimationFrame = window[vp + 'CancelAnimationFrame'] || window[vp + 'CancelRequestAnimationFrame'];
+  }
+
+  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) || !window.requestAnimationFrame || !window.cancelAnimationFrame) {
+    var lastTime = 0;
+
+    window.requestAnimationFrame = function (callback) {
+      var now = Date.now();
+      var nextTime = Math.max(lastTime + 16, now);
+      return setTimeout(function () {
+        callback(lastTime = nextTime);
+      }, nextTime - now);
+    };
+
+    window.cancelAnimationFrame = clearTimeout;
+  }
+  /**
+   * Polyfill for performance.now, required by rAF
+   */
+
+
+  if (!window.performance || !window.performance.now) {
+    window.performance = {
+      start: Date.now(),
+      now: function now() {
+        return Date.now() - this.start;
+      }
+    };
+  }
+})();
+
+if (!Function.prototype.bind) {
+  Function.prototype.bind = function (oThis) {
+    if (typeof this !== 'function') {
+      // closest thing possible to the ECMAScript 5
+      // internal IsCallable function
+      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');
+    }
+
+    var aArgs = Array.prototype.slice.call(arguments, 1),
+        fToBind = this,
+        fNOP = function fNOP() {},
+        fBound = function fBound() {
+      return fToBind.apply(this instanceof fNOP ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments)));
+    };
+
+    if (this.prototype) {
+      // native functions don't have a prototype
+      fNOP.prototype = this.prototype;
+    }
+
+    fBound.prototype = new fNOP();
+    return fBound;
+  };
+} // Polyfill to get the name of a function in IE9
+
+
+function functionName(fn) {
+  if (typeof Function.prototype.name === 'undefined') {
+    var funcNameRegex = /function\s([^(]{1,})\(/;
+    var results = funcNameRegex.exec(fn.toString());
+    return results && results.length > 1 ? results[1].trim() : "";
+  } else if (typeof fn.prototype === 'undefined') {
+    return fn.constructor.name;
+  } else {
+    return fn.prototype.constructor.name;
+  }
+}
+
+function parseValue(str) {
+  if ('true' === str) return true;else if ('false' === str) return false;else if (!isNaN(str * 1)) return parseFloat(str);
+  return str;
+} // Convert PascalCase to kebab-case
+// Thank you: http://stackoverflow.com/a/8955580
+
+
+function hyphenate(str) {
+  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
+}
+
+var Box = {
+  ImNotTouchingYou: ImNotTouchingYou,
+  OverlapArea: OverlapArea,
+  GetDimensions: GetDimensions,
+  GetOffsets: GetOffsets,
+  GetExplicitOffsets: GetExplicitOffsets
+  /**
+   * Compares the dimensions of an element to a container and determines collision events with container.
+   * @function
+   * @param {jQuery} element - jQuery object to test for collisions.
+   * @param {jQuery} parent - jQuery object to use as bounding container.
+   * @param {Boolean} lrOnly - set to true to check left and right values only.
+   * @param {Boolean} tbOnly - set to true to check top and bottom values only.
+   * @default if no parent object passed, detects collisions with `window`.
+   * @returns {Boolean} - true if collision free, false if a collision in any direction.
+   */
+
+};
+
+function ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;
+}
+
+function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  var eleDims = GetDimensions(element),
+      topOver,
+      bottomOver,
+      leftOver,
+      rightOver;
+
+  if (parent) {
+    var parDims = GetDimensions(parent);
+    bottomOver = parDims.height + parDims.offset.top - (eleDims.offset.top + eleDims.height);
+    topOver = eleDims.offset.top - parDims.offset.top;
+    leftOver = eleDims.offset.left - parDims.offset.left;
+    rightOver = parDims.width + parDims.offset.left - (eleDims.offset.left + eleDims.width);
+  } else {
+    bottomOver = eleDims.windowDims.height + eleDims.windowDims.offset.top - (eleDims.offset.top + eleDims.height);
+    topOver = eleDims.offset.top - eleDims.windowDims.offset.top;
+    leftOver = eleDims.offset.left - eleDims.windowDims.offset.left;
+    rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);
+  }
+
+  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);
+  topOver = Math.min(topOver, 0);
+  leftOver = Math.min(leftOver, 0);
+  rightOver = Math.min(rightOver, 0);
+
+  if (lrOnly) {
+    return leftOver + rightOver;
+  }
+
+  if (tbOnly) {
+    return topOver + bottomOver;
+  } // use sum of squares b/c we care about overlap area.
+
+
+  return Math.sqrt(topOver * topOver + bottomOver * bottomOver + leftOver * leftOver + rightOver * rightOver);
+}
+/**
+ * Uses native methods to return an object of dimension values.
+ * @function
+ * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.
+ * @returns {Object} - nested object of integer pixel values
+ * TODO - if element is window, return only those values.
+ */
+
+
+function GetDimensions(elem) {
+  elem = elem.length ? elem[0] : elem;
+
+  if (elem === window || elem === document) {
+    throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");
+  }
+
+  var rect = elem.getBoundingClientRect(),
+      parRect = elem.parentNode.getBoundingClientRect(),
+      winRect = document.body.getBoundingClientRect(),
+      winY = window.pageYOffset,
+      winX = window.pageXOffset;
+  return {
+    width: rect.width,
+    height: rect.height,
+    offset: {
+      top: rect.top + winY,
+      left: rect.left + winX
+    },
+    parentDims: {
+      width: parRect.width,
+      height: parRect.height,
+      offset: {
+        top: parRect.top + winY,
+        left: parRect.left + winX
+      }
+    },
+    windowDims: {
+      width: winRect.width,
+      height: winRect.height,
+      offset: {
+        top: winY,
+        left: winX
+      }
+    }
+  };
+}
+/**
+ * Returns an object of top and left integer pixel values for dynamically rendered elements,
+ * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where
+ * you don't know alignment, but generally from
+ * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.
+ * @function
+ * @param {jQuery} element - jQuery object for the element being positioned.
+ * @param {jQuery} anchor - jQuery object for the element's anchor point.
+ * @param {String} position - a string relating to the desired position of the element, relative to it's anchor
+ * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.
+ * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.
+ * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.
+ * TODO alter/rewrite to work with `em` values as well/instead of pixels
+ */
+
+
+function GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {
+  console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5");
+
+  switch (position) {
+    case 'top':
+      return rtl() ? GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);
+
+    case 'bottom':
+      return rtl() ? GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+
+    case 'center top':
+      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);
+
+    case 'center bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);
+
+    case 'center left':
+      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);
+
+    case 'center right':
+      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);
+
+    case 'left bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);
+
+    case 'right bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+    // Backwards compatibility... this along with the reveal and reveal full
+    // classes are the only ones that didn't reference anchor
+
+    case 'center':
+      return {
+        left: $eleDims.windowDims.offset.left + $eleDims.windowDims.width / 2 - $eleDims.width / 2 + hOffset,
+        top: $eleDims.windowDims.offset.top + $eleDims.windowDims.height / 2 - ($eleDims.height / 2 + vOffset)
+      };
+
+    case 'reveal':
+      return {
+        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,
+        top: $eleDims.windowDims.offset.top + vOffset
+      };
+
+    case 'reveal full':
+      return {
+        left: $eleDims.windowDims.offset.left,
+        top: $eleDims.windowDims.offset.top
+      };
+      break;
+
+    default:
+      return {
+        left: rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset : $anchorDims.offset.left + hOffset,
+        top: $anchorDims.offset.top + $anchorDims.height + vOffset
+      };
+  }
+}
+
+function GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {
+  var $eleDims = GetDimensions(element),
+      $anchorDims = anchor ? GetDimensions(anchor) : null;
+  var topVal, leftVal; // set position related attribute
+
+  switch (position) {
+    case 'top':
+      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);
+      break;
+
+    case 'bottom':
+      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;
+      break;
+
+    case 'left':
+      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);
+      break;
+
+    case 'right':
+      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;
+      break;
+  } // set alignment related attribute
+
+
+  switch (position) {
+    case 'top':
+    case 'bottom':
+      switch (alignment) {
+        case 'left':
+          leftVal = $anchorDims.offset.left + hOffset;
+          break;
+
+        case 'right':
+          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;
+          break;
+
+        case 'center':
+          leftVal = isOverflow ? hOffset : $anchorDims.offset.left + $anchorDims.width / 2 - $eleDims.width / 2 + hOffset;
+          break;
+      }
+
+      break;
+
+    case 'right':
+    case 'left':
+      switch (alignment) {
+        case 'bottom':
+          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;
+          break;
+
+        case 'top':
+          topVal = $anchorDims.offset.top + vOffset;
+          break;
+
+        case 'center':
+          topVal = $anchorDims.offset.top + vOffset + $anchorDims.height / 2 - $eleDims.height / 2;
+          break;
+      }
+
+      break;
+  }
+
+  return {
+    top: topVal,
+    left: leftVal
+  };
+}
+
+/**
+ * Runs a callback function when images are fully loaded.
+ * @param {Object} images - Image(s) to check if loaded.
+ * @param {Func} callback - Function to execute when image is fully loaded.
+ */
+
+function onImagesLoaded(images, callback) {
+  var unloaded = images.length;
+
+  if (unloaded === 0) {
+    callback();
+  }
+
+  images.each(function () {
+    // Check if image is loaded
+    if (this.complete && typeof this.naturalWidth !== 'undefined') {
+      singleImageLoaded();
+    } else {
+      // If the above check failed, simulate loading on detached element.
+      var image = new Image(); // Still count image as loaded if it finalizes with an error.
+
+      var events = "load.zf.images error.zf.images";
+      $(image).one(events, function me(event) {
+        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.
+        $(this).off(events, me);
+        singleImageLoaded();
+      });
+      image.src = $(this).attr('src');
+    }
+  });
+
+  function singleImageLoaded() {
+    unloaded--;
+
+    if (unloaded === 0) {
+      callback();
+    }
+  }
+}
+
+/*******************************************
+ *                                         *
+ * This util was created by Marius Olbertz *
+ * Please thank Marius on GitHub /owlbertz *
+ * or the web http://www.mariusolbertz.de/ *
+ *                                         *
+ ******************************************/
+var keyCodes = {
+  9: 'TAB',
+  13: 'ENTER',
+  27: 'ESCAPE',
+  32: 'SPACE',
+  35: 'END',
+  36: 'HOME',
+  37: 'ARROW_LEFT',
+  38: 'ARROW_UP',
+  39: 'ARROW_RIGHT',
+  40: 'ARROW_DOWN'
+};
+var commands = {}; // Functions pulled out to be referenceable from internals
+
+function findFocusable($element) {
+  if (!$element) {
+    return false;
+  }
+
+  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function () {
+    if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) {
+      return false;
+    } //only have visible elements and those that have a tabindex greater or equal 0
+
+
+    return true;
+  });
+}
+
+function parseKey(event) {
+  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase(); // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events
+
+  key = key.replace(/\W+/, '');
+  if (event.shiftKey) key = "SHIFT_".concat(key);
+  if (event.ctrlKey) key = "CTRL_".concat(key);
+  if (event.altKey) key = "ALT_".concat(key); // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)
+
+  key = key.replace(/_$/, '');
+  return key;
+}
+
+var Keyboard = {
+  keys: getKeyCodes(keyCodes),
+
+  /**
+   * Parses the (keyboard) event and returns a String that represents its key
+   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
+   * @param {Event} event - the event generated by the event handler
+   * @return String key - String that represents the key pressed
+   */
+  parseKey: parseKey,
+
+  /**
+   * Handles the given (keyboard) event
+   * @param {Event} event - the event generated by the event handler
+   * @param {String} component - Foundation component's name, e.g. Slider or Reveal
+   * @param {Objects} functions - collection of functions that are to be executed
+   */
+  handleKey: function handleKey(event, component, functions) {
+    var commandList = commands[component],
+        keyCode = this.parseKey(event),
+        cmds,
+        command,
+        fn;
+    if (!commandList) return console.warn('Component not defined!');
+
+    if (typeof commandList.ltr === 'undefined') {
+      // this component does not differentiate between ltr and rtl
+      cmds = commandList; // use plain list
+    } else {
+      // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa
+      if (rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);else cmds = $.extend({}, commandList.rtl, commandList.ltr);
+    }
+
+    command = cmds[keyCode];
+    fn = functions[command];
+
+    if (fn && typeof fn === 'function') {
+      // execute function  if exists
+      var returnValue = fn.apply();
+
+      if (functions.handled || typeof functions.handled === 'function') {
+        // execute function when event was handled
+        functions.handled(returnValue);
+      }
+    } else {
+      if (functions.unhandled || typeof functions.unhandled === 'function') {
+        // execute function when event was not handled
+        functions.unhandled();
+      }
+    }
+  },
+
+  /**
+   * Finds all focusable elements within the given `$element`
+   * @param {jQuery} $element - jQuery object to search within
+   * @return {jQuery} $focusable - all focusable elements within `$element`
+   */
+  findFocusable: findFocusable,
+
+  /**
+   * Returns the component name name
+   * @param {Object} component - Foundation component, e.g. Slider or Reveal
+   * @return String componentName
+   */
+  register: function register(componentName, cmds) {
+    commands[componentName] = cmds;
+  },
+  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?
+  //
+
+  /**
+   * Traps the focus in the given element.
+   * @param  {jQuery} $element  jQuery object to trap the foucs into.
+   */
+  trapFocus: function trapFocus($element) {
+    var $focusable = findFocusable($element),
+        $firstFocusable = $focusable.eq(0),
+        $lastFocusable = $focusable.eq(-1);
+    $element.on('keydown.zf.trapfocus', function (event) {
+      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {
+        event.preventDefault();
+        $firstFocusable.focus();
+      } else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {
+        event.preventDefault();
+        $lastFocusable.focus();
+      }
+    });
+  },
+
+  /**
+   * Releases the trapped focus from the given element.
+   * @param  {jQuery} $element  jQuery object to release the focus for.
+   */
+  releaseFocus: function releaseFocus($element) {
+    $element.off('keydown.zf.trapfocus');
+  }
+};
+/*
+ * Constants for easier comparing.
+ * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
+ */
+
+function getKeyCodes(kcs) {
+  var k = {};
+
+  for (var kc in kcs) {
+    k[kcs[kc]] = kcs[kc];
+  }
+
+  return k;
+}
+
+/**
+ * Motion module.
+ * @module foundation.motion
+ */
+
+var initClasses = ['mui-enter', 'mui-leave'];
+var activeClasses = ['mui-enter-active', 'mui-leave-active'];
+var Motion = {
+  animateIn: function animateIn(element, animation, cb) {
+    animate(true, element, animation, cb);
+  },
+  animateOut: function animateOut(element, animation, cb) {
+    animate(false, element, animation, cb);
+  }
+};
+
+function Move(duration, elem, fn) {
+  var anim,
+      prog,
+      start = null; // console.log('called');
+
+  if (duration === 0) {
+    fn.apply(elem);
+    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
+    return;
+  }
+
+  function move(ts) {
+    if (!start) start = ts; // console.log(start, ts);
+
+    prog = ts - start;
+    fn.apply(elem);
+
+    if (prog < duration) {
+      anim = window.requestAnimationFrame(move, elem);
+    } else {
+      window.cancelAnimationFrame(anim);
+      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
+    }
+  }
+
+  anim = window.requestAnimationFrame(move);
+}
+/**
+ * Animates an element in or out using a CSS transition class.
+ * @function
+ * @private
+ * @param {Boolean} isIn - Defines if the animation is in or out.
+ * @param {Object} element - jQuery or HTML object to animate.
+ * @param {String} animation - CSS class to use.
+ * @param {Function} cb - Callback to run when animation is finished.
+ */
+
+
+function animate(isIn, element, animation, cb) {
+  element = $(element).eq(0);
+  if (!element.length) return;
+  var initClass = isIn ? initClasses[0] : initClasses[1];
+  var activeClass = isIn ? activeClasses[0] : activeClasses[1]; // Set up the animation
+
+  reset();
+  element.addClass(animation).css('transition', 'none');
+  requestAnimationFrame(function () {
+    element.addClass(initClass);
+    if (isIn) element.show();
+  }); // Start the animation
+
+  requestAnimationFrame(function () {
+    element[0].offsetWidth;
+    element.css('transition', '').addClass(activeClass);
+  }); // Clean up the animation when it finishes
+
+  element.one(transitionend(element), finish); // Hides the element (for out animations), resets the element, and runs a callback
+
+  function finish() {
+    if (!isIn) element.hide();
+    reset();
+    if (cb) cb.apply(element);
+  } // Resets transitions and removes motion-specific classes
+
+
+  function reset() {
+    element[0].style.transitionDuration = 0;
+    element.removeClass("".concat(initClass, " ").concat(activeClass, " ").concat(animation));
+  }
+}
+
+var Nest = {
+  Feather: function Feather(menu) {
+    var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zf';
+    menu.attr('role', 'menubar');
+    var items = menu.find('li').attr({
+      'role': 'menuitem'
+    }),
+        subMenuClass = "is-".concat(type, "-submenu"),
+        subItemClass = "".concat(subMenuClass, "-item"),
+        hasSubClass = "is-".concat(type, "-submenu-parent"),
+        applyAria = type !== 'accordion'; // Accordions handle their own ARIA attriutes.
+
+    items.each(function () {
+      var $item = $(this),
+          $sub = $item.children('ul');
+
+      if ($sub.length) {
+        $item.addClass(hasSubClass);
+
+        if (applyAria) {
+          $item.attr({
+            'aria-haspopup': true,
+            'aria-label': $item.children('a:first').text()
+          }); // Note:  Drilldowns behave differently in how they hide, and so need
+          // additional attributes.  We should look if this possibly over-generalized
+          // utility (Nest) is appropriate when we rework menus in 6.4
+
+          if (type === 'drilldown') {
+            $item.attr({
+              'aria-expanded': false
+            });
+          }
+        }
+
+        $sub.addClass("submenu ".concat(subMenuClass)).attr({
+          'data-submenu': '',
+          'role': 'menubar'
+        });
+
+        if (type === 'drilldown') {
+          $sub.attr({
+            'aria-hidden': true
+          });
+        }
+      }
+
+      if ($item.parent('[data-submenu]').length) {
+        $item.addClass("is-submenu-item ".concat(subItemClass));
+      }
+    });
+    return;
+  },
+  Burn: function Burn(menu, type) {
+    var //items = menu.find('li'),
+    subMenuClass = "is-".concat(type, "-submenu"),
+        subItemClass = "".concat(subMenuClass, "-item"),
+        hasSubClass = "is-".concat(type, "-submenu-parent");
+    menu.find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li').removeClass("".concat(subMenuClass, " ").concat(subItemClass, " ").concat(hasSubClass, " is-submenu-item submenu is-active")).removeAttr('data-submenu').css('display', '');
+  }
+};
+
+function Timer(elem, options, cb) {
+  var _this = this,
+      duration = options.duration,
+      //options is an object for easily adding features later.
+  nameSpace = Object.keys(elem.data())[0] || 'timer',
+      remain = -1,
+      start,
+      timer;
+
+  this.isPaused = false;
+
+  this.restart = function () {
+    remain = -1;
+    clearTimeout(timer);
+    this.start();
+  };
+
+  this.start = function () {
+    this.isPaused = false; // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+
+    clearTimeout(timer);
+    remain = remain <= 0 ? duration : remain;
+    elem.data('paused', false);
+    start = Date.now();
+    timer = setTimeout(function () {
+      if (options.infinite) {
+        _this.restart(); //rerun the timer.
+
+      }
+
+      if (cb && typeof cb === 'function') {
+        cb();
+      }
+    }, remain);
+    elem.trigger("timerstart.zf.".concat(nameSpace));
+  };
+
+  this.pause = function () {
+    this.isPaused = true; //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+
+    clearTimeout(timer);
+    elem.data('paused', true);
+    var end = Date.now();
+    remain = remain - (end - start);
+    elem.trigger("timerpaused.zf.".concat(nameSpace));
+  };
+}
+
+var Touch = {};
+var startPosX,
+    startPosY,
+    startTime,
+    elapsedTime,
+    startEvent,
+    isMoving = false,
+    didMoved = false;
+
+function onTouchEnd(e) {
+  this.removeEventListener('touchmove', onTouchMove);
+  this.removeEventListener('touchend', onTouchEnd); // If the touch did not move, consider it as a "tap"
+
+  if (!didMoved) {
+    var tapEvent = $.Event('tap', startEvent || e);
+    $(this).trigger(tapEvent);
+  }
+
+  startEvent = null;
+  isMoving = false;
+  didMoved = false;
+}
+
+function onTouchMove(e) {
+  if ($.spotSwipe.preventDefault) {
+    e.preventDefault();
+  }
+
+  if (isMoving) {
+    var x = e.touches[0].pageX;
+    var y = e.touches[0].pageY;
+    var dx = startPosX - x;
+    var dir;
+    didMoved = true;
+    elapsedTime = new Date().getTime() - startTime;
+
+    if (Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
+      dir = dx > 0 ? 'left' : 'right';
+    } // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
+    //   dir = dy > 0 ? 'down' : 'up';
+    // }
+
+
+    if (dir) {
+      e.preventDefault();
+      onTouchEnd.apply(this, arguments);
+      $(this).trigger($.Event('swipe', e), dir).trigger($.Event("swipe".concat(dir), e));
+    }
+  }
+}
+
+function onTouchStart(e) {
+  if (e.touches.length == 1) {
+    startPosX = e.touches[0].pageX;
+    startPosY = e.touches[0].pageY;
+    startEvent = e;
+    isMoving = true;
+    didMoved = false;
+    startTime = new Date().getTime();
+    this.addEventListener('touchmove', onTouchMove, false);
+    this.addEventListener('touchend', onTouchEnd, false);
+  }
+}
+
+function init() {
+  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);
+}
+
+var SpotSwipe =
+/*#__PURE__*/
+function () {
+  function SpotSwipe($$$1) {
+    _classCallCheck(this, SpotSwipe);
+
+    this.version = '1.0.0';
+    this.enabled = 'ontouchstart' in document.documentElement;
+    this.preventDefault = false;
+    this.moveThreshold = 75;
+    this.timeThreshold = 200;
+    this.$ = $$$1;
+
+    this._init();
+  }
+
+  _createClass(SpotSwipe, [{
+    key: "_init",
+    value: function _init() {
+      var $$$1 = this.$;
+      $$$1.event.special.swipe = {
+        setup: init
+      };
+      $$$1.event.special.tap = {
+        setup: init
+      };
+      $$$1.each(['left', 'up', 'down', 'right'], function () {
+        $$$1.event.special["swipe".concat(this)] = {
+          setup: function setup() {
+            $$$1(this).on('swipe', $$$1.noop);
+          }
+        };
+      });
+    }
+  }]);
+
+  return SpotSwipe;
+}();
+/****************************************************
+ * As far as I can tell, both setupSpotSwipe and    *
+ * setupTouchHandler should be idempotent,          *
+ * because they directly replace functions &        *
+ * values, and do not add event handlers directly.  *
+ ****************************************************/
+
+
+Touch.setupSpotSwipe = function ($$$1) {
+  $$$1.spotSwipe = new SpotSwipe($$$1);
+};
+/****************************************************
+ * Method for adding pseudo drag events to elements *
+ ***************************************************/
+
+
+Touch.setupTouchHandler = function ($$$1) {
+  $$$1.fn.addTouch = function () {
+    this.each(function (i, el) {
+      $$$1(el).bind('touchstart touchmove touchend touchcancel', function (event) {
+        //we pass the original event object because the jQuery event
+        //object is normalized to w3c specs and does not provide the TouchList
+        handleTouch(event);
+      });
+    });
+
+    var handleTouch = function handleTouch(event) {
+      var touches = event.changedTouches,
+          first = touches[0],
+          eventTypes = {
+        touchstart: 'mousedown',
+        touchmove: 'mousemove',
+        touchend: 'mouseup'
+      },
+          type = eventTypes[event.type],
+          simulatedEvent;
+
+      if ('MouseEvent' in window && typeof window.MouseEvent === 'function') {
+        simulatedEvent = new window.MouseEvent(type, {
+          'bubbles': true,
+          'cancelable': true,
+          'screenX': first.screenX,
+          'screenY': first.screenY,
+          'clientX': first.clientX,
+          'clientY': first.clientY
+        });
+      } else {
+        simulatedEvent = document.createEvent('MouseEvent');
+        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0
+        /*left*/
+        , null);
+      }
+
+      first.target.dispatchEvent(simulatedEvent);
+    };
+  };
+};
+
+Touch.init = function ($$$1) {
+  if (typeof $$$1.spotSwipe === 'undefined') {
+    Touch.setupSpotSwipe($$$1);
+    Touch.setupTouchHandler($$$1);
+  }
+};
+
+var MutationObserver = function () {
+  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
+  for (var i = 0; i < prefixes.length; i++) {
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
+    }
+  }
+
+  return false;
+}();
+
+var triggers = function triggers(el, type) {
+  el.data(type).split(' ').forEach(function (id) {
+    $("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
+  });
+};
+
+var Triggers = {
+  Listeners: {
+    Basic: {},
+    Global: {}
+  },
+  Initializers: {}
+};
+Triggers.Listeners.Basic = {
+  openListener: function openListener() {
+    triggers($(this), 'open');
+  },
+  closeListener: function closeListener() {
+    var id = $(this).data('close');
+
+    if (id) {
+      triggers($(this), 'close');
+    } else {
+      $(this).trigger('close.zf.trigger');
+    }
+  },
+  toggleListener: function toggleListener() {
+    var id = $(this).data('toggle');
+
+    if (id) {
+      triggers($(this), 'toggle');
+    } else {
+      $(this).trigger('toggle.zf.trigger');
+    }
+  },
+  closeableListener: function closeableListener(e) {
+    e.stopPropagation();
+    var animation = $(this).data('closable');
+
+    if (animation !== '') {
+      Motion.animateOut($(this), animation, function () {
+        $(this).trigger('closed.zf');
+      });
+    } else {
+      $(this).fadeOut().trigger('closed.zf');
+    }
+  },
+  toggleFocusListener: function toggleFocusListener() {
+    var id = $(this).data('toggle-focus');
+    $("#".concat(id)).triggerHandler('toggle.zf.trigger', [$(this)]);
+  }
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
+
+Triggers.Initializers.addOpenListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
+  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
+// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
+Triggers.Initializers.addCloseListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
+  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
+
+Triggers.Initializers.addToggleListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
+  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
+
+Triggers.Initializers.addCloseableListener = function ($elem) {
+  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
+  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
+
+Triggers.Initializers.addToggleFocusListener = function ($elem) {
+  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
+  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
+}; // More Global/complex listeners and triggers
+
+
+Triggers.Listeners.Global = {
+  resizeListener: function resizeListener($nodes) {
+    if (!MutationObserver) {
+      //fallback for IE 9
+      $nodes.each(function () {
+        $(this).triggerHandler('resizeme.zf.trigger');
+      });
+    } //trigger all listening elements and signal a resize event
+
+
+    $nodes.attr('data-events', "resize");
+  },
+  scrollListener: function scrollListener($nodes) {
+    if (!MutationObserver) {
+      //fallback for IE 9
+      $nodes.each(function () {
+        $(this).triggerHandler('scrollme.zf.trigger');
+      });
+    } //trigger all listening elements and signal a scroll event
+
+
+    $nodes.attr('data-events', "scroll");
+  },
+  closeMeListener: function closeMeListener(e, pluginId) {
+    var plugin = e.namespace.split('.')[0];
+    var plugins = $("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
+    plugins.each(function () {
+      var _this = $(this);
+
+      _this.triggerHandler('close.zf.trigger', [_this]);
+    });
+  } // Global, parses whole document.
+
+};
+
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = $('[data-yeti-box]'),
+      plugNames = ['dropdown', 'tooltip', 'reveal'];
+
+  if (pluginName) {
+    if (typeof pluginName === 'string') {
+      plugNames.push(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
+    } else {
+      console.error('Plugin names must be strings');
+    }
+  }
+
+  if (yetiBoxes.length) {
+    var listeners = plugNames.map(function (name) {
+      return "closeme.zf.".concat(name);
+    }).join(' ');
+    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+  }
+};
+
+function debounceGlobalListener(debounce, trigger, listener) {
+  var timer,
+      args = Array.prototype.slice.call(arguments, 3);
+  $(window).off(trigger).on(trigger, function (e) {
+    if (timer) {
+      clearTimeout(timer);
+    }
+
+    timer = setTimeout(function () {
+      listener.apply(null, args);
+    }, debounce || 10); //default time to emit scroll event
+  });
+}
+
+Triggers.Initializers.addResizeListener = function (debounce) {
+  var $nodes = $('[data-resize]');
+
+  if ($nodes.length) {
+    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
+  }
+};
+
+Triggers.Initializers.addScrollListener = function (debounce) {
+  var $nodes = $('[data-scroll]');
+
+  if ($nodes.length) {
+    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
+  }
+};
+
+Triggers.Initializers.addMutationEventsListener = function ($elem) {
+  if (!MutationObserver) {
+    return false;
+  }
+
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = $(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
+
+    switch (mutationRecordsList[0].type) {
+      case "attributes":
+        if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
+          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
+        }
+
+        if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
+          $target.triggerHandler('resizeme.zf.trigger', [$target]);
+        }
+
+        if (mutationRecordsList[0].attributeName === "style") {
+          $target.closest("[data-mutate]").attr("data-events", "mutate");
+          $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+        }
+
+        break;
+
+      case "childList":
+        $target.closest("[data-mutate]").attr("data-events", "mutate");
+        $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+        break;
+
+      default:
+        return false;
+      //nothing
+    }
+  };
+
+  if ($nodes.length) {
+    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
+    for (var i = 0; i <= $nodes.length - 1; i++) {
+      var elementObserver = new MutationObserver(listeningElementsMutation);
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
+    }
+  }
+};
+
+Triggers.Initializers.addSimpleListeners = function () {
+  var $document = $(document);
+  Triggers.Initializers.addOpenListener($document);
+  Triggers.Initializers.addCloseListener($document);
+  Triggers.Initializers.addToggleListener($document);
+  Triggers.Initializers.addCloseableListener($document);
+  Triggers.Initializers.addToggleFocusListener($document);
+};
+
+Triggers.Initializers.addGlobalListeners = function () {
+  var $document = $(document);
+  Triggers.Initializers.addMutationEventsListener($document);
+  Triggers.Initializers.addResizeListener();
+  Triggers.Initializers.addScrollListener();
+  Triggers.Initializers.addClosemeListener();
+};
+
+Triggers.init = function ($$$1, Foundation) {
+  onLoad($$$1(window), function () {
+    if ($$$1.triggersInitialized !== true) {
+      Triggers.Initializers.addSimpleListeners();
+      Triggers.Initializers.addGlobalListeners();
+      $$$1.triggersInitialized = true;
+    }
+  });
+
+  if (Foundation) {
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
+    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
+  }
+};
+
+// {function} _setup (replaces previous constructor),
+// {function} _destroy (replaces previous destroy)
+
+var Plugin =
+/*#__PURE__*/
+function () {
+  function Plugin(element, options) {
+    _classCallCheck(this, Plugin);
+
+    this._setup(element, options);
+
+    var pluginName = getPluginName(this);
+    this.uuid = GetYoDigits(6, pluginName);
+
+    if (!this.$element.attr("data-".concat(pluginName))) {
+      this.$element.attr("data-".concat(pluginName), this.uuid);
+    }
+
+    if (!this.$element.data('zfPlugin')) {
+      this.$element.data('zfPlugin', this);
+    }
+    /**
+     * Fires when the plugin has initialized.
+     * @event Plugin#init
+     */
+
+
+    this.$element.trigger("init.zf.".concat(pluginName));
+  }
+
+  _createClass(Plugin, [{
+    key: "destroy",
+    value: function destroy() {
+      this._destroy();
+
+      var pluginName = getPluginName(this);
+      this.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin')
+      /**
+       * Fires when the plugin has been destroyed.
+       * @event Plugin#destroyed
+       */
+      .trigger("destroyed.zf.".concat(pluginName));
+
+      for (var prop in this) {
+        this[prop] = null; //clean up script to prep for garbage collection.
+      }
+    }
+  }]);
+
+  return Plugin;
+}(); // Convert PascalCase to kebab-case
+// Thank you: http://stackoverflow.com/a/8955580
+
+
+function hyphenate$1(str) {
+  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
+}
+
+function getPluginName(obj) {
+  if (typeof obj.constructor.name !== 'undefined') {
+    return hyphenate$1(obj.constructor.name);
+  } else {
+    return hyphenate$1(obj.className);
+  }
+}
+
+/**
+ * Abide module.
+ * @module foundation.abide
+ */
+
+var Abide =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Abide, _Plugin);
+
+  function Abide() {
+    _classCallCheck(this, Abide);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Abide).apply(this, arguments));
+  }
+
+  _createClass(Abide, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Abide.
+     * @class
+     * @name Abide
+     * @fires Abide#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element) {
+      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+      this.$element = element;
+      this.options = $.extend(true, {}, Abide.defaults, this.$element.data(), options);
+      this.className = 'Abide'; // ie9 back compat
+
+      this._init();
+    }
+    /**
+     * Initializes the Abide plugin and calls functions to get Abide functioning on load.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      this.$inputs = $.merge( // Consider as input to validate:
+      this.$element.find('input').not('[type=submit]'), // * all input fields expect submit
+      this.$element.find('textarea, select') // * all textareas and select fields
+      );
+      var $globalErrors = this.$element.find('[data-abide-error]'); // Add a11y attributes to all fields
+
+      if (this.options.a11yAttributes) {
+        this.$inputs.each(function (i, input) {
+          return _this2.addA11yAttributes($(input));
+        });
+        $globalErrors.each(function (i, error) {
+          return _this2.addGlobalErrorA11yAttributes($(error));
+        });
+      }
+
+      this._events();
+    }
+    /**
+     * Initializes events for Abide.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this3 = this;
+
+      this.$element.off('.abide').on('reset.zf.abide', function () {
+        _this3.resetForm();
+      }).on('submit.zf.abide', function () {
+        return _this3.validateForm();
+      });
+
+      if (this.options.validateOn === 'fieldChange') {
+        this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) {
+          _this3.validateInput($(e.target));
+        });
+      }
+
+      if (this.options.liveValidate) {
+        this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) {
+          _this3.validateInput($(e.target));
+        });
+      }
+
+      if (this.options.validateOnBlur) {
+        this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) {
+          _this3.validateInput($(e.target));
+        });
+      }
+    }
+    /**
+     * Calls necessary functions to update Abide upon DOM change
+     * @private
+     */
+
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      this._init();
+    }
+    /**
+     * Checks whether or not a form element has the required attribute and if it's checked or not
+     * @param {Object} element - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
+
+  }, {
+    key: "requiredCheck",
+    value: function requiredCheck($el) {
+      if (!$el.attr('required')) return true;
+      var isGood = true;
+
+      switch ($el[0].type) {
+        case 'checkbox':
+          isGood = $el[0].checked;
+          break;
+
+        case 'select':
+        case 'select-one':
+        case 'select-multiple':
+          var opt = $el.find('option:selected');
+          if (!opt.length || !opt.val()) isGood = false;
+          break;
+
+        default:
+          if (!$el.val() || !$el.val().length) isGood = false;
+      }
+
+      return isGood;
+    }
+    /**
+     * Get:
+     * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:
+     *   1. The element's direct sibling('s).
+     *   2. The element's parent's children.
+     * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.
+     *
+     * This allows for multiple form errors per input, though if none are found, no form errors will be shown.
+     *
+     * @param {Object} $el - jQuery object to use as reference to find the form error selector.
+     * @returns {Object} jQuery object with the selector.
+     */
+
+  }, {
+    key: "findFormError",
+    value: function findFormError($el) {
+      var id = $el[0].id;
+      var $error = $el.siblings(this.options.formErrorSelector);
+
+      if (!$error.length) {
+        $error = $el.parent().find(this.options.formErrorSelector);
+      }
+
+      if (id) {
+        $error = $error.add(this.$element.find("[data-form-error-for=\"".concat(id, "\"]")));
+      }
+
+      return $error;
+    }
+    /**
+     * Get the first element in this order:
+     * 2. The <label> with the attribute `[for="someInputId"]`
+     * 3. The `.closest()` <label>
+     *
+     * @param {Object} $el - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
+
+  }, {
+    key: "findLabel",
+    value: function findLabel($el) {
+      var id = $el[0].id;
+      var $label = this.$element.find("label[for=\"".concat(id, "\"]"));
+
+      if (!$label.length) {
+        return $el.closest('label');
+      }
+
+      return $label;
+    }
+    /**
+     * Get the set of labels associated with a set of radio els in this order
+     * 2. The <label> with the attribute `[for="someInputId"]`
+     * 3. The `.closest()` <label>
+     *
+     * @param {Object} $el - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
+
+  }, {
+    key: "findRadioLabels",
+    value: function findRadioLabels($els) {
+      var _this4 = this;
+
+      var labels = $els.map(function (i, el) {
+        var id = el.id;
+
+        var $label = _this4.$element.find("label[for=\"".concat(id, "\"]"));
+
+        if (!$label.length) {
+          $label = $(el).closest('label');
+        }
+
+        return $label[0];
+      });
+      return $(labels);
+    }
+    /**
+     * Adds the CSS error class as specified by the Abide settings to the label, input, and the form
+     * @param {Object} $el - jQuery object to add the class to
+     */
+
+  }, {
+    key: "addErrorClasses",
+    value: function addErrorClasses($el) {
+      var $label = this.findLabel($el);
+      var $formError = this.findFormError($el);
+
+      if ($label.length) {
+        $label.addClass(this.options.labelErrorClass);
+      }
+
+      if ($formError.length) {
+        $formError.addClass(this.options.formErrorClass);
+      }
+
+      $el.addClass(this.options.inputErrorClass).attr({
+        'data-invalid': '',
+        'aria-invalid': true
+      });
+    }
+    /**
+     * Adds [for] and [role=alert] attributes to all form error targetting $el,
+     * and [aria-describedby] attribute to $el toward the first form error.
+     * @param {Object} $el - jQuery object
+     */
+
+  }, {
+    key: "addA11yAttributes",
+    value: function addA11yAttributes($el) {
+      var $errors = this.findFormError($el);
+      var $labels = $errors.filter('label');
+      var $error = $errors.first();
+      if (!$errors.length) return; // Set [aria-describedby] on the input toward the first form error if it is not set
+
+      if (typeof $el.attr('aria-describedby') === 'undefined') {
+        // Get the first error ID or create one
+        var errorId = $error.attr('id');
+
+        if (typeof errorId === 'undefined') {
+          errorId = GetYoDigits(6, 'abide-error');
+          $error.attr('id', errorId);
+        }
+        $el.attr('aria-describedby', errorId);
+      }
+
+      if ($labels.filter('[for]').length < $labels.length) {
+        // Get the input ID or create one
+        var elemId = $el.attr('id');
+
+        if (typeof elemId === 'undefined') {
+          elemId = GetYoDigits(6, 'abide-input');
+          $el.attr('id', elemId);
+        }
+
+        $labels.each(function (i, label) {
+          var $label = $(label);
+          if (typeof $label.attr('for') === 'undefined') $label.attr('for', elemId);
+        });
+      } // For each error targeting $el, set [role=alert] if it is not set.
+
+
+      $errors.each(function (i, label) {
+        var $label = $(label);
+        if (typeof $label.attr('role') === 'undefined') $label.attr('role', 'alert');
+      }).end();
+    }
+    /**
+     * Adds [aria-live] attribute to the given global form error $el.
+     * @param {Object} $el - jQuery object to add the attribute to
+     */
+
+  }, {
+    key: "addGlobalErrorA11yAttributes",
+    value: function addGlobalErrorA11yAttributes($el) {
+      if (typeof $el.attr('aria-live') === 'undefined') $el.attr('aria-live', this.options.a11yErrorLevel);
+    }
+    /**
+     * Remove CSS error classes etc from an entire radio button group
+     * @param {String} groupName - A string that specifies the name of a radio button group
+     *
+     */
+
+  }, {
+    key: "removeRadioErrorClasses",
+    value: function removeRadioErrorClasses(groupName) {
+      var $els = this.$element.find(":radio[name=\"".concat(groupName, "\"]"));
+      var $labels = this.findRadioLabels($els);
+      var $formErrors = this.findFormError($els);
+
+      if ($labels.length) {
+        $labels.removeClass(this.options.labelErrorClass);
+      }
+
+      if ($formErrors.length) {
+        $formErrors.removeClass(this.options.formErrorClass);
+      }
+
+      $els.removeClass(this.options.inputErrorClass).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+    }
+    /**
+     * Removes CSS error class as specified by the Abide settings from the label, input, and the form
+     * @param {Object} $el - jQuery object to remove the class from
+     */
+
+  }, {
+    key: "removeErrorClasses",
+    value: function removeErrorClasses($el) {
+      // radios need to clear all of the els
+      if ($el[0].type == 'radio') {
+        return this.removeRadioErrorClasses($el.attr('name'));
+      }
+
+      var $label = this.findLabel($el);
+      var $formError = this.findFormError($el);
+
+      if ($label.length) {
+        $label.removeClass(this.options.labelErrorClass);
+      }
+
+      if ($formError.length) {
+        $formError.removeClass(this.options.formErrorClass);
+      }
+
+      $el.removeClass(this.options.inputErrorClass).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+    }
+    /**
+     * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.
+     * Ignores inputs with data-abide-ignore, type="hidden" or disabled attributes set
+     * @fires Abide#invalid
+     * @fires Abide#valid
+     * @param {Object} element - jQuery object to validate, should be an HTML input
+     * @returns {Boolean} goodToGo - If the input is valid or not.
+     */
+
+  }, {
+    key: "validateInput",
+    value: function validateInput($el) {
+      var clearRequire = this.requiredCheck($el),
+          validated = false,
+          customValidator = true,
+          validator = $el.attr('data-validator'),
+          equalTo = true; // don't validate ignored inputs or hidden inputs or disabled inputs
+
+      if ($el.is('[data-abide-ignore]') || $el.is('[type="hidden"]') || $el.is('[disabled]')) {
+        return true;
+      }
+
+      switch ($el[0].type) {
+        case 'radio':
+          validated = this.validateRadio($el.attr('name'));
+          break;
+
+        case 'checkbox':
+          validated = clearRequire;
+          break;
+
+        case 'select':
+        case 'select-one':
+        case 'select-multiple':
+          validated = clearRequire;
+          break;
+
+        default:
+          validated = this.validateText($el);
+      }
+
+      if (validator) {
+        customValidator = this.matchValidation($el, validator, $el.attr('required'));
+      }
+
+      if ($el.attr('data-equalto')) {
+        equalTo = this.options.validators.equalTo($el);
+      }
+
+      var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;
+      var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';
+
+      if (goodToGo) {
+        // Re-validate inputs that depend on this one with equalto
+        var dependentElements = this.$element.find("[data-equalto=\"".concat($el.attr('id'), "\"]"));
+
+        if (dependentElements.length) {
+          var _this = this;
+
+          dependentElements.each(function () {
+            if ($(this).val()) {
+              _this.validateInput($(this));
+            }
+          });
+        }
+      }
+
+      this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);
+      /**
+       * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`
+       * Trigger includes the DOM element of the input.
+       * @event Abide#valid
+       * @event Abide#invalid
+       */
+
+      $el.trigger(message, [$el]);
+      return goodToGo;
+    }
+    /**
+     * Goes through a form and if there are any invalid inputs, it will display the form error element
+     * @returns {Boolean} noError - true if no errors were detected...
+     * @fires Abide#formvalid
+     * @fires Abide#forminvalid
+     */
+
+  }, {
+    key: "validateForm",
+    value: function validateForm() {
+      var _this5 = this;
+
+      var acc = [];
+
+      var _this = this;
+
+      this.$inputs.each(function () {
+        acc.push(_this.validateInput($(this)));
+      });
+      var noError = acc.indexOf(false) === -1;
+      this.$element.find('[data-abide-error]').each(function (i, elem) {
+        var $elem = $(elem); // Ensure a11y attributes are set
+
+        if (_this5.options.a11yAttributes) _this5.addGlobalErrorA11yAttributes($elem); // Show or hide the error
+
+        $elem.css('display', noError ? 'none' : 'block');
+      });
+      /**
+       * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.
+       * Trigger includes the element of the form.
+       * @event Abide#formvalid
+       * @event Abide#forminvalid
+       */
+
+      this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);
+      return noError;
+    }
+    /**
+     * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.
+     * @param {Object} $el - jQuery object to validate, should be a text input HTML element
+     * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns
+     * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified
+     */
+
+  }, {
+    key: "validateText",
+    value: function validateText($el, pattern) {
+      // A pattern can be passed to this function, or it will be infered from the input's "pattern" attribute, or it's "type" attribute
+      pattern = pattern || $el.attr('pattern') || $el.attr('type');
+      var inputText = $el.val();
+      var valid = false;
+
+      if (inputText.length) {
+        // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp
+        if (this.options.patterns.hasOwnProperty(pattern)) {
+          valid = this.options.patterns[pattern].test(inputText);
+        } // If the pattern name isn't also the type attribute of the field, then test it as a regexp
+        else if (pattern !== $el.attr('type')) {
+            valid = new RegExp(pattern).test(inputText);
+          } else {
+            valid = true;
+          }
+      } // An empty field is valid if it's not required
+      else if (!$el.prop('required')) {
+          valid = true;
+        }
+
+      return valid;
+    }
+    /**
+     * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.
+     * @param {String} groupName - A string that specifies the name of a radio button group
+     * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)
+     */
+
+  }, {
+    key: "validateRadio",
+    value: function validateRadio(groupName) {
+      // If at least one radio in the group has the `required` attribute, the group is considered required
+      // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice
+      var $group = this.$element.find(":radio[name=\"".concat(groupName, "\"]"));
+      var valid = false,
+          required = false; // For the group to be required, at least one radio needs to be required
+
+      $group.each(function (i, e) {
+        if ($(e).attr('required')) {
+          required = true;
+        }
+      });
+      if (!required) valid = true;
+
+      if (!valid) {
+        // For the group to be valid, at least one radio needs to be checked
+        $group.each(function (i, e) {
+          if ($(e).prop('checked')) {
+            valid = true;
+          }
+        });
+      }
+      return valid;
+    }
+    /**
+     * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator="foo bar baz"` in a space separated listed.
+     * @param {Object} $el - jQuery input element.
+     * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.
+     * @param {Boolean} required - self explanatory?
+     * @returns {Boolean} - true if validations passed.
+     */
+
+  }, {
+    key: "matchValidation",
+    value: function matchValidation($el, validators, required) {
+      var _this6 = this;
+
+      required = required ? true : false;
+      var clear = validators.split(' ').map(function (v) {
+        return _this6.options.validators[v]($el, required, $el.parent());
+      });
+      return clear.indexOf(false) === -1;
+    }
+    /**
+     * Resets form inputs and styles
+     * @fires Abide#formreset
+     */
+
+  }, {
+    key: "resetForm",
+    value: function resetForm() {
+      var $form = this.$element,
+          opts = this.options;
+      $(".".concat(opts.labelErrorClass), $form).not('small').removeClass(opts.labelErrorClass);
+      $(".".concat(opts.inputErrorClass), $form).not('small').removeClass(opts.inputErrorClass);
+      $("".concat(opts.formErrorSelector, ".").concat(opts.formErrorClass)).removeClass(opts.formErrorClass);
+      $form.find('[data-abide-error]').css('display', 'none');
+      $(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      $(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      /**
+       * Fires when the form has been reset.
+       * @event Abide#formreset
+       */
+
+      $form.trigger('formreset.zf.abide', [$form]);
+    }
+    /**
+     * Destroys an instance of Abide.
+     * Removes error styles and classes from elements, without resetting their values.
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      var _this = this;
+
+      this.$element.off('.abide').find('[data-abide-error]').css('display', 'none');
+      this.$inputs.off('.abide').each(function () {
+        _this.removeErrorClasses($(this));
+      });
+    }
+  }]);
+
+  return Abide;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+Abide.defaults = {
+  /**
+   * The default event to validate inputs. Checkboxes and radios validate immediately.
+   * Remove or change this value for manual validation.
+   * @option
+   * @type {?string}
+   * @default 'fieldChange'
+   */
+  validateOn: 'fieldChange',
+
+  /**
+   * Class to be applied to input labels on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-invalid-label'
+   */
+  labelErrorClass: 'is-invalid-label',
+
+  /**
+   * Class to be applied to inputs on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-invalid-input'
+   */
+  inputErrorClass: 'is-invalid-input',
+
+  /**
+   * Class selector to use to target Form Errors for show/hide.
+   * @option
+   * @type {string}
+   * @default '.form-error'
+   */
+  formErrorSelector: '.form-error',
+
+  /**
+   * Class added to Form Errors on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-visible'
+   */
+  formErrorClass: 'is-visible',
+
+  /**
+   * If true, automatically insert when possible:
+   * - `[aria-describedby]` on fields
+   * - `[role=alert]` on form errors and `[for]` on form error labels
+   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  a11yAttributes: true,
+
+  /**
+   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.
+   * Options are: 'assertive', 'polite' and 'off'/null
+   * @option
+   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions
+   * @type {string}
+   * @default 'assertive'
+   */
+  a11yErrorLevel: 'assertive',
+
+  /**
+   * Set to true to validate text inputs on any value change.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  liveValidate: false,
+
+  /**
+   * Set to true to validate inputs on blur.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  validateOnBlur: false,
+  patterns: {
+    alpha: /^[a-zA-Z]+$/,
+    alpha_numeric: /^[a-zA-Z0-9]+$/,
+    integer: /^[-+]?\d+$/,
+    number: /^[-+]?\d*(?:[\.\,]\d+)?$/,
+    // amex, visa, diners
+    card: /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,
+    cvv: /^([0-9]){3,4}$/,
+    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address
+    email: /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,
+    // From CommonRegexJS (@talyssonoc)
+    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76
+    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.
+    url: /^((?:(https?|ftps?|file|ssh|sftp):\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\))+(?:\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?\xab\xbb\u201c\u201d\u2018\u2019]))$/,
+    // abc.de
+    domain: /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,
+    datetime: /^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,
+    // YYYY-MM-DD
+    date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,
+    // HH:MM:SS
+    time: /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,
+    dateISO: /^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,
+    // MM/DD/YYYY
+    month_day_year: /^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,
+    // DD/MM/YYYY
+    day_month_year: /^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,
+    // #FFF or #FFFFFF
+    color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,
+    // Domain || URL
+    website: {
+      test: function test(text) {
+        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);
+      }
+    }
+  },
+
+  /**
+   * Optional validation functions to be used. `equalTo` being the only default included function.
+   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:
+   * el : The jQuery element to validate.
+   * required : Boolean value of the required attribute be present or not.
+   * parent : The direct parent of the input.
+   * @option
+   */
+  validators: {
+    equalTo: function equalTo(el, required, parent) {
+      return $("#".concat(el.attr('data-equalto'))).val() === el.val();
+    }
+  }
+};
+
+/**
+ * Accordion module.
+ * @module foundation.accordion
+ * @requires foundation.util.keyboard
+ */
+
+var Accordion =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Accordion, _Plugin);
+
+  function Accordion() {
+    _classCallCheck(this, Accordion);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Accordion).apply(this, arguments));
+  }
+
+  _createClass(Accordion, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of an accordion.
+     * @class
+     * @name Accordion
+     * @fires Accordion#init
+     * @param {jQuery} element - jQuery object to make into an accordion.
+     * @param {Object} options - a plain object with settings to override the default options.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);
+      this.className = 'Accordion'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('Accordion', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
+        'ARROW_DOWN': 'next',
+        'ARROW_UP': 'previous'
+      });
+    }
+    /**
+     * Initializes the accordion by animating the preset active pane(s).
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      this._isInitializing = true;
+      this.$element.attr('role', 'tablist');
+      this.$tabs = this.$element.children('[data-accordion-item]');
+      this.$tabs.each(function (idx, el) {
+        var $el = $(el),
+            $content = $el.children('[data-tab-content]'),
+            id = $content[0].id || GetYoDigits(6, 'accordion'),
+            linkId = el.id ? "".concat(el.id, "-label") : "".concat(id, "-label");
+        $el.find('a:first').attr({
+          'aria-controls': id,
+          'role': 'tab',
+          'id': linkId,
+          'aria-expanded': false,
+          'aria-selected': false
+        });
+        $content.attr({
+          'role': 'tabpanel',
+          'aria-labelledby': linkId,
+          'aria-hidden': true,
+          'id': id
+        });
+      });
+      var $initActive = this.$element.find('.is-active').children('[data-tab-content]');
+
+      if ($initActive.length) {
+        // Save up the initial hash to return to it later when going back in history
+        this._initialAnchor = $initActive.prev('a').attr('href');
+
+        this._openSingleTab($initActive);
+      }
+
+      this._checkDeepLink = function () {
+        var anchor = window.location.hash;
+
+        if (!anchor.length) {
+          // If we are still initializing and there is no anchor, then there is nothing to do
+          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor
+
+          if (_this2._initialAnchor) anchor = _this2._initialAnchor;
+        }
+
+        var $anchor = anchor && $(anchor);
+
+        var $link = anchor && _this2.$element.find("[href$=\"".concat(anchor, "\"]")); // Whether the anchor element that has been found is part of this element
+
+
+        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, open it (if not already active)
+
+        if ($anchor && $link && $link.length) {
+          if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {
+            _this2._openSingleTab($anchor);
+          }
+        } // Otherwise, close everything
+        else {
+            _this2._closeAllTabs();
+          }
+
+        if (isOwnAnchor) {
+          // Roll up a little to show the titles
+          if (_this2.options.deepLinkSmudge) {
+            onLoad($(window), function () {
+              var offset = _this2.$element.offset();
+
+              $('html, body').animate({
+                scrollTop: offset.top
+              }, _this2.options.deepLinkSmudgeDelay);
+            });
+          }
+          /**
+           * Fires when the plugin has deeplinked at pageload
+           * @event Accordion#deeplink
+           */
+
+
+          _this2.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);
+        }
+      }; //use browser to open a tab, if it exists in this tabset
+
+
+      if (this.options.deepLink) {
+        this._checkDeepLink();
+      }
+
+      this._events();
+
+      this._isInitializing = false;
+    }
+    /**
+     * Adds event handlers for items within the accordion.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      this.$tabs.each(function () {
+        var $elem = $(this);
+        var $tabContent = $elem.children('[data-tab-content]');
+
+        if ($tabContent.length) {
+          $elem.children('a').off('click.zf.accordion keydown.zf.accordion').on('click.zf.accordion', function (e) {
+            e.preventDefault();
+
+            _this.toggle($tabContent);
+          }).on('keydown.zf.accordion', function (e) {
+            Keyboard.handleKey(e, 'Accordion', {
+              toggle: function toggle() {
+                _this.toggle($tabContent);
+              },
+              next: function next() {
+                var $a = $elem.next().find('a').focus();
+
+                if (!_this.options.multiExpand) {
+                  $a.trigger('click.zf.accordion');
+                }
+              },
+              previous: function previous() {
+                var $a = $elem.prev().find('a').focus();
+
+                if (!_this.options.multiExpand) {
+                  $a.trigger('click.zf.accordion');
+                }
+              },
+              handled: function handled() {
+                e.preventDefault();
+                e.stopPropagation();
+              }
+            });
+          });
+        }
+      });
+
+      if (this.options.deepLink) {
+        $(window).on('hashchange', this._checkDeepLink);
+      }
+    }
+    /**
+     * Toggles the selected content pane's open/close state.
+     * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle($target) {
+      if ($target.closest('[data-accordion]').is('[disabled]')) {
+        console.info('Cannot toggle an accordion that is disabled.');
+        return;
+      }
+
+      if ($target.parent().hasClass('is-active')) {
+        this.up($target);
+      } else {
+        this.down($target);
+      } //either replace or update browser history
+
+
+      if (this.options.deepLink) {
+        var anchor = $target.prev('a').attr('href');
+
+        if (this.options.updateHistory) {
+          history.pushState({}, '', anchor);
+        } else {
+          history.replaceState({}, '', anchor);
+        }
+      }
+    }
+    /**
+     * Opens the accordion tab defined by `$target`.
+     * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).
+     * @fires Accordion#down
+     * @function
+     */
+
+  }, {
+    key: "down",
+    value: function down($target) {
+      if ($target.closest('[data-accordion]').is('[disabled]')) {
+        console.info('Cannot call down on an accordion that is disabled.');
+        return;
+      }
+
+      if (this.options.multiExpand) this._openTab($target);else this._openSingleTab($target);
+    }
+    /**
+     * Closes the tab defined by `$target`.
+     * It may be ignored if the Accordion options don't allow it.
+     *
+     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+     * @fires Accordion#up
+     * @function
+     */
+
+  }, {
+    key: "up",
+    value: function up($target) {
+      if (this.$element.is('[disabled]')) {
+        console.info('Cannot call up on an accordion that is disabled.');
+        return;
+      } // Don't close the item if it is already closed
+
+
+      var $targetItem = $target.parent();
+      if (!$targetItem.hasClass('is-active')) return; // Don't close the item if there is no other active item (unless with `allowAllClosed`)
+
+      var $othersItems = $targetItem.siblings();
+      if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;
+
+      this._closeTab($target);
+    }
+    /**
+     * Make the tab defined by `$target` the only opened tab, closing all others tabs.
+     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_openSingleTab",
+    value: function _openSingleTab($target) {
+      // Close all the others active tabs.
+      var $activeContents = this.$element.children('.is-active').children('[data-tab-content]');
+
+      if ($activeContents.length) {
+        this._closeTab($activeContents.not($target));
+      } // Then open the target.
+
+
+      this._openTab($target);
+    }
+    /**
+     * Opens the tab defined by `$target`.
+     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+     * @fires Accordion#down
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_openTab",
+    value: function _openTab($target) {
+      var _this3 = this;
+
+      var $targetItem = $target.parent();
+      var targetContentId = $target.attr('aria-labelledby');
+      $target.attr('aria-hidden', false);
+      $targetItem.addClass('is-active');
+      $("#".concat(targetContentId)).attr({
+        'aria-expanded': true,
+        'aria-selected': true
+      });
+      $target.slideDown(this.options.slideSpeed, function () {
+        /**
+         * Fires when the tab is done opening.
+         * @event Accordion#down
+         */
+        _this3.$element.trigger('down.zf.accordion', [$target]);
+      });
+    }
+    /**
+     * Closes the tab defined by `$target`.
+     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+     * @fires Accordion#up
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_closeTab",
+    value: function _closeTab($target) {
+      var _this4 = this;
+
+      var $targetItem = $target.parent();
+      var targetContentId = $target.attr('aria-labelledby');
+      $target.attr('aria-hidden', true);
+      $targetItem.removeClass('is-active');
+      $("#".concat(targetContentId)).attr({
+        'aria-expanded': false,
+        'aria-selected': false
+      });
+      $target.slideUp(this.options.slideSpeed, function () {
+        /**
+         * Fires when the tab is done collapsing up.
+         * @event Accordion#up
+         */
+        _this4.$element.trigger('up.zf.accordion', [$target]);
+      });
+    }
+    /**
+     * Closes all active tabs
+     * @fires Accordion#up
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_closeAllTabs",
+    value: function _closeAllTabs() {
+      var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');
+
+      if ($activeTabs.length) {
+        this._closeTab($activeTabs);
+      }
+    }
+    /**
+     * Destroys an instance of an accordion.
+     * @fires Accordion#destroyed
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');
+      this.$element.find('a').off('.zf.accordion');
+
+      if (this.options.deepLink) {
+        $(window).off('hashchange', this._checkDeepLink);
+      }
+    }
+  }]);
+
+  return Accordion;
+}(Plugin);
+
+Accordion.defaults = {
+  /**
+   * Amount of time to animate the opening of an accordion pane.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  slideSpeed: 250,
+
+  /**
+   * Allow the accordion to have multiple open panes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  multiExpand: false,
+
+  /**
+   * Allow the accordion to close all panes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowAllClosed: false,
+
+  /**
+   * Link the location hash to the open pane.
+   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+
+  /**
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinkSmudge: false,
+
+  /**
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
+   * @option
+   * @type {number}
+   * @default 300
+   */
+  deepLinkSmudgeDelay: 300,
+
+  /**
+   * If `deepLink` is enabled, update the browser history with the open accordion
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  updateHistory: false
+};
+
+/**
+ * AccordionMenu module.
+ * @module foundation.accordionMenu
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.nest
+ */
+
+var AccordionMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(AccordionMenu, _Plugin);
+
+  function AccordionMenu() {
+    _classCallCheck(this, AccordionMenu);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(AccordionMenu).apply(this, arguments));
+  }
+
+  _createClass(AccordionMenu, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of an accordion menu.
+     * @class
+     * @name AccordionMenu
+     * @fires AccordionMenu#init
+     * @param {jQuery} element - jQuery object to make into an accordion menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);
+      this.className = 'AccordionMenu'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('AccordionMenu', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
+        'ARROW_RIGHT': 'open',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'close',
+        'ESCAPE': 'closeAll'
+      });
+    }
+    /**
+     * Initializes the accordion menu by hiding all nested menus.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      Nest.Feather(this.$element, 'accordion');
+
+      var _this = this;
+
+      this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');
+
+      this.$element.attr({
+        'role': 'tree',
+        'aria-multiselectable': this.options.multiOpen
+      });
+      this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');
+      this.$menuLinks.each(function () {
+        var linkId = this.id || GetYoDigits(6, 'acc-menu-link'),
+            $elem = $(this),
+            $sub = $elem.children('[data-submenu]'),
+            subId = $sub[0].id || GetYoDigits(6, 'acc-menu'),
+            isActive = $sub.hasClass('is-active');
+
+        if (_this.options.parentLink) {
+          var $anchor = $elem.children('a');
+          $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-accordion-submenu-item"></li>');
+        }
+
+        if (_this.options.submenuToggle) {
+          $elem.addClass('has-submenu-toggle');
+          $elem.children('a').after('<button id="' + linkId + '" class="submenu-toggle" aria-controls="' + subId + '" aria-expanded="' + isActive + '" title="' + _this.options.submenuToggleText + '"><span class="submenu-toggle-text">' + _this.options.submenuToggleText + '</span></button>');
+        } else {
+          $elem.attr({
+            'aria-controls': subId,
+            'aria-expanded': isActive,
+            'id': linkId
+          });
+        }
+
+        $sub.attr({
+          'aria-labelledby': linkId,
+          'aria-hidden': !isActive,
+          'role': 'group',
+          'id': subId
+        });
+      });
+      this.$element.find('li').attr({
+        'role': 'treeitem'
+      });
+      var initPanes = this.$element.find('.is-active');
+
+      if (initPanes.length) {
+        var _this = this;
+
+        initPanes.each(function () {
+          _this.down($(this));
+        });
+      }
+
+      this._events();
+    }
+    /**
+     * Adds event handlers for items within the menu.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      this.$element.find('li').each(function () {
+        var $submenu = $(this).children('[data-submenu]');
+
+        if ($submenu.length) {
+          if (_this.options.submenuToggle) {
+            $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
+              _this.toggle($submenu);
+            });
+          } else {
+            $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
+              e.preventDefault();
+
+              _this.toggle($submenu);
+            });
+          }
+        }
+      }).on('keydown.zf.accordionmenu', function (e) {
+        var $element = $(this),
+            $elements = $element.parent('ul').children('li'),
+            $prevElement,
+            $nextElement,
+            $target = $element.children('[data-submenu]');
+        $elements.each(function (i) {
+          if ($(this).is($element)) {
+            $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first();
+            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first();
+
+            if ($(this).children('[data-submenu]:visible').length) {
+              // has open sub menu
+              $nextElement = $element.find('li:first-child').find('a').first();
+            }
+
+            if ($(this).is(':first-child')) {
+              // is first element of sub menu
+              $prevElement = $element.parents('li').first().find('a').first();
+            } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) {
+              // if previous element has open sub menu
+              $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();
+            }
+
+            if ($(this).is(':last-child')) {
+              // is last element of sub menu
+              $nextElement = $element.parents('li').first().next('li').find('a').first();
+            }
+
+            return;
+          }
+        });
+        Keyboard.handleKey(e, 'AccordionMenu', {
+          open: function open() {
+            if ($target.is(':hidden')) {
+              _this.down($target);
+
+              $target.find('li').first().find('a').first().focus();
+            }
+          },
+          close: function close() {
+            if ($target.length && !$target.is(':hidden')) {
+              // close active sub of this item
+              _this.up($target);
+            } else if ($element.parent('[data-submenu]').length) {
+              // close currently open sub
+              _this.up($element.parent('[data-submenu]'));
+
+              $element.parents('li').first().find('a').first().focus();
+            }
+          },
+          up: function up() {
+            $prevElement.focus();
+            return true;
+          },
+          down: function down() {
+            $nextElement.focus();
+            return true;
+          },
+          toggle: function toggle() {
+            if (_this.options.submenuToggle) {
+              return false;
+            }
+
+            if ($element.children('[data-submenu]').length) {
+              _this.toggle($element.children('[data-submenu]'));
+
+              return true;
+            }
+          },
+          closeAll: function closeAll() {
+            _this.hideAll();
+          },
+          handled: function handled(preventDefault) {
+            if (preventDefault) {
+              e.preventDefault();
+            }
+
+            e.stopImmediatePropagation();
+          }
+        });
+      }); //.attr('tabindex', 0);
+    }
+    /**
+     * Closes all panes of the menu.
+     * @function
+     */
+
+  }, {
+    key: "hideAll",
+    value: function hideAll() {
+      this.up(this.$element.find('[data-submenu]'));
+    }
+    /**
+     * Opens all panes of the menu.
+     * @function
+     */
+
+  }, {
+    key: "showAll",
+    value: function showAll() {
+      this.down(this.$element.find('[data-submenu]'));
+    }
+    /**
+     * Toggles the open/close state of a submenu.
+     * @function
+     * @param {jQuery} $target - the submenu to toggle
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle($target) {
+      if (!$target.is(':animated')) {
+        if (!$target.is(':hidden')) {
+          this.up($target);
+        } else {
+          this.down($target);
+        }
+      }
+    }
+    /**
+     * Opens the sub-menu defined by `$target`.
+     * @param {jQuery} $target - Sub-menu to open.
+     * @fires AccordionMenu#down
+     */
+
+  }, {
+    key: "down",
+    value: function down($target) {
+      var _this2 = this;
+
+      // If having multiple submenus active is disabled, close all the submenus
+      // that are not parents or children of the targeted submenu.
+      if (!this.options.multiOpen) {
+        // The "branch" of the targetted submenu, from the component root to
+        // the active submenus nested in it.
+        var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); // All the active submenus that are not in the branch.
+
+        var $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);
+        this.up($othersActiveSubmenus);
+      }
+
+      $target.addClass('is-active').attr({
+        'aria-hidden': false
+      });
+
+      if (this.options.submenuToggle) {
+        $target.prev('.submenu-toggle').attr({
+          'aria-expanded': true
+        });
+      } else {
+        $target.parent('.is-accordion-submenu-parent').attr({
+          'aria-expanded': true
+        });
+      }
+
+      $target.slideDown(this.options.slideSpeed, function () {
+        /**
+         * Fires when the menu is done opening.
+         * @event AccordionMenu#down
+         */
+        _this2.$element.trigger('down.zf.accordionMenu', [$target]);
+      });
+    }
+    /**
+     * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.
+     * @param {jQuery} $target - Sub-menu to close.
+     * @fires AccordionMenu#up
+     */
+
+  }, {
+    key: "up",
+    value: function up($target) {
+      var _this3 = this;
+
+      var $submenus = $target.find('[data-submenu]');
+      var $allmenus = $target.add($submenus);
+      $submenus.slideUp(0);
+      $allmenus.removeClass('is-active').attr('aria-hidden', true);
+
+      if (this.options.submenuToggle) {
+        $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);
+      } else {
+        $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);
+      }
+
+      $target.slideUp(this.options.slideSpeed, function () {
+        /**
+         * Fires when the menu is done collapsing up.
+         * @event AccordionMenu#up
+         */
+        _this3.$element.trigger('up.zf.accordionMenu', [$target]);
+      });
+    }
+    /**
+     * Destroys an instance of accordion menu.
+     * @fires AccordionMenu#destroyed
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.find('[data-submenu]').slideDown(0).css('display', '');
+      this.$element.find('a').off('click.zf.accordionMenu');
+      this.$element.find('[data-is-parent-link]').detach();
+
+      if (this.options.submenuToggle) {
+        this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');
+        this.$element.find('.submenu-toggle').remove();
+      }
+
+      Nest.Burn(this.$element, 'accordion');
+    }
+  }]);
+
+  return AccordionMenu;
+}(Plugin);
+
+AccordionMenu.defaults = {
+  /**
+   * Adds the parent link to the submenu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  parentLink: false,
+
+  /**
+   * Amount of time to animate the opening of a submenu in ms.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  slideSpeed: 250,
+
+  /**
+   * Adds a separate submenu toggle button. This allows the parent item to have a link.
+   * @option
+   * @example true
+   */
+  submenuToggle: false,
+
+  /**
+   * The text used for the submenu toggle if enabled. This is used for screen readers only.
+   * @option
+   * @example true
+   */
+  submenuToggleText: 'Toggle menu',
+
+  /**
+   * Allow the menu to have multiple open panes.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  multiOpen: true
+};
+
+/**
+ * Drilldown module.
+ * @module foundation.drilldown
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.nest
+ * @requires foundation.util.box
+ */
+
+var Drilldown =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Drilldown, _Plugin);
+
+  function Drilldown() {
+    _classCallCheck(this, Drilldown);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Drilldown).apply(this, arguments));
+  }
+
+  _createClass(Drilldown, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a drilldown menu.
+     * @class
+     * @name Drilldown
+     * @param {jQuery} element - jQuery object to make into an accordion menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);
+      this.className = 'Drilldown'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('Drilldown', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'previous',
+        'ESCAPE': 'close',
+        'TAB': 'down',
+        'SHIFT_TAB': 'up'
+      });
+    }
+    /**
+     * Initializes the drilldown by creating jQuery collections of elements
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      Nest.Feather(this.$element, 'drilldown');
+
+      if (this.options.autoApplyClass) {
+        this.$element.addClass('drilldown');
+      }
+
+      this.$element.attr({
+        'role': 'tree',
+        'aria-multiselectable': false
+      });
+      this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');
+      this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');
+      this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a'); // Set the main menu as current by default (unless a submenu is selected)
+      // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu
+
+      this.$currentMenu = this.$element;
+      this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown'));
+
+      this._prepareMenu();
+
+      this._registerEvents();
+
+      this._keyboardEvents();
+    }
+    /**
+     * prepares drilldown menu by setting attributes to links and elements
+     * sets a min height to prevent content jumping
+     * wraps the element if not already wrapped
+     * @private
+     * @function
+     */
+
+  }, {
+    key: "_prepareMenu",
+    value: function _prepareMenu() {
+      var _this = this; // if(!this.options.holdOpen){
+      //   this._menuLinkEvents();
+      // }
+
+
+      this.$submenuAnchors.each(function () {
+        var $link = $(this);
+        var $sub = $link.parent();
+
+        if (_this.options.parentLink) {
+          $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>');
+        }
+
+        $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);
+        $link.children('[data-submenu]').attr({
+          'aria-hidden': true,
+          'tabindex': 0,
+          'role': 'group'
+        });
+
+        _this._events($link);
+      });
+      this.$submenus.each(function () {
+        var $menu = $(this),
+            $back = $menu.find('.js-drilldown-back');
+
+        if (!$back.length) {
+          switch (_this.options.backButtonPosition) {
+            case "bottom":
+              $menu.append(_this.options.backButton);
+              break;
+
+            case "top":
+              $menu.prepend(_this.options.backButton);
+              break;
+
+            default:
+              console.error("Unsupported backButtonPosition value '" + _this.options.backButtonPosition + "'");
+          }
+        }
+
+        _this._back($menu);
+      });
+      this.$submenus.addClass('invisible');
+
+      if (!this.options.autoHeight) {
+        this.$submenus.addClass('drilldown-submenu-cover-previous');
+      } // create a wrapper on element if it doesn't exist.
+
+
+      if (!this.$element.parent().hasClass('is-drilldown')) {
+        this.$wrapper = $(this.options.wrapper).addClass('is-drilldown');
+        if (this.options.animateHeight) this.$wrapper.addClass('animate-height');
+        this.$element.wrap(this.$wrapper);
+      } // set wrapper
+
+
+      this.$wrapper = this.$element.parent();
+      this.$wrapper.css(this._getMaxDims());
+    }
+  }, {
+    key: "_resize",
+    value: function _resize() {
+      this.$wrapper.css({
+        'max-width': 'none',
+        'min-height': 'none'
+      }); // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths
+
+      this.$wrapper.css(this._getMaxDims());
+    }
+    /**
+     * Adds event handlers to elements in the menu.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the current menu item to add handlers to.
+     */
+
+  }, {
+    key: "_events",
+    value: function _events($elem) {
+      var _this = this;
+
+      $elem.off('click.zf.drilldown').on('click.zf.drilldown', function (e) {
+        if ($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) {
+          e.stopImmediatePropagation();
+          e.preventDefault();
+        } // if(e.target !== e.currentTarget.firstElementChild){
+        //   return false;
+        // }
+
+
+        _this._show($elem.parent('li'));
+
+        if (_this.options.closeOnClick) {
+          var $body = $('body');
+          $body.off('.zf.drilldown').on('click.zf.drilldown', function (e) {
+            if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target)) {
+              return;
+            }
+
+            e.preventDefault();
+
+            _this._hideAll();
+
+            $body.off('.zf.drilldown');
+          });
+        }
+      });
+    }
+    /**
+     * Adds event handlers to the menu element.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_registerEvents",
+    value: function _registerEvents() {
+      if (this.options.scrollTop) {
+        this._bindHandler = this._scrollTop.bind(this);
+        this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown', this._bindHandler);
+      }
+
+      this.$element.on('mutateme.zf.trigger', this._resize.bind(this));
+    }
+    /**
+     * Scroll to Top of Element or data-scroll-top-element
+     * @function
+     * @fires Drilldown#scrollme
+     */
+
+  }, {
+    key: "_scrollTop",
+    value: function _scrollTop() {
+      var _this = this;
+
+      var $scrollTopElement = _this.options.scrollTopElement != '' ? $(_this.options.scrollTopElement) : _this.$element,
+          scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10);
+      $('html, body').stop(true).animate({
+        scrollTop: scrollPos
+      }, _this.options.animationDuration, _this.options.animationEasing, function () {
+        /**
+          * Fires after the menu has scrolled
+          * @event Drilldown#scrollme
+          */
+        if (this === $('html')[0]) _this.$element.trigger('scrollme.zf.drilldown');
+      });
+    }
+    /**
+     * Adds keydown event listener to `li`'s in the menu.
+     * @private
+     */
+
+  }, {
+    key: "_keyboardEvents",
+    value: function _keyboardEvents() {
+      var _this = this;
+
+      this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function (e) {
+        var $element = $(this),
+            $elements = $element.parent('li').parent('ul').children('li').children('a'),
+            $prevElement,
+            $nextElement;
+        $elements.each(function (i) {
+          if ($(this).is($element)) {
+            $prevElement = $elements.eq(Math.max(0, i - 1));
+            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
+            return;
+          }
+        });
+        Keyboard.handleKey(e, 'Drilldown', {
+          next: function next() {
+            if ($element.is(_this.$submenuAnchors)) {
+              _this._show($element.parent('li'));
+
+              $element.parent('li').one(transitionend($element), function () {
+                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
+              });
+              return true;
+            }
+          },
+          previous: function previous() {
+            _this._hide($element.parent('li').parent('ul'));
+
+            $element.parent('li').parent('ul').one(transitionend($element), function () {
+              setTimeout(function () {
+                $element.parent('li').parent('ul').parent('li').children('a').first().focus();
+              }, 1);
+            });
+            return true;
+          },
+          up: function up() {
+            $prevElement.focus(); // Don't tap focus on first element in root ul
+
+            return !$element.is(_this.$element.find('> li:first-child > a'));
+          },
+          down: function down() {
+            $nextElement.focus(); // Don't tap focus on last element in root ul
+
+            return !$element.is(_this.$element.find('> li:last-child > a'));
+          },
+          close: function close() {
+            // Don't close on element in root ul
+            if (!$element.is(_this.$element.find('> li > a'))) {
+              _this._hide($element.parent().parent());
+
+              $element.parent().parent().siblings('a').focus();
+            }
+          },
+          open: function open() {
+            if (_this.options.parentLink && $element.attr('href')) {
+              // Link with href
+              return false;
+            } else if (!$element.is(_this.$menuItems)) {
+              // not menu item means back button
+              _this._hide($element.parent('li').parent('ul'));
+
+              $element.parent('li').parent('ul').one(transitionend($element), function () {
+                setTimeout(function () {
+                  $element.parent('li').parent('ul').parent('li').children('a').first().focus();
+                }, 1);
+              });
+              return true;
+            } else if ($element.is(_this.$submenuAnchors)) {
+              // Sub menu item
+              _this._show($element.parent('li'));
+
+              $element.parent('li').one(transitionend($element), function () {
+                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
+              });
+              return true;
+            }
+          },
+          handled: function handled(preventDefault) {
+            if (preventDefault) {
+              e.preventDefault();
+            }
+
+            e.stopImmediatePropagation();
+          }
+        });
+      }); // end keyboardAccess
+    }
+    /**
+     * Closes all open elements, and returns to root menu.
+     * @function
+     * @fires Drilldown#closed
+     */
+
+  }, {
+    key: "_hideAll",
+    value: function _hideAll() {
+      var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');
+      if (this.options.autoHeight) this.$wrapper.css({
+        height: $elem.parent().closest('ul').data('calcHeight')
+      });
+      $elem.one(transitionend($elem), function (e) {
+        $elem.removeClass('is-active is-closing');
+      });
+      /**
+       * Fires when the menu is fully closed.
+       * @event Drilldown#closed
+       */
+
+      this.$element.trigger('closed.zf.drilldown');
+    }
+    /**
+     * Adds event listener for each `back` button, and closes open menus.
+     * @function
+     * @fires Drilldown#back
+     * @param {jQuery} $elem - the current sub-menu to add `back` event.
+     */
+
+  }, {
+    key: "_back",
+    value: function _back($elem) {
+      var _this = this;
+
+      $elem.off('click.zf.drilldown');
+      $elem.children('.js-drilldown-back').on('click.zf.drilldown', function (e) {
+        e.stopImmediatePropagation(); // console.log('mouseup on back');
+
+        _this._hide($elem); // If there is a parent submenu, call show
+
+
+        var parentSubMenu = $elem.parent('li').parent('ul').parent('li');
+
+        if (parentSubMenu.length) {
+          _this._show(parentSubMenu);
+        }
+      });
+    }
+    /**
+     * Adds event listener to menu items w/o submenus to close open menus on click.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_menuLinkEvents",
+    value: function _menuLinkEvents() {
+      var _this = this;
+
+      this.$menuItems.not('.is-drilldown-submenu-parent').off('click.zf.drilldown').on('click.zf.drilldown', function (e) {
+        // e.stopImmediatePropagation();
+        setTimeout(function () {
+          _this._hideAll();
+        }, 0);
+      });
+    }
+    /**
+     * Sets the CSS classes for submenu to show it.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the target submenu (`ul` tag)
+     * @param {boolean} trigger - trigger drilldown event
+     */
+
+  }, {
+    key: "_setShowSubMenuClasses",
+    value: function _setShowSubMenuClasses($elem, trigger) {
+      $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+      $elem.parent('li').attr('aria-expanded', true);
+
+      if (trigger === true) {
+        this.$element.trigger('open.zf.drilldown', [$elem]);
+      }
+    }
+    /**
+     * Sets the CSS classes for submenu to hide it.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the target submenu (`ul` tag)
+     * @param {boolean} trigger - trigger drilldown event
+     */
+
+  }, {
+    key: "_setHideSubMenuClasses",
+    value: function _setHideSubMenuClasses($elem, trigger) {
+      $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);
+      $elem.parent('li').attr('aria-expanded', false);
+
+      if (trigger === true) {
+        $elem.trigger('hide.zf.drilldown', [$elem]);
+      }
+    }
+    /**
+     * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.
+     * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.
+     * @function
+     * @fires Drilldown#open
+     * @param {jQuery} $elem - the target (sub)menu (`ul` tag)
+     * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused
+     */
+
+  }, {
+    key: "_showMenu",
+    value: function _showMenu($elem, autoFocus) {
+      var _this = this; // Reset drilldown
+
+
+      var $expandedSubmenus = this.$element.find('li[aria-expanded="true"] > ul[data-submenu]');
+      $expandedSubmenus.each(function (index) {
+        _this._setHideSubMenuClasses($(this));
+      }); // Save the menu as the currently displayed one.
+
+      this.$currentMenu = $elem; // If target menu is root, focus first link & exit
+
+      if ($elem.is('[data-drilldown]')) {
+        if (autoFocus === true) $elem.find('li[role="treeitem"] > a').first().focus();
+        if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));
+        return;
+      } // Find all submenus on way to root incl. the element itself
+
+
+      var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); // Open target menu and all submenus on its way to root
+
+      $submenus.each(function (index) {
+        // Update height of first child (target menu) if autoHeight option true
+        if (index === 0 && _this.options.autoHeight) {
+          _this.$wrapper.css('height', $(this).data('calcHeight'));
+        }
+
+        var isLastChild = index == $submenus.length - 1; // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link
+        // Last child makes sure the event gets always triggered even if going through several menus
+
+        if (isLastChild === true) {
+          $(this).one(transitionend($(this)), function () {
+            if (autoFocus === true) {
+              $elem.find('li[role="treeitem"] > a').first().focus();
+            }
+          });
+        }
+
+        _this._setShowSubMenuClasses($(this), isLastChild);
+      });
+    }
+    /**
+     * Opens a submenu.
+     * @function
+     * @fires Drilldown#open
+     * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.
+     */
+
+  }, {
+    key: "_show",
+    value: function _show($elem) {
+      var $submenu = $elem.children('[data-submenu]');
+      $elem.attr('aria-expanded', true);
+      this.$currentMenu = $submenu;
+      $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+
+      if (this.options.autoHeight) {
+        this.$wrapper.css({
+          height: $submenu.data('calcHeight')
+        });
+      }
+      /**
+       * Fires when the submenu has opened.
+       * @event Drilldown#open
+       */
+
+
+      this.$element.trigger('open.zf.drilldown', [$elem]);
+    }
+    /**
+     * Hides a submenu
+     * @function
+     * @fires Drilldown#hide
+     * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.
+     */
+
+  }, {
+    key: "_hide",
+    value: function _hide($elem) {
+      if (this.options.autoHeight) this.$wrapper.css({
+        height: $elem.parent().closest('ul').data('calcHeight')
+      });
+
+      $elem.parent('li').attr('aria-expanded', false);
+      $elem.attr('aria-hidden', true);
+      $elem.addClass('is-closing').one(transitionend($elem), function () {
+        $elem.removeClass('is-active is-closing');
+        $elem.blur().addClass('invisible');
+      });
+      /**
+       * Fires when the submenu has closed.
+       * @event Drilldown#hide
+       */
+
+      $elem.trigger('hide.zf.drilldown', [$elem]);
+    }
+    /**
+     * Iterates through the nested menus to calculate the min-height, and max-width for the menu.
+     * Prevents content jumping.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_getMaxDims",
+    value: function _getMaxDims() {
+      var maxHeight = 0,
+          result = {},
+          _this = this; // Recalculate menu heights and total max height
+
+
+      this.$submenus.add(this.$element).each(function () {
+        var numOfElems = $(this).children('li').length;
+        var height = Box.GetDimensions(this).height;
+        maxHeight = height > maxHeight ? height : maxHeight;
+
+        if (_this.options.autoHeight) {
+          $(this).data('calcHeight', height);
+        }
+      });
+      if (this.options.autoHeight) result['height'] = this.$currentMenu.data('calcHeight');else result['min-height'] = "".concat(maxHeight, "px");
+      result['max-width'] = "".concat(this.$element[0].getBoundingClientRect().width, "px");
+      return result;
+    }
+    /**
+     * Destroys the Drilldown Menu
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      if (this.options.scrollTop) this.$element.off('.zf.drilldown', this._bindHandler);
+
+      this._hideAll();
+
+      this.$element.off('mutateme.zf.trigger');
+      Nest.Burn(this.$element, 'drilldown');
+      this.$element.unwrap().find('.js-drilldown-back, .is-submenu-parent-item').remove().end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu').end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');
+      this.$submenuAnchors.each(function () {
+        $(this).off('.zf.drilldown');
+      });
+      this.$element.find('[data-is-parent-link]').detach();
+      this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');
+      this.$element.find('a').each(function () {
+        var $link = $(this);
+        $link.removeAttr('tabindex');
+
+        if ($link.data('savedHref')) {
+          $link.attr('href', $link.data('savedHref')).removeData('savedHref');
+        } else {
+          return;
+        }
+      });
+    }
+  }]);
+
+  return Drilldown;
+}(Plugin);
+
+Drilldown.defaults = {
+  /**
+   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are
+   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.
+   * @option
+   * @type {boolian}
+   * @default true
+   */
+  autoApplyClass: true,
+
+  /**
+   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\`) if copy and pasting.
+   * @option
+   * @type {string}
+   * @default '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>'
+   */
+  backButton: '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',
+
+  /**
+   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.
+   * @option
+   * @type {string}
+   * @default top
+   */
+  backButtonPosition: 'top',
+
+  /**
+   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\`) if copy and pasting.
+   * @option
+   * @type {string}
+   * @default '<div></div>'
+   */
+  wrapper: '<div></div>',
+
+  /**
+   * Adds the parent link to the submenu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  parentLink: false,
+
+  /**
+   * Allow the menu to return to root list on body click.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  closeOnClick: false,
+
+  /**
+   * Allow the menu to auto adjust height.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoHeight: false,
+
+  /**
+   * Animate the auto adjust height.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animateHeight: false,
+
+  /**
+   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  scrollTop: false,
+
+  /**
+   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  scrollTopElement: '',
+
+  /**
+   * ScrollTop offset
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  scrollTopOffset: 0,
+
+  /**
+   * Scroll animation duration
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+
+  /**
+   * Scroll animation easing. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @see {@link https://api.jquery.com/animate|JQuery animate}
+   * @default 'swing'
+   */
+  animationEasing: 'swing' // holdOpen: false
+
+};
+
+var POSITIONS = ['left', 'right', 'top', 'bottom'];
+var VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];
+var HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];
+var ALIGNMENTS = {
+  'left': VERTICAL_ALIGNMENTS,
+  'right': VERTICAL_ALIGNMENTS,
+  'top': HORIZONTAL_ALIGNMENTS,
+  'bottom': HORIZONTAL_ALIGNMENTS
+};
+
+function nextItem(item, array) {
+  var currentIdx = array.indexOf(item);
+
+  if (currentIdx === array.length - 1) {
+    return array[0];
+  } else {
+    return array[currentIdx + 1];
+  }
+}
+
+var Positionable =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Positionable, _Plugin);
+
+  function Positionable() {
+    _classCallCheck(this, Positionable);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments));
+  }
+
+  _createClass(Positionable, [{
+    key: "_init",
+
+    /**
+     * Abstract class encapsulating the tether-like explicit positioning logic
+     * including repositioning based on overlap.
+     * Expects classes to define defaults for vOffset, hOffset, position,
+     * alignment, allowOverlap, and allowBottomOverlap. They can do this by
+     * extending the defaults, or (for now recommended due to the way docs are
+     * generated) by explicitly declaring them.
+     *
+     **/
+    value: function _init() {
+      this.triedPositions = {};
+      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;
+      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;
+      this.originalPosition = this.position;
+      this.originalAlignment = this.alignment;
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      return 'bottom';
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      switch (this.position) {
+        case 'bottom':
+        case 'top':
+          return rtl() ? 'right' : 'left';
+
+        case 'left':
+        case 'right':
+          return 'bottom';
+      }
+    }
+    /**
+     * Adjusts the positionable possible positions by iterating through alignments
+     * and positions.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_reposition",
+    value: function _reposition() {
+      if (this._alignmentsExhausted(this.position)) {
+        this.position = nextItem(this.position, POSITIONS);
+        this.alignment = ALIGNMENTS[this.position][0];
+      } else {
+        this._realign();
+      }
+    }
+    /**
+     * Adjusts the dropdown pane possible positions by iterating through alignments
+     * on the current position.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_realign",
+    value: function _realign() {
+      this._addTriedPosition(this.position, this.alignment);
+
+      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);
+    }
+  }, {
+    key: "_addTriedPosition",
+    value: function _addTriedPosition(position, alignment) {
+      this.triedPositions[position] = this.triedPositions[position] || [];
+      this.triedPositions[position].push(alignment);
+    }
+  }, {
+    key: "_positionsExhausted",
+    value: function _positionsExhausted() {
+      var isExhausted = true;
+
+      for (var i = 0; i < POSITIONS.length; i++) {
+        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);
+      }
+
+      return isExhausted;
+    }
+  }, {
+    key: "_alignmentsExhausted",
+    value: function _alignmentsExhausted(position) {
+      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;
+    } // When we're trying to center, we don't want to apply offset that's going to
+    // take us just off center, so wrap around to return 0 for the appropriate
+    // offset in those alignments.  TODO: Figure out if we want to make this
+    // configurable behavior... it feels more intuitive, especially for tooltips, but
+    // it's possible someone might actually want to start from center and then nudge
+    // slightly off.
+
+  }, {
+    key: "_getVOffset",
+    value: function _getVOffset() {
+      return this.options.vOffset;
+    }
+  }, {
+    key: "_getHOffset",
+    value: function _getHOffset() {
+      return this.options.hOffset;
+    }
+  }, {
+    key: "_setPosition",
+    value: function _setPosition($anchor, $element, $parent) {
+      if ($anchor.attr('aria-expanded') === 'false') {
+        return false;
+      }
+
+      var $eleDims = Box.GetDimensions($element),
+          $anchorDims = Box.GetDimensions($anchor);
+
+      if (!this.options.allowOverlap) {
+        // restore original position & alignment before checking overlap
+        this.position = this.originalPosition;
+        this.alignment = this.originalAlignment;
+      }
+
+      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+
+      if (!this.options.allowOverlap) {
+        var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better
+
+        var minCoordinates = {
+          position: this.position,
+          alignment: this.alignment
+        };
+
+        while (!this._positionsExhausted()) {
+          var overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
+
+          if (overlap === 0) {
+            return;
+          }
+
+          if (overlap < minOverlap) {
+            minOverlap = overlap;
+            minCoordinates = {
+              position: this.position,
+              alignment: this.alignment
+            };
+          }
+
+          this._reposition();
+
+          $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+        } // If we get through the entire loop, there was no non-overlapping
+        // position available. Pick the version with least overlap.
+
+
+        this.position = minCoordinates.position;
+        this.alignment = minCoordinates.alignment;
+        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+      }
+    }
+  }]);
+
+  return Positionable;
+}(Plugin);
+
+Positionable.defaults = {
+  /**
+   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+
+  /**
+   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow overlap of container/window. If false, dropdown positionable first
+   * try to position as defined by data-position and data-alignment, but
+   * reposition if it would cause an overflow.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  allowBottomOverlap: true,
+
+  /**
+   * Number of pixels the positionable should be separated vertically from anchor
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+
+  /**
+   * Number of pixels the positionable should be separated horizontally from anchor
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0
+};
+
+/**
+ * Dropdown module.
+ * @module foundation.dropdown
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.box
+ * @requires foundation.util.triggers
+ */
+
+var Dropdown =
+/*#__PURE__*/
+function (_Positionable) {
+  _inherits(Dropdown, _Positionable);
+
+  function Dropdown() {
+    _classCallCheck(this, Dropdown);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Dropdown).apply(this, arguments));
+  }
+
+  _createClass(Dropdown, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a dropdown.
+     * @class
+     * @name Dropdown
+     * @param {jQuery} element - jQuery object to make into a dropdown.
+     *        Object should be of the dropdown panel, rather than its anchor.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);
+      this.className = 'Dropdown'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      this._init();
+
+      Keyboard.register('Dropdown', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
+        'ESCAPE': 'close'
+      });
+    }
+    /**
+     * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var $id = this.$element.attr('id');
+      this.$anchors = $("[data-toggle=\"".concat($id, "\"]")).length ? $("[data-toggle=\"".concat($id, "\"]")) : $("[data-open=\"".concat($id, "\"]"));
+      this.$anchors.attr({
+        'aria-controls': $id,
+        'data-is-focus': false,
+        'data-yeti-box': $id,
+        'aria-haspopup': true,
+        'aria-expanded': false
+      });
+
+      this._setCurrentAnchor(this.$anchors.first());
+
+      if (this.options.parentClass) {
+        this.$parent = this.$element.parents('.' + this.options.parentClass);
+      } else {
+        this.$parent = null;
+      } // Set [aria-labelledby] on the Dropdown if it is not set
+
+
+      if (typeof this.$element.attr('aria-labelledby') === 'undefined') {
+        // Get the anchor ID or create one
+        if (typeof this.$currentAnchor.attr('id') === 'undefined') {
+          this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));
+        }
+        this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));
+      }
+
+      this.$element.attr({
+        'aria-hidden': 'true',
+        'data-yeti-box': $id,
+        'data-resize': $id
+      });
+
+      _get(_getPrototypeOf(Dropdown.prototype), "_init", this).call(this);
+
+      this._events();
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      // handle legacy classnames
+      var position = this.$element[0].className.match(/(top|left|right|bottom)/g);
+
+      if (position) {
+        return position[0];
+      } else {
+        return 'bottom';
+      }
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      // handle legacy float approach
+      var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.attr('class'));
+
+      if (horizontalPosition) {
+        return horizontalPosition[1];
+      }
+
+      return _get(_getPrototypeOf(Dropdown.prototype), "_getDefaultAlignment", this).call(this);
+    }
+    /**
+     * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.
+     * Recursively calls itself if a collision is detected, with a new position class.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_setPosition",
+    value: function _setPosition() {
+      this.$element.removeClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment));
+
+      _get(_getPrototypeOf(Dropdown.prototype), "_setPosition", this).call(this, this.$currentAnchor, this.$element, this.$parent);
+
+      this.$element.addClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment));
+    }
+    /**
+     * Make it a current anchor.
+     * Current anchor as the reference for the position of Dropdown panes.
+     * @param {HTML} el - DOM element of the anchor.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_setCurrentAnchor",
+    value: function _setCurrentAnchor(el) {
+      this.$currentAnchor = $(el);
+    }
+    /**
+     * Adds event listeners to the element utilizing the triggers utility library.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      this.$element.on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': this.close.bind(this),
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'resizeme.zf.trigger': this._setPosition.bind(this)
+      });
+      this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function () {
+        _this._setCurrentAnchor(this);
+      });
+
+      if (this.options.hover) {
+        this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
+          _this._setCurrentAnchor(this);
+
+          var bodyData = $('body').data();
+
+          if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') {
+            clearTimeout(_this.timeout);
+            _this.timeout = setTimeout(function () {
+              _this.open();
+
+              _this.$anchors.data('hover', true);
+            }, _this.options.hoverDelay);
+          }
+        }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function () {
+          clearTimeout(_this.timeout);
+          _this.timeout = setTimeout(function () {
+            _this.close();
+
+            _this.$anchors.data('hover', false);
+          }, _this.options.hoverDelay);
+        }));
+
+        if (this.options.hoverPane) {
+          this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
+            clearTimeout(_this.timeout);
+          }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function () {
+            clearTimeout(_this.timeout);
+            _this.timeout = setTimeout(function () {
+              _this.close();
+
+              _this.$anchors.data('hover', false);
+            }, _this.options.hoverDelay);
+          }));
+        }
+      }
+
+      this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) {
+        var $target = $(this),
+            visibleFocusableElements = Keyboard.findFocusable(_this.$element);
+        Keyboard.handleKey(e, 'Dropdown', {
+          open: function open() {
+            if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {
+              _this.open();
+
+              _this.$element.attr('tabindex', -1).focus();
+
+              e.preventDefault();
+            }
+          },
+          close: function close() {
+            _this.close();
+
+            _this.$anchors.focus();
+          }
+        });
+      });
+    }
+    /**
+     * Adds an event handler to the body to close any dropdowns on a click.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_addBodyHandler",
+    value: function _addBodyHandler() {
+      var $body = $(document.body).not(this.$element),
+          _this = this;
+
+      $body.off('click.zf.dropdown').on('click.zf.dropdown', function (e) {
+        if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {
+          return;
+        }
+
+        if (_this.$element.is(e.target) || _this.$element.find(e.target).length) {
+          return;
+        }
+
+        _this.close();
+
+        $body.off('click.zf.dropdown');
+      });
+    }
+    /**
+     * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.
+     * @function
+     * @fires Dropdown#closeme
+     * @fires Dropdown#show
+     */
+
+  }, {
+    key: "open",
+    value: function open() {
+      // var _this = this;
+
+      /**
+       * Fires to close other open dropdowns, typically when dropdown is opening
+       * @event Dropdown#closeme
+       */
+      this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));
+      this.$anchors.addClass('hover').attr({
+        'aria-expanded': true
+      }); // this.$element/*.show()*/;
+
+      this.$element.addClass('is-opening');
+
+      this._setPosition();
+
+      this.$element.removeClass('is-opening').addClass('is-open').attr({
+        'aria-hidden': false
+      });
+
+      if (this.options.autoFocus) {
+        var $focusable = Keyboard.findFocusable(this.$element);
+
+        if ($focusable.length) {
+          $focusable.eq(0).focus();
+        }
+      }
+
+      if (this.options.closeOnClick) {
+        this._addBodyHandler();
+      }
+
+      if (this.options.trapFocus) {
+        Keyboard.trapFocus(this.$element);
+      }
+      /**
+       * Fires once the dropdown is visible.
+       * @event Dropdown#show
+       */
+
+
+      this.$element.trigger('show.zf.dropdown', [this.$element]);
+    }
+    /**
+     * Closes the open dropdown pane.
+     * @function
+     * @fires Dropdown#hide
+     */
+
+  }, {
+    key: "close",
+    value: function close() {
+      if (!this.$element.hasClass('is-open')) {
+        return false;
+      }
+
+      this.$element.removeClass('is-open').attr({
+        'aria-hidden': true
+      });
+      this.$anchors.removeClass('hover').attr('aria-expanded', false);
+      /**
+       * Fires once the dropdown is no longer visible.
+       * @event Dropdown#hide
+       */
+
+      this.$element.trigger('hide.zf.dropdown', [this.$element]);
+
+      if (this.options.trapFocus) {
+        Keyboard.releaseFocus(this.$element);
+      }
+    }
+    /**
+     * Toggles the dropdown pane's visibility.
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      if (this.$element.hasClass('is-open')) {
+        if (this.$anchors.data('hover')) return;
+        this.close();
+      } else {
+        this.open();
+      }
+    }
+    /**
+     * Destroys the dropdown.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.trigger').hide();
+      this.$anchors.off('.zf.dropdown');
+      $(document.body).off('click.zf.dropdown');
+    }
+  }]);
+
+  return Dropdown;
+}(Positionable);
+
+Dropdown.defaults = {
+  /**
+   * Class that designates bounding container of Dropdown (default: window)
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  parentClass: null,
+
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  hoverDelay: 250,
+
+  /**
+   * Allow submenus to open on hover events
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  hover: false,
+
+  /**
+   * Don't close dropdown when hovering over dropdown pane
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  hoverPane: false,
+
+  /**
+   * Number of pixels between the dropdown pane and the triggering element on open.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+
+  /**
+   * Number of pixels between the dropdown pane and the triggering element on open.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0,
+
+  /**
+   * Position of dropdown. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+
+  /**
+   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  allowBottomOverlap: true,
+
+  /**
+   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  trapFocus: false,
+
+  /**
+   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoFocus: false,
+
+  /**
+   * Allows a click on the body to close the dropdown.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  closeOnClick: false
+};
+
+/**
+ * DropdownMenu module.
+ * @module foundation.dropdown-menu
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.box
+ * @requires foundation.util.nest
+ */
+
+var DropdownMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(DropdownMenu, _Plugin);
+
+  function DropdownMenu() {
+    _classCallCheck(this, DropdownMenu);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(DropdownMenu).apply(this, arguments));
+  }
+
+  _createClass(DropdownMenu, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of DropdownMenu.
+     * @class
+     * @name DropdownMenu
+     * @fires DropdownMenu#init
+     * @param {jQuery} element - jQuery object to make into a dropdown menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);
+      this.className = 'DropdownMenu'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('DropdownMenu', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'previous',
+        'ESCAPE': 'close'
+      });
+    }
+    /**
+     * Initializes the plugin, and calls _prepareMenu
+     * @private
+     * @function
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      Nest.Feather(this.$element, 'dropdown');
+      var subs = this.$element.find('li.is-dropdown-submenu-parent');
+      this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');
+      this.$menuItems = this.$element.find('[role="menuitem"]');
+      this.$tabs = this.$element.children('[role="menuitem"]');
+      this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);
+
+      if (this.options.alignment === 'auto') {
+        if (this.$element.hasClass(this.options.rightClass) || rtl() || this.$element.parents('.top-bar-right').is('*')) {
+          this.options.alignment = 'right';
+          subs.addClass('opens-left');
+        } else {
+          this.options.alignment = 'left';
+          subs.addClass('opens-right');
+        }
+      } else {
+        if (this.options.alignment === 'right') {
+          subs.addClass('opens-left');
+        } else {
+          subs.addClass('opens-right');
+        }
+      }
+
+      this.changed = false;
+
+      this._events();
+    }
+  }, {
+    key: "_isVertical",
+    value: function _isVertical() {
+      return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';
+    }
+  }, {
+    key: "_isRtl",
+    value: function _isRtl() {
+      return this.$element.hasClass('align-right') || rtl() && !this.$element.hasClass('align-left');
+    }
+    /**
+     * Adds event listeners to elements within the menu
+     * @private
+     * @function
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this,
+          hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined',
+          parClass = 'is-dropdown-submenu-parent'; // used for onClick and in the keyboard handlers
+
+
+      var handleClickFn = function handleClickFn(e) {
+        var $elem = $(e.target).parentsUntil('ul', ".".concat(parClass)),
+            hasSub = $elem.hasClass(parClass),
+            hasClicked = $elem.attr('data-is-click') === 'true',
+            $sub = $elem.children('.is-dropdown-submenu');
+
+        if (hasSub) {
+          if (hasClicked) {
+            if (!_this.options.closeOnClick || !_this.options.clickOpen && !hasTouch || _this.options.forceFollow && hasTouch) {
+              return;
+            } else {
+              e.stopImmediatePropagation();
+              e.preventDefault();
+
+              _this._hide($elem);
+            }
+          } else {
+            e.preventDefault();
+            e.stopImmediatePropagation();
+
+            _this._show($sub);
+
+            $elem.add($elem.parentsUntil(_this.$element, ".".concat(parClass))).attr('data-is-click', true);
+          }
+        }
+      };
+
+      if (this.options.clickOpen || hasTouch) {
+        this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);
+      } // Handle Leaf element Clicks
+
+
+      if (_this.options.closeOnClickInside) {
+        this.$menuItems.on('click.zf.dropdownmenu', function (e) {
+          var $elem = $(this),
+              hasSub = $elem.hasClass(parClass);
+
+          if (!hasSub) {
+            _this._hide();
+          }
+        });
+      }
+
+      if (!this.options.disableHover) {
+        this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {
+          var $elem = $(this),
+              hasSub = $elem.hasClass(parClass);
+
+          if (hasSub) {
+            clearTimeout($elem.data('_delay'));
+            $elem.data('_delay', setTimeout(function () {
+              _this._show($elem.children('.is-dropdown-submenu'));
+            }, _this.options.hoverDelay));
+          }
+        }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) {
+          var $elem = $(this),
+              hasSub = $elem.hasClass(parClass);
+
+          if (hasSub && _this.options.autoclose) {
+            if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) {
+              return false;
+            }
+
+            clearTimeout($elem.data('_delay'));
+            $elem.data('_delay', setTimeout(function () {
+              _this._hide($elem);
+            }, _this.options.closingTime));
+          }
+        }));
+      }
+
+      this.$menuItems.on('keydown.zf.dropdownmenu', function (e) {
+        var $element = $(e.target).parentsUntil('ul', '[role="menuitem"]'),
+            isTab = _this.$tabs.index($element) > -1,
+            $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),
+            $prevElement,
+            $nextElement;
+        $elements.each(function (i) {
+          if ($(this).is($element)) {
+            $prevElement = $elements.eq(i - 1);
+            $nextElement = $elements.eq(i + 1);
+            return;
+          }
+        });
+
+        var nextSibling = function nextSibling() {
+          $nextElement.children('a:first').focus();
+          e.preventDefault();
+        },
+            prevSibling = function prevSibling() {
+          $prevElement.children('a:first').focus();
+          e.preventDefault();
+        },
+            openSub = function openSub() {
+          var $sub = $element.children('ul.is-dropdown-submenu');
+
+          if ($sub.length) {
+            _this._show($sub);
+
+            $element.find('li > a:first').focus();
+            e.preventDefault();
+          } else {
+            return;
+          }
+        },
+            closeSub = function closeSub() {
+          //if ($element.is(':first-child')) {
+          var close = $element.parent('ul').parent('li');
+          close.children('a:first').focus();
+
+          _this._hide(close);
+
+          e.preventDefault(); //}
+        };
+
+        var functions = {
+          open: openSub,
+          close: function close() {
+            _this._hide(_this.$element);
+
+            _this.$menuItems.eq(0).children('a').focus(); // focus to first element
+
+
+            e.preventDefault();
+          },
+          handled: function handled() {
+            e.stopImmediatePropagation();
+          }
+        };
+
+        if (isTab) {
+          if (_this._isVertical()) {
+            // vertical menu
+            if (_this._isRtl()) {
+              // right aligned
+              $.extend(functions, {
+                down: nextSibling,
+                up: prevSibling,
+                next: closeSub,
+                previous: openSub
+              });
+            } else {
+              // left aligned
+              $.extend(functions, {
+                down: nextSibling,
+                up: prevSibling,
+                next: openSub,
+                previous: closeSub
+              });
+            }
+          } else {
+            // horizontal menu
+            if (_this._isRtl()) {
+              // right aligned
+              $.extend(functions, {
+                next: prevSibling,
+                previous: nextSibling,
+                down: openSub,
+                up: closeSub
+              });
+            } else {
+              // left aligned
+              $.extend(functions, {
+                next: nextSibling,
+                previous: prevSibling,
+                down: openSub,
+                up: closeSub
+              });
+            }
+          }
+        } else {
+          // not tabs -> one sub
+          if (_this._isRtl()) {
+            // right aligned
+            $.extend(functions, {
+              next: closeSub,
+              previous: openSub,
+              down: nextSibling,
+              up: prevSibling
+            });
+          } else {
+            // left aligned
+            $.extend(functions, {
+              next: openSub,
+              previous: closeSub,
+              down: nextSibling,
+              up: prevSibling
+            });
+          }
+        }
+
+        Keyboard.handleKey(e, 'DropdownMenu', functions);
+      });
+    }
+    /**
+     * Adds an event handler to the body to close any dropdowns on a click.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_addBodyHandler",
+    value: function _addBodyHandler() {
+      var $body = $(document.body),
+          _this = this;
+
+      $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu').on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function (e) {
+        var $link = _this.$element.find(e.target);
+
+        if ($link.length) {
+          return;
+        }
+
+        _this._hide();
+
+        $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');
+      });
+    }
+    /**
+     * Opens a dropdown pane, and checks for collisions first.
+     * @param {jQuery} $sub - ul element that is a submenu to show
+     * @function
+     * @private
+     * @fires Dropdownmenu#show
+     */
+
+  }, {
+    key: "_show",
+    value: function _show($sub) {
+      var idx = this.$tabs.index(this.$tabs.filter(function (i, el) {
+        return $(el).find($sub).length > 0;
+      }));
+      var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');
+
+      this._hide($sibs, idx);
+
+      $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active');
+      var clear = Box.ImNotTouchingYou($sub, null, true);
+
+      if (!clear) {
+        var oldClass = this.options.alignment === 'left' ? '-right' : '-left',
+            $parentLi = $sub.parent('.is-dropdown-submenu-parent');
+        $parentLi.removeClass("opens".concat(oldClass)).addClass("opens-".concat(this.options.alignment));
+        clear = Box.ImNotTouchingYou($sub, null, true);
+
+        if (!clear) {
+          $parentLi.removeClass("opens-".concat(this.options.alignment)).addClass('opens-inner');
+        }
+
+        this.changed = true;
+      }
+
+      $sub.css('visibility', '');
+
+      if (this.options.closeOnClick) {
+        this._addBodyHandler();
+      }
+      /**
+       * Fires when the new dropdown pane is visible.
+       * @event Dropdownmenu#show
+       */
+
+
+      this.$element.trigger('show.zf.dropdownmenu', [$sub]);
+    }
+    /**
+     * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.
+     * @function
+     * @param {jQuery} $elem - element with a submenu to hide
+     * @param {Number} idx - index of the $tabs collection to hide
+     * @private
+     */
+
+  }, {
+    key: "_hide",
+    value: function _hide($elem, idx) {
+      var $toClose;
+
+      if ($elem && $elem.length) {
+        $toClose = $elem;
+      } else if (typeof idx !== 'undefined') {
+        $toClose = this.$tabs.not(function (i, el) {
+          return i === idx;
+        });
+      } else {
+        $toClose = this.$element;
+      }
+
+      var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;
+
+      if (somethingToClose) {
+        $toClose.find('li.is-active').add($toClose).attr({
+          'data-is-click': false
+        }).removeClass('is-active');
+        $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');
+
+        if (this.changed || $toClose.find('opens-inner').length) {
+          var oldClass = this.options.alignment === 'left' ? 'right' : 'left';
+          $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass("opens-inner opens-".concat(this.options.alignment)).addClass("opens-".concat(oldClass));
+          this.changed = false;
+        }
+        /**
+         * Fires when the open menus are closed.
+         * @event Dropdownmenu#hide
+         */
+
+
+        this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);
+      }
+    }
+    /**
+     * Destroys the plugin.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click').removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');
+      $(document.body).off('.zf.dropdownmenu');
+      Nest.Burn(this.$element, 'dropdown');
+    }
+  }]);
+
+  return DropdownMenu;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+DropdownMenu.defaults = {
+  /**
+   * Disallows hover events from opening submenus
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disableHover: false,
+
+  /**
+   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  autoclose: true,
+
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  hoverDelay: 50,
+
+  /**
+   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  clickOpen: false,
+
+  /**
+   * Amount of time to delay closing a submenu on a mouseleave event.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  closingTime: 500,
+
+  /**
+   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow clicks on the body to close any open submenus.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Allow clicks on leaf anchor links to close any open submenus.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClickInside: true,
+
+  /**
+   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.
+   * @option
+   * @type {string}
+   * @default 'vertical'
+   */
+  verticalClass: 'vertical',
+
+  /**
+   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.
+   * @option
+   * @type {string}
+   * @default 'align-right'
+   */
+  rightClass: 'align-right',
+
+  /**
+   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  forceFollow: true
+};
+
+/**
+ * Equalizer module.
+ * @module foundation.equalizer
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.imageLoader if equalizer contains images
+ */
+
+var Equalizer =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Equalizer, _Plugin);
+
+  function Equalizer() {
+    _classCallCheck(this, Equalizer);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Equalizer).apply(this, arguments));
+  }
+
+  _createClass(Equalizer, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Equalizer.
+     * @class
+     * @name Equalizer
+     * @fires Equalizer#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Equalizer.defaults, this.$element.data(), options);
+      this.className = 'Equalizer'; // ie9 back compat
+
+      this._init();
+    }
+    /**
+     * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var eqId = this.$element.attr('data-equalizer') || '';
+      var $watched = this.$element.find("[data-equalizer-watch=\"".concat(eqId, "\"]"));
+
+      MediaQuery._init();
+
+      this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');
+      this.$element.attr('data-resize', eqId || GetYoDigits(6, 'eq'));
+      this.$element.attr('data-mutate', eqId || GetYoDigits(6, 'eq'));
+      this.hasNested = this.$element.find('[data-equalizer]').length > 0;
+      this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;
+      this.isOn = false;
+      this._bindHandler = {
+        onResizeMeBound: this._onResizeMe.bind(this),
+        onPostEqualizedBound: this._onPostEqualized.bind(this)
+      };
+      var imgs = this.$element.find('img');
+      var tooSmall;
+
+      if (this.options.equalizeOn) {
+        tooSmall = this._checkMQ();
+        $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));
+      } else {
+        this._events();
+      }
+
+      if (typeof tooSmall !== 'undefined' && tooSmall === false || typeof tooSmall === 'undefined') {
+        if (imgs.length) {
+          onImagesLoaded(imgs, this._reflow.bind(this));
+        } else {
+          this._reflow();
+        }
+      }
+    }
+    /**
+     * Removes event listeners if the breakpoint is too small.
+     * @private
+     */
+
+  }, {
+    key: "_pauseEvents",
+    value: function _pauseEvents() {
+      this.isOn = false;
+      this.$element.off({
+        '.zf.equalizer': this._bindHandler.onPostEqualizedBound,
+        'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,
+        'mutateme.zf.trigger': this._bindHandler.onResizeMeBound
+      });
+    }
+    /**
+     * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound
+     * @private
+     */
+
+  }, {
+    key: "_onResizeMe",
+    value: function _onResizeMe(e) {
+      this._reflow();
+    }
+    /**
+     * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound
+     * @private
+     */
+
+  }, {
+    key: "_onPostEqualized",
+    value: function _onPostEqualized(e) {
+      if (e.target !== this.$element[0]) {
+        this._reflow();
+      }
+    }
+    /**
+     * Initializes events for Equalizer.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+
+      this._pauseEvents();
+
+      if (this.hasNested) {
+        this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);
+      } else {
+        this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);
+        this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);
+      }
+
+      this.isOn = true;
+    }
+    /**
+     * Checks the current breakpoint to the minimum required size.
+     * @private
+     */
+
+  }, {
+    key: "_checkMQ",
+    value: function _checkMQ() {
+      var tooSmall = !MediaQuery.is(this.options.equalizeOn);
+
+      if (tooSmall) {
+        if (this.isOn) {
+          this._pauseEvents();
+
+          this.$watched.css('height', 'auto');
+        }
+      } else {
+        if (!this.isOn) {
+          this._events();
+        }
+      }
+
+      return tooSmall;
+    }
+    /**
+     * A noop version for the plugin
+     * @private
+     */
+
+  }, {
+    key: "_killswitch",
+    value: function _killswitch() {
+      return;
+    }
+    /**
+     * Calls necessary functions to update Equalizer upon DOM change
+     * @private
+     */
+
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      if (!this.options.equalizeOnStack) {
+        if (this._isStacked()) {
+          this.$watched.css('height', 'auto');
+          return false;
+        }
+      }
+
+      if (this.options.equalizeByRow) {
+        this.getHeightsByRow(this.applyHeightByRow.bind(this));
+      } else {
+        this.getHeights(this.applyHeight.bind(this));
+      }
+    }
+    /**
+     * Manually determines if the first 2 elements are *NOT* stacked.
+     * @private
+     */
+
+  }, {
+    key: "_isStacked",
+    value: function _isStacked() {
+      if (!this.$watched[0] || !this.$watched[1]) {
+        return true;
+      }
+
+      return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;
+    }
+    /**
+     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
+     * @param {Function} cb - A non-optional callback to return the heights array to.
+     * @returns {Array} heights - An array of heights of children within Equalizer container
+     */
+
+  }, {
+    key: "getHeights",
+    value: function getHeights(cb) {
+      var heights = [];
+
+      for (var i = 0, len = this.$watched.length; i < len; i++) {
+        this.$watched[i].style.height = 'auto';
+        heights.push(this.$watched[i].offsetHeight);
+      }
+
+      cb(heights);
+    }
+    /**
+     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
+     * @param {Function} cb - A non-optional callback to return the heights array to.
+     * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
+     */
+
+  }, {
+    key: "getHeightsByRow",
+    value: function getHeightsByRow(cb) {
+      var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0,
+          groups = [],
+          group = 0; //group by Row
+
+      groups[group] = [];
+
+      for (var i = 0, len = this.$watched.length; i < len; i++) {
+        this.$watched[i].style.height = 'auto'; //maybe could use this.$watched[i].offsetTop
+
+        var elOffsetTop = $(this.$watched[i]).offset().top;
+
+        if (elOffsetTop != lastElTopOffset) {
+          group++;
+          groups[group] = [];
+          lastElTopOffset = elOffsetTop;
+        }
+
+        groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]);
+      }
+
+      for (var j = 0, ln = groups.length; j < ln; j++) {
+        var heights = $(groups[j]).map(function () {
+          return this[1];
+        }).get();
+        var max = Math.max.apply(null, heights);
+        groups[j].push(max);
+      }
+
+      cb(groups);
+    }
+    /**
+     * Changes the CSS height property of each child in an Equalizer parent to match the tallest
+     * @param {array} heights - An array of heights of children within Equalizer container
+     * @fires Equalizer#preequalized
+     * @fires Equalizer#postequalized
+     */
+
+  }, {
+    key: "applyHeight",
+    value: function applyHeight(heights) {
+      var max = Math.max.apply(null, heights);
+      /**
+       * Fires before the heights are applied
+       * @event Equalizer#preequalized
+       */
+
+      this.$element.trigger('preequalized.zf.equalizer');
+      this.$watched.css('height', max);
+      /**
+       * Fires when the heights have been applied
+       * @event Equalizer#postequalized
+       */
+
+      this.$element.trigger('postequalized.zf.equalizer');
+    }
+    /**
+     * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row
+     * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
+     * @fires Equalizer#preequalized
+     * @fires Equalizer#preequalizedrow
+     * @fires Equalizer#postequalizedrow
+     * @fires Equalizer#postequalized
+     */
+
+  }, {
+    key: "applyHeightByRow",
+    value: function applyHeightByRow(groups) {
+      /**
+       * Fires before the heights are applied
+       */
+      this.$element.trigger('preequalized.zf.equalizer');
+
+      for (var i = 0, len = groups.length; i < len; i++) {
+        var groupsILength = groups[i].length,
+            max = groups[i][groupsILength - 1];
+
+        if (groupsILength <= 2) {
+          $(groups[i][0][0]).css({
+            'height': 'auto'
+          });
+          continue;
+        }
+        /**
+          * Fires before the heights per row are applied
+          * @event Equalizer#preequalizedrow
+          */
+
+
+        this.$element.trigger('preequalizedrow.zf.equalizer');
+
+        for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) {
+          $(groups[i][j][0]).css({
+            'height': max
+          });
+        }
+        /**
+          * Fires when the heights per row have been applied
+          * @event Equalizer#postequalizedrow
+          */
+
+
+        this.$element.trigger('postequalizedrow.zf.equalizer');
+      }
+      /**
+       * Fires when the heights have been applied
+       */
+
+
+      this.$element.trigger('postequalized.zf.equalizer');
+    }
+    /**
+     * Destroys an instance of Equalizer.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this._pauseEvents();
+
+      this.$watched.css('height', 'auto');
+    }
+  }]);
+
+  return Equalizer;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+Equalizer.defaults = {
+  /**
+   * Enable height equalization when stacked on smaller screens.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  equalizeOnStack: false,
+
+  /**
+   * Enable height equalization row by row.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  equalizeByRow: false,
+
+  /**
+   * String representing the minimum breakpoint size the plugin should equalize heights on.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  equalizeOn: ''
+};
+
+/**
+ * Interchange module.
+ * @module foundation.interchange
+ * @requires foundation.util.mediaQuery
+ */
+
+var Interchange =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Interchange, _Plugin);
+
+  function Interchange() {
+    _classCallCheck(this, Interchange);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Interchange).apply(this, arguments));
+  }
+
+  _createClass(Interchange, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Interchange.
+     * @class
+     * @name Interchange
+     * @fires Interchange#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Interchange.defaults, options);
+      this.rules = [];
+      this.currentPath = '';
+      this.className = 'Interchange'; // ie9 back compat
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Interchange plugin and calls functions to get interchange functioning on load.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init();
+
+      var id = this.$element[0].id || GetYoDigits(6, 'interchange');
+      this.$element.attr({
+        'data-resize': id,
+        'id': id
+      });
+
+      this._addBreakpoints();
+
+      this._generateRules();
+
+      this._reflow();
+    }
+    /**
+     * Initializes events for Interchange.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this2 = this;
+
+      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () {
+        return _this2._reflow();
+      });
+    }
+    /**
+     * Calls necessary functions to update Interchange upon DOM change
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      var match; // Iterate through each rule, but only save the last match
+
+      for (var i in this.rules) {
+        if (this.rules.hasOwnProperty(i)) {
+          var rule = this.rules[i];
+
+          if (window.matchMedia(rule.query).matches) {
+            match = rule;
+          }
+        }
+      }
+
+      if (match) {
+        this.replace(match.path);
+      }
+    }
+    /**
+     * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_addBreakpoints",
+    value: function _addBreakpoints() {
+      for (var i in MediaQuery.queries) {
+        if (MediaQuery.queries.hasOwnProperty(i)) {
+          var query = MediaQuery.queries[i];
+          Interchange.SPECIAL_QUERIES[query.name] = query.value;
+        }
+      }
+    }
+    /**
+     * Checks the Interchange element for the provided media query + content pairings
+     * @function
+     * @private
+     * @param {Object} element - jQuery object that is an Interchange instance
+     * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys
+     */
+
+  }, {
+    key: "_generateRules",
+    value: function _generateRules(element) {
+      var rulesList = [];
+      var rules;
+
+      if (this.options.rules) {
+        rules = this.options.rules;
+      } else {
+        rules = this.$element.data('interchange');
+      }
+
+      rules = typeof rules === 'string' ? rules.match(/\[.*?, .*?\]/g) : rules;
+
+      for (var i in rules) {
+        if (rules.hasOwnProperty(i)) {
+          var rule = rules[i].slice(1, -1).split(', ');
+          var path = rule.slice(0, -1).join('');
+          var query = rule[rule.length - 1];
+
+          if (Interchange.SPECIAL_QUERIES[query]) {
+            query = Interchange.SPECIAL_QUERIES[query];
+          }
+
+          rulesList.push({
+            path: path,
+            query: query
+          });
+        }
+      }
+
+      this.rules = rulesList;
+    }
+    /**
+     * Update the `src` property of an image, or change the HTML of a container, to the specified path.
+     * @function
+     * @param {String} path - Path to the image or HTML partial.
+     * @fires Interchange#replaced
+     */
+
+  }, {
+    key: "replace",
+    value: function replace(path) {
+      if (this.currentPath === path) return;
+
+      var _this = this,
+          trigger = 'replaced.zf.interchange'; // Replacing images
+
+
+      if (this.$element[0].nodeName === 'IMG') {
+        this.$element.attr('src', path).on('load', function () {
+          _this.currentPath = path;
+        }).trigger(trigger);
+      } // Replacing background images
+      else if (path.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {
+          path = path.replace(/\(/g, '%28').replace(/\)/g, '%29');
+          this.$element.css({
+            'background-image': 'url(' + path + ')'
+          }).trigger(trigger);
+        } // Replacing HTML
+        else {
+            $.get(path, function (response) {
+              _this.$element.html(response).trigger(trigger);
+
+              $(response).foundation();
+              _this.currentPath = path;
+            });
+          }
+      /**
+       * Fires when content in an Interchange element is done being loaded.
+       * @event Interchange#replaced
+       */
+      // this.$element.trigger('replaced.zf.interchange');
+
+    }
+    /**
+     * Destroys an instance of interchange.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('resizeme.zf.trigger');
+    }
+  }]);
+
+  return Interchange;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+Interchange.defaults = {
+  /**
+   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.
+   * @option
+   * @type {?array}
+   * @default null
+   */
+  rules: null
+};
+Interchange.SPECIAL_QUERIES = {
+  'landscape': 'screen and (orientation: landscape)',
+  'portrait': 'screen and (orientation: portrait)',
+  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'
+};
+
+/**
+ * SmoothScroll module.
+ * @module foundation.smooth-scroll
+ */
+
+var SmoothScroll =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(SmoothScroll, _Plugin);
+
+  function SmoothScroll() {
+    _classCallCheck(this, SmoothScroll);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(SmoothScroll).apply(this, arguments));
+  }
+
+  _createClass(SmoothScroll, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of SmoothScroll.
+     * @class
+     * @name SmoothScroll
+     * @fires SmoothScroll#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);
+      this.className = 'SmoothScroll'; // ie9 back compat
+
+      this._init();
+    }
+    /**
+     * Initialize the SmoothScroll plugin
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');
+      this.$element.attr({
+        id: id
+      });
+
+      this._events();
+    }
+    /**
+     * Initializes events for SmoothScroll.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._linkClickListener = this._handleLinkClick.bind(this);
+      this.$element.on('click.zf.smoothScroll', this._linkClickListener);
+      this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
+    }
+    /**
+     * Handle the given event to smoothly scroll to the anchor pointed by the event target.
+     * @param {*} e - event
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_handleLinkClick",
+    value: function _handleLinkClick(e) {
+      var _this = this;
+
+      // Follow the link if it does not point to an anchor.
+      if (!$(e.currentTarget).is('a[href^="#"]')) return;
+      var arrival = e.currentTarget.getAttribute('href');
+      this._inTransition = true;
+      SmoothScroll.scrollToLoc(arrival, this.options, function () {
+        _this._inTransition = false;
+      });
+      e.preventDefault();
+    }
+  }, {
+    key: "_destroy",
+
+    /**
+     * Destroys the SmoothScroll instance.
+     * @function
+     */
+    value: function _destroy() {
+      this.$element.off('click.zf.smoothScroll', this._linkClickListener);
+      this.$element.off('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
+    }
+  }], [{
+    key: "scrollToLoc",
+
+    /**
+     * Function to scroll to a given location on the page.
+     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'
+     * @param {Object} options - The options to use.
+     * @param {Function} callback - The callback function.
+     * @static
+     * @function
+     */
+    value: function scrollToLoc(loc) {
+      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults;
+      var callback = arguments.length > 2 ? arguments[2] : undefined;
+      var $loc = $(loc); // Do nothing if target does not exist to prevent errors
+
+      if (!$loc.length) return false;
+      var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);
+      $('html, body').stop(true).animate({
+        scrollTop: scrollPos
+      }, options.animationDuration, options.animationEasing, function () {
+        if (typeof callback === 'function') {
+          callback();
+        }
+      });
+    }
+  }]);
+
+  return SmoothScroll;
+}(Plugin);
+/**
+ * Default settings for plugin.
+ */
+
+
+SmoothScroll.defaults = {
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
+
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
+
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
+};
+
+/**
+ * Magellan module.
+ * @module foundation.magellan
+ * @requires foundation.smoothScroll
+ */
+
+var Magellan =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Magellan, _Plugin);
+
+  function Magellan() {
+    _classCallCheck(this, Magellan);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Magellan).apply(this, arguments));
+  }
+
+  _createClass(Magellan, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Magellan.
+     * @class
+     * @name Magellan
+     * @fires Magellan#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Magellan.defaults, this.$element.data(), options);
+      this.className = 'Magellan'; // ie9 back compat
+
+      this._init();
+
+      this.calcPoints();
+    }
+    /**
+     * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var id = this.$element[0].id || GetYoDigits(6, 'magellan');
+
+      this.$targets = $('[data-magellan-target]');
+      this.$links = this.$element.find('a');
+      this.$element.attr({
+        'data-resize': id,
+        'data-scroll': id,
+        'id': id
+      });
+      this.$active = $();
+      this.scrollPos = parseInt(window.pageYOffset, 10);
+
+      this._events();
+    }
+    /**
+     * Calculates an array of pixel values that are the demarcation lines between locations on the page.
+     * Can be invoked if new elements are added or the size of a location changes.
+     * @function
+     */
+
+  }, {
+    key: "calcPoints",
+    value: function calcPoints() {
+      var _this = this,
+          body = document.body,
+          html = document.documentElement;
+
+      this.points = [];
+      this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));
+      this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));
+      this.$targets.each(function () {
+        var $tar = $(this),
+            pt = Math.round($tar.offset().top - _this.options.threshold);
+        $tar.targetPoint = pt;
+
+        _this.points.push(pt);
+      });
+    }
+    /**
+     * Initializes events for Magellan.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this,
+          $body = $('html, body'),
+          opts = {
+        duration: _this.options.animationDuration,
+        easing: _this.options.animationEasing
+      };
+
+      $(window).one('load', function () {
+        if (_this.options.deepLinking) {
+          if (location.hash) {
+            _this.scrollToLoc(location.hash);
+          }
+        }
+
+        _this.calcPoints();
+
+        _this._updateActive();
+      });
+      _this.onLoadListener = onLoad($(window), function () {
+        _this.$element.on({
+          'resizeme.zf.trigger': _this.reflow.bind(_this),
+          'scrollme.zf.trigger': _this._updateActive.bind(_this)
+        }).on('click.zf.magellan', 'a[href^="#"]', function (e) {
+          e.preventDefault();
+          var arrival = this.getAttribute('href');
+
+          _this.scrollToLoc(arrival);
+        });
+      });
+
+      this._deepLinkScroll = function (e) {
+        if (_this.options.deepLinking) {
+          _this.scrollToLoc(window.location.hash);
+        }
+      };
+
+      $(window).on('hashchange', this._deepLinkScroll);
+    }
+    /**
+     * Function to scroll to a given location on the page.
+     * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'
+     * @function
+     */
+
+  }, {
+    key: "scrollToLoc",
+    value: function scrollToLoc(loc) {
+      this._inTransition = true;
+
+      var _this = this;
+
+      var options = {
+        animationEasing: this.options.animationEasing,
+        animationDuration: this.options.animationDuration,
+        threshold: this.options.threshold,
+        offset: this.options.offset
+      };
+      SmoothScroll.scrollToLoc(loc, options, function () {
+        _this._inTransition = false;
+      });
+    }
+    /**
+     * Calls necessary functions to update Magellan upon DOM change
+     * @function
+     */
+
+  }, {
+    key: "reflow",
+    value: function reflow() {
+      this.calcPoints();
+
+      this._updateActive();
+    }
+    /**
+     * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.
+     * @private
+     * @function
+     * @fires Magellan#update
+     */
+
+  }, {
+    key: "_updateActive",
+    value: function _updateActive()
+    /*evt, elem, scrollPos*/
+    {
+      var _this2 = this;
+
+      if (this._inTransition) return;
+      var newScrollPos = parseInt(window.pageYOffset, 10);
+      var isScrollingUp = this.scrollPos > newScrollPos;
+      this.scrollPos = newScrollPos;
+      var activeIdx; // Before the first point: no link
+
+      if (newScrollPos < this.points[0]) ;
+      /* do nothing */
+      // At the bottom of the page: last link
+      else if (newScrollPos + this.winHeight === this.docHeight) {
+          activeIdx = this.points.length - 1;
+        } // Otherwhise, use the last visible link
+        else {
+            var visibleLinks = this.points.filter(function (p, i) {
+              return p - _this2.options.offset - (isScrollingUp ? _this2.options.threshold : 0) <= newScrollPos;
+            });
+            activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;
+          } // Get the new active link
+
+
+      var $oldActive = this.$active;
+      var activeHash = '';
+
+      if (typeof activeIdx !== 'undefined') {
+        this.$active = this.$links.filter('[href="#' + this.$targets.eq(activeIdx).data('magellan-target') + '"]');
+        if (this.$active.length) activeHash = this.$active[0].getAttribute('href');
+      } else {
+        this.$active = $();
+      }
+
+      var isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);
+      var isNewHash = activeHash !== window.location.hash; // Update the active link element
+
+      if (isNewActive) {
+        $oldActive.removeClass(this.options.activeClass);
+        this.$active.addClass(this.options.activeClass);
+      } // Update the hash (it may have changed with the same active link)
+
+
+      if (this.options.deepLinking && isNewHash) {
+        if (window.history.pushState) {
+          // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384
+          var url = activeHash ? activeHash : window.location.pathname + window.location.search;
+          window.history.pushState(null, null, url);
+        } else {
+          window.location.hash = activeHash;
+        }
+      }
+
+      if (isNewActive) {
+        /**
+         * Fires when magellan is finished updating to the new active element.
+         * @event Magellan#update
+         */
+        this.$element.trigger('update.zf.magellan', [this.$active]);
+      }
+    }
+    /**
+     * Destroys an instance of Magellan and resets the url of the window.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.trigger .zf.magellan').find(".".concat(this.options.activeClass)).removeClass(this.options.activeClass);
+
+      if (this.options.deepLinking) {
+        var hash = this.$active[0].getAttribute('href');
+        window.location.hash.replace(hash, '');
+      }
+
+      $(window).off('hashchange', this._deepLinkScroll);
+      if (this.onLoadListener) $(window).off(this.onLoadListener);
+    }
+  }]);
+
+  return Magellan;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+Magellan.defaults = {
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
+
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
+
+  /**
+   * Class applied to the active locations link on the magellan container.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  activeClass: 'is-active',
+
+  /**
+   * Allows the script to manipulate the url of the current page, and if supported, alter the history.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinking: false,
+
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
+};
+
+/**
+ * OffCanvas module.
+ * @module foundation.offcanvas
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.triggers
+ */
+
+var OffCanvas =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(OffCanvas, _Plugin);
+
+  function OffCanvas() {
+    _classCallCheck(this, OffCanvas);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(OffCanvas).apply(this, arguments));
+  }
+
+  _createClass(OffCanvas, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of an off-canvas wrapper.
+     * @class
+     * @name OffCanvas
+     * @fires OffCanvas#init
+     * @param {Object} element - jQuery object to initialize.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      var _this2 = this;
+
+      this.className = 'OffCanvas'; // ie9 back compat
+
+      this.$element = element;
+      this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);
+      this.contentClasses = {
+        base: [],
+        reveal: []
+      };
+      this.$lastTrigger = $();
+      this.$triggers = $();
+      this.position = 'left';
+      this.$content = $();
+      this.nested = !!this.options.nested; // Defines the CSS transition/position classes of the off-canvas content container.
+
+      $(['push', 'overlap']).each(function (index, val) {
+        _this2.contentClasses.base.push('has-transition-' + val);
+      });
+      $(['left', 'right', 'top', 'bottom']).each(function (index, val) {
+        _this2.contentClasses.base.push('has-position-' + val);
+
+        _this2.contentClasses.reveal.push('has-reveal-' + val);
+      }); // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      MediaQuery._init();
+
+      this._init();
+
+      this._events();
+
+      Keyboard.register('OffCanvas', {
+        'ESCAPE': 'close'
+      });
+    }
+    /**
+     * Initializes the off-canvas wrapper by adding the exit overlay (if needed).
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var id = this.$element.attr('id');
+      this.$element.attr('aria-hidden', 'true'); // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)
+
+      if (this.options.contentId) {
+        this.$content = $('#' + this.options.contentId);
+      } else if (this.$element.siblings('[data-off-canvas-content]').length) {
+        this.$content = this.$element.siblings('[data-off-canvas-content]').first();
+      } else {
+        this.$content = this.$element.closest('[data-off-canvas-content]').first();
+      }
+
+      if (!this.options.contentId) {
+        // Assume that the off-canvas element is nested if it isn't a sibling of the content
+        this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;
+      } else if (this.options.contentId && this.options.nested === null) {
+        // Warning if using content ID without setting the nested option
+        // Once the element is nested it is required to work properly in this case
+        console.warn('Remember to use the nested option if using the content ID option!');
+      }
+
+      if (this.nested === true) {
+        // Force transition overlap if nested
+        this.options.transition = 'overlap'; // Remove appropriate classes if already assigned in markup
+
+        this.$element.removeClass('is-transition-push');
+      }
+
+      this.$element.addClass("is-transition-".concat(this.options.transition, " is-closed")); // Find triggers that affect this element and add aria-expanded to them
+
+      this.$triggers = $(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id); // Get position by checking for related CSS class
+
+      this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position; // Add an overlay over the content if necessary
+
+      if (this.options.contentOverlay === true) {
+        var overlay = document.createElement('div');
+        var overlayPosition = $(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';
+        overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);
+        this.$overlay = $(overlay);
+
+        if (overlayPosition === 'is-overlay-fixed') {
+          $(this.$overlay).insertAfter(this.$element);
+        } else {
+          this.$content.append(this.$overlay);
+        }
+      } // Get the revealOn option from the class.
+
+
+      var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\s]+)', 'g');
+      var revealOnClass = revealOnRegExp.exec(this.$element[0].className);
+
+      if (revealOnClass) {
+        this.options.isRevealed = true;
+        this.options.revealOn = this.options.revealOn || revealOnClass[1];
+      } // Ensure the `reveal-on-*` class is set.
+
+
+      if (this.options.isRevealed === true && this.options.revealOn) {
+        this.$element.first().addClass("".concat(this.options.revealClass).concat(this.options.revealOn));
+
+        this._setMQChecker();
+      }
+
+      if (this.options.transitionTime) {
+        this.$element.css('transition-duration', this.options.transitionTime);
+      } // Initally remove all transition/position CSS classes from off-canvas content container.
+
+
+      this._removeContentClasses();
+    }
+    /**
+     * Adds event handlers to the off-canvas wrapper and the exit overlay.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this.$element.off('.zf.trigger .zf.offcanvas').on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': this.close.bind(this),
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'keydown.zf.offcanvas': this._handleKeyboard.bind(this)
+      });
+
+      if (this.options.closeOnClick === true) {
+        var $target = this.options.contentOverlay ? this.$overlay : this.$content;
+        $target.on({
+          'click.zf.offcanvas': this.close.bind(this)
+        });
+      }
+    }
+    /**
+     * Applies event listener for elements that will reveal at certain breakpoints.
+     * @private
+     */
+
+  }, {
+    key: "_setMQChecker",
+    value: function _setMQChecker() {
+      var _this = this;
+
+      this.onLoadListener = onLoad($(window), function () {
+        if (MediaQuery.atLeast(_this.options.revealOn)) {
+          _this.reveal(true);
+        }
+      });
+      $(window).on('changed.zf.mediaquery', function () {
+        if (MediaQuery.atLeast(_this.options.revealOn)) {
+          _this.reveal(true);
+        } else {
+          _this.reveal(false);
+        }
+      });
+    }
+    /**
+     * Removes the CSS transition/position classes of the off-canvas content container.
+     * Removing the classes is important when another off-canvas gets opened that uses the same content container.
+     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
+     * @private
+     */
+
+  }, {
+    key: "_removeContentClasses",
+    value: function _removeContentClasses(hasReveal) {
+      if (typeof hasReveal !== 'boolean') {
+        this.$content.removeClass(this.contentClasses.base.join(' '));
+      } else if (hasReveal === false) {
+        this.$content.removeClass("has-reveal-".concat(this.position));
+      }
+    }
+    /**
+     * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.
+     * Beforehand any transition/position class gets removed.
+     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
+     * @private
+     */
+
+  }, {
+    key: "_addContentClasses",
+    value: function _addContentClasses(hasReveal) {
+      this._removeContentClasses(hasReveal);
+
+      if (typeof hasReveal !== 'boolean') {
+        this.$content.addClass("has-transition-".concat(this.options.transition, " has-position-").concat(this.position));
+      } else if (hasReveal === true) {
+        this.$content.addClass("has-reveal-".concat(this.position));
+      }
+    }
+    /**
+     * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.
+     * @param {Boolean} isRevealed - true if element should be revealed.
+     * @function
+     */
+
+  }, {
+    key: "reveal",
+    value: function reveal(isRevealed) {
+      if (isRevealed) {
+        this.close();
+        this.isRevealed = true;
+        this.$element.attr('aria-hidden', 'false');
+        this.$element.off('open.zf.trigger toggle.zf.trigger');
+        this.$element.removeClass('is-closed');
+      } else {
+        this.isRevealed = false;
+        this.$element.attr('aria-hidden', 'true');
+        this.$element.off('open.zf.trigger toggle.zf.trigger').on({
+          'open.zf.trigger': this.open.bind(this),
+          'toggle.zf.trigger': this.toggle.bind(this)
+        });
+        this.$element.addClass('is-closed');
+      }
+
+      this._addContentClasses(isRevealed);
+    }
+    /**
+     * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.
+     * @private
+     */
+
+  }, {
+    key: "_stopScrolling",
+    value: function _stopScrolling(event) {
+      return false;
+    } // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios
+    // Only really works for y, not sure how to extend to x or if we need to.
+
+  }, {
+    key: "_recordScrollable",
+    value: function _recordScrollable(event) {
+      var elem = this; // called from event handler context with this as elem
+      // If the element is scrollable (content overflows), then...
+
+      if (elem.scrollHeight !== elem.clientHeight) {
+        // If we're at the top, scroll down one pixel to allow scrolling up
+        if (elem.scrollTop === 0) {
+          elem.scrollTop = 1;
+        } // If we're at the bottom, scroll up one pixel to allow scrolling down
+
+
+        if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {
+          elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;
+        }
+      }
+
+      elem.allowUp = elem.scrollTop > 0;
+      elem.allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight;
+      elem.lastY = event.originalEvent.pageY;
+    }
+  }, {
+    key: "_stopScrollPropagation",
+    value: function _stopScrollPropagation(event) {
+      var elem = this; // called from event handler context with this as elem
+
+      var up = event.pageY < elem.lastY;
+      var down = !up;
+      elem.lastY = event.pageY;
+
+      if (up && elem.allowUp || down && elem.allowDown) {
+        event.stopPropagation();
+      } else {
+        event.preventDefault();
+      }
+    }
+    /**
+     * Opens the off-canvas menu.
+     * @function
+     * @param {Object} event - Event object passed from listener.
+     * @param {jQuery} trigger - element that triggered the off-canvas to open.
+     * @fires Offcanvas#opened
+     * @todo also trigger 'open' event?
+     */
+
+  }, {
+    key: "open",
+    value: function open(event, trigger) {
+      if (this.$element.hasClass('is-open') || this.isRevealed) {
+        return;
+      }
+
+      var _this = this;
+
+      if (trigger) {
+        this.$lastTrigger = trigger;
+      }
+
+      if (this.options.forceTo === 'top') {
+        window.scrollTo(0, 0);
+      } else if (this.options.forceTo === 'bottom') {
+        window.scrollTo(0, document.body.scrollHeight);
+      }
+
+      if (this.options.transitionTime && this.options.transition !== 'overlap') {
+        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);
+      } else {
+        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');
+      }
+
+      this.$element.addClass('is-open').removeClass('is-closed');
+      this.$triggers.attr('aria-expanded', 'true');
+      this.$element.attr('aria-hidden', 'false');
+      this.$content.addClass('is-open-' + this.position); // If `contentScroll` is set to false, add class and disable scrolling on touch devices.
+
+      if (this.options.contentScroll === false) {
+        $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);
+        this.$element.on('touchstart', this._recordScrollable);
+        this.$element.on('touchmove', this._stopScrollPropagation);
+      }
+
+      if (this.options.contentOverlay === true) {
+        this.$overlay.addClass('is-visible');
+      }
+
+      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+        this.$overlay.addClass('is-closable');
+      }
+
+      if (this.options.autoFocus === true) {
+        this.$element.one(transitionend(this.$element), function () {
+          if (!_this.$element.hasClass('is-open')) {
+            return; // exit if prematurely closed
+          }
+
+          var canvasFocus = _this.$element.find('[data-autofocus]');
+
+          if (canvasFocus.length) {
+            canvasFocus.eq(0).focus();
+          } else {
+            _this.$element.find('a, button').eq(0).focus();
+          }
+        });
+      }
+
+      if (this.options.trapFocus === true) {
+        this.$content.attr('tabindex', '-1');
+        Keyboard.trapFocus(this.$element);
+      }
+
+      this._addContentClasses();
+      /**
+       * Fires when the off-canvas menu opens.
+       * @event Offcanvas#opened
+       */
+
+
+      this.$element.trigger('opened.zf.offcanvas');
+    }
+    /**
+     * Closes the off-canvas menu.
+     * @function
+     * @param {Function} cb - optional cb to fire after closure.
+     * @fires Offcanvas#closed
+     */
+
+  }, {
+    key: "close",
+    value: function close(cb) {
+      if (!this.$element.hasClass('is-open') || this.isRevealed) {
+        return;
+      }
+
+      var _this = this;
+
+      this.$element.removeClass('is-open');
+      this.$element.attr('aria-hidden', 'true')
+      /**
+       * Fires when the off-canvas menu opens.
+       * @event Offcanvas#closed
+       */
+      .trigger('closed.zf.offcanvas');
+      this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom'); // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.
+
+      if (this.options.contentScroll === false) {
+        $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);
+        this.$element.off('touchstart', this._recordScrollable);
+        this.$element.off('touchmove', this._stopScrollPropagation);
+      }
+
+      if (this.options.contentOverlay === true) {
+        this.$overlay.removeClass('is-visible');
+      }
+
+      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+        this.$overlay.removeClass('is-closable');
+      }
+
+      this.$triggers.attr('aria-expanded', 'false');
+
+      if (this.options.trapFocus === true) {
+        this.$content.removeAttr('tabindex');
+        Keyboard.releaseFocus(this.$element);
+      } // Listen to transitionEnd and add class when done.
+
+
+      this.$element.one(transitionend(this.$element), function (e) {
+        _this.$element.addClass('is-closed');
+
+        _this._removeContentClasses();
+      });
+    }
+    /**
+     * Toggles the off-canvas menu open or closed.
+     * @function
+     * @param {Object} event - Event object passed from listener.
+     * @param {jQuery} trigger - element that triggered the off-canvas to open.
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle(event, trigger) {
+      if (this.$element.hasClass('is-open')) {
+        this.close(event, trigger);
+      } else {
+        this.open(event, trigger);
+      }
+    }
+    /**
+     * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_handleKeyboard",
+    value: function _handleKeyboard(e) {
+      var _this3 = this;
+
+      Keyboard.handleKey(e, 'OffCanvas', {
+        close: function close() {
+          _this3.close();
+
+          _this3.$lastTrigger.focus();
+
+          return true;
+        },
+        handled: function handled() {
+          e.stopPropagation();
+          e.preventDefault();
+        }
+      });
+    }
+    /**
+     * Destroys the offcanvas plugin.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.close();
+      this.$element.off('.zf.trigger .zf.offcanvas');
+      this.$overlay.off('.zf.offcanvas');
+      if (this.onLoadListener) $(window).off(this.onLoadListener);
+    }
+  }]);
+
+  return OffCanvas;
+}(Plugin);
+
+OffCanvas.defaults = {
+  /**
+   * Allow the user to click outside of the menu to close it.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Adds an overlay on top of `[data-off-canvas-content]`.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  contentOverlay: true,
+
+  /**
+   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  contentId: null,
+
+  /**
+   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.
+   * @option
+   * @type {boolean}
+   * @default null
+   */
+  nested: null,
+
+  /**
+   * Enable/disable scrolling of the main content when an off canvas panel is open.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  contentScroll: true,
+
+  /**
+   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.
+   * @option
+   * @type {number}
+   * @default null
+   */
+  transitionTime: null,
+
+  /**
+   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.
+   * @option
+   * @type {string}
+   * @default push
+   */
+  transition: 'push',
+
+  /**
+   * Force the page to scroll to top or bottom on open.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  forceTo: null,
+
+  /**
+   * Allow the offcanvas to remain open for certain breakpoints.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  isRevealed: false,
+
+  /**
+   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  revealOn: null,
+
+  /**
+   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  autoFocus: true,
+
+  /**
+   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.
+   * @option
+   * @type {string}
+   * @default reveal-for-
+   * @todo improve the regex testing for this.
+   */
+  revealClass: 'reveal-for-',
+
+  /**
+   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  trapFocus: false
+};
+
+/**
+ * Orbit module.
+ * @module foundation.orbit
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.motion
+ * @requires foundation.util.timer
+ * @requires foundation.util.imageLoader
+ * @requires foundation.util.touch
+ */
+
+var Orbit =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Orbit, _Plugin);
+
+  function Orbit() {
+    _classCallCheck(this, Orbit);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Orbit).apply(this, arguments));
+  }
+
+  _createClass(Orbit, [{
+    key: "_setup",
+
+    /**
+    * Creates a new instance of an orbit carousel.
+    * @class
+    * @name Orbit
+    * @param {jQuery} element - jQuery object to make into an Orbit Carousel.
+    * @param {Object} options - Overrides to the default plugin settings.
+    */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);
+      this.className = 'Orbit'; // ie9 back compat
+
+      Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.
+
+      this._init();
+
+      Keyboard.register('Orbit', {
+        'ltr': {
+          'ARROW_RIGHT': 'next',
+          'ARROW_LEFT': 'previous'
+        },
+        'rtl': {
+          'ARROW_LEFT': 'next',
+          'ARROW_RIGHT': 'previous'
+        }
+      });
+    }
+    /**
+    * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide
+      this._reset();
+
+      this.$wrapper = this.$element.find(".".concat(this.options.containerClass));
+      this.$slides = this.$element.find(".".concat(this.options.slideClass));
+      var $images = this.$element.find('img'),
+          initActive = this.$slides.filter('.is-active'),
+          id = this.$element[0].id || GetYoDigits(6, 'orbit');
+      this.$element.attr({
+        'data-resize': id,
+        'id': id
+      });
+
+      if (!initActive.length) {
+        this.$slides.eq(0).addClass('is-active');
+      }
+
+      if (!this.options.useMUI) {
+        this.$slides.addClass('no-motionui');
+      }
+
+      if ($images.length) {
+        onImagesLoaded($images, this._prepareForOrbit.bind(this));
+      } else {
+        this._prepareForOrbit(); //hehe
+
+      }
+
+      if (this.options.bullets) {
+        this._loadBullets();
+      }
+
+      this._events();
+
+      if (this.options.autoPlay && this.$slides.length > 1) {
+        this.geoSync();
+      }
+
+      if (this.options.accessible) {
+        // allow wrapper to be focusable to enable arrow navigation
+        this.$wrapper.attr('tabindex', 0);
+      }
+    }
+    /**
+    * Creates a jQuery collection of bullets, if they are being used.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_loadBullets",
+    value: function _loadBullets() {
+      this.$bullets = this.$element.find(".".concat(this.options.boxOfBullets)).find('button');
+    }
+    /**
+    * Sets a `timer` object on the orbit, and starts the counter for the next slide.
+    * @function
+    */
+
+  }, {
+    key: "geoSync",
+    value: function geoSync() {
+      var _this = this;
+
+      this.timer = new Timer(this.$element, {
+        duration: this.options.timerDelay,
+        infinite: false
+      }, function () {
+        _this.changeSlide(true);
+      });
+      this.timer.start();
+    }
+    /**
+    * Sets wrapper and slide heights for the orbit.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_prepareForOrbit",
+    value: function _prepareForOrbit() {
+
+      this._setWrapperHeight();
+    }
+    /**
+    * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.
+    * @function
+    * @private
+    * @param {Function} cb - a callback function to fire when complete.
+    */
+
+  }, {
+    key: "_setWrapperHeight",
+    value: function _setWrapperHeight(cb) {
+      //rewrite this to `for` loop
+      var max = 0,
+          temp,
+          counter = 0,
+          _this = this;
+
+      this.$slides.each(function () {
+        temp = this.getBoundingClientRect().height;
+        $(this).attr('data-slide', counter); // hide all slides but the active one
+
+        if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {
+          $(this).css({
+            'display': 'none'
+          });
+        }
+
+        max = temp > max ? temp : max;
+        counter++;
+      });
+
+      if (counter === this.$slides.length) {
+        this.$wrapper.css({
+          'height': max
+        }); //only change the wrapper height property once.
+
+        if (cb) {
+          cb(max);
+        } //fire callback with max height dimension.
+
+      }
+    }
+    /**
+    * Sets the max-height of each slide.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_setSlideHeight",
+    value: function _setSlideHeight(height) {
+      this.$slides.each(function () {
+        $(this).css('max-height', height);
+      });
+    }
+    /**
+    * Adds event listeners to basically everything within the element.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this; //***************************************
+      //**Now using custom event - thanks to:**
+      //**      Yohai Ararat of Toronto      **
+      //***************************************
+      //
+
+
+      this.$element.off('.resizeme.zf.trigger').on({
+        'resizeme.zf.trigger': this._prepareForOrbit.bind(this)
+      });
+
+      if (this.$slides.length > 1) {
+        if (this.options.swipe) {
+          this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) {
+            e.preventDefault();
+
+            _this.changeSlide(true);
+          }).on('swiperight.zf.orbit', function (e) {
+            e.preventDefault();
+
+            _this.changeSlide(false);
+          });
+        } //***************************************
+
+
+        if (this.options.autoPlay) {
+          this.$slides.on('click.zf.orbit', function () {
+            _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);
+
+            _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();
+          });
+
+          if (this.options.pauseOnHover) {
+            this.$element.on('mouseenter.zf.orbit', function () {
+              _this.timer.pause();
+            }).on('mouseleave.zf.orbit', function () {
+              if (!_this.$element.data('clickedOn')) {
+                _this.timer.start();
+              }
+            });
+          }
+        }
+
+        if (this.options.navButtons) {
+          var $controls = this.$element.find(".".concat(this.options.nextClass, ", .").concat(this.options.prevClass));
+          $controls.attr('tabindex', 0) //also need to handle enter/return and spacebar key presses
+          .on('click.zf.orbit touchend.zf.orbit', function (e) {
+            e.preventDefault();
+
+            _this.changeSlide($(this).hasClass(_this.options.nextClass));
+          });
+        }
+
+        if (this.options.bullets) {
+          this.$bullets.on('click.zf.orbit touchend.zf.orbit', function () {
+            if (/is-active/g.test(this.className)) {
+              return false;
+            } //if this is active, kick out of function.
+
+
+            var idx = $(this).data('slide'),
+                ltr = idx > _this.$slides.filter('.is-active').data('slide'),
+                $slide = _this.$slides.eq(idx);
+
+            _this.changeSlide(ltr, $slide, idx);
+          });
+        }
+
+        if (this.options.accessible) {
+          this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) {
+            // handle keyboard event with keyboard util
+            Keyboard.handleKey(e, 'Orbit', {
+              next: function next() {
+                _this.changeSlide(true);
+              },
+              previous: function previous() {
+                _this.changeSlide(false);
+              },
+              handled: function handled() {
+                // if bullet is focused, make sure focus moves
+                if ($(e.target).is(_this.$bullets)) {
+                  _this.$bullets.filter('.is-active').focus();
+                }
+              }
+            });
+          });
+        }
+      }
+    }
+    /**
+     * Resets Orbit so it can be reinitialized
+     */
+
+  }, {
+    key: "_reset",
+    value: function _reset() {
+      // Don't do anything if there are no slides (first run)
+      if (typeof this.$slides == 'undefined') {
+        return;
+      }
+
+      if (this.$slides.length > 1) {
+        // Remove old events
+        this.$element.off('.zf.orbit').find('*').off('.zf.orbit'); // Restart timer if autoPlay is enabled
+
+        if (this.options.autoPlay) {
+          this.timer.restart();
+        } // Reset all sliddes
+
+
+        this.$slides.each(function (el) {
+          $(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide();
+        }); // Show the first slide
+
+        this.$slides.first().addClass('is-active').show(); // Triggers when the slide has finished animating
+
+        this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); // Select first bullet if bullets are present
+
+        if (this.options.bullets) {
+          this._updateBullets(0);
+        }
+      }
+    }
+    /**
+    * Changes the current slide to a new one.
+    * @function
+    * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.
+    * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.
+    * @param {Number} idx - the index of the new slide in its collection, if one chosen.
+    * @fires Orbit#slidechange
+    */
+
+  }, {
+    key: "changeSlide",
+    value: function changeSlide(isLTR, chosenSlide, idx) {
+      if (!this.$slides) {
+        return;
+      } // Don't freak out if we're in the middle of cleanup
+
+
+      var $curSlide = this.$slides.filter('.is-active').eq(0);
+
+      if (/mui/g.test($curSlide[0].className)) {
+        return false;
+      } //if the slide is currently animating, kick out of the function
+
+
+      var $firstSlide = this.$slides.first(),
+          $lastSlide = this.$slides.last(),
+          dirIn = isLTR ? 'Right' : 'Left',
+          dirOut = isLTR ? 'Left' : 'Right',
+          _this = this,
+          $newSlide;
+
+      if (!chosenSlide) {
+        //most of the time, this will be auto played or clicked from the navButtons.
+        $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!
+        this.options.infiniteWrap ? $curSlide.next(".".concat(this.options.slideClass)).length ? $curSlide.next(".".concat(this.options.slideClass)) : $firstSlide : $curSlide.next(".".concat(this.options.slideClass)) : //pick next slide if moving left to right
+        this.options.infiniteWrap ? $curSlide.prev(".".concat(this.options.slideClass)).length ? $curSlide.prev(".".concat(this.options.slideClass)) : $lastSlide : $curSlide.prev(".".concat(this.options.slideClass)); //pick prev slide if moving right to left
+      } else {
+        $newSlide = chosenSlide;
+      }
+
+      if ($newSlide.length) {
+        /**
+        * Triggers before the next slide starts animating in and only if a next slide has been found.
+        * @event Orbit#beforeslidechange
+        */
+        this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);
+
+        if (this.options.bullets) {
+          idx = idx || this.$slides.index($newSlide); //grab index to update bullets
+
+          this._updateBullets(idx);
+        }
+
+        if (this.options.useMUI && !this.$element.is(':hidden')) {
+          Motion.animateIn($newSlide.addClass('is-active'), this.options["animInFrom".concat(dirIn)], function () {
+            $newSlide.css({
+              'display': 'block'
+            }).attr('aria-live', 'polite');
+          });
+          Motion.animateOut($curSlide.removeClass('is-active'), this.options["animOutTo".concat(dirOut)], function () {
+            $curSlide.removeAttr('aria-live');
+
+            if (_this.options.autoPlay && !_this.timer.isPaused) {
+              _this.timer.restart();
+            } //do stuff?
+
+          });
+        } else {
+          $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();
+          $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();
+
+          if (this.options.autoPlay && !this.timer.isPaused) {
+            this.timer.restart();
+          }
+        }
+        /**
+        * Triggers when the slide has finished animating in.
+        * @event Orbit#slidechange
+        */
+
+
+        this.$element.trigger('slidechange.zf.orbit', [$newSlide]);
+      }
+    }
+    /**
+    * Updates the active state of the bullets, if displayed.
+    * @function
+    * @private
+    * @param {Number} idx - the index of the current slide.
+    */
+
+  }, {
+    key: "_updateBullets",
+    value: function _updateBullets(idx) {
+      var $oldBullet = this.$element.find(".".concat(this.options.boxOfBullets)).find('.is-active').removeClass('is-active').blur(),
+          span = $oldBullet.find('span:last').detach(),
+          $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);
+    }
+    /**
+    * Destroys the carousel and hides the element.
+    * @function
+    */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();
+    }
+  }]);
+
+  return Orbit;
+}(Plugin);
+
+Orbit.defaults = {
+  /**
+  * Tells the JS to look for and loadBullets.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  bullets: true,
+
+  /**
+  * Tells the JS to apply event listeners to nav buttons
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  navButtons: true,
+
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-in-right'
+  */
+  animInFromRight: 'slide-in-right',
+
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-out-right'
+  */
+  animOutToRight: 'slide-out-right',
+
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-in-left'
+  *
+  */
+  animInFromLeft: 'slide-in-left',
+
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-out-left'
+  */
+  animOutToLeft: 'slide-out-left',
+
+  /**
+  * Allows Orbit to automatically animate on page load.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  autoPlay: true,
+
+  /**
+  * Amount of time, in ms, between slide transitions
+  * @option
+   * @type {number}
+  * @default 5000
+  */
+  timerDelay: 5000,
+
+  /**
+  * Allows Orbit to infinitely loop through the slides
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  infiniteWrap: true,
+
+  /**
+  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  swipe: true,
+
+  /**
+  * Allows the timing function to pause animation on hover.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  pauseOnHover: true,
+
+  /**
+  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  accessible: true,
+
+  /**
+  * Class applied to the container of Orbit
+  * @option
+   * @type {string}
+  * @default 'orbit-container'
+  */
+  containerClass: 'orbit-container',
+
+  /**
+  * Class applied to individual slides.
+  * @option
+   * @type {string}
+  * @default 'orbit-slide'
+  */
+  slideClass: 'orbit-slide',
+
+  /**
+  * Class applied to the bullet container. You're welcome.
+  * @option
+   * @type {string}
+  * @default 'orbit-bullets'
+  */
+  boxOfBullets: 'orbit-bullets',
+
+  /**
+  * Class applied to the `next` navigation button.
+  * @option
+   * @type {string}
+  * @default 'orbit-next'
+  */
+  nextClass: 'orbit-next',
+
+  /**
+  * Class applied to the `previous` navigation button.
+  * @option
+   * @type {string}
+  * @default 'orbit-previous'
+  */
+  prevClass: 'orbit-previous',
+
+  /**
+  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  useMUI: true
+};
+
+var MenuPlugins = {
+  dropdown: {
+    cssClass: 'dropdown',
+    plugin: DropdownMenu
+  },
+  drilldown: {
+    cssClass: 'drilldown',
+    plugin: Drilldown
+  },
+  accordion: {
+    cssClass: 'accordion-menu',
+    plugin: AccordionMenu
+  }
+}; // import "foundation.util.triggers.js";
+
+/**
+ * ResponsiveMenu module.
+ * @module foundation.responsiveMenu
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ */
+
+var ResponsiveMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveMenu, _Plugin);
+
+  function ResponsiveMenu() {
+    _classCallCheck(this, ResponsiveMenu);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveMenu).apply(this, arguments));
+  }
+
+  _createClass(ResponsiveMenu, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a responsive menu.
+     * @class
+     * @name ResponsiveMenu
+     * @fires ResponsiveMenu#init
+     * @param {jQuery} element - jQuery object to make into a dropdown menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = $(element);
+      this.rules = this.$element.data('responsive-menu');
+      this.currentMq = null;
+      this.currentPlugin = null;
+      this.className = 'ResponsiveMenu'; // ie9 back compat
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
+
+
+      if (typeof this.rules === 'string') {
+        var rulesTree = {}; // Parse rules from "classes" pulled from data attribute
+
+        var rules = this.rules.split(' '); // Iterate through every rule found
+
+        for (var i = 0; i < rules.length; i++) {
+          var rule = rules[i].split('-');
+          var ruleSize = rule.length > 1 ? rule[0] : 'small';
+          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+
+          if (MenuPlugins[rulePlugin] !== null) {
+            rulesTree[ruleSize] = MenuPlugins[rulePlugin];
+          }
+        }
+
+        this.rules = rulesTree;
+      }
+
+      if (!$.isEmptyObject(this.rules)) {
+        this._checkMediaQueries();
+      } // Add data-mutate since children may need it.
+
+
+      this.$element.attr('data-mutate', this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu'));
+    }
+    /**
+     * Initializes events for the Menu.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      $(window).on('changed.zf.mediaquery', function () {
+        _this._checkMediaQueries();
+      }); // $(window).on('resize.zf.ResponsiveMenu', function() {
+      //   _this._checkMediaQueries();
+      // });
+    }
+    /**
+     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_checkMediaQueries",
+    value: function _checkMediaQueries() {
+      var matchedMq,
+          _this = this; // Iterate through each rule and find the last matching rule
+
+
+      $.each(this.rules, function (key) {
+        if (MediaQuery.atLeast(key)) {
+          matchedMq = key;
+        }
+      }); // No match? No dice
+
+      if (!matchedMq) return; // Plugin already initialized? We good
+
+      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes
+
+      $.each(MenuPlugins, function (key, value) {
+        _this.$element.removeClass(value.cssClass);
+      }); // Add the CSS class for the new plugin
+
+      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin
+
+      if (this.currentPlugin) this.currentPlugin.destroy();
+      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+    }
+    /**
+     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.currentPlugin.destroy();
+      $(window).off('.zf.ResponsiveMenu');
+    }
+  }]);
+
+  return ResponsiveMenu;
+}(Plugin);
+
+ResponsiveMenu.defaults = {};
+
+/**
+ * ResponsiveToggle module.
+ * @module foundation.responsiveToggle
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.motion
+ */
+
+var ResponsiveToggle =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveToggle, _Plugin);
+
+  function ResponsiveToggle() {
+    _classCallCheck(this, ResponsiveToggle);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveToggle).apply(this, arguments));
+  }
+
+  _createClass(ResponsiveToggle, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Tab Bar.
+     * @class
+     * @name ResponsiveToggle
+     * @fires ResponsiveToggle#init
+     * @param {jQuery} element - jQuery object to attach tab bar functionality to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = $(element);
+      this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
+      this.className = 'ResponsiveToggle'; // ie9 back compat
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the tab bar by finding the target element, toggling element, and running update().
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init();
+
+      var targetID = this.$element.data('responsive-toggle');
+
+      if (!targetID) {
+        console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');
+      }
+
+      this.$targetMenu = $("#".concat(targetID));
+      this.$toggler = this.$element.find('[data-toggle]').filter(function () {
+        var target = $(this).data('toggle');
+        return target === targetID || target === "";
+      });
+      this.options = $.extend({}, this.options, this.$targetMenu.data()); // If they were set, parse the animation classes
+
+      if (this.options.animate) {
+        var input = this.options.animate.split(' ');
+        this.animationIn = input[0];
+        this.animationOut = input[1] || null;
+      }
+
+      this._update();
+    }
+    /**
+     * Adds necessary event handlers for the tab bar to work.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+
+      this._updateMqHandler = this._update.bind(this);
+      $(window).on('changed.zf.mediaquery', this._updateMqHandler);
+      this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));
+    }
+    /**
+     * Checks the current media query to determine if the tab bar should be visible or hidden.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_update",
+    value: function _update() {
+      // Mobile
+      if (!MediaQuery.atLeast(this.options.hideFor)) {
+        this.$element.show();
+        this.$targetMenu.hide();
+      } // Desktop
+      else {
+          this.$element.hide();
+          this.$targetMenu.show();
+        }
+    }
+    /**
+     * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.
+     * @function
+     * @fires ResponsiveToggle#toggled
+     */
+
+  }, {
+    key: "toggleMenu",
+    value: function toggleMenu() {
+      var _this2 = this;
+
+      if (!MediaQuery.atLeast(this.options.hideFor)) {
+        /**
+         * Fires when the element attached to the tab bar toggles.
+         * @event ResponsiveToggle#toggled
+         */
+        if (this.options.animate) {
+          if (this.$targetMenu.is(':hidden')) {
+            Motion.animateIn(this.$targetMenu, this.animationIn, function () {
+              _this2.$element.trigger('toggled.zf.responsiveToggle');
+
+              _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
+            });
+          } else {
+            Motion.animateOut(this.$targetMenu, this.animationOut, function () {
+              _this2.$element.trigger('toggled.zf.responsiveToggle');
+            });
+          }
+        } else {
+          this.$targetMenu.toggle(0);
+          this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');
+          this.$element.trigger('toggled.zf.responsiveToggle');
+        }
+      }
+    }
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.responsiveToggle');
+      this.$toggler.off('.zf.responsiveToggle');
+      $(window).off('changed.zf.mediaquery', this._updateMqHandler);
+    }
+  }]);
+
+  return ResponsiveToggle;
+}(Plugin);
+
+ResponsiveToggle.defaults = {
+  /**
+   * The breakpoint after which the menu is always shown, and the tab bar is hidden.
+   * @option
+   * @type {string}
+   * @default 'medium'
+   */
+  hideFor: 'medium',
+
+  /**
+   * To decide if the toggle should be animated or not.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animate: false
+};
+
+/**
+ * Reveal module.
+ * @module foundation.reveal
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.motion if using animations
+ */
+
+var Reveal =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Reveal, _Plugin);
+
+  function Reveal() {
+    _classCallCheck(this, Reveal);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Reveal).apply(this, arguments));
+  }
+
+  _createClass(Reveal, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Reveal.
+     * @class
+     * @name Reveal
+     * @param {jQuery} element - jQuery object to use for the modal.
+     * @param {Object} options - optional parameters.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);
+      this.className = 'Reveal'; // ie9 back compat
+
+      this._init(); // Triggers init is idempotent, just need to make sure it is initialized
+
+
+      Triggers.init($);
+      Keyboard.register('Reveal', {
+        'ESCAPE': 'close'
+      });
+    }
+    /**
+     * Initializes the modal by adding the overlay and close buttons, (if selected).
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      MediaQuery._init();
+
+      this.id = this.$element.attr('id');
+      this.isActive = false;
+      this.cached = {
+        mq: MediaQuery.current
+      };
+      this.$anchor = $("[data-open=\"".concat(this.id, "\"]")).length ? $("[data-open=\"".concat(this.id, "\"]")) : $("[data-toggle=\"".concat(this.id, "\"]"));
+      this.$anchor.attr({
+        'aria-controls': this.id,
+        'aria-haspopup': true,
+        'tabindex': 0
+      });
+
+      if (this.options.fullScreen || this.$element.hasClass('full')) {
+        this.options.fullScreen = true;
+        this.options.overlay = false;
+      }
+
+      if (this.options.overlay && !this.$overlay) {
+        this.$overlay = this._makeOverlay(this.id);
+      }
+
+      this.$element.attr({
+        'role': 'dialog',
+        'aria-hidden': true,
+        'data-yeti-box': this.id,
+        'data-resize': this.id
+      });
+
+      if (this.$overlay) {
+        this.$element.detach().appendTo(this.$overlay);
+      } else {
+        this.$element.detach().appendTo($(this.options.appendTo));
+        this.$element.addClass('without-overlay');
+      }
+
+      this._events();
+
+      if (this.options.deepLink && window.location.hash === "#".concat(this.id)) {
+        this.onLoadListener = onLoad($(window), function () {
+          return _this2.open();
+        });
+      }
+    }
+    /**
+     * Creates an overlay div to display behind the modal.
+     * @private
+     */
+
+  }, {
+    key: "_makeOverlay",
+    value: function _makeOverlay() {
+      var additionalOverlayClasses = '';
+
+      if (this.options.additionalOverlayClasses) {
+        additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;
+      }
+
+      return $('<div></div>').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo);
+    }
+    /**
+     * Updates position of modal
+     * TODO:  Figure out if we actually need to cache these values or if it doesn't matter
+     * @private
+     */
+
+  }, {
+    key: "_updatePosition",
+    value: function _updatePosition() {
+      var width = this.$element.outerWidth();
+      var outerWidth = $(window).width();
+      var height = this.$element.outerHeight();
+      var outerHeight = $(window).height();
+      var left,
+          top = null;
+
+      if (this.options.hOffset === 'auto') {
+        left = parseInt((outerWidth - width) / 2, 10);
+      } else {
+        left = parseInt(this.options.hOffset, 10);
+      }
+
+      if (this.options.vOffset === 'auto') {
+        if (height > outerHeight) {
+          top = parseInt(Math.min(100, outerHeight / 10), 10);
+        } else {
+          top = parseInt((outerHeight - height) / 4, 10);
+        }
+      } else if (this.options.vOffset !== null) {
+        top = parseInt(this.options.vOffset, 10);
+      }
+
+      if (top !== null) {
+        this.$element.css({
+          top: top + 'px'
+        });
+      } // only worry about left if we don't have an overlay or we have a horizontal offset,
+      // otherwise we're perfectly in the middle
+
+
+      if (!this.$overlay || this.options.hOffset !== 'auto') {
+        this.$element.css({
+          left: left + 'px'
+        });
+        this.$element.css({
+          margin: '0px'
+        });
+      }
+    }
+    /**
+     * Adds event handlers for the modal.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this3 = this;
+
+      var _this = this;
+
+      this.$element.on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': function closeZfTrigger(event, $element) {
+          if (event.target === _this.$element[0] || $(event.target).parents('[data-closable]')[0] === $element) {
+            // only close reveal when it's explicitly called
+            return _this3.close.apply(_this3);
+          }
+        },
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'resizeme.zf.trigger': function resizemeZfTrigger() {
+          _this._updatePosition();
+        }
+      });
+
+      if (this.options.closeOnClick && this.options.overlay) {
+        this.$overlay.off('.zf.reveal').on('click.zf.reveal', function (e) {
+          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target) || !$.contains(document, e.target)) {
+            return;
+          }
+
+          _this.close();
+        });
+      }
+
+      if (this.options.deepLink) {
+        $(window).on("hashchange.zf.reveal:".concat(this.id), this._handleState.bind(this));
+      }
+    }
+    /**
+     * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.
+     * @private
+     */
+
+  }, {
+    key: "_handleState",
+    value: function _handleState(e) {
+      if (window.location.hash === '#' + this.id && !this.isActive) {
+        this.open();
+      } else {
+        this.close();
+      }
+    }
+    /**
+    * Disables the scroll when Reveal is shown to prevent the background from shifting
+    * @param {number} scrollTop - Scroll to visually apply, window current scroll by default
+    */
+
+  }, {
+    key: "_disableScroll",
+    value: function _disableScroll(scrollTop) {
+      scrollTop = scrollTop || $(window).scrollTop();
+
+      if ($(document).height() > $(window).height()) {
+        $("html").css("top", -scrollTop);
+      }
+    }
+    /**
+    * Reenables the scroll when Reveal closes
+    * @param {number} scrollTop - Scroll to restore, html "top" property by default (as set by `_disableScroll`)
+    */
+
+  }, {
+    key: "_enableScroll",
+    value: function _enableScroll(scrollTop) {
+      scrollTop = scrollTop || parseInt($("html").css("top"));
+
+      if ($(document).height() > $(window).height()) {
+        $("html").css("top", "");
+        $(window).scrollTop(-scrollTop);
+      }
+    }
+    /**
+     * Opens the modal controlled by `this.$anchor`, and closes all others by default.
+     * @function
+     * @fires Reveal#closeme
+     * @fires Reveal#open
+     */
+
+  }, {
+    key: "open",
+    value: function open() {
+      var _this4 = this;
+
+      // either update or replace browser history
+      var hash = "#".concat(this.id);
+
+      if (this.options.deepLink && window.location.hash !== hash) {
+        if (window.history.pushState) {
+          if (this.options.updateHistory) {
+            window.history.pushState({}, '', hash);
+          } else {
+            window.history.replaceState({}, '', hash);
+          }
+        } else {
+          window.location.hash = hash;
+        }
+      } // Remember anchor that opened it to set focus back later, have general anchors as fallback
+
+
+      this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;
+      this.isActive = true; // Make elements invisible, but remove display: none so we can get size and positioning
+
+      this.$element.css({
+        'visibility': 'hidden'
+      }).show().scrollTop(0);
+
+      if (this.options.overlay) {
+        this.$overlay.css({
+          'visibility': 'hidden'
+        }).show();
+      }
+
+      this._updatePosition();
+
+      this.$element.hide().css({
+        'visibility': ''
+      });
+
+      if (this.$overlay) {
+        this.$overlay.css({
+          'visibility': ''
+        }).hide();
+
+        if (this.$element.hasClass('fast')) {
+          this.$overlay.addClass('fast');
+        } else if (this.$element.hasClass('slow')) {
+          this.$overlay.addClass('slow');
+        }
+      }
+
+      if (!this.options.multipleOpened) {
+        /**
+         * Fires immediately before the modal opens.
+         * Closes any other modals that are currently open
+         * @event Reveal#closeme
+         */
+        this.$element.trigger('closeme.zf.reveal', this.id);
+      }
+
+      this._disableScroll();
+
+      var _this = this; // Motion UI method of reveal
+
+
+      if (this.options.animationIn) {
+        var afterAnimation = function afterAnimation() {
+          _this.$element.attr({
+            'aria-hidden': false,
+            'tabindex': -1
+          }).focus();
+
+          _this._addGlobalClasses();
+
+          Keyboard.trapFocus(_this.$element);
+        };
+
+        if (this.options.overlay) {
+          Motion.animateIn(this.$overlay, 'fade-in');
+        }
+
+        Motion.animateIn(this.$element, this.options.animationIn, function () {
+          if (_this4.$element) {
+            // protect against object having been removed
+            _this4.focusableElements = Keyboard.findFocusable(_this4.$element);
+            afterAnimation();
+          }
+        });
+      } // jQuery method of reveal
+      else {
+          if (this.options.overlay) {
+            this.$overlay.show(0);
+          }
+
+          this.$element.show(this.options.showDelay);
+        } // handle accessibility
+
+
+      this.$element.attr({
+        'aria-hidden': false,
+        'tabindex': -1
+      }).focus();
+      Keyboard.trapFocus(this.$element);
+
+      this._addGlobalClasses();
+
+      this._addGlobalListeners();
+      /**
+       * Fires when the modal has successfully opened.
+       * @event Reveal#open
+       */
+
+
+      this.$element.trigger('open.zf.reveal');
+    }
+    /**
+     * Adds classes and listeners on document required by open modals.
+     *
+     * The following classes are added and updated:
+     * - `.is-reveal-open` - Prevents the scroll on document
+     * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the
+     *                       scroll was not disabled. This prevent a "shift" of the page content due
+     *                       the scrollbar disappearing when the modal opens.
+     *
+     * @private
+     */
+
+  }, {
+    key: "_addGlobalClasses",
+    value: function _addGlobalClasses() {
+      var updateScrollbarClass = function updateScrollbarClass() {
+        $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));
+      };
+
+      this.$element.on('resizeme.zf.trigger.revealScrollbarListener', function () {
+        return updateScrollbarClass();
+      });
+      updateScrollbarClass();
+      $('html').addClass('is-reveal-open');
+    }
+    /**
+     * Removes classes and listeners on document that were required by open modals.
+     * @private
+     */
+
+  }, {
+    key: "_removeGlobalClasses",
+    value: function _removeGlobalClasses() {
+      this.$element.off('resizeme.zf.trigger.revealScrollbarListener');
+      $('html').removeClass('is-reveal-open');
+      $('html').removeClass('zf-has-scroll');
+    }
+    /**
+     * Adds extra event handlers for the body and window if necessary.
+     * @private
+     */
+
+  }, {
+    key: "_addGlobalListeners",
+    value: function _addGlobalListeners() {
+      var _this = this;
+
+      if (!this.$element) {
+        return;
+      } // If we're in the middle of cleanup, don't freak out
+
+
+      this.focusableElements = Keyboard.findFocusable(this.$element);
+
+      if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {
+        $('body').on('click.zf.reveal', function (e) {
+          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target) || !$.contains(document, e.target)) {
+            return;
+          }
+
+          _this.close();
+        });
+      }
+
+      if (this.options.closeOnEsc) {
+        $(window).on('keydown.zf.reveal', function (e) {
+          Keyboard.handleKey(e, 'Reveal', {
+            close: function close() {
+              if (_this.options.closeOnEsc) {
+                _this.close();
+              }
+            }
+          });
+        });
+      }
+    }
+    /**
+     * Closes the modal.
+     * @function
+     * @fires Reveal#closed
+     */
+
+  }, {
+    key: "close",
+    value: function close() {
+      if (!this.isActive || !this.$element.is(':visible')) {
+        return false;
+      }
+
+      var _this = this; // Motion UI method of hiding
+
+
+      if (this.options.animationOut) {
+        if (this.options.overlay) {
+          Motion.animateOut(this.$overlay, 'fade-out');
+        }
+
+        Motion.animateOut(this.$element, this.options.animationOut, finishUp);
+      } // jQuery method of hiding
+      else {
+          this.$element.hide(this.options.hideDelay);
+
+          if (this.options.overlay) {
+            this.$overlay.hide(0, finishUp);
+          } else {
+            finishUp();
+          }
+        } // Conditionals to remove extra event listeners added on open
+
+
+      if (this.options.closeOnEsc) {
+        $(window).off('keydown.zf.reveal');
+      }
+
+      if (!this.options.overlay && this.options.closeOnClick) {
+        $('body').off('click.zf.reveal');
+      }
+
+      this.$element.off('keydown.zf.reveal');
+
+      function finishUp() {
+        // Get the current top before the modal is closed and restore the scroll after.
+        // TODO: use component properties instead of HTML properties
+        // See https://github.com/zurb/foundation-sites/pull/10786
+        var scrollTop = parseInt($("html").css("top"));
+
+        if ($('.reveal:visible').length === 0) {
+          _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
+
+        }
+
+        Keyboard.releaseFocus(_this.$element);
+
+        _this.$element.attr('aria-hidden', true);
+
+        _this._enableScroll(scrollTop);
+        /**
+        * Fires when the modal is done closing.
+        * @event Reveal#closed
+        */
+
+
+        _this.$element.trigger('closed.zf.reveal');
+      }
+      /**
+      * Resets the modal content
+      * This prevents a running video to keep going in the background
+      */
+
+
+      if (this.options.resetOnClose) {
+        this.$element.html(this.$element.html());
+      }
+
+      this.isActive = false; // If deepLink and we did not switched to an other modal...
+
+      if (_this.options.deepLink && window.location.hash === "#".concat(this.id)) {
+        // Remove the history hash
+        if (window.history.replaceState) {
+          var urlWithoutHash = window.location.pathname + window.location.search;
+
+          if (this.options.updateHistory) {
+            window.history.pushState({}, '', urlWithoutHash); // remove the hash
+          } else {
+            window.history.replaceState('', document.title, urlWithoutHash);
+          }
+        } else {
+          window.location.hash = '';
+        }
+      }
+
+      this.$activeAnchor.focus();
+    }
+    /**
+     * Toggles the open/closed state of a modal.
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      if (this.isActive) {
+        this.close();
+      } else {
+        this.open();
+      }
+    }
+  }, {
+    key: "_destroy",
+
+    /**
+     * Destroys an instance of a modal.
+     * @function
+     */
+    value: function _destroy() {
+      if (this.options.overlay) {
+        this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()
+
+        this.$overlay.hide().off().remove();
+      }
+
+      this.$element.hide().off();
+      this.$anchor.off('.zf');
+      $(window).off(".zf.reveal:".concat(this.id));
+      if (this.onLoadListener) $(window).off(this.onLoadListener);
+
+      if ($('.reveal:visible').length === 0) {
+        this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
+
+      }
+    }
+  }]);
+
+  return Reveal;
+}(Plugin);
+
+Reveal.defaults = {
+  /**
+   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  animationIn: '',
+
+  /**
+   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  animationOut: '',
+
+  /**
+   * Time, in ms, to delay the opening of a modal after a click if no animation used.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  showDelay: 0,
+
+  /**
+   * Time, in ms, to delay the closing of a modal after a click if no animation used.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hideDelay: 0,
+
+  /**
+   * Allows a click on the body/overlay to close the modal.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Allows the modal to close if the user presses the `ESCAPE` key.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnEsc: true,
+
+  /**
+   * If true, allows multiple modals to be displayed at once.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  multipleOpened: false,
+
+  /**
+   * Distance, in pixels, the modal should push down from the top of the screen.
+   * @option
+   * @type {number|string}
+   * @default auto
+   */
+  vOffset: 'auto',
+
+  /**
+   * Distance, in pixels, the modal should push in from the side of the screen.
+   * @option
+   * @type {number|string}
+   * @default auto
+   */
+  hOffset: 'auto',
+
+  /**
+   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  fullScreen: false,
+
+  /**
+   * Allows the modal to generate an overlay div, which will cover the view when modal opens.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  overlay: true,
+
+  /**
+   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  resetOnClose: false,
+
+  /**
+   * Link the location hash to the modal.
+   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+
+  /**
+   * If `deepLink` is enabled, update the browser history with the open modal
+   * @option
+   * @default false
+   */
+  updateHistory: false,
+
+  /**
+  * Allows the modal to append to custom div.
+  * @option
+  * @type {string}
+  * @default "body"
+  */
+  appendTo: "body",
+
+  /**
+   * Allows adding additional class names to the reveal overlay.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  additionalOverlayClasses: ''
+};
+
+/**
+ * Slider module.
+ * @module foundation.slider
+ * @requires foundation.util.motion
+ * @requires foundation.util.triggers
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.touch
+ */
+
+var Slider =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Slider, _Plugin);
+
+  function Slider() {
+    _classCallCheck(this, Slider);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Slider).apply(this, arguments));
+  }
+
+  _createClass(Slider, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a slider control.
+     * @class
+     * @name Slider
+     * @param {jQuery} element - jQuery object to make into a slider control.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Slider.defaults, this.$element.data(), options);
+      this.className = 'Slider'; // ie9 back compat
+      // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.
+
+      Touch.init($);
+      Triggers.init($);
+
+      this._init();
+
+      Keyboard.register('Slider', {
+        'ltr': {
+          'ARROW_RIGHT': 'increase',
+          'ARROW_UP': 'increase',
+          'ARROW_DOWN': 'decrease',
+          'ARROW_LEFT': 'decrease',
+          'SHIFT_ARROW_RIGHT': 'increase_fast',
+          'SHIFT_ARROW_UP': 'increase_fast',
+          'SHIFT_ARROW_DOWN': 'decrease_fast',
+          'SHIFT_ARROW_LEFT': 'decrease_fast',
+          'HOME': 'min',
+          'END': 'max'
+        },
+        'rtl': {
+          'ARROW_LEFT': 'increase',
+          'ARROW_RIGHT': 'decrease',
+          'SHIFT_ARROW_LEFT': 'increase_fast',
+          'SHIFT_ARROW_RIGHT': 'decrease_fast'
+        }
+      });
+    }
+    /**
+     * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      this.inputs = this.$element.find('input');
+      this.handles = this.$element.find('[data-slider-handle]');
+      this.$handle = this.handles.eq(0);
+      this.$input = this.inputs.length ? this.inputs.eq(0) : $("#".concat(this.$handle.attr('aria-controls')));
+      this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);
+
+      if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {
+        this.options.disabled = true;
+        this.$element.addClass(this.options.disabledClass);
+      }
+
+      if (!this.inputs.length) {
+        this.inputs = $().add(this.$input);
+        this.options.binding = true;
+      }
+
+      this._setInitAttr(0);
+
+      if (this.handles[1]) {
+        this.options.doubleSided = true;
+        this.$handle2 = this.handles.eq(1);
+        this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $("#".concat(this.$handle2.attr('aria-controls')));
+
+        if (!this.inputs[1]) {
+          this.inputs = this.inputs.add(this.$input2);
+        }
+
+        this._setInitAttr(1);
+      } // Set handle positions
+
+
+      this.setHandles();
+
+      this._events();
+    }
+  }, {
+    key: "setHandles",
+    value: function setHandles() {
+      var _this2 = this;
+
+      if (this.handles[1]) {
+        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, function () {
+          _this2._setHandlePos(_this2.$handle2, _this2.inputs.eq(1).val(), true);
+        });
+      } else {
+        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);
+      }
+    }
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      this.setHandles();
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)
+    */
+
+  }, {
+    key: "_pctOfBar",
+    value: function _pctOfBar(value) {
+      var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start);
+
+      switch (this.options.positionValueFunction) {
+        case "pow":
+          pctOfBar = this._logTransform(pctOfBar);
+          break;
+
+        case "log":
+          pctOfBar = this._powTransform(pctOfBar);
+          break;
+      }
+
+      return pctOfBar.toFixed(2);
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value
+    */
+
+  }, {
+    key: "_value",
+    value: function _value(pctOfBar) {
+      switch (this.options.positionValueFunction) {
+        case "pow":
+          pctOfBar = this._powTransform(pctOfBar);
+          break;
+
+        case "log":
+          pctOfBar = this._logTransform(pctOfBar);
+          break;
+      }
+
+      var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);
+      return value;
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function
+    */
+
+  }, {
+    key: "_logTransform",
+    value: function _logTransform(value) {
+      return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1);
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function
+    */
+
+  }, {
+    key: "_powTransform",
+    value: function _powTransform(value) {
+      return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1);
+    }
+    /**
+     * Sets the position of the selected handle and fill bar.
+     * @function
+     * @private
+     * @param {jQuery} $hndl - the selected handle to move.
+     * @param {Number} location - floating point between the start and end values of the slider bar.
+     * @param {Function} cb - callback function to fire on completion.
+     * @fires Slider#moved
+     * @fires Slider#changed
+     */
+
+  }, {
+    key: "_setHandlePos",
+    value: function _setHandlePos($hndl, location, noInvert, cb) {
+      // don't move if the slider has been disabled since its initialization
+      if (this.$element.hasClass(this.options.disabledClass)) {
+        return;
+      } //might need to alter that slightly for bars that will have odd number selections.
+
+
+      location = parseFloat(location); //on input change events, convert string to number...grumble.
+      // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max
+
+      if (location < this.options.start) {
+        location = this.options.start;
+      } else if (location > this.options.end) {
+        location = this.options.end;
+      }
+
+      var isDbl = this.options.doubleSided; //this is for single-handled vertical sliders, it adjusts the value to account for the slider being "upside-down"
+      //for click and drag events, it's weird due to the scale(-1, 1) css property
+
+      if (this.options.vertical && !noInvert) {
+        location = this.options.end - location;
+      }
+
+      if (isDbl) {
+        //this block is to prevent 2 handles from crossing eachother. Could/should be improved.
+        if (this.handles.index($hndl) === 0) {
+          var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));
+          location = location >= h2Val ? h2Val - this.options.step : location;
+        } else {
+          var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));
+          location = location <= h1Val ? h1Val + this.options.step : location;
+        }
+      }
+
+      var _this = this,
+          vert = this.options.vertical,
+          hOrW = vert ? 'height' : 'width',
+          lOrT = vert ? 'top' : 'left',
+          handleDim = $hndl[0].getBoundingClientRect()[hOrW],
+          elemDim = this.$element[0].getBoundingClientRect()[hOrW],
+          //percentage of bar min/max value based on click or drag point
+      pctOfBar = this._pctOfBar(location),
+          //number of actual pixels to shift the handle, based on the percentage obtained above
+      pxToMove = (elemDim - handleDim) * pctOfBar,
+          //percentage of bar to shift the handle
+      movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value
+
+
+      location = parseFloat(location.toFixed(this.options.decimal)); // declare empty object for css adjustments, only used with 2 handled-sliders
+
+      var css = {};
+
+      this._setValues($hndl, location); // TODO update to calculate based on values set to respective inputs??
+
+
+      if (isDbl) {
+        var isLeftHndl = this.handles.index($hndl) === 0,
+            //empty variable, will be used for min-height/width for fill bar
+        dim,
+            //percentage w/h of the handle compared to the slider bar
+        handlePct = ~~(percent(handleDim, elemDim) * 100); //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar
+
+        if (isLeftHndl) {
+          //left or top percentage value to apply to the fill bar.
+          css[lOrT] = "".concat(movement, "%"); //calculate the new min-height/width for the fill bar.
+
+          dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider
+          //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.
+
+          if (cb && typeof cb === 'function') {
+            cb();
+          } //this is only needed for the initialization of 2 handled sliders
+
+        } else {
+          //just caching the value of the left/bottom handle's left/top property
+          var handlePos = parseFloat(this.$handle[0].style[lOrT]); //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0
+          //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself
+
+          dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct;
+        } // assign the min-height/width to our css object
+
+
+        css["min-".concat(hOrW)] = "".concat(dim, "%");
+      }
+
+      this.$element.one('finished.zf.animate', function () {
+        /**
+         * Fires when the handle is done moving.
+         * @event Slider#moved
+         */
+        _this.$element.trigger('moved.zf.slider', [$hndl]);
+      }); //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.
+
+      var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime;
+      Move(moveTime, $hndl, function () {
+        // adjusting the left/top property of the handle, based on the percentage calculated above
+        // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,
+        // fall back to next best guess.
+        if (isNaN(movement)) {
+          $hndl.css(lOrT, "".concat(pctOfBar * 100, "%"));
+        } else {
+          $hndl.css(lOrT, "".concat(movement, "%"));
+        }
+
+        if (!_this.options.doubleSided) {
+          //if single-handled, a simple method to expand the fill bar
+          _this.$fill.css(hOrW, "".concat(pctOfBar * 100, "%"));
+        } else {
+          //otherwise, use the css object we created above
+          _this.$fill.css(css);
+        }
+      });
+      /**
+       * Fires when the value has not been change for a given time.
+       * @event Slider#changed
+       */
+
+      clearTimeout(_this.timeout);
+      _this.timeout = setTimeout(function () {
+        _this.$element.trigger('changed.zf.slider', [$hndl]);
+      }, _this.options.changedDelay);
+    }
+    /**
+     * Sets the initial attribute for the slider element.
+     * @function
+     * @private
+     * @param {Number} idx - index of the current handle/input to use.
+     */
+
+  }, {
+    key: "_setInitAttr",
+    value: function _setInitAttr(idx) {
+      var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd;
+      var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');
+      this.inputs.eq(idx).attr({
+        'id': id,
+        'max': this.options.end,
+        'min': this.options.start,
+        'step': this.options.step
+      });
+      this.inputs.eq(idx).val(initVal);
+      this.handles.eq(idx).attr({
+        'role': 'slider',
+        'aria-controls': id,
+        'aria-valuemax': this.options.end,
+        'aria-valuemin': this.options.start,
+        'aria-valuenow': initVal,
+        'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',
+        'tabindex': 0
+      });
+    }
+    /**
+     * Sets the input and `aria-valuenow` values for the slider element.
+     * @function
+     * @private
+     * @param {jQuery} $handle - the currently selected handle.
+     * @param {Number} val - floating point of the new value.
+     */
+
+  }, {
+    key: "_setValues",
+    value: function _setValues($handle, val) {
+      var idx = this.options.doubleSided ? this.handles.index($handle) : 0;
+      this.inputs.eq(idx).val(val);
+      $handle.attr('aria-valuenow', val);
+    }
+    /**
+     * Handles events on the slider element.
+     * Calculates the new location of the current handle.
+     * If there are two handles and the bar was clicked, it determines which handle to move.
+     * @function
+     * @private
+     * @param {Object} e - the `event` object passed from the listener.
+     * @param {jQuery} $handle - the current handle to calculate for, if selected.
+     * @param {Number} val - floating point number for the new value of the slider.
+     * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.
+     */
+
+  }, {
+    key: "_handleEvent",
+    value: function _handleEvent(e, $handle, val) {
+      var value, hasVal;
+
+      if (!val) {
+        //click or drag events
+        e.preventDefault();
+
+        var _this = this,
+            vertical = this.options.vertical,
+            param = vertical ? 'height' : 'width',
+            direction = vertical ? 'top' : 'left',
+            eventOffset = vertical ? e.pageY : e.pageX,
+            halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,
+            barDim = this.$element[0].getBoundingClientRect()[param],
+            windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();
+
+        var elemOffset = this.$element.offset()[direction]; // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...
+        // best way to guess this is simulated is if clientY == pageY
+
+        if (e.clientY === e.pageY) {
+          eventOffset = eventOffset + windowScroll;
+        }
+
+        var eventFromBar = eventOffset - elemOffset;
+        var barXY;
+
+        if (eventFromBar < 0) {
+          barXY = 0;
+        } else if (eventFromBar > barDim) {
+          barXY = barDim;
+        } else {
+          barXY = eventFromBar;
+        }
+
+        var offsetPct = percent(barXY, barDim);
+        value = this._value(offsetPct); // turn everything around for RTL, yay math!
+
+        if (rtl() && !this.options.vertical) {
+          value = this.options.end - value;
+        }
+
+        value = _this._adjustValue(null, value); //boolean flag for the setHandlePos fn, specifically for vertical sliders
+
+        hasVal = false;
+
+        if (!$handle) {
+          //figure out which handle it is, pass it to the next function.
+          var firstHndlPos = absPosition(this.$handle, direction, barXY, param),
+              secndHndlPos = absPosition(this.$handle2, direction, barXY, param);
+          $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;
+        }
+      } else {
+        //change event on input
+        value = this._adjustValue(null, val);
+        hasVal = true;
+      }
+
+      this._setHandlePos($handle, value, hasVal);
+    }
+    /**
+     * Adjustes value for handle in regard to step value. returns adjusted value
+     * @function
+     * @private
+     * @param {jQuery} $handle - the selected handle.
+     * @param {Number} value - value to adjust. used if $handle is falsy
+     */
+
+  }, {
+    key: "_adjustValue",
+    value: function _adjustValue($handle, value) {
+      var val,
+          step = this.options.step,
+          div = parseFloat(step / 2),
+          left,
+          prev_val,
+          next_val;
+
+      if (!!$handle) {
+        val = parseFloat($handle.attr('aria-valuenow'));
+      } else {
+        val = value;
+      }
+
+      if (val >= 0) {
+        left = val % step;
+      } else {
+        left = step + val % step;
+      }
+
+      prev_val = val - left;
+      next_val = prev_val + step;
+
+      if (left === 0) {
+        return val;
+      }
+
+      val = val >= prev_val + div ? next_val : prev_val;
+      return val;
+    }
+    /**
+     * Adds event listeners to the slider elements.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._eventsForHandle(this.$handle);
+
+      if (this.handles[1]) {
+        this._eventsForHandle(this.$handle2);
+      }
+    }
+    /**
+     * Adds event listeners a particular handle
+     * @function
+     * @private
+     * @param {jQuery} $handle - the current handle to apply listeners to.
+     */
+
+  }, {
+    key: "_eventsForHandle",
+    value: function _eventsForHandle($handle) {
+      var _this = this,
+          curHandle;
+
+      var handleChangeEvent = function handleChangeEvent(e) {
+        var idx = _this.inputs.index($(this));
+
+        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());
+      }; // IE only triggers the change event when the input loses focus which strictly follows the HTML specification
+      // listen for the enter key and trigger a change
+      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events
+
+
+      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {
+        if (e.keyCode == 13) handleChangeEvent.call(this, e);
+      });
+      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);
+
+      if (this.options.clickSelect) {
+        this.$element.off('click.zf.slider').on('click.zf.slider', function (e) {
+          if (_this.$element.data('dragging')) {
+            return false;
+          }
+
+          if (!$(e.target).is('[data-slider-handle]')) {
+            if (_this.options.doubleSided) {
+              _this._handleEvent(e);
+            } else {
+              _this._handleEvent(e, _this.$handle);
+            }
+          }
+        });
+      }
+
+      if (this.options.draggable) {
+        this.handles.addTouch();
+        var $body = $('body');
+        $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) {
+          $handle.addClass('is-dragging');
+
+          _this.$fill.addClass('is-dragging'); //
+
+
+          _this.$element.data('dragging', true);
+
+          curHandle = $(e.currentTarget);
+          $body.on('mousemove.zf.slider', function (e) {
+            e.preventDefault();
+
+            _this._handleEvent(e, curHandle);
+          }).on('mouseup.zf.slider', function (e) {
+            _this._handleEvent(e, curHandle);
+
+            $handle.removeClass('is-dragging');
+
+            _this.$fill.removeClass('is-dragging');
+
+            _this.$element.data('dragging', false);
+
+            $body.off('mousemove.zf.slider mouseup.zf.slider');
+          });
+        }) // prevent events triggered by touch
+        .on('selectstart.zf.slider touchmove.zf.slider', function (e) {
+          e.preventDefault();
+        });
+      }
+
+      $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) {
+        var _$handle = $(this),
+            idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,
+            oldValue = parseFloat(_this.inputs.eq(idx).val()),
+            newValue; // handle keyboard event with keyboard util
+
+
+        Keyboard.handleKey(e, 'Slider', {
+          decrease: function decrease() {
+            newValue = oldValue - _this.options.step;
+          },
+          increase: function increase() {
+            newValue = oldValue + _this.options.step;
+          },
+          decrease_fast: function decrease_fast() {
+            newValue = oldValue - _this.options.step * 10;
+          },
+          increase_fast: function increase_fast() {
+            newValue = oldValue + _this.options.step * 10;
+          },
+          min: function min() {
+            newValue = _this.options.start;
+          },
+          max: function max() {
+            newValue = _this.options.end;
+          },
+          handled: function handled() {
+            // only set handle pos when event was handled specially
+            e.preventDefault();
+
+            _this._setHandlePos(_$handle, newValue, true);
+          }
+        });
+        /*if (newValue) { // if pressed key has special function, update value
+          e.preventDefault();
+          _this._setHandlePos(_$handle, newValue);
+        }*/
+      });
+    }
+    /**
+     * Destroys the slider plugin.
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.handles.off('.zf.slider');
+      this.inputs.off('.zf.slider');
+      this.$element.off('.zf.slider');
+      clearTimeout(this.timeout);
+    }
+  }]);
+
+  return Slider;
+}(Plugin);
+
+Slider.defaults = {
+  /**
+   * Minimum value for the slider scale.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  start: 0,
+
+  /**
+   * Maximum value for the slider scale.
+   * @option
+   * @type {number}
+   * @default 100
+   */
+  end: 100,
+
+  /**
+   * Minimum value change per change event.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  step: 1,
+
+  /**
+   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  initialStart: 0,
+
+  /**
+   * Value at which the right handle/second input should be set to on initialization.
+   * @option
+   * @type {number}
+   * @default 100
+   */
+  initialEnd: 100,
+
+  /**
+   * Allows the input to be located outside the container and visible. Set to by the JS
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  binding: false,
+
+  /**
+   * Allows the user to click/tap on the slider bar to select a value.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  clickSelect: true,
+
+  /**
+   * Set to true and use the `vertical` class to change alignment to vertical.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  vertical: false,
+
+  /**
+   * Allows the user to drag the slider handle(s) to select a value.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  draggable: true,
+
+  /**
+   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disabled: false,
+
+  /**
+   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  doubleSided: false,
+
+  /**
+   * Potential future feature.
+   */
+  // steps: 100,
+
+  /**
+   * Number of decimal places the plugin should go to for floating point precision.
+   * @option
+   * @type {number}
+   * @default 2
+   */
+  decimal: 2,
+
+  /**
+   * Time delay for dragged elements.
+   */
+  // dragDelay: 0,
+
+  /**
+   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.
+   * @option
+   * @type {number}
+   * @default 200
+   */
+  moveTime: 200,
+  //update this if changing the transition time in the sass
+
+  /**
+   * Class applied to disabled sliders.
+   * @option
+   * @type {string}
+   * @default 'disabled'
+   */
+  disabledClass: 'disabled',
+
+  /**
+   * Will invert the default layout for a vertical<span data-tooltip title="who would do this???"> </span>slider.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  invertVertical: false,
+
+  /**
+   * Milliseconds before the `changed.zf-slider` event is triggered after value change.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  changedDelay: 500,
+
+  /**
+  * Basevalue for non-linear sliders
+  * @option
+  * @type {number}
+  * @default 5
+  */
+  nonLinearBase: 5,
+
+  /**
+  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.
+  * @option
+  * @type {string}
+  * @default 'linear'
+  */
+  positionValueFunction: 'linear'
+};
+
+function percent(frac, num) {
+  return frac / num;
+}
+
+function absPosition($handle, dir, clickPos, param) {
+  return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos);
+}
+
+function baseLog(base, value) {
+  return Math.log(value) / Math.log(base);
+}
+
+/**
+ * Sticky module.
+ * @module foundation.sticky
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ */
+
+var Sticky =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Sticky, _Plugin);
+
+  function Sticky() {
+    _classCallCheck(this, Sticky);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments));
+  }
+
+  _createClass(Sticky, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a sticky thing.
+     * @class
+     * @name Sticky
+     * @param {jQuery} element - jQuery object to make sticky.
+     * @param {Object} options - options object passed when creating the element programmatically.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);
+      this.className = 'Sticky'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      this._init();
+    }
+    /**
+     * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init();
+
+      var $parent = this.$element.parent('[data-sticky-container]'),
+          id = this.$element[0].id || GetYoDigits(6, 'sticky'),
+          _this = this;
+
+      if ($parent.length) {
+        this.$container = $parent;
+      } else {
+        this.wasWrapped = true;
+        this.$element.wrap(this.options.container);
+        this.$container = this.$element.parent();
+      }
+
+      this.$container.addClass(this.options.containerClass);
+      this.$element.addClass(this.options.stickyClass).attr({
+        'data-resize': id,
+        'data-mutate': id
+      });
+
+      if (this.options.anchor !== '') {
+        $('#' + _this.options.anchor).attr({
+          'data-mutate': id
+        });
+      }
+
+      this.scrollCount = this.options.checkEvery;
+      this.isStuck = false;
+      this.onLoadListener = onLoad($(window), function () {
+        //We calculate the container height to have correct values for anchor points offset calculation.
+        _this.containerHeight = _this.$element.css("display") == "none" ? 0 : _this.$element[0].getBoundingClientRect().height;
+
+        _this.$container.css('height', _this.containerHeight);
+
+        _this.elemHeight = _this.containerHeight;
+
+        if (_this.options.anchor !== '') {
+          _this.$anchor = $('#' + _this.options.anchor);
+        } else {
+          _this._parsePoints();
+        }
+
+        _this._setSizes(function () {
+          var scroll = window.pageYOffset;
+
+          _this._calc(false, scroll); //Unstick the element will ensure that proper classes are set.
+
+
+          if (!_this.isStuck) {
+            _this._removeSticky(scroll >= _this.topPoint ? false : true);
+          }
+        });
+
+        _this._events(id.split('-').reverse().join('-'));
+      });
+    }
+    /**
+     * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_parsePoints",
+    value: function _parsePoints() {
+      var top = this.options.topAnchor == "" ? 1 : this.options.topAnchor,
+          btm = this.options.btmAnchor == "" ? document.documentElement.scrollHeight : this.options.btmAnchor,
+          pts = [top, btm],
+          breaks = {};
+
+      for (var i = 0, len = pts.length; i < len && pts[i]; i++) {
+        var pt;
+
+        if (typeof pts[i] === 'number') {
+          pt = pts[i];
+        } else {
+          var place = pts[i].split(':'),
+              anchor = $("#".concat(place[0]));
+          pt = anchor.offset().top;
+
+          if (place[1] && place[1].toLowerCase() === 'bottom') {
+            pt += anchor[0].getBoundingClientRect().height;
+          }
+        }
+
+        breaks[i] = pt;
+      }
+
+      this.points = breaks;
+      return;
+    }
+    /**
+     * Adds event handlers for the scrolling element.
+     * @private
+     * @param {String} id - pseudo-random id for unique scroll event listener.
+     */
+
+  }, {
+    key: "_events",
+    value: function _events(id) {
+      var _this = this,
+          scrollListener = this.scrollListener = "scroll.zf.".concat(id);
+
+      if (this.isOn) {
+        return;
+      }
+
+      if (this.canStick) {
+        this.isOn = true;
+        $(window).off(scrollListener).on(scrollListener, function (e) {
+          if (_this.scrollCount === 0) {
+            _this.scrollCount = _this.options.checkEvery;
+
+            _this._setSizes(function () {
+              _this._calc(false, window.pageYOffset);
+            });
+          } else {
+            _this.scrollCount--;
+
+            _this._calc(false, window.pageYOffset);
+          }
+        });
+      }
+
+      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) {
+        _this._eventsHandler(id);
+      });
+      this.$element.on('mutateme.zf.trigger', function (e, el) {
+        _this._eventsHandler(id);
+      });
+
+      if (this.$anchor) {
+        this.$anchor.on('mutateme.zf.trigger', function (e, el) {
+          _this._eventsHandler(id);
+        });
+      }
+    }
+    /**
+     * Handler for events.
+     * @private
+     * @param {String} id - pseudo-random id for unique scroll event listener.
+     */
+
+  }, {
+    key: "_eventsHandler",
+    value: function _eventsHandler(id) {
+      var _this = this,
+          scrollListener = this.scrollListener = "scroll.zf.".concat(id);
+
+      _this._setSizes(function () {
+        _this._calc(false);
+
+        if (_this.canStick) {
+          if (!_this.isOn) {
+            _this._events(id);
+          }
+        } else if (_this.isOn) {
+          _this._pauseListeners(scrollListener);
+        }
+      });
+    }
+    /**
+     * Removes event handlers for scroll and change events on anchor.
+     * @fires Sticky#pause
+     * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`
+     */
+
+  }, {
+    key: "_pauseListeners",
+    value: function _pauseListeners(scrollListener) {
+      this.isOn = false;
+      $(window).off(scrollListener);
+      /**
+       * Fires when the plugin is paused due to resize event shrinking the view.
+       * @event Sticky#pause
+       * @private
+       */
+
+      this.$element.trigger('pause.zf.sticky');
+    }
+    /**
+     * Called on every `scroll` event and on `_init`
+     * fires functions based on booleans and cached values
+     * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.
+     * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.
+     */
+
+  }, {
+    key: "_calc",
+    value: function _calc(checkSizes, scroll) {
+      if (checkSizes) {
+        this._setSizes();
+      }
+
+      if (!this.canStick) {
+        if (this.isStuck) {
+          this._removeSticky(true);
+        }
+
+        return false;
+      }
+
+      if (!scroll) {
+        scroll = window.pageYOffset;
+      }
+
+      if (scroll >= this.topPoint) {
+        if (scroll <= this.bottomPoint) {
+          if (!this.isStuck) {
+            this._setSticky();
+          }
+        } else {
+          if (this.isStuck) {
+            this._removeSticky(false);
+          }
+        }
+      } else {
+        if (this.isStuck) {
+          this._removeSticky(true);
+        }
+      }
+    }
+    /**
+     * Causes the $element to become stuck.
+     * Adds `position: fixed;`, and helper classes.
+     * @fires Sticky#stuckto
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_setSticky",
+    value: function _setSticky() {
+      var _this = this,
+          stickTo = this.options.stickTo,
+          mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',
+          notStuckTo = stickTo === 'top' ? 'bottom' : 'top',
+          css = {};
+
+      css[mrgn] = "".concat(this.options[mrgn], "em");
+      css[stickTo] = 0;
+      css[notStuckTo] = 'auto';
+      this.isStuck = true;
+      this.$element.removeClass("is-anchored is-at-".concat(notStuckTo)).addClass("is-stuck is-at-".concat(stickTo)).css(css)
+      /**
+       * Fires when the $element has become `position: fixed;`
+       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`
+       * @event Sticky#stuckto
+       */
+      .trigger("sticky.zf.stuckto:".concat(stickTo));
+      this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd", function () {
+        _this._setSizes();
+      });
+    }
+    /**
+     * Causes the $element to become unstuck.
+     * Removes `position: fixed;`, and helper classes.
+     * Adds other helper classes.
+     * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.
+     * @fires Sticky#unstuckfrom
+     * @private
+     */
+
+  }, {
+    key: "_removeSticky",
+    value: function _removeSticky(isTop) {
+      var stickTo = this.options.stickTo,
+          stickToTop = stickTo === 'top',
+          css = {},
+          anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,
+          mrgn = stickToTop ? 'marginTop' : 'marginBottom',
+          topOrBottom = isTop ? 'top' : 'bottom';
+      css[mrgn] = 0;
+      css['bottom'] = 'auto';
+
+      if (isTop) {
+        css['top'] = 0;
+      } else {
+        css['top'] = anchorPt;
+      }
+
+      this.isStuck = false;
+      this.$element.removeClass("is-stuck is-at-".concat(stickTo)).addClass("is-anchored is-at-".concat(topOrBottom)).css(css)
+      /**
+       * Fires when the $element has become anchored.
+       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`
+       * @event Sticky#unstuckfrom
+       */
+      .trigger("sticky.zf.unstuckfrom:".concat(topOrBottom));
+    }
+    /**
+     * Sets the $element and $container sizes for plugin.
+     * Calls `_setBreakPoints`.
+     * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.
+     * @private
+     */
+
+  }, {
+    key: "_setSizes",
+    value: function _setSizes(cb) {
+      this.canStick = MediaQuery.is(this.options.stickyOn);
+
+      if (!this.canStick) {
+        if (cb && typeof cb === 'function') {
+          cb();
+        }
+      }
+
+      var newElemWidth = this.$container[0].getBoundingClientRect().width,
+          comp = window.getComputedStyle(this.$container[0]),
+          pdngl = parseInt(comp['padding-left'], 10),
+          pdngr = parseInt(comp['padding-right'], 10);
+
+      if (this.$anchor && this.$anchor.length) {
+        this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;
+      } else {
+        this._parsePoints();
+      }
+
+      this.$element.css({
+        'max-width': "".concat(newElemWidth - pdngl - pdngr, "px")
+      });
+      var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;
+
+      if (this.$element.css("display") == "none") {
+        newContainerHeight = 0;
+      }
+
+      this.containerHeight = newContainerHeight;
+      this.$container.css({
+        height: newContainerHeight
+      });
+      this.elemHeight = newContainerHeight;
+
+      if (!this.isStuck) {
+        if (this.$element.hasClass('is-at-bottom')) {
+          var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;
+          this.$element.css('top', anchorPt);
+        }
+      }
+
+      this._setBreakPoints(newContainerHeight, function () {
+        if (cb && typeof cb === 'function') {
+          cb();
+        }
+      });
+    }
+    /**
+     * Sets the upper and lower breakpoints for the element to become sticky/unsticky.
+     * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.
+     * @param {Function} cb - optional callback function to be called on completion.
+     * @private
+     */
+
+  }, {
+    key: "_setBreakPoints",
+    value: function _setBreakPoints(elemHeight, cb) {
+      if (!this.canStick) {
+        if (cb && typeof cb === 'function') {
+          cb();
+        } else {
+          return false;
+        }
+      }
+
+      var mTop = emCalc(this.options.marginTop),
+          mBtm = emCalc(this.options.marginBottom),
+          topPoint = this.points ? this.points[0] : this.$anchor.offset().top,
+          bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,
+          // topPoint = this.$anchor.offset().top || this.points[0],
+      // bottomPoint = topPoint + this.anchorHeight || this.points[1],
+      winHeight = window.innerHeight;
+
+      if (this.options.stickTo === 'top') {
+        topPoint -= mTop;
+        bottomPoint -= elemHeight + mTop;
+      } else if (this.options.stickTo === 'bottom') {
+        topPoint -= winHeight - (elemHeight + mBtm);
+        bottomPoint -= winHeight - mBtm;
+      }
+
+      this.topPoint = topPoint;
+      this.bottomPoint = bottomPoint;
+
+      if (cb && typeof cb === 'function') {
+        cb();
+      }
+    }
+    /**
+     * Destroys the current sticky element.
+     * Resets the element to the top position first.
+     * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this._removeSticky(true);
+
+      this.$element.removeClass("".concat(this.options.stickyClass, " is-anchored is-at-top")).css({
+        height: '',
+        top: '',
+        bottom: '',
+        'max-width': ''
+      }).off('resizeme.zf.trigger').off('mutateme.zf.trigger');
+
+      if (this.$anchor && this.$anchor.length) {
+        this.$anchor.off('change.zf.sticky');
+      }
+
+      if (this.scrollListener) $(window).off(this.scrollListener);
+      if (this.onLoadListener) $(window).off(this.onLoadListener);
+
+      if (this.wasWrapped) {
+        this.$element.unwrap();
+      } else {
+        this.$container.removeClass(this.options.containerClass).css({
+          height: ''
+        });
+      }
+    }
+  }]);
+
+  return Sticky;
+}(Plugin);
+
+Sticky.defaults = {
+  /**
+   * Customizable container template. Add your own classes for styling and sizing.
+   * @option
+   * @type {string}
+   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'
+   */
+  container: '<div data-sticky-container></div>',
+
+  /**
+   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.
+   * @option
+   * @type {string}
+   * @default 'top'
+   */
+  stickTo: 'top',
+
+  /**
+   * If anchored to a single element, the id of that element.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  anchor: '',
+
+  /**
+   * If using more than one element as anchor points, the id of the top anchor.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  topAnchor: '',
+
+  /**
+   * If using more than one element as anchor points, the id of the bottom anchor.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  btmAnchor: '',
+
+  /**
+   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  marginTop: 1,
+
+  /**
+   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  marginBottom: 1,
+
+  /**
+   * Breakpoint string that is the minimum screen size an element should become sticky.
+   * @option
+   * @type {string}
+   * @default 'medium'
+   */
+  stickyOn: 'medium',
+
+  /**
+   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.
+   * @option
+   * @type {string}
+   * @default 'sticky'
+   */
+  stickyClass: 'sticky',
+
+  /**
+   * Class applied to sticky container. Foundation defaults to `sticky-container`.
+   * @option
+   * @type {string}
+   * @default 'sticky-container'
+   */
+  containerClass: 'sticky-container',
+
+  /**
+   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.
+   * @option
+   * @type {number}
+   * @default -1
+   */
+  checkEvery: -1
+};
+/**
+ * Helper function to calculate em values
+ * @param Number {em} - number of em's to calculate into pixels
+ */
+
+function emCalc(em) {
+  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;
+}
+
+/**
+ * Tabs module.
+ * @module foundation.tabs
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.imageLoader if tabs contain images
+ */
+
+var Tabs =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Tabs, _Plugin);
+
+  function Tabs() {
+    _classCallCheck(this, Tabs);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments));
+  }
+
+  _createClass(Tabs, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of tabs.
+     * @class
+     * @name Tabs
+     * @fires Tabs#init
+     * @param {jQuery} element - jQuery object to make into tabs.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);
+      this.className = 'Tabs'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('Tabs', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'previous',
+        'ARROW_DOWN': 'next',
+        'ARROW_LEFT': 'previous' // 'TAB': 'next',
+        // 'SHIFT_TAB': 'previous'
+
+      });
+    }
+    /**
+     * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      var _this = this;
+
+      this._isInitializing = true;
+      this.$element.attr({
+        'role': 'tablist'
+      });
+      this.$tabTitles = this.$element.find(".".concat(this.options.linkClass));
+      this.$tabContent = $("[data-tabs-content=\"".concat(this.$element[0].id, "\"]"));
+      this.$tabTitles.each(function () {
+        var $elem = $(this),
+            $link = $elem.find('a'),
+            isActive = $elem.hasClass("".concat(_this.options.linkActiveClass)),
+            hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),
+            linkId = $link[0].id ? $link[0].id : "".concat(hash, "-label"),
+            $tabContent = $("#".concat(hash));
+        $elem.attr({
+          'role': 'presentation'
+        });
+        $link.attr({
+          'role': 'tab',
+          'aria-controls': hash,
+          'aria-selected': isActive,
+          'id': linkId,
+          'tabindex': isActive ? '0' : '-1'
+        });
+        $tabContent.attr({
+          'role': 'tabpanel',
+          'aria-labelledby': linkId
+        }); // Save up the initial hash to return to it later when going back in history
+
+        if (isActive) {
+          _this._initialAnchor = "#".concat(hash);
+        }
+
+        if (!isActive) {
+          $tabContent.attr('aria-hidden', 'true');
+        }
+
+        if (isActive && _this.options.autoFocus) {
+          _this.onLoadListener = onLoad($(window), function () {
+            $('html, body').animate({
+              scrollTop: $elem.offset().top
+            }, _this.options.deepLinkSmudgeDelay, function () {
+              $link.focus();
+            });
+          });
+        }
+      });
+
+      if (this.options.matchHeight) {
+        var $images = this.$tabContent.find('img');
+
+        if ($images.length) {
+          onImagesLoaded($images, this._setHeight.bind(this));
+        } else {
+          this._setHeight();
+        }
+      } // Current context-bound function to open tabs on page load or history hashchange
+
+
+      this._checkDeepLink = function () {
+        var anchor = window.location.hash;
+
+        if (!anchor.length) {
+          // If we are still initializing and there is no anchor, then there is nothing to do
+          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor
+
+          if (_this2._initialAnchor) anchor = _this2._initialAnchor;
+        }
+
+        var $anchor = anchor && $(anchor);
+
+        var $link = anchor && _this2.$element.find('[href$="' + anchor + '"]'); // Whether the anchor element that has been found is part of this element
+
+
+        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, select it
+
+        if ($anchor && $anchor.length && $link && $link.length) {
+          _this2.selectTab($anchor, true);
+        } // Otherwise, collapse everything
+        else {
+            _this2._collapse();
+          }
+
+        if (isOwnAnchor) {
+          // Roll up a little to show the titles
+          if (_this2.options.deepLinkSmudge) {
+            var offset = _this2.$element.offset();
+
+            $('html, body').animate({
+              scrollTop: offset.top
+            }, _this2.options.deepLinkSmudgeDelay);
+          }
+          /**
+           * Fires when the plugin has deeplinked at pageload
+           * @event Tabs#deeplink
+           */
+
+
+          _this2.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);
+        }
+      }; //use browser to open a tab, if it exists in this tabset
+
+
+      if (this.options.deepLink) {
+        this._checkDeepLink();
+      }
+
+      this._events();
+
+      this._isInitializing = false;
+    }
+    /**
+     * Adds event handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._addKeyHandler();
+
+      this._addClickHandler();
+
+      this._setHeightMqHandler = null;
+
+      if (this.options.matchHeight) {
+        this._setHeightMqHandler = this._setHeight.bind(this);
+        $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);
+      }
+
+      if (this.options.deepLink) {
+        $(window).on('hashchange', this._checkDeepLink);
+      }
+    }
+    /**
+     * Adds click handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_addClickHandler",
+    value: function _addClickHandler() {
+      var _this = this;
+
+      this.$element.off('click.zf.tabs').on('click.zf.tabs', ".".concat(this.options.linkClass), function (e) {
+        e.preventDefault();
+        e.stopPropagation();
+
+        _this._handleTabChange($(this));
+      });
+    }
+    /**
+     * Adds keyboard event handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_addKeyHandler",
+    value: function _addKeyHandler() {
+      var _this = this;
+
+      this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) {
+        if (e.which === 9) return;
+        var $element = $(this),
+            $elements = $element.parent('ul').children('li'),
+            $prevElement,
+            $nextElement;
+        $elements.each(function (i) {
+          if ($(this).is($element)) {
+            if (_this.options.wrapOnKeys) {
+              $prevElement = i === 0 ? $elements.last() : $elements.eq(i - 1);
+              $nextElement = i === $elements.length - 1 ? $elements.first() : $elements.eq(i + 1);
+            } else {
+              $prevElement = $elements.eq(Math.max(0, i - 1));
+              $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
+            }
+
+            return;
+          }
+        }); // handle keyboard event with keyboard util
+
+        Keyboard.handleKey(e, 'Tabs', {
+          open: function open() {
+            $element.find('[role="tab"]').focus();
+
+            _this._handleTabChange($element);
+          },
+          previous: function previous() {
+            $prevElement.find('[role="tab"]').focus();
+
+            _this._handleTabChange($prevElement);
+          },
+          next: function next() {
+            $nextElement.find('[role="tab"]').focus();
+
+            _this._handleTabChange($nextElement);
+          },
+          handled: function handled() {
+            e.stopPropagation();
+            e.preventDefault();
+          }
+        });
+      });
+    }
+    /**
+     * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.
+     * @param {jQuery} $target - Tab to open.
+     * @param {boolean} historyHandled - browser has already handled a history update
+     * @fires Tabs#change
+     * @function
+     */
+
+  }, {
+    key: "_handleTabChange",
+    value: function _handleTabChange($target, historyHandled) {
+      // With `activeCollapse`, if the target is the active Tab, collapse it.
+      if ($target.hasClass("".concat(this.options.linkActiveClass))) {
+        if (this.options.activeCollapse) {
+          this._collapse();
+        }
+
+        return;
+      }
+
+      var $oldTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass)),
+          $tabLink = $target.find('[role="tab"]'),
+          target = $tabLink.attr('data-tabs-target'),
+          anchor = target && target.length ? "#".concat(target) : $tabLink[0].hash,
+          $targetContent = this.$tabContent.find(anchor); //close old tab
+
+      this._collapseTab($oldTab); //open new tab
+
+
+      this._openTab($target); //either replace or update browser history
+
+
+      if (this.options.deepLink && !historyHandled) {
+        if (this.options.updateHistory) {
+          history.pushState({}, '', anchor);
+        } else {
+          history.replaceState({}, '', anchor);
+        }
+      }
+      /**
+       * Fires when the plugin has successfully changed tabs.
+       * @event Tabs#change
+       */
+
+
+      this.$element.trigger('change.zf.tabs', [$target, $targetContent]); //fire to children a mutation event
+
+      $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger");
+    }
+    /**
+     * Opens the tab `$targetContent` defined by `$target`.
+     * @param {jQuery} $target - Tab to open.
+     * @function
+     */
+
+  }, {
+    key: "_openTab",
+    value: function _openTab($target) {
+      var $tabLink = $target.find('[role="tab"]'),
+          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),
+          $targetContent = this.$tabContent.find("#".concat(hash));
+      $target.addClass("".concat(this.options.linkActiveClass));
+      $tabLink.attr({
+        'aria-selected': 'true',
+        'tabindex': '0'
+      });
+      $targetContent.addClass("".concat(this.options.panelActiveClass)).removeAttr('aria-hidden');
+    }
+    /**
+     * Collapses `$targetContent` defined by `$target`.
+     * @param {jQuery} $target - Tab to collapse.
+     * @function
+     */
+
+  }, {
+    key: "_collapseTab",
+    value: function _collapseTab($target) {
+      var $target_anchor = $target.removeClass("".concat(this.options.linkActiveClass)).find('[role="tab"]').attr({
+        'aria-selected': 'false',
+        'tabindex': -1
+      });
+      $("#".concat($target_anchor.attr('aria-controls'))).removeClass("".concat(this.options.panelActiveClass)).attr({
+        'aria-hidden': 'true'
+      });
+    }
+    /**
+     * Collapses the active Tab.
+     * @fires Tabs#collapse
+     * @function
+     */
+
+  }, {
+    key: "_collapse",
+    value: function _collapse() {
+      var $activeTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass));
+
+      if ($activeTab.length) {
+        this._collapseTab($activeTab);
+        /**
+        * Fires when the plugin has successfully collapsed tabs.
+        * @event Tabs#collapse
+        */
+
+
+        this.$element.trigger('collapse.zf.tabs', [$activeTab]);
+      }
+    }
+    /**
+     * Public method for selecting a content pane to display.
+     * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.
+     * @param {boolean} historyHandled - browser has already handled a history update
+     * @function
+     */
+
+  }, {
+    key: "selectTab",
+    value: function selectTab(elem, historyHandled) {
+      var idStr;
+
+      if (_typeof(elem) === 'object') {
+        idStr = elem[0].id;
+      } else {
+        idStr = elem;
+      }
+
+      if (idStr.indexOf('#') < 0) {
+        idStr = "#".concat(idStr);
+      }
+
+      var $target = this.$tabTitles.has("[href$=\"".concat(idStr, "\"]"));
+
+      this._handleTabChange($target, historyHandled);
+    }
+  }, {
+    key: "_setHeight",
+
+    /**
+     * Sets the height of each panel to the height of the tallest panel.
+     * If enabled in options, gets called on media query change.
+     * If loading content via external source, can be called directly or with _reflow.
+     * If enabled with `data-match-height="true"`, tabs sets to equal height
+     * @function
+     * @private
+     */
+    value: function _setHeight() {
+      var max = 0,
+          _this = this; // Lock down the `this` value for the root tabs object
+
+
+      this.$tabContent.find(".".concat(this.options.panelClass)).css('height', '').each(function () {
+        var panel = $(this),
+            isActive = panel.hasClass("".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child
+
+        if (!isActive) {
+          panel.css({
+            'visibility': 'hidden',
+            'display': 'block'
+          });
+        }
+
+        var temp = this.getBoundingClientRect().height;
+
+        if (!isActive) {
+          panel.css({
+            'visibility': '',
+            'display': ''
+          });
+        }
+
+        max = temp > max ? temp : max;
+      }).css('height', "".concat(max, "px"));
+    }
+    /**
+     * Destroys an instance of tabs.
+     * @fires Tabs#destroyed
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.find(".".concat(this.options.linkClass)).off('.zf.tabs').hide().end().find(".".concat(this.options.panelClass)).hide();
+
+      if (this.options.matchHeight) {
+        if (this._setHeightMqHandler != null) {
+          $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);
+        }
+      }
+
+      if (this.options.deepLink) {
+        $(window).off('hashchange', this._checkDeepLink);
+      }
+
+      if (this.onLoadListener) {
+        $(window).off(this.onLoadListener);
+      }
+    }
+  }]);
+
+  return Tabs;
+}(Plugin);
+
+Tabs.defaults = {
+  /**
+   * Link the location hash to the active pane.
+   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+
+  /**
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinkSmudge: false,
+
+  /**
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
+   * @option
+   * @type {number}
+   * @default 300
+   */
+  deepLinkSmudgeDelay: 300,
+
+  /**
+   * If `deepLink` is enabled, update the browser history with the open tab
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  updateHistory: false,
+
+  /**
+   * Allows the window to scroll to content of active pane on load.
+   * Not recommended if more than one tab panel per page.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoFocus: false,
+
+  /**
+   * Allows keyboard input to 'wrap' around the tab links.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  wrapOnKeys: true,
+
+  /**
+   * Allows the tab content panes to match heights if set to true.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  matchHeight: false,
+
+  /**
+   * Allows active tabs to collapse when clicked.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  activeCollapse: false,
+
+  /**
+   * Class applied to `li`'s in tab link list.
+   * @option
+   * @type {string}
+   * @default 'tabs-title'
+   */
+  linkClass: 'tabs-title',
+
+  /**
+   * Class applied to the active `li` in tab link list.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  linkActiveClass: 'is-active',
+
+  /**
+   * Class applied to the content containers.
+   * @option
+   * @type {string}
+   * @default 'tabs-panel'
+   */
+  panelClass: 'tabs-panel',
+
+  /**
+   * Class applied to the active content container.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  panelActiveClass: 'is-active'
+};
+
+/**
+ * Toggler module.
+ * @module foundation.toggler
+ * @requires foundation.util.motion
+ * @requires foundation.util.triggers
+ */
+
+var Toggler =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Toggler, _Plugin);
+
+  function Toggler() {
+    _classCallCheck(this, Toggler);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Toggler).apply(this, arguments));
+  }
+
+  _createClass(Toggler, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Toggler.
+     * @class
+     * @name Toggler
+     * @fires Toggler#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Toggler.defaults, element.data(), options);
+      this.className = '';
+      this.className = 'Toggler'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var input; // Parse animation classes if they were set
+
+      if (this.options.animate) {
+        input = this.options.animate.split(' ');
+        this.animationIn = input[0];
+        this.animationOut = input[1] || null;
+      } // Otherwise, parse toggle class
+      else {
+          input = this.$element.data('toggler'); // Allow for a . at the beginning of the string
+
+          this.className = input[0] === '.' ? input.slice(1) : input;
+        } // Add ARIA attributes to triggers:
+
+
+      var id = this.$element[0].id,
+          $triggers = $("[data-open~=\"".concat(id, "\"], [data-close~=\"").concat(id, "\"], [data-toggle~=\"").concat(id, "\"]")); // - aria-expanded: according to the element visibility.
+
+      $triggers.attr('aria-expanded', !this.$element.is(':hidden')); // - aria-controls: adding the element id to it if not already in it.
+
+      $triggers.each(function (index, trigger) {
+        var $trigger = $(trigger);
+        var controls = $trigger.attr('aria-controls') || '';
+        var containsId = new RegExp("\\b".concat(RegExpEscape(id), "\\b")).test(controls);
+        if (!containsId) $trigger.attr('aria-controls', controls ? "".concat(controls, " ").concat(id) : id);
+      });
+    }
+    /**
+     * Initializes events for the toggle trigger.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));
+    }
+    /**
+     * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was "on" or "off".
+     * @function
+     * @fires Toggler#on
+     * @fires Toggler#off
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      this[this.options.animate ? '_toggleAnimate' : '_toggleClass']();
+    }
+  }, {
+    key: "_toggleClass",
+    value: function _toggleClass() {
+      this.$element.toggleClass(this.className);
+      var isOn = this.$element.hasClass(this.className);
+
+      if (isOn) {
+        /**
+         * Fires if the target element has the class after a toggle.
+         * @event Toggler#on
+         */
+        this.$element.trigger('on.zf.toggler');
+      } else {
+        /**
+         * Fires if the target element does not have the class after a toggle.
+         * @event Toggler#off
+         */
+        this.$element.trigger('off.zf.toggler');
+      }
+
+      this._updateARIA(isOn);
+
+      this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');
+    }
+  }, {
+    key: "_toggleAnimate",
+    value: function _toggleAnimate() {
+      var _this = this;
+
+      if (this.$element.is(':hidden')) {
+        Motion.animateIn(this.$element, this.animationIn, function () {
+          _this._updateARIA(true);
+
+          this.trigger('on.zf.toggler');
+          this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+        });
+      } else {
+        Motion.animateOut(this.$element, this.animationOut, function () {
+          _this._updateARIA(false);
+
+          this.trigger('off.zf.toggler');
+          this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+        });
+      }
+    }
+  }, {
+    key: "_updateARIA",
+    value: function _updateARIA(isOn) {
+      var id = this.$element[0].id;
+      $("[data-open=\"".concat(id, "\"], [data-close=\"").concat(id, "\"], [data-toggle=\"").concat(id, "\"]")).attr({
+        'aria-expanded': isOn ? true : false
+      });
+    }
+    /**
+     * Destroys the instance of Toggler on the element.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.toggler');
+    }
+  }]);
+
+  return Toggler;
+}(Plugin);
+
+Toggler.defaults = {
+  /**
+   * Tells the plugin if the element should animated when toggled.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animate: false
+};
+
+/**
+ * Tooltip module.
+ * @module foundation.tooltip
+ * @requires foundation.util.box
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.triggers
+ */
+
+var Tooltip =
+/*#__PURE__*/
+function (_Positionable) {
+  _inherits(Tooltip, _Positionable);
+
+  function Tooltip() {
+    _classCallCheck(this, Tooltip);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments));
+  }
+
+  _createClass(Tooltip, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a Tooltip.
+     * @class
+     * @name Tooltip
+     * @fires Tooltip#init
+     * @param {jQuery} element - jQuery object to attach a tooltip to.
+     * @param {Object} options - object to extend the default configuration.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);
+      this.className = 'Tooltip'; // ie9 back compat
+
+      this.isActive = false;
+      this.isClick = false; // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      this._init();
+    }
+    /**
+     * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init();
+
+      var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');
+      this.options.tipText = this.options.tipText || this.$element.attr('title');
+      this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);
+
+      if (this.options.allowHtml) {
+        this.template.appendTo(document.body).html(this.options.tipText).hide();
+      } else {
+        this.template.appendTo(document.body).text(this.options.tipText).hide();
+      }
+
+      this.$element.attr({
+        'title': '',
+        'aria-describedby': elemId,
+        'data-yeti-box': elemId,
+        'data-toggle': elemId,
+        'data-resize': elemId
+      }).addClass(this.options.triggerClass);
+
+      _get(_getPrototypeOf(Tooltip.prototype), "_init", this).call(this);
+
+      this._events();
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      // handle legacy classnames
+      var position = this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);
+      return position ? position[0] : 'top';
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      return 'center';
+    }
+  }, {
+    key: "_getHOffset",
+    value: function _getHOffset() {
+      if (this.position === 'left' || this.position === 'right') {
+        return this.options.hOffset + this.options.tooltipWidth;
+      } else {
+        return this.options.hOffset;
+      }
+    }
+  }, {
+    key: "_getVOffset",
+    value: function _getVOffset() {
+      if (this.position === 'top' || this.position === 'bottom') {
+        return this.options.vOffset + this.options.tooltipHeight;
+      } else {
+        return this.options.vOffset;
+      }
+    }
+    /**
+     * builds the tooltip element, adds attributes, and returns the template.
+     * @private
+     */
+
+  }, {
+    key: "_buildTemplate",
+    value: function _buildTemplate(id) {
+      var templateClasses = "".concat(this.options.tooltipClass, " ").concat(this.options.templateClasses).trim();
+      var $template = $('<div></div>').addClass(templateClasses).attr({
+        'role': 'tooltip',
+        'aria-hidden': true,
+        'data-is-active': false,
+        'data-is-focus': false,
+        'id': id
+      });
+      return $template;
+    }
+    /**
+     * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.
+     * if the tooltip is larger than the screen width, default to full width - any user selected margin
+     * @private
+     */
+
+  }, {
+    key: "_setPosition",
+    value: function _setPosition() {
+      _get(_getPrototypeOf(Tooltip.prototype), "_setPosition", this).call(this, this.$element, this.template);
+    }
+    /**
+     * reveals the tooltip, and fires an event to close any other open tooltips on the page
+     * @fires Tooltip#closeme
+     * @fires Tooltip#show
+     * @function
+     */
+
+  }, {
+    key: "show",
+    value: function show() {
+      if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {
+        // console.error('The screen is too small to display this tooltip');
+        return false;
+      }
+
+      var _this = this;
+
+      this.template.css('visibility', 'hidden').show();
+
+      this._setPosition();
+
+      this.template.removeClass('top bottom left right').addClass(this.position);
+      this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);
+      /**
+       * Fires to close all other open tooltips on the page
+       * @event Closeme#tooltip
+       */
+
+      this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));
+      this.template.attr({
+        'data-is-active': true,
+        'aria-hidden': false
+      });
+      _this.isActive = true; // console.log(this.template);
+
+      this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {//maybe do stuff?
+      });
+      /**
+       * Fires when the tooltip is shown
+       * @event Tooltip#show
+       */
+
+      this.$element.trigger('show.zf.tooltip');
+    }
+    /**
+     * Hides the current tooltip, and resets the positioning class if it was changed due to collision
+     * @fires Tooltip#hide
+     * @function
+     */
+
+  }, {
+    key: "hide",
+    value: function hide() {
+      // console.log('hiding', this.$element.data('yeti-box'));
+      var _this = this;
+
+      this.template.stop().attr({
+        'aria-hidden': true,
+        'data-is-active': false
+      }).fadeOut(this.options.fadeOutDuration, function () {
+        _this.isActive = false;
+        _this.isClick = false;
+      });
+      /**
+       * fires when the tooltip is hidden
+       * @event Tooltip#hide
+       */
+
+      this.$element.trigger('hide.zf.tooltip');
+    }
+    /**
+     * adds event listeners for the tooltip and its anchor
+     * TODO combine some of the listeners like focus and mouseenter, etc.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      var $template = this.template;
+      var isFocus = false;
+
+      if (!this.options.disableHover) {
+        this.$element.on('mouseenter.zf.tooltip', function (e) {
+          if (!_this.isActive) {
+            _this.timeout = setTimeout(function () {
+              _this.show();
+            }, _this.options.hoverDelay);
+          }
+        }).on('mouseleave.zf.tooltip', ignoreMousedisappear(function (e) {
+          clearTimeout(_this.timeout);
+
+          if (!isFocus || _this.isClick && !_this.options.clickOpen) {
+            _this.hide();
+          }
+        }));
+      }
+
+      if (this.options.clickOpen) {
+        this.$element.on('mousedown.zf.tooltip', function (e) {
+          e.stopImmediatePropagation();
+
+          if (_this.isClick) ; else {
+            _this.isClick = true;
+
+            if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {
+              _this.show();
+            }
+          }
+        });
+      } else {
+        this.$element.on('mousedown.zf.tooltip', function (e) {
+          e.stopImmediatePropagation();
+          _this.isClick = true;
+        });
+      }
+
+      if (!this.options.disableForTouch) {
+        this.$element.on('tap.zf.tooltip touchend.zf.tooltip', function (e) {
+          _this.isActive ? _this.hide() : _this.show();
+        });
+      }
+
+      this.$element.on({
+        // 'toggle.zf.trigger': this.toggle.bind(this),
+        // 'close.zf.trigger': this.hide.bind(this)
+        'close.zf.trigger': this.hide.bind(this)
+      });
+      this.$element.on('focus.zf.tooltip', function (e) {
+        isFocus = true;
+
+        if (_this.isClick) {
+          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't
+          // a real focus, otherwise on hover and come back we get bad behavior
+          if (!_this.options.clickOpen) {
+            isFocus = false;
+          }
+
+          return false;
+        } else {
+          _this.show();
+        }
+      }).on('focusout.zf.tooltip', function (e) {
+        isFocus = false;
+        _this.isClick = false;
+
+        _this.hide();
+      }).on('resizeme.zf.trigger', function () {
+        if (_this.isActive) {
+          _this._setPosition();
+        }
+      });
+    }
+    /**
+     * adds a toggle method, in addition to the static show() & hide() functions
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      if (this.isActive) {
+        this.hide();
+      } else {
+        this.show();
+      }
+    }
+    /**
+     * Destroys an instance of tooltip, removes template element from the view.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass(this.options.triggerClass).removeClass('top right left bottom').removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');
+      this.template.remove();
+    }
+  }]);
+
+  return Tooltip;
+}(Positionable);
+
+Tooltip.defaults = {
+  disableForTouch: false,
+
+  /**
+   * Time, in ms, before a tooltip should open on hover.
+   * @option
+   * @type {number}
+   * @default 200
+   */
+  hoverDelay: 200,
+
+  /**
+   * Time, in ms, a tooltip should take to fade into view.
+   * @option
+   * @type {number}
+   * @default 150
+   */
+  fadeInDuration: 150,
+
+  /**
+   * Time, in ms, a tooltip should take to fade out of view.
+   * @option
+   * @type {number}
+   * @default 150
+   */
+  fadeOutDuration: 150,
+
+  /**
+   * Disables hover events from opening the tooltip if set to true
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disableHover: false,
+
+  /**
+   * Optional addtional classes to apply to the tooltip template on init.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  templateClasses: '',
+
+  /**
+   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.
+   * @option
+   * @type {string}
+   * @default 'tooltip'
+   */
+  tooltipClass: 'tooltip',
+
+  /**
+   * Class applied to the tooltip anchor element.
+   * @option
+   * @type {string}
+   * @default 'has-tip'
+   */
+  triggerClass: 'has-tip',
+
+  /**
+   * Minimum breakpoint size at which to open the tooltip.
+   * @option
+   * @type {string}
+   * @default 'small'
+   */
+  showOn: 'small',
+
+  /**
+   * Custom template to be used to generate markup for tooltip.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  template: '',
+
+  /**
+   * Text displayed in the tooltip template on open.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  tipText: '',
+  touchCloseText: 'Tap to close.',
+
+  /**
+   * Allows the tooltip to remain open if triggered with a click or touch event.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  clickOpen: true,
+
+  /**
+   * Position of tooltip. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+
+  /**
+   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow overlap of container/window. If false, tooltip will first try to
+   * position as defined by data-position and data-alignment, but reposition if
+   * it would cause an overflow.  @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * Less common for tooltips.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowBottomOverlap: false,
+
+  /**
+   * Distance, in pixels, the template should push away from the anchor on the Y axis.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+
+  /**
+   * Distance, in pixels, the template should push away from the anchor on the X axis
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0,
+
+  /**
+   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip
+   * @option
+   * @type {number}
+   * @default 14
+   */
+  tooltipHeight: 14,
+
+  /**
+   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip
+   * @option
+   * @type {number}
+   * @default 12
+   */
+  tooltipWidth: 12,
+
+  /**
+  * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,
+  * allowing HTML may open yourself up to XSS attacks.
+  * @option
+  * @type {boolean}
+  * @default false
+  */
+  allowHtml: false
+};
+
+var MenuPlugins$1 = {
+  tabs: {
+    cssClass: 'tabs',
+    plugin: Tabs
+  },
+  accordion: {
+    cssClass: 'accordion',
+    plugin: Accordion
+  }
+};
+/**
+ * ResponsiveAccordionTabs module.
+ * @module foundation.responsiveAccordionTabs
+ * @requires foundation.util.motion
+ * @requires foundation.accordion
+ * @requires foundation.tabs
+ */
+
+var ResponsiveAccordionTabs =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveAccordionTabs, _Plugin);
+
+  function ResponsiveAccordionTabs() {
+    _classCallCheck(this, ResponsiveAccordionTabs);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveAccordionTabs).apply(this, arguments));
+  }
+
+  _createClass(ResponsiveAccordionTabs, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a responsive accordion tabs.
+     * @class
+     * @name ResponsiveAccordionTabs
+     * @fires ResponsiveAccordionTabs#init
+     * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = $(element);
+      this.options = $.extend({}, this.$element.data(), options);
+      this.rules = this.$element.data('responsive-accordion-tabs');
+      this.currentMq = null;
+      this.currentPlugin = null;
+      this.className = 'ResponsiveAccordionTabs'; // ie9 back compat
+
+      if (!this.$element.attr('id')) {
+        this.$element.attr('id', GetYoDigits(6, 'responsiveaccordiontabs'));
+      }
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
+
+
+      if (typeof this.rules === 'string') {
+        var rulesTree = {}; // Parse rules from "classes" pulled from data attribute
+
+        var rules = this.rules.split(' '); // Iterate through every rule found
+
+        for (var i = 0; i < rules.length; i++) {
+          var rule = rules[i].split('-');
+          var ruleSize = rule.length > 1 ? rule[0] : 'small';
+          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+
+          if (MenuPlugins$1[rulePlugin] !== null) {
+            rulesTree[ruleSize] = MenuPlugins$1[rulePlugin];
+          }
+        }
+
+        this.rules = rulesTree;
+      }
+
+      this._getAllOptions();
+
+      if (!$.isEmptyObject(this.rules)) {
+        this._checkMediaQueries();
+      }
+    }
+  }, {
+    key: "_getAllOptions",
+    value: function _getAllOptions() {
+      //get all defaults and options
+      var _this = this;
+
+      _this.allOptions = {};
+
+      for (var key in MenuPlugins$1) {
+        if (MenuPlugins$1.hasOwnProperty(key)) {
+          var obj = MenuPlugins$1[key];
+
+          try {
+            var dummyPlugin = $('<ul></ul>');
+            var tmpPlugin = new obj.plugin(dummyPlugin, _this.options);
+
+            for (var keyKey in tmpPlugin.options) {
+              if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {
+                var objObj = tmpPlugin.options[keyKey];
+                _this.allOptions[keyKey] = objObj;
+              }
+            }
+
+            tmpPlugin.destroy();
+          } catch (e) {}
+        }
+      }
+    }
+    /**
+     * Initializes events for the Menu.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);
+      $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
+    }
+    /**
+     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_checkMediaQueries",
+    value: function _checkMediaQueries() {
+      var matchedMq,
+          _this = this; // Iterate through each rule and find the last matching rule
+
+
+      $.each(this.rules, function (key) {
+        if (MediaQuery.atLeast(key)) {
+          matchedMq = key;
+        }
+      }); // No match? No dice
+
+      if (!matchedMq) return; // Plugin already initialized? We good
+
+      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes
+
+      $.each(MenuPlugins$1, function (key, value) {
+        _this.$element.removeClass(value.cssClass);
+      }); // Add the CSS class for the new plugin
+
+      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin
+
+      if (this.currentPlugin) {
+        //don't know why but on nested elements data zfPlugin get's lost
+        if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData);
+        this.currentPlugin.destroy();
+      }
+
+      this._handleMarkup(this.rules[matchedMq].cssClass);
+
+      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+      this.storezfData = this.currentPlugin.$element.data('zfPlugin');
+    }
+  }, {
+    key: "_handleMarkup",
+    value: function _handleMarkup(toSet) {
+      var _this = this,
+          fromString = 'accordion';
+
+      var $panels = $('[data-tabs-content=' + this.$element.attr('id') + ']');
+      if ($panels.length) fromString = 'tabs';
+
+      if (fromString === toSet) {
+        return;
+      }
+      var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title';
+      var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel';
+      this.$element.removeAttr('role');
+      var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');
+      var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');
+
+      if (fromString === 'tabs') {
+        $panels = $panels.children('.' + tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');
+        $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');
+      } else {
+        $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');
+      }
+      $panels.css({
+        display: '',
+        visibility: ''
+      });
+      $liHeads.css({
+        display: '',
+        visibility: ''
+      });
+
+      if (toSet === 'accordion') {
+        $panels.each(function (key, value) {
+          $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({
+            height: ''
+          });
+          $('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id="tabs-placeholder-' + _this.$element.attr('id') + '"></div>').detach();
+          $liHeads.addClass('accordion-item').attr('data-accordion-item', '');
+          $liHeadsA.addClass('accordion-title');
+        });
+      } else if (toSet === 'tabs') {
+        var $tabsContent = $('[data-tabs-content=' + _this.$element.attr('id') + ']');
+        var $placeholder = $('#tabs-placeholder-' + _this.$element.attr('id'));
+
+        if ($placeholder.length) {
+          $tabsContent = $('<div class="tabs-content"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));
+          $placeholder.remove();
+        } else {
+          $tabsContent = $('<div class="tabs-content"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));
+        }
+        $panels.each(function (key, value) {
+          var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);
+          var hash = $liHeadsA.get(key).hash.slice(1);
+          var id = $(value).attr('id') || GetYoDigits(6, 'accordion');
+
+          if (hash !== id) {
+            if (hash !== '') {
+              $(value).attr('id', hash);
+            } else {
+              hash = id;
+              $(value).attr('id', hash);
+              $($liHeadsA.get(key)).attr('href', $($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);
+            }
+          }
+          var isActive = $($liHeads.get(key)).hasClass('is-active');
+
+          if (isActive) {
+            tempValue.addClass('is-active');
+          }
+        });
+        $liHeads.addClass(tabsTitle);
+      }
+    }
+    /**
+     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      if (this.currentPlugin) this.currentPlugin.destroy();
+      $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
+    }
+  }]);
+
+  return ResponsiveAccordionTabs;
+}(Plugin);
+
+ResponsiveAccordionTabs.defaults = {};
+
+Foundation.addToJquery($); // Add Foundation Utils to Foundation global namespace for backwards
+// compatibility.
+
+Foundation.rtl = rtl;
+Foundation.GetYoDigits = GetYoDigits;
+Foundation.transitionend = transitionend;
+Foundation.RegExpEscape = RegExpEscape;
+Foundation.onLoad = onLoad;
+Foundation.Box = Box;
+Foundation.onImagesLoaded = onImagesLoaded;
+Foundation.Keyboard = Keyboard;
+Foundation.MediaQuery = MediaQuery;
+Foundation.Motion = Motion;
+Foundation.Move = Move;
+Foundation.Nest = Nest;
+Foundation.Timer = Timer; // Touch and Triggers previously were almost purely sede effect driven,
+// so no need to add it to Foundation, just init them.
+
+Touch.init($);
+Triggers.init($, Foundation);
+
+MediaQuery._init();
+
+Foundation.plugin(Abide, 'Abide');
+Foundation.plugin(Accordion, 'Accordion');
+Foundation.plugin(AccordionMenu, 'AccordionMenu');
+Foundation.plugin(Drilldown, 'Drilldown');
+Foundation.plugin(Dropdown, 'Dropdown');
+Foundation.plugin(DropdownMenu, 'DropdownMenu');
+Foundation.plugin(Equalizer, 'Equalizer');
+Foundation.plugin(Interchange, 'Interchange');
+Foundation.plugin(Magellan, 'Magellan');
+Foundation.plugin(OffCanvas, 'OffCanvas');
+Foundation.plugin(Orbit, 'Orbit');
+Foundation.plugin(ResponsiveMenu, 'ResponsiveMenu');
+Foundation.plugin(ResponsiveToggle, 'ResponsiveToggle');
+Foundation.plugin(Reveal, 'Reveal');
+Foundation.plugin(Slider, 'Slider');
+Foundation.plugin(SmoothScroll, 'SmoothScroll');
+Foundation.plugin(Sticky, 'Sticky');
+Foundation.plugin(Tabs, 'Tabs');
+Foundation.plugin(Toggler, 'Toggler');
+Foundation.plugin(Tooltip, 'Tooltip');
+Foundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');
+
+exports.CoreUtils = foundation_core_utils;
+exports.Core = Foundation;
+exports.Foundation = Foundation;
+exports.Box = Box;
+exports.onImagesLoaded = onImagesLoaded;
+exports.Keyboard = Keyboard;
+exports.MediaQuery = MediaQuery;
+exports.Motion = Motion;
+exports.Move = Move;
+exports.Nest = Nest;
+exports.Timer = Timer;
+exports.Touch = Touch;
+exports.Triggers = Triggers;
+exports.Abide = Abide;
+exports.Accordion = Accordion;
+exports.AccordionMenu = AccordionMenu;
+exports.Drilldown = Drilldown;
+exports.Dropdown = Dropdown;
+exports.DropdownMenu = DropdownMenu;
+exports.Equalizer = Equalizer;
+exports.Interchange = Interchange;
+exports.Magellan = Magellan;
+exports.OffCanvas = OffCanvas;
+exports.Orbit = Orbit;
+exports.ResponsiveMenu = ResponsiveMenu;
+exports.ResponsiveToggle = ResponsiveToggle;
+exports.Reveal = Reveal;
+exports.Slider = Slider;
+exports.SmoothScroll = SmoothScroll;
+exports.Sticky = Sticky;
+exports.Tabs = Tabs;
+exports.Toggler = Toggler;
+exports.Tooltip = Tooltip;
+exports.ResponsiveAccordionTabs = ResponsiveAccordionTabs;
+exports.default = Foundation;
+//# sourceMappingURL=foundation.cjs.js.map
diff --git a/dist/js/foundation.cjs.js.map b/dist/js/foundation.cjs.js.map
new file mode 100644 (file)
index 0000000..1e679f8
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"file":"foundation.cjs.js","sources":["../../js/foundation.core.utils.js","../../js/foundation.util.mediaQuery.js","../../js/foundation.core.js","../../js/foundation.util.box.js","../../js/foundation.util.imageLoader.js","../../js/foundation.util.keyboard.js","../../js/foundation.util.motion.js","../../js/foundation.util.nest.js","../../js/foundation.util.timer.js","../../js/foundation.util.touch.js","../../js/foundation.util.triggers.js","../../js/foundation.core.plugin.js","../../js/foundation.abide.js","../../js/foundation.accordion.js","../../js/foundation.accordionMenu.js","../../js/foundation.drilldown.js","../../js/foundation.positionable.js","../../js/foundation.dropdown.js","../../js/foundation.dropdownMenu.js","../../js/foundation.equalizer.js","../../js/foundation.interchange.js","../../js/foundation.smoothScroll.js","../../js/foundation.magellan.js","../../js/foundation.offcanvas.js","../../js/foundation.orbit.js","../../js/foundation.responsiveMenu.js","../../js/foundation.responsiveToggle.js","../../js/foundation.reveal.js","../../js/foundation.slider.js","../../js/foundation.sticky.js","../../js/foundation.tabs.js","../../js/foundation.toggler.js","../../js/foundation.tooltip.js","../../js/foundation.responsiveAccordionTabs.js","../../js/entries/foundation.js"],"sourcesContent":["\"use strict\";\n\nimport $ from 'jquery';\n\n// Core Foundation Utilities, utilized in a number of places.\n\n  /**\n   * Returns a boolean for RTL support\n   */\nfunction rtl() {\n  return $('html').attr('dir') === 'rtl';\n}\n\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\nfunction GetYoDigits(length, namespace){\n  length = length || 6;\n  return Math.round((Math.pow(36, length + 1) - Math.random() * Math.pow(36, length))).toString(36).slice(1) + (namespace ? `-${namespace}` : '');\n}\n\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\nfunction RegExpEscape(str){\n  return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem){\n  var transitions = {\n    'transition': 'transitionend',\n    'WebkitTransition': 'webkitTransitionEnd',\n    'MozTransition': 'transitionend',\n    'OTransition': 'otransitionend'\n  };\n  var elem = document.createElement('div'),\n      end;\n\n  for (var t in transitions){\n    if (typeof elem.style[t] !== 'undefined'){\n      end = transitions[t];\n    }\n  }\n  if(end){\n    return end;\n  }else{\n    end = setTimeout(function(){\n      $elem.triggerHandler('transitionend', [$elem]);\n    }, 1);\n    return 'transitionend';\n  }\n}\n\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\nfunction onLoad($elem, handler) {\n  const didLoad = document.readyState === 'complete';\n  const eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n  const cb = () => $elem.triggerHandler(eventType);\n\n  if ($elem) {\n    if (handler) $elem.one(eventType, handler);\n\n    if (didLoad)\n      setTimeout(cb);\n    else\n      $(window).one('load', cb);\n  }\n\n  return eventType;\n}\n\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n *   (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n *   outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\nfunction ignoreMousedisappear(handler, { ignoreLeaveWindow = false, ignoreReappear = false } = {}) {\n  return function leaveEventHandler(eLeave, ...rest) {\n    const callback = handler.bind(this, eLeave, ...rest);\n\n    // The mouse left: call the given callback if the mouse entered elsewhere\n    if (eLeave.relatedTarget !== null) {\n      return callback();\n    }\n\n    // Otherwise, check if the mouse actually left the window.\n    // In firefox if the user switched between windows, the window sill have the focus by the time\n    // the event is triggered. We have to debounce the event to test this case.\n    setTimeout(function leaveEventDebouncer() {\n      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n        return callback();\n      }\n\n      // Otherwise, wait for the mouse to reeapear outside of the element,\n      if (!ignoreReappear) {\n        $(document).one('mouseenter', function reenterEventHandler(eReenter) {\n          if (!$(eLeave.currentTarget).has(eReenter.target).length) {\n            // Fill where the mouse finally entered.\n            eLeave.relatedTarget = eReenter.target;\n            callback();\n          }\n        });\n      }\n\n    }, 0);\n  };\n}\n\nexport { rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear };\n","'use strict';\n\nimport $ from 'jquery';\n\n// Default set of media queries\nconst defaultQueries = {\n  'default' : 'only screen',\n  landscape : 'only screen and (orientation: landscape)',\n  portrait : 'only screen and (orientation: portrait)',\n  retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' +\n    'only screen and (min--moz-device-pixel-ratio: 2),' +\n    'only screen and (-o-min-device-pixel-ratio: 2/1),' +\n    'only screen and (min-device-pixel-ratio: 2),' +\n    'only screen and (min-resolution: 192dpi),' +\n    'only screen and (min-resolution: 2dppx)'\n  };\n\n\n// matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n/* eslint-disable */\nwindow.matchMedia || (window.matchMedia = (function () {\n  \"use strict\";\n\n  // For browsers that support matchMedium api such as IE 9 and webkit\n  var styleMedia = (window.styleMedia || window.media);\n\n  // For those that don't support matchMedium\n  if (!styleMedia) {\n    var style   = document.createElement('style'),\n    script      = document.getElementsByTagName('script')[0],\n    info        = null;\n\n    style.type  = 'text/css';\n    style.id    = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    }\n\n    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n    info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;\n\n    styleMedia = {\n      matchMedium: function (media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';\n\n        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        }\n\n        // Test if media query is true or false\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function(media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n})());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init() {\n    var self = this;\n    var $meta = $('meta.foundation-mq');\n    if(!$meta.length){\n      $('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = $('.foundation-mq').css('font-family');\n    var namedQueries;\n\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if(namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: `only screen and (min-width: ${namedQueries[key]})`\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is(size) {\n    size = size.trim().split(' ');\n    if(size.length > 1 && size[1] === 'only') {\n      if(size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get(size) {\n    for (var i in this.queries) {\n      if(this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (typeof matched === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher() {\n    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', () => {\n      var newSize = this._getCurrentSize(), currentSize = this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        this.current = newSize;\n\n        // Broadcast the media query change on the window\n        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n};\n\n\n\n// Thank you: https://github.com/sindresorhus/query-string\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function(ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key);\n\n    // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n    return ret;\n  }, {});\n\n  return styleObject;\n}\n\nexport {MediaQuery};\n","\"use strict\";\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\n\nvar FOUNDATION_VERSION = '6.5.3';\n\n// Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\nvar Foundation = {\n  version: FOUNDATION_VERSION,\n\n  /**\n   * Stores initialized plugins.\n   */\n  _plugins: {},\n\n  /**\n   * Stores generated unique ids for plugin instances\n   */\n  _uuids: [],\n\n  /**\n   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n   * @param {Object} plugin - The constructor of the plugin.\n   */\n  plugin: function(plugin, name) {\n    // Object key to use when adding to global Foundation object\n    // Examples: Foundation.Reveal, Foundation.OffCanvas\n    var className = (name || functionName(plugin));\n    // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n    // Examples: data-reveal, data-off-canvas\n    var attrName  = hyphenate(className);\n\n    // Add to the Foundation object and the plugins list (for reflowing)\n    this._plugins[attrName] = this[className] = plugin;\n  },\n  /**\n   * @function\n   * Populates the _uuids array with pointers to each individual plugin instance.\n   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n   * Also fires the initialization event for each plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @param {String} name - the name of the plugin, passed as a camelCased string.\n   * @fires Plugin#init\n   */\n  registerPlugin: function(plugin, name){\n    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n    plugin.uuid = GetYoDigits(6, pluginName);\n\n    if(!plugin.$element.attr(`data-${pluginName}`)){ plugin.$element.attr(`data-${pluginName}`, plugin.uuid); }\n    if(!plugin.$element.data('zfPlugin')){ plugin.$element.data('zfPlugin', plugin); }\n          /**\n           * Fires when the plugin has initialized.\n           * @event Plugin#init\n           */\n    plugin.$element.trigger(`init.zf.${pluginName}`);\n\n    this._uuids.push(plugin.uuid);\n\n    return;\n  },\n  /**\n   * @function\n   * Removes the plugins uuid from the _uuids array.\n   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n   * Also fires the destroyed event for the plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @fires Plugin#destroyed\n   */\n  unregisterPlugin: function(plugin){\n    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n    plugin.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n          /**\n           * Fires when the plugin has been destroyed.\n           * @event Plugin#destroyed\n           */\n          .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in plugin){\n      plugin[prop] = null;//clean up script to prep for garbage collection.\n    }\n    return;\n  },\n\n  /**\n   * @function\n   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n   * @default If no argument is passed, reflow all currently active plugins.\n   */\n   reInit: function(plugins){\n     var isJQ = plugins instanceof $;\n     try{\n       if(isJQ){\n         plugins.each(function(){\n           $(this).data('zfPlugin')._init();\n         });\n       }else{\n         var type = typeof plugins,\n         _this = this,\n         fns = {\n           'object': function(plgs){\n             plgs.forEach(function(p){\n               p = hyphenate(p);\n               $('[data-'+ p +']').foundation('_init');\n             });\n           },\n           'string': function(){\n             plugins = hyphenate(plugins);\n             $('[data-'+ plugins +']').foundation('_init');\n           },\n           'undefined': function(){\n             this['object'](Object.keys(_this._plugins));\n           }\n         };\n         fns[type](plugins);\n       }\n     }catch(err){\n       console.error(err);\n     }finally{\n       return plugins;\n     }\n   },\n\n  /**\n   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n   */\n  reflow: function(elem, plugins) {\n\n    // If plugins is undefined, just grab everything\n    if (typeof plugins === 'undefined') {\n      plugins = Object.keys(this._plugins);\n    }\n    // If plugins is a string, convert it to an array with one item\n    else if (typeof plugins === 'string') {\n      plugins = [plugins];\n    }\n\n    var _this = this;\n\n    // Iterate through each plugin\n    $.each(plugins, function(i, name) {\n      // Get the current plugin\n      var plugin = _this._plugins[name];\n\n      // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n      var $elem = $(elem).find('[data-'+name+']').addBack('[data-'+name+']');\n\n      // For each plugin found, initialize it\n      $elem.each(function() {\n        var $el = $(this),\n            opts = {};\n        // Don't double-dip on plugins\n        if ($el.data('zfPlugin')) {\n          console.warn(\"Tried to initialize \"+name+\" on an element that already has a Foundation plugin.\");\n          return;\n        }\n\n        if($el.attr('data-options')){\n          var thing = $el.attr('data-options').split(';').forEach(function(e, i){\n            var opt = e.split(':').map(function(el){ return el.trim(); });\n            if(opt[0]) opts[opt[0]] = parseValue(opt[1]);\n          });\n        }\n        try{\n          $el.data('zfPlugin', new plugin($(this), opts));\n        }catch(er){\n          console.error(er);\n        }finally{\n          return;\n        }\n      });\n    });\n  },\n  getFnName: functionName,\n\n  addToJquery: function($) {\n    // TODO: consider not making this a jQuery function\n    // TODO: need way to reflow vs. re-initialize\n    /**\n     * The Foundation jQuery method.\n     * @param {String|Array} method - An action to perform on the current jQuery object.\n     */\n    var foundation = function(method) {\n      var type = typeof method,\n          $noJS = $('.no-js');\n\n      if($noJS.length){\n        $noJS.removeClass('no-js');\n      }\n\n      if(type === 'undefined'){//needs to initialize the Foundation object, or an individual plugin.\n        MediaQuery._init();\n        Foundation.reflow(this);\n      }else if(type === 'string'){//an individual method to invoke on a plugin or group of plugins\n        var args = Array.prototype.slice.call(arguments, 1);//collect all the arguments, if necessary\n        var plugClass = this.data('zfPlugin');//determine the class of plugin\n\n        if(typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined'){//make sure both the class and method exist\n          if(this.length === 1){//if there's only one, call it directly.\n              plugClass[method].apply(plugClass, args);\n          }else{\n            this.each(function(i, el){//otherwise loop through the jQuery collection and invoke the method on each\n              plugClass[method].apply($(el).data('zfPlugin'), args);\n            });\n          }\n        }else{//error for no class or no method\n          throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n        }\n      }else{//error for invalid argument type\n        throw new TypeError(`We're sorry, ${type} is not a valid parameter. You must use a string representing the method you wish to invoke.`);\n      }\n      return this;\n    };\n    $.fn.foundation = foundation;\n    return $;\n  }\n};\n\nFoundation.util = {\n  /**\n   * Function for applying a debounce effect to a function call.\n   * @function\n   * @param {Function} func - Function to be called at end of timeout.\n   * @param {Number} delay - Time in ms to delay the call of `func`.\n   * @returns function\n   */\n  throttle: function (func, delay) {\n    var timer = null;\n\n    return function () {\n      var context = this, args = arguments;\n\n      if (timer === null) {\n        timer = setTimeout(function () {\n          func.apply(context, args);\n          timer = null;\n        }, delay);\n      }\n    };\n  }\n};\n\nwindow.Foundation = Foundation;\n\n// Polyfill for requestAnimationFrame\n(function() {\n  if (!Date.now || !window.Date.now)\n    window.Date.now = Date.now = function() { return new Date().getTime(); };\n\n  var vendors = ['webkit', 'moz'];\n  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n      var vp = vendors[i];\n      window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];\n      window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']\n                                 || window[vp+'CancelRequestAnimationFrame']);\n  }\n  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)\n    || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n    var lastTime = 0;\n    window.requestAnimationFrame = function(callback) {\n        var now = Date.now();\n        var nextTime = Math.max(lastTime + 16, now);\n        return setTimeout(function() { callback(lastTime = nextTime); },\n                          nextTime - now);\n    };\n    window.cancelAnimationFrame = clearTimeout;\n  }\n  /**\n   * Polyfill for performance.now, required by rAF\n   */\n  if(!window.performance || !window.performance.now){\n    window.performance = {\n      start: Date.now(),\n      now: function(){ return Date.now() - this.start; }\n    };\n  }\n})();\nif (!Function.prototype.bind) {\n  Function.prototype.bind = function(oThis) {\n    if (typeof this !== 'function') {\n      // closest thing possible to the ECMAScript 5\n      // internal IsCallable function\n      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n    }\n\n    var aArgs   = Array.prototype.slice.call(arguments, 1),\n        fToBind = this,\n        fNOP    = function() {},\n        fBound  = function() {\n          return fToBind.apply(this instanceof fNOP\n                 ? this\n                 : oThis,\n                 aArgs.concat(Array.prototype.slice.call(arguments)));\n        };\n\n    if (this.prototype) {\n      // native functions don't have a prototype\n      fNOP.prototype = this.prototype;\n    }\n    fBound.prototype = new fNOP();\n\n    return fBound;\n  };\n}\n// Polyfill to get the name of a function in IE9\nfunction functionName(fn) {\n  if (typeof Function.prototype.name === 'undefined') {\n    var funcNameRegex = /function\\s([^(]{1,})\\(/;\n    var results = (funcNameRegex).exec((fn).toString());\n    return (results && results.length > 1) ? results[1].trim() : \"\";\n  }\n  else if (typeof fn.prototype === 'undefined') {\n    return fn.constructor.name;\n  }\n  else {\n    return fn.prototype.constructor.name;\n  }\n}\nfunction parseValue(str){\n  if ('true' === str) return true;\n  else if ('false' === str) return false;\n  else if (!isNaN(str * 1)) return parseFloat(str);\n  return str;\n}\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nexport {Foundation};\n","'use strict';\n\n\nimport { rtl as Rtl } from \"./foundation.core.utils\";\n\nvar Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  OverlapArea: OverlapArea,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets,\n  GetExplicitOffsets: GetExplicitOffsets\n}\n\n/**\n * Compares the dimensions of an element to a container and determines collision events with container.\n * @function\n * @param {jQuery} element - jQuery object to test for collisions.\n * @param {jQuery} parent - jQuery object to use as bounding container.\n * @param {Boolean} lrOnly - set to true to check left and right values only.\n * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n * @default if no parent object passed, detects collisions with `window`.\n * @returns {Boolean} - true if collision free, false if a collision in any direction.\n */\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n};\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  var eleDims = GetDimensions(element),\n  topOver, bottomOver, leftOver, rightOver;\n  if (parent) {\n    var parDims = GetDimensions(parent);\n\n    bottomOver = (parDims.height + parDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - parDims.offset.top;\n    leftOver   = eleDims.offset.left - parDims.offset.left;\n    rightOver  = (parDims.width + parDims.offset.left) - (eleDims.offset.left + eleDims.width);\n  }\n  else {\n    bottomOver = (eleDims.windowDims.height + eleDims.windowDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - eleDims.windowDims.offset.top;\n    leftOver   = eleDims.offset.left - eleDims.windowDims.offset.left;\n    rightOver  = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n  }\n\n  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n  topOver    = Math.min(topOver, 0);\n  leftOver   = Math.min(leftOver, 0);\n  rightOver  = Math.min(rightOver, 0);\n\n  if (lrOnly) {\n    return leftOver + rightOver;\n  }\n  if (tbOnly) {\n    return topOver + bottomOver;\n  }\n\n  // use sum of squares b/c we care about overlap area.\n  return Math.sqrt((topOver * topOver) + (bottomOver * bottomOver) + (leftOver * leftOver) + (rightOver * rightOver));\n}\n\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\nfunction GetDimensions(elem){\n  elem = elem.length ? elem[0] : elem;\n\n  if (elem === window || elem === document) {\n    throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n  }\n\n  var rect = elem.getBoundingClientRect(),\n      parRect = elem.parentNode.getBoundingClientRect(),\n      winRect = document.body.getBoundingClientRect(),\n      winY = window.pageYOffset,\n      winX = window.pageXOffset;\n\n  return {\n    width: rect.width,\n    height: rect.height,\n    offset: {\n      top: rect.top + winY,\n      left: rect.left + winX\n    },\n    parentDims: {\n      width: parRect.width,\n      height: parRect.height,\n      offset: {\n        top: parRect.top + winY,\n        left: parRect.left + winX\n      }\n    },\n    windowDims: {\n      width: winRect.width,\n      height: winRect.height,\n      offset: {\n        top: winY,\n        left: winX\n      }\n    }\n  }\n}\n\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\nfunction GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {\n  console.log(\"NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5\");\n  switch (position) {\n    case 'top':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);\n    case 'bottom':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    case 'center top':\n      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);\n    case 'center bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);\n    case 'center left':\n      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);\n    case 'center right':\n      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);\n    case 'left bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);\n    case 'right bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    // Backwards compatibility... this along with the reveal and reveal full\n    // classes are the only ones that didn't reference anchor\n    case 'center':\n      return {\n        left: ($eleDims.windowDims.offset.left + ($eleDims.windowDims.width / 2)) - ($eleDims.width / 2) + hOffset,\n        top: ($eleDims.windowDims.offset.top + ($eleDims.windowDims.height / 2)) - ($eleDims.height / 2 + vOffset)\n      }\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + vOffset\n      }\n    case 'reveal full':\n      return {\n        left: $eleDims.windowDims.offset.left,\n        top: $eleDims.windowDims.offset.top\n      }\n      break;\n    default:\n      return {\n        left: (Rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset: $anchorDims.offset.left + hOffset),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n\n  }\n\n}\n\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n      var topVal, leftVal;\n\n  // set position related attribute\n\n  switch (position) {\n    case 'top':\n      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n      break;\n    case 'bottom':\n      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n      break;\n    case 'left':\n      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n      break;\n    case 'right':\n      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n      break;\n  }\n\n\n  // set alignment related attribute\n  switch (position) {\n    case 'top':\n    case 'bottom':\n      switch (alignment) {\n        case 'left':\n          leftVal = $anchorDims.offset.left + hOffset;\n          break;\n        case 'right':\n          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n          break;\n        case 'center':\n          leftVal = isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)) + hOffset;\n          break;\n      }\n      break;\n    case 'right':\n    case 'left':\n      switch (alignment) {\n        case 'bottom':\n          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n          break;\n        case 'top':\n          topVal = $anchorDims.offset.top + vOffset\n          break;\n        case 'center':\n          topVal = ($anchorDims.offset.top + vOffset + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n          break;\n      }\n      break;\n  }\n  return {top: topVal, left: leftVal};\n}\n\nexport {Box};\n","'use strict';\n\nimport $ from 'jquery';\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\nfunction onImagesLoaded(images, callback){\n  var self = this,\n      unloaded = images.length;\n\n  if (unloaded === 0) {\n    callback();\n  }\n\n  images.each(function(){\n    // Check if image is loaded\n    if (this.complete && typeof this.naturalWidth !== 'undefined') {\n      singleImageLoaded();\n    }\n    else {\n      // If the above check failed, simulate loading on detached element.\n      var image = new Image();\n      // Still count image as loaded if it finalizes with an error.\n      var events = \"load.zf.images error.zf.images\";\n      $(image).one(events, function me(event){\n        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n        $(this).off(events, me);\n        singleImageLoaded();\n      });\n      image.src = $(this).attr('src');\n    }\n  });\n\n  function singleImageLoaded() {\n    unloaded--;\n    if (unloaded === 0) {\n      callback();\n    }\n  }\n}\n\nexport { onImagesLoaded };\n","/*******************************************\n *                                         *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n *                                         *\n ******************************************/\n\n'use strict';\n\nimport $ from 'jquery';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  35: 'END',\n  36: 'HOME',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n}\n\nvar commands = {}\n\n// Functions pulled out to be referenceable from internals\nfunction findFocusable($element) {\n  if(!$element) {return false; }\n  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function() {\n    if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) { return false; } //only have visible elements and those that have a tabindex greater or equal 0\n    return true;\n  });\n}\n\nfunction parseKey(event) {\n  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();\n\n  // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n  key = key.replace(/\\W+/, '');\n\n  if (event.shiftKey) key = `SHIFT_${key}`;\n  if (event.ctrlKey) key = `CTRL_${key}`;\n  if (event.altKey) key = `ALT_${key}`;\n\n  // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n  key = key.replace(/_$/, '');\n\n  return key;\n}\n\nvar Keyboard = {\n  keys: getKeyCodes(keyCodes),\n\n  /**\n   * Parses the (keyboard) event and returns a String that represents its key\n   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n   * @param {Event} event - the event generated by the event handler\n   * @return String key - String that represents the key pressed\n   */\n  parseKey: parseKey,\n\n  /**\n   * Handles the given (keyboard) event\n   * @param {Event} event - the event generated by the event handler\n   * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n   * @param {Objects} functions - collection of functions that are to be executed\n   */\n  handleKey(event, component, functions) {\n    var commandList = commands[component],\n      keyCode = this.parseKey(event),\n      cmds,\n      command,\n      fn;\n\n    if (!commandList) return console.warn('Component not defined!');\n\n    if (typeof commandList.ltr === 'undefined') { // this component does not differentiate between ltr and rtl\n        cmds = commandList; // use plain list\n    } else { // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n        if (Rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);\n\n        else cmds = $.extend({}, commandList.rtl, commandList.ltr);\n    }\n    command = cmds[keyCode];\n\n    fn = functions[command];\n    if (fn && typeof fn === 'function') { // execute function  if exists\n      var returnValue = fn.apply();\n      if (functions.handled || typeof functions.handled === 'function') { // execute function when event was handled\n          functions.handled(returnValue);\n      }\n    } else {\n      if (functions.unhandled || typeof functions.unhandled === 'function') { // execute function when event was not handled\n          functions.unhandled();\n      }\n    }\n  },\n\n  /**\n   * Finds all focusable elements within the given `$element`\n   * @param {jQuery} $element - jQuery object to search within\n   * @return {jQuery} $focusable - all focusable elements within `$element`\n   */\n\n  findFocusable: findFocusable,\n\n  /**\n   * Returns the component name name\n   * @param {Object} component - Foundation component, e.g. Slider or Reveal\n   * @return String componentName\n   */\n\n  register(componentName, cmds) {\n    commands[componentName] = cmds;\n  },\n\n\n  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n  //\n  /**\n   * Traps the focus in the given element.\n   * @param  {jQuery} $element  jQuery object to trap the foucs into.\n   */\n  trapFocus($element) {\n    var $focusable = findFocusable($element),\n        $firstFocusable = $focusable.eq(0),\n        $lastFocusable = $focusable.eq(-1);\n\n    $element.on('keydown.zf.trapfocus', function(event) {\n      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      }\n      else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n        event.preventDefault();\n        $lastFocusable.focus();\n      }\n    });\n  },\n  /**\n   * Releases the trapped focus from the given element.\n   * @param  {jQuery} $element  jQuery object to release the focus for.\n   */\n  releaseFocus($element) {\n    $element.off('keydown.zf.trapfocus');\n  }\n}\n\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\nfunction getKeyCodes(kcs) {\n  var k = {};\n  for (var kc in kcs) k[kcs[kc]] = kcs[kc];\n  return k;\n}\n\nexport {Keyboard};\n","'use strict';\n\nimport $ from 'jquery';\nimport { transitionend } from './foundation.core.utils';\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nconst initClasses   = ['mui-enter', 'mui-leave'];\nconst activeClasses = ['mui-enter-active', 'mui-leave-active'];\n\nconst Motion = {\n  animateIn: function(element, animation, cb) {\n    animate(true, element, animation, cb);\n  },\n\n  animateOut: function(element, animation, cb) {\n    animate(false, element, animation, cb);\n  }\n}\n\nfunction Move(duration, elem, fn){\n  var anim, prog, start = null;\n  // console.log('called');\n\n  if (duration === 0) {\n    fn.apply(elem);\n    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    return;\n  }\n\n  function move(ts){\n    if(!start) start = ts;\n    // console.log(start, ts);\n    prog = ts - start;\n    fn.apply(elem);\n\n    if(prog < duration){ anim = window.requestAnimationFrame(move, elem); }\n    else{\n      window.cancelAnimationFrame(anim);\n      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    }\n  }\n  anim = window.requestAnimationFrame(move);\n}\n\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\nfunction animate(isIn, element, animation, cb) {\n  element = $(element).eq(0);\n\n  if (!element.length) return;\n\n  var initClass = isIn ? initClasses[0] : initClasses[1];\n  var activeClass = isIn ? activeClasses[0] : activeClasses[1];\n\n  // Set up the animation\n  reset();\n\n  element\n    .addClass(animation)\n    .css('transition', 'none');\n\n  requestAnimationFrame(() => {\n    element.addClass(initClass);\n    if (isIn) element.show();\n  });\n\n  // Start the animation\n  requestAnimationFrame(() => {\n    element[0].offsetWidth;\n    element\n      .css('transition', '')\n      .addClass(activeClass);\n  });\n\n  // Clean up the animation when it finishes\n  element.one(transitionend(element), finish);\n\n  // Hides the element (for out animations), resets the element, and runs a callback\n  function finish() {\n    if (!isIn) element.hide();\n    reset();\n    if (cb) cb.apply(element);\n  }\n\n  // Resets transitions and removes motion-specific classes\n  function reset() {\n    element[0].style.transitionDuration = 0;\n    element.removeClass(`${initClass} ${activeClass} ${animation}`);\n  }\n}\n\nexport { Move, Motion };\n\n","'use strict';\n\nimport $ from 'jquery';\n\nconst Nest = {\n  Feather(menu, type = 'zf') {\n    menu.attr('role', 'menubar');\n\n    var items = menu.find('li').attr({'role': 'menuitem'}),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`,\n        applyAria = (type !== 'accordion'); // Accordions handle their own ARIA attriutes.\n\n    items.each(function() {\n      var $item = $(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item.addClass(hasSubClass);\n        if(applyAria) {\n          $item.attr({\n            'aria-haspopup': true,\n            'aria-label': $item.children('a:first').text()\n          });\n          // Note:  Drilldowns behave differently in how they hide, and so need\n          // additional attributes.  We should look if this possibly over-generalized\n          // utility (Nest) is appropriate when we rework menus in 6.4\n          if(type === 'drilldown') {\n            $item.attr({'aria-expanded': false});\n          }\n        }\n        $sub\n          .addClass(`submenu ${subMenuClass}`)\n          .attr({\n            'data-submenu': '',\n            'role': 'menubar'\n          });\n        if(type === 'drilldown') {\n          $sub.attr({'aria-hidden': true});\n        }\n      }\n\n      if ($item.parent('[data-submenu]').length) {\n        $item.addClass(`is-submenu-item ${subItemClass}`);\n      }\n    });\n\n    return;\n  },\n\n  Burn(menu, type) {\n    var //items = menu.find('li'),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`;\n\n    menu\n      .find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li')\n      .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n      .removeAttr('data-submenu').css('display', '');\n\n  }\n}\n\nexport {Nest};\n","'use strict';\n\nimport $ from 'jquery';\n\nfunction Timer(elem, options, cb) {\n  var _this = this,\n      duration = options.duration,//options is an object for easily adding features later.\n      nameSpace = Object.keys(elem.data())[0] || 'timer',\n      remain = -1,\n      start,\n      timer;\n\n  this.isPaused = false;\n\n  this.restart = function() {\n    remain = -1;\n    clearTimeout(timer);\n    this.start();\n  }\n\n  this.start = function() {\n    this.isPaused = false;\n    // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    remain = remain <= 0 ? duration : remain;\n    elem.data('paused', false);\n    start = Date.now();\n    timer = setTimeout(function(){\n      if(options.infinite){\n        _this.restart();//rerun the timer.\n      }\n      if (cb && typeof cb === 'function') { cb(); }\n    }, remain);\n    elem.trigger(`timerstart.zf.${nameSpace}`);\n  }\n\n  this.pause = function() {\n    this.isPaused = true;\n    //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    elem.data('paused', true);\n    var end = Date.now();\n    remain = remain - (end - start);\n    elem.trigger(`timerpaused.zf.${nameSpace}`);\n  }\n}\n\nexport {Timer};\n","//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nimport $ from 'jquery';\n\nvar Touch = {};\n\nvar startPosX,\n    startPosY,\n    startTime,\n    elapsedTime,\n    startEvent,\n    isMoving = false,\n    didMoved = false;\n\nfunction onTouchEnd(e) {\n  this.removeEventListener('touchmove', onTouchMove);\n  this.removeEventListener('touchend', onTouchEnd);\n\n  // If the touch did not move, consider it as a \"tap\"\n  if (!didMoved) {\n    var tapEvent = $.Event('tap', startEvent || e);\n    $(this).trigger(tapEvent);\n  }\n\n  startEvent = null;\n  isMoving = false;\n  didMoved = false;\n}\n\nfunction onTouchMove(e) {\n  if ($.spotSwipe.preventDefault) { e.preventDefault(); }\n\n  if(isMoving) {\n    var x = e.touches[0].pageX;\n    var y = e.touches[0].pageY;\n    var dx = startPosX - x;\n    var dy = startPosY - y;\n    var dir;\n    didMoved = true;\n    elapsedTime = new Date().getTime() - startTime;\n    if(Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n      dir = dx > 0 ? 'left' : 'right';\n    }\n    // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n    //   dir = dy > 0 ? 'down' : 'up';\n    // }\n    if(dir) {\n      e.preventDefault();\n      onTouchEnd.apply(this, arguments);\n      $(this)\n        .trigger($.Event('swipe', e), dir)\n        .trigger($.Event(`swipe${dir}`, e));\n    }\n  }\n\n}\n\nfunction onTouchStart(e) {\n\n  if (e.touches.length == 1) {\n    startPosX = e.touches[0].pageX;\n    startPosY = e.touches[0].pageY;\n    startEvent = e;\n    isMoving = true;\n    didMoved = false;\n    startTime = new Date().getTime();\n    this.addEventListener('touchmove', onTouchMove, false);\n    this.addEventListener('touchend', onTouchEnd, false);\n  }\n}\n\nfunction init() {\n  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);\n}\n\nfunction teardown() {\n  this.removeEventListener('touchstart', onTouchStart);\n}\n\nclass SpotSwipe {\n  constructor($) {\n    this.version = '1.0.0';\n    this.enabled = 'ontouchstart' in document.documentElement;\n    this.preventDefault = false;\n    this.moveThreshold = 75;\n    this.timeThreshold = 200;\n    this.$ = $;\n    this._init();\n  }\n\n  _init() {\n    var $ = this.$;\n    $.event.special.swipe = { setup: init };\n    $.event.special.tap = { setup: init };\n\n    $.each(['left', 'up', 'down', 'right'], function () {\n      $.event.special[`swipe${this}`] = { setup: function(){\n        $(this).on('swipe', $.noop);\n      } };\n    });\n  }\n}\n\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and    *\n * setupTouchHandler should be idempotent,          *\n * because they directly replace functions &        *\n * values, and do not add event handlers directly.  *\n ****************************************************/\n\nTouch.setupSpotSwipe = function($) {\n  $.spotSwipe = new SpotSwipe($);\n};\n\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\nTouch.setupTouchHandler = function($) {\n  $.fn.addTouch = function(){\n    this.each(function(i,el){\n      $(el).bind('touchstart touchmove touchend touchcancel', function(event)  {\n        //we pass the original event object because the jQuery event\n        //object is normalized to w3c specs and does not provide the TouchList\n        handleTouch(event);\n      });\n    });\n\n    var handleTouch = function(event){\n      var touches = event.changedTouches,\n          first = touches[0],\n          eventTypes = {\n            touchstart: 'mousedown',\n            touchmove: 'mousemove',\n            touchend: 'mouseup'\n          },\n          type = eventTypes[event.type],\n          simulatedEvent\n        ;\n\n      if('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n        simulatedEvent = new window.MouseEvent(type, {\n          'bubbles': true,\n          'cancelable': true,\n          'screenX': first.screenX,\n          'screenY': first.screenY,\n          'clientX': first.clientX,\n          'clientY': first.clientY\n        });\n      } else {\n        simulatedEvent = document.createEvent('MouseEvent');\n        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0/*left*/, null);\n      }\n      first.target.dispatchEvent(simulatedEvent);\n    };\n  };\n};\n\nTouch.init = function ($) {\n\n  if(typeof($.spotSwipe) === 'undefined') {\n    Touch.setupSpotSwipe($);\n    Touch.setupTouchHandler($);\n  }\n};\n\nexport {Touch};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","'use strict';\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\n\n// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\nclass Plugin {\n\n  constructor(element, options) {\n    this._setup(element, options);\n    var pluginName = getPluginName(this);\n    this.uuid = GetYoDigits(6, pluginName);\n\n    if(!this.$element.attr(`data-${pluginName}`)){ this.$element.attr(`data-${pluginName}`, this.uuid); }\n    if(!this.$element.data('zfPlugin')){ this.$element.data('zfPlugin', this); }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n    this.$element.trigger(`init.zf.${pluginName}`);\n  }\n\n  destroy() {\n    this._destroy();\n    var pluginName = getPluginName(this);\n    this.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n        /**\n         * Fires when the plugin has been destroyed.\n         * @event Plugin#destroyed\n         */\n        .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in this){\n      this[prop] = null;//clean up script to prep for garbage collection.\n    }\n  }\n}\n\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n  if(typeof(obj.constructor.name) !== 'undefined') {\n    return hyphenate(obj.constructor.name);\n  } else {\n    return hyphenate(obj.className);\n  }\n}\n\nexport {Plugin};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nclass Abide extends Plugin {\n  /**\n   * Creates a new instance of Abide.\n   * @class\n   * @name Abide\n   * @fires Abide#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options = {}) {\n    this.$element = element;\n    this.options  = $.extend(true, {}, Abide.defaults, this.$element.data(), options);\n\n    this.className = 'Abide'; // ie9 back compat\n    this._init();\n  }\n\n  /**\n   * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n   * @private\n   */\n  _init() {\n    this.$inputs = $.merge(                               // Consider as input to validate:\n      this.$element.find('input').not('[type=submit]'),   // * all input fields expect submit\n      this.$element.find('textarea, select')              // * all textareas and select fields\n    );\n    const $globalErrors = this.$element.find('[data-abide-error]');\n\n    // Add a11y attributes to all fields\n    if (this.options.a11yAttributes) {\n      this.$inputs.each((i, input) => this.addA11yAttributes($(input)));\n      $globalErrors.each((i, error) => this.addGlobalErrorA11yAttributes($(error)));\n    }\n\n    this._events();\n  }\n\n  /**\n   * Initializes events for Abide.\n   * @private\n   */\n  _events() {\n    this.$element.off('.abide')\n      .on('reset.zf.abide', () => {\n        this.resetForm();\n      })\n      .on('submit.zf.abide', () => {\n        return this.validateForm();\n      });\n\n    if (this.options.validateOn === 'fieldChange') {\n      this.$inputs\n        .off('change.zf.abide')\n        .on('change.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.liveValidate) {\n      this.$inputs\n        .off('input.zf.abide')\n        .on('input.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.validateOnBlur) {\n      this.$inputs\n        .off('blur.zf.abide')\n        .on('blur.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n  }\n\n  /**\n   * Calls necessary functions to update Abide upon DOM change\n   * @private\n   */\n  _reflow() {\n    this._init();\n  }\n\n  /**\n   * Checks whether or not a form element has the required attribute and if it's checked or not\n   * @param {Object} element - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  requiredCheck($el) {\n    if (!$el.attr('required')) return true;\n\n    var isGood = true;\n\n    switch ($el[0].type) {\n      case 'checkbox':\n        isGood = $el[0].checked;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        var opt = $el.find('option:selected');\n        if (!opt.length || !opt.val()) isGood = false;\n        break;\n\n      default:\n        if(!$el.val() || !$el.val().length) isGood = false;\n    }\n\n    return isGood;\n  }\n\n  /**\n   * Get:\n   * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n   *   1. The element's direct sibling('s).\n   *   2. The element's parent's children.\n   * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n   *\n   * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n   *\n   * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n   * @returns {Object} jQuery object with the selector.\n   */\n  findFormError($el) {\n    var id = $el[0].id;\n    var $error = $el.siblings(this.options.formErrorSelector);\n\n    if (!$error.length) {\n      $error = $el.parent().find(this.options.formErrorSelector);\n    }\n\n    if (id) {\n      $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"]`));\n    }\n\n    return $error;\n  }\n\n  /**\n   * Get the first element in this order:\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findLabel($el) {\n    var id = $el[0].id;\n    var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n    if (!$label.length) {\n      return $el.closest('label');\n    }\n\n    return $label;\n  }\n\n  /**\n   * Get the set of labels associated with a set of radio els in this order\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findRadioLabels($els) {\n    var labels = $els.map((i, el) => {\n      var id = el.id;\n      var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n      if (!$label.length) {\n        $label = $(el).closest('label');\n      }\n      return $label[0];\n    });\n\n    return $(labels);\n  }\n\n  /**\n   * Adds the CSS error class as specified by the Abide settings to the label, input, and the form\n   * @param {Object} $el - jQuery object to add the class to\n   */\n  addErrorClasses($el) {\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.addClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.addClass(this.options.formErrorClass);\n    }\n\n    $el.addClass(this.options.inputErrorClass).attr({\n      'data-invalid': '',\n      'aria-invalid': true\n    });\n  }\n\n  /**\n   * Adds [for] and [role=alert] attributes to all form error targetting $el,\n   * and [aria-describedby] attribute to $el toward the first form error.\n   * @param {Object} $el - jQuery object\n   */\n  addA11yAttributes($el) {\n    let $errors = this.findFormError($el);\n    let $labels = $errors.filter('label');\n    let $error = $errors.first();\n    if (!$errors.length) return;\n\n    // Set [aria-describedby] on the input toward the first form error if it is not set\n    if (typeof $el.attr('aria-describedby') === 'undefined') {\n      // Get the first error ID or create one\n      let errorId = $error.attr('id');\n      if (typeof errorId === 'undefined') {\n        errorId = GetYoDigits(6, 'abide-error');\n        $error.attr('id', errorId);\n      };\n\n      $el.attr('aria-describedby', errorId);\n    }\n\n    if ($labels.filter('[for]').length < $labels.length) {\n      // Get the input ID or create one\n      let elemId = $el.attr('id');\n      if (typeof elemId === 'undefined') {\n        elemId = GetYoDigits(6, 'abide-input');\n        $el.attr('id', elemId);\n      };\n\n      // For each label targeting $el, set [for] if it is not set.\n      $labels.each((i, label) => {\n        const $label = $(label);\n        if (typeof $label.attr('for') === 'undefined')\n          $label.attr('for', elemId);\n      });\n    }\n\n    // For each error targeting $el, set [role=alert] if it is not set.\n    $errors.each((i, label) => {\n      const $label = $(label);\n      if (typeof $label.attr('role') === 'undefined')\n        $label.attr('role', 'alert');\n    }).end();\n  }\n\n  /**\n   * Adds [aria-live] attribute to the given global form error $el.\n   * @param {Object} $el - jQuery object to add the attribute to\n   */\n  addGlobalErrorA11yAttributes($el) {\n    if (typeof $el.attr('aria-live') === 'undefined')\n      $el.attr('aria-live', this.options.a11yErrorLevel);\n  }\n\n  /**\n   * Remove CSS error classes etc from an entire radio button group\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   *\n   */\n  removeRadioErrorClasses(groupName) {\n    var $els = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var $labels = this.findRadioLabels($els);\n    var $formErrors = this.findFormError($els);\n\n    if ($labels.length) {\n      $labels.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formErrors.length) {\n      $formErrors.removeClass(this.options.formErrorClass);\n    }\n\n    $els.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n\n  }\n\n  /**\n   * Removes CSS error class as specified by the Abide settings from the label, input, and the form\n   * @param {Object} $el - jQuery object to remove the class from\n   */\n  removeErrorClasses($el) {\n    // radios need to clear all of the els\n    if($el[0].type == 'radio') {\n      return this.removeRadioErrorClasses($el.attr('name'));\n    }\n\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.removeClass(this.options.formErrorClass);\n    }\n\n    $el.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n  }\n\n  /**\n   * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.\n   * Ignores inputs with data-abide-ignore, type=\"hidden\" or disabled attributes set\n   * @fires Abide#invalid\n   * @fires Abide#valid\n   * @param {Object} element - jQuery object to validate, should be an HTML input\n   * @returns {Boolean} goodToGo - If the input is valid or not.\n   */\n  validateInput($el) {\n    var clearRequire = this.requiredCheck($el),\n        validated = false,\n        customValidator = true,\n        validator = $el.attr('data-validator'),\n        equalTo = true;\n\n    // don't validate ignored inputs or hidden inputs or disabled inputs\n    if ($el.is('[data-abide-ignore]') || $el.is('[type=\"hidden\"]') || $el.is('[disabled]')) {\n      return true;\n    }\n\n    switch ($el[0].type) {\n      case 'radio':\n        validated = this.validateRadio($el.attr('name'));\n        break;\n\n      case 'checkbox':\n        validated = clearRequire;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        validated = clearRequire;\n        break;\n\n      default:\n        validated = this.validateText($el);\n    }\n\n    if (validator) {\n      customValidator = this.matchValidation($el, validator, $el.attr('required'));\n    }\n\n    if ($el.attr('data-equalto')) {\n      equalTo = this.options.validators.equalTo($el);\n    }\n\n\n    var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;\n    var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';\n\n    if (goodToGo) {\n      // Re-validate inputs that depend on this one with equalto\n      const dependentElements = this.$element.find(`[data-equalto=\"${$el.attr('id')}\"]`);\n      if (dependentElements.length) {\n        let _this = this;\n        dependentElements.each(function() {\n          if ($(this).val()) {\n            _this.validateInput($(this));\n          }\n        });\n      }\n    }\n\n    this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);\n\n    /**\n     * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`\n     * Trigger includes the DOM element of the input.\n     * @event Abide#valid\n     * @event Abide#invalid\n     */\n    $el.trigger(message, [$el]);\n\n    return goodToGo;\n  }\n\n  /**\n   * Goes through a form and if there are any invalid inputs, it will display the form error element\n   * @returns {Boolean} noError - true if no errors were detected...\n   * @fires Abide#formvalid\n   * @fires Abide#forminvalid\n   */\n  validateForm() {\n    var acc = [];\n    var _this = this;\n\n    this.$inputs.each(function() {\n      acc.push(_this.validateInput($(this)));\n    });\n\n    var noError = acc.indexOf(false) === -1;\n\n    this.$element.find('[data-abide-error]').each((i, elem) => {\n      const $elem = $(elem);\n      // Ensure a11y attributes are set\n      if (this.options.a11yAttributes) this.addGlobalErrorA11yAttributes($elem);\n      // Show or hide the error\n      $elem.css('display', (noError ? 'none' : 'block'));\n    });\n\n    /**\n     * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.\n     * Trigger includes the element of the form.\n     * @event Abide#formvalid\n     * @event Abide#forminvalid\n     */\n    this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);\n\n    return noError;\n  }\n\n  /**\n   * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.\n   * @param {Object} $el - jQuery object to validate, should be a text input HTML element\n   * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns\n   * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified\n   */\n  validateText($el, pattern) {\n    // A pattern can be passed to this function, or it will be infered from the input's \"pattern\" attribute, or it's \"type\" attribute\n    pattern = (pattern || $el.attr('pattern') || $el.attr('type'));\n    var inputText = $el.val();\n    var valid = false;\n\n    if (inputText.length) {\n      // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp\n      if (this.options.patterns.hasOwnProperty(pattern)) {\n        valid = this.options.patterns[pattern].test(inputText);\n      }\n      // If the pattern name isn't also the type attribute of the field, then test it as a regexp\n      else if (pattern !== $el.attr('type')) {\n        valid = new RegExp(pattern).test(inputText);\n      }\n      else {\n        valid = true;\n      }\n    }\n    // An empty field is valid if it's not required\n    else if (!$el.prop('required')) {\n      valid = true;\n    }\n\n    return valid;\n   }\n\n  /**\n   * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)\n   */\n  validateRadio(groupName) {\n    // If at least one radio in the group has the `required` attribute, the group is considered required\n    // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice\n    var $group = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var valid = false, required = false;\n\n    // For the group to be required, at least one radio needs to be required\n    $group.each((i, e) => {\n      if ($(e).attr('required')) {\n        required = true;\n      }\n    });\n    if(!required) valid=true;\n\n    if (!valid) {\n      // For the group to be valid, at least one radio needs to be checked\n      $group.each((i, e) => {\n        if ($(e).prop('checked')) {\n          valid = true;\n        }\n      });\n    };\n\n    return valid;\n  }\n\n  /**\n   * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator=\"foo bar baz\"` in a space separated listed.\n   * @param {Object} $el - jQuery input element.\n   * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.\n   * @param {Boolean} required - self explanatory?\n   * @returns {Boolean} - true if validations passed.\n   */\n  matchValidation($el, validators, required) {\n    required = required ? true : false;\n\n    var clear = validators.split(' ').map((v) => {\n      return this.options.validators[v]($el, required, $el.parent());\n    });\n    return clear.indexOf(false) === -1;\n  }\n\n  /**\n   * Resets form inputs and styles\n   * @fires Abide#formreset\n   */\n  resetForm() {\n    var $form = this.$element,\n        opts = this.options;\n\n    $(`.${opts.labelErrorClass}`, $form).not('small').removeClass(opts.labelErrorClass);\n    $(`.${opts.inputErrorClass}`, $form).not('small').removeClass(opts.inputErrorClass);\n    $(`${opts.formErrorSelector}.${opts.formErrorClass}`).removeClass(opts.formErrorClass);\n    $form.find('[data-abide-error]').css('display', 'none');\n    $(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:radio', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    /**\n     * Fires when the form has been reset.\n     * @event Abide#formreset\n     */\n    $form.trigger('formreset.zf.abide', [$form]);\n  }\n\n  /**\n   * Destroys an instance of Abide.\n   * Removes error styles and classes from elements, without resetting their values.\n   */\n  _destroy() {\n    var _this = this;\n    this.$element\n      .off('.abide')\n      .find('[data-abide-error]')\n        .css('display', 'none');\n\n    this.$inputs\n      .off('.abide')\n      .each(function() {\n        _this.removeErrorClasses($(this));\n      });\n  }\n}\n\n/**\n * Default settings for plugin\n */\nAbide.defaults = {\n  /**\n   * The default event to validate inputs. Checkboxes and radios validate immediately.\n   * Remove or change this value for manual validation.\n   * @option\n   * @type {?string}\n   * @default 'fieldChange'\n   */\n  validateOn: 'fieldChange',\n\n  /**\n   * Class to be applied to input labels on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-label'\n   */\n  labelErrorClass: 'is-invalid-label',\n\n  /**\n   * Class to be applied to inputs on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-input'\n   */\n  inputErrorClass: 'is-invalid-input',\n\n  /**\n   * Class selector to use to target Form Errors for show/hide.\n   * @option\n   * @type {string}\n   * @default '.form-error'\n   */\n  formErrorSelector: '.form-error',\n\n  /**\n   * Class added to Form Errors on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-visible'\n   */\n  formErrorClass: 'is-visible',\n\n  /**\n   * If true, automatically insert when possible:\n   * - `[aria-describedby]` on fields\n   * - `[role=alert]` on form errors and `[for]` on form error labels\n   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  a11yAttributes: true,\n\n  /**\n   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.\n   * Options are: 'assertive', 'polite' and 'off'/null\n   * @option\n   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions\n   * @type {string}\n   * @default 'assertive'\n   */\n  a11yErrorLevel: 'assertive',\n\n  /**\n   * Set to true to validate text inputs on any value change.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  liveValidate: false,\n\n  /**\n   * Set to true to validate inputs on blur.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  validateOnBlur: false,\n\n  patterns: {\n    alpha : /^[a-zA-Z]+$/,\n    alpha_numeric : /^[a-zA-Z0-9]+$/,\n    integer : /^[-+]?\\d+$/,\n    number : /^[-+]?\\d*(?:[\\.\\,]\\d+)?$/,\n\n    // amex, visa, diners\n    card : /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\\d{3})\\d{11})$/,\n    cvv : /^([0-9]){3,4}$/,\n\n    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address\n    email : /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,\n\n    // From CommonRegexJS (@talyssonoc)\n    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76\n    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.\n    url: /^((?:(https?|ftps?|file|ssh|sftp):\\/\\/|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}\\/)(?:[^\\s()<>]+|\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\))+(?:\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:\\'\".,<>?\\xab\\xbb\\u201c\\u201d\\u2018\\u2019]))$/,\n\n    // abc.de\n    domain : /^([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,8}$/,\n\n    datetime : /^([0-2][0-9]{3})\\-([0-1][0-9])\\-([0-3][0-9])T([0-5][0-9])\\:([0-5][0-9])\\:([0-5][0-9])(Z|([\\-\\+]([0-1][0-9])\\:00))$/,\n    // YYYY-MM-DD\n    date : /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,\n    // HH:MM:SS\n    time : /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,\n    dateISO : /^\\d{4}[\\/\\-]\\d{1,2}[\\/\\-]\\d{1,2}$/,\n    // MM/DD/YYYY\n    month_day_year : /^(0[1-9]|1[012])[- \\/.](0[1-9]|[12][0-9]|3[01])[- \\/.]\\d{4}$/,\n    // DD/MM/YYYY\n    day_month_year : /^(0[1-9]|[12][0-9]|3[01])[- \\/.](0[1-9]|1[012])[- \\/.]\\d{4}$/,\n\n    // #FFF or #FFFFFF\n    color : /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,\n\n    // Domain || URL\n    website: {\n      test: (text) => {\n        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);\n      }\n    }\n  },\n\n  /**\n   * Optional validation functions to be used. `equalTo` being the only default included function.\n   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:\n   * el : The jQuery element to validate.\n   * required : Boolean value of the required attribute be present or not.\n   * parent : The direct parent of the input.\n   * @option\n   */\n  validators: {\n    equalTo: function (el, required, parent) {\n      return $(`#${el.attr('data-equalto')}`).val() === el.val();\n    }\n  }\n}\n\nexport {Abide};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Accordion module.\n * @module foundation.accordion\n * @requires foundation.util.keyboard\n */\n\nclass Accordion extends Plugin {\n  /**\n   * Creates a new instance of an accordion.\n   * @class\n   * @name Accordion\n   * @fires Accordion#init\n   * @param {jQuery} element - jQuery object to make into an accordion.\n   * @param {Object} options - a plain object with settings to override the default options.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);\n\n    this.className = 'Accordion'; // ie9 back compat\n    this._init();\n\n    Keyboard.register('Accordion', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_DOWN': 'next',\n      'ARROW_UP': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the accordion by animating the preset active pane(s).\n   * @private\n   */\n  _init() {\n    this._isInitializing = true;\n\n    this.$element.attr('role', 'tablist');\n    this.$tabs = this.$element.children('[data-accordion-item]');\n\n    this.$tabs.each(function(idx, el) {\n      var $el = $(el),\n          $content = $el.children('[data-tab-content]'),\n          id = $content[0].id || GetYoDigits(6, 'accordion'),\n          linkId = (el.id) ? `${el.id}-label` : `${id}-label`;\n\n      $el.find('a:first').attr({\n        'aria-controls': id,\n        'role': 'tab',\n        'id': linkId,\n        'aria-expanded': false,\n        'aria-selected': false\n      });\n\n      $content.attr({'role': 'tabpanel', 'aria-labelledby': linkId, 'aria-hidden': true, 'id': id});\n    });\n\n    var $initActive = this.$element.find('.is-active').children('[data-tab-content]');\n    if ($initActive.length) {\n      // Save up the initial hash to return to it later when going back in history\n      this._initialAnchor = $initActive.prev('a').attr('href');\n      this._openSingleTab($initActive);\n    }\n\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find(`[href$=\"${anchor}\"]`);\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, open it (if not already active)\n      if ($anchor && $link && $link.length) {\n        if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {\n          this._openSingleTab($anchor);\n        };\n      }\n      // Otherwise, close everything\n      else {\n        this._closeAllTabs();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          onLoad($(window), () => {\n            var offset = this.$element.offset();\n            $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n          });\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Accordion#deeplink\n         */\n        this.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the accordion.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$tabs.each(function() {\n      var $elem = $(this);\n      var $tabContent = $elem.children('[data-tab-content]');\n      if ($tabContent.length) {\n        $elem.children('a').off('click.zf.accordion keydown.zf.accordion')\n               .on('click.zf.accordion', function(e) {\n          e.preventDefault();\n          _this.toggle($tabContent);\n        }).on('keydown.zf.accordion', function(e){\n          Keyboard.handleKey(e, 'Accordion', {\n            toggle: function() {\n              _this.toggle($tabContent);\n            },\n            next: function() {\n              var $a = $elem.next().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            previous: function() {\n              var $a = $elem.prev().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            handled: function() {\n              e.preventDefault();\n              e.stopPropagation();\n            }\n          });\n        });\n      }\n    });\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Toggles the selected content pane's open/close state.\n   * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).\n   * @function\n   */\n  toggle($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]')) {\n      console.info('Cannot toggle an accordion that is disabled.');\n      return;\n    }\n    if($target.parent().hasClass('is-active')) {\n      this.up($target);\n    } else {\n      this.down($target);\n    }\n    //either replace or update browser history\n    if (this.options.deepLink) {\n      var anchor = $target.prev('a').attr('href');\n\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n  }\n\n  /**\n   * Opens the accordion tab defined by `$target`.\n   * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   */\n  down($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]'))  {\n      console.info('Cannot call down on an accordion that is disabled.');\n      return;\n    }\n\n    if (this.options.multiExpand)\n      this._openTab($target);\n    else\n      this._openSingleTab($target);\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * It may be ignored if the Accordion options don't allow it.\n   *\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   */\n  up($target) {\n    if (this.$element.is('[disabled]')) {\n      console.info('Cannot call up on an accordion that is disabled.');\n      return;\n    }\n\n    // Don't close the item if it is already closed\n    const $targetItem = $target.parent();\n    if (!$targetItem.hasClass('is-active')) return;\n\n    // Don't close the item if there is no other active item (unless with `allowAllClosed`)\n    const $othersItems = $targetItem.siblings();\n    if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;\n\n    this._closeTab($target);\n  }\n\n  /**\n   * Make the tab defined by `$target` the only opened tab, closing all others tabs.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @function\n   * @private\n   */\n  _openSingleTab($target) {\n    // Close all the others active tabs.\n    const $activeContents = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeContents.length) {\n      this._closeTab($activeContents.not($target));\n    }\n\n    // Then open the target.\n    this._openTab($target);\n  }\n\n  /**\n   * Opens the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   * @private\n   */\n  _openTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', false);\n    $targetItem.addClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n      'aria-expanded': true,\n      'aria-selected': true\n    });\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done opening.\n       * @event Accordion#down\n       */\n      this.$element.trigger('down.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', true)\n    $targetItem.removeClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n     'aria-expanded': false,\n     'aria-selected': false\n    });\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done collapsing up.\n       * @event Accordion#up\n       */\n      this.$element.trigger('up.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes all active tabs\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeAllTabs() {\n    var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeTabs.length) {\n      this._closeTab($activeTabs);\n    }\n  }\n\n  /**\n   * Destroys an instance of an accordion.\n   * @fires Accordion#destroyed\n   * @function\n   */\n  _destroy() {\n    this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');\n    this.$element.find('a').off('.zf.accordion');\n    if(this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n  }\n}\n\nAccordion.defaults = {\n  /**\n   * Amount of time to animate the opening of an accordion pane.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Allow the accordion to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multiExpand: false,\n  /**\n   * Allow the accordion to close all panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowAllClosed: false,\n  /**\n   * Link the location hash to the open pane.\n   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open accordion\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false\n};\n\nexport {Accordion};\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n */\n\nclass AccordionMenu extends Plugin {\n  /**\n   * Creates a new instance of an accordion menu.\n   * @class\n   * @name AccordionMenu\n   * @fires AccordionMenu#init\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n    this.className = 'AccordionMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('AccordionMenu', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_RIGHT': 'open',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'close',\n      'ESCAPE': 'closeAll'\n    });\n  }\n\n\n\n  /**\n   * Initializes the accordion menu by hiding all nested menus.\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'accordion');\n\n    var _this = this;\n\n    this.$element.find('[data-submenu]').not('.is-active').slideUp(0);//.find('a').css('padding-left', '1rem');\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': this.options.multiOpen\n    });\n\n    this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');\n    this.$menuLinks.each(function(){\n      var linkId = this.id || GetYoDigits(6, 'acc-menu-link'),\n          $elem = $(this),\n          $sub = $elem.children('[data-submenu]'),\n          subId = $sub[0].id || GetYoDigits(6, 'acc-menu'),\n          isActive = $sub.hasClass('is-active');\n\n      if(_this.options.parentLink) {\n        let $anchor = $elem.children('a');\n        $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-accordion-submenu-item\"></li>');\n      }\n\n      if(_this.options.submenuToggle) {\n        $elem.addClass('has-submenu-toggle');\n        $elem.children('a').after('<button id=\"' + linkId + '\" class=\"submenu-toggle\" aria-controls=\"' + subId + '\" aria-expanded=\"' + isActive + '\" title=\"' + _this.options.submenuToggleText + '\"><span class=\"submenu-toggle-text\">' + _this.options.submenuToggleText + '</span></button>');\n      } else {\n        $elem.attr({\n          'aria-controls': subId,\n          'aria-expanded': isActive,\n          'id': linkId\n        });\n      }\n      $sub.attr({\n        'aria-labelledby': linkId,\n        'aria-hidden': !isActive,\n        'role': 'group',\n        'id': subId\n      });\n    });\n    this.$element.find('li').attr({\n      'role': 'treeitem'\n    });\n    var initPanes = this.$element.find('.is-active');\n    if(initPanes.length){\n      var _this = this;\n      initPanes.each(function(){\n        _this.down($(this));\n      });\n    }\n    this._events();\n  }\n\n  /**\n   * Adds event handlers for items within the menu.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.find('li').each(function() {\n      var $submenu = $(this).children('[data-submenu]');\n\n      if ($submenu.length) {\n        if(_this.options.submenuToggle) {\n          $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n            _this.toggle($submenu);\n          });\n        } else {\n            $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n              e.preventDefault();\n              _this.toggle($submenu);\n            });\n        }\n      }\n    }).on('keydown.zf.accordionmenu', function(e){\n      var $element = $(this),\n          $elements = $element.parent('ul').children('li'),\n          $prevElement,\n          $nextElement,\n          $target = $element.children('[data-submenu]');\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1)).find('a').first();\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1)).find('a').first();\n\n          if ($(this).children('[data-submenu]:visible').length) { // has open sub menu\n            $nextElement = $element.find('li:first-child').find('a').first();\n          }\n          if ($(this).is(':first-child')) { // is first element of sub menu\n            $prevElement = $element.parents('li').first().find('a').first();\n          } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) { // if previous element has open sub menu\n            $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();\n          }\n          if ($(this).is(':last-child')) { // is last element of sub menu\n            $nextElement = $element.parents('li').first().next('li').find('a').first();\n          }\n\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'AccordionMenu', {\n        open: function() {\n          if ($target.is(':hidden')) {\n            _this.down($target);\n            $target.find('li').first().find('a').first().focus();\n          }\n        },\n        close: function() {\n          if ($target.length && !$target.is(':hidden')) { // close active sub of this item\n            _this.up($target);\n          } else if ($element.parent('[data-submenu]').length) { // close currently open sub\n            _this.up($element.parent('[data-submenu]'));\n            $element.parents('li').first().find('a').first().focus();\n          }\n        },\n        up: function() {\n          $prevElement.focus();\n          return true;\n        },\n        down: function() {\n          $nextElement.focus();\n          return true;\n        },\n        toggle: function() {\n          if (_this.options.submenuToggle) {\n            return false;\n          }\n          if ($element.children('[data-submenu]').length) {\n            _this.toggle($element.children('[data-submenu]'));\n            return true;\n          }\n        },\n        closeAll: function() {\n          _this.hideAll();\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    });//.attr('tabindex', 0);\n  }\n\n  /**\n   * Closes all panes of the menu.\n   * @function\n   */\n  hideAll() {\n    this.up(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Opens all panes of the menu.\n   * @function\n   */\n  showAll() {\n    this.down(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Toggles the open/close state of a submenu.\n   * @function\n   * @param {jQuery} $target - the submenu to toggle\n   */\n  toggle($target){\n    if(!$target.is(':animated')) {\n      if (!$target.is(':hidden')) {\n        this.up($target);\n      }\n      else {\n        this.down($target);\n      }\n    }\n  }\n\n  /**\n   * Opens the sub-menu defined by `$target`.\n   * @param {jQuery} $target - Sub-menu to open.\n   * @fires AccordionMenu#down\n   */\n  down($target) {\n    // If having multiple submenus active is disabled, close all the submenus\n    // that are not parents or children of the targeted submenu.\n    if (!this.options.multiOpen) {\n      // The \"branch\" of the targetted submenu, from the component root to\n      // the active submenus nested in it.\n      const $targetBranch = $target.parentsUntil(this.$element)\n        .add($target)\n        .add($target.find('.is-active'));\n      // All the active submenus that are not in the branch.\n      const $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);\n\n      this.up($othersActiveSubmenus);\n    }\n\n    $target\n      .addClass('is-active')\n      .attr({ 'aria-hidden': false });\n\n    if(this.options.submenuToggle) {\n      $target.prev('.submenu-toggle').attr({'aria-expanded': true});\n    }\n    else {\n      $target.parent('.is-accordion-submenu-parent').attr({'aria-expanded': true});\n    }\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done opening.\n       * @event AccordionMenu#down\n       */\n      this.$element.trigger('down.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.\n   * @param {jQuery} $target - Sub-menu to close.\n   * @fires AccordionMenu#up\n   */\n  up($target) {\n    const $submenus = $target.find('[data-submenu]');\n    const $allmenus = $target.add($submenus);\n\n    $submenus.slideUp(0);\n    $allmenus\n      .removeClass('is-active')\n      .attr('aria-hidden', true);\n\n    if(this.options.submenuToggle) {\n      $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);\n    }\n    else {\n      $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\n    }\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done collapsing up.\n       * @event AccordionMenu#up\n       */\n      this.$element.trigger('up.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Destroys an instance of accordion menu.\n   * @fires AccordionMenu#destroyed\n   */\n  _destroy() {\n    this.$element.find('[data-submenu]').slideDown(0).css('display', '');\n    this.$element.find('a').off('click.zf.accordionMenu');\n    this.$element.find('[data-is-parent-link]').detach();\n\n    if(this.options.submenuToggle) {\n      this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');\n      this.$element.find('.submenu-toggle').remove();\n    }\n\n    Nest.Burn(this.$element, 'accordion');\n  }\n}\n\nAccordionMenu.defaults = {\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Amount of time to animate the opening of a submenu in ms.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Adds a separate submenu toggle button. This allows the parent item to have a link.\n   * @option\n   * @example true\n   */\n  submenuToggle: false,\n  /**\n   * The text used for the submenu toggle if enabled. This is used for screen readers only.\n   * @option\n   * @example true\n   */\n  submenuToggleText: 'Toggle menu',\n  /**\n   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\nexport {AccordionMenu};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits, transitionend } from './foundation.core.utils';\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Drilldown module.\n * @module foundation.drilldown\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n * @requires foundation.util.box\n */\n\nclass Drilldown extends Plugin {\n  /**\n   * Creates a new instance of a drilldown menu.\n   * @class\n   * @name Drilldown\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);\n    this.className = 'Drilldown'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('Drilldown', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close',\n      'TAB': 'down',\n      'SHIFT_TAB': 'up'\n    });\n  }\n\n  /**\n   * Initializes the drilldown by creating jQuery collections of elements\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'drilldown');\n\n    if(this.options.autoApplyClass) {\n      this.$element.addClass('drilldown');\n    }\n\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': false\n    });\n    this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');\n    this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');\n    this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a');\n\n    // Set the main menu as current by default (unless a submenu is selected)\n    // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu\n    this.$currentMenu = this.$element;\n\n    this.$element.attr('data-mutate', (this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown')));\n\n    this._prepareMenu();\n    this._registerEvents();\n\n    this._keyboardEvents();\n  }\n\n  /**\n   * prepares drilldown menu by setting attributes to links and elements\n   * sets a min height to prevent content jumping\n   * wraps the element if not already wrapped\n   * @private\n   * @function\n   */\n  _prepareMenu() {\n    var _this = this;\n    // if(!this.options.holdOpen){\n    //   this._menuLinkEvents();\n    // }\n    this.$submenuAnchors.each(function(){\n      var $link = $(this);\n      var $sub = $link.parent();\n      if(_this.options.parentLink){\n        $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-drilldown-submenu-item\" role=\"menuitem\"></li>');\n      }\n      $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);\n      $link.children('[data-submenu]')\n          .attr({\n            'aria-hidden': true,\n            'tabindex': 0,\n            'role': 'group'\n          });\n      _this._events($link);\n    });\n    this.$submenus.each(function(){\n      var $menu = $(this),\n          $back = $menu.find('.js-drilldown-back');\n      if(!$back.length){\n        switch (_this.options.backButtonPosition) {\n          case \"bottom\":\n            $menu.append(_this.options.backButton);\n            break;\n          case \"top\":\n            $menu.prepend(_this.options.backButton);\n            break;\n          default:\n            console.error(\"Unsupported backButtonPosition value '\" + _this.options.backButtonPosition + \"'\");\n        }\n      }\n      _this._back($menu);\n    });\n\n    this.$submenus.addClass('invisible');\n    if(!this.options.autoHeight) {\n      this.$submenus.addClass('drilldown-submenu-cover-previous');\n    }\n\n    // create a wrapper on element if it doesn't exist.\n    if(!this.$element.parent().hasClass('is-drilldown')){\n      this.$wrapper = $(this.options.wrapper).addClass('is-drilldown');\n      if(this.options.animateHeight) this.$wrapper.addClass('animate-height');\n      this.$element.wrap(this.$wrapper);\n    }\n    // set wrapper\n    this.$wrapper = this.$element.parent();\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  _resize() {\n    this.$wrapper.css({'max-width': 'none', 'min-height': 'none'});\n    // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  /**\n   * Adds event handlers to elements in the menu.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the current menu item to add handlers to.\n   */\n  _events($elem) {\n    var _this = this;\n\n    $elem.off('click.zf.drilldown')\n    .on('click.zf.drilldown', function(e){\n      if($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')){\n        e.stopImmediatePropagation();\n        e.preventDefault();\n      }\n\n      // if(e.target !== e.currentTarget.firstElementChild){\n      //   return false;\n      // }\n      _this._show($elem.parent('li'));\n\n      if(_this.options.closeOnClick){\n        var $body = $('body');\n        $body.off('.zf.drilldown').on('click.zf.drilldown', function(e){\n          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target)) { return; }\n          e.preventDefault();\n          _this._hideAll();\n          $body.off('.zf.drilldown');\n        });\n      }\n    });\n  }\n\n  /**\n   * Adds event handlers to the menu element.\n   * @function\n   * @private\n   */\n  _registerEvents() {\n    if(this.options.scrollTop){\n      this._bindHandler = this._scrollTop.bind(this);\n      this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown',this._bindHandler);\n    }\n    this.$element.on('mutateme.zf.trigger', this._resize.bind(this));\n  }\n\n  /**\n   * Scroll to Top of Element or data-scroll-top-element\n   * @function\n   * @fires Drilldown#scrollme\n   */\n  _scrollTop() {\n    var _this = this;\n    var $scrollTopElement = _this.options.scrollTopElement!=''?$(_this.options.scrollTopElement):_this.$element,\n        scrollPos = parseInt($scrollTopElement.offset().top+_this.options.scrollTopOffset, 10);\n    $('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing,function(){\n      /**\n        * Fires after the menu has scrolled\n        * @event Drilldown#scrollme\n        */\n      if(this===$('html')[0])_this.$element.trigger('scrollme.zf.drilldown');\n    });\n  }\n\n  /**\n   * Adds keydown event listener to `li`'s in the menu.\n   * @private\n   */\n  _keyboardEvents() {\n    var _this = this;\n\n    this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function(e){\n      var $element = $(this),\n          $elements = $element.parent('li').parent('ul').children('li').children('a'),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1));\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'Drilldown', {\n        next: function() {\n          if ($element.is(_this.$submenuAnchors)) {\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        previous: function() {\n          _this._hide($element.parent('li').parent('ul'));\n          $element.parent('li').parent('ul').one(transitionend($element), function(){\n            setTimeout(function() {\n              $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n            }, 1);\n          });\n          return true;\n        },\n        up: function() {\n          $prevElement.focus();\n          // Don't tap focus on first element in root ul\n          return !$element.is(_this.$element.find('> li:first-child > a'));\n        },\n        down: function() {\n          $nextElement.focus();\n          // Don't tap focus on last element in root ul\n          return !$element.is(_this.$element.find('> li:last-child > a'));\n        },\n        close: function() {\n          // Don't close on element in root ul\n          if (!$element.is(_this.$element.find('> li > a'))) {\n            _this._hide($element.parent().parent());\n            $element.parent().parent().siblings('a').focus();\n          }\n        },\n        open: function() {\n          if (_this.options.parentLink && $element.attr('href')) { // Link with href\n            return false;\n          } else if (!$element.is(_this.$menuItems)) { // not menu item means back button\n            _this._hide($element.parent('li').parent('ul'));\n            $element.parent('li').parent('ul').one(transitionend($element), function(){\n              setTimeout(function() {\n                $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n              }, 1);\n            });\n            return true;\n          } else if ($element.is(_this.$submenuAnchors)) { // Sub menu item\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    }); // end keyboardAccess\n  }\n\n  /**\n   * Closes all open elements, and returns to root menu.\n   * @function\n   * @fires Drilldown#closed\n   */\n  _hideAll() {\n    var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    $elem.one(transitionend($elem), function(e){\n      $elem.removeClass('is-active is-closing');\n    });\n        /**\n         * Fires when the menu is fully closed.\n         * @event Drilldown#closed\n         */\n    this.$element.trigger('closed.zf.drilldown');\n  }\n\n  /**\n   * Adds event listener for each `back` button, and closes open menus.\n   * @function\n   * @fires Drilldown#back\n   * @param {jQuery} $elem - the current sub-menu to add `back` event.\n   */\n  _back($elem) {\n    var _this = this;\n    $elem.off('click.zf.drilldown');\n    $elem.children('.js-drilldown-back')\n      .on('click.zf.drilldown', function(e){\n        e.stopImmediatePropagation();\n        // console.log('mouseup on back');\n        _this._hide($elem);\n\n        // If there is a parent submenu, call show\n        let parentSubMenu = $elem.parent('li').parent('ul').parent('li');\n        if (parentSubMenu.length) {\n          _this._show(parentSubMenu);\n        }\n      });\n  }\n\n  /**\n   * Adds event listener to menu items w/o submenus to close open menus on click.\n   * @function\n   * @private\n   */\n  _menuLinkEvents() {\n    var _this = this;\n    this.$menuItems.not('.is-drilldown-submenu-parent')\n        .off('click.zf.drilldown')\n        .on('click.zf.drilldown', function(e){\n          // e.stopImmediatePropagation();\n          setTimeout(function(){\n            _this._hideAll();\n          }, 0);\n      });\n  }\n\n  /**\n   * Sets the CSS classes for submenu to show it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setShowSubMenuClasses($elem, trigger) {\n    $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    $elem.parent('li').attr('aria-expanded', true);\n    if (trigger === true) {\n      this.$element.trigger('open.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Sets the CSS classes for submenu to hide it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setHideSubMenuClasses($elem, trigger) {\n    $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);\n    $elem.parent('li').attr('aria-expanded', false);\n    if (trigger === true) {\n      $elem.trigger('hide.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.\n   * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the target (sub)menu (`ul` tag)\n   * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused\n   */\n  _showMenu($elem, autoFocus) {\n\n    var _this = this;\n\n    // Reset drilldown\n    var $expandedSubmenus = this.$element.find('li[aria-expanded=\"true\"] > ul[data-submenu]');\n    $expandedSubmenus.each(function(index) {\n      _this._setHideSubMenuClasses($(this));\n    });\n\n    // Save the menu as the currently displayed one.\n    this.$currentMenu = $elem;\n\n    // If target menu is root, focus first link & exit\n    if ($elem.is('[data-drilldown]')) {\n      if (autoFocus === true) $elem.find('li[role=\"treeitem\"] > a').first().focus();\n      if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));\n      return;\n    }\n\n    // Find all submenus on way to root incl. the element itself\n    var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]');\n\n    // Open target menu and all submenus on its way to root\n    $submenus.each(function(index) {\n\n      // Update height of first child (target menu) if autoHeight option true\n      if (index === 0 && _this.options.autoHeight) {\n        _this.$wrapper.css('height', $(this).data('calcHeight'));\n      }\n\n      var isLastChild = index == $submenus.length - 1;\n\n      // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link\n      // Last child makes sure the event gets always triggered even if going through several menus\n      if (isLastChild === true) {\n        $(this).one(transitionend($(this)), () => {\n          if (autoFocus === true) {\n            $elem.find('li[role=\"treeitem\"] > a').first().focus();\n          }\n        });\n      }\n\n      _this._setShowSubMenuClasses($(this), isLastChild);\n    });\n  }\n\n  /**\n   * Opens a submenu.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.\n   */\n  _show($elem) {\n    const $submenu = $elem.children('[data-submenu]');\n\n    $elem.attr('aria-expanded', true);\n\n    this.$currentMenu = $submenu;\n    $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    if (this.options.autoHeight) {\n      this.$wrapper.css({ height: $submenu.data('calcHeight') });\n    }\n\n    /**\n     * Fires when the submenu has opened.\n     * @event Drilldown#open\n     */\n    this.$element.trigger('open.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Hides a submenu\n   * @function\n   * @fires Drilldown#hide\n   * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.\n   */\n  _hide($elem) {\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    var _this = this;\n    $elem.parent('li').attr('aria-expanded', false);\n    $elem.attr('aria-hidden', true);\n    $elem.addClass('is-closing')\n         .one(transitionend($elem), function(){\n           $elem.removeClass('is-active is-closing');\n           $elem.blur().addClass('invisible');\n         });\n    /**\n     * Fires when the submenu has closed.\n     * @event Drilldown#hide\n     */\n    $elem.trigger('hide.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Iterates through the nested menus to calculate the min-height, and max-width for the menu.\n   * Prevents content jumping.\n   * @function\n   * @private\n   */\n  _getMaxDims() {\n    var maxHeight = 0, result = {}, _this = this;\n\n    // Recalculate menu heights and total max height\n    this.$submenus.add(this.$element).each(function(){\n      var numOfElems = $(this).children('li').length;\n      var height = Box.GetDimensions(this).height;\n\n      maxHeight = height > maxHeight ? height : maxHeight;\n\n      if(_this.options.autoHeight) {\n        $(this).data('calcHeight',height);\n      }\n    });\n\n    if (this.options.autoHeight)\n      result['height'] = this.$currentMenu.data('calcHeight');\n    else\n      result['min-height'] = `${maxHeight}px`;\n\n    result['max-width'] = `${this.$element[0].getBoundingClientRect().width}px`;\n\n    return result;\n  }\n\n  /**\n   * Destroys the Drilldown Menu\n   * @function\n   */\n  _destroy() {\n    if(this.options.scrollTop) this.$element.off('.zf.drilldown',this._bindHandler);\n    this._hideAll();\n\t  this.$element.off('mutateme.zf.trigger');\n    Nest.Burn(this.$element, 'drilldown');\n    this.$element.unwrap()\n                 .find('.js-drilldown-back, .is-submenu-parent-item').remove()\n                 .end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu')\n                 .end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');\n    this.$submenuAnchors.each(function() {\n      $(this).off('.zf.drilldown');\n    });\n\n    this.$element.find('[data-is-parent-link]').detach();\n    this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');\n\n    this.$element.find('a').each(function(){\n      var $link = $(this);\n      $link.removeAttr('tabindex');\n      if($link.data('savedHref')){\n        $link.attr('href', $link.data('savedHref')).removeData('savedHref');\n      }else{ return; }\n    });\n  };\n}\n\nDrilldown.defaults = {\n  /**\n   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are\n   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.\n   * @option\n   * @type {boolian}\n   * @default true\n   */\n  autoApplyClass: true,\n  /**\n   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>'\n   */\n  backButton: '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>',\n  /**\n   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default top\n   */\n  backButtonPosition: 'top',\n  /**\n   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<div></div>'\n   */\n  wrapper: '<div></div>',\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Allow the menu to return to root list on body click.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false,\n  /**\n   * Allow the menu to auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoHeight: false,\n  /**\n   * Animate the auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animateHeight: false,\n  /**\n   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  scrollTop: false,\n  /**\n   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  scrollTopElement: '',\n  /**\n   * ScrollTop offset\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  scrollTopOffset: 0,\n  /**\n   * Scroll animation duration\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Scroll animation easing. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @see {@link https://api.jquery.com/animate|JQuery animate}\n   * @default 'swing'\n   */\n  animationEasing: 'swing'\n  // holdOpen: false\n};\n\nexport {Drilldown};\n","'use strict';\n\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst POSITIONS = ['left', 'right', 'top', 'bottom'];\nconst VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nconst HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\n\nconst ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n}\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n  if(currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\n\nclass Positionable extends Plugin {\n  /**\n   * Abstract class encapsulating the tether-like explicit positioning logic\n   * including repositioning based on overlap.\n   * Expects classes to define defaults for vOffset, hOffset, position,\n   * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n   * extending the defaults, or (for now recommended due to the way docs are\n   * generated) by explicitly declaring them.\n   *\n   **/\n\n  _init() {\n    this.triedPositions = {};\n    this.position  = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n    this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n    this.originalPosition = this.position;\n    this.originalAlignment = this.alignment;\n  }\n\n  _getDefaultPosition () {\n    return 'bottom';\n  }\n\n  _getDefaultAlignment() {\n    switch(this.position) {\n      case 'bottom':\n      case 'top':\n        return Rtl() ? 'right' : 'left';\n      case 'left':\n      case 'right':\n        return 'bottom';\n    }\n  }\n\n  /**\n   * Adjusts the positionable possible positions by iterating through alignments\n   * and positions.\n   * @function\n   * @private\n   */\n  _reposition() {\n    if(this._alignmentsExhausted(this.position)) {\n      this.position = nextItem(this.position, POSITIONS);\n      this.alignment = ALIGNMENTS[this.position][0];\n    } else {\n      this._realign();\n    }\n  }\n\n  /**\n   * Adjusts the dropdown pane possible positions by iterating through alignments\n   * on the current position.\n   * @function\n   * @private\n   */\n  _realign() {\n    this._addTriedPosition(this.position, this.alignment)\n    this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position])\n  }\n\n  _addTriedPosition(position, alignment) {\n    this.triedPositions[position] = this.triedPositions[position] || []\n    this.triedPositions[position].push(alignment);\n  }\n\n  _positionsExhausted() {\n    var isExhausted = true;\n    for(var i = 0; i < POSITIONS.length; i++) {\n      isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n    }\n    return isExhausted;\n  }\n\n  _alignmentsExhausted(position) {\n    return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n  }\n\n\n  // When we're trying to center, we don't want to apply offset that's going to\n  // take us just off center, so wrap around to return 0 for the appropriate\n  // offset in those alignments.  TODO: Figure out if we want to make this\n  // configurable behavior... it feels more intuitive, especially for tooltips, but\n  // it's possible someone might actually want to start from center and then nudge\n  // slightly off.\n  _getVOffset() {\n    return this.options.vOffset;\n  }\n\n  _getHOffset() {\n    return this.options.hOffset;\n  }\n\n\n  _setPosition($anchor, $element, $parent) {\n    if($anchor.attr('aria-expanded') === 'false'){ return false; }\n    var $eleDims = Box.GetDimensions($element),\n        $anchorDims = Box.GetDimensions($anchor);\n\n\n    if (!this.options.allowOverlap) {\n      // restore original position & alignment before checking overlap\n      this.position = this.originalPosition;\n      this.alignment = this.originalAlignment;\n    }\n\n    $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n    if(!this.options.allowOverlap) {\n      var overlaps = {};\n      var minOverlap = 100000000;\n      // default coordinates to how we start, in case we can't figure out better\n      var minCoordinates = {position: this.position, alignment: this.alignment};\n      while(!this._positionsExhausted()) {\n        let overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n        if(overlap === 0) {\n          return;\n        }\n\n        if(overlap < minOverlap) {\n          minOverlap = overlap;\n          minCoordinates = {position: this.position, alignment: this.alignment};\n        }\n\n        this._reposition();\n\n        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n      // If we get through the entire loop, there was no non-overlapping\n      // position available. Pick the version with least overlap.\n      this.position = minCoordinates.position;\n      this.alignment = minCoordinates.alignment;\n      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n    }\n  }\n\n}\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n}\n\nexport {Positionable};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { Positionable } from './foundation.positionable';\n\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Dropdown module.\n * @module foundation.dropdown\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.triggers\n */\nclass Dropdown extends Positionable {\n  /**\n   * Creates a new instance of a dropdown.\n   * @class\n   * @name Dropdown\n   * @param {jQuery} element - jQuery object to make into a dropdown.\n   *        Object should be of the dropdown panel, rather than its anchor.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);\n    this.className = 'Dropdown'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Dropdown', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.\n   * @function\n   * @private\n   */\n  _init() {\n    var $id = this.$element.attr('id');\n\n    this.$anchors = $(`[data-toggle=\"${$id}\"]`).length ? $(`[data-toggle=\"${$id}\"]`) : $(`[data-open=\"${$id}\"]`);\n    this.$anchors.attr({\n      'aria-controls': $id,\n      'data-is-focus': false,\n      'data-yeti-box': $id,\n      'aria-haspopup': true,\n      'aria-expanded': false\n    });\n\n    this._setCurrentAnchor(this.$anchors.first());\n\n    if(this.options.parentClass){\n      this.$parent = this.$element.parents('.' + this.options.parentClass);\n    }else{\n      this.$parent = null;\n    }\n\n    // Set [aria-labelledby] on the Dropdown if it is not set\n    if (typeof this.$element.attr('aria-labelledby') === 'undefined') {\n      // Get the anchor ID or create one\n      if (typeof this.$currentAnchor.attr('id') === 'undefined') {\n        this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));\n      };\n\n      this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));\n    }\n\n    this.$element.attr({\n      'aria-hidden': 'true',\n      'data-yeti-box': $id,\n      'data-resize': $id,\n    });\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/(top|left|right|bottom)/g);\n    if(position) {\n      return position[0];\n    } else {\n      return 'bottom'\n    }\n  }\n\n  _getDefaultAlignment() {\n    // handle legacy float approach\n    var horizontalPosition = /float-(\\S+)/.exec(this.$currentAnchor.attr('class'));\n    if(horizontalPosition) {\n      return horizontalPosition[1];\n    }\n\n    return super._getDefaultAlignment();\n  }\n\n\n\n  /**\n   * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.\n   * Recursively calls itself if a collision is detected, with a new position class.\n   * @function\n   * @private\n   */\n  _setPosition() {\n    this.$element.removeClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n    super._setPosition(this.$currentAnchor, this.$element, this.$parent);\n    this.$element.addClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n  }\n\n  /**\n   * Make it a current anchor.\n   * Current anchor as the reference for the position of Dropdown panes.\n   * @param {HTML} el - DOM element of the anchor.\n   * @function\n   * @private\n   */\n  _setCurrentAnchor(el) {\n    this.$currentAnchor = $(el);\n  }\n\n  /**\n   * Adds event listeners to the element utilizing the triggers utility library.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': this._setPosition.bind(this)\n    });\n\n    this.$anchors.off('click.zf.trigger')\n      .on('click.zf.trigger', function() { _this._setCurrentAnchor(this); });\n\n    if(this.options.hover){\n      this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n      .on('mouseenter.zf.dropdown', function(){\n        _this._setCurrentAnchor(this);\n\n        var bodyData = $('body').data();\n        if(typeof(bodyData.whatinput) === 'undefined' || bodyData.whatinput === 'mouse') {\n          clearTimeout(_this.timeout);\n          _this.timeout = setTimeout(function(){\n            _this.open();\n            _this.$anchors.data('hover', true);\n          }, _this.options.hoverDelay);\n        }\n      }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n        clearTimeout(_this.timeout);\n        _this.timeout = setTimeout(function(){\n          _this.close();\n          _this.$anchors.data('hover', false);\n        }, _this.options.hoverDelay);\n      }));\n      if(this.options.hoverPane){\n        this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n            .on('mouseenter.zf.dropdown', function(){\n              clearTimeout(_this.timeout);\n            }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n              clearTimeout(_this.timeout);\n              _this.timeout = setTimeout(function(){\n                _this.close();\n                _this.$anchors.data('hover', false);\n              }, _this.options.hoverDelay);\n            }));\n      }\n    }\n    this.$anchors.add(this.$element).on('keydown.zf.dropdown', function(e) {\n\n      var $target = $(this),\n        visibleFocusableElements = Keyboard.findFocusable(_this.$element);\n\n      Keyboard.handleKey(e, 'Dropdown', {\n        open: function() {\n          if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {\n            _this.open();\n            _this.$element.attr('tabindex', -1).focus();\n            e.preventDefault();\n          }\n        },\n        close: function() {\n          _this.close();\n          _this.$anchors.focus();\n        }\n      });\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n     var $body = $(document.body).not(this.$element),\n         _this = this;\n     $body.off('click.zf.dropdown')\n          .on('click.zf.dropdown', function(e){\n            if(_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {\n              return;\n            }\n            if(_this.$element.is(e.target) || _this.$element.find(e.target).length) {\n              return;\n            }\n            _this.close();\n            $body.off('click.zf.dropdown');\n          });\n  }\n\n  /**\n   * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.\n   * @function\n   * @fires Dropdown#closeme\n   * @fires Dropdown#show\n   */\n  open() {\n    // var _this = this;\n    /**\n     * Fires to close other open dropdowns, typically when dropdown is opening\n     * @event Dropdown#closeme\n     */\n    this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));\n    this.$anchors.addClass('hover')\n        .attr({'aria-expanded': true});\n    // this.$element/*.show()*/;\n\n    this.$element.addClass('is-opening');\n    this._setPosition();\n    this.$element.removeClass('is-opening').addClass('is-open')\n        .attr({'aria-hidden': false});\n\n    if(this.options.autoFocus){\n      var $focusable = Keyboard.findFocusable(this.$element);\n      if($focusable.length){\n        $focusable.eq(0).focus();\n      }\n    }\n\n    if(this.options.closeOnClick){ this._addBodyHandler(); }\n\n    if (this.options.trapFocus) {\n      Keyboard.trapFocus(this.$element);\n    }\n\n    /**\n     * Fires once the dropdown is visible.\n     * @event Dropdown#show\n     */\n    this.$element.trigger('show.zf.dropdown', [this.$element]);\n  }\n\n  /**\n   * Closes the open dropdown pane.\n   * @function\n   * @fires Dropdown#hide\n   */\n  close() {\n    if(!this.$element.hasClass('is-open')){\n      return false;\n    }\n    this.$element.removeClass('is-open')\n        .attr({'aria-hidden': true});\n\n    this.$anchors.removeClass('hover')\n        .attr('aria-expanded', false);\n\n    /**\n     * Fires once the dropdown is no longer visible.\n     * @event Dropdown#hide\n     */\n    this.$element.trigger('hide.zf.dropdown', [this.$element]);\n\n    if (this.options.trapFocus) {\n      Keyboard.releaseFocus(this.$element);\n    }\n  }\n\n  /**\n   * Toggles the dropdown pane's visibility.\n   * @function\n   */\n  toggle() {\n    if(this.$element.hasClass('is-open')){\n      if(this.$anchors.data('hover')) return;\n      this.close();\n    }else{\n      this.open();\n    }\n  }\n\n  /**\n   * Destroys the dropdown.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger').hide();\n    this.$anchors.off('.zf.dropdown');\n    $(document.body).off('click.zf.dropdown');\n\n  }\n}\n\nDropdown.defaults = {\n  /**\n   * Class that designates bounding container of Dropdown (default: window)\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  parentClass: null,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  hoverDelay: 250,\n  /**\n   * Allow submenus to open on hover events\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hover: false,\n  /**\n   * Don't close dropdown when hovering over dropdown pane\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hoverPane: false,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Position of dropdown. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false,\n  /**\n   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n  /**\n   * Allows a click on the body to close the dropdown.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false\n};\n\nexport {Dropdown};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl, ignoreMousedisappear } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { Box } from './foundation.util.box';\n\n/**\n * DropdownMenu module.\n * @module foundation.dropdown-menu\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.nest\n */\n\nclass DropdownMenu extends Plugin {\n  /**\n   * Creates a new instance of DropdownMenu.\n   * @class\n   * @name DropdownMenu\n   * @fires DropdownMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n    this.className = 'DropdownMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('DropdownMenu', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin, and calls _prepareMenu\n   * @private\n   * @function\n   */\n  _init() {\n    Nest.Feather(this.$element, 'dropdown');\n\n    var subs = this.$element.find('li.is-dropdown-submenu-parent');\n    this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');\n\n    this.$menuItems = this.$element.find('[role=\"menuitem\"]');\n    this.$tabs = this.$element.children('[role=\"menuitem\"]');\n    this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);\n\n    if (this.options.alignment === 'auto') {\n        if (this.$element.hasClass(this.options.rightClass) || Rtl() || this.$element.parents('.top-bar-right').is('*')) {\n            this.options.alignment = 'right';\n            subs.addClass('opens-left');\n        } else {\n            this.options.alignment = 'left';\n            subs.addClass('opens-right');\n        }\n    } else {\n      if (this.options.alignment === 'right') {\n          subs.addClass('opens-left');\n      } else {\n          subs.addClass('opens-right');\n      }\n    }\n    this.changed = false;\n    this._events();\n  };\n\n  _isVertical() {\n    return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';\n  }\n\n  _isRtl() {\n    return this.$element.hasClass('align-right') || (Rtl() && !this.$element.hasClass('align-left'));\n  }\n\n  /**\n   * Adds event listeners to elements within the menu\n   * @private\n   * @function\n   */\n  _events() {\n    var _this = this,\n        hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined'),\n        parClass = 'is-dropdown-submenu-parent';\n\n    // used for onClick and in the keyboard handlers\n    var handleClickFn = function(e) {\n      var $elem = $(e.target).parentsUntil('ul', `.${parClass}`),\n          hasSub = $elem.hasClass(parClass),\n          hasClicked = $elem.attr('data-is-click') === 'true',\n          $sub = $elem.children('.is-dropdown-submenu');\n\n      if (hasSub) {\n        if (hasClicked) {\n          if (!_this.options.closeOnClick || (!_this.options.clickOpen && !hasTouch) || (_this.options.forceFollow && hasTouch)) { return; }\n          else {\n            e.stopImmediatePropagation();\n            e.preventDefault();\n            _this._hide($elem);\n          }\n        } else {\n          e.preventDefault();\n          e.stopImmediatePropagation();\n          _this._show($sub);\n          $elem.add($elem.parentsUntil(_this.$element, `.${parClass}`)).attr('data-is-click', true);\n        }\n      }\n    };\n\n    if (this.options.clickOpen || hasTouch) {\n      this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);\n    }\n\n    // Handle Leaf element Clicks\n    if(_this.options.closeOnClickInside){\n      this.$menuItems.on('click.zf.dropdownmenu', function(e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if(!hasSub){\n          _this._hide();\n        }\n      });\n    }\n\n    if (!this.options.disableHover) {\n      this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {\n        var $elem = $(this),\n          hasSub = $elem.hasClass(parClass);\n\n        if (hasSub) {\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._show($elem.children('.is-dropdown-submenu'));\n          }, _this.options.hoverDelay));\n        }\n      }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if (hasSub && _this.options.autoclose) {\n          if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { return false; }\n\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._hide($elem);\n          }, _this.options.closingTime));\n        }\n      }));\n    }\n    this.$menuItems.on('keydown.zf.dropdownmenu', function(e) {\n      var $element = $(e.target).parentsUntil('ul', '[role=\"menuitem\"]'),\n          isTab = _this.$tabs.index($element) > -1,\n          $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(i-1);\n          $nextElement = $elements.eq(i+1);\n          return;\n        }\n      });\n\n      var nextSibling = function() {\n        $nextElement.children('a:first').focus();\n        e.preventDefault();\n      }, prevSibling = function() {\n        $prevElement.children('a:first').focus();\n        e.preventDefault();\n      }, openSub = function() {\n        var $sub = $element.children('ul.is-dropdown-submenu');\n        if ($sub.length) {\n          _this._show($sub);\n          $element.find('li > a:first').focus();\n          e.preventDefault();\n        } else { return; }\n      }, closeSub = function() {\n        //if ($element.is(':first-child')) {\n        var close = $element.parent('ul').parent('li');\n        close.children('a:first').focus();\n        _this._hide(close);\n        e.preventDefault();\n        //}\n      };\n      var functions = {\n        open: openSub,\n        close: function() {\n          _this._hide(_this.$element);\n          _this.$menuItems.eq(0).children('a').focus(); // focus to first element\n          e.preventDefault();\n        },\n        handled: function() {\n          e.stopImmediatePropagation();\n        }\n      };\n\n      if (isTab) {\n        if (_this._isVertical()) { // vertical menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: closeSub,\n              previous: openSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: openSub,\n              previous: closeSub\n            });\n          }\n        } else { // horizontal menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              next: prevSibling,\n              previous: nextSibling,\n              down: openSub,\n              up: closeSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              next: nextSibling,\n              previous: prevSibling,\n              down: openSub,\n              up: closeSub\n            });\n          }\n        }\n      } else { // not tabs -> one sub\n        if (_this._isRtl()) { // right aligned\n          $.extend(functions, {\n            next: closeSub,\n            previous: openSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        } else { // left aligned\n          $.extend(functions, {\n            next: openSub,\n            previous: closeSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        }\n      }\n      Keyboard.handleKey(e, 'DropdownMenu', functions);\n\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n    var $body = $(document.body),\n        _this = this;\n    $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu')\n         .on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function(e) {\n           var $link = _this.$element.find(e.target);\n           if ($link.length) { return; }\n\n           _this._hide();\n           $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');\n         });\n  }\n\n  /**\n   * Opens a dropdown pane, and checks for collisions first.\n   * @param {jQuery} $sub - ul element that is a submenu to show\n   * @function\n   * @private\n   * @fires Dropdownmenu#show\n   */\n  _show($sub) {\n    var idx = this.$tabs.index(this.$tabs.filter(function(i, el) {\n      return $(el).find($sub).length > 0;\n    }));\n    var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');\n    this._hide($sibs, idx);\n    $sub.css('visibility', 'hidden').addClass('js-dropdown-active')\n        .parent('li.is-dropdown-submenu-parent').addClass('is-active');\n    var clear = Box.ImNotTouchingYou($sub, null, true);\n    if (!clear) {\n      var oldClass = this.options.alignment === 'left' ? '-right' : '-left',\n          $parentLi = $sub.parent('.is-dropdown-submenu-parent');\n      $parentLi.removeClass(`opens${oldClass}`).addClass(`opens-${this.options.alignment}`);\n      clear = Box.ImNotTouchingYou($sub, null, true);\n      if (!clear) {\n        $parentLi.removeClass(`opens-${this.options.alignment}`).addClass('opens-inner');\n      }\n      this.changed = true;\n    }\n    $sub.css('visibility', '');\n    if (this.options.closeOnClick) { this._addBodyHandler(); }\n    /**\n     * Fires when the new dropdown pane is visible.\n     * @event Dropdownmenu#show\n     */\n    this.$element.trigger('show.zf.dropdownmenu', [$sub]);\n  }\n\n  /**\n   * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.\n   * @function\n   * @param {jQuery} $elem - element with a submenu to hide\n   * @param {Number} idx - index of the $tabs collection to hide\n   * @private\n   */\n  _hide($elem, idx) {\n    var $toClose;\n    if ($elem && $elem.length) {\n      $toClose = $elem;\n    } else if (typeof idx !== 'undefined') {\n      $toClose = this.$tabs.not(function(i, el) {\n        return i === idx;\n      });\n    }\n    else {\n      $toClose = this.$element;\n    }\n    var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;\n\n    if (somethingToClose) {\n      $toClose.find('li.is-active').add($toClose).attr({\n        'data-is-click': false\n      }).removeClass('is-active');\n\n      $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');\n\n      if (this.changed || $toClose.find('opens-inner').length) {\n        var oldClass = this.options.alignment === 'left' ? 'right' : 'left';\n        $toClose.find('li.is-dropdown-submenu-parent').add($toClose)\n                .removeClass(`opens-inner opens-${this.options.alignment}`)\n                .addClass(`opens-${oldClass}`);\n        this.changed = false;\n      }\n      /**\n       * Fires when the open menus are closed.\n       * @event Dropdownmenu#hide\n       */\n      this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);\n    }\n  }\n\n  /**\n   * Destroys the plugin.\n   * @function\n   */\n  _destroy() {\n    this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click')\n        .removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');\n    $(document.body).off('.zf.dropdownmenu');\n    Nest.Burn(this.$element, 'dropdown');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nDropdownMenu.defaults = {\n  /**\n   * Disallows hover events from opening submenus\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoclose: true,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  hoverDelay: 50,\n  /**\n   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  clickOpen: false,\n  /**\n   * Amount of time to delay closing a submenu on a mouseleave event.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n\n  closingTime: 500,\n  /**\n   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow clicks on the body to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allow clicks on leaf anchor links to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClickInside: true,\n  /**\n   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'vertical'\n   */\n  verticalClass: 'vertical',\n  /**\n   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'align-right'\n   */\n  rightClass: 'align-right',\n  /**\n   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  forceFollow: true\n};\n\nexport {DropdownMenu};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.imageLoader if equalizer contains images\n */\n\nclass Equalizer extends Plugin {\n  /**\n   * Creates a new instance of Equalizer.\n   * @class\n   * @name Equalizer\n   * @fires Equalizer#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options){\n    this.$element = element;\n    this.options  = $.extend({}, Equalizer.defaults, this.$element.data(), options);\n    this.className = 'Equalizer'; // ie9 back compat\n\n    this._init();\n  }\n\n  /**\n   * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var eqId = this.$element.attr('data-equalizer') || '';\n    var $watched = this.$element.find(`[data-equalizer-watch=\"${eqId}\"]`);\n\n    MediaQuery._init();\n\n    this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n    this.$element.attr('data-resize', (eqId || GetYoDigits(6, 'eq')));\n    this.$element.attr('data-mutate', (eqId || GetYoDigits(6, 'eq')));\n\n    this.hasNested = this.$element.find('[data-equalizer]').length > 0;\n    this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;\n    this.isOn = false;\n    this._bindHandler = {\n      onResizeMeBound: this._onResizeMe.bind(this),\n      onPostEqualizedBound: this._onPostEqualized.bind(this)\n    };\n\n    var imgs = this.$element.find('img');\n    var tooSmall;\n    if(this.options.equalizeOn){\n      tooSmall = this._checkMQ();\n      $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));\n    }else{\n      this._events();\n    }\n    if((typeof tooSmall !== 'undefined' && tooSmall === false) || typeof tooSmall === 'undefined'){\n      if(imgs.length){\n        onImagesLoaded(imgs, this._reflow.bind(this));\n      }else{\n        this._reflow();\n      }\n    }\n  }\n\n  /**\n   * Removes event listeners if the breakpoint is too small.\n   * @private\n   */\n  _pauseEvents() {\n    this.isOn = false;\n    this.$element.off({\n      '.zf.equalizer': this._bindHandler.onPostEqualizedBound,\n      'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,\n\t  'mutateme.zf.trigger': this._bindHandler.onResizeMeBound\n    });\n  }\n\n  /**\n   * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound\n   * @private\n   */\n  _onResizeMe(e) {\n    this._reflow();\n  }\n\n  /**\n   * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound\n   * @private\n   */\n  _onPostEqualized(e) {\n    if(e.target !== this.$element[0]){ this._reflow(); }\n  }\n\n  /**\n   * Initializes events for Equalizer.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this._pauseEvents();\n    if(this.hasNested){\n      this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);\n    }else{\n      this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);\n\t  this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);\n    }\n    this.isOn = true;\n  }\n\n  /**\n   * Checks the current breakpoint to the minimum required size.\n   * @private\n   */\n  _checkMQ() {\n    var tooSmall = !MediaQuery.is(this.options.equalizeOn);\n    if(tooSmall){\n      if(this.isOn){\n        this._pauseEvents();\n        this.$watched.css('height', 'auto');\n      }\n    }else{\n      if(!this.isOn){\n        this._events();\n      }\n    }\n    return tooSmall;\n  }\n\n  /**\n   * A noop version for the plugin\n   * @private\n   */\n  _killswitch() {\n    return;\n  }\n\n  /**\n   * Calls necessary functions to update Equalizer upon DOM change\n   * @private\n   */\n  _reflow() {\n    if(!this.options.equalizeOnStack){\n      if(this._isStacked()){\n        this.$watched.css('height', 'auto');\n        return false;\n      }\n    }\n    if (this.options.equalizeByRow) {\n      this.getHeightsByRow(this.applyHeightByRow.bind(this));\n    }else{\n      this.getHeights(this.applyHeight.bind(this));\n    }\n  }\n\n  /**\n   * Manually determines if the first 2 elements are *NOT* stacked.\n   * @private\n   */\n  _isStacked() {\n    if (!this.$watched[0] || !this.$watched[1]) {\n      return true;\n    }\n    return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} heights - An array of heights of children within Equalizer container\n   */\n  getHeights(cb) {\n    var heights = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      heights.push(this.$watched[i].offsetHeight);\n    }\n    cb(heights);\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   */\n  getHeightsByRow(cb) {\n    var lastElTopOffset = (this.$watched.length ? this.$watched.first().offset().top : 0),\n        groups = [],\n        group = 0;\n    //group by Row\n    groups[group] = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      //maybe could use this.$watched[i].offsetTop\n      var elOffsetTop = $(this.$watched[i]).offset().top;\n      if (elOffsetTop!=lastElTopOffset) {\n        group++;\n        groups[group] = [];\n        lastElTopOffset=elOffsetTop;\n      }\n      groups[group].push([this.$watched[i],this.$watched[i].offsetHeight]);\n    }\n\n    for (var j = 0, ln = groups.length; j < ln; j++) {\n      var heights = $(groups[j]).map(function(){ return this[1]; }).get();\n      var max         = Math.max.apply(null, heights);\n      groups[j].push(max);\n    }\n    cb(groups);\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest\n   * @param {array} heights - An array of heights of children within Equalizer container\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#postequalized\n   */\n  applyHeight(heights) {\n    var max = Math.max.apply(null, heights);\n    /**\n     * Fires before the heights are applied\n     * @event Equalizer#preequalized\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n\n    this.$watched.css('height', max);\n\n    /**\n     * Fires when the heights have been applied\n     * @event Equalizer#postequalized\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row\n   * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#preequalizedrow\n   * @fires Equalizer#postequalizedrow\n   * @fires Equalizer#postequalized\n   */\n  applyHeightByRow(groups) {\n    /**\n     * Fires before the heights are applied\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n    for (var i = 0, len = groups.length; i < len ; i++) {\n      var groupsILength = groups[i].length,\n          max = groups[i][groupsILength - 1];\n      if (groupsILength<=2) {\n        $(groups[i][0][0]).css({'height':'auto'});\n        continue;\n      }\n      /**\n        * Fires before the heights per row are applied\n        * @event Equalizer#preequalizedrow\n        */\n      this.$element.trigger('preequalizedrow.zf.equalizer');\n      for (var j = 0, lenJ = (groupsILength-1); j < lenJ ; j++) {\n        $(groups[i][j][0]).css({'height':max});\n      }\n      /**\n        * Fires when the heights per row have been applied\n        * @event Equalizer#postequalizedrow\n        */\n      this.$element.trigger('postequalizedrow.zf.equalizer');\n    }\n    /**\n     * Fires when the heights have been applied\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Destroys an instance of Equalizer.\n   * @function\n   */\n  _destroy() {\n    this._pauseEvents();\n    this.$watched.css('height', 'auto');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nEqualizer.defaults = {\n  /**\n   * Enable height equalization when stacked on smaller screens.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeOnStack: false,\n  /**\n   * Enable height equalization row by row.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeByRow: false,\n  /**\n   * String representing the minimum breakpoint size the plugin should equalize heights on.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  equalizeOn: ''\n};\n\nexport {Equalizer};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n */\n\nclass Interchange extends Plugin {\n  /**\n   * Creates a new instance of Interchange.\n   * @class\n   * @name Interchange\n   * @fires Interchange#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Interchange.defaults, options);\n    this.rules = [];\n    this.currentPath = '';\n    this.className = 'Interchange'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Interchange plugin and calls functions to get interchange functioning on load.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var id = this.$element[0].id || GetYoDigits(6, 'interchange');\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    this._addBreakpoints();\n    this._generateRules();\n    this._reflow();\n  }\n\n  /**\n   * Initializes events for Interchange.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', () => this._reflow());\n  }\n\n  /**\n   * Calls necessary functions to update Interchange upon DOM change\n   * @function\n   * @private\n   */\n  _reflow() {\n    var match;\n\n    // Iterate through each rule, but only save the last match\n    for (var i in this.rules) {\n      if(this.rules.hasOwnProperty(i)) {\n        var rule = this.rules[i];\n        if (window.matchMedia(rule.query).matches) {\n          match = rule;\n        }\n      }\n    }\n\n    if (match) {\n      this.replace(match.path);\n    }\n  }\n\n  /**\n   * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.\n   * @function\n   * @private\n   */\n  _addBreakpoints() {\n    for (var i in MediaQuery.queries) {\n      if (MediaQuery.queries.hasOwnProperty(i)) {\n        var query = MediaQuery.queries[i];\n        Interchange.SPECIAL_QUERIES[query.name] = query.value;\n      }\n    }\n  }\n\n  /**\n   * Checks the Interchange element for the provided media query + content pairings\n   * @function\n   * @private\n   * @param {Object} element - jQuery object that is an Interchange instance\n   * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys\n   */\n  _generateRules(element) {\n    var rulesList = [];\n    var rules;\n\n    if (this.options.rules) {\n      rules = this.options.rules;\n    }\n    else {\n      rules = this.$element.data('interchange');\n    }\n\n    rules =  typeof rules === 'string' ? rules.match(/\\[.*?, .*?\\]/g) : rules;\n\n    for (var i in rules) {\n      if(rules.hasOwnProperty(i)) {\n        var rule = rules[i].slice(1, -1).split(', ');\n        var path = rule.slice(0, -1).join('');\n        var query = rule[rule.length - 1];\n\n        if (Interchange.SPECIAL_QUERIES[query]) {\n          query = Interchange.SPECIAL_QUERIES[query];\n        }\n\n        rulesList.push({\n          path: path,\n          query: query\n        });\n      }\n    }\n\n    this.rules = rulesList;\n  }\n\n  /**\n   * Update the `src` property of an image, or change the HTML of a container, to the specified path.\n   * @function\n   * @param {String} path - Path to the image or HTML partial.\n   * @fires Interchange#replaced\n   */\n  replace(path) {\n    if (this.currentPath === path) return;\n\n    var _this = this,\n        trigger = 'replaced.zf.interchange';\n\n    // Replacing images\n    if (this.$element[0].nodeName === 'IMG') {\n      this.$element.attr('src', path).on('load', function() {\n        _this.currentPath = path;\n      })\n      .trigger(trigger);\n    }\n    // Replacing background images\n    else if (path.match(/\\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {\n      path = path.replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n      this.$element.css({ 'background-image': 'url('+path+')' })\n          .trigger(trigger);\n    }\n    // Replacing HTML\n    else {\n      $.get(path, function(response) {\n        _this.$element.html(response)\n             .trigger(trigger);\n        $(response).foundation();\n        _this.currentPath = path;\n      });\n    }\n\n    /**\n     * Fires when content in an Interchange element is done being loaded.\n     * @event Interchange#replaced\n     */\n    // this.$element.trigger('replaced.zf.interchange');\n  }\n\n  /**\n   * Destroys an instance of interchange.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('resizeme.zf.trigger')\n  }\n}\n\n/**\n * Default settings for plugin\n */\nInterchange.defaults = {\n  /**\n   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.\n   * @option\n   * @type {?array}\n   * @default null\n   */\n  rules: null\n};\n\nInterchange.SPECIAL_QUERIES = {\n  'landscape': 'screen and (orientation: landscape)',\n  'portrait': 'screen and (orientation: portrait)',\n  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'\n};\n\nexport {Interchange};\n","import $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * SmoothScroll module.\n * @module foundation.smooth-scroll\n */\nclass SmoothScroll extends Plugin {\n  /**\n   * Creates a new instance of SmoothScroll.\n   * @class\n   * @name SmoothScroll\n   * @fires SmoothScroll#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n    _setup(element, options) {\n        this.$element = element;\n        this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);\n        this.className = 'SmoothScroll'; // ie9 back compat\n\n        this._init();\n    }\n\n    /**\n     * Initialize the SmoothScroll plugin\n     * @private\n     */\n    _init() {\n        const id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');\n        this.$element.attr({ id });\n\n        this._events();\n    }\n\n    /**\n     * Initializes events for SmoothScroll.\n     * @private\n     */\n    _events() {\n        this._linkClickListener = this._handleLinkClick.bind(this);\n        this.$element.on('click.zf.smoothScroll', this._linkClickListener);\n        this.$element.on('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n\n    /**\n     * Handle the given event to smoothly scroll to the anchor pointed by the event target.\n     * @param {*} e - event\n     * @function\n     * @private\n     */\n    _handleLinkClick(e) {\n        // Follow the link if it does not point to an anchor.\n        if (!$(e.currentTarget).is('a[href^=\"#\"]')) return;\n\n        const arrival = e.currentTarget.getAttribute('href');\n\n        this._inTransition = true;\n\n        SmoothScroll.scrollToLoc(arrival, this.options, () => {\n            this._inTransition = false;\n        });\n\n        e.preventDefault();\n    };\n\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'\n     * @param {Object} options - The options to use.\n     * @param {Function} callback - The callback function.\n     * @static\n     * @function\n     */\n    static scrollToLoc(loc, options = SmoothScroll.defaults, callback) {\n        const $loc = $(loc);\n\n        // Do nothing if target does not exist to prevent errors\n        if (!$loc.length) return false;\n\n        var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);\n\n        $('html, body').stop(true).animate(\n            { scrollTop: scrollPos },\n            options.animationDuration,\n            options.animationEasing,\n            () => {\n                if (typeof callback === 'function'){\n                    callback();\n                }\n            }\n        );\n    }\n\n    /**\n     * Destroys the SmoothScroll instance.\n     * @function\n     */\n    _destroy() {\n        this.$element.off('click.zf.smoothScroll', this._linkClickListener)\n        this.$element.off('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n}\n\n/**\n * Default settings for plugin.\n */\nSmoothScroll.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {SmoothScroll}\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { SmoothScroll } from './foundation.smoothScroll';\n\n/**\n * Magellan module.\n * @module foundation.magellan\n * @requires foundation.smoothScroll\n */\n\nclass Magellan extends Plugin {\n  /**\n   * Creates a new instance of Magellan.\n   * @class\n   * @name Magellan\n   * @fires Magellan#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options  = $.extend({}, Magellan.defaults, this.$element.data(), options);\n    this.className = 'Magellan'; // ie9 back compat\n\n    this._init();\n    this.calcPoints();\n  }\n\n  /**\n   * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var id = this.$element[0].id || GetYoDigits(6, 'magellan');\n    var _this = this;\n    this.$targets = $('[data-magellan-target]');\n    this.$links = this.$element.find('a');\n    this.$element.attr({\n      'data-resize': id,\n      'data-scroll': id,\n      'id': id\n    });\n    this.$active = $();\n    this.scrollPos = parseInt(window.pageYOffset, 10);\n\n    this._events();\n  }\n\n  /**\n   * Calculates an array of pixel values that are the demarcation lines between locations on the page.\n   * Can be invoked if new elements are added or the size of a location changes.\n   * @function\n   */\n  calcPoints() {\n    var _this = this,\n        body = document.body,\n        html = document.documentElement;\n\n    this.points = [];\n    this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));\n    this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));\n\n    this.$targets.each(function(){\n      var $tar = $(this),\n          pt = Math.round($tar.offset().top - _this.options.threshold);\n      $tar.targetPoint = pt;\n      _this.points.push(pt);\n    });\n  }\n\n  /**\n   * Initializes events for Magellan.\n   * @private\n   */\n  _events() {\n    var _this = this,\n        $body = $('html, body'),\n        opts = {\n          duration: _this.options.animationDuration,\n          easing:   _this.options.animationEasing\n        };\n\n    $(window).one('load', function(){\n      if(_this.options.deepLinking){\n        if(location.hash){\n          _this.scrollToLoc(location.hash);\n        }\n      }\n      _this.calcPoints();\n      _this._updateActive();\n    });\n\n    _this.onLoadListener = onLoad($(window), function () {\n      _this.$element\n        .on({\n          'resizeme.zf.trigger': _this.reflow.bind(_this),\n          'scrollme.zf.trigger': _this._updateActive.bind(_this)\n        })\n        .on('click.zf.magellan', 'a[href^=\"#\"]', function (e) {\n          e.preventDefault();\n          var arrival   = this.getAttribute('href');\n          _this.scrollToLoc(arrival);\n        });\n    });\n\n    this._deepLinkScroll = function(e) {\n      if(_this.options.deepLinking) {\n        _this.scrollToLoc(window.location.hash);\n      }\n    };\n\n    $(window).on('hashchange', this._deepLinkScroll);\n  }\n\n  /**\n   * Function to scroll to a given location on the page.\n   * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'\n   * @function\n   */\n  scrollToLoc(loc) {\n    this._inTransition = true;\n    var _this = this;\n\n    var options = {\n      animationEasing: this.options.animationEasing,\n      animationDuration: this.options.animationDuration,\n      threshold: this.options.threshold,\n      offset: this.options.offset\n    };\n\n    SmoothScroll.scrollToLoc(loc, options, function() {\n      _this._inTransition = false;\n    })\n  }\n\n  /**\n   * Calls necessary functions to update Magellan upon DOM change\n   * @function\n   */\n  reflow() {\n    this.calcPoints();\n    this._updateActive();\n  }\n\n  /**\n   * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.\n   * @private\n   * @function\n   * @fires Magellan#update\n   */\n  _updateActive(/*evt, elem, scrollPos*/) {\n    if(this._inTransition) return;\n\n    const newScrollPos = parseInt(window.pageYOffset, 10);\n    const isScrollingUp = this.scrollPos > newScrollPos;\n    this.scrollPos = newScrollPos;\n\n    let activeIdx;\n    // Before the first point: no link\n    if(newScrollPos < this.points[0]){ /* do nothing */ }\n    // At the bottom of the page: last link\n    else if(newScrollPos + this.winHeight === this.docHeight){ activeIdx = this.points.length - 1; }\n    // Otherwhise, use the last visible link\n    else{\n      const visibleLinks = this.points.filter((p, i) => {\n        return (p - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) <= newScrollPos;\n      });\n      activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;\n    }\n\n    // Get the new active link\n    const $oldActive = this.$active;\n    let activeHash = '';\n    if(typeof activeIdx !== 'undefined'){\n      this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(activeIdx).data('magellan-target') + '\"]');\n      if (this.$active.length) activeHash = this.$active[0].getAttribute('href');\n    }else{\n      this.$active = $();\n    }\n    const isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);\n    const isNewHash = activeHash !== window.location.hash;\n\n    // Update the active link element\n    if(isNewActive) {\n      $oldActive.removeClass(this.options.activeClass);\n      this.$active.addClass(this.options.activeClass);\n    }\n\n    // Update the hash (it may have changed with the same active link)\n    if(this.options.deepLinking && isNewHash){\n      if(window.history.pushState){\n        // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384\n        const url = activeHash ? activeHash : window.location.pathname + window.location.search;\n        window.history.pushState(null, null, url);\n      }else{\n        window.location.hash = activeHash;\n      }\n    }\n\n    if (isNewActive) {\n      /**\n       * Fires when magellan is finished updating to the new active element.\n       * @event Magellan#update\n       */\n    \tthis.$element.trigger('update.zf.magellan', [this.$active]);\n\t  }\n  }\n\n  /**\n   * Destroys an instance of Magellan and resets the url of the window.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger .zf.magellan')\n        .find(`.${this.options.activeClass}`).removeClass(this.options.activeClass);\n\n    if(this.options.deepLinking){\n      var hash = this.$active[0].getAttribute('href');\n      window.location.hash.replace(hash, '');\n    }\n\n    $(window).off('hashchange', this._deepLinkScroll)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\n/**\n * Default settings for plugin\n */\nMagellan.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Class applied to the active locations link on the magellan container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  activeClass: 'is-active',\n  /**\n   * Allows the script to manipulate the url of the current page, and if supported, alter the history.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinking: false,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {Magellan};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, transitionend, RegExpEscape } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * OffCanvas module.\n * @module foundation.offcanvas\n * @requires foundation.util.keyboard\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass OffCanvas extends Plugin {\n  /**\n   * Creates a new instance of an off-canvas wrapper.\n   * @class\n   * @name OffCanvas\n   * @fires OffCanvas#init\n   * @param {Object} element - jQuery object to initialize.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.className = 'OffCanvas'; // ie9 back compat\n    this.$element = element;\n    this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);\n    this.contentClasses = { base: [], reveal: [] };\n    this.$lastTrigger = $();\n    this.$triggers = $();\n    this.position = 'left';\n    this.$content = $();\n    this.nested = !!(this.options.nested);\n\n    // Defines the CSS transition/position classes of the off-canvas content container.\n    $(['push', 'overlap']).each((index, val) => {\n      this.contentClasses.base.push('has-transition-'+val);\n    });\n    $(['left', 'right', 'top', 'bottom']).each((index, val) => {\n      this.contentClasses.base.push('has-position-'+val);\n      this.contentClasses.reveal.push('has-reveal-'+val);\n    });\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n    MediaQuery._init();\n\n    this._init();\n    this._events();\n\n    Keyboard.register('OffCanvas', {\n      'ESCAPE': 'close'\n    });\n\n  }\n\n  /**\n   * Initializes the off-canvas wrapper by adding the exit overlay (if needed).\n   * @function\n   * @private\n   */\n  _init() {\n    var id = this.$element.attr('id');\n\n    this.$element.attr('aria-hidden', 'true');\n\n    // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)\n    if (this.options.contentId) {\n      this.$content = $('#'+this.options.contentId);\n    } else if (this.$element.siblings('[data-off-canvas-content]').length) {\n      this.$content = this.$element.siblings('[data-off-canvas-content]').first();\n    } else {\n      this.$content = this.$element.closest('[data-off-canvas-content]').first();\n    }\n\n    if (!this.options.contentId) {\n      // Assume that the off-canvas element is nested if it isn't a sibling of the content\n      this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;\n\n    } else if (this.options.contentId && this.options.nested === null) {\n      // Warning if using content ID without setting the nested option\n      // Once the element is nested it is required to work properly in this case\n      console.warn('Remember to use the nested option if using the content ID option!');\n    }\n\n    if (this.nested === true) {\n      // Force transition overlap if nested\n      this.options.transition = 'overlap';\n      // Remove appropriate classes if already assigned in markup\n      this.$element.removeClass('is-transition-push');\n    }\n\n    this.$element.addClass(`is-transition-${this.options.transition} is-closed`);\n\n    // Find triggers that affect this element and add aria-expanded to them\n    this.$triggers = $(document)\n      .find('[data-open=\"'+id+'\"], [data-close=\"'+id+'\"], [data-toggle=\"'+id+'\"]')\n      .attr('aria-expanded', 'false')\n      .attr('aria-controls', id);\n\n    // Get position by checking for related CSS class\n    this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\\-(left|top|right|bottom)/)[1] : this.position;\n\n    // Add an overlay over the content if necessary\n    if (this.options.contentOverlay === true) {\n      var overlay = document.createElement('div');\n      var overlayPosition = $(this.$element).css(\"position\") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';\n      overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);\n      this.$overlay = $(overlay);\n      if(overlayPosition === 'is-overlay-fixed') {\n        $(this.$overlay).insertAfter(this.$element);\n      } else {\n        this.$content.append(this.$overlay);\n      }\n    }\n\n    // Get the revealOn option from the class.\n    var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\\\s]+)', 'g');\n    var revealOnClass = revealOnRegExp.exec(this.$element[0].className);\n    if (revealOnClass) {\n      this.options.isRevealed = true;\n      this.options.revealOn = this.options.revealOn || revealOnClass[1];\n    }\n\n    // Ensure the `reveal-on-*` class is set.\n    if (this.options.isRevealed === true && this.options.revealOn) {\n      this.$element.first().addClass(`${this.options.revealClass}${this.options.revealOn}`);\n      this._setMQChecker();\n    }\n\n    if (this.options.transitionTime) {\n      this.$element.css('transition-duration', this.options.transitionTime);\n    }\n\n    // Initally remove all transition/position CSS classes from off-canvas content container.\n    this._removeContentClasses();\n  }\n\n  /**\n   * Adds event handlers to the off-canvas wrapper and the exit overlay.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('.zf.trigger .zf.offcanvas').on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'keydown.zf.offcanvas': this._handleKeyboard.bind(this)\n    });\n\n    if (this.options.closeOnClick === true) {\n      var $target = this.options.contentOverlay ? this.$overlay : this.$content;\n      $target.on({'click.zf.offcanvas': this.close.bind(this)});\n    }\n  }\n\n  /**\n   * Applies event listener for elements that will reveal at certain breakpoints.\n   * @private\n   */\n  _setMQChecker() {\n    var _this = this;\n\n    this.onLoadListener = onLoad($(window), function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      }\n    });\n\n    $(window).on('changed.zf.mediaquery', function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      } else {\n        _this.reveal(false);\n      }\n    });\n  }\n\n  /**\n   * Removes the CSS transition/position classes of the off-canvas content container.\n   * Removing the classes is important when another off-canvas gets opened that uses the same content container.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _removeContentClasses(hasReveal) {\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.removeClass(this.contentClasses.base.join(' '));\n    } else if (hasReveal === false) {\n      this.$content.removeClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.\n   * Beforehand any transition/position class gets removed.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _addContentClasses(hasReveal) {\n    this._removeContentClasses(hasReveal);\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.addClass(`has-transition-${this.options.transition} has-position-${this.position}`);\n    } else if (hasReveal === true) {\n      this.$content.addClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.\n   * @param {Boolean} isRevealed - true if element should be revealed.\n   * @function\n   */\n  reveal(isRevealed) {\n    if (isRevealed) {\n      this.close();\n      this.isRevealed = true;\n      this.$element.attr('aria-hidden', 'false');\n      this.$element.off('open.zf.trigger toggle.zf.trigger');\n      this.$element.removeClass('is-closed');\n    } else {\n      this.isRevealed = false;\n      this.$element.attr('aria-hidden', 'true');\n      this.$element.off('open.zf.trigger toggle.zf.trigger').on({\n        'open.zf.trigger': this.open.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this)\n      });\n      this.$element.addClass('is-closed');\n    }\n    this._addContentClasses(isRevealed);\n  }\n\n  /**\n   * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.\n   * @private\n   */\n  _stopScrolling(event) {\n    return false;\n  }\n\n  // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios\n  // Only really works for y, not sure how to extend to x or if we need to.\n  _recordScrollable(event) {\n    let elem = this; // called from event handler context with this as elem\n\n     // If the element is scrollable (content overflows), then...\n    if (elem.scrollHeight !== elem.clientHeight) {\n      // If we're at the top, scroll down one pixel to allow scrolling up\n      if (elem.scrollTop === 0) {\n        elem.scrollTop = 1;\n      }\n      // If we're at the bottom, scroll up one pixel to allow scrolling down\n      if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {\n        elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;\n      }\n    }\n    elem.allowUp = elem.scrollTop > 0;\n    elem.allowDown = elem.scrollTop < (elem.scrollHeight - elem.clientHeight);\n    elem.lastY = event.originalEvent.pageY;\n  }\n\n  _stopScrollPropagation(event) {\n    let elem = this; // called from event handler context with this as elem\n    let up = event.pageY < elem.lastY;\n    let down = !up;\n    elem.lastY = event.pageY;\n\n    if((up && elem.allowUp) || (down && elem.allowDown)) {\n      event.stopPropagation();\n    } else {\n      event.preventDefault();\n    }\n  }\n\n  /**\n   * Opens the off-canvas menu.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   * @fires Offcanvas#opened\n   * @todo also trigger 'open' event?\n   */\n  open(event, trigger) {\n    if (this.$element.hasClass('is-open') || this.isRevealed) { return; }\n    var _this = this;\n\n    if (trigger) {\n      this.$lastTrigger = trigger;\n    }\n\n    if (this.options.forceTo === 'top') {\n      window.scrollTo(0, 0);\n    } else if (this.options.forceTo === 'bottom') {\n      window.scrollTo(0,document.body.scrollHeight);\n    }\n\n    if (this.options.transitionTime && this.options.transition !== 'overlap') {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);\n    } else {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');\n    }\n\n    this.$element.addClass('is-open').removeClass('is-closed');\n\n    this.$triggers.attr('aria-expanded', 'true');\n    this.$element.attr('aria-hidden', 'false');\n\n    this.$content.addClass('is-open-' + this.position);\n\n    // If `contentScroll` is set to false, add class and disable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);\n      this.$element.on('touchstart', this._recordScrollable);\n      this.$element.on('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-closable');\n    }\n\n    if (this.options.autoFocus === true) {\n      this.$element.one(transitionend(this.$element), function() {\n        if (!_this.$element.hasClass('is-open')) {\n          return; // exit if prematurely closed\n        }\n        var canvasFocus = _this.$element.find('[data-autofocus]');\n        if (canvasFocus.length) {\n            canvasFocus.eq(0).focus();\n        } else {\n            _this.$element.find('a, button').eq(0).focus();\n        }\n      });\n    }\n\n    if (this.options.trapFocus === true) {\n      this.$content.attr('tabindex', '-1');\n      Keyboard.trapFocus(this.$element);\n    }\n\n    this._addContentClasses();\n\n    /**\n     * Fires when the off-canvas menu opens.\n     * @event Offcanvas#opened\n     */\n    this.$element.trigger('opened.zf.offcanvas');\n  }\n\n  /**\n   * Closes the off-canvas menu.\n   * @function\n   * @param {Function} cb - optional cb to fire after closure.\n   * @fires Offcanvas#closed\n   */\n  close(cb) {\n    if (!this.$element.hasClass('is-open') || this.isRevealed) { return; }\n\n    var _this = this;\n\n    this.$element.removeClass('is-open');\n\n    this.$element.attr('aria-hidden', 'true')\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#closed\n       */\n        .trigger('closed.zf.offcanvas');\n\n    this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');\n\n    // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);\n      this.$element.off('touchstart', this._recordScrollable);\n      this.$element.off('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-closable');\n    }\n\n    this.$triggers.attr('aria-expanded', 'false');\n\n    if (this.options.trapFocus === true) {\n      this.$content.removeAttr('tabindex');\n      Keyboard.releaseFocus(this.$element);\n    }\n\n    // Listen to transitionEnd and add class when done.\n    this.$element.one(transitionend(this.$element), function(e) {\n      _this.$element.addClass('is-closed');\n      _this._removeContentClasses();\n    });\n  }\n\n  /**\n   * Toggles the off-canvas menu open or closed.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   */\n  toggle(event, trigger) {\n    if (this.$element.hasClass('is-open')) {\n      this.close(event, trigger);\n    }\n    else {\n      this.open(event, trigger);\n    }\n  }\n\n  /**\n   * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.\n   * @function\n   * @private\n   */\n  _handleKeyboard(e) {\n    Keyboard.handleKey(e, 'OffCanvas', {\n      close: () => {\n        this.close();\n        this.$lastTrigger.focus();\n        return true;\n      },\n      handled: () => {\n        e.stopPropagation();\n        e.preventDefault();\n      }\n    });\n  }\n\n  /**\n   * Destroys the offcanvas plugin.\n   * @function\n   */\n  _destroy() {\n    this.close();\n    this.$element.off('.zf.trigger .zf.offcanvas');\n    this.$overlay.off('.zf.offcanvas');\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\nOffCanvas.defaults = {\n  /**\n   * Allow the user to click outside of the menu to close it.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Adds an overlay on top of `[data-off-canvas-content]`.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentOverlay: true,\n\n  /**\n   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  contentId: null,\n\n  /**\n   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.\n   * @option\n   * @type {boolean}\n   * @default null\n   */\n  nested: null,\n\n  /**\n   * Enable/disable scrolling of the main content when an off canvas panel is open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentScroll: true,\n\n  /**\n   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.\n   * @option\n   * @type {number}\n   * @default null\n   */\n  transitionTime: null,\n\n  /**\n   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.\n   * @option\n   * @type {string}\n   * @default push\n   */\n  transition: 'push',\n\n  /**\n   * Force the page to scroll to top or bottom on open.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  forceTo: null,\n\n  /**\n   * Allow the offcanvas to remain open for certain breakpoints.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  isRevealed: false,\n\n  /**\n   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  revealOn: null,\n\n  /**\n   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoFocus: true,\n\n  /**\n   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.\n   * @option\n   * @type {string}\n   * @default reveal-for-\n   * @todo improve the regex testing for this.\n   */\n  revealClass: 'reveal-for-',\n\n  /**\n   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false\n}\n\nexport {OffCanvas};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Motion } from './foundation.util.motion';\nimport { Timer } from './foundation.util.timer';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { Touch } from './foundation.util.touch'\n\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timer\n * @requires foundation.util.imageLoader\n * @requires foundation.util.touch\n */\n\nclass Orbit extends Plugin {\n  /**\n  * Creates a new instance of an orbit carousel.\n  * @class\n  * @name Orbit\n  * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n  * @param {Object} options - Overrides to the default plugin settings.\n  */\n  _setup(element, options){\n    this.$element = element;\n    this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);\n    this.className = 'Orbit'; // ie9 back compat\n\n    Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.\n\n    this._init();\n\n    Keyboard.register('Orbit', {\n      'ltr': {\n        'ARROW_RIGHT': 'next',\n        'ARROW_LEFT': 'previous'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'next',\n        'ARROW_RIGHT': 'previous'\n      }\n    });\n  }\n\n  /**\n  * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.\n  * @function\n  * @private\n  */\n  _init() {\n    // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide\n    this._reset();\n\n    this.$wrapper = this.$element.find(`.${this.options.containerClass}`);\n    this.$slides = this.$element.find(`.${this.options.slideClass}`);\n\n    var $images = this.$element.find('img'),\n        initActive = this.$slides.filter('.is-active'),\n        id = this.$element[0].id || GetYoDigits(6, 'orbit');\n\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    if (!initActive.length) {\n      this.$slides.eq(0).addClass('is-active');\n    }\n\n    if (!this.options.useMUI) {\n      this.$slides.addClass('no-motionui');\n    }\n\n    if ($images.length) {\n      onImagesLoaded($images, this._prepareForOrbit.bind(this));\n    } else {\n      this._prepareForOrbit();//hehe\n    }\n\n    if (this.options.bullets) {\n      this._loadBullets();\n    }\n\n    this._events();\n\n    if (this.options.autoPlay && this.$slides.length > 1) {\n      this.geoSync();\n    }\n\n    if (this.options.accessible) { // allow wrapper to be focusable to enable arrow navigation\n      this.$wrapper.attr('tabindex', 0);\n    }\n  }\n\n  /**\n  * Creates a jQuery collection of bullets, if they are being used.\n  * @function\n  * @private\n  */\n  _loadBullets() {\n    this.$bullets = this.$element.find(`.${this.options.boxOfBullets}`).find('button');\n  }\n\n  /**\n  * Sets a `timer` object on the orbit, and starts the counter for the next slide.\n  * @function\n  */\n  geoSync() {\n    var _this = this;\n    this.timer = new Timer(\n      this.$element,\n      {\n        duration: this.options.timerDelay,\n        infinite: false\n      },\n      function() {\n        _this.changeSlide(true);\n      });\n    this.timer.start();\n  }\n\n  /**\n  * Sets wrapper and slide heights for the orbit.\n  * @function\n  * @private\n  */\n  _prepareForOrbit() {\n    var _this = this;\n    this._setWrapperHeight();\n  }\n\n  /**\n  * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.\n  * @function\n  * @private\n  * @param {Function} cb - a callback function to fire when complete.\n  */\n  _setWrapperHeight(cb) {//rewrite this to `for` loop\n    var max = 0, temp, counter = 0, _this = this;\n\n    this.$slides.each(function() {\n      temp = this.getBoundingClientRect().height;\n      $(this).attr('data-slide', counter);\n\n      // hide all slides but the active one\n      if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {\n        $(this).css({'display': 'none'});\n      }\n      max = temp > max ? temp : max;\n      counter++;\n    });\n\n    if (counter === this.$slides.length) {\n      this.$wrapper.css({'height': max}); //only change the wrapper height property once.\n      if(cb) {cb(max);} //fire callback with max height dimension.\n    }\n  }\n\n  /**\n  * Sets the max-height of each slide.\n  * @function\n  * @private\n  */\n  _setSlideHeight(height) {\n    this.$slides.each(function() {\n      $(this).css('max-height', height);\n    });\n  }\n\n  /**\n  * Adds event listeners to basically everything within the element.\n  * @function\n  * @private\n  */\n  _events() {\n    var _this = this;\n\n    //***************************************\n    //**Now using custom event - thanks to:**\n    //**      Yohai Ararat of Toronto      **\n    //***************************************\n    //\n    this.$element.off('.resizeme.zf.trigger').on({\n      'resizeme.zf.trigger': this._prepareForOrbit.bind(this)\n    })\n    if (this.$slides.length > 1) {\n\n      if (this.options.swipe) {\n        this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit')\n        .on('swipeleft.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(true);\n        }).on('swiperight.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(false);\n        });\n      }\n      //***************************************\n\n      if (this.options.autoPlay) {\n        this.$slides.on('click.zf.orbit', function() {\n          _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);\n          _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();\n        });\n\n        if (this.options.pauseOnHover) {\n          this.$element.on('mouseenter.zf.orbit', function() {\n            _this.timer.pause();\n          }).on('mouseleave.zf.orbit', function() {\n            if (!_this.$element.data('clickedOn')) {\n              _this.timer.start();\n            }\n          });\n        }\n      }\n\n      if (this.options.navButtons) {\n        var $controls = this.$element.find(`.${this.options.nextClass}, .${this.options.prevClass}`);\n        $controls.attr('tabindex', 0)\n        //also need to handle enter/return and spacebar key presses\n        .on('click.zf.orbit touchend.zf.orbit', function(e){\n\t  e.preventDefault();\n          _this.changeSlide($(this).hasClass(_this.options.nextClass));\n        });\n      }\n\n      if (this.options.bullets) {\n        this.$bullets.on('click.zf.orbit touchend.zf.orbit', function() {\n          if (/is-active/g.test(this.className)) { return false; }//if this is active, kick out of function.\n          var idx = $(this).data('slide'),\n          ltr = idx > _this.$slides.filter('.is-active').data('slide'),\n          $slide = _this.$slides.eq(idx);\n\n          _this.changeSlide(ltr, $slide, idx);\n        });\n      }\n\n      if (this.options.accessible) {\n        this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function(e) {\n          // handle keyboard event with keyboard util\n          Keyboard.handleKey(e, 'Orbit', {\n            next: function() {\n              _this.changeSlide(true);\n            },\n            previous: function() {\n              _this.changeSlide(false);\n            },\n            handled: function() { // if bullet is focused, make sure focus moves\n              if ($(e.target).is(_this.$bullets)) {\n                _this.$bullets.filter('.is-active').focus();\n              }\n            }\n          });\n        });\n      }\n    }\n  }\n\n  /**\n   * Resets Orbit so it can be reinitialized\n   */\n  _reset() {\n    // Don't do anything if there are no slides (first run)\n    if (typeof this.$slides == 'undefined') {\n      return;\n    }\n\n    if (this.$slides.length > 1) {\n      // Remove old events\n      this.$element.off('.zf.orbit').find('*').off('.zf.orbit')\n\n      // Restart timer if autoPlay is enabled\n      if (this.options.autoPlay) {\n        this.timer.restart();\n      }\n\n      // Reset all sliddes\n      this.$slides.each(function(el) {\n        $(el).removeClass('is-active is-active is-in')\n          .removeAttr('aria-live')\n          .hide();\n      });\n\n      // Show the first slide\n      this.$slides.first().addClass('is-active').show();\n\n      // Triggers when the slide has finished animating\n      this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);\n\n      // Select first bullet if bullets are present\n      if (this.options.bullets) {\n        this._updateBullets(0);\n      }\n    }\n  }\n\n  /**\n  * Changes the current slide to a new one.\n  * @function\n  * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.\n  * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.\n  * @param {Number} idx - the index of the new slide in its collection, if one chosen.\n  * @fires Orbit#slidechange\n  */\n  changeSlide(isLTR, chosenSlide, idx) {\n    if (!this.$slides) {return; } // Don't freak out if we're in the middle of cleanup\n    var $curSlide = this.$slides.filter('.is-active').eq(0);\n\n    if (/mui/g.test($curSlide[0].className)) { return false; } //if the slide is currently animating, kick out of the function\n\n    var $firstSlide = this.$slides.first(),\n    $lastSlide = this.$slides.last(),\n    dirIn = isLTR ? 'Right' : 'Left',\n    dirOut = isLTR ? 'Left' : 'Right',\n    _this = this,\n    $newSlide;\n\n    if (!chosenSlide) { //most of the time, this will be auto played or clicked from the navButtons.\n      $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!\n      (this.options.infiniteWrap ? $curSlide.next(`.${this.options.slideClass}`).length ? $curSlide.next(`.${this.options.slideClass}`) : $firstSlide : $curSlide.next(`.${this.options.slideClass}`))//pick next slide if moving left to right\n      :\n      (this.options.infiniteWrap ? $curSlide.prev(`.${this.options.slideClass}`).length ? $curSlide.prev(`.${this.options.slideClass}`) : $lastSlide : $curSlide.prev(`.${this.options.slideClass}`));//pick prev slide if moving right to left\n    } else {\n      $newSlide = chosenSlide;\n    }\n\n    if ($newSlide.length) {\n      /**\n      * Triggers before the next slide starts animating in and only if a next slide has been found.\n      * @event Orbit#beforeslidechange\n      */\n      this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);\n\n      if (this.options.bullets) {\n        idx = idx || this.$slides.index($newSlide); //grab index to update bullets\n        this._updateBullets(idx);\n      }\n\n      if (this.options.useMUI && !this.$element.is(':hidden')) {\n        Motion.animateIn(\n          $newSlide.addClass('is-active'),\n          this.options[`animInFrom${dirIn}`],\n          function(){\n            $newSlide.css({'display': 'block'}).attr('aria-live', 'polite');\n        });\n\n        Motion.animateOut(\n          $curSlide.removeClass('is-active'),\n          this.options[`animOutTo${dirOut}`],\n          function(){\n            $curSlide.removeAttr('aria-live');\n            if(_this.options.autoPlay && !_this.timer.isPaused){\n              _this.timer.restart();\n            }\n            //do stuff?\n          });\n      } else {\n        $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();\n        $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();\n        if (this.options.autoPlay && !this.timer.isPaused) {\n          this.timer.restart();\n        }\n      }\n    /**\n    * Triggers when the slide has finished animating in.\n    * @event Orbit#slidechange\n    */\n      this.$element.trigger('slidechange.zf.orbit', [$newSlide]);\n    }\n  }\n\n  /**\n  * Updates the active state of the bullets, if displayed.\n  * @function\n  * @private\n  * @param {Number} idx - the index of the current slide.\n  */\n  _updateBullets(idx) {\n    var $oldBullet = this.$element.find(`.${this.options.boxOfBullets}`)\n    .find('.is-active').removeClass('is-active').blur(),\n    span = $oldBullet.find('span:last').detach(),\n    $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);\n  }\n\n  /**\n  * Destroys the carousel and hides the element.\n  * @function\n  */\n  _destroy() {\n    this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();\n  }\n}\n\nOrbit.defaults = {\n  /**\n  * Tells the JS to look for and loadBullets.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  bullets: true,\n  /**\n  * Tells the JS to apply event listeners to nav buttons\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  navButtons: true,\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-right'\n  */\n  animInFromRight: 'slide-in-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-right'\n  */\n  animOutToRight: 'slide-out-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-left'\n  *\n  */\n  animInFromLeft: 'slide-in-left',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-left'\n  */\n  animOutToLeft: 'slide-out-left',\n  /**\n  * Allows Orbit to automatically animate on page load.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  autoPlay: true,\n  /**\n  * Amount of time, in ms, between slide transitions\n  * @option\n   * @type {number}\n  * @default 5000\n  */\n  timerDelay: 5000,\n  /**\n  * Allows Orbit to infinitely loop through the slides\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  infiniteWrap: true,\n  /**\n  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  swipe: true,\n  /**\n  * Allows the timing function to pause animation on hover.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  pauseOnHover: true,\n  /**\n  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  accessible: true,\n  /**\n  * Class applied to the container of Orbit\n  * @option\n   * @type {string}\n  * @default 'orbit-container'\n  */\n  containerClass: 'orbit-container',\n  /**\n  * Class applied to individual slides.\n  * @option\n   * @type {string}\n  * @default 'orbit-slide'\n  */\n  slideClass: 'orbit-slide',\n  /**\n  * Class applied to the bullet container. You're welcome.\n  * @option\n   * @type {string}\n  * @default 'orbit-bullets'\n  */\n  boxOfBullets: 'orbit-bullets',\n  /**\n  * Class applied to the `next` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-next'\n  */\n  nextClass: 'orbit-next',\n  /**\n  * Class applied to the `previous` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-previous'\n  */\n  prevClass: 'orbit-previous',\n  /**\n  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  useMUI: true\n};\n\nexport {Orbit};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { DropdownMenu } from './foundation.dropdownMenu';\nimport { Drilldown } from './foundation.drilldown';\nimport { AccordionMenu } from './foundation.accordionMenu';\n\nlet MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: DropdownMenu\n  },\n drilldown: {\n    cssClass: 'drilldown',\n    plugin: Drilldown\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: AccordionMenu\n  }\n};\n\n  // import \"foundation.util.triggers.js\";\n\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveMenu extends Plugin {\n  /**\n   * Creates a new instance of a responsive menu.\n   * @class\n   * @name ResponsiveMenu\n   * @fires ResponsiveMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.rules = this.$element.data('responsive-menu');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveMenu'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n\n    MediaQuery._init();\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n    // Add data-mutate since children may need it.\n    this.$element.attr('data-mutate', (this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')));\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    $(window).on('changed.zf.mediaquery', function() {\n      _this._checkMediaQueries();\n    });\n    // $(window).on('resize.zf.ResponsiveMenu', function() {\n    //   _this._checkMediaQueries();\n    // });\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    this.currentPlugin.destroy();\n    $(window).off('.zf.ResponsiveMenu');\n  }\n}\n\nResponsiveMenu.defaults = {};\n\nexport {ResponsiveMenu};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion\n */\n\nclass ResponsiveToggle extends Plugin {\n  /**\n   * Creates a new instance of Tab Bar.\n   * @class\n   * @name ResponsiveToggle\n   * @fires ResponsiveToggle#init\n   * @param {jQuery} element - jQuery object to attach tab bar functionality to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n    this.className = 'ResponsiveToggle'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the tab bar by finding the target element, toggling element, and running update().\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var targetID = this.$element.data('responsive-toggle');\n    if (!targetID) {\n      console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');\n    }\n\n    this.$targetMenu = $(`#${targetID}`);\n    this.$toggler = this.$element.find('[data-toggle]').filter(function() {\n      var target = $(this).data('toggle');\n      return (target === targetID || target === \"\");\n    });\n    this.options = $.extend({}, this.options, this.$targetMenu.data());\n\n    // If they were set, parse the animation classes\n    if(this.options.animate) {\n      let input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n\n    this._update();\n  }\n\n  /**\n   * Adds necessary event handlers for the tab bar to work.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this._updateMqHandler = this._update.bind(this);\n\n    $(window).on('changed.zf.mediaquery', this._updateMqHandler);\n\n    this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));\n  }\n\n  /**\n   * Checks the current media query to determine if the tab bar should be visible or hidden.\n   * @function\n   * @private\n   */\n  _update() {\n    // Mobile\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      this.$element.show();\n      this.$targetMenu.hide();\n    }\n\n    // Desktop\n    else {\n      this.$element.hide();\n      this.$targetMenu.show();\n    }\n  }\n\n  /**\n   * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.\n   * @function\n   * @fires ResponsiveToggle#toggled\n   */\n  toggleMenu() {\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      /**\n       * Fires when the element attached to the tab bar toggles.\n       * @event ResponsiveToggle#toggled\n       */\n      if(this.options.animate) {\n        if (this.$targetMenu.is(':hidden')) {\n          Motion.animateIn(this.$targetMenu, this.animationIn, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n            this.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');\n          });\n        }\n        else {\n          Motion.animateOut(this.$targetMenu, this.animationOut, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n          });\n        }\n      }\n      else {\n        this.$targetMenu.toggle(0);\n        this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        this.$element.trigger('toggled.zf.responsiveToggle');\n      }\n    }\n  };\n\n  _destroy() {\n    this.$element.off('.zf.responsiveToggle');\n    this.$toggler.off('.zf.responsiveToggle');\n\n    $(window).off('changed.zf.mediaquery', this._updateMqHandler);\n  }\n}\n\nResponsiveToggle.defaults = {\n  /**\n   * The breakpoint after which the menu is always shown, and the tab bar is hidden.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  hideFor: 'medium',\n\n  /**\n   * To decide if the toggle should be animated or not.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport { ResponsiveToggle };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nclass Reveal extends Plugin {\n  /**\n   * Creates a new instance of Reveal.\n   * @class\n   * @name Reveal\n   * @param {jQuery} element - jQuery object to use for the modal.\n   * @param {Object} options - optional parameters.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);\n    this.className = 'Reveal'; // ie9 back compat\n    this._init();\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    Keyboard.register('Reveal', {\n      'ESCAPE': 'close',\n    });\n  }\n\n  /**\n   * Initializes the modal by adding the overlay and close buttons, (if selected).\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    this.id = this.$element.attr('id');\n    this.isActive = false;\n    this.cached = {mq: MediaQuery.current};\n\n    this.$anchor = $(`[data-open=\"${this.id}\"]`).length ? $(`[data-open=\"${this.id}\"]`) : $(`[data-toggle=\"${this.id}\"]`);\n    this.$anchor.attr({\n      'aria-controls': this.id,\n      'aria-haspopup': true,\n      'tabindex': 0\n    });\n\n    if (this.options.fullScreen || this.$element.hasClass('full')) {\n      this.options.fullScreen = true;\n      this.options.overlay = false;\n    }\n    if (this.options.overlay && !this.$overlay) {\n      this.$overlay = this._makeOverlay(this.id);\n    }\n\n    this.$element.attr({\n        'role': 'dialog',\n        'aria-hidden': true,\n        'data-yeti-box': this.id,\n        'data-resize': this.id\n    });\n\n    if(this.$overlay) {\n      this.$element.detach().appendTo(this.$overlay);\n    } else {\n      this.$element.detach().appendTo($(this.options.appendTo));\n      this.$element.addClass('without-overlay');\n    }\n    this._events();\n    if (this.options.deepLink && window.location.hash === ( `#${this.id}`)) {\n      this.onLoadListener = onLoad($(window), () => this.open());\n    }\n  }\n\n  /**\n   * Creates an overlay div to display behind the modal.\n   * @private\n   */\n  _makeOverlay() {\n    var additionalOverlayClasses = '';\n\n    if (this.options.additionalOverlayClasses) {\n      additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;\n    }\n\n    return $('<div></div>')\n      .addClass('reveal-overlay' + additionalOverlayClasses)\n      .appendTo(this.options.appendTo);\n  }\n\n  /**\n   * Updates position of modal\n   * TODO:  Figure out if we actually need to cache these values or if it doesn't matter\n   * @private\n   */\n  _updatePosition() {\n    var width = this.$element.outerWidth();\n    var outerWidth = $(window).width();\n    var height = this.$element.outerHeight();\n    var outerHeight = $(window).height();\n    var left, top = null;\n    if (this.options.hOffset === 'auto') {\n      left = parseInt((outerWidth - width) / 2, 10);\n    } else {\n      left = parseInt(this.options.hOffset, 10);\n    }\n    if (this.options.vOffset === 'auto') {\n      if (height > outerHeight) {\n        top = parseInt(Math.min(100, outerHeight / 10), 10);\n      } else {\n        top = parseInt((outerHeight - height) / 4, 10);\n      }\n    } else if (this.options.vOffset !== null) {\n      top = parseInt(this.options.vOffset, 10);\n    }\n\n    if (top !== null) {\n      this.$element.css({top: top + 'px'});\n    }\n\n    // only worry about left if we don't have an overlay or we have a horizontal offset,\n    // otherwise we're perfectly in the middle\n    if (!this.$overlay || (this.options.hOffset !== 'auto')) {\n      this.$element.css({left: left + 'px'});\n      this.$element.css({margin: '0px'});\n    }\n\n  }\n\n  /**\n   * Adds event handlers for the modal.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': (event, $element) => {\n        if ((event.target === _this.$element[0]) ||\n            ($(event.target).parents('[data-closable]')[0] === $element)) { // only close reveal when it's explicitly called\n          return this.close.apply(this);\n        }\n      },\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': function() {\n        _this._updatePosition();\n      }\n    });\n\n    if (this.options.closeOnClick && this.options.overlay) {\n      this.$overlay.off('.zf.reveal').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) {\n              return;\n        }\n        _this.close();\n      });\n    }\n    if (this.options.deepLink) {\n      $(window).on(`hashchange.zf.reveal:${this.id}`, this._handleState.bind(this));\n    }\n  }\n\n  /**\n   * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.\n   * @private\n   */\n  _handleState(e) {\n    if(window.location.hash === ( '#' + this.id) && !this.isActive){ this.open(); }\n    else{ this.close(); }\n  }\n\n  /**\n  * Disables the scroll when Reveal is shown to prevent the background from shifting\n  * @param {number} scrollTop - Scroll to visually apply, window current scroll by default\n  */\n  _disableScroll(scrollTop) {\n    scrollTop = scrollTop || $(window).scrollTop();\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", -scrollTop);\n    }\n  }\n\n  /**\n  * Reenables the scroll when Reveal closes\n  * @param {number} scrollTop - Scroll to restore, html \"top\" property by default (as set by `_disableScroll`)\n  */\n  _enableScroll(scrollTop) {\n    scrollTop = scrollTop || parseInt($(\"html\").css(\"top\"));\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", \"\");\n      $(window).scrollTop(-scrollTop);\n    }\n  }\n\n\n  /**\n   * Opens the modal controlled by `this.$anchor`, and closes all others by default.\n   * @function\n   * @fires Reveal#closeme\n   * @fires Reveal#open\n   */\n  open() {\n    // either update or replace browser history\n    const hash = `#${this.id}`;\n    if (this.options.deepLink && window.location.hash !== hash) {\n\n      if (window.history.pushState) {\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', hash);\n        } else {\n          window.history.replaceState({}, '', hash);\n        }\n      } else {\n        window.location.hash = hash;\n      }\n    }\n\n    // Remember anchor that opened it to set focus back later, have general anchors as fallback\n    this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;\n\n    this.isActive = true;\n\n    // Make elements invisible, but remove display: none so we can get size and positioning\n    this.$element\n        .css({ 'visibility': 'hidden' })\n        .show()\n        .scrollTop(0);\n    if (this.options.overlay) {\n      this.$overlay.css({'visibility': 'hidden'}).show();\n    }\n\n    this._updatePosition();\n\n    this.$element\n      .hide()\n      .css({ 'visibility': '' });\n\n    if(this.$overlay) {\n      this.$overlay.css({'visibility': ''}).hide();\n      if(this.$element.hasClass('fast')) {\n        this.$overlay.addClass('fast');\n      } else if (this.$element.hasClass('slow')) {\n        this.$overlay.addClass('slow');\n      }\n    }\n\n\n    if (!this.options.multipleOpened) {\n      /**\n       * Fires immediately before the modal opens.\n       * Closes any other modals that are currently open\n       * @event Reveal#closeme\n       */\n      this.$element.trigger('closeme.zf.reveal', this.id);\n    }\n\n    this._disableScroll();\n\n    var _this = this;\n\n    // Motion UI method of reveal\n    if (this.options.animationIn) {\n      function afterAnimation(){\n        _this.$element\n          .attr({\n            'aria-hidden': false,\n            'tabindex': -1\n          })\n          .focus();\n        _this._addGlobalClasses();\n        Keyboard.trapFocus(_this.$element);\n      }\n      if (this.options.overlay) {\n        Motion.animateIn(this.$overlay, 'fade-in');\n      }\n      Motion.animateIn(this.$element, this.options.animationIn, () => {\n        if(this.$element) { // protect against object having been removed\n          this.focusableElements = Keyboard.findFocusable(this.$element);\n          afterAnimation();\n        }\n      });\n    }\n    // jQuery method of reveal\n    else {\n      if (this.options.overlay) {\n        this.$overlay.show(0);\n      }\n      this.$element.show(this.options.showDelay);\n    }\n\n    // handle accessibility\n    this.$element\n      .attr({\n        'aria-hidden': false,\n        'tabindex': -1\n      })\n      .focus();\n    Keyboard.trapFocus(this.$element);\n\n    this._addGlobalClasses();\n\n    this._addGlobalListeners();\n\n    /**\n     * Fires when the modal has successfully opened.\n     * @event Reveal#open\n     */\n    this.$element.trigger('open.zf.reveal');\n  }\n\n  /**\n   * Adds classes and listeners on document required by open modals.\n   *\n   * The following classes are added and updated:\n   * - `.is-reveal-open` - Prevents the scroll on document\n   * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the\n   *                       scroll was not disabled. This prevent a \"shift\" of the page content due\n   *                       the scrollbar disappearing when the modal opens.\n   *\n   * @private\n   */\n  _addGlobalClasses() {\n    const updateScrollbarClass = () => {\n      $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));\n    };\n\n    this.$element.on('resizeme.zf.trigger.revealScrollbarListener', () => updateScrollbarClass());\n    updateScrollbarClass();\n    $('html').addClass('is-reveal-open');\n  }\n\n  /**\n   * Removes classes and listeners on document that were required by open modals.\n   * @private\n   */\n  _removeGlobalClasses() {\n    this.$element.off('resizeme.zf.trigger.revealScrollbarListener');\n    $('html').removeClass('is-reveal-open');\n    $('html').removeClass('zf-has-scroll');\n  }\n\n  /**\n   * Adds extra event handlers for the body and window if necessary.\n   * @private\n   */\n  _addGlobalListeners() {\n    var _this = this;\n    if(!this.$element) { return; } // If we're in the middle of cleanup, don't freak out\n    this.focusableElements = Keyboard.findFocusable(this.$element);\n\n    if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {\n      $('body').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) { return; }\n        _this.close();\n      });\n    }\n\n    if (this.options.closeOnEsc) {\n      $(window).on('keydown.zf.reveal', function(e) {\n        Keyboard.handleKey(e, 'Reveal', {\n          close: function() {\n            if (_this.options.closeOnEsc) {\n              _this.close();\n            }\n          }\n        });\n      });\n    }\n  }\n\n  /**\n   * Closes the modal.\n   * @function\n   * @fires Reveal#closed\n   */\n  close() {\n    if (!this.isActive || !this.$element.is(':visible')) {\n      return false;\n    }\n    var _this = this;\n\n    // Motion UI method of hiding\n    if (this.options.animationOut) {\n      if (this.options.overlay) {\n        Motion.animateOut(this.$overlay, 'fade-out');\n      }\n\n      Motion.animateOut(this.$element, this.options.animationOut, finishUp);\n    }\n    // jQuery method of hiding\n    else {\n      this.$element.hide(this.options.hideDelay);\n\n      if (this.options.overlay) {\n        this.$overlay.hide(0, finishUp);\n      }\n      else {\n        finishUp();\n      }\n    }\n\n    // Conditionals to remove extra event listeners added on open\n    if (this.options.closeOnEsc) {\n      $(window).off('keydown.zf.reveal');\n    }\n\n    if (!this.options.overlay && this.options.closeOnClick) {\n      $('body').off('click.zf.reveal');\n    }\n\n    this.$element.off('keydown.zf.reveal');\n\n    function finishUp() {\n\n      // Get the current top before the modal is closed and restore the scroll after.\n      // TODO: use component properties instead of HTML properties\n      // See https://github.com/zurb/foundation-sites/pull/10786\n      var scrollTop = parseInt($(\"html\").css(\"top\"));\n\n      if ($('.reveal:visible').length  === 0) {\n        _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n      }\n\n      Keyboard.releaseFocus(_this.$element);\n\n      _this.$element.attr('aria-hidden', true);\n\n      _this._enableScroll(scrollTop);\n\n      /**\n      * Fires when the modal is done closing.\n      * @event Reveal#closed\n      */\n      _this.$element.trigger('closed.zf.reveal');\n    }\n\n    /**\n    * Resets the modal content\n    * This prevents a running video to keep going in the background\n    */\n    if (this.options.resetOnClose) {\n      this.$element.html(this.$element.html());\n    }\n\n    this.isActive = false;\n    // If deepLink and we did not switched to an other modal...\n    if (_this.options.deepLink && window.location.hash === `#${this.id}`) {\n      // Remove the history hash\n      if (window.history.replaceState) {\n        const urlWithoutHash = window.location.pathname + window.location.search;\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', urlWithoutHash); // remove the hash\n        } else {\n          window.history.replaceState('', document.title, urlWithoutHash);\n        }\n      } else {\n        window.location.hash = '';\n      }\n    }\n\n    this.$activeAnchor.focus();\n  }\n\n  /**\n   * Toggles the open/closed state of a modal.\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.close();\n    } else {\n      this.open();\n    }\n  };\n\n  /**\n   * Destroys an instance of a modal.\n   * @function\n   */\n  _destroy() {\n    if (this.options.overlay) {\n      this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()\n      this.$overlay.hide().off().remove();\n    }\n    this.$element.hide().off();\n    this.$anchor.off('.zf');\n    $(window).off(`.zf.reveal:${this.id}`)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n\n    if ($('.reveal:visible').length  === 0) {\n      this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n    }\n  };\n}\n\nReveal.defaults = {\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationIn: '',\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationOut: '',\n  /**\n   * Time, in ms, to delay the opening of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  showDelay: 0,\n  /**\n   * Time, in ms, to delay the closing of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hideDelay: 0,\n  /**\n   * Allows a click on the body/overlay to close the modal.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allows the modal to close if the user presses the `ESCAPE` key.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnEsc: true,\n  /**\n   * If true, allows multiple modals to be displayed at once.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multipleOpened: false,\n  /**\n   * Distance, in pixels, the modal should push down from the top of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  vOffset: 'auto',\n  /**\n   * Distance, in pixels, the modal should push in from the side of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  hOffset: 'auto',\n  /**\n   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  fullScreen: false,\n  /**\n   * Allows the modal to generate an overlay div, which will cover the view when modal opens.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  overlay: true,\n  /**\n   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  resetOnClose: false,\n  /**\n   * Link the location hash to the modal.\n   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open modal\n   * @option\n   * @default false\n   */\n  updateHistory: false,\n    /**\n   * Allows the modal to append to custom div.\n   * @option\n   * @type {string}\n   * @default \"body\"\n   */\n  appendTo: \"body\",\n  /**\n   * Allows adding additional class names to the reveal overlay.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  additionalOverlayClasses: ''\n};\n\nexport {Reveal};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Move } from './foundation.util.motion';\nimport { GetYoDigits, rtl as Rtl } from './foundation.core.utils';\n\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Touch } from './foundation.util.touch';\n\nimport { Triggers } from './foundation.util.triggers';\n/**\n * Slider module.\n * @module foundation.slider\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n */\n\nclass Slider extends Plugin {\n  /**\n   * Creates a new instance of a slider control.\n   * @class\n   * @name Slider\n   * @param {jQuery} element - jQuery object to make into a slider control.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Slider.defaults, this.$element.data(), options);\n    this.className = 'Slider'; // ie9 back compat\n\n  // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.\n    Touch.init($);\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Slider', {\n      'ltr': {\n        'ARROW_RIGHT': 'increase',\n        'ARROW_UP': 'increase',\n        'ARROW_DOWN': 'decrease',\n        'ARROW_LEFT': 'decrease',\n        'SHIFT_ARROW_RIGHT': 'increase_fast',\n        'SHIFT_ARROW_UP': 'increase_fast',\n        'SHIFT_ARROW_DOWN': 'decrease_fast',\n        'SHIFT_ARROW_LEFT': 'decrease_fast',\n        'HOME': 'min',\n        'END': 'max'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'increase',\n        'ARROW_RIGHT': 'decrease',\n        'SHIFT_ARROW_LEFT': 'increase_fast',\n        'SHIFT_ARROW_RIGHT': 'decrease_fast'\n      }\n    });\n  }\n\n  /**\n   * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).\n   * @function\n   * @private\n   */\n  _init() {\n    this.inputs = this.$element.find('input');\n    this.handles = this.$element.find('[data-slider-handle]');\n\n    this.$handle = this.handles.eq(0);\n    this.$input = this.inputs.length ? this.inputs.eq(0) : $(`#${this.$handle.attr('aria-controls')}`);\n    this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);\n\n    var isDbl = false,\n        _this = this;\n    if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {\n      this.options.disabled = true;\n      this.$element.addClass(this.options.disabledClass);\n    }\n    if (!this.inputs.length) {\n      this.inputs = $().add(this.$input);\n      this.options.binding = true;\n    }\n\n    this._setInitAttr(0);\n\n    if (this.handles[1]) {\n      this.options.doubleSided = true;\n      this.$handle2 = this.handles.eq(1);\n      this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $(`#${this.$handle2.attr('aria-controls')}`);\n\n      if (!this.inputs[1]) {\n        this.inputs = this.inputs.add(this.$input2);\n      }\n      isDbl = true;\n\n      // this.$handle.triggerHandler('click.zf.slider');\n      this._setInitAttr(1);\n    }\n\n    // Set handle positions\n    this.setHandles();\n\n    this._events();\n  }\n\n  setHandles() {\n    if(this.handles[1]) {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, () => {\n        this._setHandlePos(this.$handle2, this.inputs.eq(1).val(), true);\n      });\n    } else {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);\n    }\n  }\n\n  _reflow() {\n    this.setHandles();\n  }\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)\n  */\n  _pctOfBar(value) {\n    var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start)\n\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    }\n\n    return pctOfBar.toFixed(2)\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value\n  */\n  _value(pctOfBar) {\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    }\n    var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);\n\n    return value\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function\n  */\n  _logTransform(value) {\n    return baseLog(this.options.nonLinearBase, ((value*(this.options.nonLinearBase-1))+1))\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function\n  */\n  _powTransform(value) {\n    return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1)\n  }\n\n  /**\n   * Sets the position of the selected handle and fill bar.\n   * @function\n   * @private\n   * @param {jQuery} $hndl - the selected handle to move.\n   * @param {Number} location - floating point between the start and end values of the slider bar.\n   * @param {Function} cb - callback function to fire on completion.\n   * @fires Slider#moved\n   * @fires Slider#changed\n   */\n  _setHandlePos($hndl, location, noInvert, cb) {\n    // don't move if the slider has been disabled since its initialization\n    if (this.$element.hasClass(this.options.disabledClass)) {\n      return;\n    }\n    //might need to alter that slightly for bars that will have odd number selections.\n    location = parseFloat(location);//on input change events, convert string to number...grumble.\n\n    // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max\n    if (location < this.options.start) { location = this.options.start; }\n    else if (location > this.options.end) { location = this.options.end; }\n\n    var isDbl = this.options.doubleSided;\n\n    //this is for single-handled vertical sliders, it adjusts the value to account for the slider being \"upside-down\"\n    //for click and drag events, it's weird due to the scale(-1, 1) css property\n    if (this.options.vertical && !noInvert) {\n      location = this.options.end - location;\n    }\n\n    if (isDbl) { //this block is to prevent 2 handles from crossing eachother. Could/should be improved.\n      if (this.handles.index($hndl) === 0) {\n        var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));\n        location = location >= h2Val ? h2Val - this.options.step : location;\n      } else {\n        var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));\n        location = location <= h1Val ? h1Val + this.options.step : location;\n      }\n    }\n\n    var _this = this,\n        vert = this.options.vertical,\n        hOrW = vert ? 'height' : 'width',\n        lOrT = vert ? 'top' : 'left',\n        handleDim = $hndl[0].getBoundingClientRect()[hOrW],\n        elemDim = this.$element[0].getBoundingClientRect()[hOrW],\n        //percentage of bar min/max value based on click or drag point\n        pctOfBar = this._pctOfBar(location),\n        //number of actual pixels to shift the handle, based on the percentage obtained above\n        pxToMove = (elemDim - handleDim) * pctOfBar,\n        //percentage of bar to shift the handle\n        movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);\n        //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value\n        location = parseFloat(location.toFixed(this.options.decimal));\n        // declare empty object for css adjustments, only used with 2 handled-sliders\n    var css = {};\n\n    this._setValues($hndl, location);\n\n    // TODO update to calculate based on values set to respective inputs??\n    if (isDbl) {\n      var isLeftHndl = this.handles.index($hndl) === 0,\n          //empty variable, will be used for min-height/width for fill bar\n          dim,\n          //percentage w/h of the handle compared to the slider bar\n          handlePct =  ~~(percent(handleDim, elemDim) * 100);\n      //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar\n      if (isLeftHndl) {\n        //left or top percentage value to apply to the fill bar.\n        css[lOrT] = `${movement}%`;\n        //calculate the new min-height/width for the fill bar.\n        dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;\n        //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider\n        //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.\n        if (cb && typeof cb === 'function') { cb(); }//this is only needed for the initialization of 2 handled sliders\n      } else {\n        //just caching the value of the left/bottom handle's left/top property\n        var handlePos = parseFloat(this.$handle[0].style[lOrT]);\n        //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0\n        //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself\n        dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start)/((this.options.end-this.options.start)/100) : handlePos) + handlePct;\n      }\n      // assign the min-height/width to our css object\n      css[`min-${hOrW}`] = `${dim}%`;\n    }\n\n    this.$element.one('finished.zf.animate', function() {\n                    /**\n                     * Fires when the handle is done moving.\n                     * @event Slider#moved\n                     */\n                    _this.$element.trigger('moved.zf.slider', [$hndl]);\n                });\n\n    //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.\n    var moveTime = this.$element.data('dragging') ? 1000/60 : this.options.moveTime;\n\n    Move(moveTime, $hndl, function() {\n      // adjusting the left/top property of the handle, based on the percentage calculated above\n      // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,\n      // fall back to next best guess.\n      if (isNaN(movement)) {\n        $hndl.css(lOrT, `${pctOfBar * 100}%`);\n      }\n      else {\n        $hndl.css(lOrT, `${movement}%`);\n      }\n\n      if (!_this.options.doubleSided) {\n        //if single-handled, a simple method to expand the fill bar\n        _this.$fill.css(hOrW, `${pctOfBar * 100}%`);\n      } else {\n        //otherwise, use the css object we created above\n        _this.$fill.css(css);\n      }\n    });\n\n\n    /**\n     * Fires when the value has not been change for a given time.\n     * @event Slider#changed\n     */\n    clearTimeout(_this.timeout);\n    _this.timeout = setTimeout(function(){\n      _this.$element.trigger('changed.zf.slider', [$hndl]);\n    }, _this.options.changedDelay);\n  }\n\n  /**\n   * Sets the initial attribute for the slider element.\n   * @function\n   * @private\n   * @param {Number} idx - index of the current handle/input to use.\n   */\n  _setInitAttr(idx) {\n    var initVal = (idx === 0 ? this.options.initialStart : this.options.initialEnd)\n    var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');\n    this.inputs.eq(idx).attr({\n      'id': id,\n      'max': this.options.end,\n      'min': this.options.start,\n      'step': this.options.step\n    });\n    this.inputs.eq(idx).val(initVal);\n    this.handles.eq(idx).attr({\n      'role': 'slider',\n      'aria-controls': id,\n      'aria-valuemax': this.options.end,\n      'aria-valuemin': this.options.start,\n      'aria-valuenow': initVal,\n      'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',\n      'tabindex': 0\n    });\n  }\n\n  /**\n   * Sets the input and `aria-valuenow` values for the slider element.\n   * @function\n   * @private\n   * @param {jQuery} $handle - the currently selected handle.\n   * @param {Number} val - floating point of the new value.\n   */\n  _setValues($handle, val) {\n    var idx = this.options.doubleSided ? this.handles.index($handle) : 0;\n    this.inputs.eq(idx).val(val);\n    $handle.attr('aria-valuenow', val);\n  }\n\n  /**\n   * Handles events on the slider element.\n   * Calculates the new location of the current handle.\n   * If there are two handles and the bar was clicked, it determines which handle to move.\n   * @function\n   * @private\n   * @param {Object} e - the `event` object passed from the listener.\n   * @param {jQuery} $handle - the current handle to calculate for, if selected.\n   * @param {Number} val - floating point number for the new value of the slider.\n   * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.\n   */\n  _handleEvent(e, $handle, val) {\n    var value, hasVal;\n    if (!val) {//click or drag events\n      e.preventDefault();\n      var _this = this,\n          vertical = this.options.vertical,\n          param = vertical ? 'height' : 'width',\n          direction = vertical ? 'top' : 'left',\n          eventOffset = vertical ? e.pageY : e.pageX,\n          halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,\n          barDim = this.$element[0].getBoundingClientRect()[param],\n          windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();\n\n\n      var elemOffset = this.$element.offset()[direction];\n\n      // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...\n      // best way to guess this is simulated is if clientY == pageY\n      if (e.clientY === e.pageY) { eventOffset = eventOffset + windowScroll; }\n      var eventFromBar = eventOffset - elemOffset;\n      var barXY;\n      if (eventFromBar < 0) {\n        barXY = 0;\n      } else if (eventFromBar > barDim) {\n        barXY = barDim;\n      } else {\n        barXY = eventFromBar;\n      }\n      var offsetPct = percent(barXY, barDim);\n\n      value = this._value(offsetPct);\n\n      // turn everything around for RTL, yay math!\n      if (Rtl() && !this.options.vertical) {value = this.options.end - value;}\n\n      value = _this._adjustValue(null, value);\n      //boolean flag for the setHandlePos fn, specifically for vertical sliders\n      hasVal = false;\n\n      if (!$handle) {//figure out which handle it is, pass it to the next function.\n        var firstHndlPos = absPosition(this.$handle, direction, barXY, param),\n            secndHndlPos = absPosition(this.$handle2, direction, barXY, param);\n            $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;\n      }\n\n    } else {//change event on input\n      value = this._adjustValue(null, val);\n      hasVal = true;\n    }\n\n    this._setHandlePos($handle, value, hasVal);\n  }\n\n  /**\n   * Adjustes value for handle in regard to step value. returns adjusted value\n   * @function\n   * @private\n   * @param {jQuery} $handle - the selected handle.\n   * @param {Number} value - value to adjust. used if $handle is falsy\n   */\n  _adjustValue($handle, value) {\n    var val,\n      step = this.options.step,\n      div = parseFloat(step/2),\n      left, prev_val, next_val;\n    if (!!$handle) {\n      val = parseFloat($handle.attr('aria-valuenow'));\n    }\n    else {\n      val = value;\n    }\n    if (val >= 0) {\n      left = val % step;\n    } else {\n      left = step + (val % step);\n    }\n    prev_val = val - left;\n    next_val = prev_val + step;\n    if (left === 0) {\n      return val;\n    }\n    val = val >= prev_val + div ? next_val : prev_val;\n    return val;\n  }\n\n  /**\n   * Adds event listeners to the slider elements.\n   * @function\n   * @private\n   */\n  _events() {\n    this._eventsForHandle(this.$handle);\n    if(this.handles[1]) {\n      this._eventsForHandle(this.$handle2);\n    }\n  }\n\n\n  /**\n   * Adds event listeners a particular handle\n   * @function\n   * @private\n   * @param {jQuery} $handle - the current handle to apply listeners to.\n   */\n  _eventsForHandle($handle) {\n    var _this = this,\n        curHandle,\n        timer;\n\n      const handleChangeEvent = function(e) {\n        const idx = _this.inputs.index($(this));\n        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());\n      };\n\n      // IE only triggers the change event when the input loses focus which strictly follows the HTML specification\n      // listen for the enter key and trigger a change\n      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events\n      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {\n        if(e.keyCode == 13) handleChangeEvent.call(this, e);\n      });\n\n      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);\n\n      if (this.options.clickSelect) {\n        this.$element.off('click.zf.slider').on('click.zf.slider', function(e) {\n          if (_this.$element.data('dragging')) { return false; }\n\n          if (!$(e.target).is('[data-slider-handle]')) {\n            if (_this.options.doubleSided) {\n              _this._handleEvent(e);\n            } else {\n              _this._handleEvent(e, _this.$handle);\n            }\n          }\n        });\n      }\n\n    if (this.options.draggable) {\n      this.handles.addTouch();\n\n      var $body = $('body');\n      $handle\n        .off('mousedown.zf.slider')\n        .on('mousedown.zf.slider', function(e) {\n          $handle.addClass('is-dragging');\n          _this.$fill.addClass('is-dragging');//\n          _this.$element.data('dragging', true);\n\n          curHandle = $(e.currentTarget);\n\n          $body.on('mousemove.zf.slider', function(e) {\n            e.preventDefault();\n            _this._handleEvent(e, curHandle);\n\n          }).on('mouseup.zf.slider', function(e) {\n            _this._handleEvent(e, curHandle);\n\n            $handle.removeClass('is-dragging');\n            _this.$fill.removeClass('is-dragging');\n            _this.$element.data('dragging', false);\n\n            $body.off('mousemove.zf.slider mouseup.zf.slider');\n          });\n      })\n      // prevent events triggered by touch\n      .on('selectstart.zf.slider touchmove.zf.slider', function(e) {\n        e.preventDefault();\n      });\n    }\n\n    $handle.off('keydown.zf.slider').on('keydown.zf.slider', function(e) {\n      var _$handle = $(this),\n          idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,\n          oldValue = parseFloat(_this.inputs.eq(idx).val()),\n          newValue;\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Slider', {\n        decrease: function() {\n          newValue = oldValue - _this.options.step;\n        },\n        increase: function() {\n          newValue = oldValue + _this.options.step;\n        },\n        decrease_fast: function() {\n          newValue = oldValue - _this.options.step * 10;\n        },\n        increase_fast: function() {\n          newValue = oldValue + _this.options.step * 10;\n        },\n        min: function() {\n          newValue = _this.options.start;\n        },\n        max: function() {\n          newValue = _this.options.end;\n        },\n        handled: function() { // only set handle pos when event was handled specially\n          e.preventDefault();\n          _this._setHandlePos(_$handle, newValue, true);\n        }\n      });\n      /*if (newValue) { // if pressed key has special function, update value\n        e.preventDefault();\n        _this._setHandlePos(_$handle, newValue);\n      }*/\n    });\n  }\n\n  /**\n   * Destroys the slider plugin.\n   */\n  _destroy() {\n    this.handles.off('.zf.slider');\n    this.inputs.off('.zf.slider');\n    this.$element.off('.zf.slider');\n\n    clearTimeout(this.timeout);\n  }\n}\n\nSlider.defaults = {\n  /**\n   * Minimum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  start: 0,\n  /**\n   * Maximum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  end: 100,\n  /**\n   * Minimum value change per change event.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  step: 1,\n  /**\n   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  initialStart: 0,\n  /**\n   * Value at which the right handle/second input should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  initialEnd: 100,\n  /**\n   * Allows the input to be located outside the container and visible. Set to by the JS\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  binding: false,\n  /**\n   * Allows the user to click/tap on the slider bar to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickSelect: true,\n  /**\n   * Set to true and use the `vertical` class to change alignment to vertical.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  vertical: false,\n  /**\n   * Allows the user to drag the slider handle(s) to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  draggable: true,\n  /**\n   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disabled: false,\n  /**\n   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  doubleSided: false,\n  /**\n   * Potential future feature.\n   */\n  // steps: 100,\n  /**\n   * Number of decimal places the plugin should go to for floating point precision.\n   * @option\n   * @type {number}\n   * @default 2\n   */\n  decimal: 2,\n  /**\n   * Time delay for dragged elements.\n   */\n  // dragDelay: 0,\n  /**\n   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  moveTime: 200,//update this if changing the transition time in the sass\n  /**\n   * Class applied to disabled sliders.\n   * @option\n   * @type {string}\n   * @default 'disabled'\n   */\n  disabledClass: 'disabled',\n  /**\n   * Will invert the default layout for a vertical<span data-tooltip title=\"who would do this???\"> </span>slider.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  invertVertical: false,\n  /**\n   * Milliseconds before the `changed.zf-slider` event is triggered after value change.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  changedDelay: 500,\n  /**\n  * Basevalue for non-linear sliders\n  * @option\n  * @type {number}\n  * @default 5\n  */\n  nonLinearBase: 5,\n  /**\n  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.\n  * @option\n  * @type {string}\n  * @default 'linear'\n  */\n  positionValueFunction: 'linear',\n};\n\nfunction percent(frac, num) {\n  return (frac / num);\n}\nfunction absPosition($handle, dir, clickPos, param) {\n  return Math.abs(($handle.position()[dir] + ($handle[param]() / 2)) - clickPos);\n}\nfunction baseLog(base, value) {\n  return Math.log(value)/Math.log(base)\n}\n\nexport {Slider};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass Sticky extends Plugin {\n  /**\n   * Creates a new instance of a sticky thing.\n   * @class\n   * @name Sticky\n   * @param {jQuery} element - jQuery object to make sticky.\n   * @param {Object} options - options object passed when creating the element programmatically.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);\n    this.className = 'Sticky'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var $parent = this.$element.parent('[data-sticky-container]'),\n        id = this.$element[0].id || GetYoDigits(6, 'sticky'),\n        _this = this;\n\n    if($parent.length){\n      this.$container = $parent;\n    } else {\n      this.wasWrapped = true;\n      this.$element.wrap(this.options.container);\n      this.$container = this.$element.parent();\n    }\n    this.$container.addClass(this.options.containerClass);\n\n    this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });\n    if (this.options.anchor !== '') {\n        $('#' + _this.options.anchor).attr({ 'data-mutate': id });\n    }\n\n    this.scrollCount = this.options.checkEvery;\n    this.isStuck = false;\n    this.onLoadListener = onLoad($(window), function () {\n      //We calculate the container height to have correct values for anchor points offset calculation.\n      _this.containerHeight = _this.$element.css(\"display\") == \"none\" ? 0 : _this.$element[0].getBoundingClientRect().height;\n      _this.$container.css('height', _this.containerHeight);\n      _this.elemHeight = _this.containerHeight;\n      if (_this.options.anchor !== '') {\n        _this.$anchor = $('#' + _this.options.anchor);\n      } else {\n        _this._parsePoints();\n      }\n\n      _this._setSizes(function () {\n        var scroll = window.pageYOffset;\n        _this._calc(false, scroll);\n        //Unstick the element will ensure that proper classes are set.\n        if (!_this.isStuck) {\n          _this._removeSticky((scroll >= _this.topPoint) ? false : true);\n        }\n      });\n      _this._events(id.split('-').reverse().join('-'));\n    });\n  }\n\n  /**\n   * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.\n   * @function\n   * @private\n   */\n  _parsePoints() {\n    var top = this.options.topAnchor == \"\" ? 1 : this.options.topAnchor,\n        btm = this.options.btmAnchor== \"\" ? document.documentElement.scrollHeight : this.options.btmAnchor,\n        pts = [top, btm],\n        breaks = {};\n    for (var i = 0, len = pts.length; i < len && pts[i]; i++) {\n      var pt;\n      if (typeof pts[i] === 'number') {\n        pt = pts[i];\n      } else {\n        var place = pts[i].split(':'),\n            anchor = $(`#${place[0]}`);\n\n        pt = anchor.offset().top;\n        if (place[1] && place[1].toLowerCase() === 'bottom') {\n          pt += anchor[0].getBoundingClientRect().height;\n        }\n      }\n      breaks[i] = pt;\n    }\n\n\n    this.points = breaks;\n    return;\n  }\n\n  /**\n   * Adds event handlers for the scrolling element.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _events(id) {\n    var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n    if (this.isOn) { return; }\n    if (this.canStick) {\n      this.isOn = true;\n      $(window).off(scrollListener)\n               .on(scrollListener, function(e) {\n                 if (_this.scrollCount === 0) {\n                   _this.scrollCount = _this.options.checkEvery;\n                   _this._setSizes(function() {\n                     _this._calc(false, window.pageYOffset);\n                   });\n                 } else {\n                   _this.scrollCount--;\n                   _this._calc(false, window.pageYOffset);\n                 }\n              });\n    }\n\n    this.$element.off('resizeme.zf.trigger')\n                 .on('resizeme.zf.trigger', function(e, el) {\n                    _this._eventsHandler(id);\n    });\n\n    this.$element.on('mutateme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n    });\n\n    if(this.$anchor) {\n      this.$anchor.on('mutateme.zf.trigger', function (e, el) {\n          _this._eventsHandler(id);\n      });\n    }\n  }\n\n  /**\n   * Handler for events.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _eventsHandler(id) {\n       var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n\n       _this._setSizes(function() {\n       _this._calc(false);\n       if (_this.canStick) {\n         if (!_this.isOn) {\n           _this._events(id);\n         }\n       } else if (_this.isOn) {\n         _this._pauseListeners(scrollListener);\n       }\n     });\n  }\n\n  /**\n   * Removes event handlers for scroll and change events on anchor.\n   * @fires Sticky#pause\n   * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`\n   */\n  _pauseListeners(scrollListener) {\n    this.isOn = false;\n    $(window).off(scrollListener);\n\n    /**\n     * Fires when the plugin is paused due to resize event shrinking the view.\n     * @event Sticky#pause\n     * @private\n     */\n     this.$element.trigger('pause.zf.sticky');\n  }\n\n  /**\n   * Called on every `scroll` event and on `_init`\n   * fires functions based on booleans and cached values\n   * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.\n   * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.\n   */\n  _calc(checkSizes, scroll) {\n    if (checkSizes) { this._setSizes(); }\n\n    if (!this.canStick) {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n      return false;\n    }\n\n    if (!scroll) { scroll = window.pageYOffset; }\n\n    if (scroll >= this.topPoint) {\n      if (scroll <= this.bottomPoint) {\n        if (!this.isStuck) {\n          this._setSticky();\n        }\n      } else {\n        if (this.isStuck) {\n          this._removeSticky(false);\n        }\n      }\n    } else {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n    }\n  }\n\n  /**\n   * Causes the $element to become stuck.\n   * Adds `position: fixed;`, and helper classes.\n   * @fires Sticky#stuckto\n   * @function\n   * @private\n   */\n  _setSticky() {\n    var _this = this,\n        stickTo = this.options.stickTo,\n        mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickTo === 'top' ? 'bottom' : 'top',\n        css = {};\n\n    css[mrgn] = `${this.options[mrgn]}em`;\n    css[stickTo] = 0;\n    css[notStuckTo] = 'auto';\n    this.isStuck = true;\n    this.$element.removeClass(`is-anchored is-at-${notStuckTo}`)\n                 .addClass(`is-stuck is-at-${stickTo}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become `position: fixed;`\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`\n                  * @event Sticky#stuckto\n                  */\n                 .trigger(`sticky.zf.stuckto:${stickTo}`);\n    this.$element.on(\"transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd\", function() {\n      _this._setSizes();\n    });\n  }\n\n  /**\n   * Causes the $element to become unstuck.\n   * Removes `position: fixed;`, and helper classes.\n   * Adds other helper classes.\n   * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.\n   * @fires Sticky#unstuckfrom\n   * @private\n   */\n  _removeSticky(isTop) {\n    var stickTo = this.options.stickTo,\n        stickToTop = stickTo === 'top',\n        css = {},\n        anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,\n        mrgn = stickToTop ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickToTop ? 'bottom' : 'top',\n        topOrBottom = isTop ? 'top' : 'bottom';\n\n    css[mrgn] = 0;\n\n    css['bottom'] = 'auto';\n    if(isTop) {\n      css['top'] = 0;\n    } else {\n      css['top'] = anchorPt;\n    }\n\n    this.isStuck = false;\n    this.$element.removeClass(`is-stuck is-at-${stickTo}`)\n                 .addClass(`is-anchored is-at-${topOrBottom}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become anchored.\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`\n                  * @event Sticky#unstuckfrom\n                  */\n                 .trigger(`sticky.zf.unstuckfrom:${topOrBottom}`);\n  }\n\n  /**\n   * Sets the $element and $container sizes for plugin.\n   * Calls `_setBreakPoints`.\n   * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.\n   * @private\n   */\n  _setSizes(cb) {\n    this.canStick = MediaQuery.is(this.options.stickyOn);\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n    }\n    var _this = this,\n        newElemWidth = this.$container[0].getBoundingClientRect().width,\n        comp = window.getComputedStyle(this.$container[0]),\n        pdngl = parseInt(comp['padding-left'], 10),\n        pdngr = parseInt(comp['padding-right'], 10);\n\n    if (this.$anchor && this.$anchor.length) {\n      this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;\n    } else {\n      this._parsePoints();\n    }\n\n    this.$element.css({\n      'max-width': `${newElemWidth - pdngl - pdngr}px`\n    });\n\n    var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;\n    if (this.$element.css(\"display\") == \"none\") {\n      newContainerHeight = 0;\n    }\n    this.containerHeight = newContainerHeight;\n    this.$container.css({\n      height: newContainerHeight\n    });\n    this.elemHeight = newContainerHeight;\n\n    if (!this.isStuck) {\n      if (this.$element.hasClass('is-at-bottom')) {\n        var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;\n        this.$element.css('top', anchorPt);\n      }\n    }\n\n    this._setBreakPoints(newContainerHeight, function() {\n      if (cb && typeof cb === 'function') { cb(); }\n    });\n  }\n\n  /**\n   * Sets the upper and lower breakpoints for the element to become sticky/unsticky.\n   * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.\n   * @param {Function} cb - optional callback function to be called on completion.\n   * @private\n   */\n  _setBreakPoints(elemHeight, cb) {\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n      else { return false; }\n    }\n    var mTop = emCalc(this.options.marginTop),\n        mBtm = emCalc(this.options.marginBottom),\n        topPoint = this.points ? this.points[0] : this.$anchor.offset().top,\n        bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,\n        // topPoint = this.$anchor.offset().top || this.points[0],\n        // bottomPoint = topPoint + this.anchorHeight || this.points[1],\n        winHeight = window.innerHeight;\n\n    if (this.options.stickTo === 'top') {\n      topPoint -= mTop;\n      bottomPoint -= (elemHeight + mTop);\n    } else if (this.options.stickTo === 'bottom') {\n      topPoint -= (winHeight - (elemHeight + mBtm));\n      bottomPoint -= (winHeight - mBtm);\n    } else {\n      //this would be the stickTo: both option... tricky\n    }\n\n    this.topPoint = topPoint;\n    this.bottomPoint = bottomPoint;\n\n    if (cb && typeof cb === 'function') { cb(); }\n  }\n\n  /**\n   * Destroys the current sticky element.\n   * Resets the element to the top position first.\n   * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.\n   * @function\n   */\n  _destroy() {\n    this._removeSticky(true);\n\n    this.$element.removeClass(`${this.options.stickyClass} is-anchored is-at-top`)\n                 .css({\n                   height: '',\n                   top: '',\n                   bottom: '',\n                   'max-width': ''\n                 })\n                 .off('resizeme.zf.trigger')\n                 .off('mutateme.zf.trigger');\n    if (this.$anchor && this.$anchor.length) {\n      this.$anchor.off('change.zf.sticky');\n    }\n    if (this.scrollListener) $(window).off(this.scrollListener)\n    if (this.onLoadListener) $(window).off(this.onLoadListener)\n\n    if (this.wasWrapped) {\n      this.$element.unwrap();\n    } else {\n      this.$container.removeClass(this.options.containerClass)\n                     .css({\n                       height: ''\n                     });\n    }\n  }\n}\n\nSticky.defaults = {\n  /**\n   * Customizable container template. Add your own classes for styling and sizing.\n   * @option\n   * @type {string}\n   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'\n   */\n  container: '<div data-sticky-container></div>',\n  /**\n   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default 'top'\n   */\n  stickTo: 'top',\n  /**\n   * If anchored to a single element, the id of that element.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  anchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the top anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  topAnchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the bottom anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  btmAnchor: '',\n  /**\n   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginTop: 1,\n  /**\n   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginBottom: 1,\n  /**\n   * Breakpoint string that is the minimum screen size an element should become sticky.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  stickyOn: 'medium',\n  /**\n   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.\n   * @option\n   * @type {string}\n   * @default 'sticky'\n   */\n  stickyClass: 'sticky',\n  /**\n   * Class applied to sticky container. Foundation defaults to `sticky-container`.\n   * @option\n   * @type {string}\n   * @default 'sticky-container'\n   */\n  containerClass: 'sticky-container',\n  /**\n   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.\n   * @option\n   * @type {number}\n   * @default -1\n   */\n  checkEvery: -1\n};\n\n/**\n * Helper function to calculate em values\n * @param Number {em} - number of em's to calculate into pixels\n */\nfunction emCalc(em) {\n  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;\n}\n\nexport {Sticky};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { Plugin } from './foundation.core.plugin';\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.imageLoader if tabs contain images\n */\n\nclass Tabs extends Plugin {\n  /**\n   * Creates a new instance of tabs.\n   * @class\n   * @name Tabs\n   * @fires Tabs#init\n   * @param {jQuery} element - jQuery object to make into tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);\n    this.className = 'Tabs'; // ie9 back compat\n\n    this._init();\n    Keyboard.register('Tabs', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'previous',\n      'ARROW_DOWN': 'next',\n      'ARROW_LEFT': 'previous'\n      // 'TAB': 'next',\n      // 'SHIFT_TAB': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.\n   * @private\n   */\n  _init() {\n    var _this = this;\n    this._isInitializing = true;\n\n    this.$element.attr({'role': 'tablist'});\n    this.$tabTitles = this.$element.find(`.${this.options.linkClass}`);\n    this.$tabContent = $(`[data-tabs-content=\"${this.$element[0].id}\"]`);\n\n    this.$tabTitles.each(function(){\n      var $elem = $(this),\n          $link = $elem.find('a'),\n          isActive = $elem.hasClass(`${_this.options.linkActiveClass}`),\n          hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),\n          linkId = $link[0].id ? $link[0].id : `${hash}-label`,\n          $tabContent = $(`#${hash}`);\n\n      $elem.attr({'role': 'presentation'});\n\n      $link.attr({\n        'role': 'tab',\n        'aria-controls': hash,\n        'aria-selected': isActive,\n        'id': linkId,\n        'tabindex': isActive ? '0' : '-1'\n      });\n\n      $tabContent.attr({\n        'role': 'tabpanel',\n        'aria-labelledby': linkId\n      });\n\n      // Save up the initial hash to return to it later when going back in history\n      if (isActive) {\n        _this._initialAnchor = `#${hash}`;\n      }\n\n      if(!isActive) {\n        $tabContent.attr('aria-hidden', 'true');\n      }\n\n      if(isActive && _this.options.autoFocus){\n        _this.onLoadListener = onLoad($(window), function() {\n          $('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, () => {\n            $link.focus();\n          });\n        });\n      }\n    });\n\n    if(this.options.matchHeight) {\n      var $images = this.$tabContent.find('img');\n\n      if ($images.length) {\n        onImagesLoaded($images, this._setHeight.bind(this));\n      } else {\n        this._setHeight();\n      }\n    }\n\n     // Current context-bound function to open tabs on page load or history hashchange\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find('[href$=\"'+anchor+'\"]');\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, select it\n      if ($anchor && $anchor.length && $link && $link.length) {\n        this.selectTab($anchor, true);\n      }\n      // Otherwise, collapse everything\n      else {\n        this._collapse();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          var offset = this.$element.offset();\n          $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Tabs#deeplink\n         */\n        this.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the tabs.\n   * @private\n   */\n  _events() {\n    this._addKeyHandler();\n    this._addClickHandler();\n    this._setHeightMqHandler = null;\n\n    if (this.options.matchHeight) {\n      this._setHeightMqHandler = this._setHeight.bind(this);\n\n      $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);\n    }\n\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Adds click handlers for items within the tabs.\n   * @private\n   */\n  _addClickHandler() {\n    var _this = this;\n\n    this.$element\n      .off('click.zf.tabs')\n      .on('click.zf.tabs', `.${this.options.linkClass}`, function(e){\n        e.preventDefault();\n        e.stopPropagation();\n        _this._handleTabChange($(this));\n      });\n  }\n\n  /**\n   * Adds keyboard event handlers for items within the tabs.\n   * @private\n   */\n  _addKeyHandler() {\n    var _this = this;\n\n    this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function(e){\n      if (e.which === 9) return;\n\n\n      var $element = $(this),\n        $elements = $element.parent('ul').children('li'),\n        $prevElement,\n        $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          if (_this.options.wrapOnKeys) {\n            $prevElement = i === 0 ? $elements.last() : $elements.eq(i-1);\n            $nextElement = i === $elements.length -1 ? $elements.first() : $elements.eq(i+1);\n          } else {\n            $prevElement = $elements.eq(Math.max(0, i-1));\n            $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          }\n          return;\n        }\n      });\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Tabs', {\n        open: function() {\n          $element.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($element);\n        },\n        previous: function() {\n          $prevElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($prevElement);\n        },\n        next: function() {\n          $nextElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($nextElement);\n        },\n        handled: function() {\n          e.stopPropagation();\n          e.preventDefault();\n        }\n      });\n    });\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.\n   * @param {jQuery} $target - Tab to open.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @fires Tabs#change\n   * @function\n   */\n  _handleTabChange($target, historyHandled) {\n\n    // With `activeCollapse`, if the target is the active Tab, collapse it.\n    if ($target.hasClass(`${this.options.linkActiveClass}`)) {\n        if(this.options.activeCollapse) {\n            this._collapse();\n        }\n        return;\n    }\n\n    var $oldTab = this.$element.\n          find(`.${this.options.linkClass}.${this.options.linkActiveClass}`),\n          $tabLink = $target.find('[role=\"tab\"]'),\n          target = $tabLink.attr('data-tabs-target'),\n          anchor = target && target.length ? `#${target}` : $tabLink[0].hash,\n          $targetContent = this.$tabContent.find(anchor);\n\n    //close old tab\n    this._collapseTab($oldTab);\n\n    //open new tab\n    this._openTab($target);\n\n    //either replace or update browser history\n    if (this.options.deepLink && !historyHandled) {\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n\n    /**\n     * Fires when the plugin has successfully changed tabs.\n     * @event Tabs#change\n     */\n    this.$element.trigger('change.zf.tabs', [$target, $targetContent]);\n\n    //fire to children a mutation event\n    $targetContent.find(\"[data-mutate]\").trigger(\"mutateme.zf.trigger\");\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to open.\n   * @function\n   */\n  _openTab($target) {\n      var $tabLink = $target.find('[role=\"tab\"]'),\n          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),\n          $targetContent = this.$tabContent.find(`#${hash}`);\n\n      $target.addClass(`${this.options.linkActiveClass}`);\n\n      $tabLink.attr({\n        'aria-selected': 'true',\n        'tabindex': '0'\n      });\n\n      $targetContent\n        .addClass(`${this.options.panelActiveClass}`).removeAttr('aria-hidden');\n  }\n\n  /**\n   * Collapses `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to collapse.\n   * @function\n   */\n  _collapseTab($target) {\n    var $target_anchor = $target\n      .removeClass(`${this.options.linkActiveClass}`)\n      .find('[role=\"tab\"]')\n      .attr({\n        'aria-selected': 'false',\n        'tabindex': -1\n      });\n\n    $(`#${$target_anchor.attr('aria-controls')}`)\n      .removeClass(`${this.options.panelActiveClass}`)\n      .attr({ 'aria-hidden': 'true' })\n  }\n\n  /**\n   * Collapses the active Tab.\n   * @fires Tabs#collapse\n   * @function\n   */\n  _collapse() {\n    var $activeTab = this.$element.find(`.${this.options.linkClass}.${this.options.linkActiveClass}`);\n\n    if ($activeTab.length) {\n      this._collapseTab($activeTab);\n\n      /**\n      * Fires when the plugin has successfully collapsed tabs.\n      * @event Tabs#collapse\n      */\n      this.$element.trigger('collapse.zf.tabs', [$activeTab]);\n    }\n  }\n\n  /**\n   * Public method for selecting a content pane to display.\n   * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @function\n   */\n  selectTab(elem, historyHandled) {\n    var idStr;\n\n    if (typeof elem === 'object') {\n      idStr = elem[0].id;\n    } else {\n      idStr = elem;\n    }\n\n    if (idStr.indexOf('#') < 0) {\n      idStr = `#${idStr}`;\n    }\n\n    var $target = this.$tabTitles.has(`[href$=\"${idStr}\"]`);\n\n    this._handleTabChange($target, historyHandled);\n  };\n\n  /**\n   * Sets the height of each panel to the height of the tallest panel.\n   * If enabled in options, gets called on media query change.\n   * If loading content via external source, can be called directly or with _reflow.\n   * If enabled with `data-match-height=\"true\"`, tabs sets to equal height\n   * @function\n   * @private\n   */\n  _setHeight() {\n    var max = 0,\n        _this = this; // Lock down the `this` value for the root tabs object\n\n    this.$tabContent\n      .find(`.${this.options.panelClass}`)\n      .css('height', '')\n      .each(function() {\n\n        var panel = $(this),\n            isActive = panel.hasClass(`${_this.options.panelActiveClass}`); // get the options from the parent instead of trying to get them from the child\n\n        if (!isActive) {\n          panel.css({'visibility': 'hidden', 'display': 'block'});\n        }\n\n        var temp = this.getBoundingClientRect().height;\n\n        if (!isActive) {\n          panel.css({\n            'visibility': '',\n            'display': ''\n          });\n        }\n\n        max = temp > max ? temp : max;\n      })\n      .css('height', `${max}px`);\n  }\n\n  /**\n   * Destroys an instance of tabs.\n   * @fires Tabs#destroyed\n   */\n  _destroy() {\n    this.$element\n      .find(`.${this.options.linkClass}`)\n      .off('.zf.tabs').hide().end()\n      .find(`.${this.options.panelClass}`)\n      .hide();\n\n    if (this.options.matchHeight) {\n      if (this._setHeightMqHandler != null) {\n         $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);\n      }\n    }\n\n    if (this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n    if (this.onLoadListener) {\n      $(window).off(this.onLoadListener);\n    }\n  }\n}\n\nTabs.defaults = {\n  /**\n   * Link the location hash to the active pane.\n   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open tab\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n   * Allows the window to scroll to content of active pane on load.\n   * Not recommended if more than one tab panel per page.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows keyboard input to 'wrap' around the tab links.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  wrapOnKeys: true,\n\n  /**\n   * Allows the tab content panes to match heights if set to true.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  matchHeight: false,\n\n  /**\n   * Allows active tabs to collapse when clicked.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  activeCollapse: false,\n\n  /**\n   * Class applied to `li`'s in tab link list.\n   * @option\n   * @type {string}\n   * @default 'tabs-title'\n   */\n  linkClass: 'tabs-title',\n\n  /**\n   * Class applied to the active `li` in tab link list.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  linkActiveClass: 'is-active',\n\n  /**\n   * Class applied to the content containers.\n   * @option\n   * @type {string}\n   * @default 'tabs-panel'\n   */\n  panelClass: 'tabs-panel',\n\n  /**\n   * Class applied to the active content container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  panelActiveClass: 'is-active'\n};\n\nexport {Tabs};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { RegExpEscape } from './foundation.core.utils';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nclass Toggler extends Plugin {\n  /**\n   * Creates a new instance of Toggler.\n   * @class\n   * @name Toggler\n   * @fires Toggler#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Toggler.defaults, element.data(), options);\n    this.className = '';\n    this.className = 'Toggler'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.\n   * @function\n   * @private\n   */\n  _init() {\n    var input;\n    // Parse animation classes if they were set\n    if (this.options.animate) {\n      input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n    // Otherwise, parse toggle class\n    else {\n      input = this.$element.data('toggler');\n      // Allow for a . at the beginning of the string\n      this.className = input[0] === '.' ? input.slice(1) : input;\n    }\n\n    // Add ARIA attributes to triggers:\n    var id = this.$element[0].id,\n      $triggers = $(`[data-open~=\"${id}\"], [data-close~=\"${id}\"], [data-toggle~=\"${id}\"]`);\n\n    // - aria-expanded: according to the element visibility.\n    $triggers.attr('aria-expanded', !this.$element.is(':hidden'));\n    // - aria-controls: adding the element id to it if not already in it.\n    $triggers.each((index, trigger) => {\n      const $trigger = $(trigger);\n      const controls = $trigger.attr('aria-controls') || '';\n\n      const containsId = new RegExp(`\\\\b${RegExpEscape(id)}\\\\b`).test(controls);\n      if (!containsId) $trigger.attr('aria-controls', controls ? `${controls} ${id}` : id);\n    });\n  }\n\n  /**\n   * Initializes events for the toggle trigger.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));\n  }\n\n  /**\n   * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was \"on\" or \"off\".\n   * @function\n   * @fires Toggler#on\n   * @fires Toggler#off\n   */\n  toggle() {\n    this[ this.options.animate ? '_toggleAnimate' : '_toggleClass']();\n  }\n\n  _toggleClass() {\n    this.$element.toggleClass(this.className);\n\n    var isOn = this.$element.hasClass(this.className);\n    if (isOn) {\n      /**\n       * Fires if the target element has the class after a toggle.\n       * @event Toggler#on\n       */\n      this.$element.trigger('on.zf.toggler');\n    }\n    else {\n      /**\n       * Fires if the target element does not have the class after a toggle.\n       * @event Toggler#off\n       */\n      this.$element.trigger('off.zf.toggler');\n    }\n\n    this._updateARIA(isOn);\n    this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');\n  }\n\n  _toggleAnimate() {\n    var _this = this;\n\n    if (this.$element.is(':hidden')) {\n      Motion.animateIn(this.$element, this.animationIn, function() {\n        _this._updateARIA(true);\n        this.trigger('on.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n    else {\n      Motion.animateOut(this.$element, this.animationOut, function() {\n        _this._updateARIA(false);\n        this.trigger('off.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n  }\n\n  _updateARIA(isOn) {\n    var id = this.$element[0].id;\n    $(`[data-open=\"${id}\"], [data-close=\"${id}\"], [data-toggle=\"${id}\"]`)\n      .attr({\n        'aria-expanded': isOn ? true : false\n      });\n  }\n\n  /**\n   * Destroys the instance of Toggler on the element.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.toggler');\n  }\n}\n\nToggler.defaults = {\n  /**\n   * Tells the plugin if the element should animated when toggled.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport {Toggler};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Triggers } from './foundation.util.triggers';\nimport { Positionable } from './foundation.positionable';\n\n/**\n * Tooltip module.\n * @module foundation.tooltip\n * @requires foundation.util.box\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass Tooltip extends Positionable {\n  /**\n   * Creates a new instance of a Tooltip.\n   * @class\n   * @name Tooltip\n   * @fires Tooltip#init\n   * @param {jQuery} element - jQuery object to attach a tooltip to.\n   * @param {Object} options - object to extend the default configuration.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);\n    this.className = 'Tooltip'; // ie9 back compat\n\n    this.isActive = false;\n    this.isClick = false;\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');\n\n    this.options.tipText = this.options.tipText || this.$element.attr('title');\n    this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);\n\n    if (this.options.allowHtml) {\n      this.template.appendTo(document.body)\n        .html(this.options.tipText)\n        .hide();\n    } else {\n      this.template.appendTo(document.body)\n        .text(this.options.tipText)\n        .hide();\n    }\n\n    this.$element.attr({\n      'title': '',\n      'aria-describedby': elemId,\n      'data-yeti-box': elemId,\n      'data-toggle': elemId,\n      'data-resize': elemId\n    }).addClass(this.options.triggerClass);\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/\\b(top|left|right|bottom)\\b/g);\n    return position ? position[0] : 'top';\n  }\n\n  _getDefaultAlignment() {\n    return 'center';\n  }\n\n  _getHOffset() {\n    if(this.position === 'left' || this.position === 'right') {\n      return this.options.hOffset + this.options.tooltipWidth;\n    } else {\n      return this.options.hOffset\n    }\n  }\n\n  _getVOffset() {\n    if(this.position === 'top' || this.position === 'bottom') {\n      return this.options.vOffset + this.options.tooltipHeight;\n    } else {\n      return this.options.vOffset\n    }\n  }\n\n  /**\n   * builds the tooltip element, adds attributes, and returns the template.\n   * @private\n   */\n  _buildTemplate(id) {\n    var templateClasses = (`${this.options.tooltipClass} ${this.options.templateClasses}`).trim();\n    var $template =  $('<div></div>').addClass(templateClasses).attr({\n      'role': 'tooltip',\n      'aria-hidden': true,\n      'data-is-active': false,\n      'data-is-focus': false,\n      'id': id\n    });\n    return $template;\n  }\n\n  /**\n   * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.\n   * if the tooltip is larger than the screen width, default to full width - any user selected margin\n   * @private\n   */\n  _setPosition() {\n    super._setPosition(this.$element, this.template);\n  }\n\n  /**\n   * reveals the tooltip, and fires an event to close any other open tooltips on the page\n   * @fires Tooltip#closeme\n   * @fires Tooltip#show\n   * @function\n   */\n  show() {\n    if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {\n      // console.error('The screen is too small to display this tooltip');\n      return false;\n    }\n\n    var _this = this;\n    this.template.css('visibility', 'hidden').show();\n    this._setPosition();\n    this.template.removeClass('top bottom left right').addClass(this.position)\n    this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);\n\n    /**\n     * Fires to close all other open tooltips on the page\n     * @event Closeme#tooltip\n     */\n    this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));\n\n\n    this.template.attr({\n      'data-is-active': true,\n      'aria-hidden': false\n    });\n    _this.isActive = true;\n    // console.log(this.template);\n    this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function() {\n      //maybe do stuff?\n    });\n    /**\n     * Fires when the tooltip is shown\n     * @event Tooltip#show\n     */\n    this.$element.trigger('show.zf.tooltip');\n  }\n\n  /**\n   * Hides the current tooltip, and resets the positioning class if it was changed due to collision\n   * @fires Tooltip#hide\n   * @function\n   */\n  hide() {\n    // console.log('hiding', this.$element.data('yeti-box'));\n    var _this = this;\n    this.template.stop().attr({\n      'aria-hidden': true,\n      'data-is-active': false\n    }).fadeOut(this.options.fadeOutDuration, function() {\n      _this.isActive = false;\n      _this.isClick = false;\n    });\n    /**\n     * fires when the tooltip is hidden\n     * @event Tooltip#hide\n     */\n    this.$element.trigger('hide.zf.tooltip');\n  }\n\n  /**\n   * adds event listeners for the tooltip and its anchor\n   * TODO combine some of the listeners like focus and mouseenter, etc.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    var $template = this.template;\n    var isFocus = false;\n\n    if (!this.options.disableHover) {\n\n      this.$element\n      .on('mouseenter.zf.tooltip', function(e) {\n        if (!_this.isActive) {\n          _this.timeout = setTimeout(function() {\n            _this.show();\n          }, _this.options.hoverDelay);\n        }\n      })\n      .on('mouseleave.zf.tooltip', ignoreMousedisappear(function(e) {\n        clearTimeout(_this.timeout);\n        if (!isFocus || (_this.isClick && !_this.options.clickOpen)) {\n          _this.hide();\n        }\n      }));\n    }\n\n    if (this.options.clickOpen) {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        if (_this.isClick) {\n          //_this.hide();\n          // _this.isClick = false;\n        } else {\n          _this.isClick = true;\n          if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {\n            _this.show();\n          }\n        }\n      });\n    } else {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        _this.isClick = true;\n      });\n    }\n\n    if (!this.options.disableForTouch) {\n      this.$element\n      .on('tap.zf.tooltip touchend.zf.tooltip', function(e) {\n        _this.isActive ? _this.hide() : _this.show();\n      });\n    }\n\n    this.$element.on({\n      // 'toggle.zf.trigger': this.toggle.bind(this),\n      // 'close.zf.trigger': this.hide.bind(this)\n      'close.zf.trigger': this.hide.bind(this)\n    });\n\n    this.$element\n      .on('focus.zf.tooltip', function(e) {\n        isFocus = true;\n        if (_this.isClick) {\n          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't\n          // a real focus, otherwise on hover and come back we get bad behavior\n          if(!_this.options.clickOpen) { isFocus = false; }\n          return false;\n        } else {\n          _this.show();\n        }\n      })\n\n      .on('focusout.zf.tooltip', function(e) {\n        isFocus = false;\n        _this.isClick = false;\n        _this.hide();\n      })\n\n      .on('resizeme.zf.trigger', function() {\n        if (_this.isActive) {\n          _this._setPosition();\n        }\n      });\n  }\n\n  /**\n   * adds a toggle method, in addition to the static show() & hide() functions\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  /**\n   * Destroys an instance of tooltip, removes template element from the view.\n   * @function\n   */\n  _destroy() {\n    this.$element.attr('title', this.template.text())\n                 .off('.zf.trigger .zf.tooltip')\n                 .removeClass(this.options.triggerClass)\n                 .removeClass('top right left bottom')\n                 .removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n\n    this.template.remove();\n  }\n}\n\nTooltip.defaults = {\n  disableForTouch: false,\n  /**\n   * Time, in ms, before a tooltip should open on hover.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  hoverDelay: 200,\n  /**\n   * Time, in ms, a tooltip should take to fade into view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeInDuration: 150,\n  /**\n   * Time, in ms, a tooltip should take to fade out of view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeOutDuration: 150,\n  /**\n   * Disables hover events from opening the tooltip if set to true\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Optional addtional classes to apply to the tooltip template on init.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  templateClasses: '',\n  /**\n   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.\n   * @option\n   * @type {string}\n   * @default 'tooltip'\n   */\n  tooltipClass: 'tooltip',\n  /**\n   * Class applied to the tooltip anchor element.\n   * @option\n   * @type {string}\n   * @default 'has-tip'\n   */\n  triggerClass: 'has-tip',\n  /**\n   * Minimum breakpoint size at which to open the tooltip.\n   * @option\n   * @type {string}\n   * @default 'small'\n   */\n  showOn: 'small',\n  /**\n   * Custom template to be used to generate markup for tooltip.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  template: '',\n  /**\n   * Text displayed in the tooltip template on open.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  tipText: '',\n  touchCloseText: 'Tap to close.',\n  /**\n   * Allows the tooltip to remain open if triggered with a click or touch event.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickOpen: true,\n  /**\n   * Position of tooltip. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, tooltip will first try to\n   * position as defined by data-position and data-alignment, but reposition if\n   * it would cause an overflow.  @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * Less common for tooltips.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowBottomOverlap: false,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the Y axis.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the X axis\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip\n   * @option\n   * @type {number}\n   * @default 14\n   */\n  tooltipHeight: 14,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip\n   * @option\n   * @type {number}\n   * @default 12\n   */\n  tooltipWidth: 12,\n    /**\n   * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,\n   * allowing HTML may open yourself up to XSS attacks.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowHtml: false\n};\n\n/**\n * TODO utilize resize event trigger\n */\n\nexport {Tooltip};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin }from './foundation.core.plugin';\n\nimport { Accordion } from './foundation.accordion';\nimport { Tabs } from './foundation.tabs';\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n  tabs: {\n    cssClass: 'tabs',\n    plugin: Tabs\n  },\n  accordion: {\n    cssClass: 'accordion',\n    plugin: Accordion\n  }\n};\n\n\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nclass ResponsiveAccordionTabs extends Plugin{\n  /**\n   * Creates a new instance of a responsive accordion tabs.\n   * @class\n   * @name ResponsiveAccordionTabs\n   * @fires ResponsiveAccordionTabs#init\n   * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options  = $.extend({}, this.$element.data(), options);\n    this.rules = this.$element.data('responsive-accordion-tabs');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveAccordionTabs'; // ie9 back compat\n    if (!this.$element.attr('id')) {\n      this.$element.attr('id',GetYoDigits(6, 'responsiveaccordiontabs'));\n    };\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    this._getAllOptions();\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n  }\n\n  _getAllOptions() {\n    //get all defaults and options\n    var _this = this;\n    _this.allOptions = {};\n    for (var key in MenuPlugins) {\n      if (MenuPlugins.hasOwnProperty(key)) {\n        var obj = MenuPlugins[key];\n        try {\n          var dummyPlugin = $('<ul></ul>');\n          var tmpPlugin = new obj.plugin(dummyPlugin,_this.options);\n          for (var keyKey in tmpPlugin.options) {\n            if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {\n              var objObj = tmpPlugin.options[keyKey];\n              _this.allOptions[keyKey] = objObj;\n            }\n          }\n          tmpPlugin.destroy();\n        }\n        catch(e) {\n        }\n      }\n    }\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);\n    $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) {\n      //don't know why but on nested elements data zfPlugin get's lost\n      if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin',this.storezfData);\n      this.currentPlugin.destroy();\n    }\n    this._handleMarkup(this.rules[matchedMq].cssClass);\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n    this.storezfData = this.currentPlugin.$element.data('zfPlugin');\n\n  }\n\n  _handleMarkup(toSet){\n    var _this = this, fromString = 'accordion';\n    var $panels = $('[data-tabs-content='+this.$element.attr('id')+']');\n    if ($panels.length) fromString = 'tabs';\n    if (fromString === toSet) {\n      return;\n    };\n\n    var tabsTitle = _this.allOptions.linkClass?_this.allOptions.linkClass:'tabs-title';\n    var tabsPanel = _this.allOptions.panelClass?_this.allOptions.panelClass:'tabs-panel';\n\n    this.$element.removeAttr('role');\n    var $liHeads = this.$element.children('.'+tabsTitle+',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');\n    var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');\n\n    if (fromString === 'tabs') {\n      $panels = $panels.children('.'+tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');\n      $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');\n    }else{\n      $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');\n    };\n\n    $panels.css({display:'',visibility:''});\n    $liHeads.css({display:'',visibility:''});\n    if (toSet === 'accordion') {\n      $panels.each(function(key,value){\n        $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content','').removeClass('is-active').css({height:''});\n        $('[data-tabs-content='+_this.$element.attr('id')+']').after('<div id=\"tabs-placeholder-'+_this.$element.attr('id')+'\"></div>').detach();\n        $liHeads.addClass('accordion-item').attr('data-accordion-item','');\n        $liHeadsA.addClass('accordion-title');\n      });\n    }else if (toSet === 'tabs'){\n      var $tabsContent = $('[data-tabs-content='+_this.$element.attr('id')+']');\n      var $placeholder = $('#tabs-placeholder-'+_this.$element.attr('id'));\n      if ($placeholder.length) {\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter($placeholder).attr('data-tabs-content',_this.$element.attr('id'));\n        $placeholder.remove();\n      }else{\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter(_this.$element).attr('data-tabs-content',_this.$element.attr('id'));\n      };\n      $panels.each(function(key,value){\n        var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);\n        var hash = $liHeadsA.get(key).hash.slice(1);\n        var id = $(value).attr('id') || GetYoDigits(6, 'accordion');\n        if (hash !== id) {\n          if (hash !== '') {\n            $(value).attr('id',hash);\n          }else{\n            hash = id;\n            $(value).attr('id',hash);\n            $($liHeadsA.get(key)).attr('href',$($liHeadsA.get(key)).attr('href').replace('#','')+'#'+hash);\n          };\n        };\n        var isActive = $($liHeads.get(key)).hasClass('is-active');\n        if (isActive) {\n          tempValue.addClass('is-active');\n        };\n      });\n      $liHeads.addClass(tabsTitle);\n    };\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n}\n\nResponsiveAccordionTabs.defaults = {};\n\nexport {ResponsiveAccordionTabs};\n","import $ from 'jquery';\n\nimport { Foundation } from '../foundation.core';\nimport * as CoreUtils from '../foundation.core.utils';\nimport { Box } from '../foundation.util.box'\nimport { onImagesLoaded } from '../foundation.util.imageLoader';\nimport { Keyboard } from '../foundation.util.keyboard';\nimport { MediaQuery } from '../foundation.util.mediaQuery';\nimport { Motion, Move } from '../foundation.util.motion';\nimport { Nest } from '../foundation.util.nest';\nimport { Timer } from '../foundation.util.timer';\nimport { Touch } from '../foundation.util.touch';\nimport { Triggers } from '../foundation.util.triggers';\nimport { Abide } from '../foundation.abide';\nimport { Accordion } from '../foundation.accordion';\nimport { AccordionMenu } from '../foundation.accordionMenu';\nimport { Drilldown } from '../foundation.drilldown';\nimport { Dropdown } from '../foundation.dropdown';\nimport { DropdownMenu } from '../foundation.dropdownMenu';\nimport { Equalizer } from '../foundation.equalizer';\nimport { Interchange } from '../foundation.interchange';\nimport { Magellan } from '../foundation.magellan';\nimport { OffCanvas } from '../foundation.offcanvas';\nimport { Orbit } from '../foundation.orbit';\nimport { ResponsiveMenu } from '../foundation.responsiveMenu';\nimport { ResponsiveToggle } from '../foundation.responsiveToggle';\nimport { Reveal } from '../foundation.reveal';\nimport { Slider } from '../foundation.slider';\nimport { SmoothScroll } from '../foundation.smoothScroll';\nimport { Sticky } from '../foundation.sticky';\nimport { Tabs } from '../foundation.tabs';\nimport { Toggler } from '../foundation.toggler';\nimport { Tooltip } from '../foundation.tooltip';\nimport { ResponsiveAccordionTabs } from '../foundation.responsiveAccordionTabs';\n\nFoundation.addToJquery($);\n\n// Add Foundation Utils to Foundation global namespace for backwards\n// compatibility.\nFoundation.rtl = CoreUtils.rtl;\nFoundation.GetYoDigits = CoreUtils.GetYoDigits;\nFoundation.transitionend = CoreUtils.transitionend;\nFoundation.RegExpEscape = CoreUtils.RegExpEscape;\nFoundation.onLoad = CoreUtils.onLoad;\n\nFoundation.Box = Box;\nFoundation.onImagesLoaded = onImagesLoaded;\nFoundation.Keyboard = Keyboard;\nFoundation.MediaQuery = MediaQuery;\nFoundation.Motion = Motion;\nFoundation.Move = Move;\nFoundation.Nest = Nest;\nFoundation.Timer = Timer;\n\n// Touch and Triggers previously were almost purely sede effect driven,\n// so no need to add it to Foundation, just init them.\nTouch.init($);\nTriggers.init($, Foundation);\nMediaQuery._init();\n\nFoundation.plugin(Abide, 'Abide');\nFoundation.plugin(Accordion, 'Accordion');\nFoundation.plugin(AccordionMenu, 'AccordionMenu');\nFoundation.plugin(Drilldown, 'Drilldown');\nFoundation.plugin(Dropdown, 'Dropdown');\nFoundation.plugin(DropdownMenu, 'DropdownMenu');\nFoundation.plugin(Equalizer, 'Equalizer');\nFoundation.plugin(Interchange, 'Interchange');\nFoundation.plugin(Magellan, 'Magellan');\nFoundation.plugin(OffCanvas, 'OffCanvas');\nFoundation.plugin(Orbit, 'Orbit');\nFoundation.plugin(ResponsiveMenu, 'ResponsiveMenu');\nFoundation.plugin(ResponsiveToggle, 'ResponsiveToggle');\nFoundation.plugin(Reveal, 'Reveal');\nFoundation.plugin(Slider, 'Slider');\nFoundation.plugin(SmoothScroll, 'SmoothScroll');\nFoundation.plugin(Sticky, 'Sticky');\nFoundation.plugin(Tabs, 'Tabs');\nFoundation.plugin(Toggler, 'Toggler');\nFoundation.plugin(Tooltip, 'Tooltip');\nFoundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');\n\nexport {\n  Foundation,\n  CoreUtils,\n  Box,\n  onImagesLoaded,\n  Keyboard,\n  MediaQuery,\n  Motion,\n  Nest,\n  Timer,\n  Touch,\n  Triggers,\n  Abide,\n  Accordion,\n  AccordionMenu,\n  Drilldown,\n  Dropdown,\n  DropdownMenu,\n  Equalizer,\n  Interchange,\n  Magellan,\n  OffCanvas,\n  Orbit,\n  ResponsiveMenu,\n  ResponsiveToggle,\n  Reveal,\n  Slider,\n  SmoothScroll,\n  Sticky,\n  Tabs,\n  Toggler,\n  Tooltip,\n  ResponsiveAccordionTabs\n}\n\nexport default Foundation;\n\n"],"names":["rtl","$","attr","GetYoDigits","length","namespace","Math","round","pow","random","toString","slice","RegExpEscape","str","replace","transitionend","$elem","transitions","elem","document","createElement","end","t","style","setTimeout","triggerHandler","onLoad","handler","didLoad","readyState","eventType","cb","one","window","ignoreMousedisappear","ignoreLeaveWindow","ignoreReappear","leaveEventHandler","eLeave","rest","callback","bind","relatedTarget","leaveEventDebouncer","hasFocus","reenterEventHandler","eReenter","currentTarget","has","target","matchMedia","styleMedia","media","script","getElementsByTagName","info","type","id","head","appendChild","parentNode","insertBefore","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","matches","MediaQuery","queries","current","_init","self","$meta","appendTo","extractedStyles","css","namedQueries","parseStyleToObject","key","hasOwnProperty","push","name","value","_getCurrentSize","_watcher","atLeast","size","query","get","is","trim","split","i","matched","off","on","newSize","currentSize","trigger","styleObject","reduce","ret","param","parts","val","decodeURIComponent","Array","isArray","FOUNDATION_VERSION","Foundation","version","_plugins","_uuids","plugin","className","functionName","attrName","hyphenate","registerPlugin","pluginName","constructor","toLowerCase","uuid","$element","data","unregisterPlugin","splice","indexOf","removeAttr","removeData","prop","reInit","plugins","isJQ","each","_this","fns","plgs","forEach","p","foundation","Object","keys","err","console","error","reflow","find","addBack","$el","opts","warn","thing","e","opt","map","el","parseValue","er","getFnName","addToJquery","method","$noJS","removeClass","args","prototype","call","arguments","plugClass","apply","ReferenceError","TypeError","fn","util","throttle","func","delay","timer","context","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","test","navigator","userAgent","lastTime","nextTime","max","clearTimeout","performance","start","Function","oThis","aArgs","fToBind","fNOP","fBound","concat","funcNameRegex","results","exec","isNaN","parseFloat","Box","ImNotTouchingYou","OverlapArea","GetDimensions","GetOffsets","GetExplicitOffsets","element","parent","lrOnly","tbOnly","ignoreBottom","eleDims","topOver","bottomOver","leftOver","rightOver","parDims","height","offset","top","left","windowDims","min","sqrt","Error","rect","getBoundingClientRect","parRect","winRect","body","winY","pageYOffset","winX","pageXOffset","parentDims","anchor","position","vOffset","hOffset","isOverflow","log","Rtl","$eleDims","$anchorDims","alignment","topVal","leftVal","onImagesLoaded","images","unloaded","complete","naturalWidth","singleImageLoaded","image","Image","events","me","event","src","keyCodes","commands","findFocusable","filter","parseKey","which","keyCode","String","fromCharCode","toUpperCase","shiftKey","ctrlKey","altKey","Keyboard","getKeyCodes","handleKey","component","functions","commandList","cmds","command","ltr","extend","returnValue","handled","unhandled","register","componentName","trapFocus","$focusable","$firstFocusable","eq","$lastFocusable","preventDefault","focus","releaseFocus","kcs","k","kc","initClasses","activeClasses","Motion","animateIn","animation","animate","animateOut","Move","duration","anim","prog","move","ts","isIn","initClass","activeClass","reset","addClass","show","offsetWidth","finish","hide","transitionDuration","Nest","Feather","menu","items","subMenuClass","subItemClass","hasSubClass","applyAria","$item","$sub","children","Burn","Timer","options","nameSpace","remain","isPaused","restart","infinite","pause","Touch","startPosX","startPosY","startTime","elapsedTime","startEvent","isMoving","didMoved","onTouchEnd","removeEventListener","onTouchMove","tapEvent","Event","spotSwipe","x","touches","pageX","y","pageY","dx","dir","abs","moveThreshold","timeThreshold","onTouchStart","addEventListener","init","SpotSwipe","enabled","documentElement","special","swipe","setup","tap","noop","setupSpotSwipe","setupTouchHandler","addTouch","handleTouch","changedTouches","first","eventTypes","touchstart","touchmove","touchend","simulatedEvent","MouseEvent","screenX","screenY","clientX","clientY","createEvent","initMouseEvent","dispatchEvent","MutationObserver","prefixes","triggers","Triggers","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","stopPropagation","fadeOut","toggleFocusListener","addOpenListener","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","scrollListener","closeMeListener","pluginId","not","addClosemeListener","yetiBoxes","plugNames","listeners","join","debounceGlobalListener","debounce","listener","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","$target","attributeName","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","triggersInitialized","IHearYou","Plugin","_setup","getPluginName","_destroy","obj","Abide","defaults","$inputs","merge","$globalErrors","a11yAttributes","input","addA11yAttributes","addGlobalErrorA11yAttributes","_events","resetForm","validateForm","validateOn","validateInput","liveValidate","validateOnBlur","isGood","checked","$error","siblings","formErrorSelector","add","$label","$els","labels","findLabel","$formError","findFormError","labelErrorClass","formErrorClass","inputErrorClass","$errors","$labels","errorId","elemId","label","a11yErrorLevel","groupName","findRadioLabels","$formErrors","removeRadioErrorClasses","clearRequire","requiredCheck","validated","customValidator","validator","equalTo","validateRadio","validateText","matchValidation","validators","goodToGo","message","dependentElements","acc","noError","pattern","inputText","valid","patterns","RegExp","$group","required","clear","v","$form","removeErrorClasses","alpha","alpha_numeric","integer","number","card","cvv","email","url","domain","datetime","date","time","dateISO","month_day_year","day_month_year","color","website","Accordion","_isInitializing","$tabs","idx","$content","linkId","$initActive","_initialAnchor","prev","_openSingleTab","_checkDeepLink","location","hash","$anchor","$link","isOwnAnchor","hasClass","_closeAllTabs","deepLinkSmudge","scrollTop","deepLinkSmudgeDelay","deepLink","$tabContent","toggle","next","$a","multiExpand","previous","up","down","updateHistory","history","pushState","replaceState","_openTab","$targetItem","$othersItems","allowAllClosed","_closeTab","$activeContents","targetContentId","slideDown","slideSpeed","slideUp","$activeTabs","stop","AccordionMenu","multiOpen","$menuLinks","subId","isActive","parentLink","clone","prependTo","wrap","submenuToggle","after","submenuToggleText","initPanes","$submenu","$elements","$prevElement","$nextElement","parents","open","close","closeAll","hideAll","stopImmediatePropagation","$targetBranch","parentsUntil","$othersActiveSubmenus","$submenus","$allmenus","detach","remove","Drilldown","autoApplyClass","$submenuAnchors","$menuItems","$currentMenu","_prepareMenu","_registerEvents","_keyboardEvents","$menu","$back","backButtonPosition","append","backButton","prepend","_back","autoHeight","$wrapper","wrapper","animateHeight","_getMaxDims","_show","closeOnClick","$body","contains","_hideAll","_bindHandler","_scrollTop","_resize","$scrollTopElement","scrollTopElement","scrollPos","parseInt","scrollTopOffset","animationDuration","animationEasing","_hide","parentSubMenu","autoFocus","$expandedSubmenus","index","_setHideSubMenuClasses","isLastChild","_setShowSubMenuClasses","blur","maxHeight","result","numOfElems","unwrap","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","nextItem","item","array","currentIdx","Positionable","triedPositions","_getDefaultPosition","_getDefaultAlignment","originalPosition","originalAlignment","_alignmentsExhausted","_realign","_addTriedPosition","isExhausted","$parent","allowOverlap","_getVOffset","_getHOffset","minOverlap","minCoordinates","_positionsExhausted","overlap","allowBottomOverlap","_reposition","Dropdown","$id","$anchors","_setCurrentAnchor","parentClass","$currentAnchor","match","horizontalPosition","_setPosition","hover","bodyData","whatinput","timeout","hoverDelay","hoverPane","visibleFocusableElements","_addBodyHandler","DropdownMenu","subs","verticalClass","rightClass","changed","hasTouch","ontouchstart","parClass","handleClickFn","hasSub","hasClicked","clickOpen","forceFollow","closeOnClickInside","disableHover","autoclose","closingTime","isTab","nextSibling","prevSibling","openSub","closeSub","_isVertical","_isRtl","$sibs","oldClass","$parentLi","$toClose","somethingToClose","Equalizer","eqId","$watched","hasNested","isNested","isOn","onResizeMeBound","_onResizeMe","onPostEqualizedBound","_onPostEqualized","imgs","tooSmall","equalizeOn","_checkMQ","_reflow","_pauseEvents","equalizeOnStack","_isStacked","equalizeByRow","getHeightsByRow","applyHeightByRow","getHeights","applyHeight","heights","len","offsetHeight","lastElTopOffset","groups","group","elOffsetTop","j","ln","groupsILength","lenJ","Interchange","rules","currentPath","_addBreakpoints","_generateRules","rule","path","SPECIAL_QUERIES","rulesList","nodeName","response","html","SmoothScroll","_linkClickListener","_handleLinkClick","arrival","getAttribute","_inTransition","scrollToLoc","loc","$loc","threshold","Magellan","calcPoints","$targets","$links","$active","points","winHeight","innerHeight","clientHeight","docHeight","scrollHeight","$tar","pt","targetPoint","easing","deepLinking","_updateActive","onLoadListener","_deepLinkScroll","newScrollPos","isScrollingUp","activeIdx","visibleLinks","$oldActive","activeHash","isNewActive","isNewHash","pathname","search","OffCanvas","contentClasses","base","reveal","$lastTrigger","$triggers","nested","contentId","transition","contentOverlay","overlay","overlayPosition","setAttribute","$overlay","insertAfter","revealOnRegExp","revealClass","revealOnClass","isRevealed","revealOn","_setMQChecker","transitionTime","_removeContentClasses","_handleKeyboard","hasReveal","_addContentClasses","allowUp","allowDown","lastY","originalEvent","forceTo","scrollTo","contentScroll","_stopScrolling","_recordScrollable","_stopScrollPropagation","canvasFocus","Orbit","_reset","containerClass","$slides","slideClass","$images","initActive","useMUI","_prepareForOrbit","bullets","_loadBullets","autoPlay","geoSync","accessible","$bullets","boxOfBullets","timerDelay","changeSlide","_setWrapperHeight","temp","counter","pauseOnHover","navButtons","$controls","nextClass","prevClass","$slide","_updateBullets","isLTR","chosenSlide","$curSlide","$firstSlide","$lastSlide","last","dirIn","dirOut","$newSlide","infiniteWrap","$oldBullet","span","$newBullet","animInFromRight","animOutToRight","animInFromLeft","animOutToLeft","MenuPlugins","dropdown","cssClass","drilldown","accordion","ResponsiveMenu","currentMq","currentPlugin","rulesTree","ruleSize","rulePlugin","isEmptyObject","_checkMediaQueries","matchedMq","destroy","ResponsiveToggle","targetID","$targetMenu","$toggler","animationIn","animationOut","_update","_updateMqHandler","toggleMenu","hideFor","Reveal","cached","mq","fullScreen","_makeOverlay","additionalOverlayClasses","outerWidth","outerHeight","margin","_updatePosition","_handleState","$activeAnchor","activeElement","multipleOpened","_disableScroll","afterAnimation","_addGlobalClasses","focusableElements","showDelay","_addGlobalListeners","updateScrollbarClass","toggleClass","closeOnEsc","finishUp","hideDelay","_removeGlobalClasses","_enableScroll","resetOnClose","urlWithoutHash","title","Slider","inputs","handles","$handle","$input","$fill","vertical","disabled","disabledClass","binding","_setInitAttr","doubleSided","$handle2","$input2","setHandles","_setHandlePos","pctOfBar","percent","positionValueFunction","_logTransform","_powTransform","toFixed","baseLog","nonLinearBase","$hndl","noInvert","isDbl","h2Val","step","h1Val","vert","hOrW","lOrT","handleDim","elemDim","_pctOfBar","pxToMove","movement","decimal","_setValues","isLeftHndl","dim","handlePct","handlePos","initialStart","moveTime","changedDelay","initVal","initialEnd","hasVal","direction","eventOffset","halfOfHandle","barDim","windowScroll","scrollLeft","elemOffset","eventFromBar","barXY","offsetPct","_value","_adjustValue","firstHndlPos","absPosition","secndHndlPos","div","prev_val","next_val","_eventsForHandle","curHandle","handleChangeEvent","_handleEvent","clickSelect","draggable","_$handle","oldValue","newValue","decrease","increase","decrease_fast","increase_fast","invertVertical","frac","num","clickPos","Sticky","$container","wasWrapped","container","stickyClass","scrollCount","checkEvery","isStuck","containerHeight","elemHeight","_parsePoints","_setSizes","scroll","_calc","_removeSticky","topPoint","reverse","topAnchor","btm","btmAnchor","pts","breaks","place","canStick","_eventsHandler","_pauseListeners","checkSizes","bottomPoint","_setSticky","stickTo","mrgn","notStuckTo","isTop","stickToTop","anchorPt","anchorHeight","topOrBottom","stickyOn","newElemWidth","comp","pdngl","pdngr","newContainerHeight","_setBreakPoints","mTop","emCalc","marginTop","mBtm","marginBottom","bottom","em","fontSize","Tabs","$tabTitles","linkClass","linkActiveClass","matchHeight","_setHeight","selectTab","_collapse","_addKeyHandler","_addClickHandler","_setHeightMqHandler","_handleTabChange","wrapOnKeys","historyHandled","activeCollapse","$oldTab","$tabLink","$targetContent","_collapseTab","panelActiveClass","$target_anchor","$activeTab","idStr","panelClass","panel","Toggler","$trigger","controls","containsId","_updateARIA","Tooltip","isClick","tipText","template","_buildTemplate","allowHtml","triggerClass","tooltipWidth","tooltipHeight","templateClasses","tooltipClass","$template","showOn","fadeIn","fadeInDuration","fadeOutDuration","isFocus","disableForTouch","touchCloseText","tabs","ResponsiveAccordionTabs","_getAllOptions","allOptions","dummyPlugin","tmpPlugin","keyKey","objObj","_changedZfMediaQueryHandler","storezfData","_handleMarkup","toSet","fromString","$panels","tabsTitle","tabsPanel","$liHeads","$liHeadsA","display","visibility","$tabsContent","$placeholder","tempValue","CoreUtils"],"mappings":"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"}
\ No newline at end of file
index a0e6e063bcc54023f52ed4d0050d0ba0b7fbb41b..67af00a220b03e7b9bf96fd2f40e9a24aad78d0c 100644 (file)
@@ -486,7 +486,7 @@ declare module FoundationSites {
 }
 
 interface JQuery {
-  foundation(method?: string|Array<any>, $element?: JQuery): JQuery;
+  foundation(method?: string | Array<any>, ...args: any[]): JQuery;
 }
 
 declare var Foundation: FoundationSites.FoundationSitesStatic;
diff --git a/dist/js/foundation.es6.js b/dist/js/foundation.es6.js
new file mode 100644 (file)
index 0000000..40bf197
--- /dev/null
@@ -0,0 +1,10373 @@
+import $ from 'jquery';
+
+// Core Foundation Utilities, utilized in a number of places.
+
+  /**
+   * Returns a boolean for RTL support
+   */
+function rtl() {
+  return $('html').attr('dir') === 'rtl';
+}
+
+/**
+ * returns a random base-36 uid with namespacing
+ * @function
+ * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.
+ * @param {String} namespace - name of plugin to be incorporated in uid, optional.
+ * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.
+ * @returns {String} - unique id
+ */
+function GetYoDigits(length, namespace){
+  length = length || 6;
+  return Math.round((Math.pow(36, length + 1) - Math.random() * Math.pow(36, length))).toString(36).slice(1) + (namespace ? `-${namespace}` : '');
+}
+
+/**
+ * Escape a string so it can be used as a regexp pattern
+ * @function
+ * @see https://stackoverflow.com/a/9310752/4317384
+ *
+ * @param {String} str - string to escape.
+ * @returns {String} - escaped string
+ */
+function RegExpEscape(str){
+  return str.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
+}
+
+function transitionend($elem){
+  var transitions = {
+    'transition': 'transitionend',
+    'WebkitTransition': 'webkitTransitionEnd',
+    'MozTransition': 'transitionend',
+    'OTransition': 'otransitionend'
+  };
+  var elem = document.createElement('div'),
+      end;
+
+  for (var t in transitions){
+    if (typeof elem.style[t] !== 'undefined'){
+      end = transitions[t];
+    }
+  }
+  if(end){
+    return end;
+  }else{
+    end = setTimeout(function(){
+      $elem.triggerHandler('transitionend', [$elem]);
+    }, 1);
+    return 'transitionend';
+  }
+}
+
+/**
+ * Return an event type to listen for window load.
+ *
+ * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.
+ * If `handler` is passed, attach it to the event on `$elem`.
+ * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.
+ * @function
+ *
+ * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.
+ * @param {Function} [] handler - function to attach to the event.
+ * @returns {String} - event type that should or will be triggered.
+ */
+function onLoad($elem, handler) {
+  const didLoad = document.readyState === 'complete';
+  const eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';
+  const cb = () => $elem.triggerHandler(eventType);
+
+  if ($elem) {
+    if (handler) $elem.one(eventType, handler);
+
+    if (didLoad)
+      setTimeout(cb);
+    else
+      $(window).one('load', cb);
+  }
+
+  return eventType;
+}
+
+/**
+ * Retuns an handler for the `mouseleave` that ignore disappeared mouses.
+ *
+ * If the mouse "disappeared" from the document (like when going on a browser UI element, See https://git.io/zf-11410),
+ * the event is ignored.
+ * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window
+ *   (like by switching to an other window with [Alt]+[Tab]).
+ * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document
+ *   outside of the element it left.
+ *
+ * @function
+ *
+ * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.
+ * @param {Object} [] options - object of options:
+ * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.
+ * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.
+ * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.
+ */
+function ignoreMousedisappear(handler, { ignoreLeaveWindow = false, ignoreReappear = false } = {}) {
+  return function leaveEventHandler(eLeave, ...rest) {
+    const callback = handler.bind(this, eLeave, ...rest);
+
+    // The mouse left: call the given callback if the mouse entered elsewhere
+    if (eLeave.relatedTarget !== null) {
+      return callback();
+    }
+
+    // Otherwise, check if the mouse actually left the window.
+    // In firefox if the user switched between windows, the window sill have the focus by the time
+    // the event is triggered. We have to debounce the event to test this case.
+    setTimeout(function leaveEventDebouncer() {
+      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {
+        return callback();
+      }
+
+      // Otherwise, wait for the mouse to reeapear outside of the element,
+      if (!ignoreReappear) {
+        $(document).one('mouseenter', function reenterEventHandler(eReenter) {
+          if (!$(eLeave.currentTarget).has(eReenter.target).length) {
+            // Fill where the mouse finally entered.
+            eLeave.relatedTarget = eReenter.target;
+            callback();
+          }
+        });
+      }
+
+    }, 0);
+  };
+}
+
+var foundation_core_utils = /*#__PURE__*/Object.freeze({
+  rtl: rtl,
+  GetYoDigits: GetYoDigits,
+  RegExpEscape: RegExpEscape,
+  transitionend: transitionend,
+  onLoad: onLoad,
+  ignoreMousedisappear: ignoreMousedisappear
+});
+
+// matchMedia() polyfill - Test a CSS media type/query in JS.
+// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license
+/* eslint-disable */
+window.matchMedia || (window.matchMedia = (function () {
+
+  // For browsers that support matchMedium api such as IE 9 and webkit
+  var styleMedia = (window.styleMedia || window.media);
+
+  // For those that don't support matchMedium
+  if (!styleMedia) {
+    var style   = document.createElement('style'),
+    script      = document.getElementsByTagName('script')[0],
+    info        = null;
+
+    style.type  = 'text/css';
+    style.id    = 'matchmediajs-test';
+
+    if (!script) {
+      document.head.appendChild(style);
+    } else {
+      script.parentNode.insertBefore(style, script);
+    }
+
+    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
+    info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;
+
+    styleMedia = {
+      matchMedium: function (media) {
+        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';
+
+        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
+        if (style.styleSheet) {
+          style.styleSheet.cssText = text;
+        } else {
+          style.textContent = text;
+        }
+
+        // Test if media query is true or false
+        return info.width === '1px';
+      }
+    };
+  }
+
+  return function(media) {
+    return {
+      matches: styleMedia.matchMedium(media || 'all'),
+      media: media || 'all'
+    };
+  };
+})());
+/* eslint-enable */
+
+var MediaQuery = {
+  queries: [],
+
+  current: '',
+
+  /**
+   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.
+   * @function
+   * @private
+   */
+  _init() {
+    var self = this;
+    var $meta = $('meta.foundation-mq');
+    if(!$meta.length){
+      $('<meta class="foundation-mq">').appendTo(document.head);
+    }
+
+    var extractedStyles = $('.foundation-mq').css('font-family');
+    var namedQueries;
+
+    namedQueries = parseStyleToObject(extractedStyles);
+
+    for (var key in namedQueries) {
+      if(namedQueries.hasOwnProperty(key)) {
+        self.queries.push({
+          name: key,
+          value: `only screen and (min-width: ${namedQueries[key]})`
+        });
+      }
+    }
+
+    this.current = this._getCurrentSize();
+
+    this._watcher();
+  },
+
+  /**
+   * Checks if the screen is at least as wide as a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to check.
+   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.
+   */
+  atLeast(size) {
+    var query = this.get(size);
+
+    if (query) {
+      return window.matchMedia(query).matches;
+    }
+
+    return false;
+  },
+
+  /**
+   * Checks if the screen matches to a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.
+   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.
+   */
+  is(size) {
+    size = size.trim().split(' ');
+    if(size.length > 1 && size[1] === 'only') {
+      if(size[0] === this._getCurrentSize()) return true;
+    } else {
+      return this.atLeast(size[0]);
+    }
+    return false;
+  },
+
+  /**
+   * Gets the media query of a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to get.
+   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.
+   */
+  get(size) {
+    for (var i in this.queries) {
+      if(this.queries.hasOwnProperty(i)) {
+        var query = this.queries[i];
+        if (size === query.name) return query.value;
+      }
+    }
+
+    return null;
+  },
+
+  /**
+   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).
+   * @function
+   * @private
+   * @returns {String} Name of the current breakpoint.
+   */
+  _getCurrentSize() {
+    var matched;
+
+    for (var i = 0; i < this.queries.length; i++) {
+      var query = this.queries[i];
+
+      if (window.matchMedia(query.value).matches) {
+        matched = query;
+      }
+    }
+
+    if (typeof matched === 'object') {
+      return matched.name;
+    } else {
+      return matched;
+    }
+  },
+
+  /**
+   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.
+   * @function
+   * @private
+   */
+  _watcher() {
+    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', () => {
+      var newSize = this._getCurrentSize(), currentSize = this.current;
+
+      if (newSize !== currentSize) {
+        // Change the current media query
+        this.current = newSize;
+
+        // Broadcast the media query change on the window
+        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
+      }
+    });
+  }
+};
+
+
+
+// Thank you: https://github.com/sindresorhus/query-string
+function parseStyleToObject(str) {
+  var styleObject = {};
+
+  if (typeof str !== 'string') {
+    return styleObject;
+  }
+
+  str = str.trim().slice(1, -1); // browsers re-quote string style values
+
+  if (!str) {
+    return styleObject;
+  }
+
+  styleObject = str.split('&').reduce(function(ret, param) {
+    var parts = param.replace(/\+/g, ' ').split('=');
+    var key = parts[0];
+    var val = parts[1];
+    key = decodeURIComponent(key);
+
+    // missing `=` should be `null`:
+    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters
+    val = typeof val === 'undefined' ? null : decodeURIComponent(val);
+
+    if (!ret.hasOwnProperty(key)) {
+      ret[key] = val;
+    } else if (Array.isArray(ret[key])) {
+      ret[key].push(val);
+    } else {
+      ret[key] = [ret[key], val];
+    }
+    return ret;
+  }, {});
+
+  return styleObject;
+}
+
+var FOUNDATION_VERSION = '6.5.3';
+
+// Global Foundation object
+// This is attached to the window, or used as a module for AMD/Browserify
+var Foundation = {
+  version: FOUNDATION_VERSION,
+
+  /**
+   * Stores initialized plugins.
+   */
+  _plugins: {},
+
+  /**
+   * Stores generated unique ids for plugin instances
+   */
+  _uuids: [],
+
+  /**
+   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.
+   * @param {Object} plugin - The constructor of the plugin.
+   */
+  plugin: function(plugin, name) {
+    // Object key to use when adding to global Foundation object
+    // Examples: Foundation.Reveal, Foundation.OffCanvas
+    var className = (name || functionName(plugin));
+    // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin
+    // Examples: data-reveal, data-off-canvas
+    var attrName  = hyphenate(className);
+
+    // Add to the Foundation object and the plugins list (for reflowing)
+    this._plugins[attrName] = this[className] = plugin;
+  },
+  /**
+   * @function
+   * Populates the _uuids array with pointers to each individual plugin instance.
+   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.
+   * Also fires the initialization event for each plugin, consolidating repetitive code.
+   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
+   * @param {String} name - the name of the plugin, passed as a camelCased string.
+   * @fires Plugin#init
+   */
+  registerPlugin: function(plugin, name){
+    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();
+    plugin.uuid = GetYoDigits(6, pluginName);
+
+    if(!plugin.$element.attr(`data-${pluginName}`)){ plugin.$element.attr(`data-${pluginName}`, plugin.uuid); }
+    if(!plugin.$element.data('zfPlugin')){ plugin.$element.data('zfPlugin', plugin); }
+          /**
+           * Fires when the plugin has initialized.
+           * @event Plugin#init
+           */
+    plugin.$element.trigger(`init.zf.${pluginName}`);
+
+    this._uuids.push(plugin.uuid);
+
+    return;
+  },
+  /**
+   * @function
+   * Removes the plugins uuid from the _uuids array.
+   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.
+   * Also fires the destroyed event for the plugin, consolidating repetitive code.
+   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
+   * @fires Plugin#destroyed
+   */
+  unregisterPlugin: function(plugin){
+    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));
+
+    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);
+    plugin.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')
+          /**
+           * Fires when the plugin has been destroyed.
+           * @event Plugin#destroyed
+           */
+          .trigger(`destroyed.zf.${pluginName}`);
+    for(var prop in plugin){
+      plugin[prop] = null;//clean up script to prep for garbage collection.
+    }
+    return;
+  },
+
+  /**
+   * @function
+   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.
+   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`
+   * @default If no argument is passed, reflow all currently active plugins.
+   */
+   reInit: function(plugins){
+     var isJQ = plugins instanceof $;
+     try{
+       if(isJQ){
+         plugins.each(function(){
+           $(this).data('zfPlugin')._init();
+         });
+       }else{
+         var type = typeof plugins,
+         _this = this,
+         fns = {
+           'object': function(plgs){
+             plgs.forEach(function(p){
+               p = hyphenate(p);
+               $('[data-'+ p +']').foundation('_init');
+             });
+           },
+           'string': function(){
+             plugins = hyphenate(plugins);
+             $('[data-'+ plugins +']').foundation('_init');
+           },
+           'undefined': function(){
+             this['object'](Object.keys(_this._plugins));
+           }
+         };
+         fns[type](plugins);
+       }
+     }catch(err){
+       console.error(err);
+     }finally{
+       return plugins;
+     }
+   },
+
+  /**
+   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.
+   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.
+   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.
+   */
+  reflow: function(elem, plugins) {
+
+    // If plugins is undefined, just grab everything
+    if (typeof plugins === 'undefined') {
+      plugins = Object.keys(this._plugins);
+    }
+    // If plugins is a string, convert it to an array with one item
+    else if (typeof plugins === 'string') {
+      plugins = [plugins];
+    }
+
+    var _this = this;
+
+    // Iterate through each plugin
+    $.each(plugins, function(i, name) {
+      // Get the current plugin
+      var plugin = _this._plugins[name];
+
+      // Localize the search to all elements inside elem, as well as elem itself, unless elem === document
+      var $elem = $(elem).find('[data-'+name+']').addBack('[data-'+name+']');
+
+      // For each plugin found, initialize it
+      $elem.each(function() {
+        var $el = $(this),
+            opts = {};
+        // Don't double-dip on plugins
+        if ($el.data('zfPlugin')) {
+          console.warn("Tried to initialize "+name+" on an element that already has a Foundation plugin.");
+          return;
+        }
+
+        if($el.attr('data-options')){
+          var thing = $el.attr('data-options').split(';').forEach(function(e, i){
+            var opt = e.split(':').map(function(el){ return el.trim(); });
+            if(opt[0]) opts[opt[0]] = parseValue(opt[1]);
+          });
+        }
+        try{
+          $el.data('zfPlugin', new plugin($(this), opts));
+        }catch(er){
+          console.error(er);
+        }finally{
+          return;
+        }
+      });
+    });
+  },
+  getFnName: functionName,
+
+  addToJquery: function($$$1) {
+    // TODO: consider not making this a jQuery function
+    // TODO: need way to reflow vs. re-initialize
+    /**
+     * The Foundation jQuery method.
+     * @param {String|Array} method - An action to perform on the current jQuery object.
+     */
+    var foundation = function(method) {
+      var type = typeof method,
+          $noJS = $$$1('.no-js');
+
+      if($noJS.length){
+        $noJS.removeClass('no-js');
+      }
+
+      if(type === 'undefined'){//needs to initialize the Foundation object, or an individual plugin.
+        MediaQuery._init();
+        Foundation.reflow(this);
+      }else if(type === 'string'){//an individual method to invoke on a plugin or group of plugins
+        var args = Array.prototype.slice.call(arguments, 1);//collect all the arguments, if necessary
+        var plugClass = this.data('zfPlugin');//determine the class of plugin
+
+        if(typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined'){//make sure both the class and method exist
+          if(this.length === 1){//if there's only one, call it directly.
+              plugClass[method].apply(plugClass, args);
+          }else{
+            this.each(function(i, el){//otherwise loop through the jQuery collection and invoke the method on each
+              plugClass[method].apply($$$1(el).data('zfPlugin'), args);
+            });
+          }
+        }else{//error for no class or no method
+          throw new ReferenceError("We're sorry, '" + method + "' is not an available method for " + (plugClass ? functionName(plugClass) : 'this element') + '.');
+        }
+      }else{//error for invalid argument type
+        throw new TypeError(`We're sorry, ${type} is not a valid parameter. You must use a string representing the method you wish to invoke.`);
+      }
+      return this;
+    };
+    $$$1.fn.foundation = foundation;
+    return $$$1;
+  }
+};
+
+Foundation.util = {
+  /**
+   * Function for applying a debounce effect to a function call.
+   * @function
+   * @param {Function} func - Function to be called at end of timeout.
+   * @param {Number} delay - Time in ms to delay the call of `func`.
+   * @returns function
+   */
+  throttle: function (func, delay) {
+    var timer = null;
+
+    return function () {
+      var context = this, args = arguments;
+
+      if (timer === null) {
+        timer = setTimeout(function () {
+          func.apply(context, args);
+          timer = null;
+        }, delay);
+      }
+    };
+  }
+};
+
+window.Foundation = Foundation;
+
+// Polyfill for requestAnimationFrame
+(function() {
+  if (!Date.now || !window.Date.now)
+    window.Date.now = Date.now = function() { return new Date().getTime(); };
+
+  var vendors = ['webkit', 'moz'];
+  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {
+      var vp = vendors[i];
+      window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];
+      window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']
+                                 || window[vp+'CancelRequestAnimationFrame']);
+  }
+  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)
+    || !window.requestAnimationFrame || !window.cancelAnimationFrame) {
+    var lastTime = 0;
+    window.requestAnimationFrame = function(callback) {
+        var now = Date.now();
+        var nextTime = Math.max(lastTime + 16, now);
+        return setTimeout(function() { callback(lastTime = nextTime); },
+                          nextTime - now);
+    };
+    window.cancelAnimationFrame = clearTimeout;
+  }
+  /**
+   * Polyfill for performance.now, required by rAF
+   */
+  if(!window.performance || !window.performance.now){
+    window.performance = {
+      start: Date.now(),
+      now: function(){ return Date.now() - this.start; }
+    };
+  }
+})();
+if (!Function.prototype.bind) {
+  Function.prototype.bind = function(oThis) {
+    if (typeof this !== 'function') {
+      // closest thing possible to the ECMAScript 5
+      // internal IsCallable function
+      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');
+    }
+
+    var aArgs   = Array.prototype.slice.call(arguments, 1),
+        fToBind = this,
+        fNOP    = function() {},
+        fBound  = function() {
+          return fToBind.apply(this instanceof fNOP
+                 ? this
+                 : oThis,
+                 aArgs.concat(Array.prototype.slice.call(arguments)));
+        };
+
+    if (this.prototype) {
+      // native functions don't have a prototype
+      fNOP.prototype = this.prototype;
+    }
+    fBound.prototype = new fNOP();
+
+    return fBound;
+  };
+}
+// Polyfill to get the name of a function in IE9
+function functionName(fn) {
+  if (typeof Function.prototype.name === 'undefined') {
+    var funcNameRegex = /function\s([^(]{1,})\(/;
+    var results = (funcNameRegex).exec((fn).toString());
+    return (results && results.length > 1) ? results[1].trim() : "";
+  }
+  else if (typeof fn.prototype === 'undefined') {
+    return fn.constructor.name;
+  }
+  else {
+    return fn.prototype.constructor.name;
+  }
+}
+function parseValue(str){
+  if ('true' === str) return true;
+  else if ('false' === str) return false;
+  else if (!isNaN(str * 1)) return parseFloat(str);
+  return str;
+}
+// Convert PascalCase to kebab-case
+// Thank you: http://stackoverflow.com/a/8955580
+function hyphenate(str) {
+  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
+}
+
+var Box = {
+  ImNotTouchingYou: ImNotTouchingYou,
+  OverlapArea: OverlapArea,
+  GetDimensions: GetDimensions,
+  GetOffsets: GetOffsets,
+  GetExplicitOffsets: GetExplicitOffsets
+};
+
+/**
+ * Compares the dimensions of an element to a container and determines collision events with container.
+ * @function
+ * @param {jQuery} element - jQuery object to test for collisions.
+ * @param {jQuery} parent - jQuery object to use as bounding container.
+ * @param {Boolean} lrOnly - set to true to check left and right values only.
+ * @param {Boolean} tbOnly - set to true to check top and bottom values only.
+ * @default if no parent object passed, detects collisions with `window`.
+ * @returns {Boolean} - true if collision free, false if a collision in any direction.
+ */
+function ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;
+}
+function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  var eleDims = GetDimensions(element),
+  topOver, bottomOver, leftOver, rightOver;
+  if (parent) {
+    var parDims = GetDimensions(parent);
+
+    bottomOver = (parDims.height + parDims.offset.top) - (eleDims.offset.top + eleDims.height);
+    topOver    = eleDims.offset.top - parDims.offset.top;
+    leftOver   = eleDims.offset.left - parDims.offset.left;
+    rightOver  = (parDims.width + parDims.offset.left) - (eleDims.offset.left + eleDims.width);
+  }
+  else {
+    bottomOver = (eleDims.windowDims.height + eleDims.windowDims.offset.top) - (eleDims.offset.top + eleDims.height);
+    topOver    = eleDims.offset.top - eleDims.windowDims.offset.top;
+    leftOver   = eleDims.offset.left - eleDims.windowDims.offset.left;
+    rightOver  = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);
+  }
+
+  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);
+  topOver    = Math.min(topOver, 0);
+  leftOver   = Math.min(leftOver, 0);
+  rightOver  = Math.min(rightOver, 0);
+
+  if (lrOnly) {
+    return leftOver + rightOver;
+  }
+  if (tbOnly) {
+    return topOver + bottomOver;
+  }
+
+  // use sum of squares b/c we care about overlap area.
+  return Math.sqrt((topOver * topOver) + (bottomOver * bottomOver) + (leftOver * leftOver) + (rightOver * rightOver));
+}
+
+/**
+ * Uses native methods to return an object of dimension values.
+ * @function
+ * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.
+ * @returns {Object} - nested object of integer pixel values
+ * TODO - if element is window, return only those values.
+ */
+function GetDimensions(elem){
+  elem = elem.length ? elem[0] : elem;
+
+  if (elem === window || elem === document) {
+    throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");
+  }
+
+  var rect = elem.getBoundingClientRect(),
+      parRect = elem.parentNode.getBoundingClientRect(),
+      winRect = document.body.getBoundingClientRect(),
+      winY = window.pageYOffset,
+      winX = window.pageXOffset;
+
+  return {
+    width: rect.width,
+    height: rect.height,
+    offset: {
+      top: rect.top + winY,
+      left: rect.left + winX
+    },
+    parentDims: {
+      width: parRect.width,
+      height: parRect.height,
+      offset: {
+        top: parRect.top + winY,
+        left: parRect.left + winX
+      }
+    },
+    windowDims: {
+      width: winRect.width,
+      height: winRect.height,
+      offset: {
+        top: winY,
+        left: winX
+      }
+    }
+  }
+}
+
+/**
+ * Returns an object of top and left integer pixel values for dynamically rendered elements,
+ * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where
+ * you don't know alignment, but generally from
+ * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.
+ * @function
+ * @param {jQuery} element - jQuery object for the element being positioned.
+ * @param {jQuery} anchor - jQuery object for the element's anchor point.
+ * @param {String} position - a string relating to the desired position of the element, relative to it's anchor
+ * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.
+ * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.
+ * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.
+ * TODO alter/rewrite to work with `em` values as well/instead of pixels
+ */
+function GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {
+  console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5");
+  switch (position) {
+    case 'top':
+      return rtl() ?
+        GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) :
+        GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);
+    case 'bottom':
+      return rtl() ?
+        GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) :
+        GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+    case 'center top':
+      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);
+    case 'center bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);
+    case 'center left':
+      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);
+    case 'center right':
+      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);
+    case 'left bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);
+    case 'right bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+    // Backwards compatibility... this along with the reveal and reveal full
+    // classes are the only ones that didn't reference anchor
+    case 'center':
+      return {
+        left: ($eleDims.windowDims.offset.left + ($eleDims.windowDims.width / 2)) - ($eleDims.width / 2) + hOffset,
+        top: ($eleDims.windowDims.offset.top + ($eleDims.windowDims.height / 2)) - ($eleDims.height / 2 + vOffset)
+      }
+    case 'reveal':
+      return {
+        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,
+        top: $eleDims.windowDims.offset.top + vOffset
+      }
+    case 'reveal full':
+      return {
+        left: $eleDims.windowDims.offset.left,
+        top: $eleDims.windowDims.offset.top
+      }
+      break;
+    default:
+      return {
+        left: (rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset: $anchorDims.offset.left + hOffset),
+        top: $anchorDims.offset.top + $anchorDims.height + vOffset
+      }
+
+  }
+
+}
+
+function GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {
+  var $eleDims = GetDimensions(element),
+      $anchorDims = anchor ? GetDimensions(anchor) : null;
+
+      var topVal, leftVal;
+
+  // set position related attribute
+
+  switch (position) {
+    case 'top':
+      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);
+      break;
+    case 'bottom':
+      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;
+      break;
+    case 'left':
+      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);
+      break;
+    case 'right':
+      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;
+      break;
+  }
+
+
+  // set alignment related attribute
+  switch (position) {
+    case 'top':
+    case 'bottom':
+      switch (alignment) {
+        case 'left':
+          leftVal = $anchorDims.offset.left + hOffset;
+          break;
+        case 'right':
+          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;
+          break;
+        case 'center':
+          leftVal = isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)) + hOffset;
+          break;
+      }
+      break;
+    case 'right':
+    case 'left':
+      switch (alignment) {
+        case 'bottom':
+          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;
+          break;
+        case 'top':
+          topVal = $anchorDims.offset.top + vOffset;
+          break;
+        case 'center':
+          topVal = ($anchorDims.offset.top + vOffset + ($anchorDims.height / 2)) - ($eleDims.height / 2);
+          break;
+      }
+      break;
+  }
+  return {top: topVal, left: leftVal};
+}
+
+/**
+ * Runs a callback function when images are fully loaded.
+ * @param {Object} images - Image(s) to check if loaded.
+ * @param {Func} callback - Function to execute when image is fully loaded.
+ */
+function onImagesLoaded(images, callback){
+  var unloaded = images.length;
+
+  if (unloaded === 0) {
+    callback();
+  }
+
+  images.each(function(){
+    // Check if image is loaded
+    if (this.complete && typeof this.naturalWidth !== 'undefined') {
+      singleImageLoaded();
+    }
+    else {
+      // If the above check failed, simulate loading on detached element.
+      var image = new Image();
+      // Still count image as loaded if it finalizes with an error.
+      var events = "load.zf.images error.zf.images";
+      $(image).one(events, function me(event){
+        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.
+        $(this).off(events, me);
+        singleImageLoaded();
+      });
+      image.src = $(this).attr('src');
+    }
+  });
+
+  function singleImageLoaded() {
+    unloaded--;
+    if (unloaded === 0) {
+      callback();
+    }
+  }
+}
+
+/*******************************************
+ *                                         *
+ * This util was created by Marius Olbertz *
+ * Please thank Marius on GitHub /owlbertz *
+ * or the web http://www.mariusolbertz.de/ *
+ *                                         *
+ ******************************************/
+
+const keyCodes = {
+  9: 'TAB',
+  13: 'ENTER',
+  27: 'ESCAPE',
+  32: 'SPACE',
+  35: 'END',
+  36: 'HOME',
+  37: 'ARROW_LEFT',
+  38: 'ARROW_UP',
+  39: 'ARROW_RIGHT',
+  40: 'ARROW_DOWN'
+};
+
+var commands = {};
+
+// Functions pulled out to be referenceable from internals
+function findFocusable($element) {
+  if(!$element) {return false; }
+  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function() {
+    if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) { return false; } //only have visible elements and those that have a tabindex greater or equal 0
+    return true;
+  });
+}
+
+function parseKey(event) {
+  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();
+
+  // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events
+  key = key.replace(/\W+/, '');
+
+  if (event.shiftKey) key = `SHIFT_${key}`;
+  if (event.ctrlKey) key = `CTRL_${key}`;
+  if (event.altKey) key = `ALT_${key}`;
+
+  // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)
+  key = key.replace(/_$/, '');
+
+  return key;
+}
+
+var Keyboard = {
+  keys: getKeyCodes(keyCodes),
+
+  /**
+   * Parses the (keyboard) event and returns a String that represents its key
+   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
+   * @param {Event} event - the event generated by the event handler
+   * @return String key - String that represents the key pressed
+   */
+  parseKey: parseKey,
+
+  /**
+   * Handles the given (keyboard) event
+   * @param {Event} event - the event generated by the event handler
+   * @param {String} component - Foundation component's name, e.g. Slider or Reveal
+   * @param {Objects} functions - collection of functions that are to be executed
+   */
+  handleKey(event, component, functions) {
+    var commandList = commands[component],
+      keyCode = this.parseKey(event),
+      cmds,
+      command,
+      fn;
+
+    if (!commandList) return console.warn('Component not defined!');
+
+    if (typeof commandList.ltr === 'undefined') { // this component does not differentiate between ltr and rtl
+        cmds = commandList; // use plain list
+    } else { // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa
+        if (rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);
+
+        else cmds = $.extend({}, commandList.rtl, commandList.ltr);
+    }
+    command = cmds[keyCode];
+
+    fn = functions[command];
+    if (fn && typeof fn === 'function') { // execute function  if exists
+      var returnValue = fn.apply();
+      if (functions.handled || typeof functions.handled === 'function') { // execute function when event was handled
+          functions.handled(returnValue);
+      }
+    } else {
+      if (functions.unhandled || typeof functions.unhandled === 'function') { // execute function when event was not handled
+          functions.unhandled();
+      }
+    }
+  },
+
+  /**
+   * Finds all focusable elements within the given `$element`
+   * @param {jQuery} $element - jQuery object to search within
+   * @return {jQuery} $focusable - all focusable elements within `$element`
+   */
+
+  findFocusable: findFocusable,
+
+  /**
+   * Returns the component name name
+   * @param {Object} component - Foundation component, e.g. Slider or Reveal
+   * @return String componentName
+   */
+
+  register(componentName, cmds) {
+    commands[componentName] = cmds;
+  },
+
+
+  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?
+  //
+  /**
+   * Traps the focus in the given element.
+   * @param  {jQuery} $element  jQuery object to trap the foucs into.
+   */
+  trapFocus($element) {
+    var $focusable = findFocusable($element),
+        $firstFocusable = $focusable.eq(0),
+        $lastFocusable = $focusable.eq(-1);
+
+    $element.on('keydown.zf.trapfocus', function(event) {
+      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {
+        event.preventDefault();
+        $firstFocusable.focus();
+      }
+      else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {
+        event.preventDefault();
+        $lastFocusable.focus();
+      }
+    });
+  },
+  /**
+   * Releases the trapped focus from the given element.
+   * @param  {jQuery} $element  jQuery object to release the focus for.
+   */
+  releaseFocus($element) {
+    $element.off('keydown.zf.trapfocus');
+  }
+};
+
+/*
+ * Constants for easier comparing.
+ * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
+ */
+function getKeyCodes(kcs) {
+  var k = {};
+  for (var kc in kcs) k[kcs[kc]] = kcs[kc];
+  return k;
+}
+
+/**
+ * Motion module.
+ * @module foundation.motion
+ */
+
+const initClasses   = ['mui-enter', 'mui-leave'];
+const activeClasses = ['mui-enter-active', 'mui-leave-active'];
+
+const Motion = {
+  animateIn: function(element, animation, cb) {
+    animate(true, element, animation, cb);
+  },
+
+  animateOut: function(element, animation, cb) {
+    animate(false, element, animation, cb);
+  }
+};
+
+function Move(duration, elem, fn){
+  var anim, prog, start = null;
+  // console.log('called');
+
+  if (duration === 0) {
+    fn.apply(elem);
+    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
+    return;
+  }
+
+  function move(ts){
+    if(!start) start = ts;
+    // console.log(start, ts);
+    prog = ts - start;
+    fn.apply(elem);
+
+    if(prog < duration){ anim = window.requestAnimationFrame(move, elem); }
+    else{
+      window.cancelAnimationFrame(anim);
+      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
+    }
+  }
+  anim = window.requestAnimationFrame(move);
+}
+
+/**
+ * Animates an element in or out using a CSS transition class.
+ * @function
+ * @private
+ * @param {Boolean} isIn - Defines if the animation is in or out.
+ * @param {Object} element - jQuery or HTML object to animate.
+ * @param {String} animation - CSS class to use.
+ * @param {Function} cb - Callback to run when animation is finished.
+ */
+function animate(isIn, element, animation, cb) {
+  element = $(element).eq(0);
+
+  if (!element.length) return;
+
+  var initClass = isIn ? initClasses[0] : initClasses[1];
+  var activeClass = isIn ? activeClasses[0] : activeClasses[1];
+
+  // Set up the animation
+  reset();
+
+  element
+    .addClass(animation)
+    .css('transition', 'none');
+
+  requestAnimationFrame(() => {
+    element.addClass(initClass);
+    if (isIn) element.show();
+  });
+
+  // Start the animation
+  requestAnimationFrame(() => {
+    element[0].offsetWidth;
+    element
+      .css('transition', '')
+      .addClass(activeClass);
+  });
+
+  // Clean up the animation when it finishes
+  element.one(transitionend(element), finish);
+
+  // Hides the element (for out animations), resets the element, and runs a callback
+  function finish() {
+    if (!isIn) element.hide();
+    reset();
+    if (cb) cb.apply(element);
+  }
+
+  // Resets transitions and removes motion-specific classes
+  function reset() {
+    element[0].style.transitionDuration = 0;
+    element.removeClass(`${initClass} ${activeClass} ${animation}`);
+  }
+}
+
+const Nest = {
+  Feather(menu, type = 'zf') {
+    menu.attr('role', 'menubar');
+
+    var items = menu.find('li').attr({'role': 'menuitem'}),
+        subMenuClass = `is-${type}-submenu`,
+        subItemClass = `${subMenuClass}-item`,
+        hasSubClass = `is-${type}-submenu-parent`,
+        applyAria = (type !== 'accordion'); // Accordions handle their own ARIA attriutes.
+
+    items.each(function() {
+      var $item = $(this),
+          $sub = $item.children('ul');
+
+      if ($sub.length) {
+        $item.addClass(hasSubClass);
+        if(applyAria) {
+          $item.attr({
+            'aria-haspopup': true,
+            'aria-label': $item.children('a:first').text()
+          });
+          // Note:  Drilldowns behave differently in how they hide, and so need
+          // additional attributes.  We should look if this possibly over-generalized
+          // utility (Nest) is appropriate when we rework menus in 6.4
+          if(type === 'drilldown') {
+            $item.attr({'aria-expanded': false});
+          }
+        }
+        $sub
+          .addClass(`submenu ${subMenuClass}`)
+          .attr({
+            'data-submenu': '',
+            'role': 'menubar'
+          });
+        if(type === 'drilldown') {
+          $sub.attr({'aria-hidden': true});
+        }
+      }
+
+      if ($item.parent('[data-submenu]').length) {
+        $item.addClass(`is-submenu-item ${subItemClass}`);
+      }
+    });
+
+    return;
+  },
+
+  Burn(menu, type) {
+    var //items = menu.find('li'),
+        subMenuClass = `is-${type}-submenu`,
+        subItemClass = `${subMenuClass}-item`,
+        hasSubClass = `is-${type}-submenu-parent`;
+
+    menu
+      .find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li')
+      .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)
+      .removeAttr('data-submenu').css('display', '');
+
+  }
+};
+
+function Timer(elem, options, cb) {
+  var _this = this,
+      duration = options.duration,//options is an object for easily adding features later.
+      nameSpace = Object.keys(elem.data())[0] || 'timer',
+      remain = -1,
+      start,
+      timer;
+
+  this.isPaused = false;
+
+  this.restart = function() {
+    remain = -1;
+    clearTimeout(timer);
+    this.start();
+  };
+
+  this.start = function() {
+    this.isPaused = false;
+    // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+    clearTimeout(timer);
+    remain = remain <= 0 ? duration : remain;
+    elem.data('paused', false);
+    start = Date.now();
+    timer = setTimeout(function(){
+      if(options.infinite){
+        _this.restart();//rerun the timer.
+      }
+      if (cb && typeof cb === 'function') { cb(); }
+    }, remain);
+    elem.trigger(`timerstart.zf.${nameSpace}`);
+  };
+
+  this.pause = function() {
+    this.isPaused = true;
+    //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+    clearTimeout(timer);
+    elem.data('paused', true);
+    var end = Date.now();
+    remain = remain - (end - start);
+    elem.trigger(`timerpaused.zf.${nameSpace}`);
+  };
+}
+
+//**************************************************
+
+var Touch = {};
+
+var startPosX,
+    startPosY,
+    startTime,
+    elapsedTime,
+    startEvent,
+    isMoving = false,
+    didMoved = false;
+
+function onTouchEnd(e) {
+  this.removeEventListener('touchmove', onTouchMove);
+  this.removeEventListener('touchend', onTouchEnd);
+
+  // If the touch did not move, consider it as a "tap"
+  if (!didMoved) {
+    var tapEvent = $.Event('tap', startEvent || e);
+    $(this).trigger(tapEvent);
+  }
+
+  startEvent = null;
+  isMoving = false;
+  didMoved = false;
+}
+
+function onTouchMove(e) {
+  if ($.spotSwipe.preventDefault) { e.preventDefault(); }
+
+  if(isMoving) {
+    var x = e.touches[0].pageX;
+    var y = e.touches[0].pageY;
+    var dx = startPosX - x;
+    var dir;
+    didMoved = true;
+    elapsedTime = new Date().getTime() - startTime;
+    if(Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
+      dir = dx > 0 ? 'left' : 'right';
+    }
+    // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
+    //   dir = dy > 0 ? 'down' : 'up';
+    // }
+    if(dir) {
+      e.preventDefault();
+      onTouchEnd.apply(this, arguments);
+      $(this)
+        .trigger($.Event('swipe', e), dir)
+        .trigger($.Event(`swipe${dir}`, e));
+    }
+  }
+
+}
+
+function onTouchStart(e) {
+
+  if (e.touches.length == 1) {
+    startPosX = e.touches[0].pageX;
+    startPosY = e.touches[0].pageY;
+    startEvent = e;
+    isMoving = true;
+    didMoved = false;
+    startTime = new Date().getTime();
+    this.addEventListener('touchmove', onTouchMove, false);
+    this.addEventListener('touchend', onTouchEnd, false);
+  }
+}
+
+function init() {
+  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);
+}
+
+class SpotSwipe {
+  constructor($$$1) {
+    this.version = '1.0.0';
+    this.enabled = 'ontouchstart' in document.documentElement;
+    this.preventDefault = false;
+    this.moveThreshold = 75;
+    this.timeThreshold = 200;
+    this.$ = $$$1;
+    this._init();
+  }
+
+  _init() {
+    var $$$1 = this.$;
+    $$$1.event.special.swipe = { setup: init };
+    $$$1.event.special.tap = { setup: init };
+
+    $$$1.each(['left', 'up', 'down', 'right'], function () {
+      $$$1.event.special[`swipe${this}`] = { setup: function(){
+        $$$1(this).on('swipe', $$$1.noop);
+      } };
+    });
+  }
+}
+
+/****************************************************
+ * As far as I can tell, both setupSpotSwipe and    *
+ * setupTouchHandler should be idempotent,          *
+ * because they directly replace functions &        *
+ * values, and do not add event handlers directly.  *
+ ****************************************************/
+
+Touch.setupSpotSwipe = function($$$1) {
+  $$$1.spotSwipe = new SpotSwipe($$$1);
+};
+
+/****************************************************
+ * Method for adding pseudo drag events to elements *
+ ***************************************************/
+Touch.setupTouchHandler = function($$$1) {
+  $$$1.fn.addTouch = function(){
+    this.each(function(i,el){
+      $$$1(el).bind('touchstart touchmove touchend touchcancel', function(event)  {
+        //we pass the original event object because the jQuery event
+        //object is normalized to w3c specs and does not provide the TouchList
+        handleTouch(event);
+      });
+    });
+
+    var handleTouch = function(event){
+      var touches = event.changedTouches,
+          first = touches[0],
+          eventTypes = {
+            touchstart: 'mousedown',
+            touchmove: 'mousemove',
+            touchend: 'mouseup'
+          },
+          type = eventTypes[event.type],
+          simulatedEvent
+        ;
+
+      if('MouseEvent' in window && typeof window.MouseEvent === 'function') {
+        simulatedEvent = new window.MouseEvent(type, {
+          'bubbles': true,
+          'cancelable': true,
+          'screenX': first.screenX,
+          'screenY': first.screenY,
+          'clientX': first.clientX,
+          'clientY': first.clientY
+        });
+      } else {
+        simulatedEvent = document.createEvent('MouseEvent');
+        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0/*left*/, null);
+      }
+      first.target.dispatchEvent(simulatedEvent);
+    };
+  };
+};
+
+Touch.init = function ($$$1) {
+
+  if(typeof($$$1.spotSwipe) === 'undefined') {
+    Touch.setupSpotSwipe($$$1);
+    Touch.setupTouchHandler($$$1);
+  }
+};
+
+const MutationObserver = (function () {
+  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+  for (var i=0; i < prefixes.length; i++) {
+    if (`${prefixes[i]}MutationObserver` in window) {
+      return window[`${prefixes[i]}MutationObserver`];
+    }
+  }
+  return false;
+}());
+
+const triggers = (el, type) => {
+  el.data(type).split(' ').forEach(id => {
+    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);
+  });
+};
+
+var Triggers = {
+  Listeners: {
+    Basic: {},
+    Global: {}
+  },
+  Initializers: {}
+};
+
+Triggers.Listeners.Basic  = {
+  openListener: function() {
+    triggers($(this), 'open');
+  },
+  closeListener: function() {
+    let id = $(this).data('close');
+    if (id) {
+      triggers($(this), 'close');
+    }
+    else {
+      $(this).trigger('close.zf.trigger');
+    }
+  },
+  toggleListener: function() {
+    let id = $(this).data('toggle');
+    if (id) {
+      triggers($(this), 'toggle');
+    } else {
+      $(this).trigger('toggle.zf.trigger');
+    }
+  },
+  closeableListener: function(e) {
+    e.stopPropagation();
+    let animation = $(this).data('closable');
+
+    if(animation !== ''){
+      Motion.animateOut($(this), animation, function() {
+        $(this).trigger('closed.zf');
+      });
+    }else{
+      $(this).fadeOut().trigger('closed.zf');
+    }
+  },
+  toggleFocusListener: function() {
+    let id = $(this).data('toggle-focus');
+    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);
+  }
+};
+
+// Elements with [data-open] will reveal a plugin that supports it when clicked.
+Triggers.Initializers.addOpenListener = ($elem) => {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
+  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
+};
+
+// Elements with [data-close] will close a plugin that supports it when clicked.
+// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+Triggers.Initializers.addCloseListener = ($elem) => {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
+  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
+};
+
+// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+Triggers.Initializers.addToggleListener = ($elem) => {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
+  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
+};
+
+// Elements with [data-closable] will respond to close.zf.trigger events.
+Triggers.Initializers.addCloseableListener = ($elem) => {
+  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
+  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
+};
+
+// Elements with [data-toggle-focus] will respond to coming in and out of focus
+Triggers.Initializers.addToggleFocusListener = ($elem) => {
+  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
+  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
+};
+
+
+
+// More Global/complex listeners and triggers
+Triggers.Listeners.Global  = {
+  resizeListener: function($nodes) {
+    if(!MutationObserver){//fallback for IE 9
+      $nodes.each(function(){
+        $(this).triggerHandler('resizeme.zf.trigger');
+      });
+    }
+    //trigger all listening elements and signal a resize event
+    $nodes.attr('data-events', "resize");
+  },
+  scrollListener: function($nodes) {
+    if(!MutationObserver){//fallback for IE 9
+      $nodes.each(function(){
+        $(this).triggerHandler('scrollme.zf.trigger');
+      });
+    }
+    //trigger all listening elements and signal a scroll event
+    $nodes.attr('data-events', "scroll");
+  },
+  closeMeListener: function(e, pluginId){
+    let plugin = e.namespace.split('.')[0];
+    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box="${pluginId}"]`);
+
+    plugins.each(function(){
+      let _this = $(this);
+      _this.triggerHandler('close.zf.trigger', [_this]);
+    });
+  }
+};
+
+// Global, parses whole document.
+Triggers.Initializers.addClosemeListener = function(pluginName) {
+  var yetiBoxes = $('[data-yeti-box]'),
+      plugNames = ['dropdown', 'tooltip', 'reveal'];
+
+  if(pluginName){
+    if(typeof pluginName === 'string'){
+      plugNames.push(pluginName);
+    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){
+      plugNames = plugNames.concat(pluginName);
+    }else{
+      console.error('Plugin names must be strings');
+    }
+  }
+  if(yetiBoxes.length){
+    let listeners = plugNames.map((name) => {
+      return `closeme.zf.${name}`;
+    }).join(' ');
+
+    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+  }
+};
+
+function debounceGlobalListener(debounce, trigger, listener) {
+  let timer, args = Array.prototype.slice.call(arguments, 3);
+  $(window).off(trigger).on(trigger, function(e) {
+    if (timer) { clearTimeout(timer); }
+    timer = setTimeout(function(){
+      listener.apply(null, args);
+    }, debounce || 10);//default time to emit scroll event
+  });
+}
+
+Triggers.Initializers.addResizeListener = function(debounce){
+  let $nodes = $('[data-resize]');
+  if($nodes.length){
+    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
+  }
+};
+
+Triggers.Initializers.addScrollListener = function(debounce){
+  let $nodes = $('[data-scroll]');
+  if($nodes.length){
+    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
+  }
+};
+
+Triggers.Initializers.addMutationEventsListener = function($elem) {
+  if(!MutationObserver){ return false; }
+  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
+
+  //element callback
+  var listeningElementsMutation = function (mutationRecordsList) {
+    var $target = $(mutationRecordsList[0].target);
+
+    //trigger the event handler for the element depending on type
+    switch (mutationRecordsList[0].type) {
+      case "attributes":
+        if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
+          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
+        }
+        if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
+          $target.triggerHandler('resizeme.zf.trigger', [$target]);
+         }
+        if (mutationRecordsList[0].attributeName === "style") {
+          $target.closest("[data-mutate]").attr("data-events","mutate");
+          $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+        }
+        break;
+
+      case "childList":
+        $target.closest("[data-mutate]").attr("data-events","mutate");
+        $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+        break;
+
+      default:
+        return false;
+      //nothing
+    }
+  };
+
+  if ($nodes.length) {
+    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
+    for (var i = 0; i <= $nodes.length - 1; i++) {
+      var elementObserver = new MutationObserver(listeningElementsMutation);
+      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+    }
+  }
+};
+
+Triggers.Initializers.addSimpleListeners = function() {
+  let $document = $(document);
+
+  Triggers.Initializers.addOpenListener($document);
+  Triggers.Initializers.addCloseListener($document);
+  Triggers.Initializers.addToggleListener($document);
+  Triggers.Initializers.addCloseableListener($document);
+  Triggers.Initializers.addToggleFocusListener($document);
+
+};
+
+Triggers.Initializers.addGlobalListeners = function() {
+  let $document = $(document);
+  Triggers.Initializers.addMutationEventsListener($document);
+  Triggers.Initializers.addResizeListener();
+  Triggers.Initializers.addScrollListener();
+  Triggers.Initializers.addClosemeListener();
+};
+
+
+Triggers.init = function ($$$1, Foundation) {
+  onLoad($$$1(window), function () {
+    if ($$$1.triggersInitialized !== true) {
+      Triggers.Initializers.addSimpleListeners();
+      Triggers.Initializers.addGlobalListeners();
+      $$$1.triggersInitialized = true;
+    }
+  });
+
+  if(Foundation) {
+    Foundation.Triggers = Triggers;
+    // Legacy included to be backwards compatible for now.
+    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
+  }
+};
+
+// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST
+// {function} _setup (replaces previous constructor),
+// {function} _destroy (replaces previous destroy)
+class Plugin {
+
+  constructor(element, options) {
+    this._setup(element, options);
+    var pluginName = getPluginName(this);
+    this.uuid = GetYoDigits(6, pluginName);
+
+    if(!this.$element.attr(`data-${pluginName}`)){ this.$element.attr(`data-${pluginName}`, this.uuid); }
+    if(!this.$element.data('zfPlugin')){ this.$element.data('zfPlugin', this); }
+    /**
+     * Fires when the plugin has initialized.
+     * @event Plugin#init
+     */
+    this.$element.trigger(`init.zf.${pluginName}`);
+  }
+
+  destroy() {
+    this._destroy();
+    var pluginName = getPluginName(this);
+    this.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')
+        /**
+         * Fires when the plugin has been destroyed.
+         * @event Plugin#destroyed
+         */
+        .trigger(`destroyed.zf.${pluginName}`);
+    for(var prop in this){
+      this[prop] = null;//clean up script to prep for garbage collection.
+    }
+  }
+}
+
+// Convert PascalCase to kebab-case
+// Thank you: http://stackoverflow.com/a/8955580
+function hyphenate$1(str) {
+  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
+}
+
+function getPluginName(obj) {
+  if(typeof(obj.constructor.name) !== 'undefined') {
+    return hyphenate$1(obj.constructor.name);
+  } else {
+    return hyphenate$1(obj.className);
+  }
+}
+
+/**
+ * Abide module.
+ * @module foundation.abide
+ */
+
+class Abide extends Plugin {
+  /**
+   * Creates a new instance of Abide.
+   * @class
+   * @name Abide
+   * @fires Abide#init
+   * @param {Object} element - jQuery object to add the trigger to.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options = {}) {
+    this.$element = element;
+    this.options  = $.extend(true, {}, Abide.defaults, this.$element.data(), options);
+
+    this.className = 'Abide'; // ie9 back compat
+    this._init();
+  }
+
+  /**
+   * Initializes the Abide plugin and calls functions to get Abide functioning on load.
+   * @private
+   */
+  _init() {
+    this.$inputs = $.merge(                               // Consider as input to validate:
+      this.$element.find('input').not('[type=submit]'),   // * all input fields expect submit
+      this.$element.find('textarea, select')              // * all textareas and select fields
+    );
+    const $globalErrors = this.$element.find('[data-abide-error]');
+
+    // Add a11y attributes to all fields
+    if (this.options.a11yAttributes) {
+      this.$inputs.each((i, input) => this.addA11yAttributes($(input)));
+      $globalErrors.each((i, error) => this.addGlobalErrorA11yAttributes($(error)));
+    }
+
+    this._events();
+  }
+
+  /**
+   * Initializes events for Abide.
+   * @private
+   */
+  _events() {
+    this.$element.off('.abide')
+      .on('reset.zf.abide', () => {
+        this.resetForm();
+      })
+      .on('submit.zf.abide', () => {
+        return this.validateForm();
+      });
+
+    if (this.options.validateOn === 'fieldChange') {
+      this.$inputs
+        .off('change.zf.abide')
+        .on('change.zf.abide', (e) => {
+          this.validateInput($(e.target));
+        });
+    }
+
+    if (this.options.liveValidate) {
+      this.$inputs
+        .off('input.zf.abide')
+        .on('input.zf.abide', (e) => {
+          this.validateInput($(e.target));
+        });
+    }
+
+    if (this.options.validateOnBlur) {
+      this.$inputs
+        .off('blur.zf.abide')
+        .on('blur.zf.abide', (e) => {
+          this.validateInput($(e.target));
+        });
+    }
+  }
+
+  /**
+   * Calls necessary functions to update Abide upon DOM change
+   * @private
+   */
+  _reflow() {
+    this._init();
+  }
+
+  /**
+   * Checks whether or not a form element has the required attribute and if it's checked or not
+   * @param {Object} element - jQuery object to check for required attribute
+   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+   */
+  requiredCheck($el) {
+    if (!$el.attr('required')) return true;
+
+    var isGood = true;
+
+    switch ($el[0].type) {
+      case 'checkbox':
+        isGood = $el[0].checked;
+        break;
+
+      case 'select':
+      case 'select-one':
+      case 'select-multiple':
+        var opt = $el.find('option:selected');
+        if (!opt.length || !opt.val()) isGood = false;
+        break;
+
+      default:
+        if(!$el.val() || !$el.val().length) isGood = false;
+    }
+
+    return isGood;
+  }
+
+  /**
+   * Get:
+   * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:
+   *   1. The element's direct sibling('s).
+   *   2. The element's parent's children.
+   * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.
+   *
+   * This allows for multiple form errors per input, though if none are found, no form errors will be shown.
+   *
+   * @param {Object} $el - jQuery object to use as reference to find the form error selector.
+   * @returns {Object} jQuery object with the selector.
+   */
+  findFormError($el) {
+    var id = $el[0].id;
+    var $error = $el.siblings(this.options.formErrorSelector);
+
+    if (!$error.length) {
+      $error = $el.parent().find(this.options.formErrorSelector);
+    }
+
+    if (id) {
+      $error = $error.add(this.$element.find(`[data-form-error-for="${id}"]`));
+    }
+
+    return $error;
+  }
+
+  /**
+   * Get the first element in this order:
+   * 2. The <label> with the attribute `[for="someInputId"]`
+   * 3. The `.closest()` <label>
+   *
+   * @param {Object} $el - jQuery object to check for required attribute
+   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+   */
+  findLabel($el) {
+    var id = $el[0].id;
+    var $label = this.$element.find(`label[for="${id}"]`);
+
+    if (!$label.length) {
+      return $el.closest('label');
+    }
+
+    return $label;
+  }
+
+  /**
+   * Get the set of labels associated with a set of radio els in this order
+   * 2. The <label> with the attribute `[for="someInputId"]`
+   * 3. The `.closest()` <label>
+   *
+   * @param {Object} $el - jQuery object to check for required attribute
+   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+   */
+  findRadioLabels($els) {
+    var labels = $els.map((i, el) => {
+      var id = el.id;
+      var $label = this.$element.find(`label[for="${id}"]`);
+
+      if (!$label.length) {
+        $label = $(el).closest('label');
+      }
+      return $label[0];
+    });
+
+    return $(labels);
+  }
+
+  /**
+   * Adds the CSS error class as specified by the Abide settings to the label, input, and the form
+   * @param {Object} $el - jQuery object to add the class to
+   */
+  addErrorClasses($el) {
+    var $label = this.findLabel($el);
+    var $formError = this.findFormError($el);
+
+    if ($label.length) {
+      $label.addClass(this.options.labelErrorClass);
+    }
+
+    if ($formError.length) {
+      $formError.addClass(this.options.formErrorClass);
+    }
+
+    $el.addClass(this.options.inputErrorClass).attr({
+      'data-invalid': '',
+      'aria-invalid': true
+    });
+  }
+
+  /**
+   * Adds [for] and [role=alert] attributes to all form error targetting $el,
+   * and [aria-describedby] attribute to $el toward the first form error.
+   * @param {Object} $el - jQuery object
+   */
+  addA11yAttributes($el) {
+    let $errors = this.findFormError($el);
+    let $labels = $errors.filter('label');
+    let $error = $errors.first();
+    if (!$errors.length) return;
+
+    // Set [aria-describedby] on the input toward the first form error if it is not set
+    if (typeof $el.attr('aria-describedby') === 'undefined') {
+      // Get the first error ID or create one
+      let errorId = $error.attr('id');
+      if (typeof errorId === 'undefined') {
+        errorId = GetYoDigits(6, 'abide-error');
+        $error.attr('id', errorId);
+      }
+      $el.attr('aria-describedby', errorId);
+    }
+
+    if ($labels.filter('[for]').length < $labels.length) {
+      // Get the input ID or create one
+      let elemId = $el.attr('id');
+      if (typeof elemId === 'undefined') {
+        elemId = GetYoDigits(6, 'abide-input');
+        $el.attr('id', elemId);
+      }
+      // For each label targeting $el, set [for] if it is not set.
+      $labels.each((i, label) => {
+        const $label = $(label);
+        if (typeof $label.attr('for') === 'undefined')
+          $label.attr('for', elemId);
+      });
+    }
+
+    // For each error targeting $el, set [role=alert] if it is not set.
+    $errors.each((i, label) => {
+      const $label = $(label);
+      if (typeof $label.attr('role') === 'undefined')
+        $label.attr('role', 'alert');
+    }).end();
+  }
+
+  /**
+   * Adds [aria-live] attribute to the given global form error $el.
+   * @param {Object} $el - jQuery object to add the attribute to
+   */
+  addGlobalErrorA11yAttributes($el) {
+    if (typeof $el.attr('aria-live') === 'undefined')
+      $el.attr('aria-live', this.options.a11yErrorLevel);
+  }
+
+  /**
+   * Remove CSS error classes etc from an entire radio button group
+   * @param {String} groupName - A string that specifies the name of a radio button group
+   *
+   */
+  removeRadioErrorClasses(groupName) {
+    var $els = this.$element.find(`:radio[name="${groupName}"]`);
+    var $labels = this.findRadioLabels($els);
+    var $formErrors = this.findFormError($els);
+
+    if ($labels.length) {
+      $labels.removeClass(this.options.labelErrorClass);
+    }
+
+    if ($formErrors.length) {
+      $formErrors.removeClass(this.options.formErrorClass);
+    }
+
+    $els.removeClass(this.options.inputErrorClass).attr({
+      'data-invalid': null,
+      'aria-invalid': null
+    });
+
+  }
+
+  /**
+   * Removes CSS error class as specified by the Abide settings from the label, input, and the form
+   * @param {Object} $el - jQuery object to remove the class from
+   */
+  removeErrorClasses($el) {
+    // radios need to clear all of the els
+    if($el[0].type == 'radio') {
+      return this.removeRadioErrorClasses($el.attr('name'));
+    }
+
+    var $label = this.findLabel($el);
+    var $formError = this.findFormError($el);
+
+    if ($label.length) {
+      $label.removeClass(this.options.labelErrorClass);
+    }
+
+    if ($formError.length) {
+      $formError.removeClass(this.options.formErrorClass);
+    }
+
+    $el.removeClass(this.options.inputErrorClass).attr({
+      'data-invalid': null,
+      'aria-invalid': null
+    });
+  }
+
+  /**
+   * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.
+   * Ignores inputs with data-abide-ignore, type="hidden" or disabled attributes set
+   * @fires Abide#invalid
+   * @fires Abide#valid
+   * @param {Object} element - jQuery object to validate, should be an HTML input
+   * @returns {Boolean} goodToGo - If the input is valid or not.
+   */
+  validateInput($el) {
+    var clearRequire = this.requiredCheck($el),
+        validated = false,
+        customValidator = true,
+        validator = $el.attr('data-validator'),
+        equalTo = true;
+
+    // don't validate ignored inputs or hidden inputs or disabled inputs
+    if ($el.is('[data-abide-ignore]') || $el.is('[type="hidden"]') || $el.is('[disabled]')) {
+      return true;
+    }
+
+    switch ($el[0].type) {
+      case 'radio':
+        validated = this.validateRadio($el.attr('name'));
+        break;
+
+      case 'checkbox':
+        validated = clearRequire;
+        break;
+
+      case 'select':
+      case 'select-one':
+      case 'select-multiple':
+        validated = clearRequire;
+        break;
+
+      default:
+        validated = this.validateText($el);
+    }
+
+    if (validator) {
+      customValidator = this.matchValidation($el, validator, $el.attr('required'));
+    }
+
+    if ($el.attr('data-equalto')) {
+      equalTo = this.options.validators.equalTo($el);
+    }
+
+
+    var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;
+    var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';
+
+    if (goodToGo) {
+      // Re-validate inputs that depend on this one with equalto
+      const dependentElements = this.$element.find(`[data-equalto="${$el.attr('id')}"]`);
+      if (dependentElements.length) {
+        let _this = this;
+        dependentElements.each(function() {
+          if ($(this).val()) {
+            _this.validateInput($(this));
+          }
+        });
+      }
+    }
+
+    this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);
+
+    /**
+     * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`
+     * Trigger includes the DOM element of the input.
+     * @event Abide#valid
+     * @event Abide#invalid
+     */
+    $el.trigger(message, [$el]);
+
+    return goodToGo;
+  }
+
+  /**
+   * Goes through a form and if there are any invalid inputs, it will display the form error element
+   * @returns {Boolean} noError - true if no errors were detected...
+   * @fires Abide#formvalid
+   * @fires Abide#forminvalid
+   */
+  validateForm() {
+    var acc = [];
+    var _this = this;
+
+    this.$inputs.each(function() {
+      acc.push(_this.validateInput($(this)));
+    });
+
+    var noError = acc.indexOf(false) === -1;
+
+    this.$element.find('[data-abide-error]').each((i, elem) => {
+      const $elem = $(elem);
+      // Ensure a11y attributes are set
+      if (this.options.a11yAttributes) this.addGlobalErrorA11yAttributes($elem);
+      // Show or hide the error
+      $elem.css('display', (noError ? 'none' : 'block'));
+    });
+
+    /**
+     * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.
+     * Trigger includes the element of the form.
+     * @event Abide#formvalid
+     * @event Abide#forminvalid
+     */
+    this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);
+
+    return noError;
+  }
+
+  /**
+   * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.
+   * @param {Object} $el - jQuery object to validate, should be a text input HTML element
+   * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns
+   * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified
+   */
+  validateText($el, pattern) {
+    // A pattern can be passed to this function, or it will be infered from the input's "pattern" attribute, or it's "type" attribute
+    pattern = (pattern || $el.attr('pattern') || $el.attr('type'));
+    var inputText = $el.val();
+    var valid = false;
+
+    if (inputText.length) {
+      // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp
+      if (this.options.patterns.hasOwnProperty(pattern)) {
+        valid = this.options.patterns[pattern].test(inputText);
+      }
+      // If the pattern name isn't also the type attribute of the field, then test it as a regexp
+      else if (pattern !== $el.attr('type')) {
+        valid = new RegExp(pattern).test(inputText);
+      }
+      else {
+        valid = true;
+      }
+    }
+    // An empty field is valid if it's not required
+    else if (!$el.prop('required')) {
+      valid = true;
+    }
+
+    return valid;
+   }
+
+  /**
+   * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.
+   * @param {String} groupName - A string that specifies the name of a radio button group
+   * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)
+   */
+  validateRadio(groupName) {
+    // If at least one radio in the group has the `required` attribute, the group is considered required
+    // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice
+    var $group = this.$element.find(`:radio[name="${groupName}"]`);
+    var valid = false, required = false;
+
+    // For the group to be required, at least one radio needs to be required
+    $group.each((i, e) => {
+      if ($(e).attr('required')) {
+        required = true;
+      }
+    });
+    if(!required) valid=true;
+
+    if (!valid) {
+      // For the group to be valid, at least one radio needs to be checked
+      $group.each((i, e) => {
+        if ($(e).prop('checked')) {
+          valid = true;
+        }
+      });
+    }
+    return valid;
+  }
+
+  /**
+   * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator="foo bar baz"` in a space separated listed.
+   * @param {Object} $el - jQuery input element.
+   * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.
+   * @param {Boolean} required - self explanatory?
+   * @returns {Boolean} - true if validations passed.
+   */
+  matchValidation($el, validators, required) {
+    required = required ? true : false;
+
+    var clear = validators.split(' ').map((v) => {
+      return this.options.validators[v]($el, required, $el.parent());
+    });
+    return clear.indexOf(false) === -1;
+  }
+
+  /**
+   * Resets form inputs and styles
+   * @fires Abide#formreset
+   */
+  resetForm() {
+    var $form = this.$element,
+        opts = this.options;
+
+    $(`.${opts.labelErrorClass}`, $form).not('small').removeClass(opts.labelErrorClass);
+    $(`.${opts.inputErrorClass}`, $form).not('small').removeClass(opts.inputErrorClass);
+    $(`${opts.formErrorSelector}.${opts.formErrorClass}`).removeClass(opts.formErrorClass);
+    $form.find('[data-abide-error]').css('display', 'none');
+    $(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({
+      'data-invalid': null,
+      'aria-invalid': null
+    });
+    $(':input:radio', $form).not('[data-abide-ignore]').prop('checked',false).attr({
+      'data-invalid': null,
+      'aria-invalid': null
+    });
+    $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked',false).attr({
+      'data-invalid': null,
+      'aria-invalid': null
+    });
+    /**
+     * Fires when the form has been reset.
+     * @event Abide#formreset
+     */
+    $form.trigger('formreset.zf.abide', [$form]);
+  }
+
+  /**
+   * Destroys an instance of Abide.
+   * Removes error styles and classes from elements, without resetting their values.
+   */
+  _destroy() {
+    var _this = this;
+    this.$element
+      .off('.abide')
+      .find('[data-abide-error]')
+        .css('display', 'none');
+
+    this.$inputs
+      .off('.abide')
+      .each(function() {
+        _this.removeErrorClasses($(this));
+      });
+  }
+}
+
+/**
+ * Default settings for plugin
+ */
+Abide.defaults = {
+  /**
+   * The default event to validate inputs. Checkboxes and radios validate immediately.
+   * Remove or change this value for manual validation.
+   * @option
+   * @type {?string}
+   * @default 'fieldChange'
+   */
+  validateOn: 'fieldChange',
+
+  /**
+   * Class to be applied to input labels on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-invalid-label'
+   */
+  labelErrorClass: 'is-invalid-label',
+
+  /**
+   * Class to be applied to inputs on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-invalid-input'
+   */
+  inputErrorClass: 'is-invalid-input',
+
+  /**
+   * Class selector to use to target Form Errors for show/hide.
+   * @option
+   * @type {string}
+   * @default '.form-error'
+   */
+  formErrorSelector: '.form-error',
+
+  /**
+   * Class added to Form Errors on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-visible'
+   */
+  formErrorClass: 'is-visible',
+
+  /**
+   * If true, automatically insert when possible:
+   * - `[aria-describedby]` on fields
+   * - `[role=alert]` on form errors and `[for]` on form error labels
+   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  a11yAttributes: true,
+
+  /**
+   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.
+   * Options are: 'assertive', 'polite' and 'off'/null
+   * @option
+   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions
+   * @type {string}
+   * @default 'assertive'
+   */
+  a11yErrorLevel: 'assertive',
+
+  /**
+   * Set to true to validate text inputs on any value change.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  liveValidate: false,
+
+  /**
+   * Set to true to validate inputs on blur.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  validateOnBlur: false,
+
+  patterns: {
+    alpha : /^[a-zA-Z]+$/,
+    alpha_numeric : /^[a-zA-Z0-9]+$/,
+    integer : /^[-+]?\d+$/,
+    number : /^[-+]?\d*(?:[\.\,]\d+)?$/,
+
+    // amex, visa, diners
+    card : /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,
+    cvv : /^([0-9]){3,4}$/,
+
+    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address
+    email : /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,
+
+    // From CommonRegexJS (@talyssonoc)
+    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76
+    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.
+    url: /^((?:(https?|ftps?|file|ssh|sftp):\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\))+(?:\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?\xab\xbb\u201c\u201d\u2018\u2019]))$/,
+
+    // abc.de
+    domain : /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,
+
+    datetime : /^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,
+    // YYYY-MM-DD
+    date : /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,
+    // HH:MM:SS
+    time : /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,
+    dateISO : /^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,
+    // MM/DD/YYYY
+    month_day_year : /^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,
+    // DD/MM/YYYY
+    day_month_year : /^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,
+
+    // #FFF or #FFFFFF
+    color : /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,
+
+    // Domain || URL
+    website: {
+      test: (text) => {
+        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);
+      }
+    }
+  },
+
+  /**
+   * Optional validation functions to be used. `equalTo` being the only default included function.
+   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:
+   * el : The jQuery element to validate.
+   * required : Boolean value of the required attribute be present or not.
+   * parent : The direct parent of the input.
+   * @option
+   */
+  validators: {
+    equalTo: function (el, required, parent) {
+      return $(`#${el.attr('data-equalto')}`).val() === el.val();
+    }
+  }
+};
+
+/**
+ * Accordion module.
+ * @module foundation.accordion
+ * @requires foundation.util.keyboard
+ */
+
+class Accordion extends Plugin {
+  /**
+   * Creates a new instance of an accordion.
+   * @class
+   * @name Accordion
+   * @fires Accordion#init
+   * @param {jQuery} element - jQuery object to make into an accordion.
+   * @param {Object} options - a plain object with settings to override the default options.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);
+
+    this.className = 'Accordion'; // ie9 back compat
+    this._init();
+
+    Keyboard.register('Accordion', {
+      'ENTER': 'toggle',
+      'SPACE': 'toggle',
+      'ARROW_DOWN': 'next',
+      'ARROW_UP': 'previous'
+    });
+  }
+
+  /**
+   * Initializes the accordion by animating the preset active pane(s).
+   * @private
+   */
+  _init() {
+    this._isInitializing = true;
+
+    this.$element.attr('role', 'tablist');
+    this.$tabs = this.$element.children('[data-accordion-item]');
+
+    this.$tabs.each(function(idx, el) {
+      var $el = $(el),
+          $content = $el.children('[data-tab-content]'),
+          id = $content[0].id || GetYoDigits(6, 'accordion'),
+          linkId = (el.id) ? `${el.id}-label` : `${id}-label`;
+
+      $el.find('a:first').attr({
+        'aria-controls': id,
+        'role': 'tab',
+        'id': linkId,
+        'aria-expanded': false,
+        'aria-selected': false
+      });
+
+      $content.attr({'role': 'tabpanel', 'aria-labelledby': linkId, 'aria-hidden': true, 'id': id});
+    });
+
+    var $initActive = this.$element.find('.is-active').children('[data-tab-content]');
+    if ($initActive.length) {
+      // Save up the initial hash to return to it later when going back in history
+      this._initialAnchor = $initActive.prev('a').attr('href');
+      this._openSingleTab($initActive);
+    }
+
+    this._checkDeepLink = () => {
+      var anchor = window.location.hash;
+
+      if (!anchor.length) {
+        // If we are still initializing and there is no anchor, then there is nothing to do
+        if (this._isInitializing) return;
+        // Otherwise, move to the initial anchor
+        if (this._initialAnchor) anchor = this._initialAnchor;
+      }
+
+      var $anchor = anchor && $(anchor);
+      var $link = anchor && this.$element.find(`[href$="${anchor}"]`);
+      // Whether the anchor element that has been found is part of this element
+      var isOwnAnchor = !!($anchor.length && $link.length);
+
+      // If there is an anchor for the hash, open it (if not already active)
+      if ($anchor && $link && $link.length) {
+        if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {
+          this._openSingleTab($anchor);
+        }      }
+      // Otherwise, close everything
+      else {
+        this._closeAllTabs();
+      }
+
+      if (isOwnAnchor) {
+        // Roll up a little to show the titles
+        if (this.options.deepLinkSmudge) {
+          onLoad($(window), () => {
+            var offset = this.$element.offset();
+            $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);
+          });
+        }
+
+        /**
+         * Fires when the plugin has deeplinked at pageload
+         * @event Accordion#deeplink
+         */
+        this.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);
+      }
+    };
+
+    //use browser to open a tab, if it exists in this tabset
+    if (this.options.deepLink) {
+      this._checkDeepLink();
+    }
+
+    this._events();
+
+    this._isInitializing = false;
+  }
+
+  /**
+   * Adds event handlers for items within the accordion.
+   * @private
+   */
+  _events() {
+    var _this = this;
+
+    this.$tabs.each(function() {
+      var $elem = $(this);
+      var $tabContent = $elem.children('[data-tab-content]');
+      if ($tabContent.length) {
+        $elem.children('a').off('click.zf.accordion keydown.zf.accordion')
+               .on('click.zf.accordion', function(e) {
+          e.preventDefault();
+          _this.toggle($tabContent);
+        }).on('keydown.zf.accordion', function(e){
+          Keyboard.handleKey(e, 'Accordion', {
+            toggle: function() {
+              _this.toggle($tabContent);
+            },
+            next: function() {
+              var $a = $elem.next().find('a').focus();
+              if (!_this.options.multiExpand) {
+                $a.trigger('click.zf.accordion');
+              }
+            },
+            previous: function() {
+              var $a = $elem.prev().find('a').focus();
+              if (!_this.options.multiExpand) {
+                $a.trigger('click.zf.accordion');
+              }
+            },
+            handled: function() {
+              e.preventDefault();
+              e.stopPropagation();
+            }
+          });
+        });
+      }
+    });
+    if(this.options.deepLink) {
+      $(window).on('hashchange', this._checkDeepLink);
+    }
+  }
+
+  /**
+   * Toggles the selected content pane's open/close state.
+   * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).
+   * @function
+   */
+  toggle($target) {
+    if ($target.closest('[data-accordion]').is('[disabled]')) {
+      console.info('Cannot toggle an accordion that is disabled.');
+      return;
+    }
+    if($target.parent().hasClass('is-active')) {
+      this.up($target);
+    } else {
+      this.down($target);
+    }
+    //either replace or update browser history
+    if (this.options.deepLink) {
+      var anchor = $target.prev('a').attr('href');
+
+      if (this.options.updateHistory) {
+        history.pushState({}, '', anchor);
+      } else {
+        history.replaceState({}, '', anchor);
+      }
+    }
+  }
+
+  /**
+   * Opens the accordion tab defined by `$target`.
+   * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).
+   * @fires Accordion#down
+   * @function
+   */
+  down($target) {
+    if ($target.closest('[data-accordion]').is('[disabled]'))  {
+      console.info('Cannot call down on an accordion that is disabled.');
+      return;
+    }
+
+    if (this.options.multiExpand)
+      this._openTab($target);
+    else
+      this._openSingleTab($target);
+  }
+
+  /**
+   * Closes the tab defined by `$target`.
+   * It may be ignored if the Accordion options don't allow it.
+   *
+   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+   * @fires Accordion#up
+   * @function
+   */
+  up($target) {
+    if (this.$element.is('[disabled]')) {
+      console.info('Cannot call up on an accordion that is disabled.');
+      return;
+    }
+
+    // Don't close the item if it is already closed
+    const $targetItem = $target.parent();
+    if (!$targetItem.hasClass('is-active')) return;
+
+    // Don't close the item if there is no other active item (unless with `allowAllClosed`)
+    const $othersItems = $targetItem.siblings();
+    if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;
+
+    this._closeTab($target);
+  }
+
+  /**
+   * Make the tab defined by `$target` the only opened tab, closing all others tabs.
+   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+   * @function
+   * @private
+   */
+  _openSingleTab($target) {
+    // Close all the others active tabs.
+    const $activeContents = this.$element.children('.is-active').children('[data-tab-content]');
+    if ($activeContents.length) {
+      this._closeTab($activeContents.not($target));
+    }
+
+    // Then open the target.
+    this._openTab($target);
+  }
+
+  /**
+   * Opens the tab defined by `$target`.
+   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+   * @fires Accordion#down
+   * @function
+   * @private
+   */
+  _openTab($target) {
+    const $targetItem = $target.parent();
+    const targetContentId = $target.attr('aria-labelledby');
+
+    $target.attr('aria-hidden', false);
+    $targetItem.addClass('is-active');
+
+    $(`#${targetContentId}`).attr({
+      'aria-expanded': true,
+      'aria-selected': true
+    });
+
+    $target.slideDown(this.options.slideSpeed, () => {
+      /**
+       * Fires when the tab is done opening.
+       * @event Accordion#down
+       */
+      this.$element.trigger('down.zf.accordion', [$target]);
+    });
+  }
+
+  /**
+   * Closes the tab defined by `$target`.
+   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+   * @fires Accordion#up
+   * @function
+   * @private
+   */
+  _closeTab($target) {
+    const $targetItem = $target.parent();
+    const targetContentId = $target.attr('aria-labelledby');
+
+    $target.attr('aria-hidden', true);
+    $targetItem.removeClass('is-active');
+
+    $(`#${targetContentId}`).attr({
+     'aria-expanded': false,
+     'aria-selected': false
+    });
+
+    $target.slideUp(this.options.slideSpeed, () => {
+      /**
+       * Fires when the tab is done collapsing up.
+       * @event Accordion#up
+       */
+      this.$element.trigger('up.zf.accordion', [$target]);
+    });
+  }
+
+  /**
+   * Closes all active tabs
+   * @fires Accordion#up
+   * @function
+   * @private
+   */
+  _closeAllTabs() {
+    var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');
+    if ($activeTabs.length) {
+      this._closeTab($activeTabs);
+    }
+  }
+
+  /**
+   * Destroys an instance of an accordion.
+   * @fires Accordion#destroyed
+   * @function
+   */
+  _destroy() {
+    this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');
+    this.$element.find('a').off('.zf.accordion');
+    if(this.options.deepLink) {
+      $(window).off('hashchange', this._checkDeepLink);
+    }
+
+  }
+}
+
+Accordion.defaults = {
+  /**
+   * Amount of time to animate the opening of an accordion pane.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  slideSpeed: 250,
+  /**
+   * Allow the accordion to have multiple open panes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  multiExpand: false,
+  /**
+   * Allow the accordion to close all panes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowAllClosed: false,
+  /**
+   * Link the location hash to the open pane.
+   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+  /**
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinkSmudge: false,
+  /**
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
+   * @option
+   * @type {number}
+   * @default 300
+   */
+  deepLinkSmudgeDelay: 300,
+  /**
+   * If `deepLink` is enabled, update the browser history with the open accordion
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  updateHistory: false
+};
+
+/**
+ * AccordionMenu module.
+ * @module foundation.accordionMenu
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.nest
+ */
+
+class AccordionMenu extends Plugin {
+  /**
+   * Creates a new instance of an accordion menu.
+   * @class
+   * @name AccordionMenu
+   * @fires AccordionMenu#init
+   * @param {jQuery} element - jQuery object to make into an accordion menu.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);
+    this.className = 'AccordionMenu'; // ie9 back compat
+
+    this._init();
+
+    Keyboard.register('AccordionMenu', {
+      'ENTER': 'toggle',
+      'SPACE': 'toggle',
+      'ARROW_RIGHT': 'open',
+      'ARROW_UP': 'up',
+      'ARROW_DOWN': 'down',
+      'ARROW_LEFT': 'close',
+      'ESCAPE': 'closeAll'
+    });
+  }
+
+
+
+  /**
+   * Initializes the accordion menu by hiding all nested menus.
+   * @private
+   */
+  _init() {
+    Nest.Feather(this.$element, 'accordion');
+
+    var _this = this;
+
+    this.$element.find('[data-submenu]').not('.is-active').slideUp(0);//.find('a').css('padding-left', '1rem');
+    this.$element.attr({
+      'role': 'tree',
+      'aria-multiselectable': this.options.multiOpen
+    });
+
+    this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');
+    this.$menuLinks.each(function(){
+      var linkId = this.id || GetYoDigits(6, 'acc-menu-link'),
+          $elem = $(this),
+          $sub = $elem.children('[data-submenu]'),
+          subId = $sub[0].id || GetYoDigits(6, 'acc-menu'),
+          isActive = $sub.hasClass('is-active');
+
+      if(_this.options.parentLink) {
+        let $anchor = $elem.children('a');
+        $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-accordion-submenu-item"></li>');
+      }
+
+      if(_this.options.submenuToggle) {
+        $elem.addClass('has-submenu-toggle');
+        $elem.children('a').after('<button id="' + linkId + '" class="submenu-toggle" aria-controls="' + subId + '" aria-expanded="' + isActive + '" title="' + _this.options.submenuToggleText + '"><span class="submenu-toggle-text">' + _this.options.submenuToggleText + '</span></button>');
+      } else {
+        $elem.attr({
+          'aria-controls': subId,
+          'aria-expanded': isActive,
+          'id': linkId
+        });
+      }
+      $sub.attr({
+        'aria-labelledby': linkId,
+        'aria-hidden': !isActive,
+        'role': 'group',
+        'id': subId
+      });
+    });
+    this.$element.find('li').attr({
+      'role': 'treeitem'
+    });
+    var initPanes = this.$element.find('.is-active');
+    if(initPanes.length){
+      var _this = this;
+      initPanes.each(function(){
+        _this.down($(this));
+      });
+    }
+    this._events();
+  }
+
+  /**
+   * Adds event handlers for items within the menu.
+   * @private
+   */
+  _events() {
+    var _this = this;
+
+    this.$element.find('li').each(function() {
+      var $submenu = $(this).children('[data-submenu]');
+
+      if ($submenu.length) {
+        if(_this.options.submenuToggle) {
+          $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {
+            _this.toggle($submenu);
+          });
+        } else {
+            $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {
+              e.preventDefault();
+              _this.toggle($submenu);
+            });
+        }
+      }
+    }).on('keydown.zf.accordionmenu', function(e){
+      var $element = $(this),
+          $elements = $element.parent('ul').children('li'),
+          $prevElement,
+          $nextElement,
+          $target = $element.children('[data-submenu]');
+
+      $elements.each(function(i) {
+        if ($(this).is($element)) {
+          $prevElement = $elements.eq(Math.max(0, i-1)).find('a').first();
+          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1)).find('a').first();
+
+          if ($(this).children('[data-submenu]:visible').length) { // has open sub menu
+            $nextElement = $element.find('li:first-child').find('a').first();
+          }
+          if ($(this).is(':first-child')) { // is first element of sub menu
+            $prevElement = $element.parents('li').first().find('a').first();
+          } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) { // if previous element has open sub menu
+            $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();
+          }
+          if ($(this).is(':last-child')) { // is last element of sub menu
+            $nextElement = $element.parents('li').first().next('li').find('a').first();
+          }
+
+          return;
+        }
+      });
+
+      Keyboard.handleKey(e, 'AccordionMenu', {
+        open: function() {
+          if ($target.is(':hidden')) {
+            _this.down($target);
+            $target.find('li').first().find('a').first().focus();
+          }
+        },
+        close: function() {
+          if ($target.length && !$target.is(':hidden')) { // close active sub of this item
+            _this.up($target);
+          } else if ($element.parent('[data-submenu]').length) { // close currently open sub
+            _this.up($element.parent('[data-submenu]'));
+            $element.parents('li').first().find('a').first().focus();
+          }
+        },
+        up: function() {
+          $prevElement.focus();
+          return true;
+        },
+        down: function() {
+          $nextElement.focus();
+          return true;
+        },
+        toggle: function() {
+          if (_this.options.submenuToggle) {
+            return false;
+          }
+          if ($element.children('[data-submenu]').length) {
+            _this.toggle($element.children('[data-submenu]'));
+            return true;
+          }
+        },
+        closeAll: function() {
+          _this.hideAll();
+        },
+        handled: function(preventDefault) {
+          if (preventDefault) {
+            e.preventDefault();
+          }
+          e.stopImmediatePropagation();
+        }
+      });
+    });//.attr('tabindex', 0);
+  }
+
+  /**
+   * Closes all panes of the menu.
+   * @function
+   */
+  hideAll() {
+    this.up(this.$element.find('[data-submenu]'));
+  }
+
+  /**
+   * Opens all panes of the menu.
+   * @function
+   */
+  showAll() {
+    this.down(this.$element.find('[data-submenu]'));
+  }
+
+  /**
+   * Toggles the open/close state of a submenu.
+   * @function
+   * @param {jQuery} $target - the submenu to toggle
+   */
+  toggle($target){
+    if(!$target.is(':animated')) {
+      if (!$target.is(':hidden')) {
+        this.up($target);
+      }
+      else {
+        this.down($target);
+      }
+    }
+  }
+
+  /**
+   * Opens the sub-menu defined by `$target`.
+   * @param {jQuery} $target - Sub-menu to open.
+   * @fires AccordionMenu#down
+   */
+  down($target) {
+    // If having multiple submenus active is disabled, close all the submenus
+    // that are not parents or children of the targeted submenu.
+    if (!this.options.multiOpen) {
+      // The "branch" of the targetted submenu, from the component root to
+      // the active submenus nested in it.
+      const $targetBranch = $target.parentsUntil(this.$element)
+        .add($target)
+        .add($target.find('.is-active'));
+      // All the active submenus that are not in the branch.
+      const $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);
+
+      this.up($othersActiveSubmenus);
+    }
+
+    $target
+      .addClass('is-active')
+      .attr({ 'aria-hidden': false });
+
+    if(this.options.submenuToggle) {
+      $target.prev('.submenu-toggle').attr({'aria-expanded': true});
+    }
+    else {
+      $target.parent('.is-accordion-submenu-parent').attr({'aria-expanded': true});
+    }
+
+    $target.slideDown(this.options.slideSpeed, () => {
+      /**
+       * Fires when the menu is done opening.
+       * @event AccordionMenu#down
+       */
+      this.$element.trigger('down.zf.accordionMenu', [$target]);
+    });
+  }
+
+  /**
+   * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.
+   * @param {jQuery} $target - Sub-menu to close.
+   * @fires AccordionMenu#up
+   */
+  up($target) {
+    const $submenus = $target.find('[data-submenu]');
+    const $allmenus = $target.add($submenus);
+
+    $submenus.slideUp(0);
+    $allmenus
+      .removeClass('is-active')
+      .attr('aria-hidden', true);
+
+    if(this.options.submenuToggle) {
+      $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);
+    }
+    else {
+      $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);
+    }
+
+    $target.slideUp(this.options.slideSpeed, () => {
+      /**
+       * Fires when the menu is done collapsing up.
+       * @event AccordionMenu#up
+       */
+      this.$element.trigger('up.zf.accordionMenu', [$target]);
+    });
+  }
+
+  /**
+   * Destroys an instance of accordion menu.
+   * @fires AccordionMenu#destroyed
+   */
+  _destroy() {
+    this.$element.find('[data-submenu]').slideDown(0).css('display', '');
+    this.$element.find('a').off('click.zf.accordionMenu');
+    this.$element.find('[data-is-parent-link]').detach();
+
+    if(this.options.submenuToggle) {
+      this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');
+      this.$element.find('.submenu-toggle').remove();
+    }
+
+    Nest.Burn(this.$element, 'accordion');
+  }
+}
+
+AccordionMenu.defaults = {
+  /**
+   * Adds the parent link to the submenu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  parentLink: false,
+  /**
+   * Amount of time to animate the opening of a submenu in ms.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  slideSpeed: 250,
+  /**
+   * Adds a separate submenu toggle button. This allows the parent item to have a link.
+   * @option
+   * @example true
+   */
+  submenuToggle: false,
+  /**
+   * The text used for the submenu toggle if enabled. This is used for screen readers only.
+   * @option
+   * @example true
+   */
+  submenuToggleText: 'Toggle menu',
+  /**
+   * Allow the menu to have multiple open panes.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  multiOpen: true
+};
+
+/**
+ * Drilldown module.
+ * @module foundation.drilldown
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.nest
+ * @requires foundation.util.box
+ */
+
+class Drilldown extends Plugin {
+  /**
+   * Creates a new instance of a drilldown menu.
+   * @class
+   * @name Drilldown
+   * @param {jQuery} element - jQuery object to make into an accordion menu.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);
+    this.className = 'Drilldown'; // ie9 back compat
+
+    this._init();
+
+    Keyboard.register('Drilldown', {
+      'ENTER': 'open',
+      'SPACE': 'open',
+      'ARROW_RIGHT': 'next',
+      'ARROW_UP': 'up',
+      'ARROW_DOWN': 'down',
+      'ARROW_LEFT': 'previous',
+      'ESCAPE': 'close',
+      'TAB': 'down',
+      'SHIFT_TAB': 'up'
+    });
+  }
+
+  /**
+   * Initializes the drilldown by creating jQuery collections of elements
+   * @private
+   */
+  _init() {
+    Nest.Feather(this.$element, 'drilldown');
+
+    if(this.options.autoApplyClass) {
+      this.$element.addClass('drilldown');
+    }
+
+    this.$element.attr({
+      'role': 'tree',
+      'aria-multiselectable': false
+    });
+    this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');
+    this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');
+    this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a');
+
+    // Set the main menu as current by default (unless a submenu is selected)
+    // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu
+    this.$currentMenu = this.$element;
+
+    this.$element.attr('data-mutate', (this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown')));
+
+    this._prepareMenu();
+    this._registerEvents();
+
+    this._keyboardEvents();
+  }
+
+  /**
+   * prepares drilldown menu by setting attributes to links and elements
+   * sets a min height to prevent content jumping
+   * wraps the element if not already wrapped
+   * @private
+   * @function
+   */
+  _prepareMenu() {
+    var _this = this;
+    // if(!this.options.holdOpen){
+    //   this._menuLinkEvents();
+    // }
+    this.$submenuAnchors.each(function(){
+      var $link = $(this);
+      var $sub = $link.parent();
+      if(_this.options.parentLink){
+        $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>');
+      }
+      $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);
+      $link.children('[data-submenu]')
+          .attr({
+            'aria-hidden': true,
+            'tabindex': 0,
+            'role': 'group'
+          });
+      _this._events($link);
+    });
+    this.$submenus.each(function(){
+      var $menu = $(this),
+          $back = $menu.find('.js-drilldown-back');
+      if(!$back.length){
+        switch (_this.options.backButtonPosition) {
+          case "bottom":
+            $menu.append(_this.options.backButton);
+            break;
+          case "top":
+            $menu.prepend(_this.options.backButton);
+            break;
+          default:
+            console.error("Unsupported backButtonPosition value '" + _this.options.backButtonPosition + "'");
+        }
+      }
+      _this._back($menu);
+    });
+
+    this.$submenus.addClass('invisible');
+    if(!this.options.autoHeight) {
+      this.$submenus.addClass('drilldown-submenu-cover-previous');
+    }
+
+    // create a wrapper on element if it doesn't exist.
+    if(!this.$element.parent().hasClass('is-drilldown')){
+      this.$wrapper = $(this.options.wrapper).addClass('is-drilldown');
+      if(this.options.animateHeight) this.$wrapper.addClass('animate-height');
+      this.$element.wrap(this.$wrapper);
+    }
+    // set wrapper
+    this.$wrapper = this.$element.parent();
+    this.$wrapper.css(this._getMaxDims());
+  }
+
+  _resize() {
+    this.$wrapper.css({'max-width': 'none', 'min-height': 'none'});
+    // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths
+    this.$wrapper.css(this._getMaxDims());
+  }
+
+  /**
+   * Adds event handlers to elements in the menu.
+   * @function
+   * @private
+   * @param {jQuery} $elem - the current menu item to add handlers to.
+   */
+  _events($elem) {
+    var _this = this;
+
+    $elem.off('click.zf.drilldown')
+    .on('click.zf.drilldown', function(e){
+      if($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')){
+        e.stopImmediatePropagation();
+        e.preventDefault();
+      }
+
+      // if(e.target !== e.currentTarget.firstElementChild){
+      //   return false;
+      // }
+      _this._show($elem.parent('li'));
+
+      if(_this.options.closeOnClick){
+        var $body = $('body');
+        $body.off('.zf.drilldown').on('click.zf.drilldown', function(e){
+          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target)) { return; }
+          e.preventDefault();
+          _this._hideAll();
+          $body.off('.zf.drilldown');
+        });
+      }
+    });
+  }
+
+  /**
+   * Adds event handlers to the menu element.
+   * @function
+   * @private
+   */
+  _registerEvents() {
+    if(this.options.scrollTop){
+      this._bindHandler = this._scrollTop.bind(this);
+      this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown',this._bindHandler);
+    }
+    this.$element.on('mutateme.zf.trigger', this._resize.bind(this));
+  }
+
+  /**
+   * Scroll to Top of Element or data-scroll-top-element
+   * @function
+   * @fires Drilldown#scrollme
+   */
+  _scrollTop() {
+    var _this = this;
+    var $scrollTopElement = _this.options.scrollTopElement!=''?$(_this.options.scrollTopElement):_this.$element,
+        scrollPos = parseInt($scrollTopElement.offset().top+_this.options.scrollTopOffset, 10);
+    $('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing,function(){
+      /**
+        * Fires after the menu has scrolled
+        * @event Drilldown#scrollme
+        */
+      if(this===$('html')[0])_this.$element.trigger('scrollme.zf.drilldown');
+    });
+  }
+
+  /**
+   * Adds keydown event listener to `li`'s in the menu.
+   * @private
+   */
+  _keyboardEvents() {
+    var _this = this;
+
+    this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function(e){
+      var $element = $(this),
+          $elements = $element.parent('li').parent('ul').children('li').children('a'),
+          $prevElement,
+          $nextElement;
+
+      $elements.each(function(i) {
+        if ($(this).is($element)) {
+          $prevElement = $elements.eq(Math.max(0, i-1));
+          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));
+          return;
+        }
+      });
+
+      Keyboard.handleKey(e, 'Drilldown', {
+        next: function() {
+          if ($element.is(_this.$submenuAnchors)) {
+            _this._show($element.parent('li'));
+            $element.parent('li').one(transitionend($element), function(){
+              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
+            });
+            return true;
+          }
+        },
+        previous: function() {
+          _this._hide($element.parent('li').parent('ul'));
+          $element.parent('li').parent('ul').one(transitionend($element), function(){
+            setTimeout(function() {
+              $element.parent('li').parent('ul').parent('li').children('a').first().focus();
+            }, 1);
+          });
+          return true;
+        },
+        up: function() {
+          $prevElement.focus();
+          // Don't tap focus on first element in root ul
+          return !$element.is(_this.$element.find('> li:first-child > a'));
+        },
+        down: function() {
+          $nextElement.focus();
+          // Don't tap focus on last element in root ul
+          return !$element.is(_this.$element.find('> li:last-child > a'));
+        },
+        close: function() {
+          // Don't close on element in root ul
+          if (!$element.is(_this.$element.find('> li > a'))) {
+            _this._hide($element.parent().parent());
+            $element.parent().parent().siblings('a').focus();
+          }
+        },
+        open: function() {
+          if (_this.options.parentLink && $element.attr('href')) { // Link with href
+            return false;
+          } else if (!$element.is(_this.$menuItems)) { // not menu item means back button
+            _this._hide($element.parent('li').parent('ul'));
+            $element.parent('li').parent('ul').one(transitionend($element), function(){
+              setTimeout(function() {
+                $element.parent('li').parent('ul').parent('li').children('a').first().focus();
+              }, 1);
+            });
+            return true;
+          } else if ($element.is(_this.$submenuAnchors)) { // Sub menu item
+            _this._show($element.parent('li'));
+            $element.parent('li').one(transitionend($element), function(){
+              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
+            });
+            return true;
+          }
+        },
+        handled: function(preventDefault) {
+          if (preventDefault) {
+            e.preventDefault();
+          }
+          e.stopImmediatePropagation();
+        }
+      });
+    }); // end keyboardAccess
+  }
+
+  /**
+   * Closes all open elements, and returns to root menu.
+   * @function
+   * @fires Drilldown#closed
+   */
+  _hideAll() {
+    var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');
+    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});
+    $elem.one(transitionend($elem), function(e){
+      $elem.removeClass('is-active is-closing');
+    });
+        /**
+         * Fires when the menu is fully closed.
+         * @event Drilldown#closed
+         */
+    this.$element.trigger('closed.zf.drilldown');
+  }
+
+  /**
+   * Adds event listener for each `back` button, and closes open menus.
+   * @function
+   * @fires Drilldown#back
+   * @param {jQuery} $elem - the current sub-menu to add `back` event.
+   */
+  _back($elem) {
+    var _this = this;
+    $elem.off('click.zf.drilldown');
+    $elem.children('.js-drilldown-back')
+      .on('click.zf.drilldown', function(e){
+        e.stopImmediatePropagation();
+        // console.log('mouseup on back');
+        _this._hide($elem);
+
+        // If there is a parent submenu, call show
+        let parentSubMenu = $elem.parent('li').parent('ul').parent('li');
+        if (parentSubMenu.length) {
+          _this._show(parentSubMenu);
+        }
+      });
+  }
+
+  /**
+   * Adds event listener to menu items w/o submenus to close open menus on click.
+   * @function
+   * @private
+   */
+  _menuLinkEvents() {
+    var _this = this;
+    this.$menuItems.not('.is-drilldown-submenu-parent')
+        .off('click.zf.drilldown')
+        .on('click.zf.drilldown', function(e){
+          // e.stopImmediatePropagation();
+          setTimeout(function(){
+            _this._hideAll();
+          }, 0);
+      });
+  }
+
+  /**
+   * Sets the CSS classes for submenu to show it.
+   * @function
+   * @private
+   * @param {jQuery} $elem - the target submenu (`ul` tag)
+   * @param {boolean} trigger - trigger drilldown event
+   */
+  _setShowSubMenuClasses($elem, trigger) {
+    $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+    $elem.parent('li').attr('aria-expanded', true);
+    if (trigger === true) {
+      this.$element.trigger('open.zf.drilldown', [$elem]);
+    }
+  }
+
+  /**
+   * Sets the CSS classes for submenu to hide it.
+   * @function
+   * @private
+   * @param {jQuery} $elem - the target submenu (`ul` tag)
+   * @param {boolean} trigger - trigger drilldown event
+   */
+  _setHideSubMenuClasses($elem, trigger) {
+    $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);
+    $elem.parent('li').attr('aria-expanded', false);
+    if (trigger === true) {
+      $elem.trigger('hide.zf.drilldown', [$elem]);
+    }
+  }
+
+  /**
+   * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.
+   * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.
+   * @function
+   * @fires Drilldown#open
+   * @param {jQuery} $elem - the target (sub)menu (`ul` tag)
+   * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused
+   */
+  _showMenu($elem, autoFocus) {
+
+    var _this = this;
+
+    // Reset drilldown
+    var $expandedSubmenus = this.$element.find('li[aria-expanded="true"] > ul[data-submenu]');
+    $expandedSubmenus.each(function(index) {
+      _this._setHideSubMenuClasses($(this));
+    });
+
+    // Save the menu as the currently displayed one.
+    this.$currentMenu = $elem;
+
+    // If target menu is root, focus first link & exit
+    if ($elem.is('[data-drilldown]')) {
+      if (autoFocus === true) $elem.find('li[role="treeitem"] > a').first().focus();
+      if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));
+      return;
+    }
+
+    // Find all submenus on way to root incl. the element itself
+    var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]');
+
+    // Open target menu and all submenus on its way to root
+    $submenus.each(function(index) {
+
+      // Update height of first child (target menu) if autoHeight option true
+      if (index === 0 && _this.options.autoHeight) {
+        _this.$wrapper.css('height', $(this).data('calcHeight'));
+      }
+
+      var isLastChild = index == $submenus.length - 1;
+
+      // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link
+      // Last child makes sure the event gets always triggered even if going through several menus
+      if (isLastChild === true) {
+        $(this).one(transitionend($(this)), () => {
+          if (autoFocus === true) {
+            $elem.find('li[role="treeitem"] > a').first().focus();
+          }
+        });
+      }
+
+      _this._setShowSubMenuClasses($(this), isLastChild);
+    });
+  }
+
+  /**
+   * Opens a submenu.
+   * @function
+   * @fires Drilldown#open
+   * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.
+   */
+  _show($elem) {
+    const $submenu = $elem.children('[data-submenu]');
+
+    $elem.attr('aria-expanded', true);
+
+    this.$currentMenu = $submenu;
+    $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+    if (this.options.autoHeight) {
+      this.$wrapper.css({ height: $submenu.data('calcHeight') });
+    }
+
+    /**
+     * Fires when the submenu has opened.
+     * @event Drilldown#open
+     */
+    this.$element.trigger('open.zf.drilldown', [$elem]);
+  }
+
+  /**
+   * Hides a submenu
+   * @function
+   * @fires Drilldown#hide
+   * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.
+   */
+  _hide($elem) {
+    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});
+    $elem.parent('li').attr('aria-expanded', false);
+    $elem.attr('aria-hidden', true);
+    $elem.addClass('is-closing')
+         .one(transitionend($elem), function(){
+           $elem.removeClass('is-active is-closing');
+           $elem.blur().addClass('invisible');
+         });
+    /**
+     * Fires when the submenu has closed.
+     * @event Drilldown#hide
+     */
+    $elem.trigger('hide.zf.drilldown', [$elem]);
+  }
+
+  /**
+   * Iterates through the nested menus to calculate the min-height, and max-width for the menu.
+   * Prevents content jumping.
+   * @function
+   * @private
+   */
+  _getMaxDims() {
+    var maxHeight = 0, result = {}, _this = this;
+
+    // Recalculate menu heights and total max height
+    this.$submenus.add(this.$element).each(function(){
+      var numOfElems = $(this).children('li').length;
+      var height = Box.GetDimensions(this).height;
+
+      maxHeight = height > maxHeight ? height : maxHeight;
+
+      if(_this.options.autoHeight) {
+        $(this).data('calcHeight',height);
+      }
+    });
+
+    if (this.options.autoHeight)
+      result['height'] = this.$currentMenu.data('calcHeight');
+    else
+      result['min-height'] = `${maxHeight}px`;
+
+    result['max-width'] = `${this.$element[0].getBoundingClientRect().width}px`;
+
+    return result;
+  }
+
+  /**
+   * Destroys the Drilldown Menu
+   * @function
+   */
+  _destroy() {
+    if(this.options.scrollTop) this.$element.off('.zf.drilldown',this._bindHandler);
+    this._hideAll();
+         this.$element.off('mutateme.zf.trigger');
+    Nest.Burn(this.$element, 'drilldown');
+    this.$element.unwrap()
+                 .find('.js-drilldown-back, .is-submenu-parent-item').remove()
+                 .end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu')
+                 .end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');
+    this.$submenuAnchors.each(function() {
+      $(this).off('.zf.drilldown');
+    });
+
+    this.$element.find('[data-is-parent-link]').detach();
+    this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');
+
+    this.$element.find('a').each(function(){
+      var $link = $(this);
+      $link.removeAttr('tabindex');
+      if($link.data('savedHref')){
+        $link.attr('href', $link.data('savedHref')).removeData('savedHref');
+      }else{ return; }
+    });
+  };
+}
+
+Drilldown.defaults = {
+  /**
+   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are
+   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.
+   * @option
+   * @type {boolian}
+   * @default true
+   */
+  autoApplyClass: true,
+  /**
+   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\`) if copy and pasting.
+   * @option
+   * @type {string}
+   * @default '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>'
+   */
+  backButton: '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',
+  /**
+   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.
+   * @option
+   * @type {string}
+   * @default top
+   */
+  backButtonPosition: 'top',
+  /**
+   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\`) if copy and pasting.
+   * @option
+   * @type {string}
+   * @default '<div></div>'
+   */
+  wrapper: '<div></div>',
+  /**
+   * Adds the parent link to the submenu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  parentLink: false,
+  /**
+   * Allow the menu to return to root list on body click.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  closeOnClick: false,
+  /**
+   * Allow the menu to auto adjust height.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoHeight: false,
+  /**
+   * Animate the auto adjust height.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animateHeight: false,
+  /**
+   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  scrollTop: false,
+  /**
+   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  scrollTopElement: '',
+  /**
+   * ScrollTop offset
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  scrollTopOffset: 0,
+  /**
+   * Scroll animation duration
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+  /**
+   * Scroll animation easing. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @see {@link https://api.jquery.com/animate|JQuery animate}
+   * @default 'swing'
+   */
+  animationEasing: 'swing'
+  // holdOpen: false
+};
+
+const POSITIONS = ['left', 'right', 'top', 'bottom'];
+const VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];
+const HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];
+
+const ALIGNMENTS = {
+  'left': VERTICAL_ALIGNMENTS,
+  'right': VERTICAL_ALIGNMENTS,
+  'top': HORIZONTAL_ALIGNMENTS,
+  'bottom': HORIZONTAL_ALIGNMENTS
+};
+
+function nextItem(item, array) {
+  var currentIdx = array.indexOf(item);
+  if(currentIdx === array.length - 1) {
+    return array[0];
+  } else {
+    return array[currentIdx + 1];
+  }
+}
+
+
+class Positionable extends Plugin {
+  /**
+   * Abstract class encapsulating the tether-like explicit positioning logic
+   * including repositioning based on overlap.
+   * Expects classes to define defaults for vOffset, hOffset, position,
+   * alignment, allowOverlap, and allowBottomOverlap. They can do this by
+   * extending the defaults, or (for now recommended due to the way docs are
+   * generated) by explicitly declaring them.
+   *
+   **/
+
+  _init() {
+    this.triedPositions = {};
+    this.position  = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;
+    this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;
+    this.originalPosition = this.position;
+    this.originalAlignment = this.alignment;
+  }
+
+  _getDefaultPosition () {
+    return 'bottom';
+  }
+
+  _getDefaultAlignment() {
+    switch(this.position) {
+      case 'bottom':
+      case 'top':
+        return rtl() ? 'right' : 'left';
+      case 'left':
+      case 'right':
+        return 'bottom';
+    }
+  }
+
+  /**
+   * Adjusts the positionable possible positions by iterating through alignments
+   * and positions.
+   * @function
+   * @private
+   */
+  _reposition() {
+    if(this._alignmentsExhausted(this.position)) {
+      this.position = nextItem(this.position, POSITIONS);
+      this.alignment = ALIGNMENTS[this.position][0];
+    } else {
+      this._realign();
+    }
+  }
+
+  /**
+   * Adjusts the dropdown pane possible positions by iterating through alignments
+   * on the current position.
+   * @function
+   * @private
+   */
+  _realign() {
+    this._addTriedPosition(this.position, this.alignment);
+    this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);
+  }
+
+  _addTriedPosition(position, alignment) {
+    this.triedPositions[position] = this.triedPositions[position] || [];
+    this.triedPositions[position].push(alignment);
+  }
+
+  _positionsExhausted() {
+    var isExhausted = true;
+    for(var i = 0; i < POSITIONS.length; i++) {
+      isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);
+    }
+    return isExhausted;
+  }
+
+  _alignmentsExhausted(position) {
+    return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;
+  }
+
+
+  // When we're trying to center, we don't want to apply offset that's going to
+  // take us just off center, so wrap around to return 0 for the appropriate
+  // offset in those alignments.  TODO: Figure out if we want to make this
+  // configurable behavior... it feels more intuitive, especially for tooltips, but
+  // it's possible someone might actually want to start from center and then nudge
+  // slightly off.
+  _getVOffset() {
+    return this.options.vOffset;
+  }
+
+  _getHOffset() {
+    return this.options.hOffset;
+  }
+
+
+  _setPosition($anchor, $element, $parent) {
+    if($anchor.attr('aria-expanded') === 'false'){ return false; }
+    var $eleDims = Box.GetDimensions($element),
+        $anchorDims = Box.GetDimensions($anchor);
+
+
+    if (!this.options.allowOverlap) {
+      // restore original position & alignment before checking overlap
+      this.position = this.originalPosition;
+      this.alignment = this.originalAlignment;
+    }
+
+    $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+
+    if(!this.options.allowOverlap) {
+      var minOverlap = 100000000;
+      // default coordinates to how we start, in case we can't figure out better
+      var minCoordinates = {position: this.position, alignment: this.alignment};
+      while(!this._positionsExhausted()) {
+        let overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
+        if(overlap === 0) {
+          return;
+        }
+
+        if(overlap < minOverlap) {
+          minOverlap = overlap;
+          minCoordinates = {position: this.position, alignment: this.alignment};
+        }
+
+        this._reposition();
+
+        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+      }
+      // If we get through the entire loop, there was no non-overlapping
+      // position available. Pick the version with least overlap.
+      this.position = minCoordinates.position;
+      this.alignment = minCoordinates.alignment;
+      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+    }
+  }
+
+}
+
+Positionable.defaults = {
+  /**
+   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+  /**
+   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+  /**
+   * Allow overlap of container/window. If false, dropdown positionable first
+   * try to position as defined by data-position and data-alignment, but
+   * reposition if it would cause an overflow.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  allowBottomOverlap: true,
+  /**
+   * Number of pixels the positionable should be separated vertically from anchor
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+  /**
+   * Number of pixels the positionable should be separated horizontally from anchor
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0,
+};
+
+/**
+ * Dropdown module.
+ * @module foundation.dropdown
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.box
+ * @requires foundation.util.triggers
+ */
+class Dropdown extends Positionable {
+  /**
+   * Creates a new instance of a dropdown.
+   * @class
+   * @name Dropdown
+   * @param {jQuery} element - jQuery object to make into a dropdown.
+   *        Object should be of the dropdown panel, rather than its anchor.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);
+    this.className = 'Dropdown'; // ie9 back compat
+
+    // Triggers init is idempotent, just need to make sure it is initialized
+    Triggers.init($);
+
+    this._init();
+
+    Keyboard.register('Dropdown', {
+      'ENTER': 'toggle',
+      'SPACE': 'toggle',
+      'ESCAPE': 'close'
+    });
+  }
+
+  /**
+   * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.
+   * @function
+   * @private
+   */
+  _init() {
+    var $id = this.$element.attr('id');
+
+    this.$anchors = $(`[data-toggle="${$id}"]`).length ? $(`[data-toggle="${$id}"]`) : $(`[data-open="${$id}"]`);
+    this.$anchors.attr({
+      'aria-controls': $id,
+      'data-is-focus': false,
+      'data-yeti-box': $id,
+      'aria-haspopup': true,
+      'aria-expanded': false
+    });
+
+    this._setCurrentAnchor(this.$anchors.first());
+
+    if(this.options.parentClass){
+      this.$parent = this.$element.parents('.' + this.options.parentClass);
+    }else{
+      this.$parent = null;
+    }
+
+    // Set [aria-labelledby] on the Dropdown if it is not set
+    if (typeof this.$element.attr('aria-labelledby') === 'undefined') {
+      // Get the anchor ID or create one
+      if (typeof this.$currentAnchor.attr('id') === 'undefined') {
+        this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));
+      }
+      this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));
+    }
+
+    this.$element.attr({
+      'aria-hidden': 'true',
+      'data-yeti-box': $id,
+      'data-resize': $id,
+    });
+
+    super._init();
+    this._events();
+  }
+
+  _getDefaultPosition() {
+    // handle legacy classnames
+    var position = this.$element[0].className.match(/(top|left|right|bottom)/g);
+    if(position) {
+      return position[0];
+    } else {
+      return 'bottom'
+    }
+  }
+
+  _getDefaultAlignment() {
+    // handle legacy float approach
+    var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.attr('class'));
+    if(horizontalPosition) {
+      return horizontalPosition[1];
+    }
+
+    return super._getDefaultAlignment();
+  }
+
+
+
+  /**
+   * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.
+   * Recursively calls itself if a collision is detected, with a new position class.
+   * @function
+   * @private
+   */
+  _setPosition() {
+    this.$element.removeClass(`has-position-${this.position} has-alignment-${this.alignment}`);
+    super._setPosition(this.$currentAnchor, this.$element, this.$parent);
+    this.$element.addClass(`has-position-${this.position} has-alignment-${this.alignment}`);
+  }
+
+  /**
+   * Make it a current anchor.
+   * Current anchor as the reference for the position of Dropdown panes.
+   * @param {HTML} el - DOM element of the anchor.
+   * @function
+   * @private
+   */
+  _setCurrentAnchor(el) {
+    this.$currentAnchor = $(el);
+  }
+
+  /**
+   * Adds event listeners to the element utilizing the triggers utility library.
+   * @function
+   * @private
+   */
+  _events() {
+    var _this = this;
+    this.$element.on({
+      'open.zf.trigger': this.open.bind(this),
+      'close.zf.trigger': this.close.bind(this),
+      'toggle.zf.trigger': this.toggle.bind(this),
+      'resizeme.zf.trigger': this._setPosition.bind(this)
+    });
+
+    this.$anchors.off('click.zf.trigger')
+      .on('click.zf.trigger', function() { _this._setCurrentAnchor(this); });
+
+    if(this.options.hover){
+      this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')
+      .on('mouseenter.zf.dropdown', function(){
+        _this._setCurrentAnchor(this);
+
+        var bodyData = $('body').data();
+        if(typeof(bodyData.whatinput) === 'undefined' || bodyData.whatinput === 'mouse') {
+          clearTimeout(_this.timeout);
+          _this.timeout = setTimeout(function(){
+            _this.open();
+            _this.$anchors.data('hover', true);
+          }, _this.options.hoverDelay);
+        }
+      }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){
+        clearTimeout(_this.timeout);
+        _this.timeout = setTimeout(function(){
+          _this.close();
+          _this.$anchors.data('hover', false);
+        }, _this.options.hoverDelay);
+      }));
+      if(this.options.hoverPane){
+        this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')
+            .on('mouseenter.zf.dropdown', function(){
+              clearTimeout(_this.timeout);
+            }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){
+              clearTimeout(_this.timeout);
+              _this.timeout = setTimeout(function(){
+                _this.close();
+                _this.$anchors.data('hover', false);
+              }, _this.options.hoverDelay);
+            }));
+      }
+    }
+    this.$anchors.add(this.$element).on('keydown.zf.dropdown', function(e) {
+
+      var $target = $(this),
+        visibleFocusableElements = Keyboard.findFocusable(_this.$element);
+
+      Keyboard.handleKey(e, 'Dropdown', {
+        open: function() {
+          if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {
+            _this.open();
+            _this.$element.attr('tabindex', -1).focus();
+            e.preventDefault();
+          }
+        },
+        close: function() {
+          _this.close();
+          _this.$anchors.focus();
+        }
+      });
+    });
+  }
+
+  /**
+   * Adds an event handler to the body to close any dropdowns on a click.
+   * @function
+   * @private
+   */
+  _addBodyHandler() {
+     var $body = $(document.body).not(this.$element),
+         _this = this;
+     $body.off('click.zf.dropdown')
+          .on('click.zf.dropdown', function(e){
+            if(_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {
+              return;
+            }
+            if(_this.$element.is(e.target) || _this.$element.find(e.target).length) {
+              return;
+            }
+            _this.close();
+            $body.off('click.zf.dropdown');
+          });
+  }
+
+  /**
+   * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.
+   * @function
+   * @fires Dropdown#closeme
+   * @fires Dropdown#show
+   */
+  open() {
+    // var _this = this;
+    /**
+     * Fires to close other open dropdowns, typically when dropdown is opening
+     * @event Dropdown#closeme
+     */
+    this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));
+    this.$anchors.addClass('hover')
+        .attr({'aria-expanded': true});
+    // this.$element/*.show()*/;
+
+    this.$element.addClass('is-opening');
+    this._setPosition();
+    this.$element.removeClass('is-opening').addClass('is-open')
+        .attr({'aria-hidden': false});
+
+    if(this.options.autoFocus){
+      var $focusable = Keyboard.findFocusable(this.$element);
+      if($focusable.length){
+        $focusable.eq(0).focus();
+      }
+    }
+
+    if(this.options.closeOnClick){ this._addBodyHandler(); }
+
+    if (this.options.trapFocus) {
+      Keyboard.trapFocus(this.$element);
+    }
+
+    /**
+     * Fires once the dropdown is visible.
+     * @event Dropdown#show
+     */
+    this.$element.trigger('show.zf.dropdown', [this.$element]);
+  }
+
+  /**
+   * Closes the open dropdown pane.
+   * @function
+   * @fires Dropdown#hide
+   */
+  close() {
+    if(!this.$element.hasClass('is-open')){
+      return false;
+    }
+    this.$element.removeClass('is-open')
+        .attr({'aria-hidden': true});
+
+    this.$anchors.removeClass('hover')
+        .attr('aria-expanded', false);
+
+    /**
+     * Fires once the dropdown is no longer visible.
+     * @event Dropdown#hide
+     */
+    this.$element.trigger('hide.zf.dropdown', [this.$element]);
+
+    if (this.options.trapFocus) {
+      Keyboard.releaseFocus(this.$element);
+    }
+  }
+
+  /**
+   * Toggles the dropdown pane's visibility.
+   * @function
+   */
+  toggle() {
+    if(this.$element.hasClass('is-open')){
+      if(this.$anchors.data('hover')) return;
+      this.close();
+    }else{
+      this.open();
+    }
+  }
+
+  /**
+   * Destroys the dropdown.
+   * @function
+   */
+  _destroy() {
+    this.$element.off('.zf.trigger').hide();
+    this.$anchors.off('.zf.dropdown');
+    $(document.body).off('click.zf.dropdown');
+
+  }
+}
+
+Dropdown.defaults = {
+  /**
+   * Class that designates bounding container of Dropdown (default: window)
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  parentClass: null,
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  hoverDelay: 250,
+  /**
+   * Allow submenus to open on hover events
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  hover: false,
+  /**
+   * Don't close dropdown when hovering over dropdown pane
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  hoverPane: false,
+  /**
+   * Number of pixels between the dropdown pane and the triggering element on open.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+  /**
+   * Number of pixels between the dropdown pane and the triggering element on open.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0,
+  /**
+   * Position of dropdown. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+  /**
+   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+  /**
+   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  allowBottomOverlap: true,
+  /**
+   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  trapFocus: false,
+  /**
+   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoFocus: false,
+  /**
+   * Allows a click on the body to close the dropdown.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  closeOnClick: false
+};
+
+/**
+ * DropdownMenu module.
+ * @module foundation.dropdown-menu
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.box
+ * @requires foundation.util.nest
+ */
+
+class DropdownMenu extends Plugin {
+  /**
+   * Creates a new instance of DropdownMenu.
+   * @class
+   * @name DropdownMenu
+   * @fires DropdownMenu#init
+   * @param {jQuery} element - jQuery object to make into a dropdown menu.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);
+    this.className = 'DropdownMenu'; // ie9 back compat
+
+    this._init();
+
+    Keyboard.register('DropdownMenu', {
+      'ENTER': 'open',
+      'SPACE': 'open',
+      'ARROW_RIGHT': 'next',
+      'ARROW_UP': 'up',
+      'ARROW_DOWN': 'down',
+      'ARROW_LEFT': 'previous',
+      'ESCAPE': 'close'
+    });
+  }
+
+  /**
+   * Initializes the plugin, and calls _prepareMenu
+   * @private
+   * @function
+   */
+  _init() {
+    Nest.Feather(this.$element, 'dropdown');
+
+    var subs = this.$element.find('li.is-dropdown-submenu-parent');
+    this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');
+
+    this.$menuItems = this.$element.find('[role="menuitem"]');
+    this.$tabs = this.$element.children('[role="menuitem"]');
+    this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);
+
+    if (this.options.alignment === 'auto') {
+        if (this.$element.hasClass(this.options.rightClass) || rtl() || this.$element.parents('.top-bar-right').is('*')) {
+            this.options.alignment = 'right';
+            subs.addClass('opens-left');
+        } else {
+            this.options.alignment = 'left';
+            subs.addClass('opens-right');
+        }
+    } else {
+      if (this.options.alignment === 'right') {
+          subs.addClass('opens-left');
+      } else {
+          subs.addClass('opens-right');
+      }
+    }
+    this.changed = false;
+    this._events();
+  };
+
+  _isVertical() {
+    return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';
+  }
+
+  _isRtl() {
+    return this.$element.hasClass('align-right') || (rtl() && !this.$element.hasClass('align-left'));
+  }
+
+  /**
+   * Adds event listeners to elements within the menu
+   * @private
+   * @function
+   */
+  _events() {
+    var _this = this,
+        hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined'),
+        parClass = 'is-dropdown-submenu-parent';
+
+    // used for onClick and in the keyboard handlers
+    var handleClickFn = function(e) {
+      var $elem = $(e.target).parentsUntil('ul', `.${parClass}`),
+          hasSub = $elem.hasClass(parClass),
+          hasClicked = $elem.attr('data-is-click') === 'true',
+          $sub = $elem.children('.is-dropdown-submenu');
+
+      if (hasSub) {
+        if (hasClicked) {
+          if (!_this.options.closeOnClick || (!_this.options.clickOpen && !hasTouch) || (_this.options.forceFollow && hasTouch)) { return; }
+          else {
+            e.stopImmediatePropagation();
+            e.preventDefault();
+            _this._hide($elem);
+          }
+        } else {
+          e.preventDefault();
+          e.stopImmediatePropagation();
+          _this._show($sub);
+          $elem.add($elem.parentsUntil(_this.$element, `.${parClass}`)).attr('data-is-click', true);
+        }
+      }
+    };
+
+    if (this.options.clickOpen || hasTouch) {
+      this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);
+    }
+
+    // Handle Leaf element Clicks
+    if(_this.options.closeOnClickInside){
+      this.$menuItems.on('click.zf.dropdownmenu', function(e) {
+        var $elem = $(this),
+            hasSub = $elem.hasClass(parClass);
+        if(!hasSub){
+          _this._hide();
+        }
+      });
+    }
+
+    if (!this.options.disableHover) {
+      this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {
+        var $elem = $(this),
+          hasSub = $elem.hasClass(parClass);
+
+        if (hasSub) {
+          clearTimeout($elem.data('_delay'));
+          $elem.data('_delay', setTimeout(function () {
+            _this._show($elem.children('.is-dropdown-submenu'));
+          }, _this.options.hoverDelay));
+        }
+      }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) {
+        var $elem = $(this),
+            hasSub = $elem.hasClass(parClass);
+        if (hasSub && _this.options.autoclose) {
+          if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { return false; }
+
+          clearTimeout($elem.data('_delay'));
+          $elem.data('_delay', setTimeout(function () {
+            _this._hide($elem);
+          }, _this.options.closingTime));
+        }
+      }));
+    }
+    this.$menuItems.on('keydown.zf.dropdownmenu', function(e) {
+      var $element = $(e.target).parentsUntil('ul', '[role="menuitem"]'),
+          isTab = _this.$tabs.index($element) > -1,
+          $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),
+          $prevElement,
+          $nextElement;
+
+      $elements.each(function(i) {
+        if ($(this).is($element)) {
+          $prevElement = $elements.eq(i-1);
+          $nextElement = $elements.eq(i+1);
+          return;
+        }
+      });
+
+      var nextSibling = function() {
+        $nextElement.children('a:first').focus();
+        e.preventDefault();
+      }, prevSibling = function() {
+        $prevElement.children('a:first').focus();
+        e.preventDefault();
+      }, openSub = function() {
+        var $sub = $element.children('ul.is-dropdown-submenu');
+        if ($sub.length) {
+          _this._show($sub);
+          $element.find('li > a:first').focus();
+          e.preventDefault();
+        } else { return; }
+      }, closeSub = function() {
+        //if ($element.is(':first-child')) {
+        var close = $element.parent('ul').parent('li');
+        close.children('a:first').focus();
+        _this._hide(close);
+        e.preventDefault();
+        //}
+      };
+      var functions = {
+        open: openSub,
+        close: function() {
+          _this._hide(_this.$element);
+          _this.$menuItems.eq(0).children('a').focus(); // focus to first element
+          e.preventDefault();
+        },
+        handled: function() {
+          e.stopImmediatePropagation();
+        }
+      };
+
+      if (isTab) {
+        if (_this._isVertical()) { // vertical menu
+          if (_this._isRtl()) { // right aligned
+            $.extend(functions, {
+              down: nextSibling,
+              up: prevSibling,
+              next: closeSub,
+              previous: openSub
+            });
+          } else { // left aligned
+            $.extend(functions, {
+              down: nextSibling,
+              up: prevSibling,
+              next: openSub,
+              previous: closeSub
+            });
+          }
+        } else { // horizontal menu
+          if (_this._isRtl()) { // right aligned
+            $.extend(functions, {
+              next: prevSibling,
+              previous: nextSibling,
+              down: openSub,
+              up: closeSub
+            });
+          } else { // left aligned
+            $.extend(functions, {
+              next: nextSibling,
+              previous: prevSibling,
+              down: openSub,
+              up: closeSub
+            });
+          }
+        }
+      } else { // not tabs -> one sub
+        if (_this._isRtl()) { // right aligned
+          $.extend(functions, {
+            next: closeSub,
+            previous: openSub,
+            down: nextSibling,
+            up: prevSibling
+          });
+        } else { // left aligned
+          $.extend(functions, {
+            next: openSub,
+            previous: closeSub,
+            down: nextSibling,
+            up: prevSibling
+          });
+        }
+      }
+      Keyboard.handleKey(e, 'DropdownMenu', functions);
+
+    });
+  }
+
+  /**
+   * Adds an event handler to the body to close any dropdowns on a click.
+   * @function
+   * @private
+   */
+  _addBodyHandler() {
+    var $body = $(document.body),
+        _this = this;
+    $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu')
+         .on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function(e) {
+           var $link = _this.$element.find(e.target);
+           if ($link.length) { return; }
+
+           _this._hide();
+           $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');
+         });
+  }
+
+  /**
+   * Opens a dropdown pane, and checks for collisions first.
+   * @param {jQuery} $sub - ul element that is a submenu to show
+   * @function
+   * @private
+   * @fires Dropdownmenu#show
+   */
+  _show($sub) {
+    var idx = this.$tabs.index(this.$tabs.filter(function(i, el) {
+      return $(el).find($sub).length > 0;
+    }));
+    var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');
+    this._hide($sibs, idx);
+    $sub.css('visibility', 'hidden').addClass('js-dropdown-active')
+        .parent('li.is-dropdown-submenu-parent').addClass('is-active');
+    var clear = Box.ImNotTouchingYou($sub, null, true);
+    if (!clear) {
+      var oldClass = this.options.alignment === 'left' ? '-right' : '-left',
+          $parentLi = $sub.parent('.is-dropdown-submenu-parent');
+      $parentLi.removeClass(`opens${oldClass}`).addClass(`opens-${this.options.alignment}`);
+      clear = Box.ImNotTouchingYou($sub, null, true);
+      if (!clear) {
+        $parentLi.removeClass(`opens-${this.options.alignment}`).addClass('opens-inner');
+      }
+      this.changed = true;
+    }
+    $sub.css('visibility', '');
+    if (this.options.closeOnClick) { this._addBodyHandler(); }
+    /**
+     * Fires when the new dropdown pane is visible.
+     * @event Dropdownmenu#show
+     */
+    this.$element.trigger('show.zf.dropdownmenu', [$sub]);
+  }
+
+  /**
+   * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.
+   * @function
+   * @param {jQuery} $elem - element with a submenu to hide
+   * @param {Number} idx - index of the $tabs collection to hide
+   * @private
+   */
+  _hide($elem, idx) {
+    var $toClose;
+    if ($elem && $elem.length) {
+      $toClose = $elem;
+    } else if (typeof idx !== 'undefined') {
+      $toClose = this.$tabs.not(function(i, el) {
+        return i === idx;
+      });
+    }
+    else {
+      $toClose = this.$element;
+    }
+    var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;
+
+    if (somethingToClose) {
+      $toClose.find('li.is-active').add($toClose).attr({
+        'data-is-click': false
+      }).removeClass('is-active');
+
+      $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');
+
+      if (this.changed || $toClose.find('opens-inner').length) {
+        var oldClass = this.options.alignment === 'left' ? 'right' : 'left';
+        $toClose.find('li.is-dropdown-submenu-parent').add($toClose)
+                .removeClass(`opens-inner opens-${this.options.alignment}`)
+                .addClass(`opens-${oldClass}`);
+        this.changed = false;
+      }
+      /**
+       * Fires when the open menus are closed.
+       * @event Dropdownmenu#hide
+       */
+      this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);
+    }
+  }
+
+  /**
+   * Destroys the plugin.
+   * @function
+   */
+  _destroy() {
+    this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click')
+        .removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');
+    $(document.body).off('.zf.dropdownmenu');
+    Nest.Burn(this.$element, 'dropdown');
+  }
+}
+
+/**
+ * Default settings for plugin
+ */
+DropdownMenu.defaults = {
+  /**
+   * Disallows hover events from opening submenus
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disableHover: false,
+  /**
+   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  autoclose: true,
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  hoverDelay: 50,
+  /**
+   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  clickOpen: false,
+  /**
+   * Amount of time to delay closing a submenu on a mouseleave event.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+
+  closingTime: 500,
+  /**
+   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+  /**
+   * Allow clicks on the body to close any open submenus.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+  /**
+   * Allow clicks on leaf anchor links to close any open submenus.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClickInside: true,
+  /**
+   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.
+   * @option
+   * @type {string}
+   * @default 'vertical'
+   */
+  verticalClass: 'vertical',
+  /**
+   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.
+   * @option
+   * @type {string}
+   * @default 'align-right'
+   */
+  rightClass: 'align-right',
+  /**
+   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  forceFollow: true
+};
+
+/**
+ * Equalizer module.
+ * @module foundation.equalizer
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.imageLoader if equalizer contains images
+ */
+
+class Equalizer extends Plugin {
+  /**
+   * Creates a new instance of Equalizer.
+   * @class
+   * @name Equalizer
+   * @fires Equalizer#init
+   * @param {Object} element - jQuery object to add the trigger to.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options){
+    this.$element = element;
+    this.options  = $.extend({}, Equalizer.defaults, this.$element.data(), options);
+    this.className = 'Equalizer'; // ie9 back compat
+
+    this._init();
+  }
+
+  /**
+   * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.
+   * @private
+   */
+  _init() {
+    var eqId = this.$element.attr('data-equalizer') || '';
+    var $watched = this.$element.find(`[data-equalizer-watch="${eqId}"]`);
+
+    MediaQuery._init();
+
+    this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');
+    this.$element.attr('data-resize', (eqId || GetYoDigits(6, 'eq')));
+    this.$element.attr('data-mutate', (eqId || GetYoDigits(6, 'eq')));
+
+    this.hasNested = this.$element.find('[data-equalizer]').length > 0;
+    this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;
+    this.isOn = false;
+    this._bindHandler = {
+      onResizeMeBound: this._onResizeMe.bind(this),
+      onPostEqualizedBound: this._onPostEqualized.bind(this)
+    };
+
+    var imgs = this.$element.find('img');
+    var tooSmall;
+    if(this.options.equalizeOn){
+      tooSmall = this._checkMQ();
+      $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));
+    }else{
+      this._events();
+    }
+    if((typeof tooSmall !== 'undefined' && tooSmall === false) || typeof tooSmall === 'undefined'){
+      if(imgs.length){
+        onImagesLoaded(imgs, this._reflow.bind(this));
+      }else{
+        this._reflow();
+      }
+    }
+  }
+
+  /**
+   * Removes event listeners if the breakpoint is too small.
+   * @private
+   */
+  _pauseEvents() {
+    this.isOn = false;
+    this.$element.off({
+      '.zf.equalizer': this._bindHandler.onPostEqualizedBound,
+      'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,
+         'mutateme.zf.trigger': this._bindHandler.onResizeMeBound
+    });
+  }
+
+  /**
+   * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound
+   * @private
+   */
+  _onResizeMe(e) {
+    this._reflow();
+  }
+
+  /**
+   * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound
+   * @private
+   */
+  _onPostEqualized(e) {
+    if(e.target !== this.$element[0]){ this._reflow(); }
+  }
+
+  /**
+   * Initializes events for Equalizer.
+   * @private
+   */
+  _events() {
+    this._pauseEvents();
+    if(this.hasNested){
+      this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);
+    }else{
+      this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);
+         this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);
+    }
+    this.isOn = true;
+  }
+
+  /**
+   * Checks the current breakpoint to the minimum required size.
+   * @private
+   */
+  _checkMQ() {
+    var tooSmall = !MediaQuery.is(this.options.equalizeOn);
+    if(tooSmall){
+      if(this.isOn){
+        this._pauseEvents();
+        this.$watched.css('height', 'auto');
+      }
+    }else{
+      if(!this.isOn){
+        this._events();
+      }
+    }
+    return tooSmall;
+  }
+
+  /**
+   * A noop version for the plugin
+   * @private
+   */
+  _killswitch() {
+    return;
+  }
+
+  /**
+   * Calls necessary functions to update Equalizer upon DOM change
+   * @private
+   */
+  _reflow() {
+    if(!this.options.equalizeOnStack){
+      if(this._isStacked()){
+        this.$watched.css('height', 'auto');
+        return false;
+      }
+    }
+    if (this.options.equalizeByRow) {
+      this.getHeightsByRow(this.applyHeightByRow.bind(this));
+    }else{
+      this.getHeights(this.applyHeight.bind(this));
+    }
+  }
+
+  /**
+   * Manually determines if the first 2 elements are *NOT* stacked.
+   * @private
+   */
+  _isStacked() {
+    if (!this.$watched[0] || !this.$watched[1]) {
+      return true;
+    }
+    return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;
+  }
+
+  /**
+   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
+   * @param {Function} cb - A non-optional callback to return the heights array to.
+   * @returns {Array} heights - An array of heights of children within Equalizer container
+   */
+  getHeights(cb) {
+    var heights = [];
+    for(var i = 0, len = this.$watched.length; i < len; i++){
+      this.$watched[i].style.height = 'auto';
+      heights.push(this.$watched[i].offsetHeight);
+    }
+    cb(heights);
+  }
+
+  /**
+   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
+   * @param {Function} cb - A non-optional callback to return the heights array to.
+   * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
+   */
+  getHeightsByRow(cb) {
+    var lastElTopOffset = (this.$watched.length ? this.$watched.first().offset().top : 0),
+        groups = [],
+        group = 0;
+    //group by Row
+    groups[group] = [];
+    for(var i = 0, len = this.$watched.length; i < len; i++){
+      this.$watched[i].style.height = 'auto';
+      //maybe could use this.$watched[i].offsetTop
+      var elOffsetTop = $(this.$watched[i]).offset().top;
+      if (elOffsetTop!=lastElTopOffset) {
+        group++;
+        groups[group] = [];
+        lastElTopOffset=elOffsetTop;
+      }
+      groups[group].push([this.$watched[i],this.$watched[i].offsetHeight]);
+    }
+
+    for (var j = 0, ln = groups.length; j < ln; j++) {
+      var heights = $(groups[j]).map(function(){ return this[1]; }).get();
+      var max         = Math.max.apply(null, heights);
+      groups[j].push(max);
+    }
+    cb(groups);
+  }
+
+  /**
+   * Changes the CSS height property of each child in an Equalizer parent to match the tallest
+   * @param {array} heights - An array of heights of children within Equalizer container
+   * @fires Equalizer#preequalized
+   * @fires Equalizer#postequalized
+   */
+  applyHeight(heights) {
+    var max = Math.max.apply(null, heights);
+    /**
+     * Fires before the heights are applied
+     * @event Equalizer#preequalized
+     */
+    this.$element.trigger('preequalized.zf.equalizer');
+
+    this.$watched.css('height', max);
+
+    /**
+     * Fires when the heights have been applied
+     * @event Equalizer#postequalized
+     */
+     this.$element.trigger('postequalized.zf.equalizer');
+  }
+
+  /**
+   * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row
+   * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
+   * @fires Equalizer#preequalized
+   * @fires Equalizer#preequalizedrow
+   * @fires Equalizer#postequalizedrow
+   * @fires Equalizer#postequalized
+   */
+  applyHeightByRow(groups) {
+    /**
+     * Fires before the heights are applied
+     */
+    this.$element.trigger('preequalized.zf.equalizer');
+    for (var i = 0, len = groups.length; i < len ; i++) {
+      var groupsILength = groups[i].length,
+          max = groups[i][groupsILength - 1];
+      if (groupsILength<=2) {
+        $(groups[i][0][0]).css({'height':'auto'});
+        continue;
+      }
+      /**
+        * Fires before the heights per row are applied
+        * @event Equalizer#preequalizedrow
+        */
+      this.$element.trigger('preequalizedrow.zf.equalizer');
+      for (var j = 0, lenJ = (groupsILength-1); j < lenJ ; j++) {
+        $(groups[i][j][0]).css({'height':max});
+      }
+      /**
+        * Fires when the heights per row have been applied
+        * @event Equalizer#postequalizedrow
+        */
+      this.$element.trigger('postequalizedrow.zf.equalizer');
+    }
+    /**
+     * Fires when the heights have been applied
+     */
+     this.$element.trigger('postequalized.zf.equalizer');
+  }
+
+  /**
+   * Destroys an instance of Equalizer.
+   * @function
+   */
+  _destroy() {
+    this._pauseEvents();
+    this.$watched.css('height', 'auto');
+  }
+}
+
+/**
+ * Default settings for plugin
+ */
+Equalizer.defaults = {
+  /**
+   * Enable height equalization when stacked on smaller screens.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  equalizeOnStack: false,
+  /**
+   * Enable height equalization row by row.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  equalizeByRow: false,
+  /**
+   * String representing the minimum breakpoint size the plugin should equalize heights on.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  equalizeOn: ''
+};
+
+/**
+ * Interchange module.
+ * @module foundation.interchange
+ * @requires foundation.util.mediaQuery
+ */
+
+class Interchange extends Plugin {
+  /**
+   * Creates a new instance of Interchange.
+   * @class
+   * @name Interchange
+   * @fires Interchange#init
+   * @param {Object} element - jQuery object to add the trigger to.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Interchange.defaults, options);
+    this.rules = [];
+    this.currentPath = '';
+    this.className = 'Interchange'; // ie9 back compat
+
+    this._init();
+    this._events();
+  }
+
+  /**
+   * Initializes the Interchange plugin and calls functions to get interchange functioning on load.
+   * @function
+   * @private
+   */
+  _init() {
+    MediaQuery._init();
+
+    var id = this.$element[0].id || GetYoDigits(6, 'interchange');
+    this.$element.attr({
+      'data-resize': id,
+      'id': id
+    });
+
+    this._addBreakpoints();
+    this._generateRules();
+    this._reflow();
+  }
+
+  /**
+   * Initializes events for Interchange.
+   * @function
+   * @private
+   */
+  _events() {
+    this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', () => this._reflow());
+  }
+
+  /**
+   * Calls necessary functions to update Interchange upon DOM change
+   * @function
+   * @private
+   */
+  _reflow() {
+    var match;
+
+    // Iterate through each rule, but only save the last match
+    for (var i in this.rules) {
+      if(this.rules.hasOwnProperty(i)) {
+        var rule = this.rules[i];
+        if (window.matchMedia(rule.query).matches) {
+          match = rule;
+        }
+      }
+    }
+
+    if (match) {
+      this.replace(match.path);
+    }
+  }
+
+  /**
+   * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.
+   * @function
+   * @private
+   */
+  _addBreakpoints() {
+    for (var i in MediaQuery.queries) {
+      if (MediaQuery.queries.hasOwnProperty(i)) {
+        var query = MediaQuery.queries[i];
+        Interchange.SPECIAL_QUERIES[query.name] = query.value;
+      }
+    }
+  }
+
+  /**
+   * Checks the Interchange element for the provided media query + content pairings
+   * @function
+   * @private
+   * @param {Object} element - jQuery object that is an Interchange instance
+   * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys
+   */
+  _generateRules(element) {
+    var rulesList = [];
+    var rules;
+
+    if (this.options.rules) {
+      rules = this.options.rules;
+    }
+    else {
+      rules = this.$element.data('interchange');
+    }
+
+    rules =  typeof rules === 'string' ? rules.match(/\[.*?, .*?\]/g) : rules;
+
+    for (var i in rules) {
+      if(rules.hasOwnProperty(i)) {
+        var rule = rules[i].slice(1, -1).split(', ');
+        var path = rule.slice(0, -1).join('');
+        var query = rule[rule.length - 1];
+
+        if (Interchange.SPECIAL_QUERIES[query]) {
+          query = Interchange.SPECIAL_QUERIES[query];
+        }
+
+        rulesList.push({
+          path: path,
+          query: query
+        });
+      }
+    }
+
+    this.rules = rulesList;
+  }
+
+  /**
+   * Update the `src` property of an image, or change the HTML of a container, to the specified path.
+   * @function
+   * @param {String} path - Path to the image or HTML partial.
+   * @fires Interchange#replaced
+   */
+  replace(path) {
+    if (this.currentPath === path) return;
+
+    var _this = this,
+        trigger = 'replaced.zf.interchange';
+
+    // Replacing images
+    if (this.$element[0].nodeName === 'IMG') {
+      this.$element.attr('src', path).on('load', function() {
+        _this.currentPath = path;
+      })
+      .trigger(trigger);
+    }
+    // Replacing background images
+    else if (path.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {
+      path = path.replace(/\(/g, '%28').replace(/\)/g, '%29');
+      this.$element.css({ 'background-image': 'url('+path+')' })
+          .trigger(trigger);
+    }
+    // Replacing HTML
+    else {
+      $.get(path, function(response) {
+        _this.$element.html(response)
+             .trigger(trigger);
+        $(response).foundation();
+        _this.currentPath = path;
+      });
+    }
+
+    /**
+     * Fires when content in an Interchange element is done being loaded.
+     * @event Interchange#replaced
+     */
+    // this.$element.trigger('replaced.zf.interchange');
+  }
+
+  /**
+   * Destroys an instance of interchange.
+   * @function
+   */
+  _destroy() {
+    this.$element.off('resizeme.zf.trigger');
+  }
+}
+
+/**
+ * Default settings for plugin
+ */
+Interchange.defaults = {
+  /**
+   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.
+   * @option
+   * @type {?array}
+   * @default null
+   */
+  rules: null
+};
+
+Interchange.SPECIAL_QUERIES = {
+  'landscape': 'screen and (orientation: landscape)',
+  'portrait': 'screen and (orientation: portrait)',
+  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'
+};
+
+/**
+ * SmoothScroll module.
+ * @module foundation.smooth-scroll
+ */
+class SmoothScroll extends Plugin {
+  /**
+   * Creates a new instance of SmoothScroll.
+   * @class
+   * @name SmoothScroll
+   * @fires SmoothScroll#init
+   * @param {Object} element - jQuery object to add the trigger to.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+    _setup(element, options) {
+        this.$element = element;
+        this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);
+        this.className = 'SmoothScroll'; // ie9 back compat
+
+        this._init();
+    }
+
+    /**
+     * Initialize the SmoothScroll plugin
+     * @private
+     */
+    _init() {
+        const id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');
+        this.$element.attr({ id });
+
+        this._events();
+    }
+
+    /**
+     * Initializes events for SmoothScroll.
+     * @private
+     */
+    _events() {
+        this._linkClickListener = this._handleLinkClick.bind(this);
+        this.$element.on('click.zf.smoothScroll', this._linkClickListener);
+        this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
+    }
+
+    /**
+     * Handle the given event to smoothly scroll to the anchor pointed by the event target.
+     * @param {*} e - event
+     * @function
+     * @private
+     */
+    _handleLinkClick(e) {
+        // Follow the link if it does not point to an anchor.
+        if (!$(e.currentTarget).is('a[href^="#"]')) return;
+
+        const arrival = e.currentTarget.getAttribute('href');
+
+        this._inTransition = true;
+
+        SmoothScroll.scrollToLoc(arrival, this.options, () => {
+            this._inTransition = false;
+        });
+
+        e.preventDefault();
+    };
+
+    /**
+     * Function to scroll to a given location on the page.
+     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'
+     * @param {Object} options - The options to use.
+     * @param {Function} callback - The callback function.
+     * @static
+     * @function
+     */
+    static scrollToLoc(loc, options = SmoothScroll.defaults, callback) {
+        const $loc = $(loc);
+
+        // Do nothing if target does not exist to prevent errors
+        if (!$loc.length) return false;
+
+        var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);
+
+        $('html, body').stop(true).animate(
+            { scrollTop: scrollPos },
+            options.animationDuration,
+            options.animationEasing,
+            () => {
+                if (typeof callback === 'function'){
+                    callback();
+                }
+            }
+        );
+    }
+
+    /**
+     * Destroys the SmoothScroll instance.
+     * @function
+     */
+    _destroy() {
+        this.$element.off('click.zf.smoothScroll', this._linkClickListener);
+        this.$element.off('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
+    }
+}
+
+/**
+ * Default settings for plugin.
+ */
+SmoothScroll.defaults = {
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
+};
+
+/**
+ * Magellan module.
+ * @module foundation.magellan
+ * @requires foundation.smoothScroll
+ */
+
+class Magellan extends Plugin {
+  /**
+   * Creates a new instance of Magellan.
+   * @class
+   * @name Magellan
+   * @fires Magellan#init
+   * @param {Object} element - jQuery object to add the trigger to.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options  = $.extend({}, Magellan.defaults, this.$element.data(), options);
+    this.className = 'Magellan'; // ie9 back compat
+
+    this._init();
+    this.calcPoints();
+  }
+
+  /**
+   * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.
+   * @private
+   */
+  _init() {
+    var id = this.$element[0].id || GetYoDigits(6, 'magellan');
+    this.$targets = $('[data-magellan-target]');
+    this.$links = this.$element.find('a');
+    this.$element.attr({
+      'data-resize': id,
+      'data-scroll': id,
+      'id': id
+    });
+    this.$active = $();
+    this.scrollPos = parseInt(window.pageYOffset, 10);
+
+    this._events();
+  }
+
+  /**
+   * Calculates an array of pixel values that are the demarcation lines between locations on the page.
+   * Can be invoked if new elements are added or the size of a location changes.
+   * @function
+   */
+  calcPoints() {
+    var _this = this,
+        body = document.body,
+        html = document.documentElement;
+
+    this.points = [];
+    this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));
+    this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));
+
+    this.$targets.each(function(){
+      var $tar = $(this),
+          pt = Math.round($tar.offset().top - _this.options.threshold);
+      $tar.targetPoint = pt;
+      _this.points.push(pt);
+    });
+  }
+
+  /**
+   * Initializes events for Magellan.
+   * @private
+   */
+  _events() {
+    var _this = this,
+        $body = $('html, body'),
+        opts = {
+          duration: _this.options.animationDuration,
+          easing:   _this.options.animationEasing
+        };
+
+    $(window).one('load', function(){
+      if(_this.options.deepLinking){
+        if(location.hash){
+          _this.scrollToLoc(location.hash);
+        }
+      }
+      _this.calcPoints();
+      _this._updateActive();
+    });
+
+    _this.onLoadListener = onLoad($(window), function () {
+      _this.$element
+        .on({
+          'resizeme.zf.trigger': _this.reflow.bind(_this),
+          'scrollme.zf.trigger': _this._updateActive.bind(_this)
+        })
+        .on('click.zf.magellan', 'a[href^="#"]', function (e) {
+          e.preventDefault();
+          var arrival   = this.getAttribute('href');
+          _this.scrollToLoc(arrival);
+        });
+    });
+
+    this._deepLinkScroll = function(e) {
+      if(_this.options.deepLinking) {
+        _this.scrollToLoc(window.location.hash);
+      }
+    };
+
+    $(window).on('hashchange', this._deepLinkScroll);
+  }
+
+  /**
+   * Function to scroll to a given location on the page.
+   * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'
+   * @function
+   */
+  scrollToLoc(loc) {
+    this._inTransition = true;
+    var _this = this;
+
+    var options = {
+      animationEasing: this.options.animationEasing,
+      animationDuration: this.options.animationDuration,
+      threshold: this.options.threshold,
+      offset: this.options.offset
+    };
+
+    SmoothScroll.scrollToLoc(loc, options, function() {
+      _this._inTransition = false;
+    });
+  }
+
+  /**
+   * Calls necessary functions to update Magellan upon DOM change
+   * @function
+   */
+  reflow() {
+    this.calcPoints();
+    this._updateActive();
+  }
+
+  /**
+   * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.
+   * @private
+   * @function
+   * @fires Magellan#update
+   */
+  _updateActive(/*evt, elem, scrollPos*/) {
+    if(this._inTransition) return;
+
+    const newScrollPos = parseInt(window.pageYOffset, 10);
+    const isScrollingUp = this.scrollPos > newScrollPos;
+    this.scrollPos = newScrollPos;
+
+    let activeIdx;
+    // Before the first point: no link
+    if(newScrollPos < this.points[0]);
+    // At the bottom of the page: last link
+    else if(newScrollPos + this.winHeight === this.docHeight){ activeIdx = this.points.length - 1; }
+    // Otherwhise, use the last visible link
+    else{
+      const visibleLinks = this.points.filter((p, i) => {
+        return (p - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) <= newScrollPos;
+      });
+      activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;
+    }
+
+    // Get the new active link
+    const $oldActive = this.$active;
+    let activeHash = '';
+    if(typeof activeIdx !== 'undefined'){
+      this.$active = this.$links.filter('[href="#' + this.$targets.eq(activeIdx).data('magellan-target') + '"]');
+      if (this.$active.length) activeHash = this.$active[0].getAttribute('href');
+    }else{
+      this.$active = $();
+    }
+    const isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);
+    const isNewHash = activeHash !== window.location.hash;
+
+    // Update the active link element
+    if(isNewActive) {
+      $oldActive.removeClass(this.options.activeClass);
+      this.$active.addClass(this.options.activeClass);
+    }
+
+    // Update the hash (it may have changed with the same active link)
+    if(this.options.deepLinking && isNewHash){
+      if(window.history.pushState){
+        // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384
+        const url = activeHash ? activeHash : window.location.pathname + window.location.search;
+        window.history.pushState(null, null, url);
+      }else{
+        window.location.hash = activeHash;
+      }
+    }
+
+    if (isNewActive) {
+      /**
+       * Fires when magellan is finished updating to the new active element.
+       * @event Magellan#update
+       */
+       this.$element.trigger('update.zf.magellan', [this.$active]);
+         }
+  }
+
+  /**
+   * Destroys an instance of Magellan and resets the url of the window.
+   * @function
+   */
+  _destroy() {
+    this.$element.off('.zf.trigger .zf.magellan')
+        .find(`.${this.options.activeClass}`).removeClass(this.options.activeClass);
+
+    if(this.options.deepLinking){
+      var hash = this.$active[0].getAttribute('href');
+      window.location.hash.replace(hash, '');
+    }
+
+    $(window).off('hashchange', this._deepLinkScroll);
+    if (this.onLoadListener) $(window).off(this.onLoadListener);
+  }
+}
+
+/**
+ * Default settings for plugin
+ */
+Magellan.defaults = {
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
+  /**
+   * Class applied to the active locations link on the magellan container.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  activeClass: 'is-active',
+  /**
+   * Allows the script to manipulate the url of the current page, and if supported, alter the history.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinking: false,
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
+};
+
+/**
+ * OffCanvas module.
+ * @module foundation.offcanvas
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.triggers
+ */
+
+class OffCanvas extends Plugin {
+  /**
+   * Creates a new instance of an off-canvas wrapper.
+   * @class
+   * @name OffCanvas
+   * @fires OffCanvas#init
+   * @param {Object} element - jQuery object to initialize.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.className = 'OffCanvas'; // ie9 back compat
+    this.$element = element;
+    this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);
+    this.contentClasses = { base: [], reveal: [] };
+    this.$lastTrigger = $();
+    this.$triggers = $();
+    this.position = 'left';
+    this.$content = $();
+    this.nested = !!(this.options.nested);
+
+    // Defines the CSS transition/position classes of the off-canvas content container.
+    $(['push', 'overlap']).each((index, val) => {
+      this.contentClasses.base.push('has-transition-'+val);
+    });
+    $(['left', 'right', 'top', 'bottom']).each((index, val) => {
+      this.contentClasses.base.push('has-position-'+val);
+      this.contentClasses.reveal.push('has-reveal-'+val);
+    });
+
+    // Triggers init is idempotent, just need to make sure it is initialized
+    Triggers.init($);
+    MediaQuery._init();
+
+    this._init();
+    this._events();
+
+    Keyboard.register('OffCanvas', {
+      'ESCAPE': 'close'
+    });
+
+  }
+
+  /**
+   * Initializes the off-canvas wrapper by adding the exit overlay (if needed).
+   * @function
+   * @private
+   */
+  _init() {
+    var id = this.$element.attr('id');
+
+    this.$element.attr('aria-hidden', 'true');
+
+    // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)
+    if (this.options.contentId) {
+      this.$content = $('#'+this.options.contentId);
+    } else if (this.$element.siblings('[data-off-canvas-content]').length) {
+      this.$content = this.$element.siblings('[data-off-canvas-content]').first();
+    } else {
+      this.$content = this.$element.closest('[data-off-canvas-content]').first();
+    }
+
+    if (!this.options.contentId) {
+      // Assume that the off-canvas element is nested if it isn't a sibling of the content
+      this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;
+
+    } else if (this.options.contentId && this.options.nested === null) {
+      // Warning if using content ID without setting the nested option
+      // Once the element is nested it is required to work properly in this case
+      console.warn('Remember to use the nested option if using the content ID option!');
+    }
+
+    if (this.nested === true) {
+      // Force transition overlap if nested
+      this.options.transition = 'overlap';
+      // Remove appropriate classes if already assigned in markup
+      this.$element.removeClass('is-transition-push');
+    }
+
+    this.$element.addClass(`is-transition-${this.options.transition} is-closed`);
+
+    // Find triggers that affect this element and add aria-expanded to them
+    this.$triggers = $(document)
+      .find('[data-open="'+id+'"], [data-close="'+id+'"], [data-toggle="'+id+'"]')
+      .attr('aria-expanded', 'false')
+      .attr('aria-controls', id);
+
+    // Get position by checking for related CSS class
+    this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position;
+
+    // Add an overlay over the content if necessary
+    if (this.options.contentOverlay === true) {
+      var overlay = document.createElement('div');
+      var overlayPosition = $(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';
+      overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);
+      this.$overlay = $(overlay);
+      if(overlayPosition === 'is-overlay-fixed') {
+        $(this.$overlay).insertAfter(this.$element);
+      } else {
+        this.$content.append(this.$overlay);
+      }
+    }
+
+    // Get the revealOn option from the class.
+    var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\s]+)', 'g');
+    var revealOnClass = revealOnRegExp.exec(this.$element[0].className);
+    if (revealOnClass) {
+      this.options.isRevealed = true;
+      this.options.revealOn = this.options.revealOn || revealOnClass[1];
+    }
+
+    // Ensure the `reveal-on-*` class is set.
+    if (this.options.isRevealed === true && this.options.revealOn) {
+      this.$element.first().addClass(`${this.options.revealClass}${this.options.revealOn}`);
+      this._setMQChecker();
+    }
+
+    if (this.options.transitionTime) {
+      this.$element.css('transition-duration', this.options.transitionTime);
+    }
+
+    // Initally remove all transition/position CSS classes from off-canvas content container.
+    this._removeContentClasses();
+  }
+
+  /**
+   * Adds event handlers to the off-canvas wrapper and the exit overlay.
+   * @function
+   * @private
+   */
+  _events() {
+    this.$element.off('.zf.trigger .zf.offcanvas').on({
+      'open.zf.trigger': this.open.bind(this),
+      'close.zf.trigger': this.close.bind(this),
+      'toggle.zf.trigger': this.toggle.bind(this),
+      'keydown.zf.offcanvas': this._handleKeyboard.bind(this)
+    });
+
+    if (this.options.closeOnClick === true) {
+      var $target = this.options.contentOverlay ? this.$overlay : this.$content;
+      $target.on({'click.zf.offcanvas': this.close.bind(this)});
+    }
+  }
+
+  /**
+   * Applies event listener for elements that will reveal at certain breakpoints.
+   * @private
+   */
+  _setMQChecker() {
+    var _this = this;
+
+    this.onLoadListener = onLoad($(window), function () {
+      if (MediaQuery.atLeast(_this.options.revealOn)) {
+        _this.reveal(true);
+      }
+    });
+
+    $(window).on('changed.zf.mediaquery', function () {
+      if (MediaQuery.atLeast(_this.options.revealOn)) {
+        _this.reveal(true);
+      } else {
+        _this.reveal(false);
+      }
+    });
+  }
+
+  /**
+   * Removes the CSS transition/position classes of the off-canvas content container.
+   * Removing the classes is important when another off-canvas gets opened that uses the same content container.
+   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
+   * @private
+   */
+  _removeContentClasses(hasReveal) {
+    if (typeof hasReveal !== 'boolean') {
+      this.$content.removeClass(this.contentClasses.base.join(' '));
+    } else if (hasReveal === false) {
+      this.$content.removeClass(`has-reveal-${this.position}`);
+    }
+  }
+
+  /**
+   * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.
+   * Beforehand any transition/position class gets removed.
+   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
+   * @private
+   */
+  _addContentClasses(hasReveal) {
+    this._removeContentClasses(hasReveal);
+    if (typeof hasReveal !== 'boolean') {
+      this.$content.addClass(`has-transition-${this.options.transition} has-position-${this.position}`);
+    } else if (hasReveal === true) {
+      this.$content.addClass(`has-reveal-${this.position}`);
+    }
+  }
+
+  /**
+   * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.
+   * @param {Boolean} isRevealed - true if element should be revealed.
+   * @function
+   */
+  reveal(isRevealed) {
+    if (isRevealed) {
+      this.close();
+      this.isRevealed = true;
+      this.$element.attr('aria-hidden', 'false');
+      this.$element.off('open.zf.trigger toggle.zf.trigger');
+      this.$element.removeClass('is-closed');
+    } else {
+      this.isRevealed = false;
+      this.$element.attr('aria-hidden', 'true');
+      this.$element.off('open.zf.trigger toggle.zf.trigger').on({
+        'open.zf.trigger': this.open.bind(this),
+        'toggle.zf.trigger': this.toggle.bind(this)
+      });
+      this.$element.addClass('is-closed');
+    }
+    this._addContentClasses(isRevealed);
+  }
+
+  /**
+   * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.
+   * @private
+   */
+  _stopScrolling(event) {
+    return false;
+  }
+
+  // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios
+  // Only really works for y, not sure how to extend to x or if we need to.
+  _recordScrollable(event) {
+    let elem = this; // called from event handler context with this as elem
+
+     // If the element is scrollable (content overflows), then...
+    if (elem.scrollHeight !== elem.clientHeight) {
+      // If we're at the top, scroll down one pixel to allow scrolling up
+      if (elem.scrollTop === 0) {
+        elem.scrollTop = 1;
+      }
+      // If we're at the bottom, scroll up one pixel to allow scrolling down
+      if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {
+        elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;
+      }
+    }
+    elem.allowUp = elem.scrollTop > 0;
+    elem.allowDown = elem.scrollTop < (elem.scrollHeight - elem.clientHeight);
+    elem.lastY = event.originalEvent.pageY;
+  }
+
+  _stopScrollPropagation(event) {
+    let elem = this; // called from event handler context with this as elem
+    let up = event.pageY < elem.lastY;
+    let down = !up;
+    elem.lastY = event.pageY;
+
+    if((up && elem.allowUp) || (down && elem.allowDown)) {
+      event.stopPropagation();
+    } else {
+      event.preventDefault();
+    }
+  }
+
+  /**
+   * Opens the off-canvas menu.
+   * @function
+   * @param {Object} event - Event object passed from listener.
+   * @param {jQuery} trigger - element that triggered the off-canvas to open.
+   * @fires Offcanvas#opened
+   * @todo also trigger 'open' event?
+   */
+  open(event, trigger) {
+    if (this.$element.hasClass('is-open') || this.isRevealed) { return; }
+    var _this = this;
+
+    if (trigger) {
+      this.$lastTrigger = trigger;
+    }
+
+    if (this.options.forceTo === 'top') {
+      window.scrollTo(0, 0);
+    } else if (this.options.forceTo === 'bottom') {
+      window.scrollTo(0,document.body.scrollHeight);
+    }
+
+    if (this.options.transitionTime && this.options.transition !== 'overlap') {
+      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);
+    } else {
+      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');
+    }
+
+    this.$element.addClass('is-open').removeClass('is-closed');
+
+    this.$triggers.attr('aria-expanded', 'true');
+    this.$element.attr('aria-hidden', 'false');
+
+    this.$content.addClass('is-open-' + this.position);
+
+    // If `contentScroll` is set to false, add class and disable scrolling on touch devices.
+    if (this.options.contentScroll === false) {
+      $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);
+      this.$element.on('touchstart', this._recordScrollable);
+      this.$element.on('touchmove', this._stopScrollPropagation);
+    }
+
+    if (this.options.contentOverlay === true) {
+      this.$overlay.addClass('is-visible');
+    }
+
+    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+      this.$overlay.addClass('is-closable');
+    }
+
+    if (this.options.autoFocus === true) {
+      this.$element.one(transitionend(this.$element), function() {
+        if (!_this.$element.hasClass('is-open')) {
+          return; // exit if prematurely closed
+        }
+        var canvasFocus = _this.$element.find('[data-autofocus]');
+        if (canvasFocus.length) {
+            canvasFocus.eq(0).focus();
+        } else {
+            _this.$element.find('a, button').eq(0).focus();
+        }
+      });
+    }
+
+    if (this.options.trapFocus === true) {
+      this.$content.attr('tabindex', '-1');
+      Keyboard.trapFocus(this.$element);
+    }
+
+    this._addContentClasses();
+
+    /**
+     * Fires when the off-canvas menu opens.
+     * @event Offcanvas#opened
+     */
+    this.$element.trigger('opened.zf.offcanvas');
+  }
+
+  /**
+   * Closes the off-canvas menu.
+   * @function
+   * @param {Function} cb - optional cb to fire after closure.
+   * @fires Offcanvas#closed
+   */
+  close(cb) {
+    if (!this.$element.hasClass('is-open') || this.isRevealed) { return; }
+
+    var _this = this;
+
+    this.$element.removeClass('is-open');
+
+    this.$element.attr('aria-hidden', 'true')
+      /**
+       * Fires when the off-canvas menu opens.
+       * @event Offcanvas#closed
+       */
+        .trigger('closed.zf.offcanvas');
+
+    this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');
+
+    // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.
+    if (this.options.contentScroll === false) {
+      $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);
+      this.$element.off('touchstart', this._recordScrollable);
+      this.$element.off('touchmove', this._stopScrollPropagation);
+    }
+
+    if (this.options.contentOverlay === true) {
+      this.$overlay.removeClass('is-visible');
+    }
+
+    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+      this.$overlay.removeClass('is-closable');
+    }
+
+    this.$triggers.attr('aria-expanded', 'false');
+
+    if (this.options.trapFocus === true) {
+      this.$content.removeAttr('tabindex');
+      Keyboard.releaseFocus(this.$element);
+    }
+
+    // Listen to transitionEnd and add class when done.
+    this.$element.one(transitionend(this.$element), function(e) {
+      _this.$element.addClass('is-closed');
+      _this._removeContentClasses();
+    });
+  }
+
+  /**
+   * Toggles the off-canvas menu open or closed.
+   * @function
+   * @param {Object} event - Event object passed from listener.
+   * @param {jQuery} trigger - element that triggered the off-canvas to open.
+   */
+  toggle(event, trigger) {
+    if (this.$element.hasClass('is-open')) {
+      this.close(event, trigger);
+    }
+    else {
+      this.open(event, trigger);
+    }
+  }
+
+  /**
+   * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.
+   * @function
+   * @private
+   */
+  _handleKeyboard(e) {
+    Keyboard.handleKey(e, 'OffCanvas', {
+      close: () => {
+        this.close();
+        this.$lastTrigger.focus();
+        return true;
+      },
+      handled: () => {
+        e.stopPropagation();
+        e.preventDefault();
+      }
+    });
+  }
+
+  /**
+   * Destroys the offcanvas plugin.
+   * @function
+   */
+  _destroy() {
+    this.close();
+    this.$element.off('.zf.trigger .zf.offcanvas');
+    this.$overlay.off('.zf.offcanvas');
+    if (this.onLoadListener) $(window).off(this.onLoadListener);
+  }
+}
+
+OffCanvas.defaults = {
+  /**
+   * Allow the user to click outside of the menu to close it.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Adds an overlay on top of `[data-off-canvas-content]`.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  contentOverlay: true,
+
+  /**
+   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  contentId: null,
+
+  /**
+   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.
+   * @option
+   * @type {boolean}
+   * @default null
+   */
+  nested: null,
+
+  /**
+   * Enable/disable scrolling of the main content when an off canvas panel is open.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  contentScroll: true,
+
+  /**
+   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.
+   * @option
+   * @type {number}
+   * @default null
+   */
+  transitionTime: null,
+
+  /**
+   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.
+   * @option
+   * @type {string}
+   * @default push
+   */
+  transition: 'push',
+
+  /**
+   * Force the page to scroll to top or bottom on open.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  forceTo: null,
+
+  /**
+   * Allow the offcanvas to remain open for certain breakpoints.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  isRevealed: false,
+
+  /**
+   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  revealOn: null,
+
+  /**
+   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  autoFocus: true,
+
+  /**
+   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.
+   * @option
+   * @type {string}
+   * @default reveal-for-
+   * @todo improve the regex testing for this.
+   */
+  revealClass: 'reveal-for-',
+
+  /**
+   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  trapFocus: false
+};
+
+/**
+ * Orbit module.
+ * @module foundation.orbit
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.motion
+ * @requires foundation.util.timer
+ * @requires foundation.util.imageLoader
+ * @requires foundation.util.touch
+ */
+
+class Orbit extends Plugin {
+  /**
+  * Creates a new instance of an orbit carousel.
+  * @class
+  * @name Orbit
+  * @param {jQuery} element - jQuery object to make into an Orbit Carousel.
+  * @param {Object} options - Overrides to the default plugin settings.
+  */
+  _setup(element, options){
+    this.$element = element;
+    this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);
+    this.className = 'Orbit'; // ie9 back compat
+
+    Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.
+
+    this._init();
+
+    Keyboard.register('Orbit', {
+      'ltr': {
+        'ARROW_RIGHT': 'next',
+        'ARROW_LEFT': 'previous'
+      },
+      'rtl': {
+        'ARROW_LEFT': 'next',
+        'ARROW_RIGHT': 'previous'
+      }
+    });
+  }
+
+  /**
+  * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.
+  * @function
+  * @private
+  */
+  _init() {
+    // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide
+    this._reset();
+
+    this.$wrapper = this.$element.find(`.${this.options.containerClass}`);
+    this.$slides = this.$element.find(`.${this.options.slideClass}`);
+
+    var $images = this.$element.find('img'),
+        initActive = this.$slides.filter('.is-active'),
+        id = this.$element[0].id || GetYoDigits(6, 'orbit');
+
+    this.$element.attr({
+      'data-resize': id,
+      'id': id
+    });
+
+    if (!initActive.length) {
+      this.$slides.eq(0).addClass('is-active');
+    }
+
+    if (!this.options.useMUI) {
+      this.$slides.addClass('no-motionui');
+    }
+
+    if ($images.length) {
+      onImagesLoaded($images, this._prepareForOrbit.bind(this));
+    } else {
+      this._prepareForOrbit();//hehe
+    }
+
+    if (this.options.bullets) {
+      this._loadBullets();
+    }
+
+    this._events();
+
+    if (this.options.autoPlay && this.$slides.length > 1) {
+      this.geoSync();
+    }
+
+    if (this.options.accessible) { // allow wrapper to be focusable to enable arrow navigation
+      this.$wrapper.attr('tabindex', 0);
+    }
+  }
+
+  /**
+  * Creates a jQuery collection of bullets, if they are being used.
+  * @function
+  * @private
+  */
+  _loadBullets() {
+    this.$bullets = this.$element.find(`.${this.options.boxOfBullets}`).find('button');
+  }
+
+  /**
+  * Sets a `timer` object on the orbit, and starts the counter for the next slide.
+  * @function
+  */
+  geoSync() {
+    var _this = this;
+    this.timer = new Timer(
+      this.$element,
+      {
+        duration: this.options.timerDelay,
+        infinite: false
+      },
+      function() {
+        _this.changeSlide(true);
+      });
+    this.timer.start();
+  }
+
+  /**
+  * Sets wrapper and slide heights for the orbit.
+  * @function
+  * @private
+  */
+  _prepareForOrbit() {
+    this._setWrapperHeight();
+  }
+
+  /**
+  * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.
+  * @function
+  * @private
+  * @param {Function} cb - a callback function to fire when complete.
+  */
+  _setWrapperHeight(cb) {//rewrite this to `for` loop
+    var max = 0, temp, counter = 0, _this = this;
+
+    this.$slides.each(function() {
+      temp = this.getBoundingClientRect().height;
+      $(this).attr('data-slide', counter);
+
+      // hide all slides but the active one
+      if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {
+        $(this).css({'display': 'none'});
+      }
+      max = temp > max ? temp : max;
+      counter++;
+    });
+
+    if (counter === this.$slides.length) {
+      this.$wrapper.css({'height': max}); //only change the wrapper height property once.
+      if(cb) {cb(max);} //fire callback with max height dimension.
+    }
+  }
+
+  /**
+  * Sets the max-height of each slide.
+  * @function
+  * @private
+  */
+  _setSlideHeight(height) {
+    this.$slides.each(function() {
+      $(this).css('max-height', height);
+    });
+  }
+
+  /**
+  * Adds event listeners to basically everything within the element.
+  * @function
+  * @private
+  */
+  _events() {
+    var _this = this;
+
+    //***************************************
+    //**Now using custom event - thanks to:**
+    //**      Yohai Ararat of Toronto      **
+    //***************************************
+    //
+    this.$element.off('.resizeme.zf.trigger').on({
+      'resizeme.zf.trigger': this._prepareForOrbit.bind(this)
+    });
+    if (this.$slides.length > 1) {
+
+      if (this.options.swipe) {
+        this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit')
+        .on('swipeleft.zf.orbit', function(e){
+          e.preventDefault();
+          _this.changeSlide(true);
+        }).on('swiperight.zf.orbit', function(e){
+          e.preventDefault();
+          _this.changeSlide(false);
+        });
+      }
+      //***************************************
+
+      if (this.options.autoPlay) {
+        this.$slides.on('click.zf.orbit', function() {
+          _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);
+          _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();
+        });
+
+        if (this.options.pauseOnHover) {
+          this.$element.on('mouseenter.zf.orbit', function() {
+            _this.timer.pause();
+          }).on('mouseleave.zf.orbit', function() {
+            if (!_this.$element.data('clickedOn')) {
+              _this.timer.start();
+            }
+          });
+        }
+      }
+
+      if (this.options.navButtons) {
+        var $controls = this.$element.find(`.${this.options.nextClass}, .${this.options.prevClass}`);
+        $controls.attr('tabindex', 0)
+        //also need to handle enter/return and spacebar key presses
+        .on('click.zf.orbit touchend.zf.orbit', function(e){
+         e.preventDefault();
+          _this.changeSlide($(this).hasClass(_this.options.nextClass));
+        });
+      }
+
+      if (this.options.bullets) {
+        this.$bullets.on('click.zf.orbit touchend.zf.orbit', function() {
+          if (/is-active/g.test(this.className)) { return false; }//if this is active, kick out of function.
+          var idx = $(this).data('slide'),
+          ltr = idx > _this.$slides.filter('.is-active').data('slide'),
+          $slide = _this.$slides.eq(idx);
+
+          _this.changeSlide(ltr, $slide, idx);
+        });
+      }
+
+      if (this.options.accessible) {
+        this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function(e) {
+          // handle keyboard event with keyboard util
+          Keyboard.handleKey(e, 'Orbit', {
+            next: function() {
+              _this.changeSlide(true);
+            },
+            previous: function() {
+              _this.changeSlide(false);
+            },
+            handled: function() { // if bullet is focused, make sure focus moves
+              if ($(e.target).is(_this.$bullets)) {
+                _this.$bullets.filter('.is-active').focus();
+              }
+            }
+          });
+        });
+      }
+    }
+  }
+
+  /**
+   * Resets Orbit so it can be reinitialized
+   */
+  _reset() {
+    // Don't do anything if there are no slides (first run)
+    if (typeof this.$slides == 'undefined') {
+      return;
+    }
+
+    if (this.$slides.length > 1) {
+      // Remove old events
+      this.$element.off('.zf.orbit').find('*').off('.zf.orbit');
+
+      // Restart timer if autoPlay is enabled
+      if (this.options.autoPlay) {
+        this.timer.restart();
+      }
+
+      // Reset all sliddes
+      this.$slides.each(function(el) {
+        $(el).removeClass('is-active is-active is-in')
+          .removeAttr('aria-live')
+          .hide();
+      });
+
+      // Show the first slide
+      this.$slides.first().addClass('is-active').show();
+
+      // Triggers when the slide has finished animating
+      this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);
+
+      // Select first bullet if bullets are present
+      if (this.options.bullets) {
+        this._updateBullets(0);
+      }
+    }
+  }
+
+  /**
+  * Changes the current slide to a new one.
+  * @function
+  * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.
+  * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.
+  * @param {Number} idx - the index of the new slide in its collection, if one chosen.
+  * @fires Orbit#slidechange
+  */
+  changeSlide(isLTR, chosenSlide, idx) {
+    if (!this.$slides) {return; } // Don't freak out if we're in the middle of cleanup
+    var $curSlide = this.$slides.filter('.is-active').eq(0);
+
+    if (/mui/g.test($curSlide[0].className)) { return false; } //if the slide is currently animating, kick out of the function
+
+    var $firstSlide = this.$slides.first(),
+    $lastSlide = this.$slides.last(),
+    dirIn = isLTR ? 'Right' : 'Left',
+    dirOut = isLTR ? 'Left' : 'Right',
+    _this = this,
+    $newSlide;
+
+    if (!chosenSlide) { //most of the time, this will be auto played or clicked from the navButtons.
+      $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!
+      (this.options.infiniteWrap ? $curSlide.next(`.${this.options.slideClass}`).length ? $curSlide.next(`.${this.options.slideClass}`) : $firstSlide : $curSlide.next(`.${this.options.slideClass}`))//pick next slide if moving left to right
+      :
+      (this.options.infiniteWrap ? $curSlide.prev(`.${this.options.slideClass}`).length ? $curSlide.prev(`.${this.options.slideClass}`) : $lastSlide : $curSlide.prev(`.${this.options.slideClass}`));//pick prev slide if moving right to left
+    } else {
+      $newSlide = chosenSlide;
+    }
+
+    if ($newSlide.length) {
+      /**
+      * Triggers before the next slide starts animating in and only if a next slide has been found.
+      * @event Orbit#beforeslidechange
+      */
+      this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);
+
+      if (this.options.bullets) {
+        idx = idx || this.$slides.index($newSlide); //grab index to update bullets
+        this._updateBullets(idx);
+      }
+
+      if (this.options.useMUI && !this.$element.is(':hidden')) {
+        Motion.animateIn(
+          $newSlide.addClass('is-active'),
+          this.options[`animInFrom${dirIn}`],
+          function(){
+            $newSlide.css({'display': 'block'}).attr('aria-live', 'polite');
+        });
+
+        Motion.animateOut(
+          $curSlide.removeClass('is-active'),
+          this.options[`animOutTo${dirOut}`],
+          function(){
+            $curSlide.removeAttr('aria-live');
+            if(_this.options.autoPlay && !_this.timer.isPaused){
+              _this.timer.restart();
+            }
+            //do stuff?
+          });
+      } else {
+        $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();
+        $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();
+        if (this.options.autoPlay && !this.timer.isPaused) {
+          this.timer.restart();
+        }
+      }
+    /**
+    * Triggers when the slide has finished animating in.
+    * @event Orbit#slidechange
+    */
+      this.$element.trigger('slidechange.zf.orbit', [$newSlide]);
+    }
+  }
+
+  /**
+  * Updates the active state of the bullets, if displayed.
+  * @function
+  * @private
+  * @param {Number} idx - the index of the current slide.
+  */
+  _updateBullets(idx) {
+    var $oldBullet = this.$element.find(`.${this.options.boxOfBullets}`)
+    .find('.is-active').removeClass('is-active').blur(),
+    span = $oldBullet.find('span:last').detach(),
+    $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);
+  }
+
+  /**
+  * Destroys the carousel and hides the element.
+  * @function
+  */
+  _destroy() {
+    this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();
+  }
+}
+
+Orbit.defaults = {
+  /**
+  * Tells the JS to look for and loadBullets.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  bullets: true,
+  /**
+  * Tells the JS to apply event listeners to nav buttons
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  navButtons: true,
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-in-right'
+  */
+  animInFromRight: 'slide-in-right',
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-out-right'
+  */
+  animOutToRight: 'slide-out-right',
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-in-left'
+  *
+  */
+  animInFromLeft: 'slide-in-left',
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-out-left'
+  */
+  animOutToLeft: 'slide-out-left',
+  /**
+  * Allows Orbit to automatically animate on page load.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  autoPlay: true,
+  /**
+  * Amount of time, in ms, between slide transitions
+  * @option
+   * @type {number}
+  * @default 5000
+  */
+  timerDelay: 5000,
+  /**
+  * Allows Orbit to infinitely loop through the slides
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  infiniteWrap: true,
+  /**
+  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  swipe: true,
+  /**
+  * Allows the timing function to pause animation on hover.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  pauseOnHover: true,
+  /**
+  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  accessible: true,
+  /**
+  * Class applied to the container of Orbit
+  * @option
+   * @type {string}
+  * @default 'orbit-container'
+  */
+  containerClass: 'orbit-container',
+  /**
+  * Class applied to individual slides.
+  * @option
+   * @type {string}
+  * @default 'orbit-slide'
+  */
+  slideClass: 'orbit-slide',
+  /**
+  * Class applied to the bullet container. You're welcome.
+  * @option
+   * @type {string}
+  * @default 'orbit-bullets'
+  */
+  boxOfBullets: 'orbit-bullets',
+  /**
+  * Class applied to the `next` navigation button.
+  * @option
+   * @type {string}
+  * @default 'orbit-next'
+  */
+  nextClass: 'orbit-next',
+  /**
+  * Class applied to the `previous` navigation button.
+  * @option
+   * @type {string}
+  * @default 'orbit-previous'
+  */
+  prevClass: 'orbit-previous',
+  /**
+  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  useMUI: true
+};
+
+let MenuPlugins = {
+  dropdown: {
+    cssClass: 'dropdown',
+    plugin: DropdownMenu
+  },
+ drilldown: {
+    cssClass: 'drilldown',
+    plugin: Drilldown
+  },
+  accordion: {
+    cssClass: 'accordion-menu',
+    plugin: AccordionMenu
+  }
+};
+
+  // import "foundation.util.triggers.js";
+
+
+/**
+ * ResponsiveMenu module.
+ * @module foundation.responsiveMenu
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ */
+
+class ResponsiveMenu extends Plugin {
+  /**
+   * Creates a new instance of a responsive menu.
+   * @class
+   * @name ResponsiveMenu
+   * @fires ResponsiveMenu#init
+   * @param {jQuery} element - jQuery object to make into a dropdown menu.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = $(element);
+    this.rules = this.$element.data('responsive-menu');
+    this.currentMq = null;
+    this.currentPlugin = null;
+    this.className = 'ResponsiveMenu'; // ie9 back compat
+
+    this._init();
+    this._events();
+  }
+
+  /**
+   * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.
+   * @function
+   * @private
+   */
+  _init() {
+
+    MediaQuery._init();
+    // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
+    if (typeof this.rules === 'string') {
+      let rulesTree = {};
+
+      // Parse rules from "classes" pulled from data attribute
+      let rules = this.rules.split(' ');
+
+      // Iterate through every rule found
+      for (let i = 0; i < rules.length; i++) {
+        let rule = rules[i].split('-');
+        let ruleSize = rule.length > 1 ? rule[0] : 'small';
+        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+
+        if (MenuPlugins[rulePlugin] !== null) {
+          rulesTree[ruleSize] = MenuPlugins[rulePlugin];
+        }
+      }
+
+      this.rules = rulesTree;
+    }
+
+    if (!$.isEmptyObject(this.rules)) {
+      this._checkMediaQueries();
+    }
+    // Add data-mutate since children may need it.
+    this.$element.attr('data-mutate', (this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')));
+  }
+
+  /**
+   * Initializes events for the Menu.
+   * @function
+   * @private
+   */
+  _events() {
+    var _this = this;
+
+    $(window).on('changed.zf.mediaquery', function() {
+      _this._checkMediaQueries();
+    });
+    // $(window).on('resize.zf.ResponsiveMenu', function() {
+    //   _this._checkMediaQueries();
+    // });
+  }
+
+  /**
+   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
+   * @function
+   * @private
+   */
+  _checkMediaQueries() {
+    var matchedMq, _this = this;
+    // Iterate through each rule and find the last matching rule
+    $.each(this.rules, function(key) {
+      if (MediaQuery.atLeast(key)) {
+        matchedMq = key;
+      }
+    });
+
+    // No match? No dice
+    if (!matchedMq) return;
+
+    // Plugin already initialized? We good
+    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;
+
+    // Remove existing plugin-specific CSS classes
+    $.each(MenuPlugins, function(key, value) {
+      _this.$element.removeClass(value.cssClass);
+    });
+
+    // Add the CSS class for the new plugin
+    this.$element.addClass(this.rules[matchedMq].cssClass);
+
+    // Create an instance of the new plugin
+    if (this.currentPlugin) this.currentPlugin.destroy();
+    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+  }
+
+  /**
+   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+   * @function
+   */
+  _destroy() {
+    this.currentPlugin.destroy();
+    $(window).off('.zf.ResponsiveMenu');
+  }
+}
+
+ResponsiveMenu.defaults = {};
+
+/**
+ * ResponsiveToggle module.
+ * @module foundation.responsiveToggle
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.motion
+ */
+
+class ResponsiveToggle extends Plugin {
+  /**
+   * Creates a new instance of Tab Bar.
+   * @class
+   * @name ResponsiveToggle
+   * @fires ResponsiveToggle#init
+   * @param {jQuery} element - jQuery object to attach tab bar functionality to.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = $(element);
+    this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
+    this.className = 'ResponsiveToggle'; // ie9 back compat
+
+    this._init();
+    this._events();
+  }
+
+  /**
+   * Initializes the tab bar by finding the target element, toggling element, and running update().
+   * @function
+   * @private
+   */
+  _init() {
+    MediaQuery._init();
+    var targetID = this.$element.data('responsive-toggle');
+    if (!targetID) {
+      console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');
+    }
+
+    this.$targetMenu = $(`#${targetID}`);
+    this.$toggler = this.$element.find('[data-toggle]').filter(function() {
+      var target = $(this).data('toggle');
+      return (target === targetID || target === "");
+    });
+    this.options = $.extend({}, this.options, this.$targetMenu.data());
+
+    // If they were set, parse the animation classes
+    if(this.options.animate) {
+      let input = this.options.animate.split(' ');
+
+      this.animationIn = input[0];
+      this.animationOut = input[1] || null;
+    }
+
+    this._update();
+  }
+
+  /**
+   * Adds necessary event handlers for the tab bar to work.
+   * @function
+   * @private
+   */
+  _events() {
+
+    this._updateMqHandler = this._update.bind(this);
+
+    $(window).on('changed.zf.mediaquery', this._updateMqHandler);
+
+    this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));
+  }
+
+  /**
+   * Checks the current media query to determine if the tab bar should be visible or hidden.
+   * @function
+   * @private
+   */
+  _update() {
+    // Mobile
+    if (!MediaQuery.atLeast(this.options.hideFor)) {
+      this.$element.show();
+      this.$targetMenu.hide();
+    }
+
+    // Desktop
+    else {
+      this.$element.hide();
+      this.$targetMenu.show();
+    }
+  }
+
+  /**
+   * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.
+   * @function
+   * @fires ResponsiveToggle#toggled
+   */
+  toggleMenu() {
+    if (!MediaQuery.atLeast(this.options.hideFor)) {
+      /**
+       * Fires when the element attached to the tab bar toggles.
+       * @event ResponsiveToggle#toggled
+       */
+      if(this.options.animate) {
+        if (this.$targetMenu.is(':hidden')) {
+          Motion.animateIn(this.$targetMenu, this.animationIn, () => {
+            this.$element.trigger('toggled.zf.responsiveToggle');
+            this.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
+          });
+        }
+        else {
+          Motion.animateOut(this.$targetMenu, this.animationOut, () => {
+            this.$element.trigger('toggled.zf.responsiveToggle');
+          });
+        }
+      }
+      else {
+        this.$targetMenu.toggle(0);
+        this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');
+        this.$element.trigger('toggled.zf.responsiveToggle');
+      }
+    }
+  };
+
+  _destroy() {
+    this.$element.off('.zf.responsiveToggle');
+    this.$toggler.off('.zf.responsiveToggle');
+
+    $(window).off('changed.zf.mediaquery', this._updateMqHandler);
+  }
+}
+
+ResponsiveToggle.defaults = {
+  /**
+   * The breakpoint after which the menu is always shown, and the tab bar is hidden.
+   * @option
+   * @type {string}
+   * @default 'medium'
+   */
+  hideFor: 'medium',
+
+  /**
+   * To decide if the toggle should be animated or not.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animate: false
+};
+
+/**
+ * Reveal module.
+ * @module foundation.reveal
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.motion if using animations
+ */
+
+class Reveal extends Plugin {
+  /**
+   * Creates a new instance of Reveal.
+   * @class
+   * @name Reveal
+   * @param {jQuery} element - jQuery object to use for the modal.
+   * @param {Object} options - optional parameters.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);
+    this.className = 'Reveal'; // ie9 back compat
+    this._init();
+
+    // Triggers init is idempotent, just need to make sure it is initialized
+    Triggers.init($);
+
+    Keyboard.register('Reveal', {
+      'ESCAPE': 'close',
+    });
+  }
+
+  /**
+   * Initializes the modal by adding the overlay and close buttons, (if selected).
+   * @private
+   */
+  _init() {
+    MediaQuery._init();
+    this.id = this.$element.attr('id');
+    this.isActive = false;
+    this.cached = {mq: MediaQuery.current};
+
+    this.$anchor = $(`[data-open="${this.id}"]`).length ? $(`[data-open="${this.id}"]`) : $(`[data-toggle="${this.id}"]`);
+    this.$anchor.attr({
+      'aria-controls': this.id,
+      'aria-haspopup': true,
+      'tabindex': 0
+    });
+
+    if (this.options.fullScreen || this.$element.hasClass('full')) {
+      this.options.fullScreen = true;
+      this.options.overlay = false;
+    }
+    if (this.options.overlay && !this.$overlay) {
+      this.$overlay = this._makeOverlay(this.id);
+    }
+
+    this.$element.attr({
+        'role': 'dialog',
+        'aria-hidden': true,
+        'data-yeti-box': this.id,
+        'data-resize': this.id
+    });
+
+    if(this.$overlay) {
+      this.$element.detach().appendTo(this.$overlay);
+    } else {
+      this.$element.detach().appendTo($(this.options.appendTo));
+      this.$element.addClass('without-overlay');
+    }
+    this._events();
+    if (this.options.deepLink && window.location.hash === ( `#${this.id}`)) {
+      this.onLoadListener = onLoad($(window), () => this.open());
+    }
+  }
+
+  /**
+   * Creates an overlay div to display behind the modal.
+   * @private
+   */
+  _makeOverlay() {
+    var additionalOverlayClasses = '';
+
+    if (this.options.additionalOverlayClasses) {
+      additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;
+    }
+
+    return $('<div></div>')
+      .addClass('reveal-overlay' + additionalOverlayClasses)
+      .appendTo(this.options.appendTo);
+  }
+
+  /**
+   * Updates position of modal
+   * TODO:  Figure out if we actually need to cache these values or if it doesn't matter
+   * @private
+   */
+  _updatePosition() {
+    var width = this.$element.outerWidth();
+    var outerWidth = $(window).width();
+    var height = this.$element.outerHeight();
+    var outerHeight = $(window).height();
+    var left, top = null;
+    if (this.options.hOffset === 'auto') {
+      left = parseInt((outerWidth - width) / 2, 10);
+    } else {
+      left = parseInt(this.options.hOffset, 10);
+    }
+    if (this.options.vOffset === 'auto') {
+      if (height > outerHeight) {
+        top = parseInt(Math.min(100, outerHeight / 10), 10);
+      } else {
+        top = parseInt((outerHeight - height) / 4, 10);
+      }
+    } else if (this.options.vOffset !== null) {
+      top = parseInt(this.options.vOffset, 10);
+    }
+
+    if (top !== null) {
+      this.$element.css({top: top + 'px'});
+    }
+
+    // only worry about left if we don't have an overlay or we have a horizontal offset,
+    // otherwise we're perfectly in the middle
+    if (!this.$overlay || (this.options.hOffset !== 'auto')) {
+      this.$element.css({left: left + 'px'});
+      this.$element.css({margin: '0px'});
+    }
+
+  }
+
+  /**
+   * Adds event handlers for the modal.
+   * @private
+   */
+  _events() {
+    var _this = this;
+
+    this.$element.on({
+      'open.zf.trigger': this.open.bind(this),
+      'close.zf.trigger': (event, $element) => {
+        if ((event.target === _this.$element[0]) ||
+            ($(event.target).parents('[data-closable]')[0] === $element)) { // only close reveal when it's explicitly called
+          return this.close.apply(this);
+        }
+      },
+      'toggle.zf.trigger': this.toggle.bind(this),
+      'resizeme.zf.trigger': function() {
+        _this._updatePosition();
+      }
+    });
+
+    if (this.options.closeOnClick && this.options.overlay) {
+      this.$overlay.off('.zf.reveal').on('click.zf.reveal', function(e) {
+        if (e.target === _this.$element[0] ||
+          $.contains(_this.$element[0], e.target) ||
+            !$.contains(document, e.target)) {
+              return;
+        }
+        _this.close();
+      });
+    }
+    if (this.options.deepLink) {
+      $(window).on(`hashchange.zf.reveal:${this.id}`, this._handleState.bind(this));
+    }
+  }
+
+  /**
+   * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.
+   * @private
+   */
+  _handleState(e) {
+    if(window.location.hash === ( '#' + this.id) && !this.isActive){ this.open(); }
+    else{ this.close(); }
+  }
+
+  /**
+  * Disables the scroll when Reveal is shown to prevent the background from shifting
+  * @param {number} scrollTop - Scroll to visually apply, window current scroll by default
+  */
+  _disableScroll(scrollTop) {
+    scrollTop = scrollTop || $(window).scrollTop();
+    if ($(document).height() > $(window).height()) {
+      $("html")
+        .css("top", -scrollTop);
+    }
+  }
+
+  /**
+  * Reenables the scroll when Reveal closes
+  * @param {number} scrollTop - Scroll to restore, html "top" property by default (as set by `_disableScroll`)
+  */
+  _enableScroll(scrollTop) {
+    scrollTop = scrollTop || parseInt($("html").css("top"));
+    if ($(document).height() > $(window).height()) {
+      $("html")
+        .css("top", "");
+      $(window).scrollTop(-scrollTop);
+    }
+  }
+
+
+  /**
+   * Opens the modal controlled by `this.$anchor`, and closes all others by default.
+   * @function
+   * @fires Reveal#closeme
+   * @fires Reveal#open
+   */
+  open() {
+    // either update or replace browser history
+    const hash = `#${this.id}`;
+    if (this.options.deepLink && window.location.hash !== hash) {
+
+      if (window.history.pushState) {
+        if (this.options.updateHistory) {
+          window.history.pushState({}, '', hash);
+        } else {
+          window.history.replaceState({}, '', hash);
+        }
+      } else {
+        window.location.hash = hash;
+      }
+    }
+
+    // Remember anchor that opened it to set focus back later, have general anchors as fallback
+    this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;
+
+    this.isActive = true;
+
+    // Make elements invisible, but remove display: none so we can get size and positioning
+    this.$element
+        .css({ 'visibility': 'hidden' })
+        .show()
+        .scrollTop(0);
+    if (this.options.overlay) {
+      this.$overlay.css({'visibility': 'hidden'}).show();
+    }
+
+    this._updatePosition();
+
+    this.$element
+      .hide()
+      .css({ 'visibility': '' });
+
+    if(this.$overlay) {
+      this.$overlay.css({'visibility': ''}).hide();
+      if(this.$element.hasClass('fast')) {
+        this.$overlay.addClass('fast');
+      } else if (this.$element.hasClass('slow')) {
+        this.$overlay.addClass('slow');
+      }
+    }
+
+
+    if (!this.options.multipleOpened) {
+      /**
+       * Fires immediately before the modal opens.
+       * Closes any other modals that are currently open
+       * @event Reveal#closeme
+       */
+      this.$element.trigger('closeme.zf.reveal', this.id);
+    }
+
+    this._disableScroll();
+
+    var _this = this;
+
+    // Motion UI method of reveal
+    if (this.options.animationIn) {
+      function afterAnimation(){
+        _this.$element
+          .attr({
+            'aria-hidden': false,
+            'tabindex': -1
+          })
+          .focus();
+        _this._addGlobalClasses();
+        Keyboard.trapFocus(_this.$element);
+      }
+      if (this.options.overlay) {
+        Motion.animateIn(this.$overlay, 'fade-in');
+      }
+      Motion.animateIn(this.$element, this.options.animationIn, () => {
+        if(this.$element) { // protect against object having been removed
+          this.focusableElements = Keyboard.findFocusable(this.$element);
+          afterAnimation();
+        }
+      });
+    }
+    // jQuery method of reveal
+    else {
+      if (this.options.overlay) {
+        this.$overlay.show(0);
+      }
+      this.$element.show(this.options.showDelay);
+    }
+
+    // handle accessibility
+    this.$element
+      .attr({
+        'aria-hidden': false,
+        'tabindex': -1
+      })
+      .focus();
+    Keyboard.trapFocus(this.$element);
+
+    this._addGlobalClasses();
+
+    this._addGlobalListeners();
+
+    /**
+     * Fires when the modal has successfully opened.
+     * @event Reveal#open
+     */
+    this.$element.trigger('open.zf.reveal');
+  }
+
+  /**
+   * Adds classes and listeners on document required by open modals.
+   *
+   * The following classes are added and updated:
+   * - `.is-reveal-open` - Prevents the scroll on document
+   * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the
+   *                       scroll was not disabled. This prevent a "shift" of the page content due
+   *                       the scrollbar disappearing when the modal opens.
+   *
+   * @private
+   */
+  _addGlobalClasses() {
+    const updateScrollbarClass = () => {
+      $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));
+    };
+
+    this.$element.on('resizeme.zf.trigger.revealScrollbarListener', () => updateScrollbarClass());
+    updateScrollbarClass();
+    $('html').addClass('is-reveal-open');
+  }
+
+  /**
+   * Removes classes and listeners on document that were required by open modals.
+   * @private
+   */
+  _removeGlobalClasses() {
+    this.$element.off('resizeme.zf.trigger.revealScrollbarListener');
+    $('html').removeClass('is-reveal-open');
+    $('html').removeClass('zf-has-scroll');
+  }
+
+  /**
+   * Adds extra event handlers for the body and window if necessary.
+   * @private
+   */
+  _addGlobalListeners() {
+    var _this = this;
+    if(!this.$element) { return; } // If we're in the middle of cleanup, don't freak out
+    this.focusableElements = Keyboard.findFocusable(this.$element);
+
+    if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {
+      $('body').on('click.zf.reveal', function(e) {
+        if (e.target === _this.$element[0] ||
+          $.contains(_this.$element[0], e.target) ||
+            !$.contains(document, e.target)) { return; }
+        _this.close();
+      });
+    }
+
+    if (this.options.closeOnEsc) {
+      $(window).on('keydown.zf.reveal', function(e) {
+        Keyboard.handleKey(e, 'Reveal', {
+          close: function() {
+            if (_this.options.closeOnEsc) {
+              _this.close();
+            }
+          }
+        });
+      });
+    }
+  }
+
+  /**
+   * Closes the modal.
+   * @function
+   * @fires Reveal#closed
+   */
+  close() {
+    if (!this.isActive || !this.$element.is(':visible')) {
+      return false;
+    }
+    var _this = this;
+
+    // Motion UI method of hiding
+    if (this.options.animationOut) {
+      if (this.options.overlay) {
+        Motion.animateOut(this.$overlay, 'fade-out');
+      }
+
+      Motion.animateOut(this.$element, this.options.animationOut, finishUp);
+    }
+    // jQuery method of hiding
+    else {
+      this.$element.hide(this.options.hideDelay);
+
+      if (this.options.overlay) {
+        this.$overlay.hide(0, finishUp);
+      }
+      else {
+        finishUp();
+      }
+    }
+
+    // Conditionals to remove extra event listeners added on open
+    if (this.options.closeOnEsc) {
+      $(window).off('keydown.zf.reveal');
+    }
+
+    if (!this.options.overlay && this.options.closeOnClick) {
+      $('body').off('click.zf.reveal');
+    }
+
+    this.$element.off('keydown.zf.reveal');
+
+    function finishUp() {
+
+      // Get the current top before the modal is closed and restore the scroll after.
+      // TODO: use component properties instead of HTML properties
+      // See https://github.com/zurb/foundation-sites/pull/10786
+      var scrollTop = parseInt($("html").css("top"));
+
+      if ($('.reveal:visible').length  === 0) {
+        _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
+      }
+
+      Keyboard.releaseFocus(_this.$element);
+
+      _this.$element.attr('aria-hidden', true);
+
+      _this._enableScroll(scrollTop);
+
+      /**
+      * Fires when the modal is done closing.
+      * @event Reveal#closed
+      */
+      _this.$element.trigger('closed.zf.reveal');
+    }
+
+    /**
+    * Resets the modal content
+    * This prevents a running video to keep going in the background
+    */
+    if (this.options.resetOnClose) {
+      this.$element.html(this.$element.html());
+    }
+
+    this.isActive = false;
+    // If deepLink and we did not switched to an other modal...
+    if (_this.options.deepLink && window.location.hash === `#${this.id}`) {
+      // Remove the history hash
+      if (window.history.replaceState) {
+        const urlWithoutHash = window.location.pathname + window.location.search;
+        if (this.options.updateHistory) {
+          window.history.pushState({}, '', urlWithoutHash); // remove the hash
+        } else {
+          window.history.replaceState('', document.title, urlWithoutHash);
+        }
+      } else {
+        window.location.hash = '';
+      }
+    }
+
+    this.$activeAnchor.focus();
+  }
+
+  /**
+   * Toggles the open/closed state of a modal.
+   * @function
+   */
+  toggle() {
+    if (this.isActive) {
+      this.close();
+    } else {
+      this.open();
+    }
+  };
+
+  /**
+   * Destroys an instance of a modal.
+   * @function
+   */
+  _destroy() {
+    if (this.options.overlay) {
+      this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()
+      this.$overlay.hide().off().remove();
+    }
+    this.$element.hide().off();
+    this.$anchor.off('.zf');
+    $(window).off(`.zf.reveal:${this.id}`);
+    if (this.onLoadListener) $(window).off(this.onLoadListener);
+
+    if ($('.reveal:visible').length  === 0) {
+      this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
+    }
+  };
+}
+
+Reveal.defaults = {
+  /**
+   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  animationIn: '',
+  /**
+   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  animationOut: '',
+  /**
+   * Time, in ms, to delay the opening of a modal after a click if no animation used.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  showDelay: 0,
+  /**
+   * Time, in ms, to delay the closing of a modal after a click if no animation used.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hideDelay: 0,
+  /**
+   * Allows a click on the body/overlay to close the modal.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+  /**
+   * Allows the modal to close if the user presses the `ESCAPE` key.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnEsc: true,
+  /**
+   * If true, allows multiple modals to be displayed at once.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  multipleOpened: false,
+  /**
+   * Distance, in pixels, the modal should push down from the top of the screen.
+   * @option
+   * @type {number|string}
+   * @default auto
+   */
+  vOffset: 'auto',
+  /**
+   * Distance, in pixels, the modal should push in from the side of the screen.
+   * @option
+   * @type {number|string}
+   * @default auto
+   */
+  hOffset: 'auto',
+  /**
+   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  fullScreen: false,
+  /**
+   * Allows the modal to generate an overlay div, which will cover the view when modal opens.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  overlay: true,
+  /**
+   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  resetOnClose: false,
+  /**
+   * Link the location hash to the modal.
+   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+  /**
+   * If `deepLink` is enabled, update the browser history with the open modal
+   * @option
+   * @default false
+   */
+  updateHistory: false,
+    /**
+   * Allows the modal to append to custom div.
+   * @option
+   * @type {string}
+   * @default "body"
+   */
+  appendTo: "body",
+  /**
+   * Allows adding additional class names to the reveal overlay.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  additionalOverlayClasses: ''
+};
+
+/**
+ * Slider module.
+ * @module foundation.slider
+ * @requires foundation.util.motion
+ * @requires foundation.util.triggers
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.touch
+ */
+
+class Slider extends Plugin {
+  /**
+   * Creates a new instance of a slider control.
+   * @class
+   * @name Slider
+   * @param {jQuery} element - jQuery object to make into a slider control.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Slider.defaults, this.$element.data(), options);
+    this.className = 'Slider'; // ie9 back compat
+
+  // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.
+    Touch.init($);
+    Triggers.init($);
+
+    this._init();
+
+    Keyboard.register('Slider', {
+      'ltr': {
+        'ARROW_RIGHT': 'increase',
+        'ARROW_UP': 'increase',
+        'ARROW_DOWN': 'decrease',
+        'ARROW_LEFT': 'decrease',
+        'SHIFT_ARROW_RIGHT': 'increase_fast',
+        'SHIFT_ARROW_UP': 'increase_fast',
+        'SHIFT_ARROW_DOWN': 'decrease_fast',
+        'SHIFT_ARROW_LEFT': 'decrease_fast',
+        'HOME': 'min',
+        'END': 'max'
+      },
+      'rtl': {
+        'ARROW_LEFT': 'increase',
+        'ARROW_RIGHT': 'decrease',
+        'SHIFT_ARROW_LEFT': 'increase_fast',
+        'SHIFT_ARROW_RIGHT': 'decrease_fast'
+      }
+    });
+  }
+
+  /**
+   * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).
+   * @function
+   * @private
+   */
+  _init() {
+    this.inputs = this.$element.find('input');
+    this.handles = this.$element.find('[data-slider-handle]');
+
+    this.$handle = this.handles.eq(0);
+    this.$input = this.inputs.length ? this.inputs.eq(0) : $(`#${this.$handle.attr('aria-controls')}`);
+    this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);
+    if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {
+      this.options.disabled = true;
+      this.$element.addClass(this.options.disabledClass);
+    }
+    if (!this.inputs.length) {
+      this.inputs = $().add(this.$input);
+      this.options.binding = true;
+    }
+
+    this._setInitAttr(0);
+
+    if (this.handles[1]) {
+      this.options.doubleSided = true;
+      this.$handle2 = this.handles.eq(1);
+      this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $(`#${this.$handle2.attr('aria-controls')}`);
+
+      if (!this.inputs[1]) {
+        this.inputs = this.inputs.add(this.$input2);
+      }
+
+      // this.$handle.triggerHandler('click.zf.slider');
+      this._setInitAttr(1);
+    }
+
+    // Set handle positions
+    this.setHandles();
+
+    this._events();
+  }
+
+  setHandles() {
+    if(this.handles[1]) {
+      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, () => {
+        this._setHandlePos(this.$handle2, this.inputs.eq(1).val(), true);
+      });
+    } else {
+      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);
+    }
+  }
+
+  _reflow() {
+    this.setHandles();
+  }
+  /**
+  * @function
+  * @private
+  * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)
+  */
+  _pctOfBar(value) {
+    var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start);
+
+    switch(this.options.positionValueFunction) {
+    case "pow":
+      pctOfBar = this._logTransform(pctOfBar);
+      break;
+    case "log":
+      pctOfBar = this._powTransform(pctOfBar);
+      break;
+    }
+
+    return pctOfBar.toFixed(2)
+  }
+
+  /**
+  * @function
+  * @private
+  * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value
+  */
+  _value(pctOfBar) {
+    switch(this.options.positionValueFunction) {
+    case "pow":
+      pctOfBar = this._powTransform(pctOfBar);
+      break;
+    case "log":
+      pctOfBar = this._logTransform(pctOfBar);
+      break;
+    }
+    var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);
+
+    return value
+  }
+
+  /**
+  * @function
+  * @private
+  * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function
+  */
+  _logTransform(value) {
+    return baseLog(this.options.nonLinearBase, ((value*(this.options.nonLinearBase-1))+1))
+  }
+
+  /**
+  * @function
+  * @private
+  * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function
+  */
+  _powTransform(value) {
+    return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1)
+  }
+
+  /**
+   * Sets the position of the selected handle and fill bar.
+   * @function
+   * @private
+   * @param {jQuery} $hndl - the selected handle to move.
+   * @param {Number} location - floating point between the start and end values of the slider bar.
+   * @param {Function} cb - callback function to fire on completion.
+   * @fires Slider#moved
+   * @fires Slider#changed
+   */
+  _setHandlePos($hndl, location, noInvert, cb) {
+    // don't move if the slider has been disabled since its initialization
+    if (this.$element.hasClass(this.options.disabledClass)) {
+      return;
+    }
+    //might need to alter that slightly for bars that will have odd number selections.
+    location = parseFloat(location);//on input change events, convert string to number...grumble.
+
+    // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max
+    if (location < this.options.start) { location = this.options.start; }
+    else if (location > this.options.end) { location = this.options.end; }
+
+    var isDbl = this.options.doubleSided;
+
+    //this is for single-handled vertical sliders, it adjusts the value to account for the slider being "upside-down"
+    //for click and drag events, it's weird due to the scale(-1, 1) css property
+    if (this.options.vertical && !noInvert) {
+      location = this.options.end - location;
+    }
+
+    if (isDbl) { //this block is to prevent 2 handles from crossing eachother. Could/should be improved.
+      if (this.handles.index($hndl) === 0) {
+        var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));
+        location = location >= h2Val ? h2Val - this.options.step : location;
+      } else {
+        var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));
+        location = location <= h1Val ? h1Val + this.options.step : location;
+      }
+    }
+
+    var _this = this,
+        vert = this.options.vertical,
+        hOrW = vert ? 'height' : 'width',
+        lOrT = vert ? 'top' : 'left',
+        handleDim = $hndl[0].getBoundingClientRect()[hOrW],
+        elemDim = this.$element[0].getBoundingClientRect()[hOrW],
+        //percentage of bar min/max value based on click or drag point
+        pctOfBar = this._pctOfBar(location),
+        //number of actual pixels to shift the handle, based on the percentage obtained above
+        pxToMove = (elemDim - handleDim) * pctOfBar,
+        //percentage of bar to shift the handle
+        movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);
+        //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value
+        location = parseFloat(location.toFixed(this.options.decimal));
+        // declare empty object for css adjustments, only used with 2 handled-sliders
+    var css = {};
+
+    this._setValues($hndl, location);
+
+    // TODO update to calculate based on values set to respective inputs??
+    if (isDbl) {
+      var isLeftHndl = this.handles.index($hndl) === 0,
+          //empty variable, will be used for min-height/width for fill bar
+          dim,
+          //percentage w/h of the handle compared to the slider bar
+          handlePct =  ~~(percent(handleDim, elemDim) * 100);
+      //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar
+      if (isLeftHndl) {
+        //left or top percentage value to apply to the fill bar.
+        css[lOrT] = `${movement}%`;
+        //calculate the new min-height/width for the fill bar.
+        dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;
+        //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider
+        //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.
+        if (cb && typeof cb === 'function') { cb(); }//this is only needed for the initialization of 2 handled sliders
+      } else {
+        //just caching the value of the left/bottom handle's left/top property
+        var handlePos = parseFloat(this.$handle[0].style[lOrT]);
+        //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0
+        //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself
+        dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start)/((this.options.end-this.options.start)/100) : handlePos) + handlePct;
+      }
+      // assign the min-height/width to our css object
+      css[`min-${hOrW}`] = `${dim}%`;
+    }
+
+    this.$element.one('finished.zf.animate', function() {
+                    /**
+                     * Fires when the handle is done moving.
+                     * @event Slider#moved
+                     */
+                    _this.$element.trigger('moved.zf.slider', [$hndl]);
+                });
+
+    //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.
+    var moveTime = this.$element.data('dragging') ? 1000/60 : this.options.moveTime;
+
+    Move(moveTime, $hndl, function() {
+      // adjusting the left/top property of the handle, based on the percentage calculated above
+      // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,
+      // fall back to next best guess.
+      if (isNaN(movement)) {
+        $hndl.css(lOrT, `${pctOfBar * 100}%`);
+      }
+      else {
+        $hndl.css(lOrT, `${movement}%`);
+      }
+
+      if (!_this.options.doubleSided) {
+        //if single-handled, a simple method to expand the fill bar
+        _this.$fill.css(hOrW, `${pctOfBar * 100}%`);
+      } else {
+        //otherwise, use the css object we created above
+        _this.$fill.css(css);
+      }
+    });
+
+
+    /**
+     * Fires when the value has not been change for a given time.
+     * @event Slider#changed
+     */
+    clearTimeout(_this.timeout);
+    _this.timeout = setTimeout(function(){
+      _this.$element.trigger('changed.zf.slider', [$hndl]);
+    }, _this.options.changedDelay);
+  }
+
+  /**
+   * Sets the initial attribute for the slider element.
+   * @function
+   * @private
+   * @param {Number} idx - index of the current handle/input to use.
+   */
+  _setInitAttr(idx) {
+    var initVal = (idx === 0 ? this.options.initialStart : this.options.initialEnd);
+    var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');
+    this.inputs.eq(idx).attr({
+      'id': id,
+      'max': this.options.end,
+      'min': this.options.start,
+      'step': this.options.step
+    });
+    this.inputs.eq(idx).val(initVal);
+    this.handles.eq(idx).attr({
+      'role': 'slider',
+      'aria-controls': id,
+      'aria-valuemax': this.options.end,
+      'aria-valuemin': this.options.start,
+      'aria-valuenow': initVal,
+      'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',
+      'tabindex': 0
+    });
+  }
+
+  /**
+   * Sets the input and `aria-valuenow` values for the slider element.
+   * @function
+   * @private
+   * @param {jQuery} $handle - the currently selected handle.
+   * @param {Number} val - floating point of the new value.
+   */
+  _setValues($handle, val) {
+    var idx = this.options.doubleSided ? this.handles.index($handle) : 0;
+    this.inputs.eq(idx).val(val);
+    $handle.attr('aria-valuenow', val);
+  }
+
+  /**
+   * Handles events on the slider element.
+   * Calculates the new location of the current handle.
+   * If there are two handles and the bar was clicked, it determines which handle to move.
+   * @function
+   * @private
+   * @param {Object} e - the `event` object passed from the listener.
+   * @param {jQuery} $handle - the current handle to calculate for, if selected.
+   * @param {Number} val - floating point number for the new value of the slider.
+   * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.
+   */
+  _handleEvent(e, $handle, val) {
+    var value, hasVal;
+    if (!val) {//click or drag events
+      e.preventDefault();
+      var _this = this,
+          vertical = this.options.vertical,
+          param = vertical ? 'height' : 'width',
+          direction = vertical ? 'top' : 'left',
+          eventOffset = vertical ? e.pageY : e.pageX,
+          halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,
+          barDim = this.$element[0].getBoundingClientRect()[param],
+          windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();
+
+
+      var elemOffset = this.$element.offset()[direction];
+
+      // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...
+      // best way to guess this is simulated is if clientY == pageY
+      if (e.clientY === e.pageY) { eventOffset = eventOffset + windowScroll; }
+      var eventFromBar = eventOffset - elemOffset;
+      var barXY;
+      if (eventFromBar < 0) {
+        barXY = 0;
+      } else if (eventFromBar > barDim) {
+        barXY = barDim;
+      } else {
+        barXY = eventFromBar;
+      }
+      var offsetPct = percent(barXY, barDim);
+
+      value = this._value(offsetPct);
+
+      // turn everything around for RTL, yay math!
+      if (rtl() && !this.options.vertical) {value = this.options.end - value;}
+
+      value = _this._adjustValue(null, value);
+      //boolean flag for the setHandlePos fn, specifically for vertical sliders
+      hasVal = false;
+
+      if (!$handle) {//figure out which handle it is, pass it to the next function.
+        var firstHndlPos = absPosition(this.$handle, direction, barXY, param),
+            secndHndlPos = absPosition(this.$handle2, direction, barXY, param);
+            $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;
+      }
+
+    } else {//change event on input
+      value = this._adjustValue(null, val);
+      hasVal = true;
+    }
+
+    this._setHandlePos($handle, value, hasVal);
+  }
+
+  /**
+   * Adjustes value for handle in regard to step value. returns adjusted value
+   * @function
+   * @private
+   * @param {jQuery} $handle - the selected handle.
+   * @param {Number} value - value to adjust. used if $handle is falsy
+   */
+  _adjustValue($handle, value) {
+    var val,
+      step = this.options.step,
+      div = parseFloat(step/2),
+      left, prev_val, next_val;
+    if (!!$handle) {
+      val = parseFloat($handle.attr('aria-valuenow'));
+    }
+    else {
+      val = value;
+    }
+    if (val >= 0) {
+      left = val % step;
+    } else {
+      left = step + (val % step);
+    }
+    prev_val = val - left;
+    next_val = prev_val + step;
+    if (left === 0) {
+      return val;
+    }
+    val = val >= prev_val + div ? next_val : prev_val;
+    return val;
+  }
+
+  /**
+   * Adds event listeners to the slider elements.
+   * @function
+   * @private
+   */
+  _events() {
+    this._eventsForHandle(this.$handle);
+    if(this.handles[1]) {
+      this._eventsForHandle(this.$handle2);
+    }
+  }
+
+
+  /**
+   * Adds event listeners a particular handle
+   * @function
+   * @private
+   * @param {jQuery} $handle - the current handle to apply listeners to.
+   */
+  _eventsForHandle($handle) {
+    var _this = this,
+        curHandle;
+
+      const handleChangeEvent = function(e) {
+        const idx = _this.inputs.index($(this));
+        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());
+      };
+
+      // IE only triggers the change event when the input loses focus which strictly follows the HTML specification
+      // listen for the enter key and trigger a change
+      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events
+      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {
+        if(e.keyCode == 13) handleChangeEvent.call(this, e);
+      });
+
+      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);
+
+      if (this.options.clickSelect) {
+        this.$element.off('click.zf.slider').on('click.zf.slider', function(e) {
+          if (_this.$element.data('dragging')) { return false; }
+
+          if (!$(e.target).is('[data-slider-handle]')) {
+            if (_this.options.doubleSided) {
+              _this._handleEvent(e);
+            } else {
+              _this._handleEvent(e, _this.$handle);
+            }
+          }
+        });
+      }
+
+    if (this.options.draggable) {
+      this.handles.addTouch();
+
+      var $body = $('body');
+      $handle
+        .off('mousedown.zf.slider')
+        .on('mousedown.zf.slider', function(e) {
+          $handle.addClass('is-dragging');
+          _this.$fill.addClass('is-dragging');//
+          _this.$element.data('dragging', true);
+
+          curHandle = $(e.currentTarget);
+
+          $body.on('mousemove.zf.slider', function(e) {
+            e.preventDefault();
+            _this._handleEvent(e, curHandle);
+
+          }).on('mouseup.zf.slider', function(e) {
+            _this._handleEvent(e, curHandle);
+
+            $handle.removeClass('is-dragging');
+            _this.$fill.removeClass('is-dragging');
+            _this.$element.data('dragging', false);
+
+            $body.off('mousemove.zf.slider mouseup.zf.slider');
+          });
+      })
+      // prevent events triggered by touch
+      .on('selectstart.zf.slider touchmove.zf.slider', function(e) {
+        e.preventDefault();
+      });
+    }
+
+    $handle.off('keydown.zf.slider').on('keydown.zf.slider', function(e) {
+      var _$handle = $(this),
+          idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,
+          oldValue = parseFloat(_this.inputs.eq(idx).val()),
+          newValue;
+
+      // handle keyboard event with keyboard util
+      Keyboard.handleKey(e, 'Slider', {
+        decrease: function() {
+          newValue = oldValue - _this.options.step;
+        },
+        increase: function() {
+          newValue = oldValue + _this.options.step;
+        },
+        decrease_fast: function() {
+          newValue = oldValue - _this.options.step * 10;
+        },
+        increase_fast: function() {
+          newValue = oldValue + _this.options.step * 10;
+        },
+        min: function() {
+          newValue = _this.options.start;
+        },
+        max: function() {
+          newValue = _this.options.end;
+        },
+        handled: function() { // only set handle pos when event was handled specially
+          e.preventDefault();
+          _this._setHandlePos(_$handle, newValue, true);
+        }
+      });
+      /*if (newValue) { // if pressed key has special function, update value
+        e.preventDefault();
+        _this._setHandlePos(_$handle, newValue);
+      }*/
+    });
+  }
+
+  /**
+   * Destroys the slider plugin.
+   */
+  _destroy() {
+    this.handles.off('.zf.slider');
+    this.inputs.off('.zf.slider');
+    this.$element.off('.zf.slider');
+
+    clearTimeout(this.timeout);
+  }
+}
+
+Slider.defaults = {
+  /**
+   * Minimum value for the slider scale.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  start: 0,
+  /**
+   * Maximum value for the slider scale.
+   * @option
+   * @type {number}
+   * @default 100
+   */
+  end: 100,
+  /**
+   * Minimum value change per change event.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  step: 1,
+  /**
+   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  initialStart: 0,
+  /**
+   * Value at which the right handle/second input should be set to on initialization.
+   * @option
+   * @type {number}
+   * @default 100
+   */
+  initialEnd: 100,
+  /**
+   * Allows the input to be located outside the container and visible. Set to by the JS
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  binding: false,
+  /**
+   * Allows the user to click/tap on the slider bar to select a value.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  clickSelect: true,
+  /**
+   * Set to true and use the `vertical` class to change alignment to vertical.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  vertical: false,
+  /**
+   * Allows the user to drag the slider handle(s) to select a value.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  draggable: true,
+  /**
+   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disabled: false,
+  /**
+   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  doubleSided: false,
+  /**
+   * Potential future feature.
+   */
+  // steps: 100,
+  /**
+   * Number of decimal places the plugin should go to for floating point precision.
+   * @option
+   * @type {number}
+   * @default 2
+   */
+  decimal: 2,
+  /**
+   * Time delay for dragged elements.
+   */
+  // dragDelay: 0,
+  /**
+   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.
+   * @option
+   * @type {number}
+   * @default 200
+   */
+  moveTime: 200,//update this if changing the transition time in the sass
+  /**
+   * Class applied to disabled sliders.
+   * @option
+   * @type {string}
+   * @default 'disabled'
+   */
+  disabledClass: 'disabled',
+  /**
+   * Will invert the default layout for a vertical<span data-tooltip title="who would do this???"> </span>slider.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  invertVertical: false,
+  /**
+   * Milliseconds before the `changed.zf-slider` event is triggered after value change.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  changedDelay: 500,
+  /**
+  * Basevalue for non-linear sliders
+  * @option
+  * @type {number}
+  * @default 5
+  */
+  nonLinearBase: 5,
+  /**
+  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.
+  * @option
+  * @type {string}
+  * @default 'linear'
+  */
+  positionValueFunction: 'linear',
+};
+
+function percent(frac, num) {
+  return (frac / num);
+}
+function absPosition($handle, dir, clickPos, param) {
+  return Math.abs(($handle.position()[dir] + ($handle[param]() / 2)) - clickPos);
+}
+function baseLog(base, value) {
+  return Math.log(value)/Math.log(base)
+}
+
+/**
+ * Sticky module.
+ * @module foundation.sticky
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ */
+
+class Sticky extends Plugin {
+  /**
+   * Creates a new instance of a sticky thing.
+   * @class
+   * @name Sticky
+   * @param {jQuery} element - jQuery object to make sticky.
+   * @param {Object} options - options object passed when creating the element programmatically.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);
+    this.className = 'Sticky'; // ie9 back compat
+
+    // Triggers init is idempotent, just need to make sure it is initialized
+    Triggers.init($);
+
+    this._init();
+  }
+
+  /**
+   * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes
+   * @function
+   * @private
+   */
+  _init() {
+    MediaQuery._init();
+
+    var $parent = this.$element.parent('[data-sticky-container]'),
+        id = this.$element[0].id || GetYoDigits(6, 'sticky'),
+        _this = this;
+
+    if($parent.length){
+      this.$container = $parent;
+    } else {
+      this.wasWrapped = true;
+      this.$element.wrap(this.options.container);
+      this.$container = this.$element.parent();
+    }
+    this.$container.addClass(this.options.containerClass);
+
+    this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });
+    if (this.options.anchor !== '') {
+        $('#' + _this.options.anchor).attr({ 'data-mutate': id });
+    }
+
+    this.scrollCount = this.options.checkEvery;
+    this.isStuck = false;
+    this.onLoadListener = onLoad($(window), function () {
+      //We calculate the container height to have correct values for anchor points offset calculation.
+      _this.containerHeight = _this.$element.css("display") == "none" ? 0 : _this.$element[0].getBoundingClientRect().height;
+      _this.$container.css('height', _this.containerHeight);
+      _this.elemHeight = _this.containerHeight;
+      if (_this.options.anchor !== '') {
+        _this.$anchor = $('#' + _this.options.anchor);
+      } else {
+        _this._parsePoints();
+      }
+
+      _this._setSizes(function () {
+        var scroll = window.pageYOffset;
+        _this._calc(false, scroll);
+        //Unstick the element will ensure that proper classes are set.
+        if (!_this.isStuck) {
+          _this._removeSticky((scroll >= _this.topPoint) ? false : true);
+        }
+      });
+      _this._events(id.split('-').reverse().join('-'));
+    });
+  }
+
+  /**
+   * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.
+   * @function
+   * @private
+   */
+  _parsePoints() {
+    var top = this.options.topAnchor == "" ? 1 : this.options.topAnchor,
+        btm = this.options.btmAnchor== "" ? document.documentElement.scrollHeight : this.options.btmAnchor,
+        pts = [top, btm],
+        breaks = {};
+    for (var i = 0, len = pts.length; i < len && pts[i]; i++) {
+      var pt;
+      if (typeof pts[i] === 'number') {
+        pt = pts[i];
+      } else {
+        var place = pts[i].split(':'),
+            anchor = $(`#${place[0]}`);
+
+        pt = anchor.offset().top;
+        if (place[1] && place[1].toLowerCase() === 'bottom') {
+          pt += anchor[0].getBoundingClientRect().height;
+        }
+      }
+      breaks[i] = pt;
+    }
+
+
+    this.points = breaks;
+    return;
+  }
+
+  /**
+   * Adds event handlers for the scrolling element.
+   * @private
+   * @param {String} id - pseudo-random id for unique scroll event listener.
+   */
+  _events(id) {
+    var _this = this,
+        scrollListener = this.scrollListener = `scroll.zf.${id}`;
+    if (this.isOn) { return; }
+    if (this.canStick) {
+      this.isOn = true;
+      $(window).off(scrollListener)
+               .on(scrollListener, function(e) {
+                 if (_this.scrollCount === 0) {
+                   _this.scrollCount = _this.options.checkEvery;
+                   _this._setSizes(function() {
+                     _this._calc(false, window.pageYOffset);
+                   });
+                 } else {
+                   _this.scrollCount--;
+                   _this._calc(false, window.pageYOffset);
+                 }
+              });
+    }
+
+    this.$element.off('resizeme.zf.trigger')
+                 .on('resizeme.zf.trigger', function(e, el) {
+                    _this._eventsHandler(id);
+    });
+
+    this.$element.on('mutateme.zf.trigger', function (e, el) {
+        _this._eventsHandler(id);
+    });
+
+    if(this.$anchor) {
+      this.$anchor.on('mutateme.zf.trigger', function (e, el) {
+          _this._eventsHandler(id);
+      });
+    }
+  }
+
+  /**
+   * Handler for events.
+   * @private
+   * @param {String} id - pseudo-random id for unique scroll event listener.
+   */
+  _eventsHandler(id) {
+       var _this = this,
+        scrollListener = this.scrollListener = `scroll.zf.${id}`;
+
+       _this._setSizes(function() {
+       _this._calc(false);
+       if (_this.canStick) {
+         if (!_this.isOn) {
+           _this._events(id);
+         }
+       } else if (_this.isOn) {
+         _this._pauseListeners(scrollListener);
+       }
+     });
+  }
+
+  /**
+   * Removes event handlers for scroll and change events on anchor.
+   * @fires Sticky#pause
+   * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`
+   */
+  _pauseListeners(scrollListener) {
+    this.isOn = false;
+    $(window).off(scrollListener);
+
+    /**
+     * Fires when the plugin is paused due to resize event shrinking the view.
+     * @event Sticky#pause
+     * @private
+     */
+     this.$element.trigger('pause.zf.sticky');
+  }
+
+  /**
+   * Called on every `scroll` event and on `_init`
+   * fires functions based on booleans and cached values
+   * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.
+   * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.
+   */
+  _calc(checkSizes, scroll) {
+    if (checkSizes) { this._setSizes(); }
+
+    if (!this.canStick) {
+      if (this.isStuck) {
+        this._removeSticky(true);
+      }
+      return false;
+    }
+
+    if (!scroll) { scroll = window.pageYOffset; }
+
+    if (scroll >= this.topPoint) {
+      if (scroll <= this.bottomPoint) {
+        if (!this.isStuck) {
+          this._setSticky();
+        }
+      } else {
+        if (this.isStuck) {
+          this._removeSticky(false);
+        }
+      }
+    } else {
+      if (this.isStuck) {
+        this._removeSticky(true);
+      }
+    }
+  }
+
+  /**
+   * Causes the $element to become stuck.
+   * Adds `position: fixed;`, and helper classes.
+   * @fires Sticky#stuckto
+   * @function
+   * @private
+   */
+  _setSticky() {
+    var _this = this,
+        stickTo = this.options.stickTo,
+        mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',
+        notStuckTo = stickTo === 'top' ? 'bottom' : 'top',
+        css = {};
+
+    css[mrgn] = `${this.options[mrgn]}em`;
+    css[stickTo] = 0;
+    css[notStuckTo] = 'auto';
+    this.isStuck = true;
+    this.$element.removeClass(`is-anchored is-at-${notStuckTo}`)
+                 .addClass(`is-stuck is-at-${stickTo}`)
+                 .css(css)
+                 /**
+                  * Fires when the $element has become `position: fixed;`
+                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`
+                  * @event Sticky#stuckto
+                  */
+                 .trigger(`sticky.zf.stuckto:${stickTo}`);
+    this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd", function() {
+      _this._setSizes();
+    });
+  }
+
+  /**
+   * Causes the $element to become unstuck.
+   * Removes `position: fixed;`, and helper classes.
+   * Adds other helper classes.
+   * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.
+   * @fires Sticky#unstuckfrom
+   * @private
+   */
+  _removeSticky(isTop) {
+    var stickTo = this.options.stickTo,
+        stickToTop = stickTo === 'top',
+        css = {},
+        anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,
+        mrgn = stickToTop ? 'marginTop' : 'marginBottom',
+        topOrBottom = isTop ? 'top' : 'bottom';
+
+    css[mrgn] = 0;
+
+    css['bottom'] = 'auto';
+    if(isTop) {
+      css['top'] = 0;
+    } else {
+      css['top'] = anchorPt;
+    }
+
+    this.isStuck = false;
+    this.$element.removeClass(`is-stuck is-at-${stickTo}`)
+                 .addClass(`is-anchored is-at-${topOrBottom}`)
+                 .css(css)
+                 /**
+                  * Fires when the $element has become anchored.
+                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`
+                  * @event Sticky#unstuckfrom
+                  */
+                 .trigger(`sticky.zf.unstuckfrom:${topOrBottom}`);
+  }
+
+  /**
+   * Sets the $element and $container sizes for plugin.
+   * Calls `_setBreakPoints`.
+   * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.
+   * @private
+   */
+  _setSizes(cb) {
+    this.canStick = MediaQuery.is(this.options.stickyOn);
+    if (!this.canStick) {
+      if (cb && typeof cb === 'function') { cb(); }
+    }
+    var newElemWidth = this.$container[0].getBoundingClientRect().width,
+        comp = window.getComputedStyle(this.$container[0]),
+        pdngl = parseInt(comp['padding-left'], 10),
+        pdngr = parseInt(comp['padding-right'], 10);
+
+    if (this.$anchor && this.$anchor.length) {
+      this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;
+    } else {
+      this._parsePoints();
+    }
+
+    this.$element.css({
+      'max-width': `${newElemWidth - pdngl - pdngr}px`
+    });
+
+    var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;
+    if (this.$element.css("display") == "none") {
+      newContainerHeight = 0;
+    }
+    this.containerHeight = newContainerHeight;
+    this.$container.css({
+      height: newContainerHeight
+    });
+    this.elemHeight = newContainerHeight;
+
+    if (!this.isStuck) {
+      if (this.$element.hasClass('is-at-bottom')) {
+        var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;
+        this.$element.css('top', anchorPt);
+      }
+    }
+
+    this._setBreakPoints(newContainerHeight, function() {
+      if (cb && typeof cb === 'function') { cb(); }
+    });
+  }
+
+  /**
+   * Sets the upper and lower breakpoints for the element to become sticky/unsticky.
+   * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.
+   * @param {Function} cb - optional callback function to be called on completion.
+   * @private
+   */
+  _setBreakPoints(elemHeight, cb) {
+    if (!this.canStick) {
+      if (cb && typeof cb === 'function') { cb(); }
+      else { return false; }
+    }
+    var mTop = emCalc(this.options.marginTop),
+        mBtm = emCalc(this.options.marginBottom),
+        topPoint = this.points ? this.points[0] : this.$anchor.offset().top,
+        bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,
+        // topPoint = this.$anchor.offset().top || this.points[0],
+        // bottomPoint = topPoint + this.anchorHeight || this.points[1],
+        winHeight = window.innerHeight;
+
+    if (this.options.stickTo === 'top') {
+      topPoint -= mTop;
+      bottomPoint -= (elemHeight + mTop);
+    } else if (this.options.stickTo === 'bottom') {
+      topPoint -= (winHeight - (elemHeight + mBtm));
+      bottomPoint -= (winHeight - mBtm);
+    }
+
+    this.topPoint = topPoint;
+    this.bottomPoint = bottomPoint;
+
+    if (cb && typeof cb === 'function') { cb(); }
+  }
+
+  /**
+   * Destroys the current sticky element.
+   * Resets the element to the top position first.
+   * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.
+   * @function
+   */
+  _destroy() {
+    this._removeSticky(true);
+
+    this.$element.removeClass(`${this.options.stickyClass} is-anchored is-at-top`)
+                 .css({
+                   height: '',
+                   top: '',
+                   bottom: '',
+                   'max-width': ''
+                 })
+                 .off('resizeme.zf.trigger')
+                 .off('mutateme.zf.trigger');
+    if (this.$anchor && this.$anchor.length) {
+      this.$anchor.off('change.zf.sticky');
+    }
+    if (this.scrollListener) $(window).off(this.scrollListener);
+    if (this.onLoadListener) $(window).off(this.onLoadListener);
+
+    if (this.wasWrapped) {
+      this.$element.unwrap();
+    } else {
+      this.$container.removeClass(this.options.containerClass)
+                     .css({
+                       height: ''
+                     });
+    }
+  }
+}
+
+Sticky.defaults = {
+  /**
+   * Customizable container template. Add your own classes for styling and sizing.
+   * @option
+   * @type {string}
+   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'
+   */
+  container: '<div data-sticky-container></div>',
+  /**
+   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.
+   * @option
+   * @type {string}
+   * @default 'top'
+   */
+  stickTo: 'top',
+  /**
+   * If anchored to a single element, the id of that element.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  anchor: '',
+  /**
+   * If using more than one element as anchor points, the id of the top anchor.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  topAnchor: '',
+  /**
+   * If using more than one element as anchor points, the id of the bottom anchor.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  btmAnchor: '',
+  /**
+   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  marginTop: 1,
+  /**
+   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  marginBottom: 1,
+  /**
+   * Breakpoint string that is the minimum screen size an element should become sticky.
+   * @option
+   * @type {string}
+   * @default 'medium'
+   */
+  stickyOn: 'medium',
+  /**
+   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.
+   * @option
+   * @type {string}
+   * @default 'sticky'
+   */
+  stickyClass: 'sticky',
+  /**
+   * Class applied to sticky container. Foundation defaults to `sticky-container`.
+   * @option
+   * @type {string}
+   * @default 'sticky-container'
+   */
+  containerClass: 'sticky-container',
+  /**
+   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.
+   * @option
+   * @type {number}
+   * @default -1
+   */
+  checkEvery: -1
+};
+
+/**
+ * Helper function to calculate em values
+ * @param Number {em} - number of em's to calculate into pixels
+ */
+function emCalc(em) {
+  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;
+}
+
+/**
+ * Tabs module.
+ * @module foundation.tabs
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.imageLoader if tabs contain images
+ */
+
+class Tabs extends Plugin {
+  /**
+   * Creates a new instance of tabs.
+   * @class
+   * @name Tabs
+   * @fires Tabs#init
+   * @param {jQuery} element - jQuery object to make into tabs.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);
+    this.className = 'Tabs'; // ie9 back compat
+
+    this._init();
+    Keyboard.register('Tabs', {
+      'ENTER': 'open',
+      'SPACE': 'open',
+      'ARROW_RIGHT': 'next',
+      'ARROW_UP': 'previous',
+      'ARROW_DOWN': 'next',
+      'ARROW_LEFT': 'previous'
+      // 'TAB': 'next',
+      // 'SHIFT_TAB': 'previous'
+    });
+  }
+
+  /**
+   * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.
+   * @private
+   */
+  _init() {
+    var _this = this;
+    this._isInitializing = true;
+
+    this.$element.attr({'role': 'tablist'});
+    this.$tabTitles = this.$element.find(`.${this.options.linkClass}`);
+    this.$tabContent = $(`[data-tabs-content="${this.$element[0].id}"]`);
+
+    this.$tabTitles.each(function(){
+      var $elem = $(this),
+          $link = $elem.find('a'),
+          isActive = $elem.hasClass(`${_this.options.linkActiveClass}`),
+          hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),
+          linkId = $link[0].id ? $link[0].id : `${hash}-label`,
+          $tabContent = $(`#${hash}`);
+
+      $elem.attr({'role': 'presentation'});
+
+      $link.attr({
+        'role': 'tab',
+        'aria-controls': hash,
+        'aria-selected': isActive,
+        'id': linkId,
+        'tabindex': isActive ? '0' : '-1'
+      });
+
+      $tabContent.attr({
+        'role': 'tabpanel',
+        'aria-labelledby': linkId
+      });
+
+      // Save up the initial hash to return to it later when going back in history
+      if (isActive) {
+        _this._initialAnchor = `#${hash}`;
+      }
+
+      if(!isActive) {
+        $tabContent.attr('aria-hidden', 'true');
+      }
+
+      if(isActive && _this.options.autoFocus){
+        _this.onLoadListener = onLoad($(window), function() {
+          $('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, () => {
+            $link.focus();
+          });
+        });
+      }
+    });
+
+    if(this.options.matchHeight) {
+      var $images = this.$tabContent.find('img');
+
+      if ($images.length) {
+        onImagesLoaded($images, this._setHeight.bind(this));
+      } else {
+        this._setHeight();
+      }
+    }
+
+     // Current context-bound function to open tabs on page load or history hashchange
+    this._checkDeepLink = () => {
+      var anchor = window.location.hash;
+
+      if (!anchor.length) {
+        // If we are still initializing and there is no anchor, then there is nothing to do
+        if (this._isInitializing) return;
+        // Otherwise, move to the initial anchor
+        if (this._initialAnchor) anchor = this._initialAnchor;
+      }
+
+      var $anchor = anchor && $(anchor);
+      var $link = anchor && this.$element.find('[href$="'+anchor+'"]');
+      // Whether the anchor element that has been found is part of this element
+      var isOwnAnchor = !!($anchor.length && $link.length);
+
+      // If there is an anchor for the hash, select it
+      if ($anchor && $anchor.length && $link && $link.length) {
+        this.selectTab($anchor, true);
+      }
+      // Otherwise, collapse everything
+      else {
+        this._collapse();
+      }
+
+      if (isOwnAnchor) {
+        // Roll up a little to show the titles
+        if (this.options.deepLinkSmudge) {
+          var offset = this.$element.offset();
+          $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);
+        }
+
+        /**
+         * Fires when the plugin has deeplinked at pageload
+         * @event Tabs#deeplink
+         */
+        this.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);
+      }
+    };
+
+    //use browser to open a tab, if it exists in this tabset
+    if (this.options.deepLink) {
+      this._checkDeepLink();
+    }
+
+    this._events();
+
+    this._isInitializing = false;
+  }
+
+  /**
+   * Adds event handlers for items within the tabs.
+   * @private
+   */
+  _events() {
+    this._addKeyHandler();
+    this._addClickHandler();
+    this._setHeightMqHandler = null;
+
+    if (this.options.matchHeight) {
+      this._setHeightMqHandler = this._setHeight.bind(this);
+
+      $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);
+    }
+
+    if(this.options.deepLink) {
+      $(window).on('hashchange', this._checkDeepLink);
+    }
+  }
+
+  /**
+   * Adds click handlers for items within the tabs.
+   * @private
+   */
+  _addClickHandler() {
+    var _this = this;
+
+    this.$element
+      .off('click.zf.tabs')
+      .on('click.zf.tabs', `.${this.options.linkClass}`, function(e){
+        e.preventDefault();
+        e.stopPropagation();
+        _this._handleTabChange($(this));
+      });
+  }
+
+  /**
+   * Adds keyboard event handlers for items within the tabs.
+   * @private
+   */
+  _addKeyHandler() {
+    var _this = this;
+
+    this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function(e){
+      if (e.which === 9) return;
+
+
+      var $element = $(this),
+        $elements = $element.parent('ul').children('li'),
+        $prevElement,
+        $nextElement;
+
+      $elements.each(function(i) {
+        if ($(this).is($element)) {
+          if (_this.options.wrapOnKeys) {
+            $prevElement = i === 0 ? $elements.last() : $elements.eq(i-1);
+            $nextElement = i === $elements.length -1 ? $elements.first() : $elements.eq(i+1);
+          } else {
+            $prevElement = $elements.eq(Math.max(0, i-1));
+            $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));
+          }
+          return;
+        }
+      });
+
+      // handle keyboard event with keyboard util
+      Keyboard.handleKey(e, 'Tabs', {
+        open: function() {
+          $element.find('[role="tab"]').focus();
+          _this._handleTabChange($element);
+        },
+        previous: function() {
+          $prevElement.find('[role="tab"]').focus();
+          _this._handleTabChange($prevElement);
+        },
+        next: function() {
+          $nextElement.find('[role="tab"]').focus();
+          _this._handleTabChange($nextElement);
+        },
+        handled: function() {
+          e.stopPropagation();
+          e.preventDefault();
+        }
+      });
+    });
+  }
+
+  /**
+   * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.
+   * @param {jQuery} $target - Tab to open.
+   * @param {boolean} historyHandled - browser has already handled a history update
+   * @fires Tabs#change
+   * @function
+   */
+  _handleTabChange($target, historyHandled) {
+
+    // With `activeCollapse`, if the target is the active Tab, collapse it.
+    if ($target.hasClass(`${this.options.linkActiveClass}`)) {
+        if(this.options.activeCollapse) {
+            this._collapse();
+        }
+        return;
+    }
+
+    var $oldTab = this.$element.
+          find(`.${this.options.linkClass}.${this.options.linkActiveClass}`),
+          $tabLink = $target.find('[role="tab"]'),
+          target = $tabLink.attr('data-tabs-target'),
+          anchor = target && target.length ? `#${target}` : $tabLink[0].hash,
+          $targetContent = this.$tabContent.find(anchor);
+
+    //close old tab
+    this._collapseTab($oldTab);
+
+    //open new tab
+    this._openTab($target);
+
+    //either replace or update browser history
+    if (this.options.deepLink && !historyHandled) {
+      if (this.options.updateHistory) {
+        history.pushState({}, '', anchor);
+      } else {
+        history.replaceState({}, '', anchor);
+      }
+    }
+
+    /**
+     * Fires when the plugin has successfully changed tabs.
+     * @event Tabs#change
+     */
+    this.$element.trigger('change.zf.tabs', [$target, $targetContent]);
+
+    //fire to children a mutation event
+    $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger");
+  }
+
+  /**
+   * Opens the tab `$targetContent` defined by `$target`.
+   * @param {jQuery} $target - Tab to open.
+   * @function
+   */
+  _openTab($target) {
+      var $tabLink = $target.find('[role="tab"]'),
+          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),
+          $targetContent = this.$tabContent.find(`#${hash}`);
+
+      $target.addClass(`${this.options.linkActiveClass}`);
+
+      $tabLink.attr({
+        'aria-selected': 'true',
+        'tabindex': '0'
+      });
+
+      $targetContent
+        .addClass(`${this.options.panelActiveClass}`).removeAttr('aria-hidden');
+  }
+
+  /**
+   * Collapses `$targetContent` defined by `$target`.
+   * @param {jQuery} $target - Tab to collapse.
+   * @function
+   */
+  _collapseTab($target) {
+    var $target_anchor = $target
+      .removeClass(`${this.options.linkActiveClass}`)
+      .find('[role="tab"]')
+      .attr({
+        'aria-selected': 'false',
+        'tabindex': -1
+      });
+
+    $(`#${$target_anchor.attr('aria-controls')}`)
+      .removeClass(`${this.options.panelActiveClass}`)
+      .attr({ 'aria-hidden': 'true' });
+  }
+
+  /**
+   * Collapses the active Tab.
+   * @fires Tabs#collapse
+   * @function
+   */
+  _collapse() {
+    var $activeTab = this.$element.find(`.${this.options.linkClass}.${this.options.linkActiveClass}`);
+
+    if ($activeTab.length) {
+      this._collapseTab($activeTab);
+
+      /**
+      * Fires when the plugin has successfully collapsed tabs.
+      * @event Tabs#collapse
+      */
+      this.$element.trigger('collapse.zf.tabs', [$activeTab]);
+    }
+  }
+
+  /**
+   * Public method for selecting a content pane to display.
+   * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.
+   * @param {boolean} historyHandled - browser has already handled a history update
+   * @function
+   */
+  selectTab(elem, historyHandled) {
+    var idStr;
+
+    if (typeof elem === 'object') {
+      idStr = elem[0].id;
+    } else {
+      idStr = elem;
+    }
+
+    if (idStr.indexOf('#') < 0) {
+      idStr = `#${idStr}`;
+    }
+
+    var $target = this.$tabTitles.has(`[href$="${idStr}"]`);
+
+    this._handleTabChange($target, historyHandled);
+  };
+
+  /**
+   * Sets the height of each panel to the height of the tallest panel.
+   * If enabled in options, gets called on media query change.
+   * If loading content via external source, can be called directly or with _reflow.
+   * If enabled with `data-match-height="true"`, tabs sets to equal height
+   * @function
+   * @private
+   */
+  _setHeight() {
+    var max = 0,
+        _this = this; // Lock down the `this` value for the root tabs object
+
+    this.$tabContent
+      .find(`.${this.options.panelClass}`)
+      .css('height', '')
+      .each(function() {
+
+        var panel = $(this),
+            isActive = panel.hasClass(`${_this.options.panelActiveClass}`); // get the options from the parent instead of trying to get them from the child
+
+        if (!isActive) {
+          panel.css({'visibility': 'hidden', 'display': 'block'});
+        }
+
+        var temp = this.getBoundingClientRect().height;
+
+        if (!isActive) {
+          panel.css({
+            'visibility': '',
+            'display': ''
+          });
+        }
+
+        max = temp > max ? temp : max;
+      })
+      .css('height', `${max}px`);
+  }
+
+  /**
+   * Destroys an instance of tabs.
+   * @fires Tabs#destroyed
+   */
+  _destroy() {
+    this.$element
+      .find(`.${this.options.linkClass}`)
+      .off('.zf.tabs').hide().end()
+      .find(`.${this.options.panelClass}`)
+      .hide();
+
+    if (this.options.matchHeight) {
+      if (this._setHeightMqHandler != null) {
+         $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);
+      }
+    }
+
+    if (this.options.deepLink) {
+      $(window).off('hashchange', this._checkDeepLink);
+    }
+
+    if (this.onLoadListener) {
+      $(window).off(this.onLoadListener);
+    }
+  }
+}
+
+Tabs.defaults = {
+  /**
+   * Link the location hash to the active pane.
+   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+
+  /**
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinkSmudge: false,
+
+  /**
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
+   * @option
+   * @type {number}
+   * @default 300
+   */
+  deepLinkSmudgeDelay: 300,
+
+  /**
+   * If `deepLink` is enabled, update the browser history with the open tab
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  updateHistory: false,
+
+  /**
+   * Allows the window to scroll to content of active pane on load.
+   * Not recommended if more than one tab panel per page.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoFocus: false,
+
+  /**
+   * Allows keyboard input to 'wrap' around the tab links.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  wrapOnKeys: true,
+
+  /**
+   * Allows the tab content panes to match heights if set to true.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  matchHeight: false,
+
+  /**
+   * Allows active tabs to collapse when clicked.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  activeCollapse: false,
+
+  /**
+   * Class applied to `li`'s in tab link list.
+   * @option
+   * @type {string}
+   * @default 'tabs-title'
+   */
+  linkClass: 'tabs-title',
+
+  /**
+   * Class applied to the active `li` in tab link list.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  linkActiveClass: 'is-active',
+
+  /**
+   * Class applied to the content containers.
+   * @option
+   * @type {string}
+   * @default 'tabs-panel'
+   */
+  panelClass: 'tabs-panel',
+
+  /**
+   * Class applied to the active content container.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  panelActiveClass: 'is-active'
+};
+
+/**
+ * Toggler module.
+ * @module foundation.toggler
+ * @requires foundation.util.motion
+ * @requires foundation.util.triggers
+ */
+
+class Toggler extends Plugin {
+  /**
+   * Creates a new instance of Toggler.
+   * @class
+   * @name Toggler
+   * @fires Toggler#init
+   * @param {Object} element - jQuery object to add the trigger to.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Toggler.defaults, element.data(), options);
+    this.className = '';
+    this.className = 'Toggler'; // ie9 back compat
+
+    // Triggers init is idempotent, just need to make sure it is initialized
+    Triggers.init($);
+
+    this._init();
+    this._events();
+  }
+
+  /**
+   * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.
+   * @function
+   * @private
+   */
+  _init() {
+    var input;
+    // Parse animation classes if they were set
+    if (this.options.animate) {
+      input = this.options.animate.split(' ');
+
+      this.animationIn = input[0];
+      this.animationOut = input[1] || null;
+    }
+    // Otherwise, parse toggle class
+    else {
+      input = this.$element.data('toggler');
+      // Allow for a . at the beginning of the string
+      this.className = input[0] === '.' ? input.slice(1) : input;
+    }
+
+    // Add ARIA attributes to triggers:
+    var id = this.$element[0].id,
+      $triggers = $(`[data-open~="${id}"], [data-close~="${id}"], [data-toggle~="${id}"]`);
+
+    // - aria-expanded: according to the element visibility.
+    $triggers.attr('aria-expanded', !this.$element.is(':hidden'));
+    // - aria-controls: adding the element id to it if not already in it.
+    $triggers.each((index, trigger) => {
+      const $trigger = $(trigger);
+      const controls = $trigger.attr('aria-controls') || '';
+
+      const containsId = new RegExp(`\\b${RegExpEscape(id)}\\b`).test(controls);
+      if (!containsId) $trigger.attr('aria-controls', controls ? `${controls} ${id}` : id);
+    });
+  }
+
+  /**
+   * Initializes events for the toggle trigger.
+   * @function
+   * @private
+   */
+  _events() {
+    this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));
+  }
+
+  /**
+   * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was "on" or "off".
+   * @function
+   * @fires Toggler#on
+   * @fires Toggler#off
+   */
+  toggle() {
+    this[ this.options.animate ? '_toggleAnimate' : '_toggleClass']();
+  }
+
+  _toggleClass() {
+    this.$element.toggleClass(this.className);
+
+    var isOn = this.$element.hasClass(this.className);
+    if (isOn) {
+      /**
+       * Fires if the target element has the class after a toggle.
+       * @event Toggler#on
+       */
+      this.$element.trigger('on.zf.toggler');
+    }
+    else {
+      /**
+       * Fires if the target element does not have the class after a toggle.
+       * @event Toggler#off
+       */
+      this.$element.trigger('off.zf.toggler');
+    }
+
+    this._updateARIA(isOn);
+    this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');
+  }
+
+  _toggleAnimate() {
+    var _this = this;
+
+    if (this.$element.is(':hidden')) {
+      Motion.animateIn(this.$element, this.animationIn, function() {
+        _this._updateARIA(true);
+        this.trigger('on.zf.toggler');
+        this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+      });
+    }
+    else {
+      Motion.animateOut(this.$element, this.animationOut, function() {
+        _this._updateARIA(false);
+        this.trigger('off.zf.toggler');
+        this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+      });
+    }
+  }
+
+  _updateARIA(isOn) {
+    var id = this.$element[0].id;
+    $(`[data-open="${id}"], [data-close="${id}"], [data-toggle="${id}"]`)
+      .attr({
+        'aria-expanded': isOn ? true : false
+      });
+  }
+
+  /**
+   * Destroys the instance of Toggler on the element.
+   * @function
+   */
+  _destroy() {
+    this.$element.off('.zf.toggler');
+  }
+}
+
+Toggler.defaults = {
+  /**
+   * Tells the plugin if the element should animated when toggled.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animate: false
+};
+
+/**
+ * Tooltip module.
+ * @module foundation.tooltip
+ * @requires foundation.util.box
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.triggers
+ */
+
+class Tooltip extends Positionable {
+  /**
+   * Creates a new instance of a Tooltip.
+   * @class
+   * @name Tooltip
+   * @fires Tooltip#init
+   * @param {jQuery} element - jQuery object to attach a tooltip to.
+   * @param {Object} options - object to extend the default configuration.
+   */
+  _setup(element, options) {
+    this.$element = element;
+    this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);
+    this.className = 'Tooltip'; // ie9 back compat
+
+    this.isActive = false;
+    this.isClick = false;
+
+    // Triggers init is idempotent, just need to make sure it is initialized
+    Triggers.init($);
+
+    this._init();
+  }
+
+  /**
+   * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.
+   * @private
+   */
+  _init() {
+    MediaQuery._init();
+    var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');
+
+    this.options.tipText = this.options.tipText || this.$element.attr('title');
+    this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);
+
+    if (this.options.allowHtml) {
+      this.template.appendTo(document.body)
+        .html(this.options.tipText)
+        .hide();
+    } else {
+      this.template.appendTo(document.body)
+        .text(this.options.tipText)
+        .hide();
+    }
+
+    this.$element.attr({
+      'title': '',
+      'aria-describedby': elemId,
+      'data-yeti-box': elemId,
+      'data-toggle': elemId,
+      'data-resize': elemId
+    }).addClass(this.options.triggerClass);
+
+    super._init();
+    this._events();
+  }
+
+  _getDefaultPosition() {
+    // handle legacy classnames
+    var position = this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);
+    return position ? position[0] : 'top';
+  }
+
+  _getDefaultAlignment() {
+    return 'center';
+  }
+
+  _getHOffset() {
+    if(this.position === 'left' || this.position === 'right') {
+      return this.options.hOffset + this.options.tooltipWidth;
+    } else {
+      return this.options.hOffset
+    }
+  }
+
+  _getVOffset() {
+    if(this.position === 'top' || this.position === 'bottom') {
+      return this.options.vOffset + this.options.tooltipHeight;
+    } else {
+      return this.options.vOffset
+    }
+  }
+
+  /**
+   * builds the tooltip element, adds attributes, and returns the template.
+   * @private
+   */
+  _buildTemplate(id) {
+    var templateClasses = (`${this.options.tooltipClass} ${this.options.templateClasses}`).trim();
+    var $template =  $('<div></div>').addClass(templateClasses).attr({
+      'role': 'tooltip',
+      'aria-hidden': true,
+      'data-is-active': false,
+      'data-is-focus': false,
+      'id': id
+    });
+    return $template;
+  }
+
+  /**
+   * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.
+   * if the tooltip is larger than the screen width, default to full width - any user selected margin
+   * @private
+   */
+  _setPosition() {
+    super._setPosition(this.$element, this.template);
+  }
+
+  /**
+   * reveals the tooltip, and fires an event to close any other open tooltips on the page
+   * @fires Tooltip#closeme
+   * @fires Tooltip#show
+   * @function
+   */
+  show() {
+    if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {
+      // console.error('The screen is too small to display this tooltip');
+      return false;
+    }
+
+    var _this = this;
+    this.template.css('visibility', 'hidden').show();
+    this._setPosition();
+    this.template.removeClass('top bottom left right').addClass(this.position);
+    this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);
+
+    /**
+     * Fires to close all other open tooltips on the page
+     * @event Closeme#tooltip
+     */
+    this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));
+
+
+    this.template.attr({
+      'data-is-active': true,
+      'aria-hidden': false
+    });
+    _this.isActive = true;
+    // console.log(this.template);
+    this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function() {
+      //maybe do stuff?
+    });
+    /**
+     * Fires when the tooltip is shown
+     * @event Tooltip#show
+     */
+    this.$element.trigger('show.zf.tooltip');
+  }
+
+  /**
+   * Hides the current tooltip, and resets the positioning class if it was changed due to collision
+   * @fires Tooltip#hide
+   * @function
+   */
+  hide() {
+    // console.log('hiding', this.$element.data('yeti-box'));
+    var _this = this;
+    this.template.stop().attr({
+      'aria-hidden': true,
+      'data-is-active': false
+    }).fadeOut(this.options.fadeOutDuration, function() {
+      _this.isActive = false;
+      _this.isClick = false;
+    });
+    /**
+     * fires when the tooltip is hidden
+     * @event Tooltip#hide
+     */
+    this.$element.trigger('hide.zf.tooltip');
+  }
+
+  /**
+   * adds event listeners for the tooltip and its anchor
+   * TODO combine some of the listeners like focus and mouseenter, etc.
+   * @private
+   */
+  _events() {
+    var _this = this;
+    var $template = this.template;
+    var isFocus = false;
+
+    if (!this.options.disableHover) {
+
+      this.$element
+      .on('mouseenter.zf.tooltip', function(e) {
+        if (!_this.isActive) {
+          _this.timeout = setTimeout(function() {
+            _this.show();
+          }, _this.options.hoverDelay);
+        }
+      })
+      .on('mouseleave.zf.tooltip', ignoreMousedisappear(function(e) {
+        clearTimeout(_this.timeout);
+        if (!isFocus || (_this.isClick && !_this.options.clickOpen)) {
+          _this.hide();
+        }
+      }));
+    }
+
+    if (this.options.clickOpen) {
+      this.$element.on('mousedown.zf.tooltip', function(e) {
+        e.stopImmediatePropagation();
+        if (_this.isClick) ; else {
+          _this.isClick = true;
+          if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {
+            _this.show();
+          }
+        }
+      });
+    } else {
+      this.$element.on('mousedown.zf.tooltip', function(e) {
+        e.stopImmediatePropagation();
+        _this.isClick = true;
+      });
+    }
+
+    if (!this.options.disableForTouch) {
+      this.$element
+      .on('tap.zf.tooltip touchend.zf.tooltip', function(e) {
+        _this.isActive ? _this.hide() : _this.show();
+      });
+    }
+
+    this.$element.on({
+      // 'toggle.zf.trigger': this.toggle.bind(this),
+      // 'close.zf.trigger': this.hide.bind(this)
+      'close.zf.trigger': this.hide.bind(this)
+    });
+
+    this.$element
+      .on('focus.zf.tooltip', function(e) {
+        isFocus = true;
+        if (_this.isClick) {
+          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't
+          // a real focus, otherwise on hover and come back we get bad behavior
+          if(!_this.options.clickOpen) { isFocus = false; }
+          return false;
+        } else {
+          _this.show();
+        }
+      })
+
+      .on('focusout.zf.tooltip', function(e) {
+        isFocus = false;
+        _this.isClick = false;
+        _this.hide();
+      })
+
+      .on('resizeme.zf.trigger', function() {
+        if (_this.isActive) {
+          _this._setPosition();
+        }
+      });
+  }
+
+  /**
+   * adds a toggle method, in addition to the static show() & hide() functions
+   * @function
+   */
+  toggle() {
+    if (this.isActive) {
+      this.hide();
+    } else {
+      this.show();
+    }
+  }
+
+  /**
+   * Destroys an instance of tooltip, removes template element from the view.
+   * @function
+   */
+  _destroy() {
+    this.$element.attr('title', this.template.text())
+                 .off('.zf.trigger .zf.tooltip')
+                 .removeClass(this.options.triggerClass)
+                 .removeClass('top right left bottom')
+                 .removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');
+
+    this.template.remove();
+  }
+}
+
+Tooltip.defaults = {
+  disableForTouch: false,
+  /**
+   * Time, in ms, before a tooltip should open on hover.
+   * @option
+   * @type {number}
+   * @default 200
+   */
+  hoverDelay: 200,
+  /**
+   * Time, in ms, a tooltip should take to fade into view.
+   * @option
+   * @type {number}
+   * @default 150
+   */
+  fadeInDuration: 150,
+  /**
+   * Time, in ms, a tooltip should take to fade out of view.
+   * @option
+   * @type {number}
+   * @default 150
+   */
+  fadeOutDuration: 150,
+  /**
+   * Disables hover events from opening the tooltip if set to true
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disableHover: false,
+  /**
+   * Optional addtional classes to apply to the tooltip template on init.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  templateClasses: '',
+  /**
+   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.
+   * @option
+   * @type {string}
+   * @default 'tooltip'
+   */
+  tooltipClass: 'tooltip',
+  /**
+   * Class applied to the tooltip anchor element.
+   * @option
+   * @type {string}
+   * @default 'has-tip'
+   */
+  triggerClass: 'has-tip',
+  /**
+   * Minimum breakpoint size at which to open the tooltip.
+   * @option
+   * @type {string}
+   * @default 'small'
+   */
+  showOn: 'small',
+  /**
+   * Custom template to be used to generate markup for tooltip.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  template: '',
+  /**
+   * Text displayed in the tooltip template on open.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  tipText: '',
+  touchCloseText: 'Tap to close.',
+  /**
+   * Allows the tooltip to remain open if triggered with a click or touch event.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  clickOpen: true,
+  /**
+   * Position of tooltip. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+  /**
+   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+  /**
+   * Allow overlap of container/window. If false, tooltip will first try to
+   * position as defined by data-position and data-alignment, but reposition if
+   * it would cause an overflow.  @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * Less common for tooltips.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowBottomOverlap: false,
+  /**
+   * Distance, in pixels, the template should push away from the anchor on the Y axis.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+  /**
+   * Distance, in pixels, the template should push away from the anchor on the X axis
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0,
+  /**
+   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip
+   * @option
+   * @type {number}
+   * @default 14
+   */
+  tooltipHeight: 14,
+  /**
+   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip
+   * @option
+   * @type {number}
+   * @default 12
+   */
+  tooltipWidth: 12,
+    /**
+   * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,
+   * allowing HTML may open yourself up to XSS attacks.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowHtml: false
+};
+
+// The plugin matches the plugin classes with these plugin instances.
+var MenuPlugins$1 = {
+  tabs: {
+    cssClass: 'tabs',
+    plugin: Tabs
+  },
+  accordion: {
+    cssClass: 'accordion',
+    plugin: Accordion
+  }
+};
+
+
+/**
+ * ResponsiveAccordionTabs module.
+ * @module foundation.responsiveAccordionTabs
+ * @requires foundation.util.motion
+ * @requires foundation.accordion
+ * @requires foundation.tabs
+ */
+
+class ResponsiveAccordionTabs extends Plugin{
+  /**
+   * Creates a new instance of a responsive accordion tabs.
+   * @class
+   * @name ResponsiveAccordionTabs
+   * @fires ResponsiveAccordionTabs#init
+   * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.
+   * @param {Object} options - Overrides to the default plugin settings.
+   */
+  _setup(element, options) {
+    this.$element = $(element);
+    this.options  = $.extend({}, this.$element.data(), options);
+    this.rules = this.$element.data('responsive-accordion-tabs');
+    this.currentMq = null;
+    this.currentPlugin = null;
+    this.className = 'ResponsiveAccordionTabs'; // ie9 back compat
+    if (!this.$element.attr('id')) {
+      this.$element.attr('id',GetYoDigits(6, 'responsiveaccordiontabs'));
+    }
+    this._init();
+    this._events();
+  }
+
+  /**
+   * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.
+   * @function
+   * @private
+   */
+  _init() {
+    MediaQuery._init();
+
+    // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
+    if (typeof this.rules === 'string') {
+      let rulesTree = {};
+
+      // Parse rules from "classes" pulled from data attribute
+      let rules = this.rules.split(' ');
+
+      // Iterate through every rule found
+      for (let i = 0; i < rules.length; i++) {
+        let rule = rules[i].split('-');
+        let ruleSize = rule.length > 1 ? rule[0] : 'small';
+        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+
+        if (MenuPlugins$1[rulePlugin] !== null) {
+          rulesTree[ruleSize] = MenuPlugins$1[rulePlugin];
+        }
+      }
+
+      this.rules = rulesTree;
+    }
+
+    this._getAllOptions();
+
+    if (!$.isEmptyObject(this.rules)) {
+      this._checkMediaQueries();
+    }
+  }
+
+  _getAllOptions() {
+    //get all defaults and options
+    var _this = this;
+    _this.allOptions = {};
+    for (var key in MenuPlugins$1) {
+      if (MenuPlugins$1.hasOwnProperty(key)) {
+        var obj = MenuPlugins$1[key];
+        try {
+          var dummyPlugin = $('<ul></ul>');
+          var tmpPlugin = new obj.plugin(dummyPlugin,_this.options);
+          for (var keyKey in tmpPlugin.options) {
+            if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {
+              var objObj = tmpPlugin.options[keyKey];
+              _this.allOptions[keyKey] = objObj;
+            }
+          }
+          tmpPlugin.destroy();
+        }
+        catch(e) {
+        }
+      }
+    }
+  }
+
+  /**
+   * Initializes events for the Menu.
+   * @function
+   * @private
+   */
+  _events() {
+    this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);
+    $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
+  }
+
+  /**
+   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
+   * @function
+   * @private
+   */
+  _checkMediaQueries() {
+    var matchedMq, _this = this;
+    // Iterate through each rule and find the last matching rule
+    $.each(this.rules, function(key) {
+      if (MediaQuery.atLeast(key)) {
+        matchedMq = key;
+      }
+    });
+
+    // No match? No dice
+    if (!matchedMq) return;
+
+    // Plugin already initialized? We good
+    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;
+
+    // Remove existing plugin-specific CSS classes
+    $.each(MenuPlugins$1, function(key, value) {
+      _this.$element.removeClass(value.cssClass);
+    });
+
+    // Add the CSS class for the new plugin
+    this.$element.addClass(this.rules[matchedMq].cssClass);
+
+    // Create an instance of the new plugin
+    if (this.currentPlugin) {
+      //don't know why but on nested elements data zfPlugin get's lost
+      if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin',this.storezfData);
+      this.currentPlugin.destroy();
+    }
+    this._handleMarkup(this.rules[matchedMq].cssClass);
+    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+    this.storezfData = this.currentPlugin.$element.data('zfPlugin');
+
+  }
+
+  _handleMarkup(toSet){
+    var _this = this, fromString = 'accordion';
+    var $panels = $('[data-tabs-content='+this.$element.attr('id')+']');
+    if ($panels.length) fromString = 'tabs';
+    if (fromString === toSet) {
+      return;
+    }
+    var tabsTitle = _this.allOptions.linkClass?_this.allOptions.linkClass:'tabs-title';
+    var tabsPanel = _this.allOptions.panelClass?_this.allOptions.panelClass:'tabs-panel';
+
+    this.$element.removeAttr('role');
+    var $liHeads = this.$element.children('.'+tabsTitle+',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');
+    var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');
+
+    if (fromString === 'tabs') {
+      $panels = $panels.children('.'+tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');
+      $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');
+    }else{
+      $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');
+    }
+    $panels.css({display:'',visibility:''});
+    $liHeads.css({display:'',visibility:''});
+    if (toSet === 'accordion') {
+      $panels.each(function(key,value){
+        $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content','').removeClass('is-active').css({height:''});
+        $('[data-tabs-content='+_this.$element.attr('id')+']').after('<div id="tabs-placeholder-'+_this.$element.attr('id')+'"></div>').detach();
+        $liHeads.addClass('accordion-item').attr('data-accordion-item','');
+        $liHeadsA.addClass('accordion-title');
+      });
+    }else if (toSet === 'tabs'){
+      var $tabsContent = $('[data-tabs-content='+_this.$element.attr('id')+']');
+      var $placeholder = $('#tabs-placeholder-'+_this.$element.attr('id'));
+      if ($placeholder.length) {
+        $tabsContent = $('<div class="tabs-content"></div>').insertAfter($placeholder).attr('data-tabs-content',_this.$element.attr('id'));
+        $placeholder.remove();
+      }else{
+        $tabsContent = $('<div class="tabs-content"></div>').insertAfter(_this.$element).attr('data-tabs-content',_this.$element.attr('id'));
+      }      $panels.each(function(key,value){
+        var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);
+        var hash = $liHeadsA.get(key).hash.slice(1);
+        var id = $(value).attr('id') || GetYoDigits(6, 'accordion');
+        if (hash !== id) {
+          if (hash !== '') {
+            $(value).attr('id',hash);
+          }else{
+            hash = id;
+            $(value).attr('id',hash);
+            $($liHeadsA.get(key)).attr('href',$($liHeadsA.get(key)).attr('href').replace('#','')+'#'+hash);
+          }        }        var isActive = $($liHeads.get(key)).hasClass('is-active');
+        if (isActive) {
+          tempValue.addClass('is-active');
+        }      });
+      $liHeads.addClass(tabsTitle);
+    }  }
+
+  /**
+   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+   * @function
+   */
+  _destroy() {
+    if (this.currentPlugin) this.currentPlugin.destroy();
+    $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
+  }
+}
+
+ResponsiveAccordionTabs.defaults = {};
+
+Foundation.addToJquery($);
+
+// Add Foundation Utils to Foundation global namespace for backwards
+// compatibility.
+Foundation.rtl = rtl;
+Foundation.GetYoDigits = GetYoDigits;
+Foundation.transitionend = transitionend;
+Foundation.RegExpEscape = RegExpEscape;
+Foundation.onLoad = onLoad;
+
+Foundation.Box = Box;
+Foundation.onImagesLoaded = onImagesLoaded;
+Foundation.Keyboard = Keyboard;
+Foundation.MediaQuery = MediaQuery;
+Foundation.Motion = Motion;
+Foundation.Move = Move;
+Foundation.Nest = Nest;
+Foundation.Timer = Timer;
+
+// Touch and Triggers previously were almost purely sede effect driven,
+// so no need to add it to Foundation, just init them.
+Touch.init($);
+Triggers.init($, Foundation);
+MediaQuery._init();
+
+Foundation.plugin(Abide, 'Abide');
+Foundation.plugin(Accordion, 'Accordion');
+Foundation.plugin(AccordionMenu, 'AccordionMenu');
+Foundation.plugin(Drilldown, 'Drilldown');
+Foundation.plugin(Dropdown, 'Dropdown');
+Foundation.plugin(DropdownMenu, 'DropdownMenu');
+Foundation.plugin(Equalizer, 'Equalizer');
+Foundation.plugin(Interchange, 'Interchange');
+Foundation.plugin(Magellan, 'Magellan');
+Foundation.plugin(OffCanvas, 'OffCanvas');
+Foundation.plugin(Orbit, 'Orbit');
+Foundation.plugin(ResponsiveMenu, 'ResponsiveMenu');
+Foundation.plugin(ResponsiveToggle, 'ResponsiveToggle');
+Foundation.plugin(Reveal, 'Reveal');
+Foundation.plugin(Slider, 'Slider');
+Foundation.plugin(SmoothScroll, 'SmoothScroll');
+Foundation.plugin(Sticky, 'Sticky');
+Foundation.plugin(Tabs, 'Tabs');
+Foundation.plugin(Toggler, 'Toggler');
+Foundation.plugin(Tooltip, 'Tooltip');
+Foundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');
+
+export default Foundation;
+export { foundation_core_utils as CoreUtils, Foundation as Core, Foundation, Box, onImagesLoaded, Keyboard, MediaQuery, Motion, Move, Nest, Timer, Touch, Triggers, Abide, Accordion, AccordionMenu, Drilldown, Dropdown, DropdownMenu, Equalizer, Interchange, Magellan, OffCanvas, Orbit, ResponsiveMenu, ResponsiveToggle, Reveal, Slider, SmoothScroll, Sticky, Tabs, Toggler, Tooltip, ResponsiveAccordionTabs };
+//# sourceMappingURL=foundation.es6.js.map
diff --git a/dist/js/foundation.es6.js.map b/dist/js/foundation.es6.js.map
new file mode 100644 (file)
index 0000000..f8d9f38
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"file":"foundation.es6.js","sources":["../../js/foundation.core.utils.js","../../js/foundation.util.mediaQuery.js","../../js/foundation.core.js","../../js/foundation.util.box.js","../../js/foundation.util.imageLoader.js","../../js/foundation.util.keyboard.js","../../js/foundation.util.motion.js","../../js/foundation.util.nest.js","../../js/foundation.util.timer.js","../../js/foundation.util.touch.js","../../js/foundation.util.triggers.js","../../js/foundation.core.plugin.js","../../js/foundation.abide.js","../../js/foundation.accordion.js","../../js/foundation.accordionMenu.js","../../js/foundation.drilldown.js","../../js/foundation.positionable.js","../../js/foundation.dropdown.js","../../js/foundation.dropdownMenu.js","../../js/foundation.equalizer.js","../../js/foundation.interchange.js","../../js/foundation.smoothScroll.js","../../js/foundation.magellan.js","../../js/foundation.offcanvas.js","../../js/foundation.orbit.js","../../js/foundation.responsiveMenu.js","../../js/foundation.responsiveToggle.js","../../js/foundation.reveal.js","../../js/foundation.slider.js","../../js/foundation.sticky.js","../../js/foundation.tabs.js","../../js/foundation.toggler.js","../../js/foundation.tooltip.js","../../js/foundation.responsiveAccordionTabs.js","../../js/entries/foundation.js"],"sourcesContent":["\"use strict\";\n\nimport $ from 'jquery';\n\n// Core Foundation Utilities, utilized in a number of places.\n\n  /**\n   * Returns a boolean for RTL support\n   */\nfunction rtl() {\n  return $('html').attr('dir') === 'rtl';\n}\n\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\nfunction GetYoDigits(length, namespace){\n  length = length || 6;\n  return Math.round((Math.pow(36, length + 1) - Math.random() * Math.pow(36, length))).toString(36).slice(1) + (namespace ? `-${namespace}` : '');\n}\n\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\nfunction RegExpEscape(str){\n  return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem){\n  var transitions = {\n    'transition': 'transitionend',\n    'WebkitTransition': 'webkitTransitionEnd',\n    'MozTransition': 'transitionend',\n    'OTransition': 'otransitionend'\n  };\n  var elem = document.createElement('div'),\n      end;\n\n  for (var t in transitions){\n    if (typeof elem.style[t] !== 'undefined'){\n      end = transitions[t];\n    }\n  }\n  if(end){\n    return end;\n  }else{\n    end = setTimeout(function(){\n      $elem.triggerHandler('transitionend', [$elem]);\n    }, 1);\n    return 'transitionend';\n  }\n}\n\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\nfunction onLoad($elem, handler) {\n  const didLoad = document.readyState === 'complete';\n  const eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n  const cb = () => $elem.triggerHandler(eventType);\n\n  if ($elem) {\n    if (handler) $elem.one(eventType, handler);\n\n    if (didLoad)\n      setTimeout(cb);\n    else\n      $(window).one('load', cb);\n  }\n\n  return eventType;\n}\n\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n *   (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n *   outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\nfunction ignoreMousedisappear(handler, { ignoreLeaveWindow = false, ignoreReappear = false } = {}) {\n  return function leaveEventHandler(eLeave, ...rest) {\n    const callback = handler.bind(this, eLeave, ...rest);\n\n    // The mouse left: call the given callback if the mouse entered elsewhere\n    if (eLeave.relatedTarget !== null) {\n      return callback();\n    }\n\n    // Otherwise, check if the mouse actually left the window.\n    // In firefox if the user switched between windows, the window sill have the focus by the time\n    // the event is triggered. We have to debounce the event to test this case.\n    setTimeout(function leaveEventDebouncer() {\n      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n        return callback();\n      }\n\n      // Otherwise, wait for the mouse to reeapear outside of the element,\n      if (!ignoreReappear) {\n        $(document).one('mouseenter', function reenterEventHandler(eReenter) {\n          if (!$(eLeave.currentTarget).has(eReenter.target).length) {\n            // Fill where the mouse finally entered.\n            eLeave.relatedTarget = eReenter.target;\n            callback();\n          }\n        });\n      }\n\n    }, 0);\n  };\n}\n\nexport { rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear };\n","'use strict';\n\nimport $ from 'jquery';\n\n// Default set of media queries\nconst defaultQueries = {\n  'default' : 'only screen',\n  landscape : 'only screen and (orientation: landscape)',\n  portrait : 'only screen and (orientation: portrait)',\n  retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' +\n    'only screen and (min--moz-device-pixel-ratio: 2),' +\n    'only screen and (-o-min-device-pixel-ratio: 2/1),' +\n    'only screen and (min-device-pixel-ratio: 2),' +\n    'only screen and (min-resolution: 192dpi),' +\n    'only screen and (min-resolution: 2dppx)'\n  };\n\n\n// matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n/* eslint-disable */\nwindow.matchMedia || (window.matchMedia = (function () {\n  \"use strict\";\n\n  // For browsers that support matchMedium api such as IE 9 and webkit\n  var styleMedia = (window.styleMedia || window.media);\n\n  // For those that don't support matchMedium\n  if (!styleMedia) {\n    var style   = document.createElement('style'),\n    script      = document.getElementsByTagName('script')[0],\n    info        = null;\n\n    style.type  = 'text/css';\n    style.id    = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    }\n\n    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n    info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;\n\n    styleMedia = {\n      matchMedium: function (media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';\n\n        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        }\n\n        // Test if media query is true or false\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function(media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n})());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init() {\n    var self = this;\n    var $meta = $('meta.foundation-mq');\n    if(!$meta.length){\n      $('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = $('.foundation-mq').css('font-family');\n    var namedQueries;\n\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if(namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: `only screen and (min-width: ${namedQueries[key]})`\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is(size) {\n    size = size.trim().split(' ');\n    if(size.length > 1 && size[1] === 'only') {\n      if(size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get(size) {\n    for (var i in this.queries) {\n      if(this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (typeof matched === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher() {\n    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', () => {\n      var newSize = this._getCurrentSize(), currentSize = this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        this.current = newSize;\n\n        // Broadcast the media query change on the window\n        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n};\n\n\n\n// Thank you: https://github.com/sindresorhus/query-string\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function(ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key);\n\n    // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n    return ret;\n  }, {});\n\n  return styleObject;\n}\n\nexport {MediaQuery};\n","\"use strict\";\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\n\nvar FOUNDATION_VERSION = '6.5.3';\n\n// Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\nvar Foundation = {\n  version: FOUNDATION_VERSION,\n\n  /**\n   * Stores initialized plugins.\n   */\n  _plugins: {},\n\n  /**\n   * Stores generated unique ids for plugin instances\n   */\n  _uuids: [],\n\n  /**\n   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n   * @param {Object} plugin - The constructor of the plugin.\n   */\n  plugin: function(plugin, name) {\n    // Object key to use when adding to global Foundation object\n    // Examples: Foundation.Reveal, Foundation.OffCanvas\n    var className = (name || functionName(plugin));\n    // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n    // Examples: data-reveal, data-off-canvas\n    var attrName  = hyphenate(className);\n\n    // Add to the Foundation object and the plugins list (for reflowing)\n    this._plugins[attrName] = this[className] = plugin;\n  },\n  /**\n   * @function\n   * Populates the _uuids array with pointers to each individual plugin instance.\n   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n   * Also fires the initialization event for each plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @param {String} name - the name of the plugin, passed as a camelCased string.\n   * @fires Plugin#init\n   */\n  registerPlugin: function(plugin, name){\n    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n    plugin.uuid = GetYoDigits(6, pluginName);\n\n    if(!plugin.$element.attr(`data-${pluginName}`)){ plugin.$element.attr(`data-${pluginName}`, plugin.uuid); }\n    if(!plugin.$element.data('zfPlugin')){ plugin.$element.data('zfPlugin', plugin); }\n          /**\n           * Fires when the plugin has initialized.\n           * @event Plugin#init\n           */\n    plugin.$element.trigger(`init.zf.${pluginName}`);\n\n    this._uuids.push(plugin.uuid);\n\n    return;\n  },\n  /**\n   * @function\n   * Removes the plugins uuid from the _uuids array.\n   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n   * Also fires the destroyed event for the plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @fires Plugin#destroyed\n   */\n  unregisterPlugin: function(plugin){\n    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n    plugin.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n          /**\n           * Fires when the plugin has been destroyed.\n           * @event Plugin#destroyed\n           */\n          .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in plugin){\n      plugin[prop] = null;//clean up script to prep for garbage collection.\n    }\n    return;\n  },\n\n  /**\n   * @function\n   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n   * @default If no argument is passed, reflow all currently active plugins.\n   */\n   reInit: function(plugins){\n     var isJQ = plugins instanceof $;\n     try{\n       if(isJQ){\n         plugins.each(function(){\n           $(this).data('zfPlugin')._init();\n         });\n       }else{\n         var type = typeof plugins,\n         _this = this,\n         fns = {\n           'object': function(plgs){\n             plgs.forEach(function(p){\n               p = hyphenate(p);\n               $('[data-'+ p +']').foundation('_init');\n             });\n           },\n           'string': function(){\n             plugins = hyphenate(plugins);\n             $('[data-'+ plugins +']').foundation('_init');\n           },\n           'undefined': function(){\n             this['object'](Object.keys(_this._plugins));\n           }\n         };\n         fns[type](plugins);\n       }\n     }catch(err){\n       console.error(err);\n     }finally{\n       return plugins;\n     }\n   },\n\n  /**\n   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n   */\n  reflow: function(elem, plugins) {\n\n    // If plugins is undefined, just grab everything\n    if (typeof plugins === 'undefined') {\n      plugins = Object.keys(this._plugins);\n    }\n    // If plugins is a string, convert it to an array with one item\n    else if (typeof plugins === 'string') {\n      plugins = [plugins];\n    }\n\n    var _this = this;\n\n    // Iterate through each plugin\n    $.each(plugins, function(i, name) {\n      // Get the current plugin\n      var plugin = _this._plugins[name];\n\n      // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n      var $elem = $(elem).find('[data-'+name+']').addBack('[data-'+name+']');\n\n      // For each plugin found, initialize it\n      $elem.each(function() {\n        var $el = $(this),\n            opts = {};\n        // Don't double-dip on plugins\n        if ($el.data('zfPlugin')) {\n          console.warn(\"Tried to initialize \"+name+\" on an element that already has a Foundation plugin.\");\n          return;\n        }\n\n        if($el.attr('data-options')){\n          var thing = $el.attr('data-options').split(';').forEach(function(e, i){\n            var opt = e.split(':').map(function(el){ return el.trim(); });\n            if(opt[0]) opts[opt[0]] = parseValue(opt[1]);\n          });\n        }\n        try{\n          $el.data('zfPlugin', new plugin($(this), opts));\n        }catch(er){\n          console.error(er);\n        }finally{\n          return;\n        }\n      });\n    });\n  },\n  getFnName: functionName,\n\n  addToJquery: function($) {\n    // TODO: consider not making this a jQuery function\n    // TODO: need way to reflow vs. re-initialize\n    /**\n     * The Foundation jQuery method.\n     * @param {String|Array} method - An action to perform on the current jQuery object.\n     */\n    var foundation = function(method) {\n      var type = typeof method,\n          $noJS = $('.no-js');\n\n      if($noJS.length){\n        $noJS.removeClass('no-js');\n      }\n\n      if(type === 'undefined'){//needs to initialize the Foundation object, or an individual plugin.\n        MediaQuery._init();\n        Foundation.reflow(this);\n      }else if(type === 'string'){//an individual method to invoke on a plugin or group of plugins\n        var args = Array.prototype.slice.call(arguments, 1);//collect all the arguments, if necessary\n        var plugClass = this.data('zfPlugin');//determine the class of plugin\n\n        if(typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined'){//make sure both the class and method exist\n          if(this.length === 1){//if there's only one, call it directly.\n              plugClass[method].apply(plugClass, args);\n          }else{\n            this.each(function(i, el){//otherwise loop through the jQuery collection and invoke the method on each\n              plugClass[method].apply($(el).data('zfPlugin'), args);\n            });\n          }\n        }else{//error for no class or no method\n          throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n        }\n      }else{//error for invalid argument type\n        throw new TypeError(`We're sorry, ${type} is not a valid parameter. You must use a string representing the method you wish to invoke.`);\n      }\n      return this;\n    };\n    $.fn.foundation = foundation;\n    return $;\n  }\n};\n\nFoundation.util = {\n  /**\n   * Function for applying a debounce effect to a function call.\n   * @function\n   * @param {Function} func - Function to be called at end of timeout.\n   * @param {Number} delay - Time in ms to delay the call of `func`.\n   * @returns function\n   */\n  throttle: function (func, delay) {\n    var timer = null;\n\n    return function () {\n      var context = this, args = arguments;\n\n      if (timer === null) {\n        timer = setTimeout(function () {\n          func.apply(context, args);\n          timer = null;\n        }, delay);\n      }\n    };\n  }\n};\n\nwindow.Foundation = Foundation;\n\n// Polyfill for requestAnimationFrame\n(function() {\n  if (!Date.now || !window.Date.now)\n    window.Date.now = Date.now = function() { return new Date().getTime(); };\n\n  var vendors = ['webkit', 'moz'];\n  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n      var vp = vendors[i];\n      window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];\n      window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']\n                                 || window[vp+'CancelRequestAnimationFrame']);\n  }\n  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)\n    || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n    var lastTime = 0;\n    window.requestAnimationFrame = function(callback) {\n        var now = Date.now();\n        var nextTime = Math.max(lastTime + 16, now);\n        return setTimeout(function() { callback(lastTime = nextTime); },\n                          nextTime - now);\n    };\n    window.cancelAnimationFrame = clearTimeout;\n  }\n  /**\n   * Polyfill for performance.now, required by rAF\n   */\n  if(!window.performance || !window.performance.now){\n    window.performance = {\n      start: Date.now(),\n      now: function(){ return Date.now() - this.start; }\n    };\n  }\n})();\nif (!Function.prototype.bind) {\n  Function.prototype.bind = function(oThis) {\n    if (typeof this !== 'function') {\n      // closest thing possible to the ECMAScript 5\n      // internal IsCallable function\n      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n    }\n\n    var aArgs   = Array.prototype.slice.call(arguments, 1),\n        fToBind = this,\n        fNOP    = function() {},\n        fBound  = function() {\n          return fToBind.apply(this instanceof fNOP\n                 ? this\n                 : oThis,\n                 aArgs.concat(Array.prototype.slice.call(arguments)));\n        };\n\n    if (this.prototype) {\n      // native functions don't have a prototype\n      fNOP.prototype = this.prototype;\n    }\n    fBound.prototype = new fNOP();\n\n    return fBound;\n  };\n}\n// Polyfill to get the name of a function in IE9\nfunction functionName(fn) {\n  if (typeof Function.prototype.name === 'undefined') {\n    var funcNameRegex = /function\\s([^(]{1,})\\(/;\n    var results = (funcNameRegex).exec((fn).toString());\n    return (results && results.length > 1) ? results[1].trim() : \"\";\n  }\n  else if (typeof fn.prototype === 'undefined') {\n    return fn.constructor.name;\n  }\n  else {\n    return fn.prototype.constructor.name;\n  }\n}\nfunction parseValue(str){\n  if ('true' === str) return true;\n  else if ('false' === str) return false;\n  else if (!isNaN(str * 1)) return parseFloat(str);\n  return str;\n}\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nexport {Foundation};\n","'use strict';\n\n\nimport { rtl as Rtl } from \"./foundation.core.utils\";\n\nvar Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  OverlapArea: OverlapArea,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets,\n  GetExplicitOffsets: GetExplicitOffsets\n}\n\n/**\n * Compares the dimensions of an element to a container and determines collision events with container.\n * @function\n * @param {jQuery} element - jQuery object to test for collisions.\n * @param {jQuery} parent - jQuery object to use as bounding container.\n * @param {Boolean} lrOnly - set to true to check left and right values only.\n * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n * @default if no parent object passed, detects collisions with `window`.\n * @returns {Boolean} - true if collision free, false if a collision in any direction.\n */\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n};\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  var eleDims = GetDimensions(element),\n  topOver, bottomOver, leftOver, rightOver;\n  if (parent) {\n    var parDims = GetDimensions(parent);\n\n    bottomOver = (parDims.height + parDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - parDims.offset.top;\n    leftOver   = eleDims.offset.left - parDims.offset.left;\n    rightOver  = (parDims.width + parDims.offset.left) - (eleDims.offset.left + eleDims.width);\n  }\n  else {\n    bottomOver = (eleDims.windowDims.height + eleDims.windowDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - eleDims.windowDims.offset.top;\n    leftOver   = eleDims.offset.left - eleDims.windowDims.offset.left;\n    rightOver  = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n  }\n\n  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n  topOver    = Math.min(topOver, 0);\n  leftOver   = Math.min(leftOver, 0);\n  rightOver  = Math.min(rightOver, 0);\n\n  if (lrOnly) {\n    return leftOver + rightOver;\n  }\n  if (tbOnly) {\n    return topOver + bottomOver;\n  }\n\n  // use sum of squares b/c we care about overlap area.\n  return Math.sqrt((topOver * topOver) + (bottomOver * bottomOver) + (leftOver * leftOver) + (rightOver * rightOver));\n}\n\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\nfunction GetDimensions(elem){\n  elem = elem.length ? elem[0] : elem;\n\n  if (elem === window || elem === document) {\n    throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n  }\n\n  var rect = elem.getBoundingClientRect(),\n      parRect = elem.parentNode.getBoundingClientRect(),\n      winRect = document.body.getBoundingClientRect(),\n      winY = window.pageYOffset,\n      winX = window.pageXOffset;\n\n  return {\n    width: rect.width,\n    height: rect.height,\n    offset: {\n      top: rect.top + winY,\n      left: rect.left + winX\n    },\n    parentDims: {\n      width: parRect.width,\n      height: parRect.height,\n      offset: {\n        top: parRect.top + winY,\n        left: parRect.left + winX\n      }\n    },\n    windowDims: {\n      width: winRect.width,\n      height: winRect.height,\n      offset: {\n        top: winY,\n        left: winX\n      }\n    }\n  }\n}\n\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\nfunction GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {\n  console.log(\"NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5\");\n  switch (position) {\n    case 'top':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);\n    case 'bottom':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    case 'center top':\n      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);\n    case 'center bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);\n    case 'center left':\n      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);\n    case 'center right':\n      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);\n    case 'left bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);\n    case 'right bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    // Backwards compatibility... this along with the reveal and reveal full\n    // classes are the only ones that didn't reference anchor\n    case 'center':\n      return {\n        left: ($eleDims.windowDims.offset.left + ($eleDims.windowDims.width / 2)) - ($eleDims.width / 2) + hOffset,\n        top: ($eleDims.windowDims.offset.top + ($eleDims.windowDims.height / 2)) - ($eleDims.height / 2 + vOffset)\n      }\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + vOffset\n      }\n    case 'reveal full':\n      return {\n        left: $eleDims.windowDims.offset.left,\n        top: $eleDims.windowDims.offset.top\n      }\n      break;\n    default:\n      return {\n        left: (Rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset: $anchorDims.offset.left + hOffset),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n\n  }\n\n}\n\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n      var topVal, leftVal;\n\n  // set position related attribute\n\n  switch (position) {\n    case 'top':\n      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n      break;\n    case 'bottom':\n      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n      break;\n    case 'left':\n      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n      break;\n    case 'right':\n      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n      break;\n  }\n\n\n  // set alignment related attribute\n  switch (position) {\n    case 'top':\n    case 'bottom':\n      switch (alignment) {\n        case 'left':\n          leftVal = $anchorDims.offset.left + hOffset;\n          break;\n        case 'right':\n          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n          break;\n        case 'center':\n          leftVal = isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)) + hOffset;\n          break;\n      }\n      break;\n    case 'right':\n    case 'left':\n      switch (alignment) {\n        case 'bottom':\n          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n          break;\n        case 'top':\n          topVal = $anchorDims.offset.top + vOffset\n          break;\n        case 'center':\n          topVal = ($anchorDims.offset.top + vOffset + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n          break;\n      }\n      break;\n  }\n  return {top: topVal, left: leftVal};\n}\n\nexport {Box};\n","'use strict';\n\nimport $ from 'jquery';\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\nfunction onImagesLoaded(images, callback){\n  var self = this,\n      unloaded = images.length;\n\n  if (unloaded === 0) {\n    callback();\n  }\n\n  images.each(function(){\n    // Check if image is loaded\n    if (this.complete && typeof this.naturalWidth !== 'undefined') {\n      singleImageLoaded();\n    }\n    else {\n      // If the above check failed, simulate loading on detached element.\n      var image = new Image();\n      // Still count image as loaded if it finalizes with an error.\n      var events = \"load.zf.images error.zf.images\";\n      $(image).one(events, function me(event){\n        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n        $(this).off(events, me);\n        singleImageLoaded();\n      });\n      image.src = $(this).attr('src');\n    }\n  });\n\n  function singleImageLoaded() {\n    unloaded--;\n    if (unloaded === 0) {\n      callback();\n    }\n  }\n}\n\nexport { onImagesLoaded };\n","/*******************************************\n *                                         *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n *                                         *\n ******************************************/\n\n'use strict';\n\nimport $ from 'jquery';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  35: 'END',\n  36: 'HOME',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n}\n\nvar commands = {}\n\n// Functions pulled out to be referenceable from internals\nfunction findFocusable($element) {\n  if(!$element) {return false; }\n  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function() {\n    if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) { return false; } //only have visible elements and those that have a tabindex greater or equal 0\n    return true;\n  });\n}\n\nfunction parseKey(event) {\n  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();\n\n  // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n  key = key.replace(/\\W+/, '');\n\n  if (event.shiftKey) key = `SHIFT_${key}`;\n  if (event.ctrlKey) key = `CTRL_${key}`;\n  if (event.altKey) key = `ALT_${key}`;\n\n  // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n  key = key.replace(/_$/, '');\n\n  return key;\n}\n\nvar Keyboard = {\n  keys: getKeyCodes(keyCodes),\n\n  /**\n   * Parses the (keyboard) event and returns a String that represents its key\n   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n   * @param {Event} event - the event generated by the event handler\n   * @return String key - String that represents the key pressed\n   */\n  parseKey: parseKey,\n\n  /**\n   * Handles the given (keyboard) event\n   * @param {Event} event - the event generated by the event handler\n   * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n   * @param {Objects} functions - collection of functions that are to be executed\n   */\n  handleKey(event, component, functions) {\n    var commandList = commands[component],\n      keyCode = this.parseKey(event),\n      cmds,\n      command,\n      fn;\n\n    if (!commandList) return console.warn('Component not defined!');\n\n    if (typeof commandList.ltr === 'undefined') { // this component does not differentiate between ltr and rtl\n        cmds = commandList; // use plain list\n    } else { // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n        if (Rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);\n\n        else cmds = $.extend({}, commandList.rtl, commandList.ltr);\n    }\n    command = cmds[keyCode];\n\n    fn = functions[command];\n    if (fn && typeof fn === 'function') { // execute function  if exists\n      var returnValue = fn.apply();\n      if (functions.handled || typeof functions.handled === 'function') { // execute function when event was handled\n          functions.handled(returnValue);\n      }\n    } else {\n      if (functions.unhandled || typeof functions.unhandled === 'function') { // execute function when event was not handled\n          functions.unhandled();\n      }\n    }\n  },\n\n  /**\n   * Finds all focusable elements within the given `$element`\n   * @param {jQuery} $element - jQuery object to search within\n   * @return {jQuery} $focusable - all focusable elements within `$element`\n   */\n\n  findFocusable: findFocusable,\n\n  /**\n   * Returns the component name name\n   * @param {Object} component - Foundation component, e.g. Slider or Reveal\n   * @return String componentName\n   */\n\n  register(componentName, cmds) {\n    commands[componentName] = cmds;\n  },\n\n\n  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n  //\n  /**\n   * Traps the focus in the given element.\n   * @param  {jQuery} $element  jQuery object to trap the foucs into.\n   */\n  trapFocus($element) {\n    var $focusable = findFocusable($element),\n        $firstFocusable = $focusable.eq(0),\n        $lastFocusable = $focusable.eq(-1);\n\n    $element.on('keydown.zf.trapfocus', function(event) {\n      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      }\n      else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n        event.preventDefault();\n        $lastFocusable.focus();\n      }\n    });\n  },\n  /**\n   * Releases the trapped focus from the given element.\n   * @param  {jQuery} $element  jQuery object to release the focus for.\n   */\n  releaseFocus($element) {\n    $element.off('keydown.zf.trapfocus');\n  }\n}\n\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\nfunction getKeyCodes(kcs) {\n  var k = {};\n  for (var kc in kcs) k[kcs[kc]] = kcs[kc];\n  return k;\n}\n\nexport {Keyboard};\n","'use strict';\n\nimport $ from 'jquery';\nimport { transitionend } from './foundation.core.utils';\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nconst initClasses   = ['mui-enter', 'mui-leave'];\nconst activeClasses = ['mui-enter-active', 'mui-leave-active'];\n\nconst Motion = {\n  animateIn: function(element, animation, cb) {\n    animate(true, element, animation, cb);\n  },\n\n  animateOut: function(element, animation, cb) {\n    animate(false, element, animation, cb);\n  }\n}\n\nfunction Move(duration, elem, fn){\n  var anim, prog, start = null;\n  // console.log('called');\n\n  if (duration === 0) {\n    fn.apply(elem);\n    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    return;\n  }\n\n  function move(ts){\n    if(!start) start = ts;\n    // console.log(start, ts);\n    prog = ts - start;\n    fn.apply(elem);\n\n    if(prog < duration){ anim = window.requestAnimationFrame(move, elem); }\n    else{\n      window.cancelAnimationFrame(anim);\n      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    }\n  }\n  anim = window.requestAnimationFrame(move);\n}\n\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\nfunction animate(isIn, element, animation, cb) {\n  element = $(element).eq(0);\n\n  if (!element.length) return;\n\n  var initClass = isIn ? initClasses[0] : initClasses[1];\n  var activeClass = isIn ? activeClasses[0] : activeClasses[1];\n\n  // Set up the animation\n  reset();\n\n  element\n    .addClass(animation)\n    .css('transition', 'none');\n\n  requestAnimationFrame(() => {\n    element.addClass(initClass);\n    if (isIn) element.show();\n  });\n\n  // Start the animation\n  requestAnimationFrame(() => {\n    element[0].offsetWidth;\n    element\n      .css('transition', '')\n      .addClass(activeClass);\n  });\n\n  // Clean up the animation when it finishes\n  element.one(transitionend(element), finish);\n\n  // Hides the element (for out animations), resets the element, and runs a callback\n  function finish() {\n    if (!isIn) element.hide();\n    reset();\n    if (cb) cb.apply(element);\n  }\n\n  // Resets transitions and removes motion-specific classes\n  function reset() {\n    element[0].style.transitionDuration = 0;\n    element.removeClass(`${initClass} ${activeClass} ${animation}`);\n  }\n}\n\nexport { Move, Motion };\n\n","'use strict';\n\nimport $ from 'jquery';\n\nconst Nest = {\n  Feather(menu, type = 'zf') {\n    menu.attr('role', 'menubar');\n\n    var items = menu.find('li').attr({'role': 'menuitem'}),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`,\n        applyAria = (type !== 'accordion'); // Accordions handle their own ARIA attriutes.\n\n    items.each(function() {\n      var $item = $(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item.addClass(hasSubClass);\n        if(applyAria) {\n          $item.attr({\n            'aria-haspopup': true,\n            'aria-label': $item.children('a:first').text()\n          });\n          // Note:  Drilldowns behave differently in how they hide, and so need\n          // additional attributes.  We should look if this possibly over-generalized\n          // utility (Nest) is appropriate when we rework menus in 6.4\n          if(type === 'drilldown') {\n            $item.attr({'aria-expanded': false});\n          }\n        }\n        $sub\n          .addClass(`submenu ${subMenuClass}`)\n          .attr({\n            'data-submenu': '',\n            'role': 'menubar'\n          });\n        if(type === 'drilldown') {\n          $sub.attr({'aria-hidden': true});\n        }\n      }\n\n      if ($item.parent('[data-submenu]').length) {\n        $item.addClass(`is-submenu-item ${subItemClass}`);\n      }\n    });\n\n    return;\n  },\n\n  Burn(menu, type) {\n    var //items = menu.find('li'),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`;\n\n    menu\n      .find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li')\n      .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n      .removeAttr('data-submenu').css('display', '');\n\n  }\n}\n\nexport {Nest};\n","'use strict';\n\nimport $ from 'jquery';\n\nfunction Timer(elem, options, cb) {\n  var _this = this,\n      duration = options.duration,//options is an object for easily adding features later.\n      nameSpace = Object.keys(elem.data())[0] || 'timer',\n      remain = -1,\n      start,\n      timer;\n\n  this.isPaused = false;\n\n  this.restart = function() {\n    remain = -1;\n    clearTimeout(timer);\n    this.start();\n  }\n\n  this.start = function() {\n    this.isPaused = false;\n    // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    remain = remain <= 0 ? duration : remain;\n    elem.data('paused', false);\n    start = Date.now();\n    timer = setTimeout(function(){\n      if(options.infinite){\n        _this.restart();//rerun the timer.\n      }\n      if (cb && typeof cb === 'function') { cb(); }\n    }, remain);\n    elem.trigger(`timerstart.zf.${nameSpace}`);\n  }\n\n  this.pause = function() {\n    this.isPaused = true;\n    //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    elem.data('paused', true);\n    var end = Date.now();\n    remain = remain - (end - start);\n    elem.trigger(`timerpaused.zf.${nameSpace}`);\n  }\n}\n\nexport {Timer};\n","//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nimport $ from 'jquery';\n\nvar Touch = {};\n\nvar startPosX,\n    startPosY,\n    startTime,\n    elapsedTime,\n    startEvent,\n    isMoving = false,\n    didMoved = false;\n\nfunction onTouchEnd(e) {\n  this.removeEventListener('touchmove', onTouchMove);\n  this.removeEventListener('touchend', onTouchEnd);\n\n  // If the touch did not move, consider it as a \"tap\"\n  if (!didMoved) {\n    var tapEvent = $.Event('tap', startEvent || e);\n    $(this).trigger(tapEvent);\n  }\n\n  startEvent = null;\n  isMoving = false;\n  didMoved = false;\n}\n\nfunction onTouchMove(e) {\n  if ($.spotSwipe.preventDefault) { e.preventDefault(); }\n\n  if(isMoving) {\n    var x = e.touches[0].pageX;\n    var y = e.touches[0].pageY;\n    var dx = startPosX - x;\n    var dy = startPosY - y;\n    var dir;\n    didMoved = true;\n    elapsedTime = new Date().getTime() - startTime;\n    if(Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n      dir = dx > 0 ? 'left' : 'right';\n    }\n    // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n    //   dir = dy > 0 ? 'down' : 'up';\n    // }\n    if(dir) {\n      e.preventDefault();\n      onTouchEnd.apply(this, arguments);\n      $(this)\n        .trigger($.Event('swipe', e), dir)\n        .trigger($.Event(`swipe${dir}`, e));\n    }\n  }\n\n}\n\nfunction onTouchStart(e) {\n\n  if (e.touches.length == 1) {\n    startPosX = e.touches[0].pageX;\n    startPosY = e.touches[0].pageY;\n    startEvent = e;\n    isMoving = true;\n    didMoved = false;\n    startTime = new Date().getTime();\n    this.addEventListener('touchmove', onTouchMove, false);\n    this.addEventListener('touchend', onTouchEnd, false);\n  }\n}\n\nfunction init() {\n  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);\n}\n\nfunction teardown() {\n  this.removeEventListener('touchstart', onTouchStart);\n}\n\nclass SpotSwipe {\n  constructor($) {\n    this.version = '1.0.0';\n    this.enabled = 'ontouchstart' in document.documentElement;\n    this.preventDefault = false;\n    this.moveThreshold = 75;\n    this.timeThreshold = 200;\n    this.$ = $;\n    this._init();\n  }\n\n  _init() {\n    var $ = this.$;\n    $.event.special.swipe = { setup: init };\n    $.event.special.tap = { setup: init };\n\n    $.each(['left', 'up', 'down', 'right'], function () {\n      $.event.special[`swipe${this}`] = { setup: function(){\n        $(this).on('swipe', $.noop);\n      } };\n    });\n  }\n}\n\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and    *\n * setupTouchHandler should be idempotent,          *\n * because they directly replace functions &        *\n * values, and do not add event handlers directly.  *\n ****************************************************/\n\nTouch.setupSpotSwipe = function($) {\n  $.spotSwipe = new SpotSwipe($);\n};\n\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\nTouch.setupTouchHandler = function($) {\n  $.fn.addTouch = function(){\n    this.each(function(i,el){\n      $(el).bind('touchstart touchmove touchend touchcancel', function(event)  {\n        //we pass the original event object because the jQuery event\n        //object is normalized to w3c specs and does not provide the TouchList\n        handleTouch(event);\n      });\n    });\n\n    var handleTouch = function(event){\n      var touches = event.changedTouches,\n          first = touches[0],\n          eventTypes = {\n            touchstart: 'mousedown',\n            touchmove: 'mousemove',\n            touchend: 'mouseup'\n          },\n          type = eventTypes[event.type],\n          simulatedEvent\n        ;\n\n      if('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n        simulatedEvent = new window.MouseEvent(type, {\n          'bubbles': true,\n          'cancelable': true,\n          'screenX': first.screenX,\n          'screenY': first.screenY,\n          'clientX': first.clientX,\n          'clientY': first.clientY\n        });\n      } else {\n        simulatedEvent = document.createEvent('MouseEvent');\n        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0/*left*/, null);\n      }\n      first.target.dispatchEvent(simulatedEvent);\n    };\n  };\n};\n\nTouch.init = function ($) {\n\n  if(typeof($.spotSwipe) === 'undefined') {\n    Touch.setupSpotSwipe($);\n    Touch.setupTouchHandler($);\n  }\n};\n\nexport {Touch};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","'use strict';\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\n\n// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\nclass Plugin {\n\n  constructor(element, options) {\n    this._setup(element, options);\n    var pluginName = getPluginName(this);\n    this.uuid = GetYoDigits(6, pluginName);\n\n    if(!this.$element.attr(`data-${pluginName}`)){ this.$element.attr(`data-${pluginName}`, this.uuid); }\n    if(!this.$element.data('zfPlugin')){ this.$element.data('zfPlugin', this); }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n    this.$element.trigger(`init.zf.${pluginName}`);\n  }\n\n  destroy() {\n    this._destroy();\n    var pluginName = getPluginName(this);\n    this.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n        /**\n         * Fires when the plugin has been destroyed.\n         * @event Plugin#destroyed\n         */\n        .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in this){\n      this[prop] = null;//clean up script to prep for garbage collection.\n    }\n  }\n}\n\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n  if(typeof(obj.constructor.name) !== 'undefined') {\n    return hyphenate(obj.constructor.name);\n  } else {\n    return hyphenate(obj.className);\n  }\n}\n\nexport {Plugin};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nclass Abide extends Plugin {\n  /**\n   * Creates a new instance of Abide.\n   * @class\n   * @name Abide\n   * @fires Abide#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options = {}) {\n    this.$element = element;\n    this.options  = $.extend(true, {}, Abide.defaults, this.$element.data(), options);\n\n    this.className = 'Abide'; // ie9 back compat\n    this._init();\n  }\n\n  /**\n   * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n   * @private\n   */\n  _init() {\n    this.$inputs = $.merge(                               // Consider as input to validate:\n      this.$element.find('input').not('[type=submit]'),   // * all input fields expect submit\n      this.$element.find('textarea, select')              // * all textareas and select fields\n    );\n    const $globalErrors = this.$element.find('[data-abide-error]');\n\n    // Add a11y attributes to all fields\n    if (this.options.a11yAttributes) {\n      this.$inputs.each((i, input) => this.addA11yAttributes($(input)));\n      $globalErrors.each((i, error) => this.addGlobalErrorA11yAttributes($(error)));\n    }\n\n    this._events();\n  }\n\n  /**\n   * Initializes events for Abide.\n   * @private\n   */\n  _events() {\n    this.$element.off('.abide')\n      .on('reset.zf.abide', () => {\n        this.resetForm();\n      })\n      .on('submit.zf.abide', () => {\n        return this.validateForm();\n      });\n\n    if (this.options.validateOn === 'fieldChange') {\n      this.$inputs\n        .off('change.zf.abide')\n        .on('change.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.liveValidate) {\n      this.$inputs\n        .off('input.zf.abide')\n        .on('input.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.validateOnBlur) {\n      this.$inputs\n        .off('blur.zf.abide')\n        .on('blur.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n  }\n\n  /**\n   * Calls necessary functions to update Abide upon DOM change\n   * @private\n   */\n  _reflow() {\n    this._init();\n  }\n\n  /**\n   * Checks whether or not a form element has the required attribute and if it's checked or not\n   * @param {Object} element - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  requiredCheck($el) {\n    if (!$el.attr('required')) return true;\n\n    var isGood = true;\n\n    switch ($el[0].type) {\n      case 'checkbox':\n        isGood = $el[0].checked;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        var opt = $el.find('option:selected');\n        if (!opt.length || !opt.val()) isGood = false;\n        break;\n\n      default:\n        if(!$el.val() || !$el.val().length) isGood = false;\n    }\n\n    return isGood;\n  }\n\n  /**\n   * Get:\n   * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n   *   1. The element's direct sibling('s).\n   *   2. The element's parent's children.\n   * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n   *\n   * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n   *\n   * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n   * @returns {Object} jQuery object with the selector.\n   */\n  findFormError($el) {\n    var id = $el[0].id;\n    var $error = $el.siblings(this.options.formErrorSelector);\n\n    if (!$error.length) {\n      $error = $el.parent().find(this.options.formErrorSelector);\n    }\n\n    if (id) {\n      $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"]`));\n    }\n\n    return $error;\n  }\n\n  /**\n   * Get the first element in this order:\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findLabel($el) {\n    var id = $el[0].id;\n    var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n    if (!$label.length) {\n      return $el.closest('label');\n    }\n\n    return $label;\n  }\n\n  /**\n   * Get the set of labels associated with a set of radio els in this order\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findRadioLabels($els) {\n    var labels = $els.map((i, el) => {\n      var id = el.id;\n      var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n      if (!$label.length) {\n        $label = $(el).closest('label');\n      }\n      return $label[0];\n    });\n\n    return $(labels);\n  }\n\n  /**\n   * Adds the CSS error class as specified by the Abide settings to the label, input, and the form\n   * @param {Object} $el - jQuery object to add the class to\n   */\n  addErrorClasses($el) {\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.addClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.addClass(this.options.formErrorClass);\n    }\n\n    $el.addClass(this.options.inputErrorClass).attr({\n      'data-invalid': '',\n      'aria-invalid': true\n    });\n  }\n\n  /**\n   * Adds [for] and [role=alert] attributes to all form error targetting $el,\n   * and [aria-describedby] attribute to $el toward the first form error.\n   * @param {Object} $el - jQuery object\n   */\n  addA11yAttributes($el) {\n    let $errors = this.findFormError($el);\n    let $labels = $errors.filter('label');\n    let $error = $errors.first();\n    if (!$errors.length) return;\n\n    // Set [aria-describedby] on the input toward the first form error if it is not set\n    if (typeof $el.attr('aria-describedby') === 'undefined') {\n      // Get the first error ID or create one\n      let errorId = $error.attr('id');\n      if (typeof errorId === 'undefined') {\n        errorId = GetYoDigits(6, 'abide-error');\n        $error.attr('id', errorId);\n      };\n\n      $el.attr('aria-describedby', errorId);\n    }\n\n    if ($labels.filter('[for]').length < $labels.length) {\n      // Get the input ID or create one\n      let elemId = $el.attr('id');\n      if (typeof elemId === 'undefined') {\n        elemId = GetYoDigits(6, 'abide-input');\n        $el.attr('id', elemId);\n      };\n\n      // For each label targeting $el, set [for] if it is not set.\n      $labels.each((i, label) => {\n        const $label = $(label);\n        if (typeof $label.attr('for') === 'undefined')\n          $label.attr('for', elemId);\n      });\n    }\n\n    // For each error targeting $el, set [role=alert] if it is not set.\n    $errors.each((i, label) => {\n      const $label = $(label);\n      if (typeof $label.attr('role') === 'undefined')\n        $label.attr('role', 'alert');\n    }).end();\n  }\n\n  /**\n   * Adds [aria-live] attribute to the given global form error $el.\n   * @param {Object} $el - jQuery object to add the attribute to\n   */\n  addGlobalErrorA11yAttributes($el) {\n    if (typeof $el.attr('aria-live') === 'undefined')\n      $el.attr('aria-live', this.options.a11yErrorLevel);\n  }\n\n  /**\n   * Remove CSS error classes etc from an entire radio button group\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   *\n   */\n  removeRadioErrorClasses(groupName) {\n    var $els = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var $labels = this.findRadioLabels($els);\n    var $formErrors = this.findFormError($els);\n\n    if ($labels.length) {\n      $labels.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formErrors.length) {\n      $formErrors.removeClass(this.options.formErrorClass);\n    }\n\n    $els.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n\n  }\n\n  /**\n   * Removes CSS error class as specified by the Abide settings from the label, input, and the form\n   * @param {Object} $el - jQuery object to remove the class from\n   */\n  removeErrorClasses($el) {\n    // radios need to clear all of the els\n    if($el[0].type == 'radio') {\n      return this.removeRadioErrorClasses($el.attr('name'));\n    }\n\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.removeClass(this.options.formErrorClass);\n    }\n\n    $el.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n  }\n\n  /**\n   * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.\n   * Ignores inputs with data-abide-ignore, type=\"hidden\" or disabled attributes set\n   * @fires Abide#invalid\n   * @fires Abide#valid\n   * @param {Object} element - jQuery object to validate, should be an HTML input\n   * @returns {Boolean} goodToGo - If the input is valid or not.\n   */\n  validateInput($el) {\n    var clearRequire = this.requiredCheck($el),\n        validated = false,\n        customValidator = true,\n        validator = $el.attr('data-validator'),\n        equalTo = true;\n\n    // don't validate ignored inputs or hidden inputs or disabled inputs\n    if ($el.is('[data-abide-ignore]') || $el.is('[type=\"hidden\"]') || $el.is('[disabled]')) {\n      return true;\n    }\n\n    switch ($el[0].type) {\n      case 'radio':\n        validated = this.validateRadio($el.attr('name'));\n        break;\n\n      case 'checkbox':\n        validated = clearRequire;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        validated = clearRequire;\n        break;\n\n      default:\n        validated = this.validateText($el);\n    }\n\n    if (validator) {\n      customValidator = this.matchValidation($el, validator, $el.attr('required'));\n    }\n\n    if ($el.attr('data-equalto')) {\n      equalTo = this.options.validators.equalTo($el);\n    }\n\n\n    var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;\n    var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';\n\n    if (goodToGo) {\n      // Re-validate inputs that depend on this one with equalto\n      const dependentElements = this.$element.find(`[data-equalto=\"${$el.attr('id')}\"]`);\n      if (dependentElements.length) {\n        let _this = this;\n        dependentElements.each(function() {\n          if ($(this).val()) {\n            _this.validateInput($(this));\n          }\n        });\n      }\n    }\n\n    this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);\n\n    /**\n     * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`\n     * Trigger includes the DOM element of the input.\n     * @event Abide#valid\n     * @event Abide#invalid\n     */\n    $el.trigger(message, [$el]);\n\n    return goodToGo;\n  }\n\n  /**\n   * Goes through a form and if there are any invalid inputs, it will display the form error element\n   * @returns {Boolean} noError - true if no errors were detected...\n   * @fires Abide#formvalid\n   * @fires Abide#forminvalid\n   */\n  validateForm() {\n    var acc = [];\n    var _this = this;\n\n    this.$inputs.each(function() {\n      acc.push(_this.validateInput($(this)));\n    });\n\n    var noError = acc.indexOf(false) === -1;\n\n    this.$element.find('[data-abide-error]').each((i, elem) => {\n      const $elem = $(elem);\n      // Ensure a11y attributes are set\n      if (this.options.a11yAttributes) this.addGlobalErrorA11yAttributes($elem);\n      // Show or hide the error\n      $elem.css('display', (noError ? 'none' : 'block'));\n    });\n\n    /**\n     * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.\n     * Trigger includes the element of the form.\n     * @event Abide#formvalid\n     * @event Abide#forminvalid\n     */\n    this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);\n\n    return noError;\n  }\n\n  /**\n   * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.\n   * @param {Object} $el - jQuery object to validate, should be a text input HTML element\n   * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns\n   * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified\n   */\n  validateText($el, pattern) {\n    // A pattern can be passed to this function, or it will be infered from the input's \"pattern\" attribute, or it's \"type\" attribute\n    pattern = (pattern || $el.attr('pattern') || $el.attr('type'));\n    var inputText = $el.val();\n    var valid = false;\n\n    if (inputText.length) {\n      // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp\n      if (this.options.patterns.hasOwnProperty(pattern)) {\n        valid = this.options.patterns[pattern].test(inputText);\n      }\n      // If the pattern name isn't also the type attribute of the field, then test it as a regexp\n      else if (pattern !== $el.attr('type')) {\n        valid = new RegExp(pattern).test(inputText);\n      }\n      else {\n        valid = true;\n      }\n    }\n    // An empty field is valid if it's not required\n    else if (!$el.prop('required')) {\n      valid = true;\n    }\n\n    return valid;\n   }\n\n  /**\n   * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)\n   */\n  validateRadio(groupName) {\n    // If at least one radio in the group has the `required` attribute, the group is considered required\n    // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice\n    var $group = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var valid = false, required = false;\n\n    // For the group to be required, at least one radio needs to be required\n    $group.each((i, e) => {\n      if ($(e).attr('required')) {\n        required = true;\n      }\n    });\n    if(!required) valid=true;\n\n    if (!valid) {\n      // For the group to be valid, at least one radio needs to be checked\n      $group.each((i, e) => {\n        if ($(e).prop('checked')) {\n          valid = true;\n        }\n      });\n    };\n\n    return valid;\n  }\n\n  /**\n   * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator=\"foo bar baz\"` in a space separated listed.\n   * @param {Object} $el - jQuery input element.\n   * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.\n   * @param {Boolean} required - self explanatory?\n   * @returns {Boolean} - true if validations passed.\n   */\n  matchValidation($el, validators, required) {\n    required = required ? true : false;\n\n    var clear = validators.split(' ').map((v) => {\n      return this.options.validators[v]($el, required, $el.parent());\n    });\n    return clear.indexOf(false) === -1;\n  }\n\n  /**\n   * Resets form inputs and styles\n   * @fires Abide#formreset\n   */\n  resetForm() {\n    var $form = this.$element,\n        opts = this.options;\n\n    $(`.${opts.labelErrorClass}`, $form).not('small').removeClass(opts.labelErrorClass);\n    $(`.${opts.inputErrorClass}`, $form).not('small').removeClass(opts.inputErrorClass);\n    $(`${opts.formErrorSelector}.${opts.formErrorClass}`).removeClass(opts.formErrorClass);\n    $form.find('[data-abide-error]').css('display', 'none');\n    $(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:radio', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    /**\n     * Fires when the form has been reset.\n     * @event Abide#formreset\n     */\n    $form.trigger('formreset.zf.abide', [$form]);\n  }\n\n  /**\n   * Destroys an instance of Abide.\n   * Removes error styles and classes from elements, without resetting their values.\n   */\n  _destroy() {\n    var _this = this;\n    this.$element\n      .off('.abide')\n      .find('[data-abide-error]')\n        .css('display', 'none');\n\n    this.$inputs\n      .off('.abide')\n      .each(function() {\n        _this.removeErrorClasses($(this));\n      });\n  }\n}\n\n/**\n * Default settings for plugin\n */\nAbide.defaults = {\n  /**\n   * The default event to validate inputs. Checkboxes and radios validate immediately.\n   * Remove or change this value for manual validation.\n   * @option\n   * @type {?string}\n   * @default 'fieldChange'\n   */\n  validateOn: 'fieldChange',\n\n  /**\n   * Class to be applied to input labels on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-label'\n   */\n  labelErrorClass: 'is-invalid-label',\n\n  /**\n   * Class to be applied to inputs on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-input'\n   */\n  inputErrorClass: 'is-invalid-input',\n\n  /**\n   * Class selector to use to target Form Errors for show/hide.\n   * @option\n   * @type {string}\n   * @default '.form-error'\n   */\n  formErrorSelector: '.form-error',\n\n  /**\n   * Class added to Form Errors on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-visible'\n   */\n  formErrorClass: 'is-visible',\n\n  /**\n   * If true, automatically insert when possible:\n   * - `[aria-describedby]` on fields\n   * - `[role=alert]` on form errors and `[for]` on form error labels\n   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  a11yAttributes: true,\n\n  /**\n   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.\n   * Options are: 'assertive', 'polite' and 'off'/null\n   * @option\n   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions\n   * @type {string}\n   * @default 'assertive'\n   */\n  a11yErrorLevel: 'assertive',\n\n  /**\n   * Set to true to validate text inputs on any value change.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  liveValidate: false,\n\n  /**\n   * Set to true to validate inputs on blur.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  validateOnBlur: false,\n\n  patterns: {\n    alpha : /^[a-zA-Z]+$/,\n    alpha_numeric : /^[a-zA-Z0-9]+$/,\n    integer : /^[-+]?\\d+$/,\n    number : /^[-+]?\\d*(?:[\\.\\,]\\d+)?$/,\n\n    // amex, visa, diners\n    card : /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\\d{3})\\d{11})$/,\n    cvv : /^([0-9]){3,4}$/,\n\n    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address\n    email : /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,\n\n    // From CommonRegexJS (@talyssonoc)\n    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76\n    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.\n    url: /^((?:(https?|ftps?|file|ssh|sftp):\\/\\/|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}\\/)(?:[^\\s()<>]+|\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\))+(?:\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:\\'\".,<>?\\xab\\xbb\\u201c\\u201d\\u2018\\u2019]))$/,\n\n    // abc.de\n    domain : /^([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,8}$/,\n\n    datetime : /^([0-2][0-9]{3})\\-([0-1][0-9])\\-([0-3][0-9])T([0-5][0-9])\\:([0-5][0-9])\\:([0-5][0-9])(Z|([\\-\\+]([0-1][0-9])\\:00))$/,\n    // YYYY-MM-DD\n    date : /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,\n    // HH:MM:SS\n    time : /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,\n    dateISO : /^\\d{4}[\\/\\-]\\d{1,2}[\\/\\-]\\d{1,2}$/,\n    // MM/DD/YYYY\n    month_day_year : /^(0[1-9]|1[012])[- \\/.](0[1-9]|[12][0-9]|3[01])[- \\/.]\\d{4}$/,\n    // DD/MM/YYYY\n    day_month_year : /^(0[1-9]|[12][0-9]|3[01])[- \\/.](0[1-9]|1[012])[- \\/.]\\d{4}$/,\n\n    // #FFF or #FFFFFF\n    color : /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,\n\n    // Domain || URL\n    website: {\n      test: (text) => {\n        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);\n      }\n    }\n  },\n\n  /**\n   * Optional validation functions to be used. `equalTo` being the only default included function.\n   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:\n   * el : The jQuery element to validate.\n   * required : Boolean value of the required attribute be present or not.\n   * parent : The direct parent of the input.\n   * @option\n   */\n  validators: {\n    equalTo: function (el, required, parent) {\n      return $(`#${el.attr('data-equalto')}`).val() === el.val();\n    }\n  }\n}\n\nexport {Abide};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Accordion module.\n * @module foundation.accordion\n * @requires foundation.util.keyboard\n */\n\nclass Accordion extends Plugin {\n  /**\n   * Creates a new instance of an accordion.\n   * @class\n   * @name Accordion\n   * @fires Accordion#init\n   * @param {jQuery} element - jQuery object to make into an accordion.\n   * @param {Object} options - a plain object with settings to override the default options.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);\n\n    this.className = 'Accordion'; // ie9 back compat\n    this._init();\n\n    Keyboard.register('Accordion', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_DOWN': 'next',\n      'ARROW_UP': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the accordion by animating the preset active pane(s).\n   * @private\n   */\n  _init() {\n    this._isInitializing = true;\n\n    this.$element.attr('role', 'tablist');\n    this.$tabs = this.$element.children('[data-accordion-item]');\n\n    this.$tabs.each(function(idx, el) {\n      var $el = $(el),\n          $content = $el.children('[data-tab-content]'),\n          id = $content[0].id || GetYoDigits(6, 'accordion'),\n          linkId = (el.id) ? `${el.id}-label` : `${id}-label`;\n\n      $el.find('a:first').attr({\n        'aria-controls': id,\n        'role': 'tab',\n        'id': linkId,\n        'aria-expanded': false,\n        'aria-selected': false\n      });\n\n      $content.attr({'role': 'tabpanel', 'aria-labelledby': linkId, 'aria-hidden': true, 'id': id});\n    });\n\n    var $initActive = this.$element.find('.is-active').children('[data-tab-content]');\n    if ($initActive.length) {\n      // Save up the initial hash to return to it later when going back in history\n      this._initialAnchor = $initActive.prev('a').attr('href');\n      this._openSingleTab($initActive);\n    }\n\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find(`[href$=\"${anchor}\"]`);\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, open it (if not already active)\n      if ($anchor && $link && $link.length) {\n        if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {\n          this._openSingleTab($anchor);\n        };\n      }\n      // Otherwise, close everything\n      else {\n        this._closeAllTabs();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          onLoad($(window), () => {\n            var offset = this.$element.offset();\n            $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n          });\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Accordion#deeplink\n         */\n        this.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the accordion.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$tabs.each(function() {\n      var $elem = $(this);\n      var $tabContent = $elem.children('[data-tab-content]');\n      if ($tabContent.length) {\n        $elem.children('a').off('click.zf.accordion keydown.zf.accordion')\n               .on('click.zf.accordion', function(e) {\n          e.preventDefault();\n          _this.toggle($tabContent);\n        }).on('keydown.zf.accordion', function(e){\n          Keyboard.handleKey(e, 'Accordion', {\n            toggle: function() {\n              _this.toggle($tabContent);\n            },\n            next: function() {\n              var $a = $elem.next().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            previous: function() {\n              var $a = $elem.prev().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            handled: function() {\n              e.preventDefault();\n              e.stopPropagation();\n            }\n          });\n        });\n      }\n    });\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Toggles the selected content pane's open/close state.\n   * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).\n   * @function\n   */\n  toggle($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]')) {\n      console.info('Cannot toggle an accordion that is disabled.');\n      return;\n    }\n    if($target.parent().hasClass('is-active')) {\n      this.up($target);\n    } else {\n      this.down($target);\n    }\n    //either replace or update browser history\n    if (this.options.deepLink) {\n      var anchor = $target.prev('a').attr('href');\n\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n  }\n\n  /**\n   * Opens the accordion tab defined by `$target`.\n   * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   */\n  down($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]'))  {\n      console.info('Cannot call down on an accordion that is disabled.');\n      return;\n    }\n\n    if (this.options.multiExpand)\n      this._openTab($target);\n    else\n      this._openSingleTab($target);\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * It may be ignored if the Accordion options don't allow it.\n   *\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   */\n  up($target) {\n    if (this.$element.is('[disabled]')) {\n      console.info('Cannot call up on an accordion that is disabled.');\n      return;\n    }\n\n    // Don't close the item if it is already closed\n    const $targetItem = $target.parent();\n    if (!$targetItem.hasClass('is-active')) return;\n\n    // Don't close the item if there is no other active item (unless with `allowAllClosed`)\n    const $othersItems = $targetItem.siblings();\n    if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;\n\n    this._closeTab($target);\n  }\n\n  /**\n   * Make the tab defined by `$target` the only opened tab, closing all others tabs.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @function\n   * @private\n   */\n  _openSingleTab($target) {\n    // Close all the others active tabs.\n    const $activeContents = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeContents.length) {\n      this._closeTab($activeContents.not($target));\n    }\n\n    // Then open the target.\n    this._openTab($target);\n  }\n\n  /**\n   * Opens the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   * @private\n   */\n  _openTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', false);\n    $targetItem.addClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n      'aria-expanded': true,\n      'aria-selected': true\n    });\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done opening.\n       * @event Accordion#down\n       */\n      this.$element.trigger('down.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', true)\n    $targetItem.removeClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n     'aria-expanded': false,\n     'aria-selected': false\n    });\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done collapsing up.\n       * @event Accordion#up\n       */\n      this.$element.trigger('up.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes all active tabs\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeAllTabs() {\n    var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeTabs.length) {\n      this._closeTab($activeTabs);\n    }\n  }\n\n  /**\n   * Destroys an instance of an accordion.\n   * @fires Accordion#destroyed\n   * @function\n   */\n  _destroy() {\n    this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');\n    this.$element.find('a').off('.zf.accordion');\n    if(this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n  }\n}\n\nAccordion.defaults = {\n  /**\n   * Amount of time to animate the opening of an accordion pane.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Allow the accordion to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multiExpand: false,\n  /**\n   * Allow the accordion to close all panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowAllClosed: false,\n  /**\n   * Link the location hash to the open pane.\n   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open accordion\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false\n};\n\nexport {Accordion};\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n */\n\nclass AccordionMenu extends Plugin {\n  /**\n   * Creates a new instance of an accordion menu.\n   * @class\n   * @name AccordionMenu\n   * @fires AccordionMenu#init\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n    this.className = 'AccordionMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('AccordionMenu', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_RIGHT': 'open',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'close',\n      'ESCAPE': 'closeAll'\n    });\n  }\n\n\n\n  /**\n   * Initializes the accordion menu by hiding all nested menus.\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'accordion');\n\n    var _this = this;\n\n    this.$element.find('[data-submenu]').not('.is-active').slideUp(0);//.find('a').css('padding-left', '1rem');\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': this.options.multiOpen\n    });\n\n    this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');\n    this.$menuLinks.each(function(){\n      var linkId = this.id || GetYoDigits(6, 'acc-menu-link'),\n          $elem = $(this),\n          $sub = $elem.children('[data-submenu]'),\n          subId = $sub[0].id || GetYoDigits(6, 'acc-menu'),\n          isActive = $sub.hasClass('is-active');\n\n      if(_this.options.parentLink) {\n        let $anchor = $elem.children('a');\n        $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-accordion-submenu-item\"></li>');\n      }\n\n      if(_this.options.submenuToggle) {\n        $elem.addClass('has-submenu-toggle');\n        $elem.children('a').after('<button id=\"' + linkId + '\" class=\"submenu-toggle\" aria-controls=\"' + subId + '\" aria-expanded=\"' + isActive + '\" title=\"' + _this.options.submenuToggleText + '\"><span class=\"submenu-toggle-text\">' + _this.options.submenuToggleText + '</span></button>');\n      } else {\n        $elem.attr({\n          'aria-controls': subId,\n          'aria-expanded': isActive,\n          'id': linkId\n        });\n      }\n      $sub.attr({\n        'aria-labelledby': linkId,\n        'aria-hidden': !isActive,\n        'role': 'group',\n        'id': subId\n      });\n    });\n    this.$element.find('li').attr({\n      'role': 'treeitem'\n    });\n    var initPanes = this.$element.find('.is-active');\n    if(initPanes.length){\n      var _this = this;\n      initPanes.each(function(){\n        _this.down($(this));\n      });\n    }\n    this._events();\n  }\n\n  /**\n   * Adds event handlers for items within the menu.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.find('li').each(function() {\n      var $submenu = $(this).children('[data-submenu]');\n\n      if ($submenu.length) {\n        if(_this.options.submenuToggle) {\n          $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n            _this.toggle($submenu);\n          });\n        } else {\n            $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n              e.preventDefault();\n              _this.toggle($submenu);\n            });\n        }\n      }\n    }).on('keydown.zf.accordionmenu', function(e){\n      var $element = $(this),\n          $elements = $element.parent('ul').children('li'),\n          $prevElement,\n          $nextElement,\n          $target = $element.children('[data-submenu]');\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1)).find('a').first();\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1)).find('a').first();\n\n          if ($(this).children('[data-submenu]:visible').length) { // has open sub menu\n            $nextElement = $element.find('li:first-child').find('a').first();\n          }\n          if ($(this).is(':first-child')) { // is first element of sub menu\n            $prevElement = $element.parents('li').first().find('a').first();\n          } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) { // if previous element has open sub menu\n            $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();\n          }\n          if ($(this).is(':last-child')) { // is last element of sub menu\n            $nextElement = $element.parents('li').first().next('li').find('a').first();\n          }\n\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'AccordionMenu', {\n        open: function() {\n          if ($target.is(':hidden')) {\n            _this.down($target);\n            $target.find('li').first().find('a').first().focus();\n          }\n        },\n        close: function() {\n          if ($target.length && !$target.is(':hidden')) { // close active sub of this item\n            _this.up($target);\n          } else if ($element.parent('[data-submenu]').length) { // close currently open sub\n            _this.up($element.parent('[data-submenu]'));\n            $element.parents('li').first().find('a').first().focus();\n          }\n        },\n        up: function() {\n          $prevElement.focus();\n          return true;\n        },\n        down: function() {\n          $nextElement.focus();\n          return true;\n        },\n        toggle: function() {\n          if (_this.options.submenuToggle) {\n            return false;\n          }\n          if ($element.children('[data-submenu]').length) {\n            _this.toggle($element.children('[data-submenu]'));\n            return true;\n          }\n        },\n        closeAll: function() {\n          _this.hideAll();\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    });//.attr('tabindex', 0);\n  }\n\n  /**\n   * Closes all panes of the menu.\n   * @function\n   */\n  hideAll() {\n    this.up(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Opens all panes of the menu.\n   * @function\n   */\n  showAll() {\n    this.down(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Toggles the open/close state of a submenu.\n   * @function\n   * @param {jQuery} $target - the submenu to toggle\n   */\n  toggle($target){\n    if(!$target.is(':animated')) {\n      if (!$target.is(':hidden')) {\n        this.up($target);\n      }\n      else {\n        this.down($target);\n      }\n    }\n  }\n\n  /**\n   * Opens the sub-menu defined by `$target`.\n   * @param {jQuery} $target - Sub-menu to open.\n   * @fires AccordionMenu#down\n   */\n  down($target) {\n    // If having multiple submenus active is disabled, close all the submenus\n    // that are not parents or children of the targeted submenu.\n    if (!this.options.multiOpen) {\n      // The \"branch\" of the targetted submenu, from the component root to\n      // the active submenus nested in it.\n      const $targetBranch = $target.parentsUntil(this.$element)\n        .add($target)\n        .add($target.find('.is-active'));\n      // All the active submenus that are not in the branch.\n      const $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);\n\n      this.up($othersActiveSubmenus);\n    }\n\n    $target\n      .addClass('is-active')\n      .attr({ 'aria-hidden': false });\n\n    if(this.options.submenuToggle) {\n      $target.prev('.submenu-toggle').attr({'aria-expanded': true});\n    }\n    else {\n      $target.parent('.is-accordion-submenu-parent').attr({'aria-expanded': true});\n    }\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done opening.\n       * @event AccordionMenu#down\n       */\n      this.$element.trigger('down.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.\n   * @param {jQuery} $target - Sub-menu to close.\n   * @fires AccordionMenu#up\n   */\n  up($target) {\n    const $submenus = $target.find('[data-submenu]');\n    const $allmenus = $target.add($submenus);\n\n    $submenus.slideUp(0);\n    $allmenus\n      .removeClass('is-active')\n      .attr('aria-hidden', true);\n\n    if(this.options.submenuToggle) {\n      $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);\n    }\n    else {\n      $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\n    }\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done collapsing up.\n       * @event AccordionMenu#up\n       */\n      this.$element.trigger('up.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Destroys an instance of accordion menu.\n   * @fires AccordionMenu#destroyed\n   */\n  _destroy() {\n    this.$element.find('[data-submenu]').slideDown(0).css('display', '');\n    this.$element.find('a').off('click.zf.accordionMenu');\n    this.$element.find('[data-is-parent-link]').detach();\n\n    if(this.options.submenuToggle) {\n      this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');\n      this.$element.find('.submenu-toggle').remove();\n    }\n\n    Nest.Burn(this.$element, 'accordion');\n  }\n}\n\nAccordionMenu.defaults = {\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Amount of time to animate the opening of a submenu in ms.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Adds a separate submenu toggle button. This allows the parent item to have a link.\n   * @option\n   * @example true\n   */\n  submenuToggle: false,\n  /**\n   * The text used for the submenu toggle if enabled. This is used for screen readers only.\n   * @option\n   * @example true\n   */\n  submenuToggleText: 'Toggle menu',\n  /**\n   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\nexport {AccordionMenu};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits, transitionend } from './foundation.core.utils';\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Drilldown module.\n * @module foundation.drilldown\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n * @requires foundation.util.box\n */\n\nclass Drilldown extends Plugin {\n  /**\n   * Creates a new instance of a drilldown menu.\n   * @class\n   * @name Drilldown\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);\n    this.className = 'Drilldown'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('Drilldown', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close',\n      'TAB': 'down',\n      'SHIFT_TAB': 'up'\n    });\n  }\n\n  /**\n   * Initializes the drilldown by creating jQuery collections of elements\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'drilldown');\n\n    if(this.options.autoApplyClass) {\n      this.$element.addClass('drilldown');\n    }\n\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': false\n    });\n    this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');\n    this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');\n    this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a');\n\n    // Set the main menu as current by default (unless a submenu is selected)\n    // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu\n    this.$currentMenu = this.$element;\n\n    this.$element.attr('data-mutate', (this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown')));\n\n    this._prepareMenu();\n    this._registerEvents();\n\n    this._keyboardEvents();\n  }\n\n  /**\n   * prepares drilldown menu by setting attributes to links and elements\n   * sets a min height to prevent content jumping\n   * wraps the element if not already wrapped\n   * @private\n   * @function\n   */\n  _prepareMenu() {\n    var _this = this;\n    // if(!this.options.holdOpen){\n    //   this._menuLinkEvents();\n    // }\n    this.$submenuAnchors.each(function(){\n      var $link = $(this);\n      var $sub = $link.parent();\n      if(_this.options.parentLink){\n        $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-drilldown-submenu-item\" role=\"menuitem\"></li>');\n      }\n      $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);\n      $link.children('[data-submenu]')\n          .attr({\n            'aria-hidden': true,\n            'tabindex': 0,\n            'role': 'group'\n          });\n      _this._events($link);\n    });\n    this.$submenus.each(function(){\n      var $menu = $(this),\n          $back = $menu.find('.js-drilldown-back');\n      if(!$back.length){\n        switch (_this.options.backButtonPosition) {\n          case \"bottom\":\n            $menu.append(_this.options.backButton);\n            break;\n          case \"top\":\n            $menu.prepend(_this.options.backButton);\n            break;\n          default:\n            console.error(\"Unsupported backButtonPosition value '\" + _this.options.backButtonPosition + \"'\");\n        }\n      }\n      _this._back($menu);\n    });\n\n    this.$submenus.addClass('invisible');\n    if(!this.options.autoHeight) {\n      this.$submenus.addClass('drilldown-submenu-cover-previous');\n    }\n\n    // create a wrapper on element if it doesn't exist.\n    if(!this.$element.parent().hasClass('is-drilldown')){\n      this.$wrapper = $(this.options.wrapper).addClass('is-drilldown');\n      if(this.options.animateHeight) this.$wrapper.addClass('animate-height');\n      this.$element.wrap(this.$wrapper);\n    }\n    // set wrapper\n    this.$wrapper = this.$element.parent();\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  _resize() {\n    this.$wrapper.css({'max-width': 'none', 'min-height': 'none'});\n    // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  /**\n   * Adds event handlers to elements in the menu.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the current menu item to add handlers to.\n   */\n  _events($elem) {\n    var _this = this;\n\n    $elem.off('click.zf.drilldown')\n    .on('click.zf.drilldown', function(e){\n      if($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')){\n        e.stopImmediatePropagation();\n        e.preventDefault();\n      }\n\n      // if(e.target !== e.currentTarget.firstElementChild){\n      //   return false;\n      // }\n      _this._show($elem.parent('li'));\n\n      if(_this.options.closeOnClick){\n        var $body = $('body');\n        $body.off('.zf.drilldown').on('click.zf.drilldown', function(e){\n          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target)) { return; }\n          e.preventDefault();\n          _this._hideAll();\n          $body.off('.zf.drilldown');\n        });\n      }\n    });\n  }\n\n  /**\n   * Adds event handlers to the menu element.\n   * @function\n   * @private\n   */\n  _registerEvents() {\n    if(this.options.scrollTop){\n      this._bindHandler = this._scrollTop.bind(this);\n      this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown',this._bindHandler);\n    }\n    this.$element.on('mutateme.zf.trigger', this._resize.bind(this));\n  }\n\n  /**\n   * Scroll to Top of Element or data-scroll-top-element\n   * @function\n   * @fires Drilldown#scrollme\n   */\n  _scrollTop() {\n    var _this = this;\n    var $scrollTopElement = _this.options.scrollTopElement!=''?$(_this.options.scrollTopElement):_this.$element,\n        scrollPos = parseInt($scrollTopElement.offset().top+_this.options.scrollTopOffset, 10);\n    $('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing,function(){\n      /**\n        * Fires after the menu has scrolled\n        * @event Drilldown#scrollme\n        */\n      if(this===$('html')[0])_this.$element.trigger('scrollme.zf.drilldown');\n    });\n  }\n\n  /**\n   * Adds keydown event listener to `li`'s in the menu.\n   * @private\n   */\n  _keyboardEvents() {\n    var _this = this;\n\n    this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function(e){\n      var $element = $(this),\n          $elements = $element.parent('li').parent('ul').children('li').children('a'),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1));\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'Drilldown', {\n        next: function() {\n          if ($element.is(_this.$submenuAnchors)) {\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        previous: function() {\n          _this._hide($element.parent('li').parent('ul'));\n          $element.parent('li').parent('ul').one(transitionend($element), function(){\n            setTimeout(function() {\n              $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n            }, 1);\n          });\n          return true;\n        },\n        up: function() {\n          $prevElement.focus();\n          // Don't tap focus on first element in root ul\n          return !$element.is(_this.$element.find('> li:first-child > a'));\n        },\n        down: function() {\n          $nextElement.focus();\n          // Don't tap focus on last element in root ul\n          return !$element.is(_this.$element.find('> li:last-child > a'));\n        },\n        close: function() {\n          // Don't close on element in root ul\n          if (!$element.is(_this.$element.find('> li > a'))) {\n            _this._hide($element.parent().parent());\n            $element.parent().parent().siblings('a').focus();\n          }\n        },\n        open: function() {\n          if (_this.options.parentLink && $element.attr('href')) { // Link with href\n            return false;\n          } else if (!$element.is(_this.$menuItems)) { // not menu item means back button\n            _this._hide($element.parent('li').parent('ul'));\n            $element.parent('li').parent('ul').one(transitionend($element), function(){\n              setTimeout(function() {\n                $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n              }, 1);\n            });\n            return true;\n          } else if ($element.is(_this.$submenuAnchors)) { // Sub menu item\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    }); // end keyboardAccess\n  }\n\n  /**\n   * Closes all open elements, and returns to root menu.\n   * @function\n   * @fires Drilldown#closed\n   */\n  _hideAll() {\n    var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    $elem.one(transitionend($elem), function(e){\n      $elem.removeClass('is-active is-closing');\n    });\n        /**\n         * Fires when the menu is fully closed.\n         * @event Drilldown#closed\n         */\n    this.$element.trigger('closed.zf.drilldown');\n  }\n\n  /**\n   * Adds event listener for each `back` button, and closes open menus.\n   * @function\n   * @fires Drilldown#back\n   * @param {jQuery} $elem - the current sub-menu to add `back` event.\n   */\n  _back($elem) {\n    var _this = this;\n    $elem.off('click.zf.drilldown');\n    $elem.children('.js-drilldown-back')\n      .on('click.zf.drilldown', function(e){\n        e.stopImmediatePropagation();\n        // console.log('mouseup on back');\n        _this._hide($elem);\n\n        // If there is a parent submenu, call show\n        let parentSubMenu = $elem.parent('li').parent('ul').parent('li');\n        if (parentSubMenu.length) {\n          _this._show(parentSubMenu);\n        }\n      });\n  }\n\n  /**\n   * Adds event listener to menu items w/o submenus to close open menus on click.\n   * @function\n   * @private\n   */\n  _menuLinkEvents() {\n    var _this = this;\n    this.$menuItems.not('.is-drilldown-submenu-parent')\n        .off('click.zf.drilldown')\n        .on('click.zf.drilldown', function(e){\n          // e.stopImmediatePropagation();\n          setTimeout(function(){\n            _this._hideAll();\n          }, 0);\n      });\n  }\n\n  /**\n   * Sets the CSS classes for submenu to show it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setShowSubMenuClasses($elem, trigger) {\n    $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    $elem.parent('li').attr('aria-expanded', true);\n    if (trigger === true) {\n      this.$element.trigger('open.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Sets the CSS classes for submenu to hide it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setHideSubMenuClasses($elem, trigger) {\n    $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);\n    $elem.parent('li').attr('aria-expanded', false);\n    if (trigger === true) {\n      $elem.trigger('hide.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.\n   * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the target (sub)menu (`ul` tag)\n   * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused\n   */\n  _showMenu($elem, autoFocus) {\n\n    var _this = this;\n\n    // Reset drilldown\n    var $expandedSubmenus = this.$element.find('li[aria-expanded=\"true\"] > ul[data-submenu]');\n    $expandedSubmenus.each(function(index) {\n      _this._setHideSubMenuClasses($(this));\n    });\n\n    // Save the menu as the currently displayed one.\n    this.$currentMenu = $elem;\n\n    // If target menu is root, focus first link & exit\n    if ($elem.is('[data-drilldown]')) {\n      if (autoFocus === true) $elem.find('li[role=\"treeitem\"] > a').first().focus();\n      if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));\n      return;\n    }\n\n    // Find all submenus on way to root incl. the element itself\n    var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]');\n\n    // Open target menu and all submenus on its way to root\n    $submenus.each(function(index) {\n\n      // Update height of first child (target menu) if autoHeight option true\n      if (index === 0 && _this.options.autoHeight) {\n        _this.$wrapper.css('height', $(this).data('calcHeight'));\n      }\n\n      var isLastChild = index == $submenus.length - 1;\n\n      // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link\n      // Last child makes sure the event gets always triggered even if going through several menus\n      if (isLastChild === true) {\n        $(this).one(transitionend($(this)), () => {\n          if (autoFocus === true) {\n            $elem.find('li[role=\"treeitem\"] > a').first().focus();\n          }\n        });\n      }\n\n      _this._setShowSubMenuClasses($(this), isLastChild);\n    });\n  }\n\n  /**\n   * Opens a submenu.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.\n   */\n  _show($elem) {\n    const $submenu = $elem.children('[data-submenu]');\n\n    $elem.attr('aria-expanded', true);\n\n    this.$currentMenu = $submenu;\n    $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    if (this.options.autoHeight) {\n      this.$wrapper.css({ height: $submenu.data('calcHeight') });\n    }\n\n    /**\n     * Fires when the submenu has opened.\n     * @event Drilldown#open\n     */\n    this.$element.trigger('open.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Hides a submenu\n   * @function\n   * @fires Drilldown#hide\n   * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.\n   */\n  _hide($elem) {\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    var _this = this;\n    $elem.parent('li').attr('aria-expanded', false);\n    $elem.attr('aria-hidden', true);\n    $elem.addClass('is-closing')\n         .one(transitionend($elem), function(){\n           $elem.removeClass('is-active is-closing');\n           $elem.blur().addClass('invisible');\n         });\n    /**\n     * Fires when the submenu has closed.\n     * @event Drilldown#hide\n     */\n    $elem.trigger('hide.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Iterates through the nested menus to calculate the min-height, and max-width for the menu.\n   * Prevents content jumping.\n   * @function\n   * @private\n   */\n  _getMaxDims() {\n    var maxHeight = 0, result = {}, _this = this;\n\n    // Recalculate menu heights and total max height\n    this.$submenus.add(this.$element).each(function(){\n      var numOfElems = $(this).children('li').length;\n      var height = Box.GetDimensions(this).height;\n\n      maxHeight = height > maxHeight ? height : maxHeight;\n\n      if(_this.options.autoHeight) {\n        $(this).data('calcHeight',height);\n      }\n    });\n\n    if (this.options.autoHeight)\n      result['height'] = this.$currentMenu.data('calcHeight');\n    else\n      result['min-height'] = `${maxHeight}px`;\n\n    result['max-width'] = `${this.$element[0].getBoundingClientRect().width}px`;\n\n    return result;\n  }\n\n  /**\n   * Destroys the Drilldown Menu\n   * @function\n   */\n  _destroy() {\n    if(this.options.scrollTop) this.$element.off('.zf.drilldown',this._bindHandler);\n    this._hideAll();\n\t  this.$element.off('mutateme.zf.trigger');\n    Nest.Burn(this.$element, 'drilldown');\n    this.$element.unwrap()\n                 .find('.js-drilldown-back, .is-submenu-parent-item').remove()\n                 .end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu')\n                 .end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');\n    this.$submenuAnchors.each(function() {\n      $(this).off('.zf.drilldown');\n    });\n\n    this.$element.find('[data-is-parent-link]').detach();\n    this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');\n\n    this.$element.find('a').each(function(){\n      var $link = $(this);\n      $link.removeAttr('tabindex');\n      if($link.data('savedHref')){\n        $link.attr('href', $link.data('savedHref')).removeData('savedHref');\n      }else{ return; }\n    });\n  };\n}\n\nDrilldown.defaults = {\n  /**\n   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are\n   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.\n   * @option\n   * @type {boolian}\n   * @default true\n   */\n  autoApplyClass: true,\n  /**\n   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>'\n   */\n  backButton: '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>',\n  /**\n   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default top\n   */\n  backButtonPosition: 'top',\n  /**\n   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<div></div>'\n   */\n  wrapper: '<div></div>',\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Allow the menu to return to root list on body click.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false,\n  /**\n   * Allow the menu to auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoHeight: false,\n  /**\n   * Animate the auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animateHeight: false,\n  /**\n   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  scrollTop: false,\n  /**\n   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  scrollTopElement: '',\n  /**\n   * ScrollTop offset\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  scrollTopOffset: 0,\n  /**\n   * Scroll animation duration\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Scroll animation easing. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @see {@link https://api.jquery.com/animate|JQuery animate}\n   * @default 'swing'\n   */\n  animationEasing: 'swing'\n  // holdOpen: false\n};\n\nexport {Drilldown};\n","'use strict';\n\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst POSITIONS = ['left', 'right', 'top', 'bottom'];\nconst VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nconst HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\n\nconst ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n}\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n  if(currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\n\nclass Positionable extends Plugin {\n  /**\n   * Abstract class encapsulating the tether-like explicit positioning logic\n   * including repositioning based on overlap.\n   * Expects classes to define defaults for vOffset, hOffset, position,\n   * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n   * extending the defaults, or (for now recommended due to the way docs are\n   * generated) by explicitly declaring them.\n   *\n   **/\n\n  _init() {\n    this.triedPositions = {};\n    this.position  = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n    this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n    this.originalPosition = this.position;\n    this.originalAlignment = this.alignment;\n  }\n\n  _getDefaultPosition () {\n    return 'bottom';\n  }\n\n  _getDefaultAlignment() {\n    switch(this.position) {\n      case 'bottom':\n      case 'top':\n        return Rtl() ? 'right' : 'left';\n      case 'left':\n      case 'right':\n        return 'bottom';\n    }\n  }\n\n  /**\n   * Adjusts the positionable possible positions by iterating through alignments\n   * and positions.\n   * @function\n   * @private\n   */\n  _reposition() {\n    if(this._alignmentsExhausted(this.position)) {\n      this.position = nextItem(this.position, POSITIONS);\n      this.alignment = ALIGNMENTS[this.position][0];\n    } else {\n      this._realign();\n    }\n  }\n\n  /**\n   * Adjusts the dropdown pane possible positions by iterating through alignments\n   * on the current position.\n   * @function\n   * @private\n   */\n  _realign() {\n    this._addTriedPosition(this.position, this.alignment)\n    this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position])\n  }\n\n  _addTriedPosition(position, alignment) {\n    this.triedPositions[position] = this.triedPositions[position] || []\n    this.triedPositions[position].push(alignment);\n  }\n\n  _positionsExhausted() {\n    var isExhausted = true;\n    for(var i = 0; i < POSITIONS.length; i++) {\n      isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n    }\n    return isExhausted;\n  }\n\n  _alignmentsExhausted(position) {\n    return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n  }\n\n\n  // When we're trying to center, we don't want to apply offset that's going to\n  // take us just off center, so wrap around to return 0 for the appropriate\n  // offset in those alignments.  TODO: Figure out if we want to make this\n  // configurable behavior... it feels more intuitive, especially for tooltips, but\n  // it's possible someone might actually want to start from center and then nudge\n  // slightly off.\n  _getVOffset() {\n    return this.options.vOffset;\n  }\n\n  _getHOffset() {\n    return this.options.hOffset;\n  }\n\n\n  _setPosition($anchor, $element, $parent) {\n    if($anchor.attr('aria-expanded') === 'false'){ return false; }\n    var $eleDims = Box.GetDimensions($element),\n        $anchorDims = Box.GetDimensions($anchor);\n\n\n    if (!this.options.allowOverlap) {\n      // restore original position & alignment before checking overlap\n      this.position = this.originalPosition;\n      this.alignment = this.originalAlignment;\n    }\n\n    $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n    if(!this.options.allowOverlap) {\n      var overlaps = {};\n      var minOverlap = 100000000;\n      // default coordinates to how we start, in case we can't figure out better\n      var minCoordinates = {position: this.position, alignment: this.alignment};\n      while(!this._positionsExhausted()) {\n        let overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n        if(overlap === 0) {\n          return;\n        }\n\n        if(overlap < minOverlap) {\n          minOverlap = overlap;\n          minCoordinates = {position: this.position, alignment: this.alignment};\n        }\n\n        this._reposition();\n\n        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n      // If we get through the entire loop, there was no non-overlapping\n      // position available. Pick the version with least overlap.\n      this.position = minCoordinates.position;\n      this.alignment = minCoordinates.alignment;\n      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n    }\n  }\n\n}\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n}\n\nexport {Positionable};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { Positionable } from './foundation.positionable';\n\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Dropdown module.\n * @module foundation.dropdown\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.triggers\n */\nclass Dropdown extends Positionable {\n  /**\n   * Creates a new instance of a dropdown.\n   * @class\n   * @name Dropdown\n   * @param {jQuery} element - jQuery object to make into a dropdown.\n   *        Object should be of the dropdown panel, rather than its anchor.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);\n    this.className = 'Dropdown'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Dropdown', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.\n   * @function\n   * @private\n   */\n  _init() {\n    var $id = this.$element.attr('id');\n\n    this.$anchors = $(`[data-toggle=\"${$id}\"]`).length ? $(`[data-toggle=\"${$id}\"]`) : $(`[data-open=\"${$id}\"]`);\n    this.$anchors.attr({\n      'aria-controls': $id,\n      'data-is-focus': false,\n      'data-yeti-box': $id,\n      'aria-haspopup': true,\n      'aria-expanded': false\n    });\n\n    this._setCurrentAnchor(this.$anchors.first());\n\n    if(this.options.parentClass){\n      this.$parent = this.$element.parents('.' + this.options.parentClass);\n    }else{\n      this.$parent = null;\n    }\n\n    // Set [aria-labelledby] on the Dropdown if it is not set\n    if (typeof this.$element.attr('aria-labelledby') === 'undefined') {\n      // Get the anchor ID or create one\n      if (typeof this.$currentAnchor.attr('id') === 'undefined') {\n        this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));\n      };\n\n      this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));\n    }\n\n    this.$element.attr({\n      'aria-hidden': 'true',\n      'data-yeti-box': $id,\n      'data-resize': $id,\n    });\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/(top|left|right|bottom)/g);\n    if(position) {\n      return position[0];\n    } else {\n      return 'bottom'\n    }\n  }\n\n  _getDefaultAlignment() {\n    // handle legacy float approach\n    var horizontalPosition = /float-(\\S+)/.exec(this.$currentAnchor.attr('class'));\n    if(horizontalPosition) {\n      return horizontalPosition[1];\n    }\n\n    return super._getDefaultAlignment();\n  }\n\n\n\n  /**\n   * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.\n   * Recursively calls itself if a collision is detected, with a new position class.\n   * @function\n   * @private\n   */\n  _setPosition() {\n    this.$element.removeClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n    super._setPosition(this.$currentAnchor, this.$element, this.$parent);\n    this.$element.addClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n  }\n\n  /**\n   * Make it a current anchor.\n   * Current anchor as the reference for the position of Dropdown panes.\n   * @param {HTML} el - DOM element of the anchor.\n   * @function\n   * @private\n   */\n  _setCurrentAnchor(el) {\n    this.$currentAnchor = $(el);\n  }\n\n  /**\n   * Adds event listeners to the element utilizing the triggers utility library.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': this._setPosition.bind(this)\n    });\n\n    this.$anchors.off('click.zf.trigger')\n      .on('click.zf.trigger', function() { _this._setCurrentAnchor(this); });\n\n    if(this.options.hover){\n      this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n      .on('mouseenter.zf.dropdown', function(){\n        _this._setCurrentAnchor(this);\n\n        var bodyData = $('body').data();\n        if(typeof(bodyData.whatinput) === 'undefined' || bodyData.whatinput === 'mouse') {\n          clearTimeout(_this.timeout);\n          _this.timeout = setTimeout(function(){\n            _this.open();\n            _this.$anchors.data('hover', true);\n          }, _this.options.hoverDelay);\n        }\n      }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n        clearTimeout(_this.timeout);\n        _this.timeout = setTimeout(function(){\n          _this.close();\n          _this.$anchors.data('hover', false);\n        }, _this.options.hoverDelay);\n      }));\n      if(this.options.hoverPane){\n        this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n            .on('mouseenter.zf.dropdown', function(){\n              clearTimeout(_this.timeout);\n            }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n              clearTimeout(_this.timeout);\n              _this.timeout = setTimeout(function(){\n                _this.close();\n                _this.$anchors.data('hover', false);\n              }, _this.options.hoverDelay);\n            }));\n      }\n    }\n    this.$anchors.add(this.$element).on('keydown.zf.dropdown', function(e) {\n\n      var $target = $(this),\n        visibleFocusableElements = Keyboard.findFocusable(_this.$element);\n\n      Keyboard.handleKey(e, 'Dropdown', {\n        open: function() {\n          if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {\n            _this.open();\n            _this.$element.attr('tabindex', -1).focus();\n            e.preventDefault();\n          }\n        },\n        close: function() {\n          _this.close();\n          _this.$anchors.focus();\n        }\n      });\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n     var $body = $(document.body).not(this.$element),\n         _this = this;\n     $body.off('click.zf.dropdown')\n          .on('click.zf.dropdown', function(e){\n            if(_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {\n              return;\n            }\n            if(_this.$element.is(e.target) || _this.$element.find(e.target).length) {\n              return;\n            }\n            _this.close();\n            $body.off('click.zf.dropdown');\n          });\n  }\n\n  /**\n   * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.\n   * @function\n   * @fires Dropdown#closeme\n   * @fires Dropdown#show\n   */\n  open() {\n    // var _this = this;\n    /**\n     * Fires to close other open dropdowns, typically when dropdown is opening\n     * @event Dropdown#closeme\n     */\n    this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));\n    this.$anchors.addClass('hover')\n        .attr({'aria-expanded': true});\n    // this.$element/*.show()*/;\n\n    this.$element.addClass('is-opening');\n    this._setPosition();\n    this.$element.removeClass('is-opening').addClass('is-open')\n        .attr({'aria-hidden': false});\n\n    if(this.options.autoFocus){\n      var $focusable = Keyboard.findFocusable(this.$element);\n      if($focusable.length){\n        $focusable.eq(0).focus();\n      }\n    }\n\n    if(this.options.closeOnClick){ this._addBodyHandler(); }\n\n    if (this.options.trapFocus) {\n      Keyboard.trapFocus(this.$element);\n    }\n\n    /**\n     * Fires once the dropdown is visible.\n     * @event Dropdown#show\n     */\n    this.$element.trigger('show.zf.dropdown', [this.$element]);\n  }\n\n  /**\n   * Closes the open dropdown pane.\n   * @function\n   * @fires Dropdown#hide\n   */\n  close() {\n    if(!this.$element.hasClass('is-open')){\n      return false;\n    }\n    this.$element.removeClass('is-open')\n        .attr({'aria-hidden': true});\n\n    this.$anchors.removeClass('hover')\n        .attr('aria-expanded', false);\n\n    /**\n     * Fires once the dropdown is no longer visible.\n     * @event Dropdown#hide\n     */\n    this.$element.trigger('hide.zf.dropdown', [this.$element]);\n\n    if (this.options.trapFocus) {\n      Keyboard.releaseFocus(this.$element);\n    }\n  }\n\n  /**\n   * Toggles the dropdown pane's visibility.\n   * @function\n   */\n  toggle() {\n    if(this.$element.hasClass('is-open')){\n      if(this.$anchors.data('hover')) return;\n      this.close();\n    }else{\n      this.open();\n    }\n  }\n\n  /**\n   * Destroys the dropdown.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger').hide();\n    this.$anchors.off('.zf.dropdown');\n    $(document.body).off('click.zf.dropdown');\n\n  }\n}\n\nDropdown.defaults = {\n  /**\n   * Class that designates bounding container of Dropdown (default: window)\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  parentClass: null,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  hoverDelay: 250,\n  /**\n   * Allow submenus to open on hover events\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hover: false,\n  /**\n   * Don't close dropdown when hovering over dropdown pane\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hoverPane: false,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Position of dropdown. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false,\n  /**\n   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n  /**\n   * Allows a click on the body to close the dropdown.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false\n};\n\nexport {Dropdown};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl, ignoreMousedisappear } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { Box } from './foundation.util.box';\n\n/**\n * DropdownMenu module.\n * @module foundation.dropdown-menu\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.nest\n */\n\nclass DropdownMenu extends Plugin {\n  /**\n   * Creates a new instance of DropdownMenu.\n   * @class\n   * @name DropdownMenu\n   * @fires DropdownMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n    this.className = 'DropdownMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('DropdownMenu', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin, and calls _prepareMenu\n   * @private\n   * @function\n   */\n  _init() {\n    Nest.Feather(this.$element, 'dropdown');\n\n    var subs = this.$element.find('li.is-dropdown-submenu-parent');\n    this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');\n\n    this.$menuItems = this.$element.find('[role=\"menuitem\"]');\n    this.$tabs = this.$element.children('[role=\"menuitem\"]');\n    this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);\n\n    if (this.options.alignment === 'auto') {\n        if (this.$element.hasClass(this.options.rightClass) || Rtl() || this.$element.parents('.top-bar-right').is('*')) {\n            this.options.alignment = 'right';\n            subs.addClass('opens-left');\n        } else {\n            this.options.alignment = 'left';\n            subs.addClass('opens-right');\n        }\n    } else {\n      if (this.options.alignment === 'right') {\n          subs.addClass('opens-left');\n      } else {\n          subs.addClass('opens-right');\n      }\n    }\n    this.changed = false;\n    this._events();\n  };\n\n  _isVertical() {\n    return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';\n  }\n\n  _isRtl() {\n    return this.$element.hasClass('align-right') || (Rtl() && !this.$element.hasClass('align-left'));\n  }\n\n  /**\n   * Adds event listeners to elements within the menu\n   * @private\n   * @function\n   */\n  _events() {\n    var _this = this,\n        hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined'),\n        parClass = 'is-dropdown-submenu-parent';\n\n    // used for onClick and in the keyboard handlers\n    var handleClickFn = function(e) {\n      var $elem = $(e.target).parentsUntil('ul', `.${parClass}`),\n          hasSub = $elem.hasClass(parClass),\n          hasClicked = $elem.attr('data-is-click') === 'true',\n          $sub = $elem.children('.is-dropdown-submenu');\n\n      if (hasSub) {\n        if (hasClicked) {\n          if (!_this.options.closeOnClick || (!_this.options.clickOpen && !hasTouch) || (_this.options.forceFollow && hasTouch)) { return; }\n          else {\n            e.stopImmediatePropagation();\n            e.preventDefault();\n            _this._hide($elem);\n          }\n        } else {\n          e.preventDefault();\n          e.stopImmediatePropagation();\n          _this._show($sub);\n          $elem.add($elem.parentsUntil(_this.$element, `.${parClass}`)).attr('data-is-click', true);\n        }\n      }\n    };\n\n    if (this.options.clickOpen || hasTouch) {\n      this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);\n    }\n\n    // Handle Leaf element Clicks\n    if(_this.options.closeOnClickInside){\n      this.$menuItems.on('click.zf.dropdownmenu', function(e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if(!hasSub){\n          _this._hide();\n        }\n      });\n    }\n\n    if (!this.options.disableHover) {\n      this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {\n        var $elem = $(this),\n          hasSub = $elem.hasClass(parClass);\n\n        if (hasSub) {\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._show($elem.children('.is-dropdown-submenu'));\n          }, _this.options.hoverDelay));\n        }\n      }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if (hasSub && _this.options.autoclose) {\n          if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { return false; }\n\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._hide($elem);\n          }, _this.options.closingTime));\n        }\n      }));\n    }\n    this.$menuItems.on('keydown.zf.dropdownmenu', function(e) {\n      var $element = $(e.target).parentsUntil('ul', '[role=\"menuitem\"]'),\n          isTab = _this.$tabs.index($element) > -1,\n          $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(i-1);\n          $nextElement = $elements.eq(i+1);\n          return;\n        }\n      });\n\n      var nextSibling = function() {\n        $nextElement.children('a:first').focus();\n        e.preventDefault();\n      }, prevSibling = function() {\n        $prevElement.children('a:first').focus();\n        e.preventDefault();\n      }, openSub = function() {\n        var $sub = $element.children('ul.is-dropdown-submenu');\n        if ($sub.length) {\n          _this._show($sub);\n          $element.find('li > a:first').focus();\n          e.preventDefault();\n        } else { return; }\n      }, closeSub = function() {\n        //if ($element.is(':first-child')) {\n        var close = $element.parent('ul').parent('li');\n        close.children('a:first').focus();\n        _this._hide(close);\n        e.preventDefault();\n        //}\n      };\n      var functions = {\n        open: openSub,\n        close: function() {\n          _this._hide(_this.$element);\n          _this.$menuItems.eq(0).children('a').focus(); // focus to first element\n          e.preventDefault();\n        },\n        handled: function() {\n          e.stopImmediatePropagation();\n        }\n      };\n\n      if (isTab) {\n        if (_this._isVertical()) { // vertical menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: closeSub,\n              previous: openSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: openSub,\n              previous: closeSub\n            });\n          }\n        } else { // horizontal menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              next: prevSibling,\n              previous: nextSibling,\n              down: openSub,\n              up: closeSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              next: nextSibling,\n              previous: prevSibling,\n              down: openSub,\n              up: closeSub\n            });\n          }\n        }\n      } else { // not tabs -> one sub\n        if (_this._isRtl()) { // right aligned\n          $.extend(functions, {\n            next: closeSub,\n            previous: openSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        } else { // left aligned\n          $.extend(functions, {\n            next: openSub,\n            previous: closeSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        }\n      }\n      Keyboard.handleKey(e, 'DropdownMenu', functions);\n\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n    var $body = $(document.body),\n        _this = this;\n    $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu')\n         .on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function(e) {\n           var $link = _this.$element.find(e.target);\n           if ($link.length) { return; }\n\n           _this._hide();\n           $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');\n         });\n  }\n\n  /**\n   * Opens a dropdown pane, and checks for collisions first.\n   * @param {jQuery} $sub - ul element that is a submenu to show\n   * @function\n   * @private\n   * @fires Dropdownmenu#show\n   */\n  _show($sub) {\n    var idx = this.$tabs.index(this.$tabs.filter(function(i, el) {\n      return $(el).find($sub).length > 0;\n    }));\n    var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');\n    this._hide($sibs, idx);\n    $sub.css('visibility', 'hidden').addClass('js-dropdown-active')\n        .parent('li.is-dropdown-submenu-parent').addClass('is-active');\n    var clear = Box.ImNotTouchingYou($sub, null, true);\n    if (!clear) {\n      var oldClass = this.options.alignment === 'left' ? '-right' : '-left',\n          $parentLi = $sub.parent('.is-dropdown-submenu-parent');\n      $parentLi.removeClass(`opens${oldClass}`).addClass(`opens-${this.options.alignment}`);\n      clear = Box.ImNotTouchingYou($sub, null, true);\n      if (!clear) {\n        $parentLi.removeClass(`opens-${this.options.alignment}`).addClass('opens-inner');\n      }\n      this.changed = true;\n    }\n    $sub.css('visibility', '');\n    if (this.options.closeOnClick) { this._addBodyHandler(); }\n    /**\n     * Fires when the new dropdown pane is visible.\n     * @event Dropdownmenu#show\n     */\n    this.$element.trigger('show.zf.dropdownmenu', [$sub]);\n  }\n\n  /**\n   * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.\n   * @function\n   * @param {jQuery} $elem - element with a submenu to hide\n   * @param {Number} idx - index of the $tabs collection to hide\n   * @private\n   */\n  _hide($elem, idx) {\n    var $toClose;\n    if ($elem && $elem.length) {\n      $toClose = $elem;\n    } else if (typeof idx !== 'undefined') {\n      $toClose = this.$tabs.not(function(i, el) {\n        return i === idx;\n      });\n    }\n    else {\n      $toClose = this.$element;\n    }\n    var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;\n\n    if (somethingToClose) {\n      $toClose.find('li.is-active').add($toClose).attr({\n        'data-is-click': false\n      }).removeClass('is-active');\n\n      $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');\n\n      if (this.changed || $toClose.find('opens-inner').length) {\n        var oldClass = this.options.alignment === 'left' ? 'right' : 'left';\n        $toClose.find('li.is-dropdown-submenu-parent').add($toClose)\n                .removeClass(`opens-inner opens-${this.options.alignment}`)\n                .addClass(`opens-${oldClass}`);\n        this.changed = false;\n      }\n      /**\n       * Fires when the open menus are closed.\n       * @event Dropdownmenu#hide\n       */\n      this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);\n    }\n  }\n\n  /**\n   * Destroys the plugin.\n   * @function\n   */\n  _destroy() {\n    this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click')\n        .removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');\n    $(document.body).off('.zf.dropdownmenu');\n    Nest.Burn(this.$element, 'dropdown');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nDropdownMenu.defaults = {\n  /**\n   * Disallows hover events from opening submenus\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoclose: true,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  hoverDelay: 50,\n  /**\n   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  clickOpen: false,\n  /**\n   * Amount of time to delay closing a submenu on a mouseleave event.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n\n  closingTime: 500,\n  /**\n   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow clicks on the body to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allow clicks on leaf anchor links to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClickInside: true,\n  /**\n   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'vertical'\n   */\n  verticalClass: 'vertical',\n  /**\n   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'align-right'\n   */\n  rightClass: 'align-right',\n  /**\n   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  forceFollow: true\n};\n\nexport {DropdownMenu};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.imageLoader if equalizer contains images\n */\n\nclass Equalizer extends Plugin {\n  /**\n   * Creates a new instance of Equalizer.\n   * @class\n   * @name Equalizer\n   * @fires Equalizer#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options){\n    this.$element = element;\n    this.options  = $.extend({}, Equalizer.defaults, this.$element.data(), options);\n    this.className = 'Equalizer'; // ie9 back compat\n\n    this._init();\n  }\n\n  /**\n   * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var eqId = this.$element.attr('data-equalizer') || '';\n    var $watched = this.$element.find(`[data-equalizer-watch=\"${eqId}\"]`);\n\n    MediaQuery._init();\n\n    this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n    this.$element.attr('data-resize', (eqId || GetYoDigits(6, 'eq')));\n    this.$element.attr('data-mutate', (eqId || GetYoDigits(6, 'eq')));\n\n    this.hasNested = this.$element.find('[data-equalizer]').length > 0;\n    this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;\n    this.isOn = false;\n    this._bindHandler = {\n      onResizeMeBound: this._onResizeMe.bind(this),\n      onPostEqualizedBound: this._onPostEqualized.bind(this)\n    };\n\n    var imgs = this.$element.find('img');\n    var tooSmall;\n    if(this.options.equalizeOn){\n      tooSmall = this._checkMQ();\n      $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));\n    }else{\n      this._events();\n    }\n    if((typeof tooSmall !== 'undefined' && tooSmall === false) || typeof tooSmall === 'undefined'){\n      if(imgs.length){\n        onImagesLoaded(imgs, this._reflow.bind(this));\n      }else{\n        this._reflow();\n      }\n    }\n  }\n\n  /**\n   * Removes event listeners if the breakpoint is too small.\n   * @private\n   */\n  _pauseEvents() {\n    this.isOn = false;\n    this.$element.off({\n      '.zf.equalizer': this._bindHandler.onPostEqualizedBound,\n      'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,\n\t  'mutateme.zf.trigger': this._bindHandler.onResizeMeBound\n    });\n  }\n\n  /**\n   * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound\n   * @private\n   */\n  _onResizeMe(e) {\n    this._reflow();\n  }\n\n  /**\n   * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound\n   * @private\n   */\n  _onPostEqualized(e) {\n    if(e.target !== this.$element[0]){ this._reflow(); }\n  }\n\n  /**\n   * Initializes events for Equalizer.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this._pauseEvents();\n    if(this.hasNested){\n      this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);\n    }else{\n      this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);\n\t  this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);\n    }\n    this.isOn = true;\n  }\n\n  /**\n   * Checks the current breakpoint to the minimum required size.\n   * @private\n   */\n  _checkMQ() {\n    var tooSmall = !MediaQuery.is(this.options.equalizeOn);\n    if(tooSmall){\n      if(this.isOn){\n        this._pauseEvents();\n        this.$watched.css('height', 'auto');\n      }\n    }else{\n      if(!this.isOn){\n        this._events();\n      }\n    }\n    return tooSmall;\n  }\n\n  /**\n   * A noop version for the plugin\n   * @private\n   */\n  _killswitch() {\n    return;\n  }\n\n  /**\n   * Calls necessary functions to update Equalizer upon DOM change\n   * @private\n   */\n  _reflow() {\n    if(!this.options.equalizeOnStack){\n      if(this._isStacked()){\n        this.$watched.css('height', 'auto');\n        return false;\n      }\n    }\n    if (this.options.equalizeByRow) {\n      this.getHeightsByRow(this.applyHeightByRow.bind(this));\n    }else{\n      this.getHeights(this.applyHeight.bind(this));\n    }\n  }\n\n  /**\n   * Manually determines if the first 2 elements are *NOT* stacked.\n   * @private\n   */\n  _isStacked() {\n    if (!this.$watched[0] || !this.$watched[1]) {\n      return true;\n    }\n    return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} heights - An array of heights of children within Equalizer container\n   */\n  getHeights(cb) {\n    var heights = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      heights.push(this.$watched[i].offsetHeight);\n    }\n    cb(heights);\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   */\n  getHeightsByRow(cb) {\n    var lastElTopOffset = (this.$watched.length ? this.$watched.first().offset().top : 0),\n        groups = [],\n        group = 0;\n    //group by Row\n    groups[group] = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      //maybe could use this.$watched[i].offsetTop\n      var elOffsetTop = $(this.$watched[i]).offset().top;\n      if (elOffsetTop!=lastElTopOffset) {\n        group++;\n        groups[group] = [];\n        lastElTopOffset=elOffsetTop;\n      }\n      groups[group].push([this.$watched[i],this.$watched[i].offsetHeight]);\n    }\n\n    for (var j = 0, ln = groups.length; j < ln; j++) {\n      var heights = $(groups[j]).map(function(){ return this[1]; }).get();\n      var max         = Math.max.apply(null, heights);\n      groups[j].push(max);\n    }\n    cb(groups);\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest\n   * @param {array} heights - An array of heights of children within Equalizer container\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#postequalized\n   */\n  applyHeight(heights) {\n    var max = Math.max.apply(null, heights);\n    /**\n     * Fires before the heights are applied\n     * @event Equalizer#preequalized\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n\n    this.$watched.css('height', max);\n\n    /**\n     * Fires when the heights have been applied\n     * @event Equalizer#postequalized\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row\n   * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#preequalizedrow\n   * @fires Equalizer#postequalizedrow\n   * @fires Equalizer#postequalized\n   */\n  applyHeightByRow(groups) {\n    /**\n     * Fires before the heights are applied\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n    for (var i = 0, len = groups.length; i < len ; i++) {\n      var groupsILength = groups[i].length,\n          max = groups[i][groupsILength - 1];\n      if (groupsILength<=2) {\n        $(groups[i][0][0]).css({'height':'auto'});\n        continue;\n      }\n      /**\n        * Fires before the heights per row are applied\n        * @event Equalizer#preequalizedrow\n        */\n      this.$element.trigger('preequalizedrow.zf.equalizer');\n      for (var j = 0, lenJ = (groupsILength-1); j < lenJ ; j++) {\n        $(groups[i][j][0]).css({'height':max});\n      }\n      /**\n        * Fires when the heights per row have been applied\n        * @event Equalizer#postequalizedrow\n        */\n      this.$element.trigger('postequalizedrow.zf.equalizer');\n    }\n    /**\n     * Fires when the heights have been applied\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Destroys an instance of Equalizer.\n   * @function\n   */\n  _destroy() {\n    this._pauseEvents();\n    this.$watched.css('height', 'auto');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nEqualizer.defaults = {\n  /**\n   * Enable height equalization when stacked on smaller screens.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeOnStack: false,\n  /**\n   * Enable height equalization row by row.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeByRow: false,\n  /**\n   * String representing the minimum breakpoint size the plugin should equalize heights on.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  equalizeOn: ''\n};\n\nexport {Equalizer};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n */\n\nclass Interchange extends Plugin {\n  /**\n   * Creates a new instance of Interchange.\n   * @class\n   * @name Interchange\n   * @fires Interchange#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Interchange.defaults, options);\n    this.rules = [];\n    this.currentPath = '';\n    this.className = 'Interchange'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Interchange plugin and calls functions to get interchange functioning on load.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var id = this.$element[0].id || GetYoDigits(6, 'interchange');\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    this._addBreakpoints();\n    this._generateRules();\n    this._reflow();\n  }\n\n  /**\n   * Initializes events for Interchange.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', () => this._reflow());\n  }\n\n  /**\n   * Calls necessary functions to update Interchange upon DOM change\n   * @function\n   * @private\n   */\n  _reflow() {\n    var match;\n\n    // Iterate through each rule, but only save the last match\n    for (var i in this.rules) {\n      if(this.rules.hasOwnProperty(i)) {\n        var rule = this.rules[i];\n        if (window.matchMedia(rule.query).matches) {\n          match = rule;\n        }\n      }\n    }\n\n    if (match) {\n      this.replace(match.path);\n    }\n  }\n\n  /**\n   * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.\n   * @function\n   * @private\n   */\n  _addBreakpoints() {\n    for (var i in MediaQuery.queries) {\n      if (MediaQuery.queries.hasOwnProperty(i)) {\n        var query = MediaQuery.queries[i];\n        Interchange.SPECIAL_QUERIES[query.name] = query.value;\n      }\n    }\n  }\n\n  /**\n   * Checks the Interchange element for the provided media query + content pairings\n   * @function\n   * @private\n   * @param {Object} element - jQuery object that is an Interchange instance\n   * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys\n   */\n  _generateRules(element) {\n    var rulesList = [];\n    var rules;\n\n    if (this.options.rules) {\n      rules = this.options.rules;\n    }\n    else {\n      rules = this.$element.data('interchange');\n    }\n\n    rules =  typeof rules === 'string' ? rules.match(/\\[.*?, .*?\\]/g) : rules;\n\n    for (var i in rules) {\n      if(rules.hasOwnProperty(i)) {\n        var rule = rules[i].slice(1, -1).split(', ');\n        var path = rule.slice(0, -1).join('');\n        var query = rule[rule.length - 1];\n\n        if (Interchange.SPECIAL_QUERIES[query]) {\n          query = Interchange.SPECIAL_QUERIES[query];\n        }\n\n        rulesList.push({\n          path: path,\n          query: query\n        });\n      }\n    }\n\n    this.rules = rulesList;\n  }\n\n  /**\n   * Update the `src` property of an image, or change the HTML of a container, to the specified path.\n   * @function\n   * @param {String} path - Path to the image or HTML partial.\n   * @fires Interchange#replaced\n   */\n  replace(path) {\n    if (this.currentPath === path) return;\n\n    var _this = this,\n        trigger = 'replaced.zf.interchange';\n\n    // Replacing images\n    if (this.$element[0].nodeName === 'IMG') {\n      this.$element.attr('src', path).on('load', function() {\n        _this.currentPath = path;\n      })\n      .trigger(trigger);\n    }\n    // Replacing background images\n    else if (path.match(/\\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {\n      path = path.replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n      this.$element.css({ 'background-image': 'url('+path+')' })\n          .trigger(trigger);\n    }\n    // Replacing HTML\n    else {\n      $.get(path, function(response) {\n        _this.$element.html(response)\n             .trigger(trigger);\n        $(response).foundation();\n        _this.currentPath = path;\n      });\n    }\n\n    /**\n     * Fires when content in an Interchange element is done being loaded.\n     * @event Interchange#replaced\n     */\n    // this.$element.trigger('replaced.zf.interchange');\n  }\n\n  /**\n   * Destroys an instance of interchange.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('resizeme.zf.trigger')\n  }\n}\n\n/**\n * Default settings for plugin\n */\nInterchange.defaults = {\n  /**\n   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.\n   * @option\n   * @type {?array}\n   * @default null\n   */\n  rules: null\n};\n\nInterchange.SPECIAL_QUERIES = {\n  'landscape': 'screen and (orientation: landscape)',\n  'portrait': 'screen and (orientation: portrait)',\n  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'\n};\n\nexport {Interchange};\n","import $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * SmoothScroll module.\n * @module foundation.smooth-scroll\n */\nclass SmoothScroll extends Plugin {\n  /**\n   * Creates a new instance of SmoothScroll.\n   * @class\n   * @name SmoothScroll\n   * @fires SmoothScroll#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n    _setup(element, options) {\n        this.$element = element;\n        this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);\n        this.className = 'SmoothScroll'; // ie9 back compat\n\n        this._init();\n    }\n\n    /**\n     * Initialize the SmoothScroll plugin\n     * @private\n     */\n    _init() {\n        const id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');\n        this.$element.attr({ id });\n\n        this._events();\n    }\n\n    /**\n     * Initializes events for SmoothScroll.\n     * @private\n     */\n    _events() {\n        this._linkClickListener = this._handleLinkClick.bind(this);\n        this.$element.on('click.zf.smoothScroll', this._linkClickListener);\n        this.$element.on('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n\n    /**\n     * Handle the given event to smoothly scroll to the anchor pointed by the event target.\n     * @param {*} e - event\n     * @function\n     * @private\n     */\n    _handleLinkClick(e) {\n        // Follow the link if it does not point to an anchor.\n        if (!$(e.currentTarget).is('a[href^=\"#\"]')) return;\n\n        const arrival = e.currentTarget.getAttribute('href');\n\n        this._inTransition = true;\n\n        SmoothScroll.scrollToLoc(arrival, this.options, () => {\n            this._inTransition = false;\n        });\n\n        e.preventDefault();\n    };\n\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'\n     * @param {Object} options - The options to use.\n     * @param {Function} callback - The callback function.\n     * @static\n     * @function\n     */\n    static scrollToLoc(loc, options = SmoothScroll.defaults, callback) {\n        const $loc = $(loc);\n\n        // Do nothing if target does not exist to prevent errors\n        if (!$loc.length) return false;\n\n        var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);\n\n        $('html, body').stop(true).animate(\n            { scrollTop: scrollPos },\n            options.animationDuration,\n            options.animationEasing,\n            () => {\n                if (typeof callback === 'function'){\n                    callback();\n                }\n            }\n        );\n    }\n\n    /**\n     * Destroys the SmoothScroll instance.\n     * @function\n     */\n    _destroy() {\n        this.$element.off('click.zf.smoothScroll', this._linkClickListener)\n        this.$element.off('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n}\n\n/**\n * Default settings for plugin.\n */\nSmoothScroll.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {SmoothScroll}\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { SmoothScroll } from './foundation.smoothScroll';\n\n/**\n * Magellan module.\n * @module foundation.magellan\n * @requires foundation.smoothScroll\n */\n\nclass Magellan extends Plugin {\n  /**\n   * Creates a new instance of Magellan.\n   * @class\n   * @name Magellan\n   * @fires Magellan#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options  = $.extend({}, Magellan.defaults, this.$element.data(), options);\n    this.className = 'Magellan'; // ie9 back compat\n\n    this._init();\n    this.calcPoints();\n  }\n\n  /**\n   * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var id = this.$element[0].id || GetYoDigits(6, 'magellan');\n    var _this = this;\n    this.$targets = $('[data-magellan-target]');\n    this.$links = this.$element.find('a');\n    this.$element.attr({\n      'data-resize': id,\n      'data-scroll': id,\n      'id': id\n    });\n    this.$active = $();\n    this.scrollPos = parseInt(window.pageYOffset, 10);\n\n    this._events();\n  }\n\n  /**\n   * Calculates an array of pixel values that are the demarcation lines between locations on the page.\n   * Can be invoked if new elements are added or the size of a location changes.\n   * @function\n   */\n  calcPoints() {\n    var _this = this,\n        body = document.body,\n        html = document.documentElement;\n\n    this.points = [];\n    this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));\n    this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));\n\n    this.$targets.each(function(){\n      var $tar = $(this),\n          pt = Math.round($tar.offset().top - _this.options.threshold);\n      $tar.targetPoint = pt;\n      _this.points.push(pt);\n    });\n  }\n\n  /**\n   * Initializes events for Magellan.\n   * @private\n   */\n  _events() {\n    var _this = this,\n        $body = $('html, body'),\n        opts = {\n          duration: _this.options.animationDuration,\n          easing:   _this.options.animationEasing\n        };\n\n    $(window).one('load', function(){\n      if(_this.options.deepLinking){\n        if(location.hash){\n          _this.scrollToLoc(location.hash);\n        }\n      }\n      _this.calcPoints();\n      _this._updateActive();\n    });\n\n    _this.onLoadListener = onLoad($(window), function () {\n      _this.$element\n        .on({\n          'resizeme.zf.trigger': _this.reflow.bind(_this),\n          'scrollme.zf.trigger': _this._updateActive.bind(_this)\n        })\n        .on('click.zf.magellan', 'a[href^=\"#\"]', function (e) {\n          e.preventDefault();\n          var arrival   = this.getAttribute('href');\n          _this.scrollToLoc(arrival);\n        });\n    });\n\n    this._deepLinkScroll = function(e) {\n      if(_this.options.deepLinking) {\n        _this.scrollToLoc(window.location.hash);\n      }\n    };\n\n    $(window).on('hashchange', this._deepLinkScroll);\n  }\n\n  /**\n   * Function to scroll to a given location on the page.\n   * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'\n   * @function\n   */\n  scrollToLoc(loc) {\n    this._inTransition = true;\n    var _this = this;\n\n    var options = {\n      animationEasing: this.options.animationEasing,\n      animationDuration: this.options.animationDuration,\n      threshold: this.options.threshold,\n      offset: this.options.offset\n    };\n\n    SmoothScroll.scrollToLoc(loc, options, function() {\n      _this._inTransition = false;\n    })\n  }\n\n  /**\n   * Calls necessary functions to update Magellan upon DOM change\n   * @function\n   */\n  reflow() {\n    this.calcPoints();\n    this._updateActive();\n  }\n\n  /**\n   * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.\n   * @private\n   * @function\n   * @fires Magellan#update\n   */\n  _updateActive(/*evt, elem, scrollPos*/) {\n    if(this._inTransition) return;\n\n    const newScrollPos = parseInt(window.pageYOffset, 10);\n    const isScrollingUp = this.scrollPos > newScrollPos;\n    this.scrollPos = newScrollPos;\n\n    let activeIdx;\n    // Before the first point: no link\n    if(newScrollPos < this.points[0]){ /* do nothing */ }\n    // At the bottom of the page: last link\n    else if(newScrollPos + this.winHeight === this.docHeight){ activeIdx = this.points.length - 1; }\n    // Otherwhise, use the last visible link\n    else{\n      const visibleLinks = this.points.filter((p, i) => {\n        return (p - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) <= newScrollPos;\n      });\n      activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;\n    }\n\n    // Get the new active link\n    const $oldActive = this.$active;\n    let activeHash = '';\n    if(typeof activeIdx !== 'undefined'){\n      this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(activeIdx).data('magellan-target') + '\"]');\n      if (this.$active.length) activeHash = this.$active[0].getAttribute('href');\n    }else{\n      this.$active = $();\n    }\n    const isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);\n    const isNewHash = activeHash !== window.location.hash;\n\n    // Update the active link element\n    if(isNewActive) {\n      $oldActive.removeClass(this.options.activeClass);\n      this.$active.addClass(this.options.activeClass);\n    }\n\n    // Update the hash (it may have changed with the same active link)\n    if(this.options.deepLinking && isNewHash){\n      if(window.history.pushState){\n        // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384\n        const url = activeHash ? activeHash : window.location.pathname + window.location.search;\n        window.history.pushState(null, null, url);\n      }else{\n        window.location.hash = activeHash;\n      }\n    }\n\n    if (isNewActive) {\n      /**\n       * Fires when magellan is finished updating to the new active element.\n       * @event Magellan#update\n       */\n    \tthis.$element.trigger('update.zf.magellan', [this.$active]);\n\t  }\n  }\n\n  /**\n   * Destroys an instance of Magellan and resets the url of the window.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger .zf.magellan')\n        .find(`.${this.options.activeClass}`).removeClass(this.options.activeClass);\n\n    if(this.options.deepLinking){\n      var hash = this.$active[0].getAttribute('href');\n      window.location.hash.replace(hash, '');\n    }\n\n    $(window).off('hashchange', this._deepLinkScroll)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\n/**\n * Default settings for plugin\n */\nMagellan.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Class applied to the active locations link on the magellan container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  activeClass: 'is-active',\n  /**\n   * Allows the script to manipulate the url of the current page, and if supported, alter the history.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinking: false,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {Magellan};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, transitionend, RegExpEscape } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * OffCanvas module.\n * @module foundation.offcanvas\n * @requires foundation.util.keyboard\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass OffCanvas extends Plugin {\n  /**\n   * Creates a new instance of an off-canvas wrapper.\n   * @class\n   * @name OffCanvas\n   * @fires OffCanvas#init\n   * @param {Object} element - jQuery object to initialize.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.className = 'OffCanvas'; // ie9 back compat\n    this.$element = element;\n    this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);\n    this.contentClasses = { base: [], reveal: [] };\n    this.$lastTrigger = $();\n    this.$triggers = $();\n    this.position = 'left';\n    this.$content = $();\n    this.nested = !!(this.options.nested);\n\n    // Defines the CSS transition/position classes of the off-canvas content container.\n    $(['push', 'overlap']).each((index, val) => {\n      this.contentClasses.base.push('has-transition-'+val);\n    });\n    $(['left', 'right', 'top', 'bottom']).each((index, val) => {\n      this.contentClasses.base.push('has-position-'+val);\n      this.contentClasses.reveal.push('has-reveal-'+val);\n    });\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n    MediaQuery._init();\n\n    this._init();\n    this._events();\n\n    Keyboard.register('OffCanvas', {\n      'ESCAPE': 'close'\n    });\n\n  }\n\n  /**\n   * Initializes the off-canvas wrapper by adding the exit overlay (if needed).\n   * @function\n   * @private\n   */\n  _init() {\n    var id = this.$element.attr('id');\n\n    this.$element.attr('aria-hidden', 'true');\n\n    // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)\n    if (this.options.contentId) {\n      this.$content = $('#'+this.options.contentId);\n    } else if (this.$element.siblings('[data-off-canvas-content]').length) {\n      this.$content = this.$element.siblings('[data-off-canvas-content]').first();\n    } else {\n      this.$content = this.$element.closest('[data-off-canvas-content]').first();\n    }\n\n    if (!this.options.contentId) {\n      // Assume that the off-canvas element is nested if it isn't a sibling of the content\n      this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;\n\n    } else if (this.options.contentId && this.options.nested === null) {\n      // Warning if using content ID without setting the nested option\n      // Once the element is nested it is required to work properly in this case\n      console.warn('Remember to use the nested option if using the content ID option!');\n    }\n\n    if (this.nested === true) {\n      // Force transition overlap if nested\n      this.options.transition = 'overlap';\n      // Remove appropriate classes if already assigned in markup\n      this.$element.removeClass('is-transition-push');\n    }\n\n    this.$element.addClass(`is-transition-${this.options.transition} is-closed`);\n\n    // Find triggers that affect this element and add aria-expanded to them\n    this.$triggers = $(document)\n      .find('[data-open=\"'+id+'\"], [data-close=\"'+id+'\"], [data-toggle=\"'+id+'\"]')\n      .attr('aria-expanded', 'false')\n      .attr('aria-controls', id);\n\n    // Get position by checking for related CSS class\n    this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\\-(left|top|right|bottom)/)[1] : this.position;\n\n    // Add an overlay over the content if necessary\n    if (this.options.contentOverlay === true) {\n      var overlay = document.createElement('div');\n      var overlayPosition = $(this.$element).css(\"position\") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';\n      overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);\n      this.$overlay = $(overlay);\n      if(overlayPosition === 'is-overlay-fixed') {\n        $(this.$overlay).insertAfter(this.$element);\n      } else {\n        this.$content.append(this.$overlay);\n      }\n    }\n\n    // Get the revealOn option from the class.\n    var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\\\s]+)', 'g');\n    var revealOnClass = revealOnRegExp.exec(this.$element[0].className);\n    if (revealOnClass) {\n      this.options.isRevealed = true;\n      this.options.revealOn = this.options.revealOn || revealOnClass[1];\n    }\n\n    // Ensure the `reveal-on-*` class is set.\n    if (this.options.isRevealed === true && this.options.revealOn) {\n      this.$element.first().addClass(`${this.options.revealClass}${this.options.revealOn}`);\n      this._setMQChecker();\n    }\n\n    if (this.options.transitionTime) {\n      this.$element.css('transition-duration', this.options.transitionTime);\n    }\n\n    // Initally remove all transition/position CSS classes from off-canvas content container.\n    this._removeContentClasses();\n  }\n\n  /**\n   * Adds event handlers to the off-canvas wrapper and the exit overlay.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('.zf.trigger .zf.offcanvas').on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'keydown.zf.offcanvas': this._handleKeyboard.bind(this)\n    });\n\n    if (this.options.closeOnClick === true) {\n      var $target = this.options.contentOverlay ? this.$overlay : this.$content;\n      $target.on({'click.zf.offcanvas': this.close.bind(this)});\n    }\n  }\n\n  /**\n   * Applies event listener for elements that will reveal at certain breakpoints.\n   * @private\n   */\n  _setMQChecker() {\n    var _this = this;\n\n    this.onLoadListener = onLoad($(window), function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      }\n    });\n\n    $(window).on('changed.zf.mediaquery', function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      } else {\n        _this.reveal(false);\n      }\n    });\n  }\n\n  /**\n   * Removes the CSS transition/position classes of the off-canvas content container.\n   * Removing the classes is important when another off-canvas gets opened that uses the same content container.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _removeContentClasses(hasReveal) {\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.removeClass(this.contentClasses.base.join(' '));\n    } else if (hasReveal === false) {\n      this.$content.removeClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.\n   * Beforehand any transition/position class gets removed.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _addContentClasses(hasReveal) {\n    this._removeContentClasses(hasReveal);\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.addClass(`has-transition-${this.options.transition} has-position-${this.position}`);\n    } else if (hasReveal === true) {\n      this.$content.addClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.\n   * @param {Boolean} isRevealed - true if element should be revealed.\n   * @function\n   */\n  reveal(isRevealed) {\n    if (isRevealed) {\n      this.close();\n      this.isRevealed = true;\n      this.$element.attr('aria-hidden', 'false');\n      this.$element.off('open.zf.trigger toggle.zf.trigger');\n      this.$element.removeClass('is-closed');\n    } else {\n      this.isRevealed = false;\n      this.$element.attr('aria-hidden', 'true');\n      this.$element.off('open.zf.trigger toggle.zf.trigger').on({\n        'open.zf.trigger': this.open.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this)\n      });\n      this.$element.addClass('is-closed');\n    }\n    this._addContentClasses(isRevealed);\n  }\n\n  /**\n   * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.\n   * @private\n   */\n  _stopScrolling(event) {\n    return false;\n  }\n\n  // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios\n  // Only really works for y, not sure how to extend to x or if we need to.\n  _recordScrollable(event) {\n    let elem = this; // called from event handler context with this as elem\n\n     // If the element is scrollable (content overflows), then...\n    if (elem.scrollHeight !== elem.clientHeight) {\n      // If we're at the top, scroll down one pixel to allow scrolling up\n      if (elem.scrollTop === 0) {\n        elem.scrollTop = 1;\n      }\n      // If we're at the bottom, scroll up one pixel to allow scrolling down\n      if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {\n        elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;\n      }\n    }\n    elem.allowUp = elem.scrollTop > 0;\n    elem.allowDown = elem.scrollTop < (elem.scrollHeight - elem.clientHeight);\n    elem.lastY = event.originalEvent.pageY;\n  }\n\n  _stopScrollPropagation(event) {\n    let elem = this; // called from event handler context with this as elem\n    let up = event.pageY < elem.lastY;\n    let down = !up;\n    elem.lastY = event.pageY;\n\n    if((up && elem.allowUp) || (down && elem.allowDown)) {\n      event.stopPropagation();\n    } else {\n      event.preventDefault();\n    }\n  }\n\n  /**\n   * Opens the off-canvas menu.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   * @fires Offcanvas#opened\n   * @todo also trigger 'open' event?\n   */\n  open(event, trigger) {\n    if (this.$element.hasClass('is-open') || this.isRevealed) { return; }\n    var _this = this;\n\n    if (trigger) {\n      this.$lastTrigger = trigger;\n    }\n\n    if (this.options.forceTo === 'top') {\n      window.scrollTo(0, 0);\n    } else if (this.options.forceTo === 'bottom') {\n      window.scrollTo(0,document.body.scrollHeight);\n    }\n\n    if (this.options.transitionTime && this.options.transition !== 'overlap') {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);\n    } else {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');\n    }\n\n    this.$element.addClass('is-open').removeClass('is-closed');\n\n    this.$triggers.attr('aria-expanded', 'true');\n    this.$element.attr('aria-hidden', 'false');\n\n    this.$content.addClass('is-open-' + this.position);\n\n    // If `contentScroll` is set to false, add class and disable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);\n      this.$element.on('touchstart', this._recordScrollable);\n      this.$element.on('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-closable');\n    }\n\n    if (this.options.autoFocus === true) {\n      this.$element.one(transitionend(this.$element), function() {\n        if (!_this.$element.hasClass('is-open')) {\n          return; // exit if prematurely closed\n        }\n        var canvasFocus = _this.$element.find('[data-autofocus]');\n        if (canvasFocus.length) {\n            canvasFocus.eq(0).focus();\n        } else {\n            _this.$element.find('a, button').eq(0).focus();\n        }\n      });\n    }\n\n    if (this.options.trapFocus === true) {\n      this.$content.attr('tabindex', '-1');\n      Keyboard.trapFocus(this.$element);\n    }\n\n    this._addContentClasses();\n\n    /**\n     * Fires when the off-canvas menu opens.\n     * @event Offcanvas#opened\n     */\n    this.$element.trigger('opened.zf.offcanvas');\n  }\n\n  /**\n   * Closes the off-canvas menu.\n   * @function\n   * @param {Function} cb - optional cb to fire after closure.\n   * @fires Offcanvas#closed\n   */\n  close(cb) {\n    if (!this.$element.hasClass('is-open') || this.isRevealed) { return; }\n\n    var _this = this;\n\n    this.$element.removeClass('is-open');\n\n    this.$element.attr('aria-hidden', 'true')\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#closed\n       */\n        .trigger('closed.zf.offcanvas');\n\n    this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');\n\n    // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);\n      this.$element.off('touchstart', this._recordScrollable);\n      this.$element.off('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-closable');\n    }\n\n    this.$triggers.attr('aria-expanded', 'false');\n\n    if (this.options.trapFocus === true) {\n      this.$content.removeAttr('tabindex');\n      Keyboard.releaseFocus(this.$element);\n    }\n\n    // Listen to transitionEnd and add class when done.\n    this.$element.one(transitionend(this.$element), function(e) {\n      _this.$element.addClass('is-closed');\n      _this._removeContentClasses();\n    });\n  }\n\n  /**\n   * Toggles the off-canvas menu open or closed.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   */\n  toggle(event, trigger) {\n    if (this.$element.hasClass('is-open')) {\n      this.close(event, trigger);\n    }\n    else {\n      this.open(event, trigger);\n    }\n  }\n\n  /**\n   * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.\n   * @function\n   * @private\n   */\n  _handleKeyboard(e) {\n    Keyboard.handleKey(e, 'OffCanvas', {\n      close: () => {\n        this.close();\n        this.$lastTrigger.focus();\n        return true;\n      },\n      handled: () => {\n        e.stopPropagation();\n        e.preventDefault();\n      }\n    });\n  }\n\n  /**\n   * Destroys the offcanvas plugin.\n   * @function\n   */\n  _destroy() {\n    this.close();\n    this.$element.off('.zf.trigger .zf.offcanvas');\n    this.$overlay.off('.zf.offcanvas');\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\nOffCanvas.defaults = {\n  /**\n   * Allow the user to click outside of the menu to close it.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Adds an overlay on top of `[data-off-canvas-content]`.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentOverlay: true,\n\n  /**\n   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  contentId: null,\n\n  /**\n   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.\n   * @option\n   * @type {boolean}\n   * @default null\n   */\n  nested: null,\n\n  /**\n   * Enable/disable scrolling of the main content when an off canvas panel is open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentScroll: true,\n\n  /**\n   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.\n   * @option\n   * @type {number}\n   * @default null\n   */\n  transitionTime: null,\n\n  /**\n   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.\n   * @option\n   * @type {string}\n   * @default push\n   */\n  transition: 'push',\n\n  /**\n   * Force the page to scroll to top or bottom on open.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  forceTo: null,\n\n  /**\n   * Allow the offcanvas to remain open for certain breakpoints.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  isRevealed: false,\n\n  /**\n   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  revealOn: null,\n\n  /**\n   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoFocus: true,\n\n  /**\n   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.\n   * @option\n   * @type {string}\n   * @default reveal-for-\n   * @todo improve the regex testing for this.\n   */\n  revealClass: 'reveal-for-',\n\n  /**\n   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false\n}\n\nexport {OffCanvas};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Motion } from './foundation.util.motion';\nimport { Timer } from './foundation.util.timer';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { Touch } from './foundation.util.touch'\n\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timer\n * @requires foundation.util.imageLoader\n * @requires foundation.util.touch\n */\n\nclass Orbit extends Plugin {\n  /**\n  * Creates a new instance of an orbit carousel.\n  * @class\n  * @name Orbit\n  * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n  * @param {Object} options - Overrides to the default plugin settings.\n  */\n  _setup(element, options){\n    this.$element = element;\n    this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);\n    this.className = 'Orbit'; // ie9 back compat\n\n    Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.\n\n    this._init();\n\n    Keyboard.register('Orbit', {\n      'ltr': {\n        'ARROW_RIGHT': 'next',\n        'ARROW_LEFT': 'previous'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'next',\n        'ARROW_RIGHT': 'previous'\n      }\n    });\n  }\n\n  /**\n  * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.\n  * @function\n  * @private\n  */\n  _init() {\n    // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide\n    this._reset();\n\n    this.$wrapper = this.$element.find(`.${this.options.containerClass}`);\n    this.$slides = this.$element.find(`.${this.options.slideClass}`);\n\n    var $images = this.$element.find('img'),\n        initActive = this.$slides.filter('.is-active'),\n        id = this.$element[0].id || GetYoDigits(6, 'orbit');\n\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    if (!initActive.length) {\n      this.$slides.eq(0).addClass('is-active');\n    }\n\n    if (!this.options.useMUI) {\n      this.$slides.addClass('no-motionui');\n    }\n\n    if ($images.length) {\n      onImagesLoaded($images, this._prepareForOrbit.bind(this));\n    } else {\n      this._prepareForOrbit();//hehe\n    }\n\n    if (this.options.bullets) {\n      this._loadBullets();\n    }\n\n    this._events();\n\n    if (this.options.autoPlay && this.$slides.length > 1) {\n      this.geoSync();\n    }\n\n    if (this.options.accessible) { // allow wrapper to be focusable to enable arrow navigation\n      this.$wrapper.attr('tabindex', 0);\n    }\n  }\n\n  /**\n  * Creates a jQuery collection of bullets, if they are being used.\n  * @function\n  * @private\n  */\n  _loadBullets() {\n    this.$bullets = this.$element.find(`.${this.options.boxOfBullets}`).find('button');\n  }\n\n  /**\n  * Sets a `timer` object on the orbit, and starts the counter for the next slide.\n  * @function\n  */\n  geoSync() {\n    var _this = this;\n    this.timer = new Timer(\n      this.$element,\n      {\n        duration: this.options.timerDelay,\n        infinite: false\n      },\n      function() {\n        _this.changeSlide(true);\n      });\n    this.timer.start();\n  }\n\n  /**\n  * Sets wrapper and slide heights for the orbit.\n  * @function\n  * @private\n  */\n  _prepareForOrbit() {\n    var _this = this;\n    this._setWrapperHeight();\n  }\n\n  /**\n  * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.\n  * @function\n  * @private\n  * @param {Function} cb - a callback function to fire when complete.\n  */\n  _setWrapperHeight(cb) {//rewrite this to `for` loop\n    var max = 0, temp, counter = 0, _this = this;\n\n    this.$slides.each(function() {\n      temp = this.getBoundingClientRect().height;\n      $(this).attr('data-slide', counter);\n\n      // hide all slides but the active one\n      if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {\n        $(this).css({'display': 'none'});\n      }\n      max = temp > max ? temp : max;\n      counter++;\n    });\n\n    if (counter === this.$slides.length) {\n      this.$wrapper.css({'height': max}); //only change the wrapper height property once.\n      if(cb) {cb(max);} //fire callback with max height dimension.\n    }\n  }\n\n  /**\n  * Sets the max-height of each slide.\n  * @function\n  * @private\n  */\n  _setSlideHeight(height) {\n    this.$slides.each(function() {\n      $(this).css('max-height', height);\n    });\n  }\n\n  /**\n  * Adds event listeners to basically everything within the element.\n  * @function\n  * @private\n  */\n  _events() {\n    var _this = this;\n\n    //***************************************\n    //**Now using custom event - thanks to:**\n    //**      Yohai Ararat of Toronto      **\n    //***************************************\n    //\n    this.$element.off('.resizeme.zf.trigger').on({\n      'resizeme.zf.trigger': this._prepareForOrbit.bind(this)\n    })\n    if (this.$slides.length > 1) {\n\n      if (this.options.swipe) {\n        this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit')\n        .on('swipeleft.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(true);\n        }).on('swiperight.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(false);\n        });\n      }\n      //***************************************\n\n      if (this.options.autoPlay) {\n        this.$slides.on('click.zf.orbit', function() {\n          _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);\n          _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();\n        });\n\n        if (this.options.pauseOnHover) {\n          this.$element.on('mouseenter.zf.orbit', function() {\n            _this.timer.pause();\n          }).on('mouseleave.zf.orbit', function() {\n            if (!_this.$element.data('clickedOn')) {\n              _this.timer.start();\n            }\n          });\n        }\n      }\n\n      if (this.options.navButtons) {\n        var $controls = this.$element.find(`.${this.options.nextClass}, .${this.options.prevClass}`);\n        $controls.attr('tabindex', 0)\n        //also need to handle enter/return and spacebar key presses\n        .on('click.zf.orbit touchend.zf.orbit', function(e){\n\t  e.preventDefault();\n          _this.changeSlide($(this).hasClass(_this.options.nextClass));\n        });\n      }\n\n      if (this.options.bullets) {\n        this.$bullets.on('click.zf.orbit touchend.zf.orbit', function() {\n          if (/is-active/g.test(this.className)) { return false; }//if this is active, kick out of function.\n          var idx = $(this).data('slide'),\n          ltr = idx > _this.$slides.filter('.is-active').data('slide'),\n          $slide = _this.$slides.eq(idx);\n\n          _this.changeSlide(ltr, $slide, idx);\n        });\n      }\n\n      if (this.options.accessible) {\n        this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function(e) {\n          // handle keyboard event with keyboard util\n          Keyboard.handleKey(e, 'Orbit', {\n            next: function() {\n              _this.changeSlide(true);\n            },\n            previous: function() {\n              _this.changeSlide(false);\n            },\n            handled: function() { // if bullet is focused, make sure focus moves\n              if ($(e.target).is(_this.$bullets)) {\n                _this.$bullets.filter('.is-active').focus();\n              }\n            }\n          });\n        });\n      }\n    }\n  }\n\n  /**\n   * Resets Orbit so it can be reinitialized\n   */\n  _reset() {\n    // Don't do anything if there are no slides (first run)\n    if (typeof this.$slides == 'undefined') {\n      return;\n    }\n\n    if (this.$slides.length > 1) {\n      // Remove old events\n      this.$element.off('.zf.orbit').find('*').off('.zf.orbit')\n\n      // Restart timer if autoPlay is enabled\n      if (this.options.autoPlay) {\n        this.timer.restart();\n      }\n\n      // Reset all sliddes\n      this.$slides.each(function(el) {\n        $(el).removeClass('is-active is-active is-in')\n          .removeAttr('aria-live')\n          .hide();\n      });\n\n      // Show the first slide\n      this.$slides.first().addClass('is-active').show();\n\n      // Triggers when the slide has finished animating\n      this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);\n\n      // Select first bullet if bullets are present\n      if (this.options.bullets) {\n        this._updateBullets(0);\n      }\n    }\n  }\n\n  /**\n  * Changes the current slide to a new one.\n  * @function\n  * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.\n  * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.\n  * @param {Number} idx - the index of the new slide in its collection, if one chosen.\n  * @fires Orbit#slidechange\n  */\n  changeSlide(isLTR, chosenSlide, idx) {\n    if (!this.$slides) {return; } // Don't freak out if we're in the middle of cleanup\n    var $curSlide = this.$slides.filter('.is-active').eq(0);\n\n    if (/mui/g.test($curSlide[0].className)) { return false; } //if the slide is currently animating, kick out of the function\n\n    var $firstSlide = this.$slides.first(),\n    $lastSlide = this.$slides.last(),\n    dirIn = isLTR ? 'Right' : 'Left',\n    dirOut = isLTR ? 'Left' : 'Right',\n    _this = this,\n    $newSlide;\n\n    if (!chosenSlide) { //most of the time, this will be auto played or clicked from the navButtons.\n      $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!\n      (this.options.infiniteWrap ? $curSlide.next(`.${this.options.slideClass}`).length ? $curSlide.next(`.${this.options.slideClass}`) : $firstSlide : $curSlide.next(`.${this.options.slideClass}`))//pick next slide if moving left to right\n      :\n      (this.options.infiniteWrap ? $curSlide.prev(`.${this.options.slideClass}`).length ? $curSlide.prev(`.${this.options.slideClass}`) : $lastSlide : $curSlide.prev(`.${this.options.slideClass}`));//pick prev slide if moving right to left\n    } else {\n      $newSlide = chosenSlide;\n    }\n\n    if ($newSlide.length) {\n      /**\n      * Triggers before the next slide starts animating in and only if a next slide has been found.\n      * @event Orbit#beforeslidechange\n      */\n      this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);\n\n      if (this.options.bullets) {\n        idx = idx || this.$slides.index($newSlide); //grab index to update bullets\n        this._updateBullets(idx);\n      }\n\n      if (this.options.useMUI && !this.$element.is(':hidden')) {\n        Motion.animateIn(\n          $newSlide.addClass('is-active'),\n          this.options[`animInFrom${dirIn}`],\n          function(){\n            $newSlide.css({'display': 'block'}).attr('aria-live', 'polite');\n        });\n\n        Motion.animateOut(\n          $curSlide.removeClass('is-active'),\n          this.options[`animOutTo${dirOut}`],\n          function(){\n            $curSlide.removeAttr('aria-live');\n            if(_this.options.autoPlay && !_this.timer.isPaused){\n              _this.timer.restart();\n            }\n            //do stuff?\n          });\n      } else {\n        $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();\n        $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();\n        if (this.options.autoPlay && !this.timer.isPaused) {\n          this.timer.restart();\n        }\n      }\n    /**\n    * Triggers when the slide has finished animating in.\n    * @event Orbit#slidechange\n    */\n      this.$element.trigger('slidechange.zf.orbit', [$newSlide]);\n    }\n  }\n\n  /**\n  * Updates the active state of the bullets, if displayed.\n  * @function\n  * @private\n  * @param {Number} idx - the index of the current slide.\n  */\n  _updateBullets(idx) {\n    var $oldBullet = this.$element.find(`.${this.options.boxOfBullets}`)\n    .find('.is-active').removeClass('is-active').blur(),\n    span = $oldBullet.find('span:last').detach(),\n    $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);\n  }\n\n  /**\n  * Destroys the carousel and hides the element.\n  * @function\n  */\n  _destroy() {\n    this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();\n  }\n}\n\nOrbit.defaults = {\n  /**\n  * Tells the JS to look for and loadBullets.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  bullets: true,\n  /**\n  * Tells the JS to apply event listeners to nav buttons\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  navButtons: true,\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-right'\n  */\n  animInFromRight: 'slide-in-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-right'\n  */\n  animOutToRight: 'slide-out-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-left'\n  *\n  */\n  animInFromLeft: 'slide-in-left',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-left'\n  */\n  animOutToLeft: 'slide-out-left',\n  /**\n  * Allows Orbit to automatically animate on page load.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  autoPlay: true,\n  /**\n  * Amount of time, in ms, between slide transitions\n  * @option\n   * @type {number}\n  * @default 5000\n  */\n  timerDelay: 5000,\n  /**\n  * Allows Orbit to infinitely loop through the slides\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  infiniteWrap: true,\n  /**\n  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  swipe: true,\n  /**\n  * Allows the timing function to pause animation on hover.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  pauseOnHover: true,\n  /**\n  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  accessible: true,\n  /**\n  * Class applied to the container of Orbit\n  * @option\n   * @type {string}\n  * @default 'orbit-container'\n  */\n  containerClass: 'orbit-container',\n  /**\n  * Class applied to individual slides.\n  * @option\n   * @type {string}\n  * @default 'orbit-slide'\n  */\n  slideClass: 'orbit-slide',\n  /**\n  * Class applied to the bullet container. You're welcome.\n  * @option\n   * @type {string}\n  * @default 'orbit-bullets'\n  */\n  boxOfBullets: 'orbit-bullets',\n  /**\n  * Class applied to the `next` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-next'\n  */\n  nextClass: 'orbit-next',\n  /**\n  * Class applied to the `previous` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-previous'\n  */\n  prevClass: 'orbit-previous',\n  /**\n  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  useMUI: true\n};\n\nexport {Orbit};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { DropdownMenu } from './foundation.dropdownMenu';\nimport { Drilldown } from './foundation.drilldown';\nimport { AccordionMenu } from './foundation.accordionMenu';\n\nlet MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: DropdownMenu\n  },\n drilldown: {\n    cssClass: 'drilldown',\n    plugin: Drilldown\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: AccordionMenu\n  }\n};\n\n  // import \"foundation.util.triggers.js\";\n\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveMenu extends Plugin {\n  /**\n   * Creates a new instance of a responsive menu.\n   * @class\n   * @name ResponsiveMenu\n   * @fires ResponsiveMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.rules = this.$element.data('responsive-menu');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveMenu'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n\n    MediaQuery._init();\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n    // Add data-mutate since children may need it.\n    this.$element.attr('data-mutate', (this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')));\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    $(window).on('changed.zf.mediaquery', function() {\n      _this._checkMediaQueries();\n    });\n    // $(window).on('resize.zf.ResponsiveMenu', function() {\n    //   _this._checkMediaQueries();\n    // });\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    this.currentPlugin.destroy();\n    $(window).off('.zf.ResponsiveMenu');\n  }\n}\n\nResponsiveMenu.defaults = {};\n\nexport {ResponsiveMenu};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion\n */\n\nclass ResponsiveToggle extends Plugin {\n  /**\n   * Creates a new instance of Tab Bar.\n   * @class\n   * @name ResponsiveToggle\n   * @fires ResponsiveToggle#init\n   * @param {jQuery} element - jQuery object to attach tab bar functionality to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n    this.className = 'ResponsiveToggle'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the tab bar by finding the target element, toggling element, and running update().\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var targetID = this.$element.data('responsive-toggle');\n    if (!targetID) {\n      console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');\n    }\n\n    this.$targetMenu = $(`#${targetID}`);\n    this.$toggler = this.$element.find('[data-toggle]').filter(function() {\n      var target = $(this).data('toggle');\n      return (target === targetID || target === \"\");\n    });\n    this.options = $.extend({}, this.options, this.$targetMenu.data());\n\n    // If they were set, parse the animation classes\n    if(this.options.animate) {\n      let input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n\n    this._update();\n  }\n\n  /**\n   * Adds necessary event handlers for the tab bar to work.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this._updateMqHandler = this._update.bind(this);\n\n    $(window).on('changed.zf.mediaquery', this._updateMqHandler);\n\n    this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));\n  }\n\n  /**\n   * Checks the current media query to determine if the tab bar should be visible or hidden.\n   * @function\n   * @private\n   */\n  _update() {\n    // Mobile\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      this.$element.show();\n      this.$targetMenu.hide();\n    }\n\n    // Desktop\n    else {\n      this.$element.hide();\n      this.$targetMenu.show();\n    }\n  }\n\n  /**\n   * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.\n   * @function\n   * @fires ResponsiveToggle#toggled\n   */\n  toggleMenu() {\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      /**\n       * Fires when the element attached to the tab bar toggles.\n       * @event ResponsiveToggle#toggled\n       */\n      if(this.options.animate) {\n        if (this.$targetMenu.is(':hidden')) {\n          Motion.animateIn(this.$targetMenu, this.animationIn, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n            this.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');\n          });\n        }\n        else {\n          Motion.animateOut(this.$targetMenu, this.animationOut, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n          });\n        }\n      }\n      else {\n        this.$targetMenu.toggle(0);\n        this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        this.$element.trigger('toggled.zf.responsiveToggle');\n      }\n    }\n  };\n\n  _destroy() {\n    this.$element.off('.zf.responsiveToggle');\n    this.$toggler.off('.zf.responsiveToggle');\n\n    $(window).off('changed.zf.mediaquery', this._updateMqHandler);\n  }\n}\n\nResponsiveToggle.defaults = {\n  /**\n   * The breakpoint after which the menu is always shown, and the tab bar is hidden.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  hideFor: 'medium',\n\n  /**\n   * To decide if the toggle should be animated or not.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport { ResponsiveToggle };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nclass Reveal extends Plugin {\n  /**\n   * Creates a new instance of Reveal.\n   * @class\n   * @name Reveal\n   * @param {jQuery} element - jQuery object to use for the modal.\n   * @param {Object} options - optional parameters.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);\n    this.className = 'Reveal'; // ie9 back compat\n    this._init();\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    Keyboard.register('Reveal', {\n      'ESCAPE': 'close',\n    });\n  }\n\n  /**\n   * Initializes the modal by adding the overlay and close buttons, (if selected).\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    this.id = this.$element.attr('id');\n    this.isActive = false;\n    this.cached = {mq: MediaQuery.current};\n\n    this.$anchor = $(`[data-open=\"${this.id}\"]`).length ? $(`[data-open=\"${this.id}\"]`) : $(`[data-toggle=\"${this.id}\"]`);\n    this.$anchor.attr({\n      'aria-controls': this.id,\n      'aria-haspopup': true,\n      'tabindex': 0\n    });\n\n    if (this.options.fullScreen || this.$element.hasClass('full')) {\n      this.options.fullScreen = true;\n      this.options.overlay = false;\n    }\n    if (this.options.overlay && !this.$overlay) {\n      this.$overlay = this._makeOverlay(this.id);\n    }\n\n    this.$element.attr({\n        'role': 'dialog',\n        'aria-hidden': true,\n        'data-yeti-box': this.id,\n        'data-resize': this.id\n    });\n\n    if(this.$overlay) {\n      this.$element.detach().appendTo(this.$overlay);\n    } else {\n      this.$element.detach().appendTo($(this.options.appendTo));\n      this.$element.addClass('without-overlay');\n    }\n    this._events();\n    if (this.options.deepLink && window.location.hash === ( `#${this.id}`)) {\n      this.onLoadListener = onLoad($(window), () => this.open());\n    }\n  }\n\n  /**\n   * Creates an overlay div to display behind the modal.\n   * @private\n   */\n  _makeOverlay() {\n    var additionalOverlayClasses = '';\n\n    if (this.options.additionalOverlayClasses) {\n      additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;\n    }\n\n    return $('<div></div>')\n      .addClass('reveal-overlay' + additionalOverlayClasses)\n      .appendTo(this.options.appendTo);\n  }\n\n  /**\n   * Updates position of modal\n   * TODO:  Figure out if we actually need to cache these values or if it doesn't matter\n   * @private\n   */\n  _updatePosition() {\n    var width = this.$element.outerWidth();\n    var outerWidth = $(window).width();\n    var height = this.$element.outerHeight();\n    var outerHeight = $(window).height();\n    var left, top = null;\n    if (this.options.hOffset === 'auto') {\n      left = parseInt((outerWidth - width) / 2, 10);\n    } else {\n      left = parseInt(this.options.hOffset, 10);\n    }\n    if (this.options.vOffset === 'auto') {\n      if (height > outerHeight) {\n        top = parseInt(Math.min(100, outerHeight / 10), 10);\n      } else {\n        top = parseInt((outerHeight - height) / 4, 10);\n      }\n    } else if (this.options.vOffset !== null) {\n      top = parseInt(this.options.vOffset, 10);\n    }\n\n    if (top !== null) {\n      this.$element.css({top: top + 'px'});\n    }\n\n    // only worry about left if we don't have an overlay or we have a horizontal offset,\n    // otherwise we're perfectly in the middle\n    if (!this.$overlay || (this.options.hOffset !== 'auto')) {\n      this.$element.css({left: left + 'px'});\n      this.$element.css({margin: '0px'});\n    }\n\n  }\n\n  /**\n   * Adds event handlers for the modal.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': (event, $element) => {\n        if ((event.target === _this.$element[0]) ||\n            ($(event.target).parents('[data-closable]')[0] === $element)) { // only close reveal when it's explicitly called\n          return this.close.apply(this);\n        }\n      },\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': function() {\n        _this._updatePosition();\n      }\n    });\n\n    if (this.options.closeOnClick && this.options.overlay) {\n      this.$overlay.off('.zf.reveal').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) {\n              return;\n        }\n        _this.close();\n      });\n    }\n    if (this.options.deepLink) {\n      $(window).on(`hashchange.zf.reveal:${this.id}`, this._handleState.bind(this));\n    }\n  }\n\n  /**\n   * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.\n   * @private\n   */\n  _handleState(e) {\n    if(window.location.hash === ( '#' + this.id) && !this.isActive){ this.open(); }\n    else{ this.close(); }\n  }\n\n  /**\n  * Disables the scroll when Reveal is shown to prevent the background from shifting\n  * @param {number} scrollTop - Scroll to visually apply, window current scroll by default\n  */\n  _disableScroll(scrollTop) {\n    scrollTop = scrollTop || $(window).scrollTop();\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", -scrollTop);\n    }\n  }\n\n  /**\n  * Reenables the scroll when Reveal closes\n  * @param {number} scrollTop - Scroll to restore, html \"top\" property by default (as set by `_disableScroll`)\n  */\n  _enableScroll(scrollTop) {\n    scrollTop = scrollTop || parseInt($(\"html\").css(\"top\"));\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", \"\");\n      $(window).scrollTop(-scrollTop);\n    }\n  }\n\n\n  /**\n   * Opens the modal controlled by `this.$anchor`, and closes all others by default.\n   * @function\n   * @fires Reveal#closeme\n   * @fires Reveal#open\n   */\n  open() {\n    // either update or replace browser history\n    const hash = `#${this.id}`;\n    if (this.options.deepLink && window.location.hash !== hash) {\n\n      if (window.history.pushState) {\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', hash);\n        } else {\n          window.history.replaceState({}, '', hash);\n        }\n      } else {\n        window.location.hash = hash;\n      }\n    }\n\n    // Remember anchor that opened it to set focus back later, have general anchors as fallback\n    this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;\n\n    this.isActive = true;\n\n    // Make elements invisible, but remove display: none so we can get size and positioning\n    this.$element\n        .css({ 'visibility': 'hidden' })\n        .show()\n        .scrollTop(0);\n    if (this.options.overlay) {\n      this.$overlay.css({'visibility': 'hidden'}).show();\n    }\n\n    this._updatePosition();\n\n    this.$element\n      .hide()\n      .css({ 'visibility': '' });\n\n    if(this.$overlay) {\n      this.$overlay.css({'visibility': ''}).hide();\n      if(this.$element.hasClass('fast')) {\n        this.$overlay.addClass('fast');\n      } else if (this.$element.hasClass('slow')) {\n        this.$overlay.addClass('slow');\n      }\n    }\n\n\n    if (!this.options.multipleOpened) {\n      /**\n       * Fires immediately before the modal opens.\n       * Closes any other modals that are currently open\n       * @event Reveal#closeme\n       */\n      this.$element.trigger('closeme.zf.reveal', this.id);\n    }\n\n    this._disableScroll();\n\n    var _this = this;\n\n    // Motion UI method of reveal\n    if (this.options.animationIn) {\n      function afterAnimation(){\n        _this.$element\n          .attr({\n            'aria-hidden': false,\n            'tabindex': -1\n          })\n          .focus();\n        _this._addGlobalClasses();\n        Keyboard.trapFocus(_this.$element);\n      }\n      if (this.options.overlay) {\n        Motion.animateIn(this.$overlay, 'fade-in');\n      }\n      Motion.animateIn(this.$element, this.options.animationIn, () => {\n        if(this.$element) { // protect against object having been removed\n          this.focusableElements = Keyboard.findFocusable(this.$element);\n          afterAnimation();\n        }\n      });\n    }\n    // jQuery method of reveal\n    else {\n      if (this.options.overlay) {\n        this.$overlay.show(0);\n      }\n      this.$element.show(this.options.showDelay);\n    }\n\n    // handle accessibility\n    this.$element\n      .attr({\n        'aria-hidden': false,\n        'tabindex': -1\n      })\n      .focus();\n    Keyboard.trapFocus(this.$element);\n\n    this._addGlobalClasses();\n\n    this._addGlobalListeners();\n\n    /**\n     * Fires when the modal has successfully opened.\n     * @event Reveal#open\n     */\n    this.$element.trigger('open.zf.reveal');\n  }\n\n  /**\n   * Adds classes and listeners on document required by open modals.\n   *\n   * The following classes are added and updated:\n   * - `.is-reveal-open` - Prevents the scroll on document\n   * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the\n   *                       scroll was not disabled. This prevent a \"shift\" of the page content due\n   *                       the scrollbar disappearing when the modal opens.\n   *\n   * @private\n   */\n  _addGlobalClasses() {\n    const updateScrollbarClass = () => {\n      $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));\n    };\n\n    this.$element.on('resizeme.zf.trigger.revealScrollbarListener', () => updateScrollbarClass());\n    updateScrollbarClass();\n    $('html').addClass('is-reveal-open');\n  }\n\n  /**\n   * Removes classes and listeners on document that were required by open modals.\n   * @private\n   */\n  _removeGlobalClasses() {\n    this.$element.off('resizeme.zf.trigger.revealScrollbarListener');\n    $('html').removeClass('is-reveal-open');\n    $('html').removeClass('zf-has-scroll');\n  }\n\n  /**\n   * Adds extra event handlers for the body and window if necessary.\n   * @private\n   */\n  _addGlobalListeners() {\n    var _this = this;\n    if(!this.$element) { return; } // If we're in the middle of cleanup, don't freak out\n    this.focusableElements = Keyboard.findFocusable(this.$element);\n\n    if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {\n      $('body').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) { return; }\n        _this.close();\n      });\n    }\n\n    if (this.options.closeOnEsc) {\n      $(window).on('keydown.zf.reveal', function(e) {\n        Keyboard.handleKey(e, 'Reveal', {\n          close: function() {\n            if (_this.options.closeOnEsc) {\n              _this.close();\n            }\n          }\n        });\n      });\n    }\n  }\n\n  /**\n   * Closes the modal.\n   * @function\n   * @fires Reveal#closed\n   */\n  close() {\n    if (!this.isActive || !this.$element.is(':visible')) {\n      return false;\n    }\n    var _this = this;\n\n    // Motion UI method of hiding\n    if (this.options.animationOut) {\n      if (this.options.overlay) {\n        Motion.animateOut(this.$overlay, 'fade-out');\n      }\n\n      Motion.animateOut(this.$element, this.options.animationOut, finishUp);\n    }\n    // jQuery method of hiding\n    else {\n      this.$element.hide(this.options.hideDelay);\n\n      if (this.options.overlay) {\n        this.$overlay.hide(0, finishUp);\n      }\n      else {\n        finishUp();\n      }\n    }\n\n    // Conditionals to remove extra event listeners added on open\n    if (this.options.closeOnEsc) {\n      $(window).off('keydown.zf.reveal');\n    }\n\n    if (!this.options.overlay && this.options.closeOnClick) {\n      $('body').off('click.zf.reveal');\n    }\n\n    this.$element.off('keydown.zf.reveal');\n\n    function finishUp() {\n\n      // Get the current top before the modal is closed and restore the scroll after.\n      // TODO: use component properties instead of HTML properties\n      // See https://github.com/zurb/foundation-sites/pull/10786\n      var scrollTop = parseInt($(\"html\").css(\"top\"));\n\n      if ($('.reveal:visible').length  === 0) {\n        _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n      }\n\n      Keyboard.releaseFocus(_this.$element);\n\n      _this.$element.attr('aria-hidden', true);\n\n      _this._enableScroll(scrollTop);\n\n      /**\n      * Fires when the modal is done closing.\n      * @event Reveal#closed\n      */\n      _this.$element.trigger('closed.zf.reveal');\n    }\n\n    /**\n    * Resets the modal content\n    * This prevents a running video to keep going in the background\n    */\n    if (this.options.resetOnClose) {\n      this.$element.html(this.$element.html());\n    }\n\n    this.isActive = false;\n    // If deepLink and we did not switched to an other modal...\n    if (_this.options.deepLink && window.location.hash === `#${this.id}`) {\n      // Remove the history hash\n      if (window.history.replaceState) {\n        const urlWithoutHash = window.location.pathname + window.location.search;\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', urlWithoutHash); // remove the hash\n        } else {\n          window.history.replaceState('', document.title, urlWithoutHash);\n        }\n      } else {\n        window.location.hash = '';\n      }\n    }\n\n    this.$activeAnchor.focus();\n  }\n\n  /**\n   * Toggles the open/closed state of a modal.\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.close();\n    } else {\n      this.open();\n    }\n  };\n\n  /**\n   * Destroys an instance of a modal.\n   * @function\n   */\n  _destroy() {\n    if (this.options.overlay) {\n      this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()\n      this.$overlay.hide().off().remove();\n    }\n    this.$element.hide().off();\n    this.$anchor.off('.zf');\n    $(window).off(`.zf.reveal:${this.id}`)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n\n    if ($('.reveal:visible').length  === 0) {\n      this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n    }\n  };\n}\n\nReveal.defaults = {\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationIn: '',\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationOut: '',\n  /**\n   * Time, in ms, to delay the opening of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  showDelay: 0,\n  /**\n   * Time, in ms, to delay the closing of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hideDelay: 0,\n  /**\n   * Allows a click on the body/overlay to close the modal.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allows the modal to close if the user presses the `ESCAPE` key.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnEsc: true,\n  /**\n   * If true, allows multiple modals to be displayed at once.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multipleOpened: false,\n  /**\n   * Distance, in pixels, the modal should push down from the top of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  vOffset: 'auto',\n  /**\n   * Distance, in pixels, the modal should push in from the side of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  hOffset: 'auto',\n  /**\n   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  fullScreen: false,\n  /**\n   * Allows the modal to generate an overlay div, which will cover the view when modal opens.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  overlay: true,\n  /**\n   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  resetOnClose: false,\n  /**\n   * Link the location hash to the modal.\n   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open modal\n   * @option\n   * @default false\n   */\n  updateHistory: false,\n    /**\n   * Allows the modal to append to custom div.\n   * @option\n   * @type {string}\n   * @default \"body\"\n   */\n  appendTo: \"body\",\n  /**\n   * Allows adding additional class names to the reveal overlay.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  additionalOverlayClasses: ''\n};\n\nexport {Reveal};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Move } from './foundation.util.motion';\nimport { GetYoDigits, rtl as Rtl } from './foundation.core.utils';\n\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Touch } from './foundation.util.touch';\n\nimport { Triggers } from './foundation.util.triggers';\n/**\n * Slider module.\n * @module foundation.slider\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n */\n\nclass Slider extends Plugin {\n  /**\n   * Creates a new instance of a slider control.\n   * @class\n   * @name Slider\n   * @param {jQuery} element - jQuery object to make into a slider control.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Slider.defaults, this.$element.data(), options);\n    this.className = 'Slider'; // ie9 back compat\n\n  // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.\n    Touch.init($);\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Slider', {\n      'ltr': {\n        'ARROW_RIGHT': 'increase',\n        'ARROW_UP': 'increase',\n        'ARROW_DOWN': 'decrease',\n        'ARROW_LEFT': 'decrease',\n        'SHIFT_ARROW_RIGHT': 'increase_fast',\n        'SHIFT_ARROW_UP': 'increase_fast',\n        'SHIFT_ARROW_DOWN': 'decrease_fast',\n        'SHIFT_ARROW_LEFT': 'decrease_fast',\n        'HOME': 'min',\n        'END': 'max'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'increase',\n        'ARROW_RIGHT': 'decrease',\n        'SHIFT_ARROW_LEFT': 'increase_fast',\n        'SHIFT_ARROW_RIGHT': 'decrease_fast'\n      }\n    });\n  }\n\n  /**\n   * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).\n   * @function\n   * @private\n   */\n  _init() {\n    this.inputs = this.$element.find('input');\n    this.handles = this.$element.find('[data-slider-handle]');\n\n    this.$handle = this.handles.eq(0);\n    this.$input = this.inputs.length ? this.inputs.eq(0) : $(`#${this.$handle.attr('aria-controls')}`);\n    this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);\n\n    var isDbl = false,\n        _this = this;\n    if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {\n      this.options.disabled = true;\n      this.$element.addClass(this.options.disabledClass);\n    }\n    if (!this.inputs.length) {\n      this.inputs = $().add(this.$input);\n      this.options.binding = true;\n    }\n\n    this._setInitAttr(0);\n\n    if (this.handles[1]) {\n      this.options.doubleSided = true;\n      this.$handle2 = this.handles.eq(1);\n      this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $(`#${this.$handle2.attr('aria-controls')}`);\n\n      if (!this.inputs[1]) {\n        this.inputs = this.inputs.add(this.$input2);\n      }\n      isDbl = true;\n\n      // this.$handle.triggerHandler('click.zf.slider');\n      this._setInitAttr(1);\n    }\n\n    // Set handle positions\n    this.setHandles();\n\n    this._events();\n  }\n\n  setHandles() {\n    if(this.handles[1]) {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, () => {\n        this._setHandlePos(this.$handle2, this.inputs.eq(1).val(), true);\n      });\n    } else {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);\n    }\n  }\n\n  _reflow() {\n    this.setHandles();\n  }\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)\n  */\n  _pctOfBar(value) {\n    var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start)\n\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    }\n\n    return pctOfBar.toFixed(2)\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value\n  */\n  _value(pctOfBar) {\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    }\n    var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);\n\n    return value\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function\n  */\n  _logTransform(value) {\n    return baseLog(this.options.nonLinearBase, ((value*(this.options.nonLinearBase-1))+1))\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function\n  */\n  _powTransform(value) {\n    return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1)\n  }\n\n  /**\n   * Sets the position of the selected handle and fill bar.\n   * @function\n   * @private\n   * @param {jQuery} $hndl - the selected handle to move.\n   * @param {Number} location - floating point between the start and end values of the slider bar.\n   * @param {Function} cb - callback function to fire on completion.\n   * @fires Slider#moved\n   * @fires Slider#changed\n   */\n  _setHandlePos($hndl, location, noInvert, cb) {\n    // don't move if the slider has been disabled since its initialization\n    if (this.$element.hasClass(this.options.disabledClass)) {\n      return;\n    }\n    //might need to alter that slightly for bars that will have odd number selections.\n    location = parseFloat(location);//on input change events, convert string to number...grumble.\n\n    // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max\n    if (location < this.options.start) { location = this.options.start; }\n    else if (location > this.options.end) { location = this.options.end; }\n\n    var isDbl = this.options.doubleSided;\n\n    //this is for single-handled vertical sliders, it adjusts the value to account for the slider being \"upside-down\"\n    //for click and drag events, it's weird due to the scale(-1, 1) css property\n    if (this.options.vertical && !noInvert) {\n      location = this.options.end - location;\n    }\n\n    if (isDbl) { //this block is to prevent 2 handles from crossing eachother. Could/should be improved.\n      if (this.handles.index($hndl) === 0) {\n        var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));\n        location = location >= h2Val ? h2Val - this.options.step : location;\n      } else {\n        var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));\n        location = location <= h1Val ? h1Val + this.options.step : location;\n      }\n    }\n\n    var _this = this,\n        vert = this.options.vertical,\n        hOrW = vert ? 'height' : 'width',\n        lOrT = vert ? 'top' : 'left',\n        handleDim = $hndl[0].getBoundingClientRect()[hOrW],\n        elemDim = this.$element[0].getBoundingClientRect()[hOrW],\n        //percentage of bar min/max value based on click or drag point\n        pctOfBar = this._pctOfBar(location),\n        //number of actual pixels to shift the handle, based on the percentage obtained above\n        pxToMove = (elemDim - handleDim) * pctOfBar,\n        //percentage of bar to shift the handle\n        movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);\n        //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value\n        location = parseFloat(location.toFixed(this.options.decimal));\n        // declare empty object for css adjustments, only used with 2 handled-sliders\n    var css = {};\n\n    this._setValues($hndl, location);\n\n    // TODO update to calculate based on values set to respective inputs??\n    if (isDbl) {\n      var isLeftHndl = this.handles.index($hndl) === 0,\n          //empty variable, will be used for min-height/width for fill bar\n          dim,\n          //percentage w/h of the handle compared to the slider bar\n          handlePct =  ~~(percent(handleDim, elemDim) * 100);\n      //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar\n      if (isLeftHndl) {\n        //left or top percentage value to apply to the fill bar.\n        css[lOrT] = `${movement}%`;\n        //calculate the new min-height/width for the fill bar.\n        dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;\n        //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider\n        //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.\n        if (cb && typeof cb === 'function') { cb(); }//this is only needed for the initialization of 2 handled sliders\n      } else {\n        //just caching the value of the left/bottom handle's left/top property\n        var handlePos = parseFloat(this.$handle[0].style[lOrT]);\n        //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0\n        //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself\n        dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start)/((this.options.end-this.options.start)/100) : handlePos) + handlePct;\n      }\n      // assign the min-height/width to our css object\n      css[`min-${hOrW}`] = `${dim}%`;\n    }\n\n    this.$element.one('finished.zf.animate', function() {\n                    /**\n                     * Fires when the handle is done moving.\n                     * @event Slider#moved\n                     */\n                    _this.$element.trigger('moved.zf.slider', [$hndl]);\n                });\n\n    //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.\n    var moveTime = this.$element.data('dragging') ? 1000/60 : this.options.moveTime;\n\n    Move(moveTime, $hndl, function() {\n      // adjusting the left/top property of the handle, based on the percentage calculated above\n      // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,\n      // fall back to next best guess.\n      if (isNaN(movement)) {\n        $hndl.css(lOrT, `${pctOfBar * 100}%`);\n      }\n      else {\n        $hndl.css(lOrT, `${movement}%`);\n      }\n\n      if (!_this.options.doubleSided) {\n        //if single-handled, a simple method to expand the fill bar\n        _this.$fill.css(hOrW, `${pctOfBar * 100}%`);\n      } else {\n        //otherwise, use the css object we created above\n        _this.$fill.css(css);\n      }\n    });\n\n\n    /**\n     * Fires when the value has not been change for a given time.\n     * @event Slider#changed\n     */\n    clearTimeout(_this.timeout);\n    _this.timeout = setTimeout(function(){\n      _this.$element.trigger('changed.zf.slider', [$hndl]);\n    }, _this.options.changedDelay);\n  }\n\n  /**\n   * Sets the initial attribute for the slider element.\n   * @function\n   * @private\n   * @param {Number} idx - index of the current handle/input to use.\n   */\n  _setInitAttr(idx) {\n    var initVal = (idx === 0 ? this.options.initialStart : this.options.initialEnd)\n    var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');\n    this.inputs.eq(idx).attr({\n      'id': id,\n      'max': this.options.end,\n      'min': this.options.start,\n      'step': this.options.step\n    });\n    this.inputs.eq(idx).val(initVal);\n    this.handles.eq(idx).attr({\n      'role': 'slider',\n      'aria-controls': id,\n      'aria-valuemax': this.options.end,\n      'aria-valuemin': this.options.start,\n      'aria-valuenow': initVal,\n      'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',\n      'tabindex': 0\n    });\n  }\n\n  /**\n   * Sets the input and `aria-valuenow` values for the slider element.\n   * @function\n   * @private\n   * @param {jQuery} $handle - the currently selected handle.\n   * @param {Number} val - floating point of the new value.\n   */\n  _setValues($handle, val) {\n    var idx = this.options.doubleSided ? this.handles.index($handle) : 0;\n    this.inputs.eq(idx).val(val);\n    $handle.attr('aria-valuenow', val);\n  }\n\n  /**\n   * Handles events on the slider element.\n   * Calculates the new location of the current handle.\n   * If there are two handles and the bar was clicked, it determines which handle to move.\n   * @function\n   * @private\n   * @param {Object} e - the `event` object passed from the listener.\n   * @param {jQuery} $handle - the current handle to calculate for, if selected.\n   * @param {Number} val - floating point number for the new value of the slider.\n   * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.\n   */\n  _handleEvent(e, $handle, val) {\n    var value, hasVal;\n    if (!val) {//click or drag events\n      e.preventDefault();\n      var _this = this,\n          vertical = this.options.vertical,\n          param = vertical ? 'height' : 'width',\n          direction = vertical ? 'top' : 'left',\n          eventOffset = vertical ? e.pageY : e.pageX,\n          halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,\n          barDim = this.$element[0].getBoundingClientRect()[param],\n          windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();\n\n\n      var elemOffset = this.$element.offset()[direction];\n\n      // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...\n      // best way to guess this is simulated is if clientY == pageY\n      if (e.clientY === e.pageY) { eventOffset = eventOffset + windowScroll; }\n      var eventFromBar = eventOffset - elemOffset;\n      var barXY;\n      if (eventFromBar < 0) {\n        barXY = 0;\n      } else if (eventFromBar > barDim) {\n        barXY = barDim;\n      } else {\n        barXY = eventFromBar;\n      }\n      var offsetPct = percent(barXY, barDim);\n\n      value = this._value(offsetPct);\n\n      // turn everything around for RTL, yay math!\n      if (Rtl() && !this.options.vertical) {value = this.options.end - value;}\n\n      value = _this._adjustValue(null, value);\n      //boolean flag for the setHandlePos fn, specifically for vertical sliders\n      hasVal = false;\n\n      if (!$handle) {//figure out which handle it is, pass it to the next function.\n        var firstHndlPos = absPosition(this.$handle, direction, barXY, param),\n            secndHndlPos = absPosition(this.$handle2, direction, barXY, param);\n            $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;\n      }\n\n    } else {//change event on input\n      value = this._adjustValue(null, val);\n      hasVal = true;\n    }\n\n    this._setHandlePos($handle, value, hasVal);\n  }\n\n  /**\n   * Adjustes value for handle in regard to step value. returns adjusted value\n   * @function\n   * @private\n   * @param {jQuery} $handle - the selected handle.\n   * @param {Number} value - value to adjust. used if $handle is falsy\n   */\n  _adjustValue($handle, value) {\n    var val,\n      step = this.options.step,\n      div = parseFloat(step/2),\n      left, prev_val, next_val;\n    if (!!$handle) {\n      val = parseFloat($handle.attr('aria-valuenow'));\n    }\n    else {\n      val = value;\n    }\n    if (val >= 0) {\n      left = val % step;\n    } else {\n      left = step + (val % step);\n    }\n    prev_val = val - left;\n    next_val = prev_val + step;\n    if (left === 0) {\n      return val;\n    }\n    val = val >= prev_val + div ? next_val : prev_val;\n    return val;\n  }\n\n  /**\n   * Adds event listeners to the slider elements.\n   * @function\n   * @private\n   */\n  _events() {\n    this._eventsForHandle(this.$handle);\n    if(this.handles[1]) {\n      this._eventsForHandle(this.$handle2);\n    }\n  }\n\n\n  /**\n   * Adds event listeners a particular handle\n   * @function\n   * @private\n   * @param {jQuery} $handle - the current handle to apply listeners to.\n   */\n  _eventsForHandle($handle) {\n    var _this = this,\n        curHandle,\n        timer;\n\n      const handleChangeEvent = function(e) {\n        const idx = _this.inputs.index($(this));\n        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());\n      };\n\n      // IE only triggers the change event when the input loses focus which strictly follows the HTML specification\n      // listen for the enter key and trigger a change\n      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events\n      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {\n        if(e.keyCode == 13) handleChangeEvent.call(this, e);\n      });\n\n      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);\n\n      if (this.options.clickSelect) {\n        this.$element.off('click.zf.slider').on('click.zf.slider', function(e) {\n          if (_this.$element.data('dragging')) { return false; }\n\n          if (!$(e.target).is('[data-slider-handle]')) {\n            if (_this.options.doubleSided) {\n              _this._handleEvent(e);\n            } else {\n              _this._handleEvent(e, _this.$handle);\n            }\n          }\n        });\n      }\n\n    if (this.options.draggable) {\n      this.handles.addTouch();\n\n      var $body = $('body');\n      $handle\n        .off('mousedown.zf.slider')\n        .on('mousedown.zf.slider', function(e) {\n          $handle.addClass('is-dragging');\n          _this.$fill.addClass('is-dragging');//\n          _this.$element.data('dragging', true);\n\n          curHandle = $(e.currentTarget);\n\n          $body.on('mousemove.zf.slider', function(e) {\n            e.preventDefault();\n            _this._handleEvent(e, curHandle);\n\n          }).on('mouseup.zf.slider', function(e) {\n            _this._handleEvent(e, curHandle);\n\n            $handle.removeClass('is-dragging');\n            _this.$fill.removeClass('is-dragging');\n            _this.$element.data('dragging', false);\n\n            $body.off('mousemove.zf.slider mouseup.zf.slider');\n          });\n      })\n      // prevent events triggered by touch\n      .on('selectstart.zf.slider touchmove.zf.slider', function(e) {\n        e.preventDefault();\n      });\n    }\n\n    $handle.off('keydown.zf.slider').on('keydown.zf.slider', function(e) {\n      var _$handle = $(this),\n          idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,\n          oldValue = parseFloat(_this.inputs.eq(idx).val()),\n          newValue;\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Slider', {\n        decrease: function() {\n          newValue = oldValue - _this.options.step;\n        },\n        increase: function() {\n          newValue = oldValue + _this.options.step;\n        },\n        decrease_fast: function() {\n          newValue = oldValue - _this.options.step * 10;\n        },\n        increase_fast: function() {\n          newValue = oldValue + _this.options.step * 10;\n        },\n        min: function() {\n          newValue = _this.options.start;\n        },\n        max: function() {\n          newValue = _this.options.end;\n        },\n        handled: function() { // only set handle pos when event was handled specially\n          e.preventDefault();\n          _this._setHandlePos(_$handle, newValue, true);\n        }\n      });\n      /*if (newValue) { // if pressed key has special function, update value\n        e.preventDefault();\n        _this._setHandlePos(_$handle, newValue);\n      }*/\n    });\n  }\n\n  /**\n   * Destroys the slider plugin.\n   */\n  _destroy() {\n    this.handles.off('.zf.slider');\n    this.inputs.off('.zf.slider');\n    this.$element.off('.zf.slider');\n\n    clearTimeout(this.timeout);\n  }\n}\n\nSlider.defaults = {\n  /**\n   * Minimum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  start: 0,\n  /**\n   * Maximum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  end: 100,\n  /**\n   * Minimum value change per change event.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  step: 1,\n  /**\n   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  initialStart: 0,\n  /**\n   * Value at which the right handle/second input should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  initialEnd: 100,\n  /**\n   * Allows the input to be located outside the container and visible. Set to by the JS\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  binding: false,\n  /**\n   * Allows the user to click/tap on the slider bar to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickSelect: true,\n  /**\n   * Set to true and use the `vertical` class to change alignment to vertical.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  vertical: false,\n  /**\n   * Allows the user to drag the slider handle(s) to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  draggable: true,\n  /**\n   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disabled: false,\n  /**\n   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  doubleSided: false,\n  /**\n   * Potential future feature.\n   */\n  // steps: 100,\n  /**\n   * Number of decimal places the plugin should go to for floating point precision.\n   * @option\n   * @type {number}\n   * @default 2\n   */\n  decimal: 2,\n  /**\n   * Time delay for dragged elements.\n   */\n  // dragDelay: 0,\n  /**\n   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  moveTime: 200,//update this if changing the transition time in the sass\n  /**\n   * Class applied to disabled sliders.\n   * @option\n   * @type {string}\n   * @default 'disabled'\n   */\n  disabledClass: 'disabled',\n  /**\n   * Will invert the default layout for a vertical<span data-tooltip title=\"who would do this???\"> </span>slider.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  invertVertical: false,\n  /**\n   * Milliseconds before the `changed.zf-slider` event is triggered after value change.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  changedDelay: 500,\n  /**\n  * Basevalue for non-linear sliders\n  * @option\n  * @type {number}\n  * @default 5\n  */\n  nonLinearBase: 5,\n  /**\n  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.\n  * @option\n  * @type {string}\n  * @default 'linear'\n  */\n  positionValueFunction: 'linear',\n};\n\nfunction percent(frac, num) {\n  return (frac / num);\n}\nfunction absPosition($handle, dir, clickPos, param) {\n  return Math.abs(($handle.position()[dir] + ($handle[param]() / 2)) - clickPos);\n}\nfunction baseLog(base, value) {\n  return Math.log(value)/Math.log(base)\n}\n\nexport {Slider};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass Sticky extends Plugin {\n  /**\n   * Creates a new instance of a sticky thing.\n   * @class\n   * @name Sticky\n   * @param {jQuery} element - jQuery object to make sticky.\n   * @param {Object} options - options object passed when creating the element programmatically.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);\n    this.className = 'Sticky'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var $parent = this.$element.parent('[data-sticky-container]'),\n        id = this.$element[0].id || GetYoDigits(6, 'sticky'),\n        _this = this;\n\n    if($parent.length){\n      this.$container = $parent;\n    } else {\n      this.wasWrapped = true;\n      this.$element.wrap(this.options.container);\n      this.$container = this.$element.parent();\n    }\n    this.$container.addClass(this.options.containerClass);\n\n    this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });\n    if (this.options.anchor !== '') {\n        $('#' + _this.options.anchor).attr({ 'data-mutate': id });\n    }\n\n    this.scrollCount = this.options.checkEvery;\n    this.isStuck = false;\n    this.onLoadListener = onLoad($(window), function () {\n      //We calculate the container height to have correct values for anchor points offset calculation.\n      _this.containerHeight = _this.$element.css(\"display\") == \"none\" ? 0 : _this.$element[0].getBoundingClientRect().height;\n      _this.$container.css('height', _this.containerHeight);\n      _this.elemHeight = _this.containerHeight;\n      if (_this.options.anchor !== '') {\n        _this.$anchor = $('#' + _this.options.anchor);\n      } else {\n        _this._parsePoints();\n      }\n\n      _this._setSizes(function () {\n        var scroll = window.pageYOffset;\n        _this._calc(false, scroll);\n        //Unstick the element will ensure that proper classes are set.\n        if (!_this.isStuck) {\n          _this._removeSticky((scroll >= _this.topPoint) ? false : true);\n        }\n      });\n      _this._events(id.split('-').reverse().join('-'));\n    });\n  }\n\n  /**\n   * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.\n   * @function\n   * @private\n   */\n  _parsePoints() {\n    var top = this.options.topAnchor == \"\" ? 1 : this.options.topAnchor,\n        btm = this.options.btmAnchor== \"\" ? document.documentElement.scrollHeight : this.options.btmAnchor,\n        pts = [top, btm],\n        breaks = {};\n    for (var i = 0, len = pts.length; i < len && pts[i]; i++) {\n      var pt;\n      if (typeof pts[i] === 'number') {\n        pt = pts[i];\n      } else {\n        var place = pts[i].split(':'),\n            anchor = $(`#${place[0]}`);\n\n        pt = anchor.offset().top;\n        if (place[1] && place[1].toLowerCase() === 'bottom') {\n          pt += anchor[0].getBoundingClientRect().height;\n        }\n      }\n      breaks[i] = pt;\n    }\n\n\n    this.points = breaks;\n    return;\n  }\n\n  /**\n   * Adds event handlers for the scrolling element.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _events(id) {\n    var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n    if (this.isOn) { return; }\n    if (this.canStick) {\n      this.isOn = true;\n      $(window).off(scrollListener)\n               .on(scrollListener, function(e) {\n                 if (_this.scrollCount === 0) {\n                   _this.scrollCount = _this.options.checkEvery;\n                   _this._setSizes(function() {\n                     _this._calc(false, window.pageYOffset);\n                   });\n                 } else {\n                   _this.scrollCount--;\n                   _this._calc(false, window.pageYOffset);\n                 }\n              });\n    }\n\n    this.$element.off('resizeme.zf.trigger')\n                 .on('resizeme.zf.trigger', function(e, el) {\n                    _this._eventsHandler(id);\n    });\n\n    this.$element.on('mutateme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n    });\n\n    if(this.$anchor) {\n      this.$anchor.on('mutateme.zf.trigger', function (e, el) {\n          _this._eventsHandler(id);\n      });\n    }\n  }\n\n  /**\n   * Handler for events.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _eventsHandler(id) {\n       var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n\n       _this._setSizes(function() {\n       _this._calc(false);\n       if (_this.canStick) {\n         if (!_this.isOn) {\n           _this._events(id);\n         }\n       } else if (_this.isOn) {\n         _this._pauseListeners(scrollListener);\n       }\n     });\n  }\n\n  /**\n   * Removes event handlers for scroll and change events on anchor.\n   * @fires Sticky#pause\n   * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`\n   */\n  _pauseListeners(scrollListener) {\n    this.isOn = false;\n    $(window).off(scrollListener);\n\n    /**\n     * Fires when the plugin is paused due to resize event shrinking the view.\n     * @event Sticky#pause\n     * @private\n     */\n     this.$element.trigger('pause.zf.sticky');\n  }\n\n  /**\n   * Called on every `scroll` event and on `_init`\n   * fires functions based on booleans and cached values\n   * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.\n   * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.\n   */\n  _calc(checkSizes, scroll) {\n    if (checkSizes) { this._setSizes(); }\n\n    if (!this.canStick) {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n      return false;\n    }\n\n    if (!scroll) { scroll = window.pageYOffset; }\n\n    if (scroll >= this.topPoint) {\n      if (scroll <= this.bottomPoint) {\n        if (!this.isStuck) {\n          this._setSticky();\n        }\n      } else {\n        if (this.isStuck) {\n          this._removeSticky(false);\n        }\n      }\n    } else {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n    }\n  }\n\n  /**\n   * Causes the $element to become stuck.\n   * Adds `position: fixed;`, and helper classes.\n   * @fires Sticky#stuckto\n   * @function\n   * @private\n   */\n  _setSticky() {\n    var _this = this,\n        stickTo = this.options.stickTo,\n        mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickTo === 'top' ? 'bottom' : 'top',\n        css = {};\n\n    css[mrgn] = `${this.options[mrgn]}em`;\n    css[stickTo] = 0;\n    css[notStuckTo] = 'auto';\n    this.isStuck = true;\n    this.$element.removeClass(`is-anchored is-at-${notStuckTo}`)\n                 .addClass(`is-stuck is-at-${stickTo}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become `position: fixed;`\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`\n                  * @event Sticky#stuckto\n                  */\n                 .trigger(`sticky.zf.stuckto:${stickTo}`);\n    this.$element.on(\"transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd\", function() {\n      _this._setSizes();\n    });\n  }\n\n  /**\n   * Causes the $element to become unstuck.\n   * Removes `position: fixed;`, and helper classes.\n   * Adds other helper classes.\n   * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.\n   * @fires Sticky#unstuckfrom\n   * @private\n   */\n  _removeSticky(isTop) {\n    var stickTo = this.options.stickTo,\n        stickToTop = stickTo === 'top',\n        css = {},\n        anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,\n        mrgn = stickToTop ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickToTop ? 'bottom' : 'top',\n        topOrBottom = isTop ? 'top' : 'bottom';\n\n    css[mrgn] = 0;\n\n    css['bottom'] = 'auto';\n    if(isTop) {\n      css['top'] = 0;\n    } else {\n      css['top'] = anchorPt;\n    }\n\n    this.isStuck = false;\n    this.$element.removeClass(`is-stuck is-at-${stickTo}`)\n                 .addClass(`is-anchored is-at-${topOrBottom}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become anchored.\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`\n                  * @event Sticky#unstuckfrom\n                  */\n                 .trigger(`sticky.zf.unstuckfrom:${topOrBottom}`);\n  }\n\n  /**\n   * Sets the $element and $container sizes for plugin.\n   * Calls `_setBreakPoints`.\n   * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.\n   * @private\n   */\n  _setSizes(cb) {\n    this.canStick = MediaQuery.is(this.options.stickyOn);\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n    }\n    var _this = this,\n        newElemWidth = this.$container[0].getBoundingClientRect().width,\n        comp = window.getComputedStyle(this.$container[0]),\n        pdngl = parseInt(comp['padding-left'], 10),\n        pdngr = parseInt(comp['padding-right'], 10);\n\n    if (this.$anchor && this.$anchor.length) {\n      this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;\n    } else {\n      this._parsePoints();\n    }\n\n    this.$element.css({\n      'max-width': `${newElemWidth - pdngl - pdngr}px`\n    });\n\n    var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;\n    if (this.$element.css(\"display\") == \"none\") {\n      newContainerHeight = 0;\n    }\n    this.containerHeight = newContainerHeight;\n    this.$container.css({\n      height: newContainerHeight\n    });\n    this.elemHeight = newContainerHeight;\n\n    if (!this.isStuck) {\n      if (this.$element.hasClass('is-at-bottom')) {\n        var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;\n        this.$element.css('top', anchorPt);\n      }\n    }\n\n    this._setBreakPoints(newContainerHeight, function() {\n      if (cb && typeof cb === 'function') { cb(); }\n    });\n  }\n\n  /**\n   * Sets the upper and lower breakpoints for the element to become sticky/unsticky.\n   * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.\n   * @param {Function} cb - optional callback function to be called on completion.\n   * @private\n   */\n  _setBreakPoints(elemHeight, cb) {\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n      else { return false; }\n    }\n    var mTop = emCalc(this.options.marginTop),\n        mBtm = emCalc(this.options.marginBottom),\n        topPoint = this.points ? this.points[0] : this.$anchor.offset().top,\n        bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,\n        // topPoint = this.$anchor.offset().top || this.points[0],\n        // bottomPoint = topPoint + this.anchorHeight || this.points[1],\n        winHeight = window.innerHeight;\n\n    if (this.options.stickTo === 'top') {\n      topPoint -= mTop;\n      bottomPoint -= (elemHeight + mTop);\n    } else if (this.options.stickTo === 'bottom') {\n      topPoint -= (winHeight - (elemHeight + mBtm));\n      bottomPoint -= (winHeight - mBtm);\n    } else {\n      //this would be the stickTo: both option... tricky\n    }\n\n    this.topPoint = topPoint;\n    this.bottomPoint = bottomPoint;\n\n    if (cb && typeof cb === 'function') { cb(); }\n  }\n\n  /**\n   * Destroys the current sticky element.\n   * Resets the element to the top position first.\n   * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.\n   * @function\n   */\n  _destroy() {\n    this._removeSticky(true);\n\n    this.$element.removeClass(`${this.options.stickyClass} is-anchored is-at-top`)\n                 .css({\n                   height: '',\n                   top: '',\n                   bottom: '',\n                   'max-width': ''\n                 })\n                 .off('resizeme.zf.trigger')\n                 .off('mutateme.zf.trigger');\n    if (this.$anchor && this.$anchor.length) {\n      this.$anchor.off('change.zf.sticky');\n    }\n    if (this.scrollListener) $(window).off(this.scrollListener)\n    if (this.onLoadListener) $(window).off(this.onLoadListener)\n\n    if (this.wasWrapped) {\n      this.$element.unwrap();\n    } else {\n      this.$container.removeClass(this.options.containerClass)\n                     .css({\n                       height: ''\n                     });\n    }\n  }\n}\n\nSticky.defaults = {\n  /**\n   * Customizable container template. Add your own classes for styling and sizing.\n   * @option\n   * @type {string}\n   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'\n   */\n  container: '<div data-sticky-container></div>',\n  /**\n   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default 'top'\n   */\n  stickTo: 'top',\n  /**\n   * If anchored to a single element, the id of that element.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  anchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the top anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  topAnchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the bottom anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  btmAnchor: '',\n  /**\n   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginTop: 1,\n  /**\n   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginBottom: 1,\n  /**\n   * Breakpoint string that is the minimum screen size an element should become sticky.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  stickyOn: 'medium',\n  /**\n   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.\n   * @option\n   * @type {string}\n   * @default 'sticky'\n   */\n  stickyClass: 'sticky',\n  /**\n   * Class applied to sticky container. Foundation defaults to `sticky-container`.\n   * @option\n   * @type {string}\n   * @default 'sticky-container'\n   */\n  containerClass: 'sticky-container',\n  /**\n   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.\n   * @option\n   * @type {number}\n   * @default -1\n   */\n  checkEvery: -1\n};\n\n/**\n * Helper function to calculate em values\n * @param Number {em} - number of em's to calculate into pixels\n */\nfunction emCalc(em) {\n  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;\n}\n\nexport {Sticky};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { Plugin } from './foundation.core.plugin';\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.imageLoader if tabs contain images\n */\n\nclass Tabs extends Plugin {\n  /**\n   * Creates a new instance of tabs.\n   * @class\n   * @name Tabs\n   * @fires Tabs#init\n   * @param {jQuery} element - jQuery object to make into tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);\n    this.className = 'Tabs'; // ie9 back compat\n\n    this._init();\n    Keyboard.register('Tabs', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'previous',\n      'ARROW_DOWN': 'next',\n      'ARROW_LEFT': 'previous'\n      // 'TAB': 'next',\n      // 'SHIFT_TAB': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.\n   * @private\n   */\n  _init() {\n    var _this = this;\n    this._isInitializing = true;\n\n    this.$element.attr({'role': 'tablist'});\n    this.$tabTitles = this.$element.find(`.${this.options.linkClass}`);\n    this.$tabContent = $(`[data-tabs-content=\"${this.$element[0].id}\"]`);\n\n    this.$tabTitles.each(function(){\n      var $elem = $(this),\n          $link = $elem.find('a'),\n          isActive = $elem.hasClass(`${_this.options.linkActiveClass}`),\n          hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),\n          linkId = $link[0].id ? $link[0].id : `${hash}-label`,\n          $tabContent = $(`#${hash}`);\n\n      $elem.attr({'role': 'presentation'});\n\n      $link.attr({\n        'role': 'tab',\n        'aria-controls': hash,\n        'aria-selected': isActive,\n        'id': linkId,\n        'tabindex': isActive ? '0' : '-1'\n      });\n\n      $tabContent.attr({\n        'role': 'tabpanel',\n        'aria-labelledby': linkId\n      });\n\n      // Save up the initial hash to return to it later when going back in history\n      if (isActive) {\n        _this._initialAnchor = `#${hash}`;\n      }\n\n      if(!isActive) {\n        $tabContent.attr('aria-hidden', 'true');\n      }\n\n      if(isActive && _this.options.autoFocus){\n        _this.onLoadListener = onLoad($(window), function() {\n          $('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, () => {\n            $link.focus();\n          });\n        });\n      }\n    });\n\n    if(this.options.matchHeight) {\n      var $images = this.$tabContent.find('img');\n\n      if ($images.length) {\n        onImagesLoaded($images, this._setHeight.bind(this));\n      } else {\n        this._setHeight();\n      }\n    }\n\n     // Current context-bound function to open tabs on page load or history hashchange\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find('[href$=\"'+anchor+'\"]');\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, select it\n      if ($anchor && $anchor.length && $link && $link.length) {\n        this.selectTab($anchor, true);\n      }\n      // Otherwise, collapse everything\n      else {\n        this._collapse();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          var offset = this.$element.offset();\n          $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Tabs#deeplink\n         */\n        this.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the tabs.\n   * @private\n   */\n  _events() {\n    this._addKeyHandler();\n    this._addClickHandler();\n    this._setHeightMqHandler = null;\n\n    if (this.options.matchHeight) {\n      this._setHeightMqHandler = this._setHeight.bind(this);\n\n      $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);\n    }\n\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Adds click handlers for items within the tabs.\n   * @private\n   */\n  _addClickHandler() {\n    var _this = this;\n\n    this.$element\n      .off('click.zf.tabs')\n      .on('click.zf.tabs', `.${this.options.linkClass}`, function(e){\n        e.preventDefault();\n        e.stopPropagation();\n        _this._handleTabChange($(this));\n      });\n  }\n\n  /**\n   * Adds keyboard event handlers for items within the tabs.\n   * @private\n   */\n  _addKeyHandler() {\n    var _this = this;\n\n    this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function(e){\n      if (e.which === 9) return;\n\n\n      var $element = $(this),\n        $elements = $element.parent('ul').children('li'),\n        $prevElement,\n        $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          if (_this.options.wrapOnKeys) {\n            $prevElement = i === 0 ? $elements.last() : $elements.eq(i-1);\n            $nextElement = i === $elements.length -1 ? $elements.first() : $elements.eq(i+1);\n          } else {\n            $prevElement = $elements.eq(Math.max(0, i-1));\n            $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          }\n          return;\n        }\n      });\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Tabs', {\n        open: function() {\n          $element.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($element);\n        },\n        previous: function() {\n          $prevElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($prevElement);\n        },\n        next: function() {\n          $nextElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($nextElement);\n        },\n        handled: function() {\n          e.stopPropagation();\n          e.preventDefault();\n        }\n      });\n    });\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.\n   * @param {jQuery} $target - Tab to open.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @fires Tabs#change\n   * @function\n   */\n  _handleTabChange($target, historyHandled) {\n\n    // With `activeCollapse`, if the target is the active Tab, collapse it.\n    if ($target.hasClass(`${this.options.linkActiveClass}`)) {\n        if(this.options.activeCollapse) {\n            this._collapse();\n        }\n        return;\n    }\n\n    var $oldTab = this.$element.\n          find(`.${this.options.linkClass}.${this.options.linkActiveClass}`),\n          $tabLink = $target.find('[role=\"tab\"]'),\n          target = $tabLink.attr('data-tabs-target'),\n          anchor = target && target.length ? `#${target}` : $tabLink[0].hash,\n          $targetContent = this.$tabContent.find(anchor);\n\n    //close old tab\n    this._collapseTab($oldTab);\n\n    //open new tab\n    this._openTab($target);\n\n    //either replace or update browser history\n    if (this.options.deepLink && !historyHandled) {\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n\n    /**\n     * Fires when the plugin has successfully changed tabs.\n     * @event Tabs#change\n     */\n    this.$element.trigger('change.zf.tabs', [$target, $targetContent]);\n\n    //fire to children a mutation event\n    $targetContent.find(\"[data-mutate]\").trigger(\"mutateme.zf.trigger\");\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to open.\n   * @function\n   */\n  _openTab($target) {\n      var $tabLink = $target.find('[role=\"tab\"]'),\n          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),\n          $targetContent = this.$tabContent.find(`#${hash}`);\n\n      $target.addClass(`${this.options.linkActiveClass}`);\n\n      $tabLink.attr({\n        'aria-selected': 'true',\n        'tabindex': '0'\n      });\n\n      $targetContent\n        .addClass(`${this.options.panelActiveClass}`).removeAttr('aria-hidden');\n  }\n\n  /**\n   * Collapses `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to collapse.\n   * @function\n   */\n  _collapseTab($target) {\n    var $target_anchor = $target\n      .removeClass(`${this.options.linkActiveClass}`)\n      .find('[role=\"tab\"]')\n      .attr({\n        'aria-selected': 'false',\n        'tabindex': -1\n      });\n\n    $(`#${$target_anchor.attr('aria-controls')}`)\n      .removeClass(`${this.options.panelActiveClass}`)\n      .attr({ 'aria-hidden': 'true' })\n  }\n\n  /**\n   * Collapses the active Tab.\n   * @fires Tabs#collapse\n   * @function\n   */\n  _collapse() {\n    var $activeTab = this.$element.find(`.${this.options.linkClass}.${this.options.linkActiveClass}`);\n\n    if ($activeTab.length) {\n      this._collapseTab($activeTab);\n\n      /**\n      * Fires when the plugin has successfully collapsed tabs.\n      * @event Tabs#collapse\n      */\n      this.$element.trigger('collapse.zf.tabs', [$activeTab]);\n    }\n  }\n\n  /**\n   * Public method for selecting a content pane to display.\n   * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @function\n   */\n  selectTab(elem, historyHandled) {\n    var idStr;\n\n    if (typeof elem === 'object') {\n      idStr = elem[0].id;\n    } else {\n      idStr = elem;\n    }\n\n    if (idStr.indexOf('#') < 0) {\n      idStr = `#${idStr}`;\n    }\n\n    var $target = this.$tabTitles.has(`[href$=\"${idStr}\"]`);\n\n    this._handleTabChange($target, historyHandled);\n  };\n\n  /**\n   * Sets the height of each panel to the height of the tallest panel.\n   * If enabled in options, gets called on media query change.\n   * If loading content via external source, can be called directly or with _reflow.\n   * If enabled with `data-match-height=\"true\"`, tabs sets to equal height\n   * @function\n   * @private\n   */\n  _setHeight() {\n    var max = 0,\n        _this = this; // Lock down the `this` value for the root tabs object\n\n    this.$tabContent\n      .find(`.${this.options.panelClass}`)\n      .css('height', '')\n      .each(function() {\n\n        var panel = $(this),\n            isActive = panel.hasClass(`${_this.options.panelActiveClass}`); // get the options from the parent instead of trying to get them from the child\n\n        if (!isActive) {\n          panel.css({'visibility': 'hidden', 'display': 'block'});\n        }\n\n        var temp = this.getBoundingClientRect().height;\n\n        if (!isActive) {\n          panel.css({\n            'visibility': '',\n            'display': ''\n          });\n        }\n\n        max = temp > max ? temp : max;\n      })\n      .css('height', `${max}px`);\n  }\n\n  /**\n   * Destroys an instance of tabs.\n   * @fires Tabs#destroyed\n   */\n  _destroy() {\n    this.$element\n      .find(`.${this.options.linkClass}`)\n      .off('.zf.tabs').hide().end()\n      .find(`.${this.options.panelClass}`)\n      .hide();\n\n    if (this.options.matchHeight) {\n      if (this._setHeightMqHandler != null) {\n         $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);\n      }\n    }\n\n    if (this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n    if (this.onLoadListener) {\n      $(window).off(this.onLoadListener);\n    }\n  }\n}\n\nTabs.defaults = {\n  /**\n   * Link the location hash to the active pane.\n   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open tab\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n   * Allows the window to scroll to content of active pane on load.\n   * Not recommended if more than one tab panel per page.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows keyboard input to 'wrap' around the tab links.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  wrapOnKeys: true,\n\n  /**\n   * Allows the tab content panes to match heights if set to true.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  matchHeight: false,\n\n  /**\n   * Allows active tabs to collapse when clicked.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  activeCollapse: false,\n\n  /**\n   * Class applied to `li`'s in tab link list.\n   * @option\n   * @type {string}\n   * @default 'tabs-title'\n   */\n  linkClass: 'tabs-title',\n\n  /**\n   * Class applied to the active `li` in tab link list.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  linkActiveClass: 'is-active',\n\n  /**\n   * Class applied to the content containers.\n   * @option\n   * @type {string}\n   * @default 'tabs-panel'\n   */\n  panelClass: 'tabs-panel',\n\n  /**\n   * Class applied to the active content container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  panelActiveClass: 'is-active'\n};\n\nexport {Tabs};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { RegExpEscape } from './foundation.core.utils';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nclass Toggler extends Plugin {\n  /**\n   * Creates a new instance of Toggler.\n   * @class\n   * @name Toggler\n   * @fires Toggler#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Toggler.defaults, element.data(), options);\n    this.className = '';\n    this.className = 'Toggler'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.\n   * @function\n   * @private\n   */\n  _init() {\n    var input;\n    // Parse animation classes if they were set\n    if (this.options.animate) {\n      input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n    // Otherwise, parse toggle class\n    else {\n      input = this.$element.data('toggler');\n      // Allow for a . at the beginning of the string\n      this.className = input[0] === '.' ? input.slice(1) : input;\n    }\n\n    // Add ARIA attributes to triggers:\n    var id = this.$element[0].id,\n      $triggers = $(`[data-open~=\"${id}\"], [data-close~=\"${id}\"], [data-toggle~=\"${id}\"]`);\n\n    // - aria-expanded: according to the element visibility.\n    $triggers.attr('aria-expanded', !this.$element.is(':hidden'));\n    // - aria-controls: adding the element id to it if not already in it.\n    $triggers.each((index, trigger) => {\n      const $trigger = $(trigger);\n      const controls = $trigger.attr('aria-controls') || '';\n\n      const containsId = new RegExp(`\\\\b${RegExpEscape(id)}\\\\b`).test(controls);\n      if (!containsId) $trigger.attr('aria-controls', controls ? `${controls} ${id}` : id);\n    });\n  }\n\n  /**\n   * Initializes events for the toggle trigger.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));\n  }\n\n  /**\n   * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was \"on\" or \"off\".\n   * @function\n   * @fires Toggler#on\n   * @fires Toggler#off\n   */\n  toggle() {\n    this[ this.options.animate ? '_toggleAnimate' : '_toggleClass']();\n  }\n\n  _toggleClass() {\n    this.$element.toggleClass(this.className);\n\n    var isOn = this.$element.hasClass(this.className);\n    if (isOn) {\n      /**\n       * Fires if the target element has the class after a toggle.\n       * @event Toggler#on\n       */\n      this.$element.trigger('on.zf.toggler');\n    }\n    else {\n      /**\n       * Fires if the target element does not have the class after a toggle.\n       * @event Toggler#off\n       */\n      this.$element.trigger('off.zf.toggler');\n    }\n\n    this._updateARIA(isOn);\n    this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');\n  }\n\n  _toggleAnimate() {\n    var _this = this;\n\n    if (this.$element.is(':hidden')) {\n      Motion.animateIn(this.$element, this.animationIn, function() {\n        _this._updateARIA(true);\n        this.trigger('on.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n    else {\n      Motion.animateOut(this.$element, this.animationOut, function() {\n        _this._updateARIA(false);\n        this.trigger('off.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n  }\n\n  _updateARIA(isOn) {\n    var id = this.$element[0].id;\n    $(`[data-open=\"${id}\"], [data-close=\"${id}\"], [data-toggle=\"${id}\"]`)\n      .attr({\n        'aria-expanded': isOn ? true : false\n      });\n  }\n\n  /**\n   * Destroys the instance of Toggler on the element.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.toggler');\n  }\n}\n\nToggler.defaults = {\n  /**\n   * Tells the plugin if the element should animated when toggled.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport {Toggler};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Triggers } from './foundation.util.triggers';\nimport { Positionable } from './foundation.positionable';\n\n/**\n * Tooltip module.\n * @module foundation.tooltip\n * @requires foundation.util.box\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass Tooltip extends Positionable {\n  /**\n   * Creates a new instance of a Tooltip.\n   * @class\n   * @name Tooltip\n   * @fires Tooltip#init\n   * @param {jQuery} element - jQuery object to attach a tooltip to.\n   * @param {Object} options - object to extend the default configuration.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);\n    this.className = 'Tooltip'; // ie9 back compat\n\n    this.isActive = false;\n    this.isClick = false;\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');\n\n    this.options.tipText = this.options.tipText || this.$element.attr('title');\n    this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);\n\n    if (this.options.allowHtml) {\n      this.template.appendTo(document.body)\n        .html(this.options.tipText)\n        .hide();\n    } else {\n      this.template.appendTo(document.body)\n        .text(this.options.tipText)\n        .hide();\n    }\n\n    this.$element.attr({\n      'title': '',\n      'aria-describedby': elemId,\n      'data-yeti-box': elemId,\n      'data-toggle': elemId,\n      'data-resize': elemId\n    }).addClass(this.options.triggerClass);\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/\\b(top|left|right|bottom)\\b/g);\n    return position ? position[0] : 'top';\n  }\n\n  _getDefaultAlignment() {\n    return 'center';\n  }\n\n  _getHOffset() {\n    if(this.position === 'left' || this.position === 'right') {\n      return this.options.hOffset + this.options.tooltipWidth;\n    } else {\n      return this.options.hOffset\n    }\n  }\n\n  _getVOffset() {\n    if(this.position === 'top' || this.position === 'bottom') {\n      return this.options.vOffset + this.options.tooltipHeight;\n    } else {\n      return this.options.vOffset\n    }\n  }\n\n  /**\n   * builds the tooltip element, adds attributes, and returns the template.\n   * @private\n   */\n  _buildTemplate(id) {\n    var templateClasses = (`${this.options.tooltipClass} ${this.options.templateClasses}`).trim();\n    var $template =  $('<div></div>').addClass(templateClasses).attr({\n      'role': 'tooltip',\n      'aria-hidden': true,\n      'data-is-active': false,\n      'data-is-focus': false,\n      'id': id\n    });\n    return $template;\n  }\n\n  /**\n   * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.\n   * if the tooltip is larger than the screen width, default to full width - any user selected margin\n   * @private\n   */\n  _setPosition() {\n    super._setPosition(this.$element, this.template);\n  }\n\n  /**\n   * reveals the tooltip, and fires an event to close any other open tooltips on the page\n   * @fires Tooltip#closeme\n   * @fires Tooltip#show\n   * @function\n   */\n  show() {\n    if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {\n      // console.error('The screen is too small to display this tooltip');\n      return false;\n    }\n\n    var _this = this;\n    this.template.css('visibility', 'hidden').show();\n    this._setPosition();\n    this.template.removeClass('top bottom left right').addClass(this.position)\n    this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);\n\n    /**\n     * Fires to close all other open tooltips on the page\n     * @event Closeme#tooltip\n     */\n    this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));\n\n\n    this.template.attr({\n      'data-is-active': true,\n      'aria-hidden': false\n    });\n    _this.isActive = true;\n    // console.log(this.template);\n    this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function() {\n      //maybe do stuff?\n    });\n    /**\n     * Fires when the tooltip is shown\n     * @event Tooltip#show\n     */\n    this.$element.trigger('show.zf.tooltip');\n  }\n\n  /**\n   * Hides the current tooltip, and resets the positioning class if it was changed due to collision\n   * @fires Tooltip#hide\n   * @function\n   */\n  hide() {\n    // console.log('hiding', this.$element.data('yeti-box'));\n    var _this = this;\n    this.template.stop().attr({\n      'aria-hidden': true,\n      'data-is-active': false\n    }).fadeOut(this.options.fadeOutDuration, function() {\n      _this.isActive = false;\n      _this.isClick = false;\n    });\n    /**\n     * fires when the tooltip is hidden\n     * @event Tooltip#hide\n     */\n    this.$element.trigger('hide.zf.tooltip');\n  }\n\n  /**\n   * adds event listeners for the tooltip and its anchor\n   * TODO combine some of the listeners like focus and mouseenter, etc.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    var $template = this.template;\n    var isFocus = false;\n\n    if (!this.options.disableHover) {\n\n      this.$element\n      .on('mouseenter.zf.tooltip', function(e) {\n        if (!_this.isActive) {\n          _this.timeout = setTimeout(function() {\n            _this.show();\n          }, _this.options.hoverDelay);\n        }\n      })\n      .on('mouseleave.zf.tooltip', ignoreMousedisappear(function(e) {\n        clearTimeout(_this.timeout);\n        if (!isFocus || (_this.isClick && !_this.options.clickOpen)) {\n          _this.hide();\n        }\n      }));\n    }\n\n    if (this.options.clickOpen) {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        if (_this.isClick) {\n          //_this.hide();\n          // _this.isClick = false;\n        } else {\n          _this.isClick = true;\n          if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {\n            _this.show();\n          }\n        }\n      });\n    } else {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        _this.isClick = true;\n      });\n    }\n\n    if (!this.options.disableForTouch) {\n      this.$element\n      .on('tap.zf.tooltip touchend.zf.tooltip', function(e) {\n        _this.isActive ? _this.hide() : _this.show();\n      });\n    }\n\n    this.$element.on({\n      // 'toggle.zf.trigger': this.toggle.bind(this),\n      // 'close.zf.trigger': this.hide.bind(this)\n      'close.zf.trigger': this.hide.bind(this)\n    });\n\n    this.$element\n      .on('focus.zf.tooltip', function(e) {\n        isFocus = true;\n        if (_this.isClick) {\n          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't\n          // a real focus, otherwise on hover and come back we get bad behavior\n          if(!_this.options.clickOpen) { isFocus = false; }\n          return false;\n        } else {\n          _this.show();\n        }\n      })\n\n      .on('focusout.zf.tooltip', function(e) {\n        isFocus = false;\n        _this.isClick = false;\n        _this.hide();\n      })\n\n      .on('resizeme.zf.trigger', function() {\n        if (_this.isActive) {\n          _this._setPosition();\n        }\n      });\n  }\n\n  /**\n   * adds a toggle method, in addition to the static show() & hide() functions\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  /**\n   * Destroys an instance of tooltip, removes template element from the view.\n   * @function\n   */\n  _destroy() {\n    this.$element.attr('title', this.template.text())\n                 .off('.zf.trigger .zf.tooltip')\n                 .removeClass(this.options.triggerClass)\n                 .removeClass('top right left bottom')\n                 .removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n\n    this.template.remove();\n  }\n}\n\nTooltip.defaults = {\n  disableForTouch: false,\n  /**\n   * Time, in ms, before a tooltip should open on hover.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  hoverDelay: 200,\n  /**\n   * Time, in ms, a tooltip should take to fade into view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeInDuration: 150,\n  /**\n   * Time, in ms, a tooltip should take to fade out of view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeOutDuration: 150,\n  /**\n   * Disables hover events from opening the tooltip if set to true\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Optional addtional classes to apply to the tooltip template on init.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  templateClasses: '',\n  /**\n   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.\n   * @option\n   * @type {string}\n   * @default 'tooltip'\n   */\n  tooltipClass: 'tooltip',\n  /**\n   * Class applied to the tooltip anchor element.\n   * @option\n   * @type {string}\n   * @default 'has-tip'\n   */\n  triggerClass: 'has-tip',\n  /**\n   * Minimum breakpoint size at which to open the tooltip.\n   * @option\n   * @type {string}\n   * @default 'small'\n   */\n  showOn: 'small',\n  /**\n   * Custom template to be used to generate markup for tooltip.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  template: '',\n  /**\n   * Text displayed in the tooltip template on open.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  tipText: '',\n  touchCloseText: 'Tap to close.',\n  /**\n   * Allows the tooltip to remain open if triggered with a click or touch event.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickOpen: true,\n  /**\n   * Position of tooltip. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, tooltip will first try to\n   * position as defined by data-position and data-alignment, but reposition if\n   * it would cause an overflow.  @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * Less common for tooltips.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowBottomOverlap: false,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the Y axis.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the X axis\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip\n   * @option\n   * @type {number}\n   * @default 14\n   */\n  tooltipHeight: 14,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip\n   * @option\n   * @type {number}\n   * @default 12\n   */\n  tooltipWidth: 12,\n    /**\n   * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,\n   * allowing HTML may open yourself up to XSS attacks.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowHtml: false\n};\n\n/**\n * TODO utilize resize event trigger\n */\n\nexport {Tooltip};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin }from './foundation.core.plugin';\n\nimport { Accordion } from './foundation.accordion';\nimport { Tabs } from './foundation.tabs';\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n  tabs: {\n    cssClass: 'tabs',\n    plugin: Tabs\n  },\n  accordion: {\n    cssClass: 'accordion',\n    plugin: Accordion\n  }\n};\n\n\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nclass ResponsiveAccordionTabs extends Plugin{\n  /**\n   * Creates a new instance of a responsive accordion tabs.\n   * @class\n   * @name ResponsiveAccordionTabs\n   * @fires ResponsiveAccordionTabs#init\n   * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options  = $.extend({}, this.$element.data(), options);\n    this.rules = this.$element.data('responsive-accordion-tabs');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveAccordionTabs'; // ie9 back compat\n    if (!this.$element.attr('id')) {\n      this.$element.attr('id',GetYoDigits(6, 'responsiveaccordiontabs'));\n    };\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    this._getAllOptions();\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n  }\n\n  _getAllOptions() {\n    //get all defaults and options\n    var _this = this;\n    _this.allOptions = {};\n    for (var key in MenuPlugins) {\n      if (MenuPlugins.hasOwnProperty(key)) {\n        var obj = MenuPlugins[key];\n        try {\n          var dummyPlugin = $('<ul></ul>');\n          var tmpPlugin = new obj.plugin(dummyPlugin,_this.options);\n          for (var keyKey in tmpPlugin.options) {\n            if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {\n              var objObj = tmpPlugin.options[keyKey];\n              _this.allOptions[keyKey] = objObj;\n            }\n          }\n          tmpPlugin.destroy();\n        }\n        catch(e) {\n        }\n      }\n    }\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);\n    $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) {\n      //don't know why but on nested elements data zfPlugin get's lost\n      if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin',this.storezfData);\n      this.currentPlugin.destroy();\n    }\n    this._handleMarkup(this.rules[matchedMq].cssClass);\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n    this.storezfData = this.currentPlugin.$element.data('zfPlugin');\n\n  }\n\n  _handleMarkup(toSet){\n    var _this = this, fromString = 'accordion';\n    var $panels = $('[data-tabs-content='+this.$element.attr('id')+']');\n    if ($panels.length) fromString = 'tabs';\n    if (fromString === toSet) {\n      return;\n    };\n\n    var tabsTitle = _this.allOptions.linkClass?_this.allOptions.linkClass:'tabs-title';\n    var tabsPanel = _this.allOptions.panelClass?_this.allOptions.panelClass:'tabs-panel';\n\n    this.$element.removeAttr('role');\n    var $liHeads = this.$element.children('.'+tabsTitle+',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');\n    var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');\n\n    if (fromString === 'tabs') {\n      $panels = $panels.children('.'+tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');\n      $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');\n    }else{\n      $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');\n    };\n\n    $panels.css({display:'',visibility:''});\n    $liHeads.css({display:'',visibility:''});\n    if (toSet === 'accordion') {\n      $panels.each(function(key,value){\n        $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content','').removeClass('is-active').css({height:''});\n        $('[data-tabs-content='+_this.$element.attr('id')+']').after('<div id=\"tabs-placeholder-'+_this.$element.attr('id')+'\"></div>').detach();\n        $liHeads.addClass('accordion-item').attr('data-accordion-item','');\n        $liHeadsA.addClass('accordion-title');\n      });\n    }else if (toSet === 'tabs'){\n      var $tabsContent = $('[data-tabs-content='+_this.$element.attr('id')+']');\n      var $placeholder = $('#tabs-placeholder-'+_this.$element.attr('id'));\n      if ($placeholder.length) {\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter($placeholder).attr('data-tabs-content',_this.$element.attr('id'));\n        $placeholder.remove();\n      }else{\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter(_this.$element).attr('data-tabs-content',_this.$element.attr('id'));\n      };\n      $panels.each(function(key,value){\n        var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);\n        var hash = $liHeadsA.get(key).hash.slice(1);\n        var id = $(value).attr('id') || GetYoDigits(6, 'accordion');\n        if (hash !== id) {\n          if (hash !== '') {\n            $(value).attr('id',hash);\n          }else{\n            hash = id;\n            $(value).attr('id',hash);\n            $($liHeadsA.get(key)).attr('href',$($liHeadsA.get(key)).attr('href').replace('#','')+'#'+hash);\n          };\n        };\n        var isActive = $($liHeads.get(key)).hasClass('is-active');\n        if (isActive) {\n          tempValue.addClass('is-active');\n        };\n      });\n      $liHeads.addClass(tabsTitle);\n    };\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n}\n\nResponsiveAccordionTabs.defaults = {};\n\nexport {ResponsiveAccordionTabs};\n","import $ from 'jquery';\n\nimport { Foundation } from '../foundation.core';\nimport * as CoreUtils from '../foundation.core.utils';\nimport { Box } from '../foundation.util.box'\nimport { onImagesLoaded } from '../foundation.util.imageLoader';\nimport { Keyboard } from '../foundation.util.keyboard';\nimport { MediaQuery } from '../foundation.util.mediaQuery';\nimport { Motion, Move } from '../foundation.util.motion';\nimport { Nest } from '../foundation.util.nest';\nimport { Timer } from '../foundation.util.timer';\nimport { Touch } from '../foundation.util.touch';\nimport { Triggers } from '../foundation.util.triggers';\nimport { Abide } from '../foundation.abide';\nimport { Accordion } from '../foundation.accordion';\nimport { AccordionMenu } from '../foundation.accordionMenu';\nimport { Drilldown } from '../foundation.drilldown';\nimport { Dropdown } from '../foundation.dropdown';\nimport { DropdownMenu } from '../foundation.dropdownMenu';\nimport { Equalizer } from '../foundation.equalizer';\nimport { Interchange } from '../foundation.interchange';\nimport { Magellan } from '../foundation.magellan';\nimport { OffCanvas } from '../foundation.offcanvas';\nimport { Orbit } from '../foundation.orbit';\nimport { ResponsiveMenu } from '../foundation.responsiveMenu';\nimport { ResponsiveToggle } from '../foundation.responsiveToggle';\nimport { Reveal } from '../foundation.reveal';\nimport { Slider } from '../foundation.slider';\nimport { SmoothScroll } from '../foundation.smoothScroll';\nimport { Sticky } from '../foundation.sticky';\nimport { Tabs } from '../foundation.tabs';\nimport { Toggler } from '../foundation.toggler';\nimport { Tooltip } from '../foundation.tooltip';\nimport { ResponsiveAccordionTabs } from '../foundation.responsiveAccordionTabs';\n\nFoundation.addToJquery($);\n\n// Add Foundation Utils to Foundation global namespace for backwards\n// compatibility.\nFoundation.rtl = CoreUtils.rtl;\nFoundation.GetYoDigits = CoreUtils.GetYoDigits;\nFoundation.transitionend = CoreUtils.transitionend;\nFoundation.RegExpEscape = CoreUtils.RegExpEscape;\nFoundation.onLoad = CoreUtils.onLoad;\n\nFoundation.Box = Box;\nFoundation.onImagesLoaded = onImagesLoaded;\nFoundation.Keyboard = Keyboard;\nFoundation.MediaQuery = MediaQuery;\nFoundation.Motion = Motion;\nFoundation.Move = Move;\nFoundation.Nest = Nest;\nFoundation.Timer = Timer;\n\n// Touch and Triggers previously were almost purely sede effect driven,\n// so no need to add it to Foundation, just init them.\nTouch.init($);\nTriggers.init($, Foundation);\nMediaQuery._init();\n\nFoundation.plugin(Abide, 'Abide');\nFoundation.plugin(Accordion, 'Accordion');\nFoundation.plugin(AccordionMenu, 'AccordionMenu');\nFoundation.plugin(Drilldown, 'Drilldown');\nFoundation.plugin(Dropdown, 'Dropdown');\nFoundation.plugin(DropdownMenu, 'DropdownMenu');\nFoundation.plugin(Equalizer, 'Equalizer');\nFoundation.plugin(Interchange, 'Interchange');\nFoundation.plugin(Magellan, 'Magellan');\nFoundation.plugin(OffCanvas, 'OffCanvas');\nFoundation.plugin(Orbit, 'Orbit');\nFoundation.plugin(ResponsiveMenu, 'ResponsiveMenu');\nFoundation.plugin(ResponsiveToggle, 'ResponsiveToggle');\nFoundation.plugin(Reveal, 'Reveal');\nFoundation.plugin(Slider, 'Slider');\nFoundation.plugin(SmoothScroll, 'SmoothScroll');\nFoundation.plugin(Sticky, 'Sticky');\nFoundation.plugin(Tabs, 'Tabs');\nFoundation.plugin(Toggler, 'Toggler');\nFoundation.plugin(Tooltip, 'Tooltip');\nFoundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');\n\nexport {\n  Foundation,\n  CoreUtils,\n  Box,\n  onImagesLoaded,\n  Keyboard,\n  MediaQuery,\n  Motion,\n  Nest,\n  Timer,\n  Touch,\n  Triggers,\n  Abide,\n  Accordion,\n  AccordionMenu,\n  Drilldown,\n  Dropdown,\n  DropdownMenu,\n  Equalizer,\n  Interchange,\n  Magellan,\n  OffCanvas,\n  Orbit,\n  ResponsiveMenu,\n  ResponsiveToggle,\n  Reveal,\n  Slider,\n  SmoothScroll,\n  Sticky,\n  Tabs,\n  Toggler,\n  Tooltip,\n  ResponsiveAccordionTabs\n}\n\nexport default Foundation;\n\n"],"names":["$","Rtl","hyphenate","MenuPlugins","CoreUtils.rtl","CoreUtils.GetYoDigits","CoreUtils.transitionend","CoreUtils.RegExpEscape","CoreUtils.onLoad"],"mappings":"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"}
\ No newline at end of file
diff --git a/dist/js/foundation.esm.js b/dist/js/foundation.esm.js
new file mode 100644 (file)
index 0000000..a1ddd20
--- /dev/null
@@ -0,0 +1,11763 @@
+import $ from 'jquery';
+
+function _typeof(obj) {
+  if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
+    _typeof = function (obj) {
+      return typeof obj;
+    };
+  } else {
+    _typeof = function (obj) {
+      return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
+    };
+  }
+
+  return _typeof(obj);
+}
+
+function _classCallCheck(instance, Constructor) {
+  if (!(instance instanceof Constructor)) {
+    throw new TypeError("Cannot call a class as a 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);
+  }
+}
+
+function _createClass(Constructor, protoProps, staticProps) {
+  if (protoProps) _defineProperties(Constructor.prototype, protoProps);
+  if (staticProps) _defineProperties(Constructor, staticProps);
+  return Constructor;
+}
+
+function _inherits(subClass, superClass) {
+  if (typeof superClass !== "function" && superClass !== null) {
+    throw new TypeError("Super expression must either be null or a function");
+  }
+
+  subClass.prototype = Object.create(superClass && superClass.prototype, {
+    constructor: {
+      value: subClass,
+      writable: true,
+      configurable: true
+    }
+  });
+  if (superClass) _setPrototypeOf(subClass, superClass);
+}
+
+function _getPrototypeOf(o) {
+  _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) {
+    return o.__proto__ || Object.getPrototypeOf(o);
+  };
+  return _getPrototypeOf(o);
+}
+
+function _setPrototypeOf(o, p) {
+  _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) {
+    o.__proto__ = p;
+    return o;
+  };
+
+  return _setPrototypeOf(o, p);
+}
+
+function _assertThisInitialized(self) {
+  if (self === void 0) {
+    throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
+  }
+
+  return self;
+}
+
+function _possibleConstructorReturn(self, call) {
+  if (call && (typeof call === "object" || typeof call === "function")) {
+    return call;
+  }
+
+  return _assertThisInitialized(self);
+}
+
+function _superPropBase(object, property) {
+  while (!Object.prototype.hasOwnProperty.call(object, property)) {
+    object = _getPrototypeOf(object);
+    if (object === null) break;
+  }
+
+  return object;
+}
+
+function _get(target, property, receiver) {
+  if (typeof Reflect !== "undefined" && Reflect.get) {
+    _get = Reflect.get;
+  } else {
+    _get = function _get(target, property, receiver) {
+      var base = _superPropBase(target, property);
+
+      if (!base) return;
+      var desc = Object.getOwnPropertyDescriptor(base, property);
+
+      if (desc.get) {
+        return desc.get.call(receiver);
+      }
+
+      return desc.value;
+    };
+  }
+
+  return _get(target, property, receiver || target);
+}
+
+/**
+ * Returns a boolean for RTL support
+ */
+
+function rtl() {
+  return $('html').attr('dir') === 'rtl';
+}
+/**
+ * returns a random base-36 uid with namespacing
+ * @function
+ * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.
+ * @param {String} namespace - name of plugin to be incorporated in uid, optional.
+ * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.
+ * @returns {String} - unique id
+ */
+
+
+function GetYoDigits(length, namespace) {
+  length = length || 6;
+  return Math.round(Math.pow(36, length + 1) - Math.random() * Math.pow(36, length)).toString(36).slice(1) + (namespace ? "-".concat(namespace) : '');
+}
+/**
+ * Escape a string so it can be used as a regexp pattern
+ * @function
+ * @see https://stackoverflow.com/a/9310752/4317384
+ *
+ * @param {String} str - string to escape.
+ * @returns {String} - escaped string
+ */
+
+
+function RegExpEscape(str) {
+  return str.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
+}
+
+function transitionend($elem) {
+  var transitions = {
+    'transition': 'transitionend',
+    'WebkitTransition': 'webkitTransitionEnd',
+    'MozTransition': 'transitionend',
+    'OTransition': 'otransitionend'
+  };
+  var elem = document.createElement('div'),
+      end;
+
+  for (var t in transitions) {
+    if (typeof elem.style[t] !== 'undefined') {
+      end = transitions[t];
+    }
+  }
+
+  if (end) {
+    return end;
+  } else {
+    end = setTimeout(function () {
+      $elem.triggerHandler('transitionend', [$elem]);
+    }, 1);
+    return 'transitionend';
+  }
+}
+/**
+ * Return an event type to listen for window load.
+ *
+ * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.
+ * If `handler` is passed, attach it to the event on `$elem`.
+ * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.
+ * @function
+ *
+ * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.
+ * @param {Function} [] handler - function to attach to the event.
+ * @returns {String} - event type that should or will be triggered.
+ */
+
+
+function onLoad($elem, handler) {
+  var didLoad = document.readyState === 'complete';
+  var eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';
+
+  var cb = function cb() {
+    return $elem.triggerHandler(eventType);
+  };
+
+  if ($elem) {
+    if (handler) $elem.one(eventType, handler);
+    if (didLoad) setTimeout(cb);else $(window).one('load', cb);
+  }
+
+  return eventType;
+}
+/**
+ * Retuns an handler for the `mouseleave` that ignore disappeared mouses.
+ *
+ * If the mouse "disappeared" from the document (like when going on a browser UI element, See https://git.io/zf-11410),
+ * the event is ignored.
+ * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window
+ *   (like by switching to an other window with [Alt]+[Tab]).
+ * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document
+ *   outside of the element it left.
+ *
+ * @function
+ *
+ * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.
+ * @param {Object} [] options - object of options:
+ * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.
+ * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.
+ * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.
+ */
+
+
+function ignoreMousedisappear(handler) {
+  var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
+      _ref$ignoreLeaveWindo = _ref.ignoreLeaveWindow,
+      ignoreLeaveWindow = _ref$ignoreLeaveWindo === void 0 ? false : _ref$ignoreLeaveWindo,
+      _ref$ignoreReappear = _ref.ignoreReappear,
+      ignoreReappear = _ref$ignoreReappear === void 0 ? false : _ref$ignoreReappear;
+
+  return function leaveEventHandler(eLeave) {
+    for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
+      rest[_key - 1] = arguments[_key];
+    }
+
+    var callback = handler.bind.apply(handler, [this, eLeave].concat(rest)); // The mouse left: call the given callback if the mouse entered elsewhere
+
+    if (eLeave.relatedTarget !== null) {
+      return callback();
+    } // Otherwise, check if the mouse actually left the window.
+    // In firefox if the user switched between windows, the window sill have the focus by the time
+    // the event is triggered. We have to debounce the event to test this case.
+
+
+    setTimeout(function leaveEventDebouncer() {
+      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {
+        return callback();
+      } // Otherwise, wait for the mouse to reeapear outside of the element,
+
+
+      if (!ignoreReappear) {
+        $(document).one('mouseenter', function reenterEventHandler(eReenter) {
+          if (!$(eLeave.currentTarget).has(eReenter.target).length) {
+            // Fill where the mouse finally entered.
+            eLeave.relatedTarget = eReenter.target;
+            callback();
+          }
+        });
+      }
+    }, 0);
+  };
+}
+
+var foundation_core_utils = /*#__PURE__*/Object.freeze({
+  rtl: rtl,
+  GetYoDigits: GetYoDigits,
+  RegExpEscape: RegExpEscape,
+  transitionend: transitionend,
+  onLoad: onLoad,
+  ignoreMousedisappear: ignoreMousedisappear
+});
+
+// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license
+
+/* eslint-disable */
+
+window.matchMedia || (window.matchMedia = function () {
+
+  var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium
+
+  if (!styleMedia) {
+    var style = document.createElement('style'),
+        script = document.getElementsByTagName('script')[0],
+        info = null;
+    style.type = 'text/css';
+    style.id = 'matchmediajs-test';
+
+    if (!script) {
+      document.head.appendChild(style);
+    } else {
+      script.parentNode.insertBefore(style, script);
+    } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
+
+
+    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;
+    styleMedia = {
+      matchMedium: function matchMedium(media) {
+        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
+
+        if (style.styleSheet) {
+          style.styleSheet.cssText = text;
+        } else {
+          style.textContent = text;
+        } // Test if media query is true or false
+
+
+        return info.width === '1px';
+      }
+    };
+  }
+
+  return function (media) {
+    return {
+      matches: styleMedia.matchMedium(media || 'all'),
+      media: media || 'all'
+    };
+  };
+}());
+/* eslint-enable */
+
+var MediaQuery = {
+  queries: [],
+  current: '',
+
+  /**
+   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.
+   * @function
+   * @private
+   */
+  _init: function _init() {
+    var self = this;
+    var $meta = $('meta.foundation-mq');
+
+    if (!$meta.length) {
+      $('<meta class="foundation-mq">').appendTo(document.head);
+    }
+
+    var extractedStyles = $('.foundation-mq').css('font-family');
+    var namedQueries;
+    namedQueries = parseStyleToObject(extractedStyles);
+
+    for (var key in namedQueries) {
+      if (namedQueries.hasOwnProperty(key)) {
+        self.queries.push({
+          name: key,
+          value: "only screen and (min-width: ".concat(namedQueries[key], ")")
+        });
+      }
+    }
+
+    this.current = this._getCurrentSize();
+
+    this._watcher();
+  },
+
+  /**
+   * Checks if the screen is at least as wide as a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to check.
+   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.
+   */
+  atLeast: function atLeast(size) {
+    var query = this.get(size);
+
+    if (query) {
+      return window.matchMedia(query).matches;
+    }
+
+    return false;
+  },
+
+  /**
+   * Checks if the screen matches to a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.
+   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.
+   */
+  is: function is(size) {
+    size = size.trim().split(' ');
+
+    if (size.length > 1 && size[1] === 'only') {
+      if (size[0] === this._getCurrentSize()) return true;
+    } else {
+      return this.atLeast(size[0]);
+    }
+
+    return false;
+  },
+
+  /**
+   * Gets the media query of a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to get.
+   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.
+   */
+  get: function get(size) {
+    for (var i in this.queries) {
+      if (this.queries.hasOwnProperty(i)) {
+        var query = this.queries[i];
+        if (size === query.name) return query.value;
+      }
+    }
+
+    return null;
+  },
+
+  /**
+   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).
+   * @function
+   * @private
+   * @returns {String} Name of the current breakpoint.
+   */
+  _getCurrentSize: function _getCurrentSize() {
+    var matched;
+
+    for (var i = 0; i < this.queries.length; i++) {
+      var query = this.queries[i];
+
+      if (window.matchMedia(query.value).matches) {
+        matched = query;
+      }
+    }
+
+    if (_typeof(matched) === 'object') {
+      return matched.name;
+    } else {
+      return matched;
+    }
+  },
+
+  /**
+   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.
+   * @function
+   * @private
+   */
+  _watcher: function _watcher() {
+    var _this = this;
+
+    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {
+      var newSize = _this._getCurrentSize(),
+          currentSize = _this.current;
+
+      if (newSize !== currentSize) {
+        // Change the current media query
+        _this.current = newSize; // Broadcast the media query change on the window
+
+        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
+      }
+    });
+  }
+}; // Thank you: https://github.com/sindresorhus/query-string
+
+function parseStyleToObject(str) {
+  var styleObject = {};
+
+  if (typeof str !== 'string') {
+    return styleObject;
+  }
+
+  str = str.trim().slice(1, -1); // browsers re-quote string style values
+
+  if (!str) {
+    return styleObject;
+  }
+
+  styleObject = str.split('&').reduce(function (ret, param) {
+    var parts = param.replace(/\+/g, ' ').split('=');
+    var key = parts[0];
+    var val = parts[1];
+    key = decodeURIComponent(key); // missing `=` should be `null`:
+    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters
+
+    val = typeof val === 'undefined' ? null : decodeURIComponent(val);
+
+    if (!ret.hasOwnProperty(key)) {
+      ret[key] = val;
+    } else if (Array.isArray(ret[key])) {
+      ret[key].push(val);
+    } else {
+      ret[key] = [ret[key], val];
+    }
+
+    return ret;
+  }, {});
+  return styleObject;
+}
+
+var FOUNDATION_VERSION = '6.5.3'; // Global Foundation object
+// This is attached to the window, or used as a module for AMD/Browserify
+
+var Foundation = {
+  version: FOUNDATION_VERSION,
+
+  /**
+   * Stores initialized plugins.
+   */
+  _plugins: {},
+
+  /**
+   * Stores generated unique ids for plugin instances
+   */
+  _uuids: [],
+
+  /**
+   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.
+   * @param {Object} plugin - The constructor of the plugin.
+   */
+  plugin: function plugin(_plugin, name) {
+    // Object key to use when adding to global Foundation object
+    // Examples: Foundation.Reveal, Foundation.OffCanvas
+    var className = name || functionName(_plugin); // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin
+    // Examples: data-reveal, data-off-canvas
+
+    var attrName = hyphenate(className); // Add to the Foundation object and the plugins list (for reflowing)
+
+    this._plugins[attrName] = this[className] = _plugin;
+  },
+
+  /**
+   * @function
+   * Populates the _uuids array with pointers to each individual plugin instance.
+   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.
+   * Also fires the initialization event for each plugin, consolidating repetitive code.
+   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
+   * @param {String} name - the name of the plugin, passed as a camelCased string.
+   * @fires Plugin#init
+   */
+  registerPlugin: function registerPlugin(plugin, name) {
+    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();
+    plugin.uuid = GetYoDigits(6, pluginName);
+
+    if (!plugin.$element.attr("data-".concat(pluginName))) {
+      plugin.$element.attr("data-".concat(pluginName), plugin.uuid);
+    }
+
+    if (!plugin.$element.data('zfPlugin')) {
+      plugin.$element.data('zfPlugin', plugin);
+    }
+    /**
+     * Fires when the plugin has initialized.
+     * @event Plugin#init
+     */
+
+
+    plugin.$element.trigger("init.zf.".concat(pluginName));
+
+    this._uuids.push(plugin.uuid);
+
+    return;
+  },
+
+  /**
+   * @function
+   * Removes the plugins uuid from the _uuids array.
+   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.
+   * Also fires the destroyed event for the plugin, consolidating repetitive code.
+   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
+   * @fires Plugin#destroyed
+   */
+  unregisterPlugin: function unregisterPlugin(plugin) {
+    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));
+
+    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);
+
+    plugin.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin')
+    /**
+     * Fires when the plugin has been destroyed.
+     * @event Plugin#destroyed
+     */
+    .trigger("destroyed.zf.".concat(pluginName));
+
+    for (var prop in plugin) {
+      plugin[prop] = null; //clean up script to prep for garbage collection.
+    }
+
+    return;
+  },
+
+  /**
+   * @function
+   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.
+   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`
+   * @default If no argument is passed, reflow all currently active plugins.
+   */
+  reInit: function reInit(plugins) {
+    var isJQ = plugins instanceof $;
+
+    try {
+      if (isJQ) {
+        plugins.each(function () {
+          $(this).data('zfPlugin')._init();
+        });
+      } else {
+        var type = _typeof(plugins),
+            _this = this,
+            fns = {
+          'object': function object(plgs) {
+            plgs.forEach(function (p) {
+              p = hyphenate(p);
+              $('[data-' + p + ']').foundation('_init');
+            });
+          },
+          'string': function string() {
+            plugins = hyphenate(plugins);
+            $('[data-' + plugins + ']').foundation('_init');
+          },
+          'undefined': function undefined() {
+            this['object'](Object.keys(_this._plugins));
+          }
+        };
+
+        fns[type](plugins);
+      }
+    } catch (err) {
+      console.error(err);
+    } finally {
+      return plugins;
+    }
+  },
+
+  /**
+   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.
+   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.
+   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.
+   */
+  reflow: function reflow(elem, plugins) {
+    // If plugins is undefined, just grab everything
+    if (typeof plugins === 'undefined') {
+      plugins = Object.keys(this._plugins);
+    } // If plugins is a string, convert it to an array with one item
+    else if (typeof plugins === 'string') {
+        plugins = [plugins];
+      }
+
+    var _this = this; // Iterate through each plugin
+
+
+    $.each(plugins, function (i, name) {
+      // Get the current plugin
+      var plugin = _this._plugins[name]; // Localize the search to all elements inside elem, as well as elem itself, unless elem === document
+
+      var $elem = $(elem).find('[data-' + name + ']').addBack('[data-' + name + ']'); // For each plugin found, initialize it
+
+      $elem.each(function () {
+        var $el = $(this),
+            opts = {}; // Don't double-dip on plugins
+
+        if ($el.data('zfPlugin')) {
+          console.warn("Tried to initialize " + name + " on an element that already has a Foundation plugin.");
+          return;
+        }
+
+        if ($el.attr('data-options')) {
+          var thing = $el.attr('data-options').split(';').forEach(function (e, i) {
+            var opt = e.split(':').map(function (el) {
+              return el.trim();
+            });
+            if (opt[0]) opts[opt[0]] = parseValue(opt[1]);
+          });
+        }
+
+        try {
+          $el.data('zfPlugin', new plugin($(this), opts));
+        } catch (er) {
+          console.error(er);
+        } finally {
+          return;
+        }
+      });
+    });
+  },
+  getFnName: functionName,
+  addToJquery: function addToJquery($$$1) {
+    // TODO: consider not making this a jQuery function
+    // TODO: need way to reflow vs. re-initialize
+
+    /**
+     * The Foundation jQuery method.
+     * @param {String|Array} method - An action to perform on the current jQuery object.
+     */
+    var foundation = function foundation(method) {
+      var type = _typeof(method),
+          $noJS = $$$1('.no-js');
+
+      if ($noJS.length) {
+        $noJS.removeClass('no-js');
+      }
+
+      if (type === 'undefined') {
+        //needs to initialize the Foundation object, or an individual plugin.
+        MediaQuery._init();
+
+        Foundation.reflow(this);
+      } else if (type === 'string') {
+        //an individual method to invoke on a plugin or group of plugins
+        var args = Array.prototype.slice.call(arguments, 1); //collect all the arguments, if necessary
+
+        var plugClass = this.data('zfPlugin'); //determine the class of plugin
+
+        if (typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined') {
+          //make sure both the class and method exist
+          if (this.length === 1) {
+            //if there's only one, call it directly.
+            plugClass[method].apply(plugClass, args);
+          } else {
+            this.each(function (i, el) {
+              //otherwise loop through the jQuery collection and invoke the method on each
+              plugClass[method].apply($$$1(el).data('zfPlugin'), args);
+            });
+          }
+        } else {
+          //error for no class or no method
+          throw new ReferenceError("We're sorry, '" + method + "' is not an available method for " + (plugClass ? functionName(plugClass) : 'this element') + '.');
+        }
+      } else {
+        //error for invalid argument type
+        throw new TypeError("We're sorry, ".concat(type, " is not a valid parameter. You must use a string representing the method you wish to invoke."));
+      }
+
+      return this;
+    };
+
+    $$$1.fn.foundation = foundation;
+    return $$$1;
+  }
+};
+Foundation.util = {
+  /**
+   * Function for applying a debounce effect to a function call.
+   * @function
+   * @param {Function} func - Function to be called at end of timeout.
+   * @param {Number} delay - Time in ms to delay the call of `func`.
+   * @returns function
+   */
+  throttle: function throttle(func, delay) {
+    var timer = null;
+    return function () {
+      var context = this,
+          args = arguments;
+
+      if (timer === null) {
+        timer = setTimeout(function () {
+          func.apply(context, args);
+          timer = null;
+        }, delay);
+      }
+    };
+  }
+};
+window.Foundation = Foundation; // Polyfill for requestAnimationFrame
+
+(function () {
+  if (!Date.now || !window.Date.now) window.Date.now = Date.now = function () {
+    return new Date().getTime();
+  };
+  var vendors = ['webkit', 'moz'];
+
+  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {
+    var vp = vendors[i];
+    window.requestAnimationFrame = window[vp + 'RequestAnimationFrame'];
+    window.cancelAnimationFrame = window[vp + 'CancelAnimationFrame'] || window[vp + 'CancelRequestAnimationFrame'];
+  }
+
+  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) || !window.requestAnimationFrame || !window.cancelAnimationFrame) {
+    var lastTime = 0;
+
+    window.requestAnimationFrame = function (callback) {
+      var now = Date.now();
+      var nextTime = Math.max(lastTime + 16, now);
+      return setTimeout(function () {
+        callback(lastTime = nextTime);
+      }, nextTime - now);
+    };
+
+    window.cancelAnimationFrame = clearTimeout;
+  }
+  /**
+   * Polyfill for performance.now, required by rAF
+   */
+
+
+  if (!window.performance || !window.performance.now) {
+    window.performance = {
+      start: Date.now(),
+      now: function now() {
+        return Date.now() - this.start;
+      }
+    };
+  }
+})();
+
+if (!Function.prototype.bind) {
+  Function.prototype.bind = function (oThis) {
+    if (typeof this !== 'function') {
+      // closest thing possible to the ECMAScript 5
+      // internal IsCallable function
+      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');
+    }
+
+    var aArgs = Array.prototype.slice.call(arguments, 1),
+        fToBind = this,
+        fNOP = function fNOP() {},
+        fBound = function fBound() {
+      return fToBind.apply(this instanceof fNOP ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments)));
+    };
+
+    if (this.prototype) {
+      // native functions don't have a prototype
+      fNOP.prototype = this.prototype;
+    }
+
+    fBound.prototype = new fNOP();
+    return fBound;
+  };
+} // Polyfill to get the name of a function in IE9
+
+
+function functionName(fn) {
+  if (typeof Function.prototype.name === 'undefined') {
+    var funcNameRegex = /function\s([^(]{1,})\(/;
+    var results = funcNameRegex.exec(fn.toString());
+    return results && results.length > 1 ? results[1].trim() : "";
+  } else if (typeof fn.prototype === 'undefined') {
+    return fn.constructor.name;
+  } else {
+    return fn.prototype.constructor.name;
+  }
+}
+
+function parseValue(str) {
+  if ('true' === str) return true;else if ('false' === str) return false;else if (!isNaN(str * 1)) return parseFloat(str);
+  return str;
+} // Convert PascalCase to kebab-case
+// Thank you: http://stackoverflow.com/a/8955580
+
+
+function hyphenate(str) {
+  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
+}
+
+var Box = {
+  ImNotTouchingYou: ImNotTouchingYou,
+  OverlapArea: OverlapArea,
+  GetDimensions: GetDimensions,
+  GetOffsets: GetOffsets,
+  GetExplicitOffsets: GetExplicitOffsets
+  /**
+   * Compares the dimensions of an element to a container and determines collision events with container.
+   * @function
+   * @param {jQuery} element - jQuery object to test for collisions.
+   * @param {jQuery} parent - jQuery object to use as bounding container.
+   * @param {Boolean} lrOnly - set to true to check left and right values only.
+   * @param {Boolean} tbOnly - set to true to check top and bottom values only.
+   * @default if no parent object passed, detects collisions with `window`.
+   * @returns {Boolean} - true if collision free, false if a collision in any direction.
+   */
+
+};
+
+function ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;
+}
+
+function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  var eleDims = GetDimensions(element),
+      topOver,
+      bottomOver,
+      leftOver,
+      rightOver;
+
+  if (parent) {
+    var parDims = GetDimensions(parent);
+    bottomOver = parDims.height + parDims.offset.top - (eleDims.offset.top + eleDims.height);
+    topOver = eleDims.offset.top - parDims.offset.top;
+    leftOver = eleDims.offset.left - parDims.offset.left;
+    rightOver = parDims.width + parDims.offset.left - (eleDims.offset.left + eleDims.width);
+  } else {
+    bottomOver = eleDims.windowDims.height + eleDims.windowDims.offset.top - (eleDims.offset.top + eleDims.height);
+    topOver = eleDims.offset.top - eleDims.windowDims.offset.top;
+    leftOver = eleDims.offset.left - eleDims.windowDims.offset.left;
+    rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);
+  }
+
+  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);
+  topOver = Math.min(topOver, 0);
+  leftOver = Math.min(leftOver, 0);
+  rightOver = Math.min(rightOver, 0);
+
+  if (lrOnly) {
+    return leftOver + rightOver;
+  }
+
+  if (tbOnly) {
+    return topOver + bottomOver;
+  } // use sum of squares b/c we care about overlap area.
+
+
+  return Math.sqrt(topOver * topOver + bottomOver * bottomOver + leftOver * leftOver + rightOver * rightOver);
+}
+/**
+ * Uses native methods to return an object of dimension values.
+ * @function
+ * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.
+ * @returns {Object} - nested object of integer pixel values
+ * TODO - if element is window, return only those values.
+ */
+
+
+function GetDimensions(elem) {
+  elem = elem.length ? elem[0] : elem;
+
+  if (elem === window || elem === document) {
+    throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");
+  }
+
+  var rect = elem.getBoundingClientRect(),
+      parRect = elem.parentNode.getBoundingClientRect(),
+      winRect = document.body.getBoundingClientRect(),
+      winY = window.pageYOffset,
+      winX = window.pageXOffset;
+  return {
+    width: rect.width,
+    height: rect.height,
+    offset: {
+      top: rect.top + winY,
+      left: rect.left + winX
+    },
+    parentDims: {
+      width: parRect.width,
+      height: parRect.height,
+      offset: {
+        top: parRect.top + winY,
+        left: parRect.left + winX
+      }
+    },
+    windowDims: {
+      width: winRect.width,
+      height: winRect.height,
+      offset: {
+        top: winY,
+        left: winX
+      }
+    }
+  };
+}
+/**
+ * Returns an object of top and left integer pixel values for dynamically rendered elements,
+ * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where
+ * you don't know alignment, but generally from
+ * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.
+ * @function
+ * @param {jQuery} element - jQuery object for the element being positioned.
+ * @param {jQuery} anchor - jQuery object for the element's anchor point.
+ * @param {String} position - a string relating to the desired position of the element, relative to it's anchor
+ * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.
+ * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.
+ * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.
+ * TODO alter/rewrite to work with `em` values as well/instead of pixels
+ */
+
+
+function GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {
+  console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5");
+
+  switch (position) {
+    case 'top':
+      return rtl() ? GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);
+
+    case 'bottom':
+      return rtl() ? GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+
+    case 'center top':
+      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);
+
+    case 'center bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);
+
+    case 'center left':
+      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);
+
+    case 'center right':
+      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);
+
+    case 'left bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);
+
+    case 'right bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+    // Backwards compatibility... this along with the reveal and reveal full
+    // classes are the only ones that didn't reference anchor
+
+    case 'center':
+      return {
+        left: $eleDims.windowDims.offset.left + $eleDims.windowDims.width / 2 - $eleDims.width / 2 + hOffset,
+        top: $eleDims.windowDims.offset.top + $eleDims.windowDims.height / 2 - ($eleDims.height / 2 + vOffset)
+      };
+
+    case 'reveal':
+      return {
+        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,
+        top: $eleDims.windowDims.offset.top + vOffset
+      };
+
+    case 'reveal full':
+      return {
+        left: $eleDims.windowDims.offset.left,
+        top: $eleDims.windowDims.offset.top
+      };
+      break;
+
+    default:
+      return {
+        left: rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset : $anchorDims.offset.left + hOffset,
+        top: $anchorDims.offset.top + $anchorDims.height + vOffset
+      };
+  }
+}
+
+function GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {
+  var $eleDims = GetDimensions(element),
+      $anchorDims = anchor ? GetDimensions(anchor) : null;
+  var topVal, leftVal; // set position related attribute
+
+  switch (position) {
+    case 'top':
+      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);
+      break;
+
+    case 'bottom':
+      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;
+      break;
+
+    case 'left':
+      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);
+      break;
+
+    case 'right':
+      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;
+      break;
+  } // set alignment related attribute
+
+
+  switch (position) {
+    case 'top':
+    case 'bottom':
+      switch (alignment) {
+        case 'left':
+          leftVal = $anchorDims.offset.left + hOffset;
+          break;
+
+        case 'right':
+          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;
+          break;
+
+        case 'center':
+          leftVal = isOverflow ? hOffset : $anchorDims.offset.left + $anchorDims.width / 2 - $eleDims.width / 2 + hOffset;
+          break;
+      }
+
+      break;
+
+    case 'right':
+    case 'left':
+      switch (alignment) {
+        case 'bottom':
+          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;
+          break;
+
+        case 'top':
+          topVal = $anchorDims.offset.top + vOffset;
+          break;
+
+        case 'center':
+          topVal = $anchorDims.offset.top + vOffset + $anchorDims.height / 2 - $eleDims.height / 2;
+          break;
+      }
+
+      break;
+  }
+
+  return {
+    top: topVal,
+    left: leftVal
+  };
+}
+
+/**
+ * Runs a callback function when images are fully loaded.
+ * @param {Object} images - Image(s) to check if loaded.
+ * @param {Func} callback - Function to execute when image is fully loaded.
+ */
+
+function onImagesLoaded(images, callback) {
+  var unloaded = images.length;
+
+  if (unloaded === 0) {
+    callback();
+  }
+
+  images.each(function () {
+    // Check if image is loaded
+    if (this.complete && typeof this.naturalWidth !== 'undefined') {
+      singleImageLoaded();
+    } else {
+      // If the above check failed, simulate loading on detached element.
+      var image = new Image(); // Still count image as loaded if it finalizes with an error.
+
+      var events = "load.zf.images error.zf.images";
+      $(image).one(events, function me(event) {
+        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.
+        $(this).off(events, me);
+        singleImageLoaded();
+      });
+      image.src = $(this).attr('src');
+    }
+  });
+
+  function singleImageLoaded() {
+    unloaded--;
+
+    if (unloaded === 0) {
+      callback();
+    }
+  }
+}
+
+/*******************************************
+ *                                         *
+ * This util was created by Marius Olbertz *
+ * Please thank Marius on GitHub /owlbertz *
+ * or the web http://www.mariusolbertz.de/ *
+ *                                         *
+ ******************************************/
+var keyCodes = {
+  9: 'TAB',
+  13: 'ENTER',
+  27: 'ESCAPE',
+  32: 'SPACE',
+  35: 'END',
+  36: 'HOME',
+  37: 'ARROW_LEFT',
+  38: 'ARROW_UP',
+  39: 'ARROW_RIGHT',
+  40: 'ARROW_DOWN'
+};
+var commands = {}; // Functions pulled out to be referenceable from internals
+
+function findFocusable($element) {
+  if (!$element) {
+    return false;
+  }
+
+  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function () {
+    if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) {
+      return false;
+    } //only have visible elements and those that have a tabindex greater or equal 0
+
+
+    return true;
+  });
+}
+
+function parseKey(event) {
+  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase(); // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events
+
+  key = key.replace(/\W+/, '');
+  if (event.shiftKey) key = "SHIFT_".concat(key);
+  if (event.ctrlKey) key = "CTRL_".concat(key);
+  if (event.altKey) key = "ALT_".concat(key); // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)
+
+  key = key.replace(/_$/, '');
+  return key;
+}
+
+var Keyboard = {
+  keys: getKeyCodes(keyCodes),
+
+  /**
+   * Parses the (keyboard) event and returns a String that represents its key
+   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
+   * @param {Event} event - the event generated by the event handler
+   * @return String key - String that represents the key pressed
+   */
+  parseKey: parseKey,
+
+  /**
+   * Handles the given (keyboard) event
+   * @param {Event} event - the event generated by the event handler
+   * @param {String} component - Foundation component's name, e.g. Slider or Reveal
+   * @param {Objects} functions - collection of functions that are to be executed
+   */
+  handleKey: function handleKey(event, component, functions) {
+    var commandList = commands[component],
+        keyCode = this.parseKey(event),
+        cmds,
+        command,
+        fn;
+    if (!commandList) return console.warn('Component not defined!');
+
+    if (typeof commandList.ltr === 'undefined') {
+      // this component does not differentiate between ltr and rtl
+      cmds = commandList; // use plain list
+    } else {
+      // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa
+      if (rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);else cmds = $.extend({}, commandList.rtl, commandList.ltr);
+    }
+
+    command = cmds[keyCode];
+    fn = functions[command];
+
+    if (fn && typeof fn === 'function') {
+      // execute function  if exists
+      var returnValue = fn.apply();
+
+      if (functions.handled || typeof functions.handled === 'function') {
+        // execute function when event was handled
+        functions.handled(returnValue);
+      }
+    } else {
+      if (functions.unhandled || typeof functions.unhandled === 'function') {
+        // execute function when event was not handled
+        functions.unhandled();
+      }
+    }
+  },
+
+  /**
+   * Finds all focusable elements within the given `$element`
+   * @param {jQuery} $element - jQuery object to search within
+   * @return {jQuery} $focusable - all focusable elements within `$element`
+   */
+  findFocusable: findFocusable,
+
+  /**
+   * Returns the component name name
+   * @param {Object} component - Foundation component, e.g. Slider or Reveal
+   * @return String componentName
+   */
+  register: function register(componentName, cmds) {
+    commands[componentName] = cmds;
+  },
+  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?
+  //
+
+  /**
+   * Traps the focus in the given element.
+   * @param  {jQuery} $element  jQuery object to trap the foucs into.
+   */
+  trapFocus: function trapFocus($element) {
+    var $focusable = findFocusable($element),
+        $firstFocusable = $focusable.eq(0),
+        $lastFocusable = $focusable.eq(-1);
+    $element.on('keydown.zf.trapfocus', function (event) {
+      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {
+        event.preventDefault();
+        $firstFocusable.focus();
+      } else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {
+        event.preventDefault();
+        $lastFocusable.focus();
+      }
+    });
+  },
+
+  /**
+   * Releases the trapped focus from the given element.
+   * @param  {jQuery} $element  jQuery object to release the focus for.
+   */
+  releaseFocus: function releaseFocus($element) {
+    $element.off('keydown.zf.trapfocus');
+  }
+};
+/*
+ * Constants for easier comparing.
+ * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
+ */
+
+function getKeyCodes(kcs) {
+  var k = {};
+
+  for (var kc in kcs) {
+    k[kcs[kc]] = kcs[kc];
+  }
+
+  return k;
+}
+
+/**
+ * Motion module.
+ * @module foundation.motion
+ */
+
+var initClasses = ['mui-enter', 'mui-leave'];
+var activeClasses = ['mui-enter-active', 'mui-leave-active'];
+var Motion = {
+  animateIn: function animateIn(element, animation, cb) {
+    animate(true, element, animation, cb);
+  },
+  animateOut: function animateOut(element, animation, cb) {
+    animate(false, element, animation, cb);
+  }
+};
+
+function Move(duration, elem, fn) {
+  var anim,
+      prog,
+      start = null; // console.log('called');
+
+  if (duration === 0) {
+    fn.apply(elem);
+    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
+    return;
+  }
+
+  function move(ts) {
+    if (!start) start = ts; // console.log(start, ts);
+
+    prog = ts - start;
+    fn.apply(elem);
+
+    if (prog < duration) {
+      anim = window.requestAnimationFrame(move, elem);
+    } else {
+      window.cancelAnimationFrame(anim);
+      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
+    }
+  }
+
+  anim = window.requestAnimationFrame(move);
+}
+/**
+ * Animates an element in or out using a CSS transition class.
+ * @function
+ * @private
+ * @param {Boolean} isIn - Defines if the animation is in or out.
+ * @param {Object} element - jQuery or HTML object to animate.
+ * @param {String} animation - CSS class to use.
+ * @param {Function} cb - Callback to run when animation is finished.
+ */
+
+
+function animate(isIn, element, animation, cb) {
+  element = $(element).eq(0);
+  if (!element.length) return;
+  var initClass = isIn ? initClasses[0] : initClasses[1];
+  var activeClass = isIn ? activeClasses[0] : activeClasses[1]; // Set up the animation
+
+  reset();
+  element.addClass(animation).css('transition', 'none');
+  requestAnimationFrame(function () {
+    element.addClass(initClass);
+    if (isIn) element.show();
+  }); // Start the animation
+
+  requestAnimationFrame(function () {
+    element[0].offsetWidth;
+    element.css('transition', '').addClass(activeClass);
+  }); // Clean up the animation when it finishes
+
+  element.one(transitionend(element), finish); // Hides the element (for out animations), resets the element, and runs a callback
+
+  function finish() {
+    if (!isIn) element.hide();
+    reset();
+    if (cb) cb.apply(element);
+  } // Resets transitions and removes motion-specific classes
+
+
+  function reset() {
+    element[0].style.transitionDuration = 0;
+    element.removeClass("".concat(initClass, " ").concat(activeClass, " ").concat(animation));
+  }
+}
+
+var Nest = {
+  Feather: function Feather(menu) {
+    var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zf';
+    menu.attr('role', 'menubar');
+    var items = menu.find('li').attr({
+      'role': 'menuitem'
+    }),
+        subMenuClass = "is-".concat(type, "-submenu"),
+        subItemClass = "".concat(subMenuClass, "-item"),
+        hasSubClass = "is-".concat(type, "-submenu-parent"),
+        applyAria = type !== 'accordion'; // Accordions handle their own ARIA attriutes.
+
+    items.each(function () {
+      var $item = $(this),
+          $sub = $item.children('ul');
+
+      if ($sub.length) {
+        $item.addClass(hasSubClass);
+
+        if (applyAria) {
+          $item.attr({
+            'aria-haspopup': true,
+            'aria-label': $item.children('a:first').text()
+          }); // Note:  Drilldowns behave differently in how they hide, and so need
+          // additional attributes.  We should look if this possibly over-generalized
+          // utility (Nest) is appropriate when we rework menus in 6.4
+
+          if (type === 'drilldown') {
+            $item.attr({
+              'aria-expanded': false
+            });
+          }
+        }
+
+        $sub.addClass("submenu ".concat(subMenuClass)).attr({
+          'data-submenu': '',
+          'role': 'menubar'
+        });
+
+        if (type === 'drilldown') {
+          $sub.attr({
+            'aria-hidden': true
+          });
+        }
+      }
+
+      if ($item.parent('[data-submenu]').length) {
+        $item.addClass("is-submenu-item ".concat(subItemClass));
+      }
+    });
+    return;
+  },
+  Burn: function Burn(menu, type) {
+    var //items = menu.find('li'),
+    subMenuClass = "is-".concat(type, "-submenu"),
+        subItemClass = "".concat(subMenuClass, "-item"),
+        hasSubClass = "is-".concat(type, "-submenu-parent");
+    menu.find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li').removeClass("".concat(subMenuClass, " ").concat(subItemClass, " ").concat(hasSubClass, " is-submenu-item submenu is-active")).removeAttr('data-submenu').css('display', '');
+  }
+};
+
+function Timer(elem, options, cb) {
+  var _this = this,
+      duration = options.duration,
+      //options is an object for easily adding features later.
+  nameSpace = Object.keys(elem.data())[0] || 'timer',
+      remain = -1,
+      start,
+      timer;
+
+  this.isPaused = false;
+
+  this.restart = function () {
+    remain = -1;
+    clearTimeout(timer);
+    this.start();
+  };
+
+  this.start = function () {
+    this.isPaused = false; // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+
+    clearTimeout(timer);
+    remain = remain <= 0 ? duration : remain;
+    elem.data('paused', false);
+    start = Date.now();
+    timer = setTimeout(function () {
+      if (options.infinite) {
+        _this.restart(); //rerun the timer.
+
+      }
+
+      if (cb && typeof cb === 'function') {
+        cb();
+      }
+    }, remain);
+    elem.trigger("timerstart.zf.".concat(nameSpace));
+  };
+
+  this.pause = function () {
+    this.isPaused = true; //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+
+    clearTimeout(timer);
+    elem.data('paused', true);
+    var end = Date.now();
+    remain = remain - (end - start);
+    elem.trigger("timerpaused.zf.".concat(nameSpace));
+  };
+}
+
+var Touch = {};
+var startPosX,
+    startPosY,
+    startTime,
+    elapsedTime,
+    startEvent,
+    isMoving = false,
+    didMoved = false;
+
+function onTouchEnd(e) {
+  this.removeEventListener('touchmove', onTouchMove);
+  this.removeEventListener('touchend', onTouchEnd); // If the touch did not move, consider it as a "tap"
+
+  if (!didMoved) {
+    var tapEvent = $.Event('tap', startEvent || e);
+    $(this).trigger(tapEvent);
+  }
+
+  startEvent = null;
+  isMoving = false;
+  didMoved = false;
+}
+
+function onTouchMove(e) {
+  if ($.spotSwipe.preventDefault) {
+    e.preventDefault();
+  }
+
+  if (isMoving) {
+    var x = e.touches[0].pageX;
+    var y = e.touches[0].pageY;
+    var dx = startPosX - x;
+    var dir;
+    didMoved = true;
+    elapsedTime = new Date().getTime() - startTime;
+
+    if (Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
+      dir = dx > 0 ? 'left' : 'right';
+    } // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
+    //   dir = dy > 0 ? 'down' : 'up';
+    // }
+
+
+    if (dir) {
+      e.preventDefault();
+      onTouchEnd.apply(this, arguments);
+      $(this).trigger($.Event('swipe', e), dir).trigger($.Event("swipe".concat(dir), e));
+    }
+  }
+}
+
+function onTouchStart(e) {
+  if (e.touches.length == 1) {
+    startPosX = e.touches[0].pageX;
+    startPosY = e.touches[0].pageY;
+    startEvent = e;
+    isMoving = true;
+    didMoved = false;
+    startTime = new Date().getTime();
+    this.addEventListener('touchmove', onTouchMove, false);
+    this.addEventListener('touchend', onTouchEnd, false);
+  }
+}
+
+function init() {
+  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);
+}
+
+var SpotSwipe =
+/*#__PURE__*/
+function () {
+  function SpotSwipe($$$1) {
+    _classCallCheck(this, SpotSwipe);
+
+    this.version = '1.0.0';
+    this.enabled = 'ontouchstart' in document.documentElement;
+    this.preventDefault = false;
+    this.moveThreshold = 75;
+    this.timeThreshold = 200;
+    this.$ = $$$1;
+
+    this._init();
+  }
+
+  _createClass(SpotSwipe, [{
+    key: "_init",
+    value: function _init() {
+      var $$$1 = this.$;
+      $$$1.event.special.swipe = {
+        setup: init
+      };
+      $$$1.event.special.tap = {
+        setup: init
+      };
+      $$$1.each(['left', 'up', 'down', 'right'], function () {
+        $$$1.event.special["swipe".concat(this)] = {
+          setup: function setup() {
+            $$$1(this).on('swipe', $$$1.noop);
+          }
+        };
+      });
+    }
+  }]);
+
+  return SpotSwipe;
+}();
+/****************************************************
+ * As far as I can tell, both setupSpotSwipe and    *
+ * setupTouchHandler should be idempotent,          *
+ * because they directly replace functions &        *
+ * values, and do not add event handlers directly.  *
+ ****************************************************/
+
+
+Touch.setupSpotSwipe = function ($$$1) {
+  $$$1.spotSwipe = new SpotSwipe($$$1);
+};
+/****************************************************
+ * Method for adding pseudo drag events to elements *
+ ***************************************************/
+
+
+Touch.setupTouchHandler = function ($$$1) {
+  $$$1.fn.addTouch = function () {
+    this.each(function (i, el) {
+      $$$1(el).bind('touchstart touchmove touchend touchcancel', function (event) {
+        //we pass the original event object because the jQuery event
+        //object is normalized to w3c specs and does not provide the TouchList
+        handleTouch(event);
+      });
+    });
+
+    var handleTouch = function handleTouch(event) {
+      var touches = event.changedTouches,
+          first = touches[0],
+          eventTypes = {
+        touchstart: 'mousedown',
+        touchmove: 'mousemove',
+        touchend: 'mouseup'
+      },
+          type = eventTypes[event.type],
+          simulatedEvent;
+
+      if ('MouseEvent' in window && typeof window.MouseEvent === 'function') {
+        simulatedEvent = new window.MouseEvent(type, {
+          'bubbles': true,
+          'cancelable': true,
+          'screenX': first.screenX,
+          'screenY': first.screenY,
+          'clientX': first.clientX,
+          'clientY': first.clientY
+        });
+      } else {
+        simulatedEvent = document.createEvent('MouseEvent');
+        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0
+        /*left*/
+        , null);
+      }
+
+      first.target.dispatchEvent(simulatedEvent);
+    };
+  };
+};
+
+Touch.init = function ($$$1) {
+  if (typeof $$$1.spotSwipe === 'undefined') {
+    Touch.setupSpotSwipe($$$1);
+    Touch.setupTouchHandler($$$1);
+  }
+};
+
+var MutationObserver = function () {
+  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
+  for (var i = 0; i < prefixes.length; i++) {
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
+    }
+  }
+
+  return false;
+}();
+
+var triggers = function triggers(el, type) {
+  el.data(type).split(' ').forEach(function (id) {
+    $("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
+  });
+};
+
+var Triggers = {
+  Listeners: {
+    Basic: {},
+    Global: {}
+  },
+  Initializers: {}
+};
+Triggers.Listeners.Basic = {
+  openListener: function openListener() {
+    triggers($(this), 'open');
+  },
+  closeListener: function closeListener() {
+    var id = $(this).data('close');
+
+    if (id) {
+      triggers($(this), 'close');
+    } else {
+      $(this).trigger('close.zf.trigger');
+    }
+  },
+  toggleListener: function toggleListener() {
+    var id = $(this).data('toggle');
+
+    if (id) {
+      triggers($(this), 'toggle');
+    } else {
+      $(this).trigger('toggle.zf.trigger');
+    }
+  },
+  closeableListener: function closeableListener(e) {
+    e.stopPropagation();
+    var animation = $(this).data('closable');
+
+    if (animation !== '') {
+      Motion.animateOut($(this), animation, function () {
+        $(this).trigger('closed.zf');
+      });
+    } else {
+      $(this).fadeOut().trigger('closed.zf');
+    }
+  },
+  toggleFocusListener: function toggleFocusListener() {
+    var id = $(this).data('toggle-focus');
+    $("#".concat(id)).triggerHandler('toggle.zf.trigger', [$(this)]);
+  }
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
+
+Triggers.Initializers.addOpenListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
+  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
+// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
+Triggers.Initializers.addCloseListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
+  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
+
+Triggers.Initializers.addToggleListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
+  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
+
+Triggers.Initializers.addCloseableListener = function ($elem) {
+  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
+  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
+
+Triggers.Initializers.addToggleFocusListener = function ($elem) {
+  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
+  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
+}; // More Global/complex listeners and triggers
+
+
+Triggers.Listeners.Global = {
+  resizeListener: function resizeListener($nodes) {
+    if (!MutationObserver) {
+      //fallback for IE 9
+      $nodes.each(function () {
+        $(this).triggerHandler('resizeme.zf.trigger');
+      });
+    } //trigger all listening elements and signal a resize event
+
+
+    $nodes.attr('data-events', "resize");
+  },
+  scrollListener: function scrollListener($nodes) {
+    if (!MutationObserver) {
+      //fallback for IE 9
+      $nodes.each(function () {
+        $(this).triggerHandler('scrollme.zf.trigger');
+      });
+    } //trigger all listening elements and signal a scroll event
+
+
+    $nodes.attr('data-events', "scroll");
+  },
+  closeMeListener: function closeMeListener(e, pluginId) {
+    var plugin = e.namespace.split('.')[0];
+    var plugins = $("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
+    plugins.each(function () {
+      var _this = $(this);
+
+      _this.triggerHandler('close.zf.trigger', [_this]);
+    });
+  } // Global, parses whole document.
+
+};
+
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = $('[data-yeti-box]'),
+      plugNames = ['dropdown', 'tooltip', 'reveal'];
+
+  if (pluginName) {
+    if (typeof pluginName === 'string') {
+      plugNames.push(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
+    } else {
+      console.error('Plugin names must be strings');
+    }
+  }
+
+  if (yetiBoxes.length) {
+    var listeners = plugNames.map(function (name) {
+      return "closeme.zf.".concat(name);
+    }).join(' ');
+    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+  }
+};
+
+function debounceGlobalListener(debounce, trigger, listener) {
+  var timer,
+      args = Array.prototype.slice.call(arguments, 3);
+  $(window).off(trigger).on(trigger, function (e) {
+    if (timer) {
+      clearTimeout(timer);
+    }
+
+    timer = setTimeout(function () {
+      listener.apply(null, args);
+    }, debounce || 10); //default time to emit scroll event
+  });
+}
+
+Triggers.Initializers.addResizeListener = function (debounce) {
+  var $nodes = $('[data-resize]');
+
+  if ($nodes.length) {
+    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
+  }
+};
+
+Triggers.Initializers.addScrollListener = function (debounce) {
+  var $nodes = $('[data-scroll]');
+
+  if ($nodes.length) {
+    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
+  }
+};
+
+Triggers.Initializers.addMutationEventsListener = function ($elem) {
+  if (!MutationObserver) {
+    return false;
+  }
+
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = $(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
+
+    switch (mutationRecordsList[0].type) {
+      case "attributes":
+        if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
+          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
+        }
+
+        if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
+          $target.triggerHandler('resizeme.zf.trigger', [$target]);
+        }
+
+        if (mutationRecordsList[0].attributeName === "style") {
+          $target.closest("[data-mutate]").attr("data-events", "mutate");
+          $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+        }
+
+        break;
+
+      case "childList":
+        $target.closest("[data-mutate]").attr("data-events", "mutate");
+        $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+        break;
+
+      default:
+        return false;
+      //nothing
+    }
+  };
+
+  if ($nodes.length) {
+    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
+    for (var i = 0; i <= $nodes.length - 1; i++) {
+      var elementObserver = new MutationObserver(listeningElementsMutation);
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
+    }
+  }
+};
+
+Triggers.Initializers.addSimpleListeners = function () {
+  var $document = $(document);
+  Triggers.Initializers.addOpenListener($document);
+  Triggers.Initializers.addCloseListener($document);
+  Triggers.Initializers.addToggleListener($document);
+  Triggers.Initializers.addCloseableListener($document);
+  Triggers.Initializers.addToggleFocusListener($document);
+};
+
+Triggers.Initializers.addGlobalListeners = function () {
+  var $document = $(document);
+  Triggers.Initializers.addMutationEventsListener($document);
+  Triggers.Initializers.addResizeListener();
+  Triggers.Initializers.addScrollListener();
+  Triggers.Initializers.addClosemeListener();
+};
+
+Triggers.init = function ($$$1, Foundation) {
+  onLoad($$$1(window), function () {
+    if ($$$1.triggersInitialized !== true) {
+      Triggers.Initializers.addSimpleListeners();
+      Triggers.Initializers.addGlobalListeners();
+      $$$1.triggersInitialized = true;
+    }
+  });
+
+  if (Foundation) {
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
+    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
+  }
+};
+
+// {function} _setup (replaces previous constructor),
+// {function} _destroy (replaces previous destroy)
+
+var Plugin =
+/*#__PURE__*/
+function () {
+  function Plugin(element, options) {
+    _classCallCheck(this, Plugin);
+
+    this._setup(element, options);
+
+    var pluginName = getPluginName(this);
+    this.uuid = GetYoDigits(6, pluginName);
+
+    if (!this.$element.attr("data-".concat(pluginName))) {
+      this.$element.attr("data-".concat(pluginName), this.uuid);
+    }
+
+    if (!this.$element.data('zfPlugin')) {
+      this.$element.data('zfPlugin', this);
+    }
+    /**
+     * Fires when the plugin has initialized.
+     * @event Plugin#init
+     */
+
+
+    this.$element.trigger("init.zf.".concat(pluginName));
+  }
+
+  _createClass(Plugin, [{
+    key: "destroy",
+    value: function destroy() {
+      this._destroy();
+
+      var pluginName = getPluginName(this);
+      this.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin')
+      /**
+       * Fires when the plugin has been destroyed.
+       * @event Plugin#destroyed
+       */
+      .trigger("destroyed.zf.".concat(pluginName));
+
+      for (var prop in this) {
+        this[prop] = null; //clean up script to prep for garbage collection.
+      }
+    }
+  }]);
+
+  return Plugin;
+}(); // Convert PascalCase to kebab-case
+// Thank you: http://stackoverflow.com/a/8955580
+
+
+function hyphenate$1(str) {
+  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
+}
+
+function getPluginName(obj) {
+  if (typeof obj.constructor.name !== 'undefined') {
+    return hyphenate$1(obj.constructor.name);
+  } else {
+    return hyphenate$1(obj.className);
+  }
+}
+
+/**
+ * Abide module.
+ * @module foundation.abide
+ */
+
+var Abide =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Abide, _Plugin);
+
+  function Abide() {
+    _classCallCheck(this, Abide);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Abide).apply(this, arguments));
+  }
+
+  _createClass(Abide, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Abide.
+     * @class
+     * @name Abide
+     * @fires Abide#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element) {
+      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+      this.$element = element;
+      this.options = $.extend(true, {}, Abide.defaults, this.$element.data(), options);
+      this.className = 'Abide'; // ie9 back compat
+
+      this._init();
+    }
+    /**
+     * Initializes the Abide plugin and calls functions to get Abide functioning on load.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      this.$inputs = $.merge( // Consider as input to validate:
+      this.$element.find('input').not('[type=submit]'), // * all input fields expect submit
+      this.$element.find('textarea, select') // * all textareas and select fields
+      );
+      var $globalErrors = this.$element.find('[data-abide-error]'); // Add a11y attributes to all fields
+
+      if (this.options.a11yAttributes) {
+        this.$inputs.each(function (i, input) {
+          return _this2.addA11yAttributes($(input));
+        });
+        $globalErrors.each(function (i, error) {
+          return _this2.addGlobalErrorA11yAttributes($(error));
+        });
+      }
+
+      this._events();
+    }
+    /**
+     * Initializes events for Abide.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this3 = this;
+
+      this.$element.off('.abide').on('reset.zf.abide', function () {
+        _this3.resetForm();
+      }).on('submit.zf.abide', function () {
+        return _this3.validateForm();
+      });
+
+      if (this.options.validateOn === 'fieldChange') {
+        this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) {
+          _this3.validateInput($(e.target));
+        });
+      }
+
+      if (this.options.liveValidate) {
+        this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) {
+          _this3.validateInput($(e.target));
+        });
+      }
+
+      if (this.options.validateOnBlur) {
+        this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) {
+          _this3.validateInput($(e.target));
+        });
+      }
+    }
+    /**
+     * Calls necessary functions to update Abide upon DOM change
+     * @private
+     */
+
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      this._init();
+    }
+    /**
+     * Checks whether or not a form element has the required attribute and if it's checked or not
+     * @param {Object} element - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
+
+  }, {
+    key: "requiredCheck",
+    value: function requiredCheck($el) {
+      if (!$el.attr('required')) return true;
+      var isGood = true;
+
+      switch ($el[0].type) {
+        case 'checkbox':
+          isGood = $el[0].checked;
+          break;
+
+        case 'select':
+        case 'select-one':
+        case 'select-multiple':
+          var opt = $el.find('option:selected');
+          if (!opt.length || !opt.val()) isGood = false;
+          break;
+
+        default:
+          if (!$el.val() || !$el.val().length) isGood = false;
+      }
+
+      return isGood;
+    }
+    /**
+     * Get:
+     * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:
+     *   1. The element's direct sibling('s).
+     *   2. The element's parent's children.
+     * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.
+     *
+     * This allows for multiple form errors per input, though if none are found, no form errors will be shown.
+     *
+     * @param {Object} $el - jQuery object to use as reference to find the form error selector.
+     * @returns {Object} jQuery object with the selector.
+     */
+
+  }, {
+    key: "findFormError",
+    value: function findFormError($el) {
+      var id = $el[0].id;
+      var $error = $el.siblings(this.options.formErrorSelector);
+
+      if (!$error.length) {
+        $error = $el.parent().find(this.options.formErrorSelector);
+      }
+
+      if (id) {
+        $error = $error.add(this.$element.find("[data-form-error-for=\"".concat(id, "\"]")));
+      }
+
+      return $error;
+    }
+    /**
+     * Get the first element in this order:
+     * 2. The <label> with the attribute `[for="someInputId"]`
+     * 3. The `.closest()` <label>
+     *
+     * @param {Object} $el - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
+
+  }, {
+    key: "findLabel",
+    value: function findLabel($el) {
+      var id = $el[0].id;
+      var $label = this.$element.find("label[for=\"".concat(id, "\"]"));
+
+      if (!$label.length) {
+        return $el.closest('label');
+      }
+
+      return $label;
+    }
+    /**
+     * Get the set of labels associated with a set of radio els in this order
+     * 2. The <label> with the attribute `[for="someInputId"]`
+     * 3. The `.closest()` <label>
+     *
+     * @param {Object} $el - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
+
+  }, {
+    key: "findRadioLabels",
+    value: function findRadioLabels($els) {
+      var _this4 = this;
+
+      var labels = $els.map(function (i, el) {
+        var id = el.id;
+
+        var $label = _this4.$element.find("label[for=\"".concat(id, "\"]"));
+
+        if (!$label.length) {
+          $label = $(el).closest('label');
+        }
+
+        return $label[0];
+      });
+      return $(labels);
+    }
+    /**
+     * Adds the CSS error class as specified by the Abide settings to the label, input, and the form
+     * @param {Object} $el - jQuery object to add the class to
+     */
+
+  }, {
+    key: "addErrorClasses",
+    value: function addErrorClasses($el) {
+      var $label = this.findLabel($el);
+      var $formError = this.findFormError($el);
+
+      if ($label.length) {
+        $label.addClass(this.options.labelErrorClass);
+      }
+
+      if ($formError.length) {
+        $formError.addClass(this.options.formErrorClass);
+      }
+
+      $el.addClass(this.options.inputErrorClass).attr({
+        'data-invalid': '',
+        'aria-invalid': true
+      });
+    }
+    /**
+     * Adds [for] and [role=alert] attributes to all form error targetting $el,
+     * and [aria-describedby] attribute to $el toward the first form error.
+     * @param {Object} $el - jQuery object
+     */
+
+  }, {
+    key: "addA11yAttributes",
+    value: function addA11yAttributes($el) {
+      var $errors = this.findFormError($el);
+      var $labels = $errors.filter('label');
+      var $error = $errors.first();
+      if (!$errors.length) return; // Set [aria-describedby] on the input toward the first form error if it is not set
+
+      if (typeof $el.attr('aria-describedby') === 'undefined') {
+        // Get the first error ID or create one
+        var errorId = $error.attr('id');
+
+        if (typeof errorId === 'undefined') {
+          errorId = GetYoDigits(6, 'abide-error');
+          $error.attr('id', errorId);
+        }
+        $el.attr('aria-describedby', errorId);
+      }
+
+      if ($labels.filter('[for]').length < $labels.length) {
+        // Get the input ID or create one
+        var elemId = $el.attr('id');
+
+        if (typeof elemId === 'undefined') {
+          elemId = GetYoDigits(6, 'abide-input');
+          $el.attr('id', elemId);
+        }
+
+        $labels.each(function (i, label) {
+          var $label = $(label);
+          if (typeof $label.attr('for') === 'undefined') $label.attr('for', elemId);
+        });
+      } // For each error targeting $el, set [role=alert] if it is not set.
+
+
+      $errors.each(function (i, label) {
+        var $label = $(label);
+        if (typeof $label.attr('role') === 'undefined') $label.attr('role', 'alert');
+      }).end();
+    }
+    /**
+     * Adds [aria-live] attribute to the given global form error $el.
+     * @param {Object} $el - jQuery object to add the attribute to
+     */
+
+  }, {
+    key: "addGlobalErrorA11yAttributes",
+    value: function addGlobalErrorA11yAttributes($el) {
+      if (typeof $el.attr('aria-live') === 'undefined') $el.attr('aria-live', this.options.a11yErrorLevel);
+    }
+    /**
+     * Remove CSS error classes etc from an entire radio button group
+     * @param {String} groupName - A string that specifies the name of a radio button group
+     *
+     */
+
+  }, {
+    key: "removeRadioErrorClasses",
+    value: function removeRadioErrorClasses(groupName) {
+      var $els = this.$element.find(":radio[name=\"".concat(groupName, "\"]"));
+      var $labels = this.findRadioLabels($els);
+      var $formErrors = this.findFormError($els);
+
+      if ($labels.length) {
+        $labels.removeClass(this.options.labelErrorClass);
+      }
+
+      if ($formErrors.length) {
+        $formErrors.removeClass(this.options.formErrorClass);
+      }
+
+      $els.removeClass(this.options.inputErrorClass).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+    }
+    /**
+     * Removes CSS error class as specified by the Abide settings from the label, input, and the form
+     * @param {Object} $el - jQuery object to remove the class from
+     */
+
+  }, {
+    key: "removeErrorClasses",
+    value: function removeErrorClasses($el) {
+      // radios need to clear all of the els
+      if ($el[0].type == 'radio') {
+        return this.removeRadioErrorClasses($el.attr('name'));
+      }
+
+      var $label = this.findLabel($el);
+      var $formError = this.findFormError($el);
+
+      if ($label.length) {
+        $label.removeClass(this.options.labelErrorClass);
+      }
+
+      if ($formError.length) {
+        $formError.removeClass(this.options.formErrorClass);
+      }
+
+      $el.removeClass(this.options.inputErrorClass).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+    }
+    /**
+     * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.
+     * Ignores inputs with data-abide-ignore, type="hidden" or disabled attributes set
+     * @fires Abide#invalid
+     * @fires Abide#valid
+     * @param {Object} element - jQuery object to validate, should be an HTML input
+     * @returns {Boolean} goodToGo - If the input is valid or not.
+     */
+
+  }, {
+    key: "validateInput",
+    value: function validateInput($el) {
+      var clearRequire = this.requiredCheck($el),
+          validated = false,
+          customValidator = true,
+          validator = $el.attr('data-validator'),
+          equalTo = true; // don't validate ignored inputs or hidden inputs or disabled inputs
+
+      if ($el.is('[data-abide-ignore]') || $el.is('[type="hidden"]') || $el.is('[disabled]')) {
+        return true;
+      }
+
+      switch ($el[0].type) {
+        case 'radio':
+          validated = this.validateRadio($el.attr('name'));
+          break;
+
+        case 'checkbox':
+          validated = clearRequire;
+          break;
+
+        case 'select':
+        case 'select-one':
+        case 'select-multiple':
+          validated = clearRequire;
+          break;
+
+        default:
+          validated = this.validateText($el);
+      }
+
+      if (validator) {
+        customValidator = this.matchValidation($el, validator, $el.attr('required'));
+      }
+
+      if ($el.attr('data-equalto')) {
+        equalTo = this.options.validators.equalTo($el);
+      }
+
+      var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;
+      var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';
+
+      if (goodToGo) {
+        // Re-validate inputs that depend on this one with equalto
+        var dependentElements = this.$element.find("[data-equalto=\"".concat($el.attr('id'), "\"]"));
+
+        if (dependentElements.length) {
+          var _this = this;
+
+          dependentElements.each(function () {
+            if ($(this).val()) {
+              _this.validateInput($(this));
+            }
+          });
+        }
+      }
+
+      this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);
+      /**
+       * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`
+       * Trigger includes the DOM element of the input.
+       * @event Abide#valid
+       * @event Abide#invalid
+       */
+
+      $el.trigger(message, [$el]);
+      return goodToGo;
+    }
+    /**
+     * Goes through a form and if there are any invalid inputs, it will display the form error element
+     * @returns {Boolean} noError - true if no errors were detected...
+     * @fires Abide#formvalid
+     * @fires Abide#forminvalid
+     */
+
+  }, {
+    key: "validateForm",
+    value: function validateForm() {
+      var _this5 = this;
+
+      var acc = [];
+
+      var _this = this;
+
+      this.$inputs.each(function () {
+        acc.push(_this.validateInput($(this)));
+      });
+      var noError = acc.indexOf(false) === -1;
+      this.$element.find('[data-abide-error]').each(function (i, elem) {
+        var $elem = $(elem); // Ensure a11y attributes are set
+
+        if (_this5.options.a11yAttributes) _this5.addGlobalErrorA11yAttributes($elem); // Show or hide the error
+
+        $elem.css('display', noError ? 'none' : 'block');
+      });
+      /**
+       * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.
+       * Trigger includes the element of the form.
+       * @event Abide#formvalid
+       * @event Abide#forminvalid
+       */
+
+      this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);
+      return noError;
+    }
+    /**
+     * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.
+     * @param {Object} $el - jQuery object to validate, should be a text input HTML element
+     * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns
+     * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified
+     */
+
+  }, {
+    key: "validateText",
+    value: function validateText($el, pattern) {
+      // A pattern can be passed to this function, or it will be infered from the input's "pattern" attribute, or it's "type" attribute
+      pattern = pattern || $el.attr('pattern') || $el.attr('type');
+      var inputText = $el.val();
+      var valid = false;
+
+      if (inputText.length) {
+        // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp
+        if (this.options.patterns.hasOwnProperty(pattern)) {
+          valid = this.options.patterns[pattern].test(inputText);
+        } // If the pattern name isn't also the type attribute of the field, then test it as a regexp
+        else if (pattern !== $el.attr('type')) {
+            valid = new RegExp(pattern).test(inputText);
+          } else {
+            valid = true;
+          }
+      } // An empty field is valid if it's not required
+      else if (!$el.prop('required')) {
+          valid = true;
+        }
+
+      return valid;
+    }
+    /**
+     * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.
+     * @param {String} groupName - A string that specifies the name of a radio button group
+     * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)
+     */
+
+  }, {
+    key: "validateRadio",
+    value: function validateRadio(groupName) {
+      // If at least one radio in the group has the `required` attribute, the group is considered required
+      // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice
+      var $group = this.$element.find(":radio[name=\"".concat(groupName, "\"]"));
+      var valid = false,
+          required = false; // For the group to be required, at least one radio needs to be required
+
+      $group.each(function (i, e) {
+        if ($(e).attr('required')) {
+          required = true;
+        }
+      });
+      if (!required) valid = true;
+
+      if (!valid) {
+        // For the group to be valid, at least one radio needs to be checked
+        $group.each(function (i, e) {
+          if ($(e).prop('checked')) {
+            valid = true;
+          }
+        });
+      }
+      return valid;
+    }
+    /**
+     * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator="foo bar baz"` in a space separated listed.
+     * @param {Object} $el - jQuery input element.
+     * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.
+     * @param {Boolean} required - self explanatory?
+     * @returns {Boolean} - true if validations passed.
+     */
+
+  }, {
+    key: "matchValidation",
+    value: function matchValidation($el, validators, required) {
+      var _this6 = this;
+
+      required = required ? true : false;
+      var clear = validators.split(' ').map(function (v) {
+        return _this6.options.validators[v]($el, required, $el.parent());
+      });
+      return clear.indexOf(false) === -1;
+    }
+    /**
+     * Resets form inputs and styles
+     * @fires Abide#formreset
+     */
+
+  }, {
+    key: "resetForm",
+    value: function resetForm() {
+      var $form = this.$element,
+          opts = this.options;
+      $(".".concat(opts.labelErrorClass), $form).not('small').removeClass(opts.labelErrorClass);
+      $(".".concat(opts.inputErrorClass), $form).not('small').removeClass(opts.inputErrorClass);
+      $("".concat(opts.formErrorSelector, ".").concat(opts.formErrorClass)).removeClass(opts.formErrorClass);
+      $form.find('[data-abide-error]').css('display', 'none');
+      $(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      $(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      /**
+       * Fires when the form has been reset.
+       * @event Abide#formreset
+       */
+
+      $form.trigger('formreset.zf.abide', [$form]);
+    }
+    /**
+     * Destroys an instance of Abide.
+     * Removes error styles and classes from elements, without resetting their values.
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      var _this = this;
+
+      this.$element.off('.abide').find('[data-abide-error]').css('display', 'none');
+      this.$inputs.off('.abide').each(function () {
+        _this.removeErrorClasses($(this));
+      });
+    }
+  }]);
+
+  return Abide;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+Abide.defaults = {
+  /**
+   * The default event to validate inputs. Checkboxes and radios validate immediately.
+   * Remove or change this value for manual validation.
+   * @option
+   * @type {?string}
+   * @default 'fieldChange'
+   */
+  validateOn: 'fieldChange',
+
+  /**
+   * Class to be applied to input labels on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-invalid-label'
+   */
+  labelErrorClass: 'is-invalid-label',
+
+  /**
+   * Class to be applied to inputs on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-invalid-input'
+   */
+  inputErrorClass: 'is-invalid-input',
+
+  /**
+   * Class selector to use to target Form Errors for show/hide.
+   * @option
+   * @type {string}
+   * @default '.form-error'
+   */
+  formErrorSelector: '.form-error',
+
+  /**
+   * Class added to Form Errors on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-visible'
+   */
+  formErrorClass: 'is-visible',
+
+  /**
+   * If true, automatically insert when possible:
+   * - `[aria-describedby]` on fields
+   * - `[role=alert]` on form errors and `[for]` on form error labels
+   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  a11yAttributes: true,
+
+  /**
+   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.
+   * Options are: 'assertive', 'polite' and 'off'/null
+   * @option
+   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions
+   * @type {string}
+   * @default 'assertive'
+   */
+  a11yErrorLevel: 'assertive',
+
+  /**
+   * Set to true to validate text inputs on any value change.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  liveValidate: false,
+
+  /**
+   * Set to true to validate inputs on blur.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  validateOnBlur: false,
+  patterns: {
+    alpha: /^[a-zA-Z]+$/,
+    alpha_numeric: /^[a-zA-Z0-9]+$/,
+    integer: /^[-+]?\d+$/,
+    number: /^[-+]?\d*(?:[\.\,]\d+)?$/,
+    // amex, visa, diners
+    card: /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,
+    cvv: /^([0-9]){3,4}$/,
+    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address
+    email: /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,
+    // From CommonRegexJS (@talyssonoc)
+    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76
+    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.
+    url: /^((?:(https?|ftps?|file|ssh|sftp):\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\))+(?:\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?\xab\xbb\u201c\u201d\u2018\u2019]))$/,
+    // abc.de
+    domain: /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,
+    datetime: /^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,
+    // YYYY-MM-DD
+    date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,
+    // HH:MM:SS
+    time: /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,
+    dateISO: /^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,
+    // MM/DD/YYYY
+    month_day_year: /^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,
+    // DD/MM/YYYY
+    day_month_year: /^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,
+    // #FFF or #FFFFFF
+    color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,
+    // Domain || URL
+    website: {
+      test: function test(text) {
+        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);
+      }
+    }
+  },
+
+  /**
+   * Optional validation functions to be used. `equalTo` being the only default included function.
+   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:
+   * el : The jQuery element to validate.
+   * required : Boolean value of the required attribute be present or not.
+   * parent : The direct parent of the input.
+   * @option
+   */
+  validators: {
+    equalTo: function equalTo(el, required, parent) {
+      return $("#".concat(el.attr('data-equalto'))).val() === el.val();
+    }
+  }
+};
+
+/**
+ * Accordion module.
+ * @module foundation.accordion
+ * @requires foundation.util.keyboard
+ */
+
+var Accordion =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Accordion, _Plugin);
+
+  function Accordion() {
+    _classCallCheck(this, Accordion);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Accordion).apply(this, arguments));
+  }
+
+  _createClass(Accordion, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of an accordion.
+     * @class
+     * @name Accordion
+     * @fires Accordion#init
+     * @param {jQuery} element - jQuery object to make into an accordion.
+     * @param {Object} options - a plain object with settings to override the default options.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);
+      this.className = 'Accordion'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('Accordion', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
+        'ARROW_DOWN': 'next',
+        'ARROW_UP': 'previous'
+      });
+    }
+    /**
+     * Initializes the accordion by animating the preset active pane(s).
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      this._isInitializing = true;
+      this.$element.attr('role', 'tablist');
+      this.$tabs = this.$element.children('[data-accordion-item]');
+      this.$tabs.each(function (idx, el) {
+        var $el = $(el),
+            $content = $el.children('[data-tab-content]'),
+            id = $content[0].id || GetYoDigits(6, 'accordion'),
+            linkId = el.id ? "".concat(el.id, "-label") : "".concat(id, "-label");
+        $el.find('a:first').attr({
+          'aria-controls': id,
+          'role': 'tab',
+          'id': linkId,
+          'aria-expanded': false,
+          'aria-selected': false
+        });
+        $content.attr({
+          'role': 'tabpanel',
+          'aria-labelledby': linkId,
+          'aria-hidden': true,
+          'id': id
+        });
+      });
+      var $initActive = this.$element.find('.is-active').children('[data-tab-content]');
+
+      if ($initActive.length) {
+        // Save up the initial hash to return to it later when going back in history
+        this._initialAnchor = $initActive.prev('a').attr('href');
+
+        this._openSingleTab($initActive);
+      }
+
+      this._checkDeepLink = function () {
+        var anchor = window.location.hash;
+
+        if (!anchor.length) {
+          // If we are still initializing and there is no anchor, then there is nothing to do
+          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor
+
+          if (_this2._initialAnchor) anchor = _this2._initialAnchor;
+        }
+
+        var $anchor = anchor && $(anchor);
+
+        var $link = anchor && _this2.$element.find("[href$=\"".concat(anchor, "\"]")); // Whether the anchor element that has been found is part of this element
+
+
+        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, open it (if not already active)
+
+        if ($anchor && $link && $link.length) {
+          if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {
+            _this2._openSingleTab($anchor);
+          }
+        } // Otherwise, close everything
+        else {
+            _this2._closeAllTabs();
+          }
+
+        if (isOwnAnchor) {
+          // Roll up a little to show the titles
+          if (_this2.options.deepLinkSmudge) {
+            onLoad($(window), function () {
+              var offset = _this2.$element.offset();
+
+              $('html, body').animate({
+                scrollTop: offset.top
+              }, _this2.options.deepLinkSmudgeDelay);
+            });
+          }
+          /**
+           * Fires when the plugin has deeplinked at pageload
+           * @event Accordion#deeplink
+           */
+
+
+          _this2.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);
+        }
+      }; //use browser to open a tab, if it exists in this tabset
+
+
+      if (this.options.deepLink) {
+        this._checkDeepLink();
+      }
+
+      this._events();
+
+      this._isInitializing = false;
+    }
+    /**
+     * Adds event handlers for items within the accordion.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      this.$tabs.each(function () {
+        var $elem = $(this);
+        var $tabContent = $elem.children('[data-tab-content]');
+
+        if ($tabContent.length) {
+          $elem.children('a').off('click.zf.accordion keydown.zf.accordion').on('click.zf.accordion', function (e) {
+            e.preventDefault();
+
+            _this.toggle($tabContent);
+          }).on('keydown.zf.accordion', function (e) {
+            Keyboard.handleKey(e, 'Accordion', {
+              toggle: function toggle() {
+                _this.toggle($tabContent);
+              },
+              next: function next() {
+                var $a = $elem.next().find('a').focus();
+
+                if (!_this.options.multiExpand) {
+                  $a.trigger('click.zf.accordion');
+                }
+              },
+              previous: function previous() {
+                var $a = $elem.prev().find('a').focus();
+
+                if (!_this.options.multiExpand) {
+                  $a.trigger('click.zf.accordion');
+                }
+              },
+              handled: function handled() {
+                e.preventDefault();
+                e.stopPropagation();
+              }
+            });
+          });
+        }
+      });
+
+      if (this.options.deepLink) {
+        $(window).on('hashchange', this._checkDeepLink);
+      }
+    }
+    /**
+     * Toggles the selected content pane's open/close state.
+     * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle($target) {
+      if ($target.closest('[data-accordion]').is('[disabled]')) {
+        console.info('Cannot toggle an accordion that is disabled.');
+        return;
+      }
+
+      if ($target.parent().hasClass('is-active')) {
+        this.up($target);
+      } else {
+        this.down($target);
+      } //either replace or update browser history
+
+
+      if (this.options.deepLink) {
+        var anchor = $target.prev('a').attr('href');
+
+        if (this.options.updateHistory) {
+          history.pushState({}, '', anchor);
+        } else {
+          history.replaceState({}, '', anchor);
+        }
+      }
+    }
+    /**
+     * Opens the accordion tab defined by `$target`.
+     * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).
+     * @fires Accordion#down
+     * @function
+     */
+
+  }, {
+    key: "down",
+    value: function down($target) {
+      if ($target.closest('[data-accordion]').is('[disabled]')) {
+        console.info('Cannot call down on an accordion that is disabled.');
+        return;
+      }
+
+      if (this.options.multiExpand) this._openTab($target);else this._openSingleTab($target);
+    }
+    /**
+     * Closes the tab defined by `$target`.
+     * It may be ignored if the Accordion options don't allow it.
+     *
+     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+     * @fires Accordion#up
+     * @function
+     */
+
+  }, {
+    key: "up",
+    value: function up($target) {
+      if (this.$element.is('[disabled]')) {
+        console.info('Cannot call up on an accordion that is disabled.');
+        return;
+      } // Don't close the item if it is already closed
+
+
+      var $targetItem = $target.parent();
+      if (!$targetItem.hasClass('is-active')) return; // Don't close the item if there is no other active item (unless with `allowAllClosed`)
+
+      var $othersItems = $targetItem.siblings();
+      if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;
+
+      this._closeTab($target);
+    }
+    /**
+     * Make the tab defined by `$target` the only opened tab, closing all others tabs.
+     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_openSingleTab",
+    value: function _openSingleTab($target) {
+      // Close all the others active tabs.
+      var $activeContents = this.$element.children('.is-active').children('[data-tab-content]');
+
+      if ($activeContents.length) {
+        this._closeTab($activeContents.not($target));
+      } // Then open the target.
+
+
+      this._openTab($target);
+    }
+    /**
+     * Opens the tab defined by `$target`.
+     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+     * @fires Accordion#down
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_openTab",
+    value: function _openTab($target) {
+      var _this3 = this;
+
+      var $targetItem = $target.parent();
+      var targetContentId = $target.attr('aria-labelledby');
+      $target.attr('aria-hidden', false);
+      $targetItem.addClass('is-active');
+      $("#".concat(targetContentId)).attr({
+        'aria-expanded': true,
+        'aria-selected': true
+      });
+      $target.slideDown(this.options.slideSpeed, function () {
+        /**
+         * Fires when the tab is done opening.
+         * @event Accordion#down
+         */
+        _this3.$element.trigger('down.zf.accordion', [$target]);
+      });
+    }
+    /**
+     * Closes the tab defined by `$target`.
+     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+     * @fires Accordion#up
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_closeTab",
+    value: function _closeTab($target) {
+      var _this4 = this;
+
+      var $targetItem = $target.parent();
+      var targetContentId = $target.attr('aria-labelledby');
+      $target.attr('aria-hidden', true);
+      $targetItem.removeClass('is-active');
+      $("#".concat(targetContentId)).attr({
+        'aria-expanded': false,
+        'aria-selected': false
+      });
+      $target.slideUp(this.options.slideSpeed, function () {
+        /**
+         * Fires when the tab is done collapsing up.
+         * @event Accordion#up
+         */
+        _this4.$element.trigger('up.zf.accordion', [$target]);
+      });
+    }
+    /**
+     * Closes all active tabs
+     * @fires Accordion#up
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_closeAllTabs",
+    value: function _closeAllTabs() {
+      var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');
+
+      if ($activeTabs.length) {
+        this._closeTab($activeTabs);
+      }
+    }
+    /**
+     * Destroys an instance of an accordion.
+     * @fires Accordion#destroyed
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');
+      this.$element.find('a').off('.zf.accordion');
+
+      if (this.options.deepLink) {
+        $(window).off('hashchange', this._checkDeepLink);
+      }
+    }
+  }]);
+
+  return Accordion;
+}(Plugin);
+
+Accordion.defaults = {
+  /**
+   * Amount of time to animate the opening of an accordion pane.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  slideSpeed: 250,
+
+  /**
+   * Allow the accordion to have multiple open panes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  multiExpand: false,
+
+  /**
+   * Allow the accordion to close all panes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowAllClosed: false,
+
+  /**
+   * Link the location hash to the open pane.
+   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+
+  /**
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinkSmudge: false,
+
+  /**
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
+   * @option
+   * @type {number}
+   * @default 300
+   */
+  deepLinkSmudgeDelay: 300,
+
+  /**
+   * If `deepLink` is enabled, update the browser history with the open accordion
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  updateHistory: false
+};
+
+/**
+ * AccordionMenu module.
+ * @module foundation.accordionMenu
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.nest
+ */
+
+var AccordionMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(AccordionMenu, _Plugin);
+
+  function AccordionMenu() {
+    _classCallCheck(this, AccordionMenu);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(AccordionMenu).apply(this, arguments));
+  }
+
+  _createClass(AccordionMenu, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of an accordion menu.
+     * @class
+     * @name AccordionMenu
+     * @fires AccordionMenu#init
+     * @param {jQuery} element - jQuery object to make into an accordion menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);
+      this.className = 'AccordionMenu'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('AccordionMenu', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
+        'ARROW_RIGHT': 'open',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'close',
+        'ESCAPE': 'closeAll'
+      });
+    }
+    /**
+     * Initializes the accordion menu by hiding all nested menus.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      Nest.Feather(this.$element, 'accordion');
+
+      var _this = this;
+
+      this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');
+
+      this.$element.attr({
+        'role': 'tree',
+        'aria-multiselectable': this.options.multiOpen
+      });
+      this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');
+      this.$menuLinks.each(function () {
+        var linkId = this.id || GetYoDigits(6, 'acc-menu-link'),
+            $elem = $(this),
+            $sub = $elem.children('[data-submenu]'),
+            subId = $sub[0].id || GetYoDigits(6, 'acc-menu'),
+            isActive = $sub.hasClass('is-active');
+
+        if (_this.options.parentLink) {
+          var $anchor = $elem.children('a');
+          $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-accordion-submenu-item"></li>');
+        }
+
+        if (_this.options.submenuToggle) {
+          $elem.addClass('has-submenu-toggle');
+          $elem.children('a').after('<button id="' + linkId + '" class="submenu-toggle" aria-controls="' + subId + '" aria-expanded="' + isActive + '" title="' + _this.options.submenuToggleText + '"><span class="submenu-toggle-text">' + _this.options.submenuToggleText + '</span></button>');
+        } else {
+          $elem.attr({
+            'aria-controls': subId,
+            'aria-expanded': isActive,
+            'id': linkId
+          });
+        }
+
+        $sub.attr({
+          'aria-labelledby': linkId,
+          'aria-hidden': !isActive,
+          'role': 'group',
+          'id': subId
+        });
+      });
+      this.$element.find('li').attr({
+        'role': 'treeitem'
+      });
+      var initPanes = this.$element.find('.is-active');
+
+      if (initPanes.length) {
+        var _this = this;
+
+        initPanes.each(function () {
+          _this.down($(this));
+        });
+      }
+
+      this._events();
+    }
+    /**
+     * Adds event handlers for items within the menu.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      this.$element.find('li').each(function () {
+        var $submenu = $(this).children('[data-submenu]');
+
+        if ($submenu.length) {
+          if (_this.options.submenuToggle) {
+            $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
+              _this.toggle($submenu);
+            });
+          } else {
+            $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
+              e.preventDefault();
+
+              _this.toggle($submenu);
+            });
+          }
+        }
+      }).on('keydown.zf.accordionmenu', function (e) {
+        var $element = $(this),
+            $elements = $element.parent('ul').children('li'),
+            $prevElement,
+            $nextElement,
+            $target = $element.children('[data-submenu]');
+        $elements.each(function (i) {
+          if ($(this).is($element)) {
+            $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first();
+            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first();
+
+            if ($(this).children('[data-submenu]:visible').length) {
+              // has open sub menu
+              $nextElement = $element.find('li:first-child').find('a').first();
+            }
+
+            if ($(this).is(':first-child')) {
+              // is first element of sub menu
+              $prevElement = $element.parents('li').first().find('a').first();
+            } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) {
+              // if previous element has open sub menu
+              $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();
+            }
+
+            if ($(this).is(':last-child')) {
+              // is last element of sub menu
+              $nextElement = $element.parents('li').first().next('li').find('a').first();
+            }
+
+            return;
+          }
+        });
+        Keyboard.handleKey(e, 'AccordionMenu', {
+          open: function open() {
+            if ($target.is(':hidden')) {
+              _this.down($target);
+
+              $target.find('li').first().find('a').first().focus();
+            }
+          },
+          close: function close() {
+            if ($target.length && !$target.is(':hidden')) {
+              // close active sub of this item
+              _this.up($target);
+            } else if ($element.parent('[data-submenu]').length) {
+              // close currently open sub
+              _this.up($element.parent('[data-submenu]'));
+
+              $element.parents('li').first().find('a').first().focus();
+            }
+          },
+          up: function up() {
+            $prevElement.focus();
+            return true;
+          },
+          down: function down() {
+            $nextElement.focus();
+            return true;
+          },
+          toggle: function toggle() {
+            if (_this.options.submenuToggle) {
+              return false;
+            }
+
+            if ($element.children('[data-submenu]').length) {
+              _this.toggle($element.children('[data-submenu]'));
+
+              return true;
+            }
+          },
+          closeAll: function closeAll() {
+            _this.hideAll();
+          },
+          handled: function handled(preventDefault) {
+            if (preventDefault) {
+              e.preventDefault();
+            }
+
+            e.stopImmediatePropagation();
+          }
+        });
+      }); //.attr('tabindex', 0);
+    }
+    /**
+     * Closes all panes of the menu.
+     * @function
+     */
+
+  }, {
+    key: "hideAll",
+    value: function hideAll() {
+      this.up(this.$element.find('[data-submenu]'));
+    }
+    /**
+     * Opens all panes of the menu.
+     * @function
+     */
+
+  }, {
+    key: "showAll",
+    value: function showAll() {
+      this.down(this.$element.find('[data-submenu]'));
+    }
+    /**
+     * Toggles the open/close state of a submenu.
+     * @function
+     * @param {jQuery} $target - the submenu to toggle
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle($target) {
+      if (!$target.is(':animated')) {
+        if (!$target.is(':hidden')) {
+          this.up($target);
+        } else {
+          this.down($target);
+        }
+      }
+    }
+    /**
+     * Opens the sub-menu defined by `$target`.
+     * @param {jQuery} $target - Sub-menu to open.
+     * @fires AccordionMenu#down
+     */
+
+  }, {
+    key: "down",
+    value: function down($target) {
+      var _this2 = this;
+
+      // If having multiple submenus active is disabled, close all the submenus
+      // that are not parents or children of the targeted submenu.
+      if (!this.options.multiOpen) {
+        // The "branch" of the targetted submenu, from the component root to
+        // the active submenus nested in it.
+        var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); // All the active submenus that are not in the branch.
+
+        var $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);
+        this.up($othersActiveSubmenus);
+      }
+
+      $target.addClass('is-active').attr({
+        'aria-hidden': false
+      });
+
+      if (this.options.submenuToggle) {
+        $target.prev('.submenu-toggle').attr({
+          'aria-expanded': true
+        });
+      } else {
+        $target.parent('.is-accordion-submenu-parent').attr({
+          'aria-expanded': true
+        });
+      }
+
+      $target.slideDown(this.options.slideSpeed, function () {
+        /**
+         * Fires when the menu is done opening.
+         * @event AccordionMenu#down
+         */
+        _this2.$element.trigger('down.zf.accordionMenu', [$target]);
+      });
+    }
+    /**
+     * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.
+     * @param {jQuery} $target - Sub-menu to close.
+     * @fires AccordionMenu#up
+     */
+
+  }, {
+    key: "up",
+    value: function up($target) {
+      var _this3 = this;
+
+      var $submenus = $target.find('[data-submenu]');
+      var $allmenus = $target.add($submenus);
+      $submenus.slideUp(0);
+      $allmenus.removeClass('is-active').attr('aria-hidden', true);
+
+      if (this.options.submenuToggle) {
+        $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);
+      } else {
+        $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);
+      }
+
+      $target.slideUp(this.options.slideSpeed, function () {
+        /**
+         * Fires when the menu is done collapsing up.
+         * @event AccordionMenu#up
+         */
+        _this3.$element.trigger('up.zf.accordionMenu', [$target]);
+      });
+    }
+    /**
+     * Destroys an instance of accordion menu.
+     * @fires AccordionMenu#destroyed
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.find('[data-submenu]').slideDown(0).css('display', '');
+      this.$element.find('a').off('click.zf.accordionMenu');
+      this.$element.find('[data-is-parent-link]').detach();
+
+      if (this.options.submenuToggle) {
+        this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');
+        this.$element.find('.submenu-toggle').remove();
+      }
+
+      Nest.Burn(this.$element, 'accordion');
+    }
+  }]);
+
+  return AccordionMenu;
+}(Plugin);
+
+AccordionMenu.defaults = {
+  /**
+   * Adds the parent link to the submenu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  parentLink: false,
+
+  /**
+   * Amount of time to animate the opening of a submenu in ms.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  slideSpeed: 250,
+
+  /**
+   * Adds a separate submenu toggle button. This allows the parent item to have a link.
+   * @option
+   * @example true
+   */
+  submenuToggle: false,
+
+  /**
+   * The text used for the submenu toggle if enabled. This is used for screen readers only.
+   * @option
+   * @example true
+   */
+  submenuToggleText: 'Toggle menu',
+
+  /**
+   * Allow the menu to have multiple open panes.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  multiOpen: true
+};
+
+/**
+ * Drilldown module.
+ * @module foundation.drilldown
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.nest
+ * @requires foundation.util.box
+ */
+
+var Drilldown =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Drilldown, _Plugin);
+
+  function Drilldown() {
+    _classCallCheck(this, Drilldown);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Drilldown).apply(this, arguments));
+  }
+
+  _createClass(Drilldown, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a drilldown menu.
+     * @class
+     * @name Drilldown
+     * @param {jQuery} element - jQuery object to make into an accordion menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);
+      this.className = 'Drilldown'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('Drilldown', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'previous',
+        'ESCAPE': 'close',
+        'TAB': 'down',
+        'SHIFT_TAB': 'up'
+      });
+    }
+    /**
+     * Initializes the drilldown by creating jQuery collections of elements
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      Nest.Feather(this.$element, 'drilldown');
+
+      if (this.options.autoApplyClass) {
+        this.$element.addClass('drilldown');
+      }
+
+      this.$element.attr({
+        'role': 'tree',
+        'aria-multiselectable': false
+      });
+      this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');
+      this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');
+      this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a'); // Set the main menu as current by default (unless a submenu is selected)
+      // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu
+
+      this.$currentMenu = this.$element;
+      this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown'));
+
+      this._prepareMenu();
+
+      this._registerEvents();
+
+      this._keyboardEvents();
+    }
+    /**
+     * prepares drilldown menu by setting attributes to links and elements
+     * sets a min height to prevent content jumping
+     * wraps the element if not already wrapped
+     * @private
+     * @function
+     */
+
+  }, {
+    key: "_prepareMenu",
+    value: function _prepareMenu() {
+      var _this = this; // if(!this.options.holdOpen){
+      //   this._menuLinkEvents();
+      // }
+
+
+      this.$submenuAnchors.each(function () {
+        var $link = $(this);
+        var $sub = $link.parent();
+
+        if (_this.options.parentLink) {
+          $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>');
+        }
+
+        $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);
+        $link.children('[data-submenu]').attr({
+          'aria-hidden': true,
+          'tabindex': 0,
+          'role': 'group'
+        });
+
+        _this._events($link);
+      });
+      this.$submenus.each(function () {
+        var $menu = $(this),
+            $back = $menu.find('.js-drilldown-back');
+
+        if (!$back.length) {
+          switch (_this.options.backButtonPosition) {
+            case "bottom":
+              $menu.append(_this.options.backButton);
+              break;
+
+            case "top":
+              $menu.prepend(_this.options.backButton);
+              break;
+
+            default:
+              console.error("Unsupported backButtonPosition value '" + _this.options.backButtonPosition + "'");
+          }
+        }
+
+        _this._back($menu);
+      });
+      this.$submenus.addClass('invisible');
+
+      if (!this.options.autoHeight) {
+        this.$submenus.addClass('drilldown-submenu-cover-previous');
+      } // create a wrapper on element if it doesn't exist.
+
+
+      if (!this.$element.parent().hasClass('is-drilldown')) {
+        this.$wrapper = $(this.options.wrapper).addClass('is-drilldown');
+        if (this.options.animateHeight) this.$wrapper.addClass('animate-height');
+        this.$element.wrap(this.$wrapper);
+      } // set wrapper
+
+
+      this.$wrapper = this.$element.parent();
+      this.$wrapper.css(this._getMaxDims());
+    }
+  }, {
+    key: "_resize",
+    value: function _resize() {
+      this.$wrapper.css({
+        'max-width': 'none',
+        'min-height': 'none'
+      }); // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths
+
+      this.$wrapper.css(this._getMaxDims());
+    }
+    /**
+     * Adds event handlers to elements in the menu.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the current menu item to add handlers to.
+     */
+
+  }, {
+    key: "_events",
+    value: function _events($elem) {
+      var _this = this;
+
+      $elem.off('click.zf.drilldown').on('click.zf.drilldown', function (e) {
+        if ($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) {
+          e.stopImmediatePropagation();
+          e.preventDefault();
+        } // if(e.target !== e.currentTarget.firstElementChild){
+        //   return false;
+        // }
+
+
+        _this._show($elem.parent('li'));
+
+        if (_this.options.closeOnClick) {
+          var $body = $('body');
+          $body.off('.zf.drilldown').on('click.zf.drilldown', function (e) {
+            if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target)) {
+              return;
+            }
+
+            e.preventDefault();
+
+            _this._hideAll();
+
+            $body.off('.zf.drilldown');
+          });
+        }
+      });
+    }
+    /**
+     * Adds event handlers to the menu element.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_registerEvents",
+    value: function _registerEvents() {
+      if (this.options.scrollTop) {
+        this._bindHandler = this._scrollTop.bind(this);
+        this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown', this._bindHandler);
+      }
+
+      this.$element.on('mutateme.zf.trigger', this._resize.bind(this));
+    }
+    /**
+     * Scroll to Top of Element or data-scroll-top-element
+     * @function
+     * @fires Drilldown#scrollme
+     */
+
+  }, {
+    key: "_scrollTop",
+    value: function _scrollTop() {
+      var _this = this;
+
+      var $scrollTopElement = _this.options.scrollTopElement != '' ? $(_this.options.scrollTopElement) : _this.$element,
+          scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10);
+      $('html, body').stop(true).animate({
+        scrollTop: scrollPos
+      }, _this.options.animationDuration, _this.options.animationEasing, function () {
+        /**
+          * Fires after the menu has scrolled
+          * @event Drilldown#scrollme
+          */
+        if (this === $('html')[0]) _this.$element.trigger('scrollme.zf.drilldown');
+      });
+    }
+    /**
+     * Adds keydown event listener to `li`'s in the menu.
+     * @private
+     */
+
+  }, {
+    key: "_keyboardEvents",
+    value: function _keyboardEvents() {
+      var _this = this;
+
+      this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function (e) {
+        var $element = $(this),
+            $elements = $element.parent('li').parent('ul').children('li').children('a'),
+            $prevElement,
+            $nextElement;
+        $elements.each(function (i) {
+          if ($(this).is($element)) {
+            $prevElement = $elements.eq(Math.max(0, i - 1));
+            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
+            return;
+          }
+        });
+        Keyboard.handleKey(e, 'Drilldown', {
+          next: function next() {
+            if ($element.is(_this.$submenuAnchors)) {
+              _this._show($element.parent('li'));
+
+              $element.parent('li').one(transitionend($element), function () {
+                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
+              });
+              return true;
+            }
+          },
+          previous: function previous() {
+            _this._hide($element.parent('li').parent('ul'));
+
+            $element.parent('li').parent('ul').one(transitionend($element), function () {
+              setTimeout(function () {
+                $element.parent('li').parent('ul').parent('li').children('a').first().focus();
+              }, 1);
+            });
+            return true;
+          },
+          up: function up() {
+            $prevElement.focus(); // Don't tap focus on first element in root ul
+
+            return !$element.is(_this.$element.find('> li:first-child > a'));
+          },
+          down: function down() {
+            $nextElement.focus(); // Don't tap focus on last element in root ul
+
+            return !$element.is(_this.$element.find('> li:last-child > a'));
+          },
+          close: function close() {
+            // Don't close on element in root ul
+            if (!$element.is(_this.$element.find('> li > a'))) {
+              _this._hide($element.parent().parent());
+
+              $element.parent().parent().siblings('a').focus();
+            }
+          },
+          open: function open() {
+            if (_this.options.parentLink && $element.attr('href')) {
+              // Link with href
+              return false;
+            } else if (!$element.is(_this.$menuItems)) {
+              // not menu item means back button
+              _this._hide($element.parent('li').parent('ul'));
+
+              $element.parent('li').parent('ul').one(transitionend($element), function () {
+                setTimeout(function () {
+                  $element.parent('li').parent('ul').parent('li').children('a').first().focus();
+                }, 1);
+              });
+              return true;
+            } else if ($element.is(_this.$submenuAnchors)) {
+              // Sub menu item
+              _this._show($element.parent('li'));
+
+              $element.parent('li').one(transitionend($element), function () {
+                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
+              });
+              return true;
+            }
+          },
+          handled: function handled(preventDefault) {
+            if (preventDefault) {
+              e.preventDefault();
+            }
+
+            e.stopImmediatePropagation();
+          }
+        });
+      }); // end keyboardAccess
+    }
+    /**
+     * Closes all open elements, and returns to root menu.
+     * @function
+     * @fires Drilldown#closed
+     */
+
+  }, {
+    key: "_hideAll",
+    value: function _hideAll() {
+      var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');
+      if (this.options.autoHeight) this.$wrapper.css({
+        height: $elem.parent().closest('ul').data('calcHeight')
+      });
+      $elem.one(transitionend($elem), function (e) {
+        $elem.removeClass('is-active is-closing');
+      });
+      /**
+       * Fires when the menu is fully closed.
+       * @event Drilldown#closed
+       */
+
+      this.$element.trigger('closed.zf.drilldown');
+    }
+    /**
+     * Adds event listener for each `back` button, and closes open menus.
+     * @function
+     * @fires Drilldown#back
+     * @param {jQuery} $elem - the current sub-menu to add `back` event.
+     */
+
+  }, {
+    key: "_back",
+    value: function _back($elem) {
+      var _this = this;
+
+      $elem.off('click.zf.drilldown');
+      $elem.children('.js-drilldown-back').on('click.zf.drilldown', function (e) {
+        e.stopImmediatePropagation(); // console.log('mouseup on back');
+
+        _this._hide($elem); // If there is a parent submenu, call show
+
+
+        var parentSubMenu = $elem.parent('li').parent('ul').parent('li');
+
+        if (parentSubMenu.length) {
+          _this._show(parentSubMenu);
+        }
+      });
+    }
+    /**
+     * Adds event listener to menu items w/o submenus to close open menus on click.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_menuLinkEvents",
+    value: function _menuLinkEvents() {
+      var _this = this;
+
+      this.$menuItems.not('.is-drilldown-submenu-parent').off('click.zf.drilldown').on('click.zf.drilldown', function (e) {
+        // e.stopImmediatePropagation();
+        setTimeout(function () {
+          _this._hideAll();
+        }, 0);
+      });
+    }
+    /**
+     * Sets the CSS classes for submenu to show it.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the target submenu (`ul` tag)
+     * @param {boolean} trigger - trigger drilldown event
+     */
+
+  }, {
+    key: "_setShowSubMenuClasses",
+    value: function _setShowSubMenuClasses($elem, trigger) {
+      $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+      $elem.parent('li').attr('aria-expanded', true);
+
+      if (trigger === true) {
+        this.$element.trigger('open.zf.drilldown', [$elem]);
+      }
+    }
+    /**
+     * Sets the CSS classes for submenu to hide it.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the target submenu (`ul` tag)
+     * @param {boolean} trigger - trigger drilldown event
+     */
+
+  }, {
+    key: "_setHideSubMenuClasses",
+    value: function _setHideSubMenuClasses($elem, trigger) {
+      $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);
+      $elem.parent('li').attr('aria-expanded', false);
+
+      if (trigger === true) {
+        $elem.trigger('hide.zf.drilldown', [$elem]);
+      }
+    }
+    /**
+     * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.
+     * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.
+     * @function
+     * @fires Drilldown#open
+     * @param {jQuery} $elem - the target (sub)menu (`ul` tag)
+     * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused
+     */
+
+  }, {
+    key: "_showMenu",
+    value: function _showMenu($elem, autoFocus) {
+      var _this = this; // Reset drilldown
+
+
+      var $expandedSubmenus = this.$element.find('li[aria-expanded="true"] > ul[data-submenu]');
+      $expandedSubmenus.each(function (index) {
+        _this._setHideSubMenuClasses($(this));
+      }); // Save the menu as the currently displayed one.
+
+      this.$currentMenu = $elem; // If target menu is root, focus first link & exit
+
+      if ($elem.is('[data-drilldown]')) {
+        if (autoFocus === true) $elem.find('li[role="treeitem"] > a').first().focus();
+        if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));
+        return;
+      } // Find all submenus on way to root incl. the element itself
+
+
+      var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); // Open target menu and all submenus on its way to root
+
+      $submenus.each(function (index) {
+        // Update height of first child (target menu) if autoHeight option true
+        if (index === 0 && _this.options.autoHeight) {
+          _this.$wrapper.css('height', $(this).data('calcHeight'));
+        }
+
+        var isLastChild = index == $submenus.length - 1; // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link
+        // Last child makes sure the event gets always triggered even if going through several menus
+
+        if (isLastChild === true) {
+          $(this).one(transitionend($(this)), function () {
+            if (autoFocus === true) {
+              $elem.find('li[role="treeitem"] > a').first().focus();
+            }
+          });
+        }
+
+        _this._setShowSubMenuClasses($(this), isLastChild);
+      });
+    }
+    /**
+     * Opens a submenu.
+     * @function
+     * @fires Drilldown#open
+     * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.
+     */
+
+  }, {
+    key: "_show",
+    value: function _show($elem) {
+      var $submenu = $elem.children('[data-submenu]');
+      $elem.attr('aria-expanded', true);
+      this.$currentMenu = $submenu;
+      $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+
+      if (this.options.autoHeight) {
+        this.$wrapper.css({
+          height: $submenu.data('calcHeight')
+        });
+      }
+      /**
+       * Fires when the submenu has opened.
+       * @event Drilldown#open
+       */
+
+
+      this.$element.trigger('open.zf.drilldown', [$elem]);
+    }
+    /**
+     * Hides a submenu
+     * @function
+     * @fires Drilldown#hide
+     * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.
+     */
+
+  }, {
+    key: "_hide",
+    value: function _hide($elem) {
+      if (this.options.autoHeight) this.$wrapper.css({
+        height: $elem.parent().closest('ul').data('calcHeight')
+      });
+
+      $elem.parent('li').attr('aria-expanded', false);
+      $elem.attr('aria-hidden', true);
+      $elem.addClass('is-closing').one(transitionend($elem), function () {
+        $elem.removeClass('is-active is-closing');
+        $elem.blur().addClass('invisible');
+      });
+      /**
+       * Fires when the submenu has closed.
+       * @event Drilldown#hide
+       */
+
+      $elem.trigger('hide.zf.drilldown', [$elem]);
+    }
+    /**
+     * Iterates through the nested menus to calculate the min-height, and max-width for the menu.
+     * Prevents content jumping.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_getMaxDims",
+    value: function _getMaxDims() {
+      var maxHeight = 0,
+          result = {},
+          _this = this; // Recalculate menu heights and total max height
+
+
+      this.$submenus.add(this.$element).each(function () {
+        var numOfElems = $(this).children('li').length;
+        var height = Box.GetDimensions(this).height;
+        maxHeight = height > maxHeight ? height : maxHeight;
+
+        if (_this.options.autoHeight) {
+          $(this).data('calcHeight', height);
+        }
+      });
+      if (this.options.autoHeight) result['height'] = this.$currentMenu.data('calcHeight');else result['min-height'] = "".concat(maxHeight, "px");
+      result['max-width'] = "".concat(this.$element[0].getBoundingClientRect().width, "px");
+      return result;
+    }
+    /**
+     * Destroys the Drilldown Menu
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      if (this.options.scrollTop) this.$element.off('.zf.drilldown', this._bindHandler);
+
+      this._hideAll();
+
+      this.$element.off('mutateme.zf.trigger');
+      Nest.Burn(this.$element, 'drilldown');
+      this.$element.unwrap().find('.js-drilldown-back, .is-submenu-parent-item').remove().end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu').end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');
+      this.$submenuAnchors.each(function () {
+        $(this).off('.zf.drilldown');
+      });
+      this.$element.find('[data-is-parent-link]').detach();
+      this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');
+      this.$element.find('a').each(function () {
+        var $link = $(this);
+        $link.removeAttr('tabindex');
+
+        if ($link.data('savedHref')) {
+          $link.attr('href', $link.data('savedHref')).removeData('savedHref');
+        } else {
+          return;
+        }
+      });
+    }
+  }]);
+
+  return Drilldown;
+}(Plugin);
+
+Drilldown.defaults = {
+  /**
+   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are
+   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.
+   * @option
+   * @type {boolian}
+   * @default true
+   */
+  autoApplyClass: true,
+
+  /**
+   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\`) if copy and pasting.
+   * @option
+   * @type {string}
+   * @default '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>'
+   */
+  backButton: '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',
+
+  /**
+   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.
+   * @option
+   * @type {string}
+   * @default top
+   */
+  backButtonPosition: 'top',
+
+  /**
+   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\`) if copy and pasting.
+   * @option
+   * @type {string}
+   * @default '<div></div>'
+   */
+  wrapper: '<div></div>',
+
+  /**
+   * Adds the parent link to the submenu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  parentLink: false,
+
+  /**
+   * Allow the menu to return to root list on body click.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  closeOnClick: false,
+
+  /**
+   * Allow the menu to auto adjust height.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoHeight: false,
+
+  /**
+   * Animate the auto adjust height.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animateHeight: false,
+
+  /**
+   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  scrollTop: false,
+
+  /**
+   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  scrollTopElement: '',
+
+  /**
+   * ScrollTop offset
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  scrollTopOffset: 0,
+
+  /**
+   * Scroll animation duration
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+
+  /**
+   * Scroll animation easing. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @see {@link https://api.jquery.com/animate|JQuery animate}
+   * @default 'swing'
+   */
+  animationEasing: 'swing' // holdOpen: false
+
+};
+
+var POSITIONS = ['left', 'right', 'top', 'bottom'];
+var VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];
+var HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];
+var ALIGNMENTS = {
+  'left': VERTICAL_ALIGNMENTS,
+  'right': VERTICAL_ALIGNMENTS,
+  'top': HORIZONTAL_ALIGNMENTS,
+  'bottom': HORIZONTAL_ALIGNMENTS
+};
+
+function nextItem(item, array) {
+  var currentIdx = array.indexOf(item);
+
+  if (currentIdx === array.length - 1) {
+    return array[0];
+  } else {
+    return array[currentIdx + 1];
+  }
+}
+
+var Positionable =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Positionable, _Plugin);
+
+  function Positionable() {
+    _classCallCheck(this, Positionable);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments));
+  }
+
+  _createClass(Positionable, [{
+    key: "_init",
+
+    /**
+     * Abstract class encapsulating the tether-like explicit positioning logic
+     * including repositioning based on overlap.
+     * Expects classes to define defaults for vOffset, hOffset, position,
+     * alignment, allowOverlap, and allowBottomOverlap. They can do this by
+     * extending the defaults, or (for now recommended due to the way docs are
+     * generated) by explicitly declaring them.
+     *
+     **/
+    value: function _init() {
+      this.triedPositions = {};
+      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;
+      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;
+      this.originalPosition = this.position;
+      this.originalAlignment = this.alignment;
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      return 'bottom';
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      switch (this.position) {
+        case 'bottom':
+        case 'top':
+          return rtl() ? 'right' : 'left';
+
+        case 'left':
+        case 'right':
+          return 'bottom';
+      }
+    }
+    /**
+     * Adjusts the positionable possible positions by iterating through alignments
+     * and positions.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_reposition",
+    value: function _reposition() {
+      if (this._alignmentsExhausted(this.position)) {
+        this.position = nextItem(this.position, POSITIONS);
+        this.alignment = ALIGNMENTS[this.position][0];
+      } else {
+        this._realign();
+      }
+    }
+    /**
+     * Adjusts the dropdown pane possible positions by iterating through alignments
+     * on the current position.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_realign",
+    value: function _realign() {
+      this._addTriedPosition(this.position, this.alignment);
+
+      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);
+    }
+  }, {
+    key: "_addTriedPosition",
+    value: function _addTriedPosition(position, alignment) {
+      this.triedPositions[position] = this.triedPositions[position] || [];
+      this.triedPositions[position].push(alignment);
+    }
+  }, {
+    key: "_positionsExhausted",
+    value: function _positionsExhausted() {
+      var isExhausted = true;
+
+      for (var i = 0; i < POSITIONS.length; i++) {
+        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);
+      }
+
+      return isExhausted;
+    }
+  }, {
+    key: "_alignmentsExhausted",
+    value: function _alignmentsExhausted(position) {
+      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;
+    } // When we're trying to center, we don't want to apply offset that's going to
+    // take us just off center, so wrap around to return 0 for the appropriate
+    // offset in those alignments.  TODO: Figure out if we want to make this
+    // configurable behavior... it feels more intuitive, especially for tooltips, but
+    // it's possible someone might actually want to start from center and then nudge
+    // slightly off.
+
+  }, {
+    key: "_getVOffset",
+    value: function _getVOffset() {
+      return this.options.vOffset;
+    }
+  }, {
+    key: "_getHOffset",
+    value: function _getHOffset() {
+      return this.options.hOffset;
+    }
+  }, {
+    key: "_setPosition",
+    value: function _setPosition($anchor, $element, $parent) {
+      if ($anchor.attr('aria-expanded') === 'false') {
+        return false;
+      }
+
+      var $eleDims = Box.GetDimensions($element),
+          $anchorDims = Box.GetDimensions($anchor);
+
+      if (!this.options.allowOverlap) {
+        // restore original position & alignment before checking overlap
+        this.position = this.originalPosition;
+        this.alignment = this.originalAlignment;
+      }
+
+      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+
+      if (!this.options.allowOverlap) {
+        var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better
+
+        var minCoordinates = {
+          position: this.position,
+          alignment: this.alignment
+        };
+
+        while (!this._positionsExhausted()) {
+          var overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
+
+          if (overlap === 0) {
+            return;
+          }
+
+          if (overlap < minOverlap) {
+            minOverlap = overlap;
+            minCoordinates = {
+              position: this.position,
+              alignment: this.alignment
+            };
+          }
+
+          this._reposition();
+
+          $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+        } // If we get through the entire loop, there was no non-overlapping
+        // position available. Pick the version with least overlap.
+
+
+        this.position = minCoordinates.position;
+        this.alignment = minCoordinates.alignment;
+        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+      }
+    }
+  }]);
+
+  return Positionable;
+}(Plugin);
+
+Positionable.defaults = {
+  /**
+   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+
+  /**
+   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow overlap of container/window. If false, dropdown positionable first
+   * try to position as defined by data-position and data-alignment, but
+   * reposition if it would cause an overflow.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  allowBottomOverlap: true,
+
+  /**
+   * Number of pixels the positionable should be separated vertically from anchor
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+
+  /**
+   * Number of pixels the positionable should be separated horizontally from anchor
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0
+};
+
+/**
+ * Dropdown module.
+ * @module foundation.dropdown
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.box
+ * @requires foundation.util.triggers
+ */
+
+var Dropdown =
+/*#__PURE__*/
+function (_Positionable) {
+  _inherits(Dropdown, _Positionable);
+
+  function Dropdown() {
+    _classCallCheck(this, Dropdown);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Dropdown).apply(this, arguments));
+  }
+
+  _createClass(Dropdown, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a dropdown.
+     * @class
+     * @name Dropdown
+     * @param {jQuery} element - jQuery object to make into a dropdown.
+     *        Object should be of the dropdown panel, rather than its anchor.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);
+      this.className = 'Dropdown'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      this._init();
+
+      Keyboard.register('Dropdown', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
+        'ESCAPE': 'close'
+      });
+    }
+    /**
+     * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var $id = this.$element.attr('id');
+      this.$anchors = $("[data-toggle=\"".concat($id, "\"]")).length ? $("[data-toggle=\"".concat($id, "\"]")) : $("[data-open=\"".concat($id, "\"]"));
+      this.$anchors.attr({
+        'aria-controls': $id,
+        'data-is-focus': false,
+        'data-yeti-box': $id,
+        'aria-haspopup': true,
+        'aria-expanded': false
+      });
+
+      this._setCurrentAnchor(this.$anchors.first());
+
+      if (this.options.parentClass) {
+        this.$parent = this.$element.parents('.' + this.options.parentClass);
+      } else {
+        this.$parent = null;
+      } // Set [aria-labelledby] on the Dropdown if it is not set
+
+
+      if (typeof this.$element.attr('aria-labelledby') === 'undefined') {
+        // Get the anchor ID or create one
+        if (typeof this.$currentAnchor.attr('id') === 'undefined') {
+          this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));
+        }
+        this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));
+      }
+
+      this.$element.attr({
+        'aria-hidden': 'true',
+        'data-yeti-box': $id,
+        'data-resize': $id
+      });
+
+      _get(_getPrototypeOf(Dropdown.prototype), "_init", this).call(this);
+
+      this._events();
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      // handle legacy classnames
+      var position = this.$element[0].className.match(/(top|left|right|bottom)/g);
+
+      if (position) {
+        return position[0];
+      } else {
+        return 'bottom';
+      }
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      // handle legacy float approach
+      var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.attr('class'));
+
+      if (horizontalPosition) {
+        return horizontalPosition[1];
+      }
+
+      return _get(_getPrototypeOf(Dropdown.prototype), "_getDefaultAlignment", this).call(this);
+    }
+    /**
+     * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.
+     * Recursively calls itself if a collision is detected, with a new position class.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_setPosition",
+    value: function _setPosition() {
+      this.$element.removeClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment));
+
+      _get(_getPrototypeOf(Dropdown.prototype), "_setPosition", this).call(this, this.$currentAnchor, this.$element, this.$parent);
+
+      this.$element.addClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment));
+    }
+    /**
+     * Make it a current anchor.
+     * Current anchor as the reference for the position of Dropdown panes.
+     * @param {HTML} el - DOM element of the anchor.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_setCurrentAnchor",
+    value: function _setCurrentAnchor(el) {
+      this.$currentAnchor = $(el);
+    }
+    /**
+     * Adds event listeners to the element utilizing the triggers utility library.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      this.$element.on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': this.close.bind(this),
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'resizeme.zf.trigger': this._setPosition.bind(this)
+      });
+      this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function () {
+        _this._setCurrentAnchor(this);
+      });
+
+      if (this.options.hover) {
+        this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
+          _this._setCurrentAnchor(this);
+
+          var bodyData = $('body').data();
+
+          if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') {
+            clearTimeout(_this.timeout);
+            _this.timeout = setTimeout(function () {
+              _this.open();
+
+              _this.$anchors.data('hover', true);
+            }, _this.options.hoverDelay);
+          }
+        }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function () {
+          clearTimeout(_this.timeout);
+          _this.timeout = setTimeout(function () {
+            _this.close();
+
+            _this.$anchors.data('hover', false);
+          }, _this.options.hoverDelay);
+        }));
+
+        if (this.options.hoverPane) {
+          this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
+            clearTimeout(_this.timeout);
+          }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function () {
+            clearTimeout(_this.timeout);
+            _this.timeout = setTimeout(function () {
+              _this.close();
+
+              _this.$anchors.data('hover', false);
+            }, _this.options.hoverDelay);
+          }));
+        }
+      }
+
+      this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) {
+        var $target = $(this),
+            visibleFocusableElements = Keyboard.findFocusable(_this.$element);
+        Keyboard.handleKey(e, 'Dropdown', {
+          open: function open() {
+            if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {
+              _this.open();
+
+              _this.$element.attr('tabindex', -1).focus();
+
+              e.preventDefault();
+            }
+          },
+          close: function close() {
+            _this.close();
+
+            _this.$anchors.focus();
+          }
+        });
+      });
+    }
+    /**
+     * Adds an event handler to the body to close any dropdowns on a click.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_addBodyHandler",
+    value: function _addBodyHandler() {
+      var $body = $(document.body).not(this.$element),
+          _this = this;
+
+      $body.off('click.zf.dropdown').on('click.zf.dropdown', function (e) {
+        if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {
+          return;
+        }
+
+        if (_this.$element.is(e.target) || _this.$element.find(e.target).length) {
+          return;
+        }
+
+        _this.close();
+
+        $body.off('click.zf.dropdown');
+      });
+    }
+    /**
+     * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.
+     * @function
+     * @fires Dropdown#closeme
+     * @fires Dropdown#show
+     */
+
+  }, {
+    key: "open",
+    value: function open() {
+      // var _this = this;
+
+      /**
+       * Fires to close other open dropdowns, typically when dropdown is opening
+       * @event Dropdown#closeme
+       */
+      this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));
+      this.$anchors.addClass('hover').attr({
+        'aria-expanded': true
+      }); // this.$element/*.show()*/;
+
+      this.$element.addClass('is-opening');
+
+      this._setPosition();
+
+      this.$element.removeClass('is-opening').addClass('is-open').attr({
+        'aria-hidden': false
+      });
+
+      if (this.options.autoFocus) {
+        var $focusable = Keyboard.findFocusable(this.$element);
+
+        if ($focusable.length) {
+          $focusable.eq(0).focus();
+        }
+      }
+
+      if (this.options.closeOnClick) {
+        this._addBodyHandler();
+      }
+
+      if (this.options.trapFocus) {
+        Keyboard.trapFocus(this.$element);
+      }
+      /**
+       * Fires once the dropdown is visible.
+       * @event Dropdown#show
+       */
+
+
+      this.$element.trigger('show.zf.dropdown', [this.$element]);
+    }
+    /**
+     * Closes the open dropdown pane.
+     * @function
+     * @fires Dropdown#hide
+     */
+
+  }, {
+    key: "close",
+    value: function close() {
+      if (!this.$element.hasClass('is-open')) {
+        return false;
+      }
+
+      this.$element.removeClass('is-open').attr({
+        'aria-hidden': true
+      });
+      this.$anchors.removeClass('hover').attr('aria-expanded', false);
+      /**
+       * Fires once the dropdown is no longer visible.
+       * @event Dropdown#hide
+       */
+
+      this.$element.trigger('hide.zf.dropdown', [this.$element]);
+
+      if (this.options.trapFocus) {
+        Keyboard.releaseFocus(this.$element);
+      }
+    }
+    /**
+     * Toggles the dropdown pane's visibility.
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      if (this.$element.hasClass('is-open')) {
+        if (this.$anchors.data('hover')) return;
+        this.close();
+      } else {
+        this.open();
+      }
+    }
+    /**
+     * Destroys the dropdown.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.trigger').hide();
+      this.$anchors.off('.zf.dropdown');
+      $(document.body).off('click.zf.dropdown');
+    }
+  }]);
+
+  return Dropdown;
+}(Positionable);
+
+Dropdown.defaults = {
+  /**
+   * Class that designates bounding container of Dropdown (default: window)
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  parentClass: null,
+
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  hoverDelay: 250,
+
+  /**
+   * Allow submenus to open on hover events
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  hover: false,
+
+  /**
+   * Don't close dropdown when hovering over dropdown pane
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  hoverPane: false,
+
+  /**
+   * Number of pixels between the dropdown pane and the triggering element on open.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+
+  /**
+   * Number of pixels between the dropdown pane and the triggering element on open.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0,
+
+  /**
+   * Position of dropdown. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+
+  /**
+   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  allowBottomOverlap: true,
+
+  /**
+   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  trapFocus: false,
+
+  /**
+   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoFocus: false,
+
+  /**
+   * Allows a click on the body to close the dropdown.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  closeOnClick: false
+};
+
+/**
+ * DropdownMenu module.
+ * @module foundation.dropdown-menu
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.box
+ * @requires foundation.util.nest
+ */
+
+var DropdownMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(DropdownMenu, _Plugin);
+
+  function DropdownMenu() {
+    _classCallCheck(this, DropdownMenu);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(DropdownMenu).apply(this, arguments));
+  }
+
+  _createClass(DropdownMenu, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of DropdownMenu.
+     * @class
+     * @name DropdownMenu
+     * @fires DropdownMenu#init
+     * @param {jQuery} element - jQuery object to make into a dropdown menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);
+      this.className = 'DropdownMenu'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('DropdownMenu', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'previous',
+        'ESCAPE': 'close'
+      });
+    }
+    /**
+     * Initializes the plugin, and calls _prepareMenu
+     * @private
+     * @function
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      Nest.Feather(this.$element, 'dropdown');
+      var subs = this.$element.find('li.is-dropdown-submenu-parent');
+      this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');
+      this.$menuItems = this.$element.find('[role="menuitem"]');
+      this.$tabs = this.$element.children('[role="menuitem"]');
+      this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);
+
+      if (this.options.alignment === 'auto') {
+        if (this.$element.hasClass(this.options.rightClass) || rtl() || this.$element.parents('.top-bar-right').is('*')) {
+          this.options.alignment = 'right';
+          subs.addClass('opens-left');
+        } else {
+          this.options.alignment = 'left';
+          subs.addClass('opens-right');
+        }
+      } else {
+        if (this.options.alignment === 'right') {
+          subs.addClass('opens-left');
+        } else {
+          subs.addClass('opens-right');
+        }
+      }
+
+      this.changed = false;
+
+      this._events();
+    }
+  }, {
+    key: "_isVertical",
+    value: function _isVertical() {
+      return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';
+    }
+  }, {
+    key: "_isRtl",
+    value: function _isRtl() {
+      return this.$element.hasClass('align-right') || rtl() && !this.$element.hasClass('align-left');
+    }
+    /**
+     * Adds event listeners to elements within the menu
+     * @private
+     * @function
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this,
+          hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined',
+          parClass = 'is-dropdown-submenu-parent'; // used for onClick and in the keyboard handlers
+
+
+      var handleClickFn = function handleClickFn(e) {
+        var $elem = $(e.target).parentsUntil('ul', ".".concat(parClass)),
+            hasSub = $elem.hasClass(parClass),
+            hasClicked = $elem.attr('data-is-click') === 'true',
+            $sub = $elem.children('.is-dropdown-submenu');
+
+        if (hasSub) {
+          if (hasClicked) {
+            if (!_this.options.closeOnClick || !_this.options.clickOpen && !hasTouch || _this.options.forceFollow && hasTouch) {
+              return;
+            } else {
+              e.stopImmediatePropagation();
+              e.preventDefault();
+
+              _this._hide($elem);
+            }
+          } else {
+            e.preventDefault();
+            e.stopImmediatePropagation();
+
+            _this._show($sub);
+
+            $elem.add($elem.parentsUntil(_this.$element, ".".concat(parClass))).attr('data-is-click', true);
+          }
+        }
+      };
+
+      if (this.options.clickOpen || hasTouch) {
+        this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);
+      } // Handle Leaf element Clicks
+
+
+      if (_this.options.closeOnClickInside) {
+        this.$menuItems.on('click.zf.dropdownmenu', function (e) {
+          var $elem = $(this),
+              hasSub = $elem.hasClass(parClass);
+
+          if (!hasSub) {
+            _this._hide();
+          }
+        });
+      }
+
+      if (!this.options.disableHover) {
+        this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {
+          var $elem = $(this),
+              hasSub = $elem.hasClass(parClass);
+
+          if (hasSub) {
+            clearTimeout($elem.data('_delay'));
+            $elem.data('_delay', setTimeout(function () {
+              _this._show($elem.children('.is-dropdown-submenu'));
+            }, _this.options.hoverDelay));
+          }
+        }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) {
+          var $elem = $(this),
+              hasSub = $elem.hasClass(parClass);
+
+          if (hasSub && _this.options.autoclose) {
+            if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) {
+              return false;
+            }
+
+            clearTimeout($elem.data('_delay'));
+            $elem.data('_delay', setTimeout(function () {
+              _this._hide($elem);
+            }, _this.options.closingTime));
+          }
+        }));
+      }
+
+      this.$menuItems.on('keydown.zf.dropdownmenu', function (e) {
+        var $element = $(e.target).parentsUntil('ul', '[role="menuitem"]'),
+            isTab = _this.$tabs.index($element) > -1,
+            $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),
+            $prevElement,
+            $nextElement;
+        $elements.each(function (i) {
+          if ($(this).is($element)) {
+            $prevElement = $elements.eq(i - 1);
+            $nextElement = $elements.eq(i + 1);
+            return;
+          }
+        });
+
+        var nextSibling = function nextSibling() {
+          $nextElement.children('a:first').focus();
+          e.preventDefault();
+        },
+            prevSibling = function prevSibling() {
+          $prevElement.children('a:first').focus();
+          e.preventDefault();
+        },
+            openSub = function openSub() {
+          var $sub = $element.children('ul.is-dropdown-submenu');
+
+          if ($sub.length) {
+            _this._show($sub);
+
+            $element.find('li > a:first').focus();
+            e.preventDefault();
+          } else {
+            return;
+          }
+        },
+            closeSub = function closeSub() {
+          //if ($element.is(':first-child')) {
+          var close = $element.parent('ul').parent('li');
+          close.children('a:first').focus();
+
+          _this._hide(close);
+
+          e.preventDefault(); //}
+        };
+
+        var functions = {
+          open: openSub,
+          close: function close() {
+            _this._hide(_this.$element);
+
+            _this.$menuItems.eq(0).children('a').focus(); // focus to first element
+
+
+            e.preventDefault();
+          },
+          handled: function handled() {
+            e.stopImmediatePropagation();
+          }
+        };
+
+        if (isTab) {
+          if (_this._isVertical()) {
+            // vertical menu
+            if (_this._isRtl()) {
+              // right aligned
+              $.extend(functions, {
+                down: nextSibling,
+                up: prevSibling,
+                next: closeSub,
+                previous: openSub
+              });
+            } else {
+              // left aligned
+              $.extend(functions, {
+                down: nextSibling,
+                up: prevSibling,
+                next: openSub,
+                previous: closeSub
+              });
+            }
+          } else {
+            // horizontal menu
+            if (_this._isRtl()) {
+              // right aligned
+              $.extend(functions, {
+                next: prevSibling,
+                previous: nextSibling,
+                down: openSub,
+                up: closeSub
+              });
+            } else {
+              // left aligned
+              $.extend(functions, {
+                next: nextSibling,
+                previous: prevSibling,
+                down: openSub,
+                up: closeSub
+              });
+            }
+          }
+        } else {
+          // not tabs -> one sub
+          if (_this._isRtl()) {
+            // right aligned
+            $.extend(functions, {
+              next: closeSub,
+              previous: openSub,
+              down: nextSibling,
+              up: prevSibling
+            });
+          } else {
+            // left aligned
+            $.extend(functions, {
+              next: openSub,
+              previous: closeSub,
+              down: nextSibling,
+              up: prevSibling
+            });
+          }
+        }
+
+        Keyboard.handleKey(e, 'DropdownMenu', functions);
+      });
+    }
+    /**
+     * Adds an event handler to the body to close any dropdowns on a click.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_addBodyHandler",
+    value: function _addBodyHandler() {
+      var $body = $(document.body),
+          _this = this;
+
+      $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu').on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function (e) {
+        var $link = _this.$element.find(e.target);
+
+        if ($link.length) {
+          return;
+        }
+
+        _this._hide();
+
+        $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');
+      });
+    }
+    /**
+     * Opens a dropdown pane, and checks for collisions first.
+     * @param {jQuery} $sub - ul element that is a submenu to show
+     * @function
+     * @private
+     * @fires Dropdownmenu#show
+     */
+
+  }, {
+    key: "_show",
+    value: function _show($sub) {
+      var idx = this.$tabs.index(this.$tabs.filter(function (i, el) {
+        return $(el).find($sub).length > 0;
+      }));
+      var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');
+
+      this._hide($sibs, idx);
+
+      $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active');
+      var clear = Box.ImNotTouchingYou($sub, null, true);
+
+      if (!clear) {
+        var oldClass = this.options.alignment === 'left' ? '-right' : '-left',
+            $parentLi = $sub.parent('.is-dropdown-submenu-parent');
+        $parentLi.removeClass("opens".concat(oldClass)).addClass("opens-".concat(this.options.alignment));
+        clear = Box.ImNotTouchingYou($sub, null, true);
+
+        if (!clear) {
+          $parentLi.removeClass("opens-".concat(this.options.alignment)).addClass('opens-inner');
+        }
+
+        this.changed = true;
+      }
+
+      $sub.css('visibility', '');
+
+      if (this.options.closeOnClick) {
+        this._addBodyHandler();
+      }
+      /**
+       * Fires when the new dropdown pane is visible.
+       * @event Dropdownmenu#show
+       */
+
+
+      this.$element.trigger('show.zf.dropdownmenu', [$sub]);
+    }
+    /**
+     * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.
+     * @function
+     * @param {jQuery} $elem - element with a submenu to hide
+     * @param {Number} idx - index of the $tabs collection to hide
+     * @private
+     */
+
+  }, {
+    key: "_hide",
+    value: function _hide($elem, idx) {
+      var $toClose;
+
+      if ($elem && $elem.length) {
+        $toClose = $elem;
+      } else if (typeof idx !== 'undefined') {
+        $toClose = this.$tabs.not(function (i, el) {
+          return i === idx;
+        });
+      } else {
+        $toClose = this.$element;
+      }
+
+      var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;
+
+      if (somethingToClose) {
+        $toClose.find('li.is-active').add($toClose).attr({
+          'data-is-click': false
+        }).removeClass('is-active');
+        $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');
+
+        if (this.changed || $toClose.find('opens-inner').length) {
+          var oldClass = this.options.alignment === 'left' ? 'right' : 'left';
+          $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass("opens-inner opens-".concat(this.options.alignment)).addClass("opens-".concat(oldClass));
+          this.changed = false;
+        }
+        /**
+         * Fires when the open menus are closed.
+         * @event Dropdownmenu#hide
+         */
+
+
+        this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);
+      }
+    }
+    /**
+     * Destroys the plugin.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click').removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');
+      $(document.body).off('.zf.dropdownmenu');
+      Nest.Burn(this.$element, 'dropdown');
+    }
+  }]);
+
+  return DropdownMenu;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+DropdownMenu.defaults = {
+  /**
+   * Disallows hover events from opening submenus
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disableHover: false,
+
+  /**
+   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  autoclose: true,
+
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  hoverDelay: 50,
+
+  /**
+   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  clickOpen: false,
+
+  /**
+   * Amount of time to delay closing a submenu on a mouseleave event.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  closingTime: 500,
+
+  /**
+   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow clicks on the body to close any open submenus.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Allow clicks on leaf anchor links to close any open submenus.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClickInside: true,
+
+  /**
+   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.
+   * @option
+   * @type {string}
+   * @default 'vertical'
+   */
+  verticalClass: 'vertical',
+
+  /**
+   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.
+   * @option
+   * @type {string}
+   * @default 'align-right'
+   */
+  rightClass: 'align-right',
+
+  /**
+   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  forceFollow: true
+};
+
+/**
+ * Equalizer module.
+ * @module foundation.equalizer
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.imageLoader if equalizer contains images
+ */
+
+var Equalizer =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Equalizer, _Plugin);
+
+  function Equalizer() {
+    _classCallCheck(this, Equalizer);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Equalizer).apply(this, arguments));
+  }
+
+  _createClass(Equalizer, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Equalizer.
+     * @class
+     * @name Equalizer
+     * @fires Equalizer#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Equalizer.defaults, this.$element.data(), options);
+      this.className = 'Equalizer'; // ie9 back compat
+
+      this._init();
+    }
+    /**
+     * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var eqId = this.$element.attr('data-equalizer') || '';
+      var $watched = this.$element.find("[data-equalizer-watch=\"".concat(eqId, "\"]"));
+
+      MediaQuery._init();
+
+      this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');
+      this.$element.attr('data-resize', eqId || GetYoDigits(6, 'eq'));
+      this.$element.attr('data-mutate', eqId || GetYoDigits(6, 'eq'));
+      this.hasNested = this.$element.find('[data-equalizer]').length > 0;
+      this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;
+      this.isOn = false;
+      this._bindHandler = {
+        onResizeMeBound: this._onResizeMe.bind(this),
+        onPostEqualizedBound: this._onPostEqualized.bind(this)
+      };
+      var imgs = this.$element.find('img');
+      var tooSmall;
+
+      if (this.options.equalizeOn) {
+        tooSmall = this._checkMQ();
+        $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));
+      } else {
+        this._events();
+      }
+
+      if (typeof tooSmall !== 'undefined' && tooSmall === false || typeof tooSmall === 'undefined') {
+        if (imgs.length) {
+          onImagesLoaded(imgs, this._reflow.bind(this));
+        } else {
+          this._reflow();
+        }
+      }
+    }
+    /**
+     * Removes event listeners if the breakpoint is too small.
+     * @private
+     */
+
+  }, {
+    key: "_pauseEvents",
+    value: function _pauseEvents() {
+      this.isOn = false;
+      this.$element.off({
+        '.zf.equalizer': this._bindHandler.onPostEqualizedBound,
+        'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,
+        'mutateme.zf.trigger': this._bindHandler.onResizeMeBound
+      });
+    }
+    /**
+     * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound
+     * @private
+     */
+
+  }, {
+    key: "_onResizeMe",
+    value: function _onResizeMe(e) {
+      this._reflow();
+    }
+    /**
+     * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound
+     * @private
+     */
+
+  }, {
+    key: "_onPostEqualized",
+    value: function _onPostEqualized(e) {
+      if (e.target !== this.$element[0]) {
+        this._reflow();
+      }
+    }
+    /**
+     * Initializes events for Equalizer.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+
+      this._pauseEvents();
+
+      if (this.hasNested) {
+        this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);
+      } else {
+        this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);
+        this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);
+      }
+
+      this.isOn = true;
+    }
+    /**
+     * Checks the current breakpoint to the minimum required size.
+     * @private
+     */
+
+  }, {
+    key: "_checkMQ",
+    value: function _checkMQ() {
+      var tooSmall = !MediaQuery.is(this.options.equalizeOn);
+
+      if (tooSmall) {
+        if (this.isOn) {
+          this._pauseEvents();
+
+          this.$watched.css('height', 'auto');
+        }
+      } else {
+        if (!this.isOn) {
+          this._events();
+        }
+      }
+
+      return tooSmall;
+    }
+    /**
+     * A noop version for the plugin
+     * @private
+     */
+
+  }, {
+    key: "_killswitch",
+    value: function _killswitch() {
+      return;
+    }
+    /**
+     * Calls necessary functions to update Equalizer upon DOM change
+     * @private
+     */
+
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      if (!this.options.equalizeOnStack) {
+        if (this._isStacked()) {
+          this.$watched.css('height', 'auto');
+          return false;
+        }
+      }
+
+      if (this.options.equalizeByRow) {
+        this.getHeightsByRow(this.applyHeightByRow.bind(this));
+      } else {
+        this.getHeights(this.applyHeight.bind(this));
+      }
+    }
+    /**
+     * Manually determines if the first 2 elements are *NOT* stacked.
+     * @private
+     */
+
+  }, {
+    key: "_isStacked",
+    value: function _isStacked() {
+      if (!this.$watched[0] || !this.$watched[1]) {
+        return true;
+      }
+
+      return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;
+    }
+    /**
+     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
+     * @param {Function} cb - A non-optional callback to return the heights array to.
+     * @returns {Array} heights - An array of heights of children within Equalizer container
+     */
+
+  }, {
+    key: "getHeights",
+    value: function getHeights(cb) {
+      var heights = [];
+
+      for (var i = 0, len = this.$watched.length; i < len; i++) {
+        this.$watched[i].style.height = 'auto';
+        heights.push(this.$watched[i].offsetHeight);
+      }
+
+      cb(heights);
+    }
+    /**
+     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
+     * @param {Function} cb - A non-optional callback to return the heights array to.
+     * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
+     */
+
+  }, {
+    key: "getHeightsByRow",
+    value: function getHeightsByRow(cb) {
+      var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0,
+          groups = [],
+          group = 0; //group by Row
+
+      groups[group] = [];
+
+      for (var i = 0, len = this.$watched.length; i < len; i++) {
+        this.$watched[i].style.height = 'auto'; //maybe could use this.$watched[i].offsetTop
+
+        var elOffsetTop = $(this.$watched[i]).offset().top;
+
+        if (elOffsetTop != lastElTopOffset) {
+          group++;
+          groups[group] = [];
+          lastElTopOffset = elOffsetTop;
+        }
+
+        groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]);
+      }
+
+      for (var j = 0, ln = groups.length; j < ln; j++) {
+        var heights = $(groups[j]).map(function () {
+          return this[1];
+        }).get();
+        var max = Math.max.apply(null, heights);
+        groups[j].push(max);
+      }
+
+      cb(groups);
+    }
+    /**
+     * Changes the CSS height property of each child in an Equalizer parent to match the tallest
+     * @param {array} heights - An array of heights of children within Equalizer container
+     * @fires Equalizer#preequalized
+     * @fires Equalizer#postequalized
+     */
+
+  }, {
+    key: "applyHeight",
+    value: function applyHeight(heights) {
+      var max = Math.max.apply(null, heights);
+      /**
+       * Fires before the heights are applied
+       * @event Equalizer#preequalized
+       */
+
+      this.$element.trigger('preequalized.zf.equalizer');
+      this.$watched.css('height', max);
+      /**
+       * Fires when the heights have been applied
+       * @event Equalizer#postequalized
+       */
+
+      this.$element.trigger('postequalized.zf.equalizer');
+    }
+    /**
+     * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row
+     * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
+     * @fires Equalizer#preequalized
+     * @fires Equalizer#preequalizedrow
+     * @fires Equalizer#postequalizedrow
+     * @fires Equalizer#postequalized
+     */
+
+  }, {
+    key: "applyHeightByRow",
+    value: function applyHeightByRow(groups) {
+      /**
+       * Fires before the heights are applied
+       */
+      this.$element.trigger('preequalized.zf.equalizer');
+
+      for (var i = 0, len = groups.length; i < len; i++) {
+        var groupsILength = groups[i].length,
+            max = groups[i][groupsILength - 1];
+
+        if (groupsILength <= 2) {
+          $(groups[i][0][0]).css({
+            'height': 'auto'
+          });
+          continue;
+        }
+        /**
+          * Fires before the heights per row are applied
+          * @event Equalizer#preequalizedrow
+          */
+
+
+        this.$element.trigger('preequalizedrow.zf.equalizer');
+
+        for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) {
+          $(groups[i][j][0]).css({
+            'height': max
+          });
+        }
+        /**
+          * Fires when the heights per row have been applied
+          * @event Equalizer#postequalizedrow
+          */
+
+
+        this.$element.trigger('postequalizedrow.zf.equalizer');
+      }
+      /**
+       * Fires when the heights have been applied
+       */
+
+
+      this.$element.trigger('postequalized.zf.equalizer');
+    }
+    /**
+     * Destroys an instance of Equalizer.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this._pauseEvents();
+
+      this.$watched.css('height', 'auto');
+    }
+  }]);
+
+  return Equalizer;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+Equalizer.defaults = {
+  /**
+   * Enable height equalization when stacked on smaller screens.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  equalizeOnStack: false,
+
+  /**
+   * Enable height equalization row by row.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  equalizeByRow: false,
+
+  /**
+   * String representing the minimum breakpoint size the plugin should equalize heights on.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  equalizeOn: ''
+};
+
+/**
+ * Interchange module.
+ * @module foundation.interchange
+ * @requires foundation.util.mediaQuery
+ */
+
+var Interchange =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Interchange, _Plugin);
+
+  function Interchange() {
+    _classCallCheck(this, Interchange);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Interchange).apply(this, arguments));
+  }
+
+  _createClass(Interchange, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Interchange.
+     * @class
+     * @name Interchange
+     * @fires Interchange#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Interchange.defaults, options);
+      this.rules = [];
+      this.currentPath = '';
+      this.className = 'Interchange'; // ie9 back compat
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Interchange plugin and calls functions to get interchange functioning on load.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init();
+
+      var id = this.$element[0].id || GetYoDigits(6, 'interchange');
+      this.$element.attr({
+        'data-resize': id,
+        'id': id
+      });
+
+      this._addBreakpoints();
+
+      this._generateRules();
+
+      this._reflow();
+    }
+    /**
+     * Initializes events for Interchange.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this2 = this;
+
+      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () {
+        return _this2._reflow();
+      });
+    }
+    /**
+     * Calls necessary functions to update Interchange upon DOM change
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      var match; // Iterate through each rule, but only save the last match
+
+      for (var i in this.rules) {
+        if (this.rules.hasOwnProperty(i)) {
+          var rule = this.rules[i];
+
+          if (window.matchMedia(rule.query).matches) {
+            match = rule;
+          }
+        }
+      }
+
+      if (match) {
+        this.replace(match.path);
+      }
+    }
+    /**
+     * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_addBreakpoints",
+    value: function _addBreakpoints() {
+      for (var i in MediaQuery.queries) {
+        if (MediaQuery.queries.hasOwnProperty(i)) {
+          var query = MediaQuery.queries[i];
+          Interchange.SPECIAL_QUERIES[query.name] = query.value;
+        }
+      }
+    }
+    /**
+     * Checks the Interchange element for the provided media query + content pairings
+     * @function
+     * @private
+     * @param {Object} element - jQuery object that is an Interchange instance
+     * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys
+     */
+
+  }, {
+    key: "_generateRules",
+    value: function _generateRules(element) {
+      var rulesList = [];
+      var rules;
+
+      if (this.options.rules) {
+        rules = this.options.rules;
+      } else {
+        rules = this.$element.data('interchange');
+      }
+
+      rules = typeof rules === 'string' ? rules.match(/\[.*?, .*?\]/g) : rules;
+
+      for (var i in rules) {
+        if (rules.hasOwnProperty(i)) {
+          var rule = rules[i].slice(1, -1).split(', ');
+          var path = rule.slice(0, -1).join('');
+          var query = rule[rule.length - 1];
+
+          if (Interchange.SPECIAL_QUERIES[query]) {
+            query = Interchange.SPECIAL_QUERIES[query];
+          }
+
+          rulesList.push({
+            path: path,
+            query: query
+          });
+        }
+      }
+
+      this.rules = rulesList;
+    }
+    /**
+     * Update the `src` property of an image, or change the HTML of a container, to the specified path.
+     * @function
+     * @param {String} path - Path to the image or HTML partial.
+     * @fires Interchange#replaced
+     */
+
+  }, {
+    key: "replace",
+    value: function replace(path) {
+      if (this.currentPath === path) return;
+
+      var _this = this,
+          trigger = 'replaced.zf.interchange'; // Replacing images
+
+
+      if (this.$element[0].nodeName === 'IMG') {
+        this.$element.attr('src', path).on('load', function () {
+          _this.currentPath = path;
+        }).trigger(trigger);
+      } // Replacing background images
+      else if (path.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {
+          path = path.replace(/\(/g, '%28').replace(/\)/g, '%29');
+          this.$element.css({
+            'background-image': 'url(' + path + ')'
+          }).trigger(trigger);
+        } // Replacing HTML
+        else {
+            $.get(path, function (response) {
+              _this.$element.html(response).trigger(trigger);
+
+              $(response).foundation();
+              _this.currentPath = path;
+            });
+          }
+      /**
+       * Fires when content in an Interchange element is done being loaded.
+       * @event Interchange#replaced
+       */
+      // this.$element.trigger('replaced.zf.interchange');
+
+    }
+    /**
+     * Destroys an instance of interchange.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('resizeme.zf.trigger');
+    }
+  }]);
+
+  return Interchange;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+Interchange.defaults = {
+  /**
+   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.
+   * @option
+   * @type {?array}
+   * @default null
+   */
+  rules: null
+};
+Interchange.SPECIAL_QUERIES = {
+  'landscape': 'screen and (orientation: landscape)',
+  'portrait': 'screen and (orientation: portrait)',
+  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'
+};
+
+/**
+ * SmoothScroll module.
+ * @module foundation.smooth-scroll
+ */
+
+var SmoothScroll =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(SmoothScroll, _Plugin);
+
+  function SmoothScroll() {
+    _classCallCheck(this, SmoothScroll);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(SmoothScroll).apply(this, arguments));
+  }
+
+  _createClass(SmoothScroll, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of SmoothScroll.
+     * @class
+     * @name SmoothScroll
+     * @fires SmoothScroll#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);
+      this.className = 'SmoothScroll'; // ie9 back compat
+
+      this._init();
+    }
+    /**
+     * Initialize the SmoothScroll plugin
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');
+      this.$element.attr({
+        id: id
+      });
+
+      this._events();
+    }
+    /**
+     * Initializes events for SmoothScroll.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._linkClickListener = this._handleLinkClick.bind(this);
+      this.$element.on('click.zf.smoothScroll', this._linkClickListener);
+      this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
+    }
+    /**
+     * Handle the given event to smoothly scroll to the anchor pointed by the event target.
+     * @param {*} e - event
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_handleLinkClick",
+    value: function _handleLinkClick(e) {
+      var _this = this;
+
+      // Follow the link if it does not point to an anchor.
+      if (!$(e.currentTarget).is('a[href^="#"]')) return;
+      var arrival = e.currentTarget.getAttribute('href');
+      this._inTransition = true;
+      SmoothScroll.scrollToLoc(arrival, this.options, function () {
+        _this._inTransition = false;
+      });
+      e.preventDefault();
+    }
+  }, {
+    key: "_destroy",
+
+    /**
+     * Destroys the SmoothScroll instance.
+     * @function
+     */
+    value: function _destroy() {
+      this.$element.off('click.zf.smoothScroll', this._linkClickListener);
+      this.$element.off('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
+    }
+  }], [{
+    key: "scrollToLoc",
+
+    /**
+     * Function to scroll to a given location on the page.
+     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'
+     * @param {Object} options - The options to use.
+     * @param {Function} callback - The callback function.
+     * @static
+     * @function
+     */
+    value: function scrollToLoc(loc) {
+      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults;
+      var callback = arguments.length > 2 ? arguments[2] : undefined;
+      var $loc = $(loc); // Do nothing if target does not exist to prevent errors
+
+      if (!$loc.length) return false;
+      var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);
+      $('html, body').stop(true).animate({
+        scrollTop: scrollPos
+      }, options.animationDuration, options.animationEasing, function () {
+        if (typeof callback === 'function') {
+          callback();
+        }
+      });
+    }
+  }]);
+
+  return SmoothScroll;
+}(Plugin);
+/**
+ * Default settings for plugin.
+ */
+
+
+SmoothScroll.defaults = {
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
+
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
+
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
+};
+
+/**
+ * Magellan module.
+ * @module foundation.magellan
+ * @requires foundation.smoothScroll
+ */
+
+var Magellan =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Magellan, _Plugin);
+
+  function Magellan() {
+    _classCallCheck(this, Magellan);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Magellan).apply(this, arguments));
+  }
+
+  _createClass(Magellan, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Magellan.
+     * @class
+     * @name Magellan
+     * @fires Magellan#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Magellan.defaults, this.$element.data(), options);
+      this.className = 'Magellan'; // ie9 back compat
+
+      this._init();
+
+      this.calcPoints();
+    }
+    /**
+     * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var id = this.$element[0].id || GetYoDigits(6, 'magellan');
+
+      this.$targets = $('[data-magellan-target]');
+      this.$links = this.$element.find('a');
+      this.$element.attr({
+        'data-resize': id,
+        'data-scroll': id,
+        'id': id
+      });
+      this.$active = $();
+      this.scrollPos = parseInt(window.pageYOffset, 10);
+
+      this._events();
+    }
+    /**
+     * Calculates an array of pixel values that are the demarcation lines between locations on the page.
+     * Can be invoked if new elements are added or the size of a location changes.
+     * @function
+     */
+
+  }, {
+    key: "calcPoints",
+    value: function calcPoints() {
+      var _this = this,
+          body = document.body,
+          html = document.documentElement;
+
+      this.points = [];
+      this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));
+      this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));
+      this.$targets.each(function () {
+        var $tar = $(this),
+            pt = Math.round($tar.offset().top - _this.options.threshold);
+        $tar.targetPoint = pt;
+
+        _this.points.push(pt);
+      });
+    }
+    /**
+     * Initializes events for Magellan.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this,
+          $body = $('html, body'),
+          opts = {
+        duration: _this.options.animationDuration,
+        easing: _this.options.animationEasing
+      };
+
+      $(window).one('load', function () {
+        if (_this.options.deepLinking) {
+          if (location.hash) {
+            _this.scrollToLoc(location.hash);
+          }
+        }
+
+        _this.calcPoints();
+
+        _this._updateActive();
+      });
+      _this.onLoadListener = onLoad($(window), function () {
+        _this.$element.on({
+          'resizeme.zf.trigger': _this.reflow.bind(_this),
+          'scrollme.zf.trigger': _this._updateActive.bind(_this)
+        }).on('click.zf.magellan', 'a[href^="#"]', function (e) {
+          e.preventDefault();
+          var arrival = this.getAttribute('href');
+
+          _this.scrollToLoc(arrival);
+        });
+      });
+
+      this._deepLinkScroll = function (e) {
+        if (_this.options.deepLinking) {
+          _this.scrollToLoc(window.location.hash);
+        }
+      };
+
+      $(window).on('hashchange', this._deepLinkScroll);
+    }
+    /**
+     * Function to scroll to a given location on the page.
+     * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'
+     * @function
+     */
+
+  }, {
+    key: "scrollToLoc",
+    value: function scrollToLoc(loc) {
+      this._inTransition = true;
+
+      var _this = this;
+
+      var options = {
+        animationEasing: this.options.animationEasing,
+        animationDuration: this.options.animationDuration,
+        threshold: this.options.threshold,
+        offset: this.options.offset
+      };
+      SmoothScroll.scrollToLoc(loc, options, function () {
+        _this._inTransition = false;
+      });
+    }
+    /**
+     * Calls necessary functions to update Magellan upon DOM change
+     * @function
+     */
+
+  }, {
+    key: "reflow",
+    value: function reflow() {
+      this.calcPoints();
+
+      this._updateActive();
+    }
+    /**
+     * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.
+     * @private
+     * @function
+     * @fires Magellan#update
+     */
+
+  }, {
+    key: "_updateActive",
+    value: function _updateActive()
+    /*evt, elem, scrollPos*/
+    {
+      var _this2 = this;
+
+      if (this._inTransition) return;
+      var newScrollPos = parseInt(window.pageYOffset, 10);
+      var isScrollingUp = this.scrollPos > newScrollPos;
+      this.scrollPos = newScrollPos;
+      var activeIdx; // Before the first point: no link
+
+      if (newScrollPos < this.points[0]) ;
+      /* do nothing */
+      // At the bottom of the page: last link
+      else if (newScrollPos + this.winHeight === this.docHeight) {
+          activeIdx = this.points.length - 1;
+        } // Otherwhise, use the last visible link
+        else {
+            var visibleLinks = this.points.filter(function (p, i) {
+              return p - _this2.options.offset - (isScrollingUp ? _this2.options.threshold : 0) <= newScrollPos;
+            });
+            activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;
+          } // Get the new active link
+
+
+      var $oldActive = this.$active;
+      var activeHash = '';
+
+      if (typeof activeIdx !== 'undefined') {
+        this.$active = this.$links.filter('[href="#' + this.$targets.eq(activeIdx).data('magellan-target') + '"]');
+        if (this.$active.length) activeHash = this.$active[0].getAttribute('href');
+      } else {
+        this.$active = $();
+      }
+
+      var isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);
+      var isNewHash = activeHash !== window.location.hash; // Update the active link element
+
+      if (isNewActive) {
+        $oldActive.removeClass(this.options.activeClass);
+        this.$active.addClass(this.options.activeClass);
+      } // Update the hash (it may have changed with the same active link)
+
+
+      if (this.options.deepLinking && isNewHash) {
+        if (window.history.pushState) {
+          // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384
+          var url = activeHash ? activeHash : window.location.pathname + window.location.search;
+          window.history.pushState(null, null, url);
+        } else {
+          window.location.hash = activeHash;
+        }
+      }
+
+      if (isNewActive) {
+        /**
+         * Fires when magellan is finished updating to the new active element.
+         * @event Magellan#update
+         */
+        this.$element.trigger('update.zf.magellan', [this.$active]);
+      }
+    }
+    /**
+     * Destroys an instance of Magellan and resets the url of the window.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.trigger .zf.magellan').find(".".concat(this.options.activeClass)).removeClass(this.options.activeClass);
+
+      if (this.options.deepLinking) {
+        var hash = this.$active[0].getAttribute('href');
+        window.location.hash.replace(hash, '');
+      }
+
+      $(window).off('hashchange', this._deepLinkScroll);
+      if (this.onLoadListener) $(window).off(this.onLoadListener);
+    }
+  }]);
+
+  return Magellan;
+}(Plugin);
+/**
+ * Default settings for plugin
+ */
+
+
+Magellan.defaults = {
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
+
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
+
+  /**
+   * Class applied to the active locations link on the magellan container.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  activeClass: 'is-active',
+
+  /**
+   * Allows the script to manipulate the url of the current page, and if supported, alter the history.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinking: false,
+
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
+};
+
+/**
+ * OffCanvas module.
+ * @module foundation.offcanvas
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.triggers
+ */
+
+var OffCanvas =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(OffCanvas, _Plugin);
+
+  function OffCanvas() {
+    _classCallCheck(this, OffCanvas);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(OffCanvas).apply(this, arguments));
+  }
+
+  _createClass(OffCanvas, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of an off-canvas wrapper.
+     * @class
+     * @name OffCanvas
+     * @fires OffCanvas#init
+     * @param {Object} element - jQuery object to initialize.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      var _this2 = this;
+
+      this.className = 'OffCanvas'; // ie9 back compat
+
+      this.$element = element;
+      this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);
+      this.contentClasses = {
+        base: [],
+        reveal: []
+      };
+      this.$lastTrigger = $();
+      this.$triggers = $();
+      this.position = 'left';
+      this.$content = $();
+      this.nested = !!this.options.nested; // Defines the CSS transition/position classes of the off-canvas content container.
+
+      $(['push', 'overlap']).each(function (index, val) {
+        _this2.contentClasses.base.push('has-transition-' + val);
+      });
+      $(['left', 'right', 'top', 'bottom']).each(function (index, val) {
+        _this2.contentClasses.base.push('has-position-' + val);
+
+        _this2.contentClasses.reveal.push('has-reveal-' + val);
+      }); // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      MediaQuery._init();
+
+      this._init();
+
+      this._events();
+
+      Keyboard.register('OffCanvas', {
+        'ESCAPE': 'close'
+      });
+    }
+    /**
+     * Initializes the off-canvas wrapper by adding the exit overlay (if needed).
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var id = this.$element.attr('id');
+      this.$element.attr('aria-hidden', 'true'); // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)
+
+      if (this.options.contentId) {
+        this.$content = $('#' + this.options.contentId);
+      } else if (this.$element.siblings('[data-off-canvas-content]').length) {
+        this.$content = this.$element.siblings('[data-off-canvas-content]').first();
+      } else {
+        this.$content = this.$element.closest('[data-off-canvas-content]').first();
+      }
+
+      if (!this.options.contentId) {
+        // Assume that the off-canvas element is nested if it isn't a sibling of the content
+        this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;
+      } else if (this.options.contentId && this.options.nested === null) {
+        // Warning if using content ID without setting the nested option
+        // Once the element is nested it is required to work properly in this case
+        console.warn('Remember to use the nested option if using the content ID option!');
+      }
+
+      if (this.nested === true) {
+        // Force transition overlap if nested
+        this.options.transition = 'overlap'; // Remove appropriate classes if already assigned in markup
+
+        this.$element.removeClass('is-transition-push');
+      }
+
+      this.$element.addClass("is-transition-".concat(this.options.transition, " is-closed")); // Find triggers that affect this element and add aria-expanded to them
+
+      this.$triggers = $(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id); // Get position by checking for related CSS class
+
+      this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position; // Add an overlay over the content if necessary
+
+      if (this.options.contentOverlay === true) {
+        var overlay = document.createElement('div');
+        var overlayPosition = $(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';
+        overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);
+        this.$overlay = $(overlay);
+
+        if (overlayPosition === 'is-overlay-fixed') {
+          $(this.$overlay).insertAfter(this.$element);
+        } else {
+          this.$content.append(this.$overlay);
+        }
+      } // Get the revealOn option from the class.
+
+
+      var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\s]+)', 'g');
+      var revealOnClass = revealOnRegExp.exec(this.$element[0].className);
+
+      if (revealOnClass) {
+        this.options.isRevealed = true;
+        this.options.revealOn = this.options.revealOn || revealOnClass[1];
+      } // Ensure the `reveal-on-*` class is set.
+
+
+      if (this.options.isRevealed === true && this.options.revealOn) {
+        this.$element.first().addClass("".concat(this.options.revealClass).concat(this.options.revealOn));
+
+        this._setMQChecker();
+      }
+
+      if (this.options.transitionTime) {
+        this.$element.css('transition-duration', this.options.transitionTime);
+      } // Initally remove all transition/position CSS classes from off-canvas content container.
+
+
+      this._removeContentClasses();
+    }
+    /**
+     * Adds event handlers to the off-canvas wrapper and the exit overlay.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this.$element.off('.zf.trigger .zf.offcanvas').on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': this.close.bind(this),
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'keydown.zf.offcanvas': this._handleKeyboard.bind(this)
+      });
+
+      if (this.options.closeOnClick === true) {
+        var $target = this.options.contentOverlay ? this.$overlay : this.$content;
+        $target.on({
+          'click.zf.offcanvas': this.close.bind(this)
+        });
+      }
+    }
+    /**
+     * Applies event listener for elements that will reveal at certain breakpoints.
+     * @private
+     */
+
+  }, {
+    key: "_setMQChecker",
+    value: function _setMQChecker() {
+      var _this = this;
+
+      this.onLoadListener = onLoad($(window), function () {
+        if (MediaQuery.atLeast(_this.options.revealOn)) {
+          _this.reveal(true);
+        }
+      });
+      $(window).on('changed.zf.mediaquery', function () {
+        if (MediaQuery.atLeast(_this.options.revealOn)) {
+          _this.reveal(true);
+        } else {
+          _this.reveal(false);
+        }
+      });
+    }
+    /**
+     * Removes the CSS transition/position classes of the off-canvas content container.
+     * Removing the classes is important when another off-canvas gets opened that uses the same content container.
+     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
+     * @private
+     */
+
+  }, {
+    key: "_removeContentClasses",
+    value: function _removeContentClasses(hasReveal) {
+      if (typeof hasReveal !== 'boolean') {
+        this.$content.removeClass(this.contentClasses.base.join(' '));
+      } else if (hasReveal === false) {
+        this.$content.removeClass("has-reveal-".concat(this.position));
+      }
+    }
+    /**
+     * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.
+     * Beforehand any transition/position class gets removed.
+     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
+     * @private
+     */
+
+  }, {
+    key: "_addContentClasses",
+    value: function _addContentClasses(hasReveal) {
+      this._removeContentClasses(hasReveal);
+
+      if (typeof hasReveal !== 'boolean') {
+        this.$content.addClass("has-transition-".concat(this.options.transition, " has-position-").concat(this.position));
+      } else if (hasReveal === true) {
+        this.$content.addClass("has-reveal-".concat(this.position));
+      }
+    }
+    /**
+     * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.
+     * @param {Boolean} isRevealed - true if element should be revealed.
+     * @function
+     */
+
+  }, {
+    key: "reveal",
+    value: function reveal(isRevealed) {
+      if (isRevealed) {
+        this.close();
+        this.isRevealed = true;
+        this.$element.attr('aria-hidden', 'false');
+        this.$element.off('open.zf.trigger toggle.zf.trigger');
+        this.$element.removeClass('is-closed');
+      } else {
+        this.isRevealed = false;
+        this.$element.attr('aria-hidden', 'true');
+        this.$element.off('open.zf.trigger toggle.zf.trigger').on({
+          'open.zf.trigger': this.open.bind(this),
+          'toggle.zf.trigger': this.toggle.bind(this)
+        });
+        this.$element.addClass('is-closed');
+      }
+
+      this._addContentClasses(isRevealed);
+    }
+    /**
+     * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.
+     * @private
+     */
+
+  }, {
+    key: "_stopScrolling",
+    value: function _stopScrolling(event) {
+      return false;
+    } // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios
+    // Only really works for y, not sure how to extend to x or if we need to.
+
+  }, {
+    key: "_recordScrollable",
+    value: function _recordScrollable(event) {
+      var elem = this; // called from event handler context with this as elem
+      // If the element is scrollable (content overflows), then...
+
+      if (elem.scrollHeight !== elem.clientHeight) {
+        // If we're at the top, scroll down one pixel to allow scrolling up
+        if (elem.scrollTop === 0) {
+          elem.scrollTop = 1;
+        } // If we're at the bottom, scroll up one pixel to allow scrolling down
+
+
+        if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {
+          elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;
+        }
+      }
+
+      elem.allowUp = elem.scrollTop > 0;
+      elem.allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight;
+      elem.lastY = event.originalEvent.pageY;
+    }
+  }, {
+    key: "_stopScrollPropagation",
+    value: function _stopScrollPropagation(event) {
+      var elem = this; // called from event handler context with this as elem
+
+      var up = event.pageY < elem.lastY;
+      var down = !up;
+      elem.lastY = event.pageY;
+
+      if (up && elem.allowUp || down && elem.allowDown) {
+        event.stopPropagation();
+      } else {
+        event.preventDefault();
+      }
+    }
+    /**
+     * Opens the off-canvas menu.
+     * @function
+     * @param {Object} event - Event object passed from listener.
+     * @param {jQuery} trigger - element that triggered the off-canvas to open.
+     * @fires Offcanvas#opened
+     * @todo also trigger 'open' event?
+     */
+
+  }, {
+    key: "open",
+    value: function open(event, trigger) {
+      if (this.$element.hasClass('is-open') || this.isRevealed) {
+        return;
+      }
+
+      var _this = this;
+
+      if (trigger) {
+        this.$lastTrigger = trigger;
+      }
+
+      if (this.options.forceTo === 'top') {
+        window.scrollTo(0, 0);
+      } else if (this.options.forceTo === 'bottom') {
+        window.scrollTo(0, document.body.scrollHeight);
+      }
+
+      if (this.options.transitionTime && this.options.transition !== 'overlap') {
+        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);
+      } else {
+        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');
+      }
+
+      this.$element.addClass('is-open').removeClass('is-closed');
+      this.$triggers.attr('aria-expanded', 'true');
+      this.$element.attr('aria-hidden', 'false');
+      this.$content.addClass('is-open-' + this.position); // If `contentScroll` is set to false, add class and disable scrolling on touch devices.
+
+      if (this.options.contentScroll === false) {
+        $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);
+        this.$element.on('touchstart', this._recordScrollable);
+        this.$element.on('touchmove', this._stopScrollPropagation);
+      }
+
+      if (this.options.contentOverlay === true) {
+        this.$overlay.addClass('is-visible');
+      }
+
+      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+        this.$overlay.addClass('is-closable');
+      }
+
+      if (this.options.autoFocus === true) {
+        this.$element.one(transitionend(this.$element), function () {
+          if (!_this.$element.hasClass('is-open')) {
+            return; // exit if prematurely closed
+          }
+
+          var canvasFocus = _this.$element.find('[data-autofocus]');
+
+          if (canvasFocus.length) {
+            canvasFocus.eq(0).focus();
+          } else {
+            _this.$element.find('a, button').eq(0).focus();
+          }
+        });
+      }
+
+      if (this.options.trapFocus === true) {
+        this.$content.attr('tabindex', '-1');
+        Keyboard.trapFocus(this.$element);
+      }
+
+      this._addContentClasses();
+      /**
+       * Fires when the off-canvas menu opens.
+       * @event Offcanvas#opened
+       */
+
+
+      this.$element.trigger('opened.zf.offcanvas');
+    }
+    /**
+     * Closes the off-canvas menu.
+     * @function
+     * @param {Function} cb - optional cb to fire after closure.
+     * @fires Offcanvas#closed
+     */
+
+  }, {
+    key: "close",
+    value: function close(cb) {
+      if (!this.$element.hasClass('is-open') || this.isRevealed) {
+        return;
+      }
+
+      var _this = this;
+
+      this.$element.removeClass('is-open');
+      this.$element.attr('aria-hidden', 'true')
+      /**
+       * Fires when the off-canvas menu opens.
+       * @event Offcanvas#closed
+       */
+      .trigger('closed.zf.offcanvas');
+      this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom'); // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.
+
+      if (this.options.contentScroll === false) {
+        $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);
+        this.$element.off('touchstart', this._recordScrollable);
+        this.$element.off('touchmove', this._stopScrollPropagation);
+      }
+
+      if (this.options.contentOverlay === true) {
+        this.$overlay.removeClass('is-visible');
+      }
+
+      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+        this.$overlay.removeClass('is-closable');
+      }
+
+      this.$triggers.attr('aria-expanded', 'false');
+
+      if (this.options.trapFocus === true) {
+        this.$content.removeAttr('tabindex');
+        Keyboard.releaseFocus(this.$element);
+      } // Listen to transitionEnd and add class when done.
+
+
+      this.$element.one(transitionend(this.$element), function (e) {
+        _this.$element.addClass('is-closed');
+
+        _this._removeContentClasses();
+      });
+    }
+    /**
+     * Toggles the off-canvas menu open or closed.
+     * @function
+     * @param {Object} event - Event object passed from listener.
+     * @param {jQuery} trigger - element that triggered the off-canvas to open.
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle(event, trigger) {
+      if (this.$element.hasClass('is-open')) {
+        this.close(event, trigger);
+      } else {
+        this.open(event, trigger);
+      }
+    }
+    /**
+     * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_handleKeyboard",
+    value: function _handleKeyboard(e) {
+      var _this3 = this;
+
+      Keyboard.handleKey(e, 'OffCanvas', {
+        close: function close() {
+          _this3.close();
+
+          _this3.$lastTrigger.focus();
+
+          return true;
+        },
+        handled: function handled() {
+          e.stopPropagation();
+          e.preventDefault();
+        }
+      });
+    }
+    /**
+     * Destroys the offcanvas plugin.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.close();
+      this.$element.off('.zf.trigger .zf.offcanvas');
+      this.$overlay.off('.zf.offcanvas');
+      if (this.onLoadListener) $(window).off(this.onLoadListener);
+    }
+  }]);
+
+  return OffCanvas;
+}(Plugin);
+
+OffCanvas.defaults = {
+  /**
+   * Allow the user to click outside of the menu to close it.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Adds an overlay on top of `[data-off-canvas-content]`.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  contentOverlay: true,
+
+  /**
+   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  contentId: null,
+
+  /**
+   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.
+   * @option
+   * @type {boolean}
+   * @default null
+   */
+  nested: null,
+
+  /**
+   * Enable/disable scrolling of the main content when an off canvas panel is open.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  contentScroll: true,
+
+  /**
+   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.
+   * @option
+   * @type {number}
+   * @default null
+   */
+  transitionTime: null,
+
+  /**
+   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.
+   * @option
+   * @type {string}
+   * @default push
+   */
+  transition: 'push',
+
+  /**
+   * Force the page to scroll to top or bottom on open.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  forceTo: null,
+
+  /**
+   * Allow the offcanvas to remain open for certain breakpoints.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  isRevealed: false,
+
+  /**
+   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  revealOn: null,
+
+  /**
+   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  autoFocus: true,
+
+  /**
+   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.
+   * @option
+   * @type {string}
+   * @default reveal-for-
+   * @todo improve the regex testing for this.
+   */
+  revealClass: 'reveal-for-',
+
+  /**
+   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  trapFocus: false
+};
+
+/**
+ * Orbit module.
+ * @module foundation.orbit
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.motion
+ * @requires foundation.util.timer
+ * @requires foundation.util.imageLoader
+ * @requires foundation.util.touch
+ */
+
+var Orbit =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Orbit, _Plugin);
+
+  function Orbit() {
+    _classCallCheck(this, Orbit);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Orbit).apply(this, arguments));
+  }
+
+  _createClass(Orbit, [{
+    key: "_setup",
+
+    /**
+    * Creates a new instance of an orbit carousel.
+    * @class
+    * @name Orbit
+    * @param {jQuery} element - jQuery object to make into an Orbit Carousel.
+    * @param {Object} options - Overrides to the default plugin settings.
+    */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);
+      this.className = 'Orbit'; // ie9 back compat
+
+      Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.
+
+      this._init();
+
+      Keyboard.register('Orbit', {
+        'ltr': {
+          'ARROW_RIGHT': 'next',
+          'ARROW_LEFT': 'previous'
+        },
+        'rtl': {
+          'ARROW_LEFT': 'next',
+          'ARROW_RIGHT': 'previous'
+        }
+      });
+    }
+    /**
+    * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide
+      this._reset();
+
+      this.$wrapper = this.$element.find(".".concat(this.options.containerClass));
+      this.$slides = this.$element.find(".".concat(this.options.slideClass));
+      var $images = this.$element.find('img'),
+          initActive = this.$slides.filter('.is-active'),
+          id = this.$element[0].id || GetYoDigits(6, 'orbit');
+      this.$element.attr({
+        'data-resize': id,
+        'id': id
+      });
+
+      if (!initActive.length) {
+        this.$slides.eq(0).addClass('is-active');
+      }
+
+      if (!this.options.useMUI) {
+        this.$slides.addClass('no-motionui');
+      }
+
+      if ($images.length) {
+        onImagesLoaded($images, this._prepareForOrbit.bind(this));
+      } else {
+        this._prepareForOrbit(); //hehe
+
+      }
+
+      if (this.options.bullets) {
+        this._loadBullets();
+      }
+
+      this._events();
+
+      if (this.options.autoPlay && this.$slides.length > 1) {
+        this.geoSync();
+      }
+
+      if (this.options.accessible) {
+        // allow wrapper to be focusable to enable arrow navigation
+        this.$wrapper.attr('tabindex', 0);
+      }
+    }
+    /**
+    * Creates a jQuery collection of bullets, if they are being used.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_loadBullets",
+    value: function _loadBullets() {
+      this.$bullets = this.$element.find(".".concat(this.options.boxOfBullets)).find('button');
+    }
+    /**
+    * Sets a `timer` object on the orbit, and starts the counter for the next slide.
+    * @function
+    */
+
+  }, {
+    key: "geoSync",
+    value: function geoSync() {
+      var _this = this;
+
+      this.timer = new Timer(this.$element, {
+        duration: this.options.timerDelay,
+        infinite: false
+      }, function () {
+        _this.changeSlide(true);
+      });
+      this.timer.start();
+    }
+    /**
+    * Sets wrapper and slide heights for the orbit.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_prepareForOrbit",
+    value: function _prepareForOrbit() {
+
+      this._setWrapperHeight();
+    }
+    /**
+    * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.
+    * @function
+    * @private
+    * @param {Function} cb - a callback function to fire when complete.
+    */
+
+  }, {
+    key: "_setWrapperHeight",
+    value: function _setWrapperHeight(cb) {
+      //rewrite this to `for` loop
+      var max = 0,
+          temp,
+          counter = 0,
+          _this = this;
+
+      this.$slides.each(function () {
+        temp = this.getBoundingClientRect().height;
+        $(this).attr('data-slide', counter); // hide all slides but the active one
+
+        if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {
+          $(this).css({
+            'display': 'none'
+          });
+        }
+
+        max = temp > max ? temp : max;
+        counter++;
+      });
+
+      if (counter === this.$slides.length) {
+        this.$wrapper.css({
+          'height': max
+        }); //only change the wrapper height property once.
+
+        if (cb) {
+          cb(max);
+        } //fire callback with max height dimension.
+
+      }
+    }
+    /**
+    * Sets the max-height of each slide.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_setSlideHeight",
+    value: function _setSlideHeight(height) {
+      this.$slides.each(function () {
+        $(this).css('max-height', height);
+      });
+    }
+    /**
+    * Adds event listeners to basically everything within the element.
+    * @function
+    * @private
+    */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this; //***************************************
+      //**Now using custom event - thanks to:**
+      //**      Yohai Ararat of Toronto      **
+      //***************************************
+      //
+
+
+      this.$element.off('.resizeme.zf.trigger').on({
+        'resizeme.zf.trigger': this._prepareForOrbit.bind(this)
+      });
+
+      if (this.$slides.length > 1) {
+        if (this.options.swipe) {
+          this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) {
+            e.preventDefault();
+
+            _this.changeSlide(true);
+          }).on('swiperight.zf.orbit', function (e) {
+            e.preventDefault();
+
+            _this.changeSlide(false);
+          });
+        } //***************************************
+
+
+        if (this.options.autoPlay) {
+          this.$slides.on('click.zf.orbit', function () {
+            _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);
+
+            _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();
+          });
+
+          if (this.options.pauseOnHover) {
+            this.$element.on('mouseenter.zf.orbit', function () {
+              _this.timer.pause();
+            }).on('mouseleave.zf.orbit', function () {
+              if (!_this.$element.data('clickedOn')) {
+                _this.timer.start();
+              }
+            });
+          }
+        }
+
+        if (this.options.navButtons) {
+          var $controls = this.$element.find(".".concat(this.options.nextClass, ", .").concat(this.options.prevClass));
+          $controls.attr('tabindex', 0) //also need to handle enter/return and spacebar key presses
+          .on('click.zf.orbit touchend.zf.orbit', function (e) {
+            e.preventDefault();
+
+            _this.changeSlide($(this).hasClass(_this.options.nextClass));
+          });
+        }
+
+        if (this.options.bullets) {
+          this.$bullets.on('click.zf.orbit touchend.zf.orbit', function () {
+            if (/is-active/g.test(this.className)) {
+              return false;
+            } //if this is active, kick out of function.
+
+
+            var idx = $(this).data('slide'),
+                ltr = idx > _this.$slides.filter('.is-active').data('slide'),
+                $slide = _this.$slides.eq(idx);
+
+            _this.changeSlide(ltr, $slide, idx);
+          });
+        }
+
+        if (this.options.accessible) {
+          this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) {
+            // handle keyboard event with keyboard util
+            Keyboard.handleKey(e, 'Orbit', {
+              next: function next() {
+                _this.changeSlide(true);
+              },
+              previous: function previous() {
+                _this.changeSlide(false);
+              },
+              handled: function handled() {
+                // if bullet is focused, make sure focus moves
+                if ($(e.target).is(_this.$bullets)) {
+                  _this.$bullets.filter('.is-active').focus();
+                }
+              }
+            });
+          });
+        }
+      }
+    }
+    /**
+     * Resets Orbit so it can be reinitialized
+     */
+
+  }, {
+    key: "_reset",
+    value: function _reset() {
+      // Don't do anything if there are no slides (first run)
+      if (typeof this.$slides == 'undefined') {
+        return;
+      }
+
+      if (this.$slides.length > 1) {
+        // Remove old events
+        this.$element.off('.zf.orbit').find('*').off('.zf.orbit'); // Restart timer if autoPlay is enabled
+
+        if (this.options.autoPlay) {
+          this.timer.restart();
+        } // Reset all sliddes
+
+
+        this.$slides.each(function (el) {
+          $(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide();
+        }); // Show the first slide
+
+        this.$slides.first().addClass('is-active').show(); // Triggers when the slide has finished animating
+
+        this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); // Select first bullet if bullets are present
+
+        if (this.options.bullets) {
+          this._updateBullets(0);
+        }
+      }
+    }
+    /**
+    * Changes the current slide to a new one.
+    * @function
+    * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.
+    * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.
+    * @param {Number} idx - the index of the new slide in its collection, if one chosen.
+    * @fires Orbit#slidechange
+    */
+
+  }, {
+    key: "changeSlide",
+    value: function changeSlide(isLTR, chosenSlide, idx) {
+      if (!this.$slides) {
+        return;
+      } // Don't freak out if we're in the middle of cleanup
+
+
+      var $curSlide = this.$slides.filter('.is-active').eq(0);
+
+      if (/mui/g.test($curSlide[0].className)) {
+        return false;
+      } //if the slide is currently animating, kick out of the function
+
+
+      var $firstSlide = this.$slides.first(),
+          $lastSlide = this.$slides.last(),
+          dirIn = isLTR ? 'Right' : 'Left',
+          dirOut = isLTR ? 'Left' : 'Right',
+          _this = this,
+          $newSlide;
+
+      if (!chosenSlide) {
+        //most of the time, this will be auto played or clicked from the navButtons.
+        $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!
+        this.options.infiniteWrap ? $curSlide.next(".".concat(this.options.slideClass)).length ? $curSlide.next(".".concat(this.options.slideClass)) : $firstSlide : $curSlide.next(".".concat(this.options.slideClass)) : //pick next slide if moving left to right
+        this.options.infiniteWrap ? $curSlide.prev(".".concat(this.options.slideClass)).length ? $curSlide.prev(".".concat(this.options.slideClass)) : $lastSlide : $curSlide.prev(".".concat(this.options.slideClass)); //pick prev slide if moving right to left
+      } else {
+        $newSlide = chosenSlide;
+      }
+
+      if ($newSlide.length) {
+        /**
+        * Triggers before the next slide starts animating in and only if a next slide has been found.
+        * @event Orbit#beforeslidechange
+        */
+        this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);
+
+        if (this.options.bullets) {
+          idx = idx || this.$slides.index($newSlide); //grab index to update bullets
+
+          this._updateBullets(idx);
+        }
+
+        if (this.options.useMUI && !this.$element.is(':hidden')) {
+          Motion.animateIn($newSlide.addClass('is-active'), this.options["animInFrom".concat(dirIn)], function () {
+            $newSlide.css({
+              'display': 'block'
+            }).attr('aria-live', 'polite');
+          });
+          Motion.animateOut($curSlide.removeClass('is-active'), this.options["animOutTo".concat(dirOut)], function () {
+            $curSlide.removeAttr('aria-live');
+
+            if (_this.options.autoPlay && !_this.timer.isPaused) {
+              _this.timer.restart();
+            } //do stuff?
+
+          });
+        } else {
+          $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();
+          $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();
+
+          if (this.options.autoPlay && !this.timer.isPaused) {
+            this.timer.restart();
+          }
+        }
+        /**
+        * Triggers when the slide has finished animating in.
+        * @event Orbit#slidechange
+        */
+
+
+        this.$element.trigger('slidechange.zf.orbit', [$newSlide]);
+      }
+    }
+    /**
+    * Updates the active state of the bullets, if displayed.
+    * @function
+    * @private
+    * @param {Number} idx - the index of the current slide.
+    */
+
+  }, {
+    key: "_updateBullets",
+    value: function _updateBullets(idx) {
+      var $oldBullet = this.$element.find(".".concat(this.options.boxOfBullets)).find('.is-active').removeClass('is-active').blur(),
+          span = $oldBullet.find('span:last').detach(),
+          $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);
+    }
+    /**
+    * Destroys the carousel and hides the element.
+    * @function
+    */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();
+    }
+  }]);
+
+  return Orbit;
+}(Plugin);
+
+Orbit.defaults = {
+  /**
+  * Tells the JS to look for and loadBullets.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  bullets: true,
+
+  /**
+  * Tells the JS to apply event listeners to nav buttons
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  navButtons: true,
+
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-in-right'
+  */
+  animInFromRight: 'slide-in-right',
+
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-out-right'
+  */
+  animOutToRight: 'slide-out-right',
+
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-in-left'
+  *
+  */
+  animInFromLeft: 'slide-in-left',
+
+  /**
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-out-left'
+  */
+  animOutToLeft: 'slide-out-left',
+
+  /**
+  * Allows Orbit to automatically animate on page load.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  autoPlay: true,
+
+  /**
+  * Amount of time, in ms, between slide transitions
+  * @option
+   * @type {number}
+  * @default 5000
+  */
+  timerDelay: 5000,
+
+  /**
+  * Allows Orbit to infinitely loop through the slides
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  infiniteWrap: true,
+
+  /**
+  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  swipe: true,
+
+  /**
+  * Allows the timing function to pause animation on hover.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  pauseOnHover: true,
+
+  /**
+  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  accessible: true,
+
+  /**
+  * Class applied to the container of Orbit
+  * @option
+   * @type {string}
+  * @default 'orbit-container'
+  */
+  containerClass: 'orbit-container',
+
+  /**
+  * Class applied to individual slides.
+  * @option
+   * @type {string}
+  * @default 'orbit-slide'
+  */
+  slideClass: 'orbit-slide',
+
+  /**
+  * Class applied to the bullet container. You're welcome.
+  * @option
+   * @type {string}
+  * @default 'orbit-bullets'
+  */
+  boxOfBullets: 'orbit-bullets',
+
+  /**
+  * Class applied to the `next` navigation button.
+  * @option
+   * @type {string}
+  * @default 'orbit-next'
+  */
+  nextClass: 'orbit-next',
+
+  /**
+  * Class applied to the `previous` navigation button.
+  * @option
+   * @type {string}
+  * @default 'orbit-previous'
+  */
+  prevClass: 'orbit-previous',
+
+  /**
+  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  useMUI: true
+};
+
+var MenuPlugins = {
+  dropdown: {
+    cssClass: 'dropdown',
+    plugin: DropdownMenu
+  },
+  drilldown: {
+    cssClass: 'drilldown',
+    plugin: Drilldown
+  },
+  accordion: {
+    cssClass: 'accordion-menu',
+    plugin: AccordionMenu
+  }
+}; // import "foundation.util.triggers.js";
+
+/**
+ * ResponsiveMenu module.
+ * @module foundation.responsiveMenu
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ */
+
+var ResponsiveMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveMenu, _Plugin);
+
+  function ResponsiveMenu() {
+    _classCallCheck(this, ResponsiveMenu);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveMenu).apply(this, arguments));
+  }
+
+  _createClass(ResponsiveMenu, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a responsive menu.
+     * @class
+     * @name ResponsiveMenu
+     * @fires ResponsiveMenu#init
+     * @param {jQuery} element - jQuery object to make into a dropdown menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = $(element);
+      this.rules = this.$element.data('responsive-menu');
+      this.currentMq = null;
+      this.currentPlugin = null;
+      this.className = 'ResponsiveMenu'; // ie9 back compat
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
+
+
+      if (typeof this.rules === 'string') {
+        var rulesTree = {}; // Parse rules from "classes" pulled from data attribute
+
+        var rules = this.rules.split(' '); // Iterate through every rule found
+
+        for (var i = 0; i < rules.length; i++) {
+          var rule = rules[i].split('-');
+          var ruleSize = rule.length > 1 ? rule[0] : 'small';
+          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+
+          if (MenuPlugins[rulePlugin] !== null) {
+            rulesTree[ruleSize] = MenuPlugins[rulePlugin];
+          }
+        }
+
+        this.rules = rulesTree;
+      }
+
+      if (!$.isEmptyObject(this.rules)) {
+        this._checkMediaQueries();
+      } // Add data-mutate since children may need it.
+
+
+      this.$element.attr('data-mutate', this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu'));
+    }
+    /**
+     * Initializes events for the Menu.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      $(window).on('changed.zf.mediaquery', function () {
+        _this._checkMediaQueries();
+      }); // $(window).on('resize.zf.ResponsiveMenu', function() {
+      //   _this._checkMediaQueries();
+      // });
+    }
+    /**
+     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_checkMediaQueries",
+    value: function _checkMediaQueries() {
+      var matchedMq,
+          _this = this; // Iterate through each rule and find the last matching rule
+
+
+      $.each(this.rules, function (key) {
+        if (MediaQuery.atLeast(key)) {
+          matchedMq = key;
+        }
+      }); // No match? No dice
+
+      if (!matchedMq) return; // Plugin already initialized? We good
+
+      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes
+
+      $.each(MenuPlugins, function (key, value) {
+        _this.$element.removeClass(value.cssClass);
+      }); // Add the CSS class for the new plugin
+
+      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin
+
+      if (this.currentPlugin) this.currentPlugin.destroy();
+      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+    }
+    /**
+     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.currentPlugin.destroy();
+      $(window).off('.zf.ResponsiveMenu');
+    }
+  }]);
+
+  return ResponsiveMenu;
+}(Plugin);
+
+ResponsiveMenu.defaults = {};
+
+/**
+ * ResponsiveToggle module.
+ * @module foundation.responsiveToggle
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.motion
+ */
+
+var ResponsiveToggle =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveToggle, _Plugin);
+
+  function ResponsiveToggle() {
+    _classCallCheck(this, ResponsiveToggle);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveToggle).apply(this, arguments));
+  }
+
+  _createClass(ResponsiveToggle, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Tab Bar.
+     * @class
+     * @name ResponsiveToggle
+     * @fires ResponsiveToggle#init
+     * @param {jQuery} element - jQuery object to attach tab bar functionality to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = $(element);
+      this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
+      this.className = 'ResponsiveToggle'; // ie9 back compat
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the tab bar by finding the target element, toggling element, and running update().
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init();
+
+      var targetID = this.$element.data('responsive-toggle');
+
+      if (!targetID) {
+        console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');
+      }
+
+      this.$targetMenu = $("#".concat(targetID));
+      this.$toggler = this.$element.find('[data-toggle]').filter(function () {
+        var target = $(this).data('toggle');
+        return target === targetID || target === "";
+      });
+      this.options = $.extend({}, this.options, this.$targetMenu.data()); // If they were set, parse the animation classes
+
+      if (this.options.animate) {
+        var input = this.options.animate.split(' ');
+        this.animationIn = input[0];
+        this.animationOut = input[1] || null;
+      }
+
+      this._update();
+    }
+    /**
+     * Adds necessary event handlers for the tab bar to work.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+
+      this._updateMqHandler = this._update.bind(this);
+      $(window).on('changed.zf.mediaquery', this._updateMqHandler);
+      this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));
+    }
+    /**
+     * Checks the current media query to determine if the tab bar should be visible or hidden.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_update",
+    value: function _update() {
+      // Mobile
+      if (!MediaQuery.atLeast(this.options.hideFor)) {
+        this.$element.show();
+        this.$targetMenu.hide();
+      } // Desktop
+      else {
+          this.$element.hide();
+          this.$targetMenu.show();
+        }
+    }
+    /**
+     * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.
+     * @function
+     * @fires ResponsiveToggle#toggled
+     */
+
+  }, {
+    key: "toggleMenu",
+    value: function toggleMenu() {
+      var _this2 = this;
+
+      if (!MediaQuery.atLeast(this.options.hideFor)) {
+        /**
+         * Fires when the element attached to the tab bar toggles.
+         * @event ResponsiveToggle#toggled
+         */
+        if (this.options.animate) {
+          if (this.$targetMenu.is(':hidden')) {
+            Motion.animateIn(this.$targetMenu, this.animationIn, function () {
+              _this2.$element.trigger('toggled.zf.responsiveToggle');
+
+              _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
+            });
+          } else {
+            Motion.animateOut(this.$targetMenu, this.animationOut, function () {
+              _this2.$element.trigger('toggled.zf.responsiveToggle');
+            });
+          }
+        } else {
+          this.$targetMenu.toggle(0);
+          this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');
+          this.$element.trigger('toggled.zf.responsiveToggle');
+        }
+      }
+    }
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.responsiveToggle');
+      this.$toggler.off('.zf.responsiveToggle');
+      $(window).off('changed.zf.mediaquery', this._updateMqHandler);
+    }
+  }]);
+
+  return ResponsiveToggle;
+}(Plugin);
+
+ResponsiveToggle.defaults = {
+  /**
+   * The breakpoint after which the menu is always shown, and the tab bar is hidden.
+   * @option
+   * @type {string}
+   * @default 'medium'
+   */
+  hideFor: 'medium',
+
+  /**
+   * To decide if the toggle should be animated or not.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animate: false
+};
+
+/**
+ * Reveal module.
+ * @module foundation.reveal
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.motion if using animations
+ */
+
+var Reveal =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Reveal, _Plugin);
+
+  function Reveal() {
+    _classCallCheck(this, Reveal);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Reveal).apply(this, arguments));
+  }
+
+  _createClass(Reveal, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Reveal.
+     * @class
+     * @name Reveal
+     * @param {jQuery} element - jQuery object to use for the modal.
+     * @param {Object} options - optional parameters.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);
+      this.className = 'Reveal'; // ie9 back compat
+
+      this._init(); // Triggers init is idempotent, just need to make sure it is initialized
+
+
+      Triggers.init($);
+      Keyboard.register('Reveal', {
+        'ESCAPE': 'close'
+      });
+    }
+    /**
+     * Initializes the modal by adding the overlay and close buttons, (if selected).
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      MediaQuery._init();
+
+      this.id = this.$element.attr('id');
+      this.isActive = false;
+      this.cached = {
+        mq: MediaQuery.current
+      };
+      this.$anchor = $("[data-open=\"".concat(this.id, "\"]")).length ? $("[data-open=\"".concat(this.id, "\"]")) : $("[data-toggle=\"".concat(this.id, "\"]"));
+      this.$anchor.attr({
+        'aria-controls': this.id,
+        'aria-haspopup': true,
+        'tabindex': 0
+      });
+
+      if (this.options.fullScreen || this.$element.hasClass('full')) {
+        this.options.fullScreen = true;
+        this.options.overlay = false;
+      }
+
+      if (this.options.overlay && !this.$overlay) {
+        this.$overlay = this._makeOverlay(this.id);
+      }
+
+      this.$element.attr({
+        'role': 'dialog',
+        'aria-hidden': true,
+        'data-yeti-box': this.id,
+        'data-resize': this.id
+      });
+
+      if (this.$overlay) {
+        this.$element.detach().appendTo(this.$overlay);
+      } else {
+        this.$element.detach().appendTo($(this.options.appendTo));
+        this.$element.addClass('without-overlay');
+      }
+
+      this._events();
+
+      if (this.options.deepLink && window.location.hash === "#".concat(this.id)) {
+        this.onLoadListener = onLoad($(window), function () {
+          return _this2.open();
+        });
+      }
+    }
+    /**
+     * Creates an overlay div to display behind the modal.
+     * @private
+     */
+
+  }, {
+    key: "_makeOverlay",
+    value: function _makeOverlay() {
+      var additionalOverlayClasses = '';
+
+      if (this.options.additionalOverlayClasses) {
+        additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;
+      }
+
+      return $('<div></div>').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo);
+    }
+    /**
+     * Updates position of modal
+     * TODO:  Figure out if we actually need to cache these values or if it doesn't matter
+     * @private
+     */
+
+  }, {
+    key: "_updatePosition",
+    value: function _updatePosition() {
+      var width = this.$element.outerWidth();
+      var outerWidth = $(window).width();
+      var height = this.$element.outerHeight();
+      var outerHeight = $(window).height();
+      var left,
+          top = null;
+
+      if (this.options.hOffset === 'auto') {
+        left = parseInt((outerWidth - width) / 2, 10);
+      } else {
+        left = parseInt(this.options.hOffset, 10);
+      }
+
+      if (this.options.vOffset === 'auto') {
+        if (height > outerHeight) {
+          top = parseInt(Math.min(100, outerHeight / 10), 10);
+        } else {
+          top = parseInt((outerHeight - height) / 4, 10);
+        }
+      } else if (this.options.vOffset !== null) {
+        top = parseInt(this.options.vOffset, 10);
+      }
+
+      if (top !== null) {
+        this.$element.css({
+          top: top + 'px'
+        });
+      } // only worry about left if we don't have an overlay or we have a horizontal offset,
+      // otherwise we're perfectly in the middle
+
+
+      if (!this.$overlay || this.options.hOffset !== 'auto') {
+        this.$element.css({
+          left: left + 'px'
+        });
+        this.$element.css({
+          margin: '0px'
+        });
+      }
+    }
+    /**
+     * Adds event handlers for the modal.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this3 = this;
+
+      var _this = this;
+
+      this.$element.on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': function closeZfTrigger(event, $element) {
+          if (event.target === _this.$element[0] || $(event.target).parents('[data-closable]')[0] === $element) {
+            // only close reveal when it's explicitly called
+            return _this3.close.apply(_this3);
+          }
+        },
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'resizeme.zf.trigger': function resizemeZfTrigger() {
+          _this._updatePosition();
+        }
+      });
+
+      if (this.options.closeOnClick && this.options.overlay) {
+        this.$overlay.off('.zf.reveal').on('click.zf.reveal', function (e) {
+          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target) || !$.contains(document, e.target)) {
+            return;
+          }
+
+          _this.close();
+        });
+      }
+
+      if (this.options.deepLink) {
+        $(window).on("hashchange.zf.reveal:".concat(this.id), this._handleState.bind(this));
+      }
+    }
+    /**
+     * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.
+     * @private
+     */
+
+  }, {
+    key: "_handleState",
+    value: function _handleState(e) {
+      if (window.location.hash === '#' + this.id && !this.isActive) {
+        this.open();
+      } else {
+        this.close();
+      }
+    }
+    /**
+    * Disables the scroll when Reveal is shown to prevent the background from shifting
+    * @param {number} scrollTop - Scroll to visually apply, window current scroll by default
+    */
+
+  }, {
+    key: "_disableScroll",
+    value: function _disableScroll(scrollTop) {
+      scrollTop = scrollTop || $(window).scrollTop();
+
+      if ($(document).height() > $(window).height()) {
+        $("html").css("top", -scrollTop);
+      }
+    }
+    /**
+    * Reenables the scroll when Reveal closes
+    * @param {number} scrollTop - Scroll to restore, html "top" property by default (as set by `_disableScroll`)
+    */
+
+  }, {
+    key: "_enableScroll",
+    value: function _enableScroll(scrollTop) {
+      scrollTop = scrollTop || parseInt($("html").css("top"));
+
+      if ($(document).height() > $(window).height()) {
+        $("html").css("top", "");
+        $(window).scrollTop(-scrollTop);
+      }
+    }
+    /**
+     * Opens the modal controlled by `this.$anchor`, and closes all others by default.
+     * @function
+     * @fires Reveal#closeme
+     * @fires Reveal#open
+     */
+
+  }, {
+    key: "open",
+    value: function open() {
+      var _this4 = this;
+
+      // either update or replace browser history
+      var hash = "#".concat(this.id);
+
+      if (this.options.deepLink && window.location.hash !== hash) {
+        if (window.history.pushState) {
+          if (this.options.updateHistory) {
+            window.history.pushState({}, '', hash);
+          } else {
+            window.history.replaceState({}, '', hash);
+          }
+        } else {
+          window.location.hash = hash;
+        }
+      } // Remember anchor that opened it to set focus back later, have general anchors as fallback
+
+
+      this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;
+      this.isActive = true; // Make elements invisible, but remove display: none so we can get size and positioning
+
+      this.$element.css({
+        'visibility': 'hidden'
+      }).show().scrollTop(0);
+
+      if (this.options.overlay) {
+        this.$overlay.css({
+          'visibility': 'hidden'
+        }).show();
+      }
+
+      this._updatePosition();
+
+      this.$element.hide().css({
+        'visibility': ''
+      });
+
+      if (this.$overlay) {
+        this.$overlay.css({
+          'visibility': ''
+        }).hide();
+
+        if (this.$element.hasClass('fast')) {
+          this.$overlay.addClass('fast');
+        } else if (this.$element.hasClass('slow')) {
+          this.$overlay.addClass('slow');
+        }
+      }
+
+      if (!this.options.multipleOpened) {
+        /**
+         * Fires immediately before the modal opens.
+         * Closes any other modals that are currently open
+         * @event Reveal#closeme
+         */
+        this.$element.trigger('closeme.zf.reveal', this.id);
+      }
+
+      this._disableScroll();
+
+      var _this = this; // Motion UI method of reveal
+
+
+      if (this.options.animationIn) {
+        var afterAnimation = function afterAnimation() {
+          _this.$element.attr({
+            'aria-hidden': false,
+            'tabindex': -1
+          }).focus();
+
+          _this._addGlobalClasses();
+
+          Keyboard.trapFocus(_this.$element);
+        };
+
+        if (this.options.overlay) {
+          Motion.animateIn(this.$overlay, 'fade-in');
+        }
+
+        Motion.animateIn(this.$element, this.options.animationIn, function () {
+          if (_this4.$element) {
+            // protect against object having been removed
+            _this4.focusableElements = Keyboard.findFocusable(_this4.$element);
+            afterAnimation();
+          }
+        });
+      } // jQuery method of reveal
+      else {
+          if (this.options.overlay) {
+            this.$overlay.show(0);
+          }
+
+          this.$element.show(this.options.showDelay);
+        } // handle accessibility
+
+
+      this.$element.attr({
+        'aria-hidden': false,
+        'tabindex': -1
+      }).focus();
+      Keyboard.trapFocus(this.$element);
+
+      this._addGlobalClasses();
+
+      this._addGlobalListeners();
+      /**
+       * Fires when the modal has successfully opened.
+       * @event Reveal#open
+       */
+
+
+      this.$element.trigger('open.zf.reveal');
+    }
+    /**
+     * Adds classes and listeners on document required by open modals.
+     *
+     * The following classes are added and updated:
+     * - `.is-reveal-open` - Prevents the scroll on document
+     * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the
+     *                       scroll was not disabled. This prevent a "shift" of the page content due
+     *                       the scrollbar disappearing when the modal opens.
+     *
+     * @private
+     */
+
+  }, {
+    key: "_addGlobalClasses",
+    value: function _addGlobalClasses() {
+      var updateScrollbarClass = function updateScrollbarClass() {
+        $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));
+      };
+
+      this.$element.on('resizeme.zf.trigger.revealScrollbarListener', function () {
+        return updateScrollbarClass();
+      });
+      updateScrollbarClass();
+      $('html').addClass('is-reveal-open');
+    }
+    /**
+     * Removes classes and listeners on document that were required by open modals.
+     * @private
+     */
+
+  }, {
+    key: "_removeGlobalClasses",
+    value: function _removeGlobalClasses() {
+      this.$element.off('resizeme.zf.trigger.revealScrollbarListener');
+      $('html').removeClass('is-reveal-open');
+      $('html').removeClass('zf-has-scroll');
+    }
+    /**
+     * Adds extra event handlers for the body and window if necessary.
+     * @private
+     */
+
+  }, {
+    key: "_addGlobalListeners",
+    value: function _addGlobalListeners() {
+      var _this = this;
+
+      if (!this.$element) {
+        return;
+      } // If we're in the middle of cleanup, don't freak out
+
+
+      this.focusableElements = Keyboard.findFocusable(this.$element);
+
+      if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {
+        $('body').on('click.zf.reveal', function (e) {
+          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target) || !$.contains(document, e.target)) {
+            return;
+          }
+
+          _this.close();
+        });
+      }
+
+      if (this.options.closeOnEsc) {
+        $(window).on('keydown.zf.reveal', function (e) {
+          Keyboard.handleKey(e, 'Reveal', {
+            close: function close() {
+              if (_this.options.closeOnEsc) {
+                _this.close();
+              }
+            }
+          });
+        });
+      }
+    }
+    /**
+     * Closes the modal.
+     * @function
+     * @fires Reveal#closed
+     */
+
+  }, {
+    key: "close",
+    value: function close() {
+      if (!this.isActive || !this.$element.is(':visible')) {
+        return false;
+      }
+
+      var _this = this; // Motion UI method of hiding
+
+
+      if (this.options.animationOut) {
+        if (this.options.overlay) {
+          Motion.animateOut(this.$overlay, 'fade-out');
+        }
+
+        Motion.animateOut(this.$element, this.options.animationOut, finishUp);
+      } // jQuery method of hiding
+      else {
+          this.$element.hide(this.options.hideDelay);
+
+          if (this.options.overlay) {
+            this.$overlay.hide(0, finishUp);
+          } else {
+            finishUp();
+          }
+        } // Conditionals to remove extra event listeners added on open
+
+
+      if (this.options.closeOnEsc) {
+        $(window).off('keydown.zf.reveal');
+      }
+
+      if (!this.options.overlay && this.options.closeOnClick) {
+        $('body').off('click.zf.reveal');
+      }
+
+      this.$element.off('keydown.zf.reveal');
+
+      function finishUp() {
+        // Get the current top before the modal is closed and restore the scroll after.
+        // TODO: use component properties instead of HTML properties
+        // See https://github.com/zurb/foundation-sites/pull/10786
+        var scrollTop = parseInt($("html").css("top"));
+
+        if ($('.reveal:visible').length === 0) {
+          _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
+
+        }
+
+        Keyboard.releaseFocus(_this.$element);
+
+        _this.$element.attr('aria-hidden', true);
+
+        _this._enableScroll(scrollTop);
+        /**
+        * Fires when the modal is done closing.
+        * @event Reveal#closed
+        */
+
+
+        _this.$element.trigger('closed.zf.reveal');
+      }
+      /**
+      * Resets the modal content
+      * This prevents a running video to keep going in the background
+      */
+
+
+      if (this.options.resetOnClose) {
+        this.$element.html(this.$element.html());
+      }
+
+      this.isActive = false; // If deepLink and we did not switched to an other modal...
+
+      if (_this.options.deepLink && window.location.hash === "#".concat(this.id)) {
+        // Remove the history hash
+        if (window.history.replaceState) {
+          var urlWithoutHash = window.location.pathname + window.location.search;
+
+          if (this.options.updateHistory) {
+            window.history.pushState({}, '', urlWithoutHash); // remove the hash
+          } else {
+            window.history.replaceState('', document.title, urlWithoutHash);
+          }
+        } else {
+          window.location.hash = '';
+        }
+      }
+
+      this.$activeAnchor.focus();
+    }
+    /**
+     * Toggles the open/closed state of a modal.
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      if (this.isActive) {
+        this.close();
+      } else {
+        this.open();
+      }
+    }
+  }, {
+    key: "_destroy",
+
+    /**
+     * Destroys an instance of a modal.
+     * @function
+     */
+    value: function _destroy() {
+      if (this.options.overlay) {
+        this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()
+
+        this.$overlay.hide().off().remove();
+      }
+
+      this.$element.hide().off();
+      this.$anchor.off('.zf');
+      $(window).off(".zf.reveal:".concat(this.id));
+      if (this.onLoadListener) $(window).off(this.onLoadListener);
+
+      if ($('.reveal:visible').length === 0) {
+        this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
+
+      }
+    }
+  }]);
+
+  return Reveal;
+}(Plugin);
+
+Reveal.defaults = {
+  /**
+   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  animationIn: '',
+
+  /**
+   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  animationOut: '',
+
+  /**
+   * Time, in ms, to delay the opening of a modal after a click if no animation used.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  showDelay: 0,
+
+  /**
+   * Time, in ms, to delay the closing of a modal after a click if no animation used.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hideDelay: 0,
+
+  /**
+   * Allows a click on the body/overlay to close the modal.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Allows the modal to close if the user presses the `ESCAPE` key.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnEsc: true,
+
+  /**
+   * If true, allows multiple modals to be displayed at once.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  multipleOpened: false,
+
+  /**
+   * Distance, in pixels, the modal should push down from the top of the screen.
+   * @option
+   * @type {number|string}
+   * @default auto
+   */
+  vOffset: 'auto',
+
+  /**
+   * Distance, in pixels, the modal should push in from the side of the screen.
+   * @option
+   * @type {number|string}
+   * @default auto
+   */
+  hOffset: 'auto',
+
+  /**
+   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  fullScreen: false,
+
+  /**
+   * Allows the modal to generate an overlay div, which will cover the view when modal opens.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  overlay: true,
+
+  /**
+   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  resetOnClose: false,
+
+  /**
+   * Link the location hash to the modal.
+   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+
+  /**
+   * If `deepLink` is enabled, update the browser history with the open modal
+   * @option
+   * @default false
+   */
+  updateHistory: false,
+
+  /**
+  * Allows the modal to append to custom div.
+  * @option
+  * @type {string}
+  * @default "body"
+  */
+  appendTo: "body",
+
+  /**
+   * Allows adding additional class names to the reveal overlay.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  additionalOverlayClasses: ''
+};
+
+/**
+ * Slider module.
+ * @module foundation.slider
+ * @requires foundation.util.motion
+ * @requires foundation.util.triggers
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.touch
+ */
+
+var Slider =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Slider, _Plugin);
+
+  function Slider() {
+    _classCallCheck(this, Slider);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Slider).apply(this, arguments));
+  }
+
+  _createClass(Slider, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a slider control.
+     * @class
+     * @name Slider
+     * @param {jQuery} element - jQuery object to make into a slider control.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Slider.defaults, this.$element.data(), options);
+      this.className = 'Slider'; // ie9 back compat
+      // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.
+
+      Touch.init($);
+      Triggers.init($);
+
+      this._init();
+
+      Keyboard.register('Slider', {
+        'ltr': {
+          'ARROW_RIGHT': 'increase',
+          'ARROW_UP': 'increase',
+          'ARROW_DOWN': 'decrease',
+          'ARROW_LEFT': 'decrease',
+          'SHIFT_ARROW_RIGHT': 'increase_fast',
+          'SHIFT_ARROW_UP': 'increase_fast',
+          'SHIFT_ARROW_DOWN': 'decrease_fast',
+          'SHIFT_ARROW_LEFT': 'decrease_fast',
+          'HOME': 'min',
+          'END': 'max'
+        },
+        'rtl': {
+          'ARROW_LEFT': 'increase',
+          'ARROW_RIGHT': 'decrease',
+          'SHIFT_ARROW_LEFT': 'increase_fast',
+          'SHIFT_ARROW_RIGHT': 'decrease_fast'
+        }
+      });
+    }
+    /**
+     * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      this.inputs = this.$element.find('input');
+      this.handles = this.$element.find('[data-slider-handle]');
+      this.$handle = this.handles.eq(0);
+      this.$input = this.inputs.length ? this.inputs.eq(0) : $("#".concat(this.$handle.attr('aria-controls')));
+      this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);
+
+      if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {
+        this.options.disabled = true;
+        this.$element.addClass(this.options.disabledClass);
+      }
+
+      if (!this.inputs.length) {
+        this.inputs = $().add(this.$input);
+        this.options.binding = true;
+      }
+
+      this._setInitAttr(0);
+
+      if (this.handles[1]) {
+        this.options.doubleSided = true;
+        this.$handle2 = this.handles.eq(1);
+        this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $("#".concat(this.$handle2.attr('aria-controls')));
+
+        if (!this.inputs[1]) {
+          this.inputs = this.inputs.add(this.$input2);
+        }
+
+        this._setInitAttr(1);
+      } // Set handle positions
+
+
+      this.setHandles();
+
+      this._events();
+    }
+  }, {
+    key: "setHandles",
+    value: function setHandles() {
+      var _this2 = this;
+
+      if (this.handles[1]) {
+        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, function () {
+          _this2._setHandlePos(_this2.$handle2, _this2.inputs.eq(1).val(), true);
+        });
+      } else {
+        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);
+      }
+    }
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      this.setHandles();
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)
+    */
+
+  }, {
+    key: "_pctOfBar",
+    value: function _pctOfBar(value) {
+      var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start);
+
+      switch (this.options.positionValueFunction) {
+        case "pow":
+          pctOfBar = this._logTransform(pctOfBar);
+          break;
+
+        case "log":
+          pctOfBar = this._powTransform(pctOfBar);
+          break;
+      }
+
+      return pctOfBar.toFixed(2);
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value
+    */
+
+  }, {
+    key: "_value",
+    value: function _value(pctOfBar) {
+      switch (this.options.positionValueFunction) {
+        case "pow":
+          pctOfBar = this._powTransform(pctOfBar);
+          break;
+
+        case "log":
+          pctOfBar = this._logTransform(pctOfBar);
+          break;
+      }
+
+      var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);
+      return value;
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function
+    */
+
+  }, {
+    key: "_logTransform",
+    value: function _logTransform(value) {
+      return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1);
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function
+    */
+
+  }, {
+    key: "_powTransform",
+    value: function _powTransform(value) {
+      return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1);
+    }
+    /**
+     * Sets the position of the selected handle and fill bar.
+     * @function
+     * @private
+     * @param {jQuery} $hndl - the selected handle to move.
+     * @param {Number} location - floating point between the start and end values of the slider bar.
+     * @param {Function} cb - callback function to fire on completion.
+     * @fires Slider#moved
+     * @fires Slider#changed
+     */
+
+  }, {
+    key: "_setHandlePos",
+    value: function _setHandlePos($hndl, location, noInvert, cb) {
+      // don't move if the slider has been disabled since its initialization
+      if (this.$element.hasClass(this.options.disabledClass)) {
+        return;
+      } //might need to alter that slightly for bars that will have odd number selections.
+
+
+      location = parseFloat(location); //on input change events, convert string to number...grumble.
+      // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max
+
+      if (location < this.options.start) {
+        location = this.options.start;
+      } else if (location > this.options.end) {
+        location = this.options.end;
+      }
+
+      var isDbl = this.options.doubleSided; //this is for single-handled vertical sliders, it adjusts the value to account for the slider being "upside-down"
+      //for click and drag events, it's weird due to the scale(-1, 1) css property
+
+      if (this.options.vertical && !noInvert) {
+        location = this.options.end - location;
+      }
+
+      if (isDbl) {
+        //this block is to prevent 2 handles from crossing eachother. Could/should be improved.
+        if (this.handles.index($hndl) === 0) {
+          var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));
+          location = location >= h2Val ? h2Val - this.options.step : location;
+        } else {
+          var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));
+          location = location <= h1Val ? h1Val + this.options.step : location;
+        }
+      }
+
+      var _this = this,
+          vert = this.options.vertical,
+          hOrW = vert ? 'height' : 'width',
+          lOrT = vert ? 'top' : 'left',
+          handleDim = $hndl[0].getBoundingClientRect()[hOrW],
+          elemDim = this.$element[0].getBoundingClientRect()[hOrW],
+          //percentage of bar min/max value based on click or drag point
+      pctOfBar = this._pctOfBar(location),
+          //number of actual pixels to shift the handle, based on the percentage obtained above
+      pxToMove = (elemDim - handleDim) * pctOfBar,
+          //percentage of bar to shift the handle
+      movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value
+
+
+      location = parseFloat(location.toFixed(this.options.decimal)); // declare empty object for css adjustments, only used with 2 handled-sliders
+
+      var css = {};
+
+      this._setValues($hndl, location); // TODO update to calculate based on values set to respective inputs??
+
+
+      if (isDbl) {
+        var isLeftHndl = this.handles.index($hndl) === 0,
+            //empty variable, will be used for min-height/width for fill bar
+        dim,
+            //percentage w/h of the handle compared to the slider bar
+        handlePct = ~~(percent(handleDim, elemDim) * 100); //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar
+
+        if (isLeftHndl) {
+          //left or top percentage value to apply to the fill bar.
+          css[lOrT] = "".concat(movement, "%"); //calculate the new min-height/width for the fill bar.
+
+          dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider
+          //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.
+
+          if (cb && typeof cb === 'function') {
+            cb();
+          } //this is only needed for the initialization of 2 handled sliders
+
+        } else {
+          //just caching the value of the left/bottom handle's left/top property
+          var handlePos = parseFloat(this.$handle[0].style[lOrT]); //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0
+          //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself
+
+          dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct;
+        } // assign the min-height/width to our css object
+
+
+        css["min-".concat(hOrW)] = "".concat(dim, "%");
+      }
+
+      this.$element.one('finished.zf.animate', function () {
+        /**
+         * Fires when the handle is done moving.
+         * @event Slider#moved
+         */
+        _this.$element.trigger('moved.zf.slider', [$hndl]);
+      }); //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.
+
+      var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime;
+      Move(moveTime, $hndl, function () {
+        // adjusting the left/top property of the handle, based on the percentage calculated above
+        // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,
+        // fall back to next best guess.
+        if (isNaN(movement)) {
+          $hndl.css(lOrT, "".concat(pctOfBar * 100, "%"));
+        } else {
+          $hndl.css(lOrT, "".concat(movement, "%"));
+        }
+
+        if (!_this.options.doubleSided) {
+          //if single-handled, a simple method to expand the fill bar
+          _this.$fill.css(hOrW, "".concat(pctOfBar * 100, "%"));
+        } else {
+          //otherwise, use the css object we created above
+          _this.$fill.css(css);
+        }
+      });
+      /**
+       * Fires when the value has not been change for a given time.
+       * @event Slider#changed
+       */
+
+      clearTimeout(_this.timeout);
+      _this.timeout = setTimeout(function () {
+        _this.$element.trigger('changed.zf.slider', [$hndl]);
+      }, _this.options.changedDelay);
+    }
+    /**
+     * Sets the initial attribute for the slider element.
+     * @function
+     * @private
+     * @param {Number} idx - index of the current handle/input to use.
+     */
+
+  }, {
+    key: "_setInitAttr",
+    value: function _setInitAttr(idx) {
+      var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd;
+      var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');
+      this.inputs.eq(idx).attr({
+        'id': id,
+        'max': this.options.end,
+        'min': this.options.start,
+        'step': this.options.step
+      });
+      this.inputs.eq(idx).val(initVal);
+      this.handles.eq(idx).attr({
+        'role': 'slider',
+        'aria-controls': id,
+        'aria-valuemax': this.options.end,
+        'aria-valuemin': this.options.start,
+        'aria-valuenow': initVal,
+        'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',
+        'tabindex': 0
+      });
+    }
+    /**
+     * Sets the input and `aria-valuenow` values for the slider element.
+     * @function
+     * @private
+     * @param {jQuery} $handle - the currently selected handle.
+     * @param {Number} val - floating point of the new value.
+     */
+
+  }, {
+    key: "_setValues",
+    value: function _setValues($handle, val) {
+      var idx = this.options.doubleSided ? this.handles.index($handle) : 0;
+      this.inputs.eq(idx).val(val);
+      $handle.attr('aria-valuenow', val);
+    }
+    /**
+     * Handles events on the slider element.
+     * Calculates the new location of the current handle.
+     * If there are two handles and the bar was clicked, it determines which handle to move.
+     * @function
+     * @private
+     * @param {Object} e - the `event` object passed from the listener.
+     * @param {jQuery} $handle - the current handle to calculate for, if selected.
+     * @param {Number} val - floating point number for the new value of the slider.
+     * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.
+     */
+
+  }, {
+    key: "_handleEvent",
+    value: function _handleEvent(e, $handle, val) {
+      var value, hasVal;
+
+      if (!val) {
+        //click or drag events
+        e.preventDefault();
+
+        var _this = this,
+            vertical = this.options.vertical,
+            param = vertical ? 'height' : 'width',
+            direction = vertical ? 'top' : 'left',
+            eventOffset = vertical ? e.pageY : e.pageX,
+            halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,
+            barDim = this.$element[0].getBoundingClientRect()[param],
+            windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();
+
+        var elemOffset = this.$element.offset()[direction]; // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...
+        // best way to guess this is simulated is if clientY == pageY
+
+        if (e.clientY === e.pageY) {
+          eventOffset = eventOffset + windowScroll;
+        }
+
+        var eventFromBar = eventOffset - elemOffset;
+        var barXY;
+
+        if (eventFromBar < 0) {
+          barXY = 0;
+        } else if (eventFromBar > barDim) {
+          barXY = barDim;
+        } else {
+          barXY = eventFromBar;
+        }
+
+        var offsetPct = percent(barXY, barDim);
+        value = this._value(offsetPct); // turn everything around for RTL, yay math!
+
+        if (rtl() && !this.options.vertical) {
+          value = this.options.end - value;
+        }
+
+        value = _this._adjustValue(null, value); //boolean flag for the setHandlePos fn, specifically for vertical sliders
+
+        hasVal = false;
+
+        if (!$handle) {
+          //figure out which handle it is, pass it to the next function.
+          var firstHndlPos = absPosition(this.$handle, direction, barXY, param),
+              secndHndlPos = absPosition(this.$handle2, direction, barXY, param);
+          $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;
+        }
+      } else {
+        //change event on input
+        value = this._adjustValue(null, val);
+        hasVal = true;
+      }
+
+      this._setHandlePos($handle, value, hasVal);
+    }
+    /**
+     * Adjustes value for handle in regard to step value. returns adjusted value
+     * @function
+     * @private
+     * @param {jQuery} $handle - the selected handle.
+     * @param {Number} value - value to adjust. used if $handle is falsy
+     */
+
+  }, {
+    key: "_adjustValue",
+    value: function _adjustValue($handle, value) {
+      var val,
+          step = this.options.step,
+          div = parseFloat(step / 2),
+          left,
+          prev_val,
+          next_val;
+
+      if (!!$handle) {
+        val = parseFloat($handle.attr('aria-valuenow'));
+      } else {
+        val = value;
+      }
+
+      if (val >= 0) {
+        left = val % step;
+      } else {
+        left = step + val % step;
+      }
+
+      prev_val = val - left;
+      next_val = prev_val + step;
+
+      if (left === 0) {
+        return val;
+      }
+
+      val = val >= prev_val + div ? next_val : prev_val;
+      return val;
+    }
+    /**
+     * Adds event listeners to the slider elements.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._eventsForHandle(this.$handle);
+
+      if (this.handles[1]) {
+        this._eventsForHandle(this.$handle2);
+      }
+    }
+    /**
+     * Adds event listeners a particular handle
+     * @function
+     * @private
+     * @param {jQuery} $handle - the current handle to apply listeners to.
+     */
+
+  }, {
+    key: "_eventsForHandle",
+    value: function _eventsForHandle($handle) {
+      var _this = this,
+          curHandle;
+
+      var handleChangeEvent = function handleChangeEvent(e) {
+        var idx = _this.inputs.index($(this));
+
+        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());
+      }; // IE only triggers the change event when the input loses focus which strictly follows the HTML specification
+      // listen for the enter key and trigger a change
+      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events
+
+
+      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {
+        if (e.keyCode == 13) handleChangeEvent.call(this, e);
+      });
+      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);
+
+      if (this.options.clickSelect) {
+        this.$element.off('click.zf.slider').on('click.zf.slider', function (e) {
+          if (_this.$element.data('dragging')) {
+            return false;
+          }
+
+          if (!$(e.target).is('[data-slider-handle]')) {
+            if (_this.options.doubleSided) {
+              _this._handleEvent(e);
+            } else {
+              _this._handleEvent(e, _this.$handle);
+            }
+          }
+        });
+      }
+
+      if (this.options.draggable) {
+        this.handles.addTouch();
+        var $body = $('body');
+        $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) {
+          $handle.addClass('is-dragging');
+
+          _this.$fill.addClass('is-dragging'); //
+
+
+          _this.$element.data('dragging', true);
+
+          curHandle = $(e.currentTarget);
+          $body.on('mousemove.zf.slider', function (e) {
+            e.preventDefault();
+
+            _this._handleEvent(e, curHandle);
+          }).on('mouseup.zf.slider', function (e) {
+            _this._handleEvent(e, curHandle);
+
+            $handle.removeClass('is-dragging');
+
+            _this.$fill.removeClass('is-dragging');
+
+            _this.$element.data('dragging', false);
+
+            $body.off('mousemove.zf.slider mouseup.zf.slider');
+          });
+        }) // prevent events triggered by touch
+        .on('selectstart.zf.slider touchmove.zf.slider', function (e) {
+          e.preventDefault();
+        });
+      }
+
+      $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) {
+        var _$handle = $(this),
+            idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,
+            oldValue = parseFloat(_this.inputs.eq(idx).val()),
+            newValue; // handle keyboard event with keyboard util
+
+
+        Keyboard.handleKey(e, 'Slider', {
+          decrease: function decrease() {
+            newValue = oldValue - _this.options.step;
+          },
+          increase: function increase() {
+            newValue = oldValue + _this.options.step;
+          },
+          decrease_fast: function decrease_fast() {
+            newValue = oldValue - _this.options.step * 10;
+          },
+          increase_fast: function increase_fast() {
+            newValue = oldValue + _this.options.step * 10;
+          },
+          min: function min() {
+            newValue = _this.options.start;
+          },
+          max: function max() {
+            newValue = _this.options.end;
+          },
+          handled: function handled() {
+            // only set handle pos when event was handled specially
+            e.preventDefault();
+
+            _this._setHandlePos(_$handle, newValue, true);
+          }
+        });
+        /*if (newValue) { // if pressed key has special function, update value
+          e.preventDefault();
+          _this._setHandlePos(_$handle, newValue);
+        }*/
+      });
+    }
+    /**
+     * Destroys the slider plugin.
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.handles.off('.zf.slider');
+      this.inputs.off('.zf.slider');
+      this.$element.off('.zf.slider');
+      clearTimeout(this.timeout);
+    }
+  }]);
+
+  return Slider;
+}(Plugin);
+
+Slider.defaults = {
+  /**
+   * Minimum value for the slider scale.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  start: 0,
+
+  /**
+   * Maximum value for the slider scale.
+   * @option
+   * @type {number}
+   * @default 100
+   */
+  end: 100,
+
+  /**
+   * Minimum value change per change event.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  step: 1,
+
+  /**
+   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  initialStart: 0,
+
+  /**
+   * Value at which the right handle/second input should be set to on initialization.
+   * @option
+   * @type {number}
+   * @default 100
+   */
+  initialEnd: 100,
+
+  /**
+   * Allows the input to be located outside the container and visible. Set to by the JS
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  binding: false,
+
+  /**
+   * Allows the user to click/tap on the slider bar to select a value.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  clickSelect: true,
+
+  /**
+   * Set to true and use the `vertical` class to change alignment to vertical.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  vertical: false,
+
+  /**
+   * Allows the user to drag the slider handle(s) to select a value.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  draggable: true,
+
+  /**
+   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disabled: false,
+
+  /**
+   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  doubleSided: false,
+
+  /**
+   * Potential future feature.
+   */
+  // steps: 100,
+
+  /**
+   * Number of decimal places the plugin should go to for floating point precision.
+   * @option
+   * @type {number}
+   * @default 2
+   */
+  decimal: 2,
+
+  /**
+   * Time delay for dragged elements.
+   */
+  // dragDelay: 0,
+
+  /**
+   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.
+   * @option
+   * @type {number}
+   * @default 200
+   */
+  moveTime: 200,
+  //update this if changing the transition time in the sass
+
+  /**
+   * Class applied to disabled sliders.
+   * @option
+   * @type {string}
+   * @default 'disabled'
+   */
+  disabledClass: 'disabled',
+
+  /**
+   * Will invert the default layout for a vertical<span data-tooltip title="who would do this???"> </span>slider.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  invertVertical: false,
+
+  /**
+   * Milliseconds before the `changed.zf-slider` event is triggered after value change.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  changedDelay: 500,
+
+  /**
+  * Basevalue for non-linear sliders
+  * @option
+  * @type {number}
+  * @default 5
+  */
+  nonLinearBase: 5,
+
+  /**
+  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.
+  * @option
+  * @type {string}
+  * @default 'linear'
+  */
+  positionValueFunction: 'linear'
+};
+
+function percent(frac, num) {
+  return frac / num;
+}
+
+function absPosition($handle, dir, clickPos, param) {
+  return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos);
+}
+
+function baseLog(base, value) {
+  return Math.log(value) / Math.log(base);
+}
+
+/**
+ * Sticky module.
+ * @module foundation.sticky
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ */
+
+var Sticky =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Sticky, _Plugin);
+
+  function Sticky() {
+    _classCallCheck(this, Sticky);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments));
+  }
+
+  _createClass(Sticky, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a sticky thing.
+     * @class
+     * @name Sticky
+     * @param {jQuery} element - jQuery object to make sticky.
+     * @param {Object} options - options object passed when creating the element programmatically.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);
+      this.className = 'Sticky'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      this._init();
+    }
+    /**
+     * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init();
+
+      var $parent = this.$element.parent('[data-sticky-container]'),
+          id = this.$element[0].id || GetYoDigits(6, 'sticky'),
+          _this = this;
+
+      if ($parent.length) {
+        this.$container = $parent;
+      } else {
+        this.wasWrapped = true;
+        this.$element.wrap(this.options.container);
+        this.$container = this.$element.parent();
+      }
+
+      this.$container.addClass(this.options.containerClass);
+      this.$element.addClass(this.options.stickyClass).attr({
+        'data-resize': id,
+        'data-mutate': id
+      });
+
+      if (this.options.anchor !== '') {
+        $('#' + _this.options.anchor).attr({
+          'data-mutate': id
+        });
+      }
+
+      this.scrollCount = this.options.checkEvery;
+      this.isStuck = false;
+      this.onLoadListener = onLoad($(window), function () {
+        //We calculate the container height to have correct values for anchor points offset calculation.
+        _this.containerHeight = _this.$element.css("display") == "none" ? 0 : _this.$element[0].getBoundingClientRect().height;
+
+        _this.$container.css('height', _this.containerHeight);
+
+        _this.elemHeight = _this.containerHeight;
+
+        if (_this.options.anchor !== '') {
+          _this.$anchor = $('#' + _this.options.anchor);
+        } else {
+          _this._parsePoints();
+        }
+
+        _this._setSizes(function () {
+          var scroll = window.pageYOffset;
+
+          _this._calc(false, scroll); //Unstick the element will ensure that proper classes are set.
+
+
+          if (!_this.isStuck) {
+            _this._removeSticky(scroll >= _this.topPoint ? false : true);
+          }
+        });
+
+        _this._events(id.split('-').reverse().join('-'));
+      });
+    }
+    /**
+     * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_parsePoints",
+    value: function _parsePoints() {
+      var top = this.options.topAnchor == "" ? 1 : this.options.topAnchor,
+          btm = this.options.btmAnchor == "" ? document.documentElement.scrollHeight : this.options.btmAnchor,
+          pts = [top, btm],
+          breaks = {};
+
+      for (var i = 0, len = pts.length; i < len && pts[i]; i++) {
+        var pt;
+
+        if (typeof pts[i] === 'number') {
+          pt = pts[i];
+        } else {
+          var place = pts[i].split(':'),
+              anchor = $("#".concat(place[0]));
+          pt = anchor.offset().top;
+
+          if (place[1] && place[1].toLowerCase() === 'bottom') {
+            pt += anchor[0].getBoundingClientRect().height;
+          }
+        }
+
+        breaks[i] = pt;
+      }
+
+      this.points = breaks;
+      return;
+    }
+    /**
+     * Adds event handlers for the scrolling element.
+     * @private
+     * @param {String} id - pseudo-random id for unique scroll event listener.
+     */
+
+  }, {
+    key: "_events",
+    value: function _events(id) {
+      var _this = this,
+          scrollListener = this.scrollListener = "scroll.zf.".concat(id);
+
+      if (this.isOn) {
+        return;
+      }
+
+      if (this.canStick) {
+        this.isOn = true;
+        $(window).off(scrollListener).on(scrollListener, function (e) {
+          if (_this.scrollCount === 0) {
+            _this.scrollCount = _this.options.checkEvery;
+
+            _this._setSizes(function () {
+              _this._calc(false, window.pageYOffset);
+            });
+          } else {
+            _this.scrollCount--;
+
+            _this._calc(false, window.pageYOffset);
+          }
+        });
+      }
+
+      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) {
+        _this._eventsHandler(id);
+      });
+      this.$element.on('mutateme.zf.trigger', function (e, el) {
+        _this._eventsHandler(id);
+      });
+
+      if (this.$anchor) {
+        this.$anchor.on('mutateme.zf.trigger', function (e, el) {
+          _this._eventsHandler(id);
+        });
+      }
+    }
+    /**
+     * Handler for events.
+     * @private
+     * @param {String} id - pseudo-random id for unique scroll event listener.
+     */
+
+  }, {
+    key: "_eventsHandler",
+    value: function _eventsHandler(id) {
+      var _this = this,
+          scrollListener = this.scrollListener = "scroll.zf.".concat(id);
+
+      _this._setSizes(function () {
+        _this._calc(false);
+
+        if (_this.canStick) {
+          if (!_this.isOn) {
+            _this._events(id);
+          }
+        } else if (_this.isOn) {
+          _this._pauseListeners(scrollListener);
+        }
+      });
+    }
+    /**
+     * Removes event handlers for scroll and change events on anchor.
+     * @fires Sticky#pause
+     * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`
+     */
+
+  }, {
+    key: "_pauseListeners",
+    value: function _pauseListeners(scrollListener) {
+      this.isOn = false;
+      $(window).off(scrollListener);
+      /**
+       * Fires when the plugin is paused due to resize event shrinking the view.
+       * @event Sticky#pause
+       * @private
+       */
+
+      this.$element.trigger('pause.zf.sticky');
+    }
+    /**
+     * Called on every `scroll` event and on `_init`
+     * fires functions based on booleans and cached values
+     * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.
+     * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.
+     */
+
+  }, {
+    key: "_calc",
+    value: function _calc(checkSizes, scroll) {
+      if (checkSizes) {
+        this._setSizes();
+      }
+
+      if (!this.canStick) {
+        if (this.isStuck) {
+          this._removeSticky(true);
+        }
+
+        return false;
+      }
+
+      if (!scroll) {
+        scroll = window.pageYOffset;
+      }
+
+      if (scroll >= this.topPoint) {
+        if (scroll <= this.bottomPoint) {
+          if (!this.isStuck) {
+            this._setSticky();
+          }
+        } else {
+          if (this.isStuck) {
+            this._removeSticky(false);
+          }
+        }
+      } else {
+        if (this.isStuck) {
+          this._removeSticky(true);
+        }
+      }
+    }
+    /**
+     * Causes the $element to become stuck.
+     * Adds `position: fixed;`, and helper classes.
+     * @fires Sticky#stuckto
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_setSticky",
+    value: function _setSticky() {
+      var _this = this,
+          stickTo = this.options.stickTo,
+          mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',
+          notStuckTo = stickTo === 'top' ? 'bottom' : 'top',
+          css = {};
+
+      css[mrgn] = "".concat(this.options[mrgn], "em");
+      css[stickTo] = 0;
+      css[notStuckTo] = 'auto';
+      this.isStuck = true;
+      this.$element.removeClass("is-anchored is-at-".concat(notStuckTo)).addClass("is-stuck is-at-".concat(stickTo)).css(css)
+      /**
+       * Fires when the $element has become `position: fixed;`
+       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`
+       * @event Sticky#stuckto
+       */
+      .trigger("sticky.zf.stuckto:".concat(stickTo));
+      this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd", function () {
+        _this._setSizes();
+      });
+    }
+    /**
+     * Causes the $element to become unstuck.
+     * Removes `position: fixed;`, and helper classes.
+     * Adds other helper classes.
+     * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.
+     * @fires Sticky#unstuckfrom
+     * @private
+     */
+
+  }, {
+    key: "_removeSticky",
+    value: function _removeSticky(isTop) {
+      var stickTo = this.options.stickTo,
+          stickToTop = stickTo === 'top',
+          css = {},
+          anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,
+          mrgn = stickToTop ? 'marginTop' : 'marginBottom',
+          topOrBottom = isTop ? 'top' : 'bottom';
+      css[mrgn] = 0;
+      css['bottom'] = 'auto';
+
+      if (isTop) {
+        css['top'] = 0;
+      } else {
+        css['top'] = anchorPt;
+      }
+
+      this.isStuck = false;
+      this.$element.removeClass("is-stuck is-at-".concat(stickTo)).addClass("is-anchored is-at-".concat(topOrBottom)).css(css)
+      /**
+       * Fires when the $element has become anchored.
+       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`
+       * @event Sticky#unstuckfrom
+       */
+      .trigger("sticky.zf.unstuckfrom:".concat(topOrBottom));
+    }
+    /**
+     * Sets the $element and $container sizes for plugin.
+     * Calls `_setBreakPoints`.
+     * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.
+     * @private
+     */
+
+  }, {
+    key: "_setSizes",
+    value: function _setSizes(cb) {
+      this.canStick = MediaQuery.is(this.options.stickyOn);
+
+      if (!this.canStick) {
+        if (cb && typeof cb === 'function') {
+          cb();
+        }
+      }
+
+      var newElemWidth = this.$container[0].getBoundingClientRect().width,
+          comp = window.getComputedStyle(this.$container[0]),
+          pdngl = parseInt(comp['padding-left'], 10),
+          pdngr = parseInt(comp['padding-right'], 10);
+
+      if (this.$anchor && this.$anchor.length) {
+        this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;
+      } else {
+        this._parsePoints();
+      }
+
+      this.$element.css({
+        'max-width': "".concat(newElemWidth - pdngl - pdngr, "px")
+      });
+      var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;
+
+      if (this.$element.css("display") == "none") {
+        newContainerHeight = 0;
+      }
+
+      this.containerHeight = newContainerHeight;
+      this.$container.css({
+        height: newContainerHeight
+      });
+      this.elemHeight = newContainerHeight;
+
+      if (!this.isStuck) {
+        if (this.$element.hasClass('is-at-bottom')) {
+          var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;
+          this.$element.css('top', anchorPt);
+        }
+      }
+
+      this._setBreakPoints(newContainerHeight, function () {
+        if (cb && typeof cb === 'function') {
+          cb();
+        }
+      });
+    }
+    /**
+     * Sets the upper and lower breakpoints for the element to become sticky/unsticky.
+     * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.
+     * @param {Function} cb - optional callback function to be called on completion.
+     * @private
+     */
+
+  }, {
+    key: "_setBreakPoints",
+    value: function _setBreakPoints(elemHeight, cb) {
+      if (!this.canStick) {
+        if (cb && typeof cb === 'function') {
+          cb();
+        } else {
+          return false;
+        }
+      }
+
+      var mTop = emCalc(this.options.marginTop),
+          mBtm = emCalc(this.options.marginBottom),
+          topPoint = this.points ? this.points[0] : this.$anchor.offset().top,
+          bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,
+          // topPoint = this.$anchor.offset().top || this.points[0],
+      // bottomPoint = topPoint + this.anchorHeight || this.points[1],
+      winHeight = window.innerHeight;
+
+      if (this.options.stickTo === 'top') {
+        topPoint -= mTop;
+        bottomPoint -= elemHeight + mTop;
+      } else if (this.options.stickTo === 'bottom') {
+        topPoint -= winHeight - (elemHeight + mBtm);
+        bottomPoint -= winHeight - mBtm;
+      }
+
+      this.topPoint = topPoint;
+      this.bottomPoint = bottomPoint;
+
+      if (cb && typeof cb === 'function') {
+        cb();
+      }
+    }
+    /**
+     * Destroys the current sticky element.
+     * Resets the element to the top position first.
+     * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this._removeSticky(true);
+
+      this.$element.removeClass("".concat(this.options.stickyClass, " is-anchored is-at-top")).css({
+        height: '',
+        top: '',
+        bottom: '',
+        'max-width': ''
+      }).off('resizeme.zf.trigger').off('mutateme.zf.trigger');
+
+      if (this.$anchor && this.$anchor.length) {
+        this.$anchor.off('change.zf.sticky');
+      }
+
+      if (this.scrollListener) $(window).off(this.scrollListener);
+      if (this.onLoadListener) $(window).off(this.onLoadListener);
+
+      if (this.wasWrapped) {
+        this.$element.unwrap();
+      } else {
+        this.$container.removeClass(this.options.containerClass).css({
+          height: ''
+        });
+      }
+    }
+  }]);
+
+  return Sticky;
+}(Plugin);
+
+Sticky.defaults = {
+  /**
+   * Customizable container template. Add your own classes for styling and sizing.
+   * @option
+   * @type {string}
+   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'
+   */
+  container: '<div data-sticky-container></div>',
+
+  /**
+   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.
+   * @option
+   * @type {string}
+   * @default 'top'
+   */
+  stickTo: 'top',
+
+  /**
+   * If anchored to a single element, the id of that element.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  anchor: '',
+
+  /**
+   * If using more than one element as anchor points, the id of the top anchor.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  topAnchor: '',
+
+  /**
+   * If using more than one element as anchor points, the id of the bottom anchor.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  btmAnchor: '',
+
+  /**
+   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  marginTop: 1,
+
+  /**
+   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  marginBottom: 1,
+
+  /**
+   * Breakpoint string that is the minimum screen size an element should become sticky.
+   * @option
+   * @type {string}
+   * @default 'medium'
+   */
+  stickyOn: 'medium',
+
+  /**
+   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.
+   * @option
+   * @type {string}
+   * @default 'sticky'
+   */
+  stickyClass: 'sticky',
+
+  /**
+   * Class applied to sticky container. Foundation defaults to `sticky-container`.
+   * @option
+   * @type {string}
+   * @default 'sticky-container'
+   */
+  containerClass: 'sticky-container',
+
+  /**
+   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.
+   * @option
+   * @type {number}
+   * @default -1
+   */
+  checkEvery: -1
+};
+/**
+ * Helper function to calculate em values
+ * @param Number {em} - number of em's to calculate into pixels
+ */
+
+function emCalc(em) {
+  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;
+}
+
+/**
+ * Tabs module.
+ * @module foundation.tabs
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.imageLoader if tabs contain images
+ */
+
+var Tabs =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Tabs, _Plugin);
+
+  function Tabs() {
+    _classCallCheck(this, Tabs);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments));
+  }
+
+  _createClass(Tabs, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of tabs.
+     * @class
+     * @name Tabs
+     * @fires Tabs#init
+     * @param {jQuery} element - jQuery object to make into tabs.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);
+      this.className = 'Tabs'; // ie9 back compat
+
+      this._init();
+
+      Keyboard.register('Tabs', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'previous',
+        'ARROW_DOWN': 'next',
+        'ARROW_LEFT': 'previous' // 'TAB': 'next',
+        // 'SHIFT_TAB': 'previous'
+
+      });
+    }
+    /**
+     * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      var _this = this;
+
+      this._isInitializing = true;
+      this.$element.attr({
+        'role': 'tablist'
+      });
+      this.$tabTitles = this.$element.find(".".concat(this.options.linkClass));
+      this.$tabContent = $("[data-tabs-content=\"".concat(this.$element[0].id, "\"]"));
+      this.$tabTitles.each(function () {
+        var $elem = $(this),
+            $link = $elem.find('a'),
+            isActive = $elem.hasClass("".concat(_this.options.linkActiveClass)),
+            hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),
+            linkId = $link[0].id ? $link[0].id : "".concat(hash, "-label"),
+            $tabContent = $("#".concat(hash));
+        $elem.attr({
+          'role': 'presentation'
+        });
+        $link.attr({
+          'role': 'tab',
+          'aria-controls': hash,
+          'aria-selected': isActive,
+          'id': linkId,
+          'tabindex': isActive ? '0' : '-1'
+        });
+        $tabContent.attr({
+          'role': 'tabpanel',
+          'aria-labelledby': linkId
+        }); // Save up the initial hash to return to it later when going back in history
+
+        if (isActive) {
+          _this._initialAnchor = "#".concat(hash);
+        }
+
+        if (!isActive) {
+          $tabContent.attr('aria-hidden', 'true');
+        }
+
+        if (isActive && _this.options.autoFocus) {
+          _this.onLoadListener = onLoad($(window), function () {
+            $('html, body').animate({
+              scrollTop: $elem.offset().top
+            }, _this.options.deepLinkSmudgeDelay, function () {
+              $link.focus();
+            });
+          });
+        }
+      });
+
+      if (this.options.matchHeight) {
+        var $images = this.$tabContent.find('img');
+
+        if ($images.length) {
+          onImagesLoaded($images, this._setHeight.bind(this));
+        } else {
+          this._setHeight();
+        }
+      } // Current context-bound function to open tabs on page load or history hashchange
+
+
+      this._checkDeepLink = function () {
+        var anchor = window.location.hash;
+
+        if (!anchor.length) {
+          // If we are still initializing and there is no anchor, then there is nothing to do
+          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor
+
+          if (_this2._initialAnchor) anchor = _this2._initialAnchor;
+        }
+
+        var $anchor = anchor && $(anchor);
+
+        var $link = anchor && _this2.$element.find('[href$="' + anchor + '"]'); // Whether the anchor element that has been found is part of this element
+
+
+        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, select it
+
+        if ($anchor && $anchor.length && $link && $link.length) {
+          _this2.selectTab($anchor, true);
+        } // Otherwise, collapse everything
+        else {
+            _this2._collapse();
+          }
+
+        if (isOwnAnchor) {
+          // Roll up a little to show the titles
+          if (_this2.options.deepLinkSmudge) {
+            var offset = _this2.$element.offset();
+
+            $('html, body').animate({
+              scrollTop: offset.top
+            }, _this2.options.deepLinkSmudgeDelay);
+          }
+          /**
+           * Fires when the plugin has deeplinked at pageload
+           * @event Tabs#deeplink
+           */
+
+
+          _this2.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);
+        }
+      }; //use browser to open a tab, if it exists in this tabset
+
+
+      if (this.options.deepLink) {
+        this._checkDeepLink();
+      }
+
+      this._events();
+
+      this._isInitializing = false;
+    }
+    /**
+     * Adds event handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._addKeyHandler();
+
+      this._addClickHandler();
+
+      this._setHeightMqHandler = null;
+
+      if (this.options.matchHeight) {
+        this._setHeightMqHandler = this._setHeight.bind(this);
+        $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);
+      }
+
+      if (this.options.deepLink) {
+        $(window).on('hashchange', this._checkDeepLink);
+      }
+    }
+    /**
+     * Adds click handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_addClickHandler",
+    value: function _addClickHandler() {
+      var _this = this;
+
+      this.$element.off('click.zf.tabs').on('click.zf.tabs', ".".concat(this.options.linkClass), function (e) {
+        e.preventDefault();
+        e.stopPropagation();
+
+        _this._handleTabChange($(this));
+      });
+    }
+    /**
+     * Adds keyboard event handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_addKeyHandler",
+    value: function _addKeyHandler() {
+      var _this = this;
+
+      this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) {
+        if (e.which === 9) return;
+        var $element = $(this),
+            $elements = $element.parent('ul').children('li'),
+            $prevElement,
+            $nextElement;
+        $elements.each(function (i) {
+          if ($(this).is($element)) {
+            if (_this.options.wrapOnKeys) {
+              $prevElement = i === 0 ? $elements.last() : $elements.eq(i - 1);
+              $nextElement = i === $elements.length - 1 ? $elements.first() : $elements.eq(i + 1);
+            } else {
+              $prevElement = $elements.eq(Math.max(0, i - 1));
+              $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
+            }
+
+            return;
+          }
+        }); // handle keyboard event with keyboard util
+
+        Keyboard.handleKey(e, 'Tabs', {
+          open: function open() {
+            $element.find('[role="tab"]').focus();
+
+            _this._handleTabChange($element);
+          },
+          previous: function previous() {
+            $prevElement.find('[role="tab"]').focus();
+
+            _this._handleTabChange($prevElement);
+          },
+          next: function next() {
+            $nextElement.find('[role="tab"]').focus();
+
+            _this._handleTabChange($nextElement);
+          },
+          handled: function handled() {
+            e.stopPropagation();
+            e.preventDefault();
+          }
+        });
+      });
+    }
+    /**
+     * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.
+     * @param {jQuery} $target - Tab to open.
+     * @param {boolean} historyHandled - browser has already handled a history update
+     * @fires Tabs#change
+     * @function
+     */
+
+  }, {
+    key: "_handleTabChange",
+    value: function _handleTabChange($target, historyHandled) {
+      // With `activeCollapse`, if the target is the active Tab, collapse it.
+      if ($target.hasClass("".concat(this.options.linkActiveClass))) {
+        if (this.options.activeCollapse) {
+          this._collapse();
+        }
+
+        return;
+      }
+
+      var $oldTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass)),
+          $tabLink = $target.find('[role="tab"]'),
+          target = $tabLink.attr('data-tabs-target'),
+          anchor = target && target.length ? "#".concat(target) : $tabLink[0].hash,
+          $targetContent = this.$tabContent.find(anchor); //close old tab
+
+      this._collapseTab($oldTab); //open new tab
+
+
+      this._openTab($target); //either replace or update browser history
+
+
+      if (this.options.deepLink && !historyHandled) {
+        if (this.options.updateHistory) {
+          history.pushState({}, '', anchor);
+        } else {
+          history.replaceState({}, '', anchor);
+        }
+      }
+      /**
+       * Fires when the plugin has successfully changed tabs.
+       * @event Tabs#change
+       */
+
+
+      this.$element.trigger('change.zf.tabs', [$target, $targetContent]); //fire to children a mutation event
+
+      $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger");
+    }
+    /**
+     * Opens the tab `$targetContent` defined by `$target`.
+     * @param {jQuery} $target - Tab to open.
+     * @function
+     */
+
+  }, {
+    key: "_openTab",
+    value: function _openTab($target) {
+      var $tabLink = $target.find('[role="tab"]'),
+          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),
+          $targetContent = this.$tabContent.find("#".concat(hash));
+      $target.addClass("".concat(this.options.linkActiveClass));
+      $tabLink.attr({
+        'aria-selected': 'true',
+        'tabindex': '0'
+      });
+      $targetContent.addClass("".concat(this.options.panelActiveClass)).removeAttr('aria-hidden');
+    }
+    /**
+     * Collapses `$targetContent` defined by `$target`.
+     * @param {jQuery} $target - Tab to collapse.
+     * @function
+     */
+
+  }, {
+    key: "_collapseTab",
+    value: function _collapseTab($target) {
+      var $target_anchor = $target.removeClass("".concat(this.options.linkActiveClass)).find('[role="tab"]').attr({
+        'aria-selected': 'false',
+        'tabindex': -1
+      });
+      $("#".concat($target_anchor.attr('aria-controls'))).removeClass("".concat(this.options.panelActiveClass)).attr({
+        'aria-hidden': 'true'
+      });
+    }
+    /**
+     * Collapses the active Tab.
+     * @fires Tabs#collapse
+     * @function
+     */
+
+  }, {
+    key: "_collapse",
+    value: function _collapse() {
+      var $activeTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass));
+
+      if ($activeTab.length) {
+        this._collapseTab($activeTab);
+        /**
+        * Fires when the plugin has successfully collapsed tabs.
+        * @event Tabs#collapse
+        */
+
+
+        this.$element.trigger('collapse.zf.tabs', [$activeTab]);
+      }
+    }
+    /**
+     * Public method for selecting a content pane to display.
+     * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.
+     * @param {boolean} historyHandled - browser has already handled a history update
+     * @function
+     */
+
+  }, {
+    key: "selectTab",
+    value: function selectTab(elem, historyHandled) {
+      var idStr;
+
+      if (_typeof(elem) === 'object') {
+        idStr = elem[0].id;
+      } else {
+        idStr = elem;
+      }
+
+      if (idStr.indexOf('#') < 0) {
+        idStr = "#".concat(idStr);
+      }
+
+      var $target = this.$tabTitles.has("[href$=\"".concat(idStr, "\"]"));
+
+      this._handleTabChange($target, historyHandled);
+    }
+  }, {
+    key: "_setHeight",
+
+    /**
+     * Sets the height of each panel to the height of the tallest panel.
+     * If enabled in options, gets called on media query change.
+     * If loading content via external source, can be called directly or with _reflow.
+     * If enabled with `data-match-height="true"`, tabs sets to equal height
+     * @function
+     * @private
+     */
+    value: function _setHeight() {
+      var max = 0,
+          _this = this; // Lock down the `this` value for the root tabs object
+
+
+      this.$tabContent.find(".".concat(this.options.panelClass)).css('height', '').each(function () {
+        var panel = $(this),
+            isActive = panel.hasClass("".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child
+
+        if (!isActive) {
+          panel.css({
+            'visibility': 'hidden',
+            'display': 'block'
+          });
+        }
+
+        var temp = this.getBoundingClientRect().height;
+
+        if (!isActive) {
+          panel.css({
+            'visibility': '',
+            'display': ''
+          });
+        }
+
+        max = temp > max ? temp : max;
+      }).css('height', "".concat(max, "px"));
+    }
+    /**
+     * Destroys an instance of tabs.
+     * @fires Tabs#destroyed
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.find(".".concat(this.options.linkClass)).off('.zf.tabs').hide().end().find(".".concat(this.options.panelClass)).hide();
+
+      if (this.options.matchHeight) {
+        if (this._setHeightMqHandler != null) {
+          $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);
+        }
+      }
+
+      if (this.options.deepLink) {
+        $(window).off('hashchange', this._checkDeepLink);
+      }
+
+      if (this.onLoadListener) {
+        $(window).off(this.onLoadListener);
+      }
+    }
+  }]);
+
+  return Tabs;
+}(Plugin);
+
+Tabs.defaults = {
+  /**
+   * Link the location hash to the active pane.
+   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+
+  /**
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinkSmudge: false,
+
+  /**
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
+   * @option
+   * @type {number}
+   * @default 300
+   */
+  deepLinkSmudgeDelay: 300,
+
+  /**
+   * If `deepLink` is enabled, update the browser history with the open tab
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  updateHistory: false,
+
+  /**
+   * Allows the window to scroll to content of active pane on load.
+   * Not recommended if more than one tab panel per page.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoFocus: false,
+
+  /**
+   * Allows keyboard input to 'wrap' around the tab links.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  wrapOnKeys: true,
+
+  /**
+   * Allows the tab content panes to match heights if set to true.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  matchHeight: false,
+
+  /**
+   * Allows active tabs to collapse when clicked.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  activeCollapse: false,
+
+  /**
+   * Class applied to `li`'s in tab link list.
+   * @option
+   * @type {string}
+   * @default 'tabs-title'
+   */
+  linkClass: 'tabs-title',
+
+  /**
+   * Class applied to the active `li` in tab link list.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  linkActiveClass: 'is-active',
+
+  /**
+   * Class applied to the content containers.
+   * @option
+   * @type {string}
+   * @default 'tabs-panel'
+   */
+  panelClass: 'tabs-panel',
+
+  /**
+   * Class applied to the active content container.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  panelActiveClass: 'is-active'
+};
+
+/**
+ * Toggler module.
+ * @module foundation.toggler
+ * @requires foundation.util.motion
+ * @requires foundation.util.triggers
+ */
+
+var Toggler =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Toggler, _Plugin);
+
+  function Toggler() {
+    _classCallCheck(this, Toggler);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Toggler).apply(this, arguments));
+  }
+
+  _createClass(Toggler, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Toggler.
+     * @class
+     * @name Toggler
+     * @fires Toggler#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Toggler.defaults, element.data(), options);
+      this.className = '';
+      this.className = 'Toggler'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var input; // Parse animation classes if they were set
+
+      if (this.options.animate) {
+        input = this.options.animate.split(' ');
+        this.animationIn = input[0];
+        this.animationOut = input[1] || null;
+      } // Otherwise, parse toggle class
+      else {
+          input = this.$element.data('toggler'); // Allow for a . at the beginning of the string
+
+          this.className = input[0] === '.' ? input.slice(1) : input;
+        } // Add ARIA attributes to triggers:
+
+
+      var id = this.$element[0].id,
+          $triggers = $("[data-open~=\"".concat(id, "\"], [data-close~=\"").concat(id, "\"], [data-toggle~=\"").concat(id, "\"]")); // - aria-expanded: according to the element visibility.
+
+      $triggers.attr('aria-expanded', !this.$element.is(':hidden')); // - aria-controls: adding the element id to it if not already in it.
+
+      $triggers.each(function (index, trigger) {
+        var $trigger = $(trigger);
+        var controls = $trigger.attr('aria-controls') || '';
+        var containsId = new RegExp("\\b".concat(RegExpEscape(id), "\\b")).test(controls);
+        if (!containsId) $trigger.attr('aria-controls', controls ? "".concat(controls, " ").concat(id) : id);
+      });
+    }
+    /**
+     * Initializes events for the toggle trigger.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));
+    }
+    /**
+     * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was "on" or "off".
+     * @function
+     * @fires Toggler#on
+     * @fires Toggler#off
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      this[this.options.animate ? '_toggleAnimate' : '_toggleClass']();
+    }
+  }, {
+    key: "_toggleClass",
+    value: function _toggleClass() {
+      this.$element.toggleClass(this.className);
+      var isOn = this.$element.hasClass(this.className);
+
+      if (isOn) {
+        /**
+         * Fires if the target element has the class after a toggle.
+         * @event Toggler#on
+         */
+        this.$element.trigger('on.zf.toggler');
+      } else {
+        /**
+         * Fires if the target element does not have the class after a toggle.
+         * @event Toggler#off
+         */
+        this.$element.trigger('off.zf.toggler');
+      }
+
+      this._updateARIA(isOn);
+
+      this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');
+    }
+  }, {
+    key: "_toggleAnimate",
+    value: function _toggleAnimate() {
+      var _this = this;
+
+      if (this.$element.is(':hidden')) {
+        Motion.animateIn(this.$element, this.animationIn, function () {
+          _this._updateARIA(true);
+
+          this.trigger('on.zf.toggler');
+          this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+        });
+      } else {
+        Motion.animateOut(this.$element, this.animationOut, function () {
+          _this._updateARIA(false);
+
+          this.trigger('off.zf.toggler');
+          this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+        });
+      }
+    }
+  }, {
+    key: "_updateARIA",
+    value: function _updateARIA(isOn) {
+      var id = this.$element[0].id;
+      $("[data-open=\"".concat(id, "\"], [data-close=\"").concat(id, "\"], [data-toggle=\"").concat(id, "\"]")).attr({
+        'aria-expanded': isOn ? true : false
+      });
+    }
+    /**
+     * Destroys the instance of Toggler on the element.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.toggler');
+    }
+  }]);
+
+  return Toggler;
+}(Plugin);
+
+Toggler.defaults = {
+  /**
+   * Tells the plugin if the element should animated when toggled.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animate: false
+};
+
+/**
+ * Tooltip module.
+ * @module foundation.tooltip
+ * @requires foundation.util.box
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.triggers
+ */
+
+var Tooltip =
+/*#__PURE__*/
+function (_Positionable) {
+  _inherits(Tooltip, _Positionable);
+
+  function Tooltip() {
+    _classCallCheck(this, Tooltip);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments));
+  }
+
+  _createClass(Tooltip, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a Tooltip.
+     * @class
+     * @name Tooltip
+     * @fires Tooltip#init
+     * @param {jQuery} element - jQuery object to attach a tooltip to.
+     * @param {Object} options - object to extend the default configuration.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);
+      this.className = 'Tooltip'; // ie9 back compat
+
+      this.isActive = false;
+      this.isClick = false; // Triggers init is idempotent, just need to make sure it is initialized
+
+      Triggers.init($);
+
+      this._init();
+    }
+    /**
+     * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init();
+
+      var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');
+      this.options.tipText = this.options.tipText || this.$element.attr('title');
+      this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);
+
+      if (this.options.allowHtml) {
+        this.template.appendTo(document.body).html(this.options.tipText).hide();
+      } else {
+        this.template.appendTo(document.body).text(this.options.tipText).hide();
+      }
+
+      this.$element.attr({
+        'title': '',
+        'aria-describedby': elemId,
+        'data-yeti-box': elemId,
+        'data-toggle': elemId,
+        'data-resize': elemId
+      }).addClass(this.options.triggerClass);
+
+      _get(_getPrototypeOf(Tooltip.prototype), "_init", this).call(this);
+
+      this._events();
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      // handle legacy classnames
+      var position = this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);
+      return position ? position[0] : 'top';
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      return 'center';
+    }
+  }, {
+    key: "_getHOffset",
+    value: function _getHOffset() {
+      if (this.position === 'left' || this.position === 'right') {
+        return this.options.hOffset + this.options.tooltipWidth;
+      } else {
+        return this.options.hOffset;
+      }
+    }
+  }, {
+    key: "_getVOffset",
+    value: function _getVOffset() {
+      if (this.position === 'top' || this.position === 'bottom') {
+        return this.options.vOffset + this.options.tooltipHeight;
+      } else {
+        return this.options.vOffset;
+      }
+    }
+    /**
+     * builds the tooltip element, adds attributes, and returns the template.
+     * @private
+     */
+
+  }, {
+    key: "_buildTemplate",
+    value: function _buildTemplate(id) {
+      var templateClasses = "".concat(this.options.tooltipClass, " ").concat(this.options.templateClasses).trim();
+      var $template = $('<div></div>').addClass(templateClasses).attr({
+        'role': 'tooltip',
+        'aria-hidden': true,
+        'data-is-active': false,
+        'data-is-focus': false,
+        'id': id
+      });
+      return $template;
+    }
+    /**
+     * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.
+     * if the tooltip is larger than the screen width, default to full width - any user selected margin
+     * @private
+     */
+
+  }, {
+    key: "_setPosition",
+    value: function _setPosition() {
+      _get(_getPrototypeOf(Tooltip.prototype), "_setPosition", this).call(this, this.$element, this.template);
+    }
+    /**
+     * reveals the tooltip, and fires an event to close any other open tooltips on the page
+     * @fires Tooltip#closeme
+     * @fires Tooltip#show
+     * @function
+     */
+
+  }, {
+    key: "show",
+    value: function show() {
+      if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {
+        // console.error('The screen is too small to display this tooltip');
+        return false;
+      }
+
+      var _this = this;
+
+      this.template.css('visibility', 'hidden').show();
+
+      this._setPosition();
+
+      this.template.removeClass('top bottom left right').addClass(this.position);
+      this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);
+      /**
+       * Fires to close all other open tooltips on the page
+       * @event Closeme#tooltip
+       */
+
+      this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));
+      this.template.attr({
+        'data-is-active': true,
+        'aria-hidden': false
+      });
+      _this.isActive = true; // console.log(this.template);
+
+      this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {//maybe do stuff?
+      });
+      /**
+       * Fires when the tooltip is shown
+       * @event Tooltip#show
+       */
+
+      this.$element.trigger('show.zf.tooltip');
+    }
+    /**
+     * Hides the current tooltip, and resets the positioning class if it was changed due to collision
+     * @fires Tooltip#hide
+     * @function
+     */
+
+  }, {
+    key: "hide",
+    value: function hide() {
+      // console.log('hiding', this.$element.data('yeti-box'));
+      var _this = this;
+
+      this.template.stop().attr({
+        'aria-hidden': true,
+        'data-is-active': false
+      }).fadeOut(this.options.fadeOutDuration, function () {
+        _this.isActive = false;
+        _this.isClick = false;
+      });
+      /**
+       * fires when the tooltip is hidden
+       * @event Tooltip#hide
+       */
+
+      this.$element.trigger('hide.zf.tooltip');
+    }
+    /**
+     * adds event listeners for the tooltip and its anchor
+     * TODO combine some of the listeners like focus and mouseenter, etc.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      var $template = this.template;
+      var isFocus = false;
+
+      if (!this.options.disableHover) {
+        this.$element.on('mouseenter.zf.tooltip', function (e) {
+          if (!_this.isActive) {
+            _this.timeout = setTimeout(function () {
+              _this.show();
+            }, _this.options.hoverDelay);
+          }
+        }).on('mouseleave.zf.tooltip', ignoreMousedisappear(function (e) {
+          clearTimeout(_this.timeout);
+
+          if (!isFocus || _this.isClick && !_this.options.clickOpen) {
+            _this.hide();
+          }
+        }));
+      }
+
+      if (this.options.clickOpen) {
+        this.$element.on('mousedown.zf.tooltip', function (e) {
+          e.stopImmediatePropagation();
+
+          if (_this.isClick) ; else {
+            _this.isClick = true;
+
+            if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {
+              _this.show();
+            }
+          }
+        });
+      } else {
+        this.$element.on('mousedown.zf.tooltip', function (e) {
+          e.stopImmediatePropagation();
+          _this.isClick = true;
+        });
+      }
+
+      if (!this.options.disableForTouch) {
+        this.$element.on('tap.zf.tooltip touchend.zf.tooltip', function (e) {
+          _this.isActive ? _this.hide() : _this.show();
+        });
+      }
+
+      this.$element.on({
+        // 'toggle.zf.trigger': this.toggle.bind(this),
+        // 'close.zf.trigger': this.hide.bind(this)
+        'close.zf.trigger': this.hide.bind(this)
+      });
+      this.$element.on('focus.zf.tooltip', function (e) {
+        isFocus = true;
+
+        if (_this.isClick) {
+          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't
+          // a real focus, otherwise on hover and come back we get bad behavior
+          if (!_this.options.clickOpen) {
+            isFocus = false;
+          }
+
+          return false;
+        } else {
+          _this.show();
+        }
+      }).on('focusout.zf.tooltip', function (e) {
+        isFocus = false;
+        _this.isClick = false;
+
+        _this.hide();
+      }).on('resizeme.zf.trigger', function () {
+        if (_this.isActive) {
+          _this._setPosition();
+        }
+      });
+    }
+    /**
+     * adds a toggle method, in addition to the static show() & hide() functions
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      if (this.isActive) {
+        this.hide();
+      } else {
+        this.show();
+      }
+    }
+    /**
+     * Destroys an instance of tooltip, removes template element from the view.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass(this.options.triggerClass).removeClass('top right left bottom').removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');
+      this.template.remove();
+    }
+  }]);
+
+  return Tooltip;
+}(Positionable);
+
+Tooltip.defaults = {
+  disableForTouch: false,
+
+  /**
+   * Time, in ms, before a tooltip should open on hover.
+   * @option
+   * @type {number}
+   * @default 200
+   */
+  hoverDelay: 200,
+
+  /**
+   * Time, in ms, a tooltip should take to fade into view.
+   * @option
+   * @type {number}
+   * @default 150
+   */
+  fadeInDuration: 150,
+
+  /**
+   * Time, in ms, a tooltip should take to fade out of view.
+   * @option
+   * @type {number}
+   * @default 150
+   */
+  fadeOutDuration: 150,
+
+  /**
+   * Disables hover events from opening the tooltip if set to true
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disableHover: false,
+
+  /**
+   * Optional addtional classes to apply to the tooltip template on init.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  templateClasses: '',
+
+  /**
+   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.
+   * @option
+   * @type {string}
+   * @default 'tooltip'
+   */
+  tooltipClass: 'tooltip',
+
+  /**
+   * Class applied to the tooltip anchor element.
+   * @option
+   * @type {string}
+   * @default 'has-tip'
+   */
+  triggerClass: 'has-tip',
+
+  /**
+   * Minimum breakpoint size at which to open the tooltip.
+   * @option
+   * @type {string}
+   * @default 'small'
+   */
+  showOn: 'small',
+
+  /**
+   * Custom template to be used to generate markup for tooltip.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  template: '',
+
+  /**
+   * Text displayed in the tooltip template on open.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  tipText: '',
+  touchCloseText: 'Tap to close.',
+
+  /**
+   * Allows the tooltip to remain open if triggered with a click or touch event.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  clickOpen: true,
+
+  /**
+   * Position of tooltip. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+
+  /**
+   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow overlap of container/window. If false, tooltip will first try to
+   * position as defined by data-position and data-alignment, but reposition if
+   * it would cause an overflow.  @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * Less common for tooltips.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowBottomOverlap: false,
+
+  /**
+   * Distance, in pixels, the template should push away from the anchor on the Y axis.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+
+  /**
+   * Distance, in pixels, the template should push away from the anchor on the X axis
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0,
+
+  /**
+   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip
+   * @option
+   * @type {number}
+   * @default 14
+   */
+  tooltipHeight: 14,
+
+  /**
+   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip
+   * @option
+   * @type {number}
+   * @default 12
+   */
+  tooltipWidth: 12,
+
+  /**
+  * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,
+  * allowing HTML may open yourself up to XSS attacks.
+  * @option
+  * @type {boolean}
+  * @default false
+  */
+  allowHtml: false
+};
+
+var MenuPlugins$1 = {
+  tabs: {
+    cssClass: 'tabs',
+    plugin: Tabs
+  },
+  accordion: {
+    cssClass: 'accordion',
+    plugin: Accordion
+  }
+};
+/**
+ * ResponsiveAccordionTabs module.
+ * @module foundation.responsiveAccordionTabs
+ * @requires foundation.util.motion
+ * @requires foundation.accordion
+ * @requires foundation.tabs
+ */
+
+var ResponsiveAccordionTabs =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveAccordionTabs, _Plugin);
+
+  function ResponsiveAccordionTabs() {
+    _classCallCheck(this, ResponsiveAccordionTabs);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveAccordionTabs).apply(this, arguments));
+  }
+
+  _createClass(ResponsiveAccordionTabs, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a responsive accordion tabs.
+     * @class
+     * @name ResponsiveAccordionTabs
+     * @fires ResponsiveAccordionTabs#init
+     * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = $(element);
+      this.options = $.extend({}, this.$element.data(), options);
+      this.rules = this.$element.data('responsive-accordion-tabs');
+      this.currentMq = null;
+      this.currentPlugin = null;
+      this.className = 'ResponsiveAccordionTabs'; // ie9 back compat
+
+      if (!this.$element.attr('id')) {
+        this.$element.attr('id', GetYoDigits(6, 'responsiveaccordiontabs'));
+      }
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      MediaQuery._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
+
+
+      if (typeof this.rules === 'string') {
+        var rulesTree = {}; // Parse rules from "classes" pulled from data attribute
+
+        var rules = this.rules.split(' '); // Iterate through every rule found
+
+        for (var i = 0; i < rules.length; i++) {
+          var rule = rules[i].split('-');
+          var ruleSize = rule.length > 1 ? rule[0] : 'small';
+          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+
+          if (MenuPlugins$1[rulePlugin] !== null) {
+            rulesTree[ruleSize] = MenuPlugins$1[rulePlugin];
+          }
+        }
+
+        this.rules = rulesTree;
+      }
+
+      this._getAllOptions();
+
+      if (!$.isEmptyObject(this.rules)) {
+        this._checkMediaQueries();
+      }
+    }
+  }, {
+    key: "_getAllOptions",
+    value: function _getAllOptions() {
+      //get all defaults and options
+      var _this = this;
+
+      _this.allOptions = {};
+
+      for (var key in MenuPlugins$1) {
+        if (MenuPlugins$1.hasOwnProperty(key)) {
+          var obj = MenuPlugins$1[key];
+
+          try {
+            var dummyPlugin = $('<ul></ul>');
+            var tmpPlugin = new obj.plugin(dummyPlugin, _this.options);
+
+            for (var keyKey in tmpPlugin.options) {
+              if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {
+                var objObj = tmpPlugin.options[keyKey];
+                _this.allOptions[keyKey] = objObj;
+              }
+            }
+
+            tmpPlugin.destroy();
+          } catch (e) {}
+        }
+      }
+    }
+    /**
+     * Initializes events for the Menu.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);
+      $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
+    }
+    /**
+     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_checkMediaQueries",
+    value: function _checkMediaQueries() {
+      var matchedMq,
+          _this = this; // Iterate through each rule and find the last matching rule
+
+
+      $.each(this.rules, function (key) {
+        if (MediaQuery.atLeast(key)) {
+          matchedMq = key;
+        }
+      }); // No match? No dice
+
+      if (!matchedMq) return; // Plugin already initialized? We good
+
+      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes
+
+      $.each(MenuPlugins$1, function (key, value) {
+        _this.$element.removeClass(value.cssClass);
+      }); // Add the CSS class for the new plugin
+
+      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin
+
+      if (this.currentPlugin) {
+        //don't know why but on nested elements data zfPlugin get's lost
+        if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData);
+        this.currentPlugin.destroy();
+      }
+
+      this._handleMarkup(this.rules[matchedMq].cssClass);
+
+      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+      this.storezfData = this.currentPlugin.$element.data('zfPlugin');
+    }
+  }, {
+    key: "_handleMarkup",
+    value: function _handleMarkup(toSet) {
+      var _this = this,
+          fromString = 'accordion';
+
+      var $panels = $('[data-tabs-content=' + this.$element.attr('id') + ']');
+      if ($panels.length) fromString = 'tabs';
+
+      if (fromString === toSet) {
+        return;
+      }
+      var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title';
+      var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel';
+      this.$element.removeAttr('role');
+      var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');
+      var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');
+
+      if (fromString === 'tabs') {
+        $panels = $panels.children('.' + tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');
+        $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');
+      } else {
+        $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');
+      }
+      $panels.css({
+        display: '',
+        visibility: ''
+      });
+      $liHeads.css({
+        display: '',
+        visibility: ''
+      });
+
+      if (toSet === 'accordion') {
+        $panels.each(function (key, value) {
+          $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({
+            height: ''
+          });
+          $('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id="tabs-placeholder-' + _this.$element.attr('id') + '"></div>').detach();
+          $liHeads.addClass('accordion-item').attr('data-accordion-item', '');
+          $liHeadsA.addClass('accordion-title');
+        });
+      } else if (toSet === 'tabs') {
+        var $tabsContent = $('[data-tabs-content=' + _this.$element.attr('id') + ']');
+        var $placeholder = $('#tabs-placeholder-' + _this.$element.attr('id'));
+
+        if ($placeholder.length) {
+          $tabsContent = $('<div class="tabs-content"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));
+          $placeholder.remove();
+        } else {
+          $tabsContent = $('<div class="tabs-content"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));
+        }
+        $panels.each(function (key, value) {
+          var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);
+          var hash = $liHeadsA.get(key).hash.slice(1);
+          var id = $(value).attr('id') || GetYoDigits(6, 'accordion');
+
+          if (hash !== id) {
+            if (hash !== '') {
+              $(value).attr('id', hash);
+            } else {
+              hash = id;
+              $(value).attr('id', hash);
+              $($liHeadsA.get(key)).attr('href', $($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);
+            }
+          }
+          var isActive = $($liHeads.get(key)).hasClass('is-active');
+
+          if (isActive) {
+            tempValue.addClass('is-active');
+          }
+        });
+        $liHeads.addClass(tabsTitle);
+      }
+    }
+    /**
+     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      if (this.currentPlugin) this.currentPlugin.destroy();
+      $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
+    }
+  }]);
+
+  return ResponsiveAccordionTabs;
+}(Plugin);
+
+ResponsiveAccordionTabs.defaults = {};
+
+Foundation.addToJquery($); // Add Foundation Utils to Foundation global namespace for backwards
+// compatibility.
+
+Foundation.rtl = rtl;
+Foundation.GetYoDigits = GetYoDigits;
+Foundation.transitionend = transitionend;
+Foundation.RegExpEscape = RegExpEscape;
+Foundation.onLoad = onLoad;
+Foundation.Box = Box;
+Foundation.onImagesLoaded = onImagesLoaded;
+Foundation.Keyboard = Keyboard;
+Foundation.MediaQuery = MediaQuery;
+Foundation.Motion = Motion;
+Foundation.Move = Move;
+Foundation.Nest = Nest;
+Foundation.Timer = Timer; // Touch and Triggers previously were almost purely sede effect driven,
+// so no need to add it to Foundation, just init them.
+
+Touch.init($);
+Triggers.init($, Foundation);
+
+MediaQuery._init();
+
+Foundation.plugin(Abide, 'Abide');
+Foundation.plugin(Accordion, 'Accordion');
+Foundation.plugin(AccordionMenu, 'AccordionMenu');
+Foundation.plugin(Drilldown, 'Drilldown');
+Foundation.plugin(Dropdown, 'Dropdown');
+Foundation.plugin(DropdownMenu, 'DropdownMenu');
+Foundation.plugin(Equalizer, 'Equalizer');
+Foundation.plugin(Interchange, 'Interchange');
+Foundation.plugin(Magellan, 'Magellan');
+Foundation.plugin(OffCanvas, 'OffCanvas');
+Foundation.plugin(Orbit, 'Orbit');
+Foundation.plugin(ResponsiveMenu, 'ResponsiveMenu');
+Foundation.plugin(ResponsiveToggle, 'ResponsiveToggle');
+Foundation.plugin(Reveal, 'Reveal');
+Foundation.plugin(Slider, 'Slider');
+Foundation.plugin(SmoothScroll, 'SmoothScroll');
+Foundation.plugin(Sticky, 'Sticky');
+Foundation.plugin(Tabs, 'Tabs');
+Foundation.plugin(Toggler, 'Toggler');
+Foundation.plugin(Tooltip, 'Tooltip');
+Foundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');
+
+export default Foundation;
+export { foundation_core_utils as CoreUtils, Foundation as Core, Foundation, Box, onImagesLoaded, Keyboard, MediaQuery, Motion, Move, Nest, Timer, Touch, Triggers, Abide, Accordion, AccordionMenu, Drilldown, Dropdown, DropdownMenu, Equalizer, Interchange, Magellan, OffCanvas, Orbit, ResponsiveMenu, ResponsiveToggle, Reveal, Slider, SmoothScroll, Sticky, Tabs, Toggler, Tooltip, ResponsiveAccordionTabs };
+//# sourceMappingURL=foundation.esm.js.map
diff --git a/dist/js/foundation.esm.js.map b/dist/js/foundation.esm.js.map
new file mode 100644 (file)
index 0000000..5729a86
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"file":"foundation.esm.js","sources":["../../js/foundation.core.utils.js","../../js/foundation.util.mediaQuery.js","../../js/foundation.core.js","../../js/foundation.util.box.js","../../js/foundation.util.imageLoader.js","../../js/foundation.util.keyboard.js","../../js/foundation.util.motion.js","../../js/foundation.util.nest.js","../../js/foundation.util.timer.js","../../js/foundation.util.touch.js","../../js/foundation.util.triggers.js","../../js/foundation.core.plugin.js","../../js/foundation.abide.js","../../js/foundation.accordion.js","../../js/foundation.accordionMenu.js","../../js/foundation.drilldown.js","../../js/foundation.positionable.js","../../js/foundation.dropdown.js","../../js/foundation.dropdownMenu.js","../../js/foundation.equalizer.js","../../js/foundation.interchange.js","../../js/foundation.smoothScroll.js","../../js/foundation.magellan.js","../../js/foundation.offcanvas.js","../../js/foundation.orbit.js","../../js/foundation.responsiveMenu.js","../../js/foundation.responsiveToggle.js","../../js/foundation.reveal.js","../../js/foundation.slider.js","../../js/foundation.sticky.js","../../js/foundation.tabs.js","../../js/foundation.toggler.js","../../js/foundation.tooltip.js","../../js/foundation.responsiveAccordionTabs.js","../../js/entries/foundation.js"],"sourcesContent":["\"use strict\";\n\nimport $ from 'jquery';\n\n// Core Foundation Utilities, utilized in a number of places.\n\n  /**\n   * Returns a boolean for RTL support\n   */\nfunction rtl() {\n  return $('html').attr('dir') === 'rtl';\n}\n\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\nfunction GetYoDigits(length, namespace){\n  length = length || 6;\n  return Math.round((Math.pow(36, length + 1) - Math.random() * Math.pow(36, length))).toString(36).slice(1) + (namespace ? `-${namespace}` : '');\n}\n\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\nfunction RegExpEscape(str){\n  return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem){\n  var transitions = {\n    'transition': 'transitionend',\n    'WebkitTransition': 'webkitTransitionEnd',\n    'MozTransition': 'transitionend',\n    'OTransition': 'otransitionend'\n  };\n  var elem = document.createElement('div'),\n      end;\n\n  for (var t in transitions){\n    if (typeof elem.style[t] !== 'undefined'){\n      end = transitions[t];\n    }\n  }\n  if(end){\n    return end;\n  }else{\n    end = setTimeout(function(){\n      $elem.triggerHandler('transitionend', [$elem]);\n    }, 1);\n    return 'transitionend';\n  }\n}\n\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\nfunction onLoad($elem, handler) {\n  const didLoad = document.readyState === 'complete';\n  const eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n  const cb = () => $elem.triggerHandler(eventType);\n\n  if ($elem) {\n    if (handler) $elem.one(eventType, handler);\n\n    if (didLoad)\n      setTimeout(cb);\n    else\n      $(window).one('load', cb);\n  }\n\n  return eventType;\n}\n\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n *   (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n *   outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\nfunction ignoreMousedisappear(handler, { ignoreLeaveWindow = false, ignoreReappear = false } = {}) {\n  return function leaveEventHandler(eLeave, ...rest) {\n    const callback = handler.bind(this, eLeave, ...rest);\n\n    // The mouse left: call the given callback if the mouse entered elsewhere\n    if (eLeave.relatedTarget !== null) {\n      return callback();\n    }\n\n    // Otherwise, check if the mouse actually left the window.\n    // In firefox if the user switched between windows, the window sill have the focus by the time\n    // the event is triggered. We have to debounce the event to test this case.\n    setTimeout(function leaveEventDebouncer() {\n      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n        return callback();\n      }\n\n      // Otherwise, wait for the mouse to reeapear outside of the element,\n      if (!ignoreReappear) {\n        $(document).one('mouseenter', function reenterEventHandler(eReenter) {\n          if (!$(eLeave.currentTarget).has(eReenter.target).length) {\n            // Fill where the mouse finally entered.\n            eLeave.relatedTarget = eReenter.target;\n            callback();\n          }\n        });\n      }\n\n    }, 0);\n  };\n}\n\nexport { rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear };\n","'use strict';\n\nimport $ from 'jquery';\n\n// Default set of media queries\nconst defaultQueries = {\n  'default' : 'only screen',\n  landscape : 'only screen and (orientation: landscape)',\n  portrait : 'only screen and (orientation: portrait)',\n  retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' +\n    'only screen and (min--moz-device-pixel-ratio: 2),' +\n    'only screen and (-o-min-device-pixel-ratio: 2/1),' +\n    'only screen and (min-device-pixel-ratio: 2),' +\n    'only screen and (min-resolution: 192dpi),' +\n    'only screen and (min-resolution: 2dppx)'\n  };\n\n\n// matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n/* eslint-disable */\nwindow.matchMedia || (window.matchMedia = (function () {\n  \"use strict\";\n\n  // For browsers that support matchMedium api such as IE 9 and webkit\n  var styleMedia = (window.styleMedia || window.media);\n\n  // For those that don't support matchMedium\n  if (!styleMedia) {\n    var style   = document.createElement('style'),\n    script      = document.getElementsByTagName('script')[0],\n    info        = null;\n\n    style.type  = 'text/css';\n    style.id    = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    }\n\n    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n    info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;\n\n    styleMedia = {\n      matchMedium: function (media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';\n\n        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        }\n\n        // Test if media query is true or false\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function(media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n})());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init() {\n    var self = this;\n    var $meta = $('meta.foundation-mq');\n    if(!$meta.length){\n      $('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = $('.foundation-mq').css('font-family');\n    var namedQueries;\n\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if(namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: `only screen and (min-width: ${namedQueries[key]})`\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is(size) {\n    size = size.trim().split(' ');\n    if(size.length > 1 && size[1] === 'only') {\n      if(size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get(size) {\n    for (var i in this.queries) {\n      if(this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (typeof matched === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher() {\n    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', () => {\n      var newSize = this._getCurrentSize(), currentSize = this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        this.current = newSize;\n\n        // Broadcast the media query change on the window\n        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n};\n\n\n\n// Thank you: https://github.com/sindresorhus/query-string\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function(ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key);\n\n    // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n    return ret;\n  }, {});\n\n  return styleObject;\n}\n\nexport {MediaQuery};\n","\"use strict\";\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\n\nvar FOUNDATION_VERSION = '6.5.3';\n\n// Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\nvar Foundation = {\n  version: FOUNDATION_VERSION,\n\n  /**\n   * Stores initialized plugins.\n   */\n  _plugins: {},\n\n  /**\n   * Stores generated unique ids for plugin instances\n   */\n  _uuids: [],\n\n  /**\n   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n   * @param {Object} plugin - The constructor of the plugin.\n   */\n  plugin: function(plugin, name) {\n    // Object key to use when adding to global Foundation object\n    // Examples: Foundation.Reveal, Foundation.OffCanvas\n    var className = (name || functionName(plugin));\n    // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n    // Examples: data-reveal, data-off-canvas\n    var attrName  = hyphenate(className);\n\n    // Add to the Foundation object and the plugins list (for reflowing)\n    this._plugins[attrName] = this[className] = plugin;\n  },\n  /**\n   * @function\n   * Populates the _uuids array with pointers to each individual plugin instance.\n   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n   * Also fires the initialization event for each plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @param {String} name - the name of the plugin, passed as a camelCased string.\n   * @fires Plugin#init\n   */\n  registerPlugin: function(plugin, name){\n    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n    plugin.uuid = GetYoDigits(6, pluginName);\n\n    if(!plugin.$element.attr(`data-${pluginName}`)){ plugin.$element.attr(`data-${pluginName}`, plugin.uuid); }\n    if(!plugin.$element.data('zfPlugin')){ plugin.$element.data('zfPlugin', plugin); }\n          /**\n           * Fires when the plugin has initialized.\n           * @event Plugin#init\n           */\n    plugin.$element.trigger(`init.zf.${pluginName}`);\n\n    this._uuids.push(plugin.uuid);\n\n    return;\n  },\n  /**\n   * @function\n   * Removes the plugins uuid from the _uuids array.\n   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n   * Also fires the destroyed event for the plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @fires Plugin#destroyed\n   */\n  unregisterPlugin: function(plugin){\n    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n    plugin.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n          /**\n           * Fires when the plugin has been destroyed.\n           * @event Plugin#destroyed\n           */\n          .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in plugin){\n      plugin[prop] = null;//clean up script to prep for garbage collection.\n    }\n    return;\n  },\n\n  /**\n   * @function\n   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n   * @default If no argument is passed, reflow all currently active plugins.\n   */\n   reInit: function(plugins){\n     var isJQ = plugins instanceof $;\n     try{\n       if(isJQ){\n         plugins.each(function(){\n           $(this).data('zfPlugin')._init();\n         });\n       }else{\n         var type = typeof plugins,\n         _this = this,\n         fns = {\n           'object': function(plgs){\n             plgs.forEach(function(p){\n               p = hyphenate(p);\n               $('[data-'+ p +']').foundation('_init');\n             });\n           },\n           'string': function(){\n             plugins = hyphenate(plugins);\n             $('[data-'+ plugins +']').foundation('_init');\n           },\n           'undefined': function(){\n             this['object'](Object.keys(_this._plugins));\n           }\n         };\n         fns[type](plugins);\n       }\n     }catch(err){\n       console.error(err);\n     }finally{\n       return plugins;\n     }\n   },\n\n  /**\n   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n   */\n  reflow: function(elem, plugins) {\n\n    // If plugins is undefined, just grab everything\n    if (typeof plugins === 'undefined') {\n      plugins = Object.keys(this._plugins);\n    }\n    // If plugins is a string, convert it to an array with one item\n    else if (typeof plugins === 'string') {\n      plugins = [plugins];\n    }\n\n    var _this = this;\n\n    // Iterate through each plugin\n    $.each(plugins, function(i, name) {\n      // Get the current plugin\n      var plugin = _this._plugins[name];\n\n      // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n      var $elem = $(elem).find('[data-'+name+']').addBack('[data-'+name+']');\n\n      // For each plugin found, initialize it\n      $elem.each(function() {\n        var $el = $(this),\n            opts = {};\n        // Don't double-dip on plugins\n        if ($el.data('zfPlugin')) {\n          console.warn(\"Tried to initialize \"+name+\" on an element that already has a Foundation plugin.\");\n          return;\n        }\n\n        if($el.attr('data-options')){\n          var thing = $el.attr('data-options').split(';').forEach(function(e, i){\n            var opt = e.split(':').map(function(el){ return el.trim(); });\n            if(opt[0]) opts[opt[0]] = parseValue(opt[1]);\n          });\n        }\n        try{\n          $el.data('zfPlugin', new plugin($(this), opts));\n        }catch(er){\n          console.error(er);\n        }finally{\n          return;\n        }\n      });\n    });\n  },\n  getFnName: functionName,\n\n  addToJquery: function($) {\n    // TODO: consider not making this a jQuery function\n    // TODO: need way to reflow vs. re-initialize\n    /**\n     * The Foundation jQuery method.\n     * @param {String|Array} method - An action to perform on the current jQuery object.\n     */\n    var foundation = function(method) {\n      var type = typeof method,\n          $noJS = $('.no-js');\n\n      if($noJS.length){\n        $noJS.removeClass('no-js');\n      }\n\n      if(type === 'undefined'){//needs to initialize the Foundation object, or an individual plugin.\n        MediaQuery._init();\n        Foundation.reflow(this);\n      }else if(type === 'string'){//an individual method to invoke on a plugin or group of plugins\n        var args = Array.prototype.slice.call(arguments, 1);//collect all the arguments, if necessary\n        var plugClass = this.data('zfPlugin');//determine the class of plugin\n\n        if(typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined'){//make sure both the class and method exist\n          if(this.length === 1){//if there's only one, call it directly.\n              plugClass[method].apply(plugClass, args);\n          }else{\n            this.each(function(i, el){//otherwise loop through the jQuery collection and invoke the method on each\n              plugClass[method].apply($(el).data('zfPlugin'), args);\n            });\n          }\n        }else{//error for no class or no method\n          throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n        }\n      }else{//error for invalid argument type\n        throw new TypeError(`We're sorry, ${type} is not a valid parameter. You must use a string representing the method you wish to invoke.`);\n      }\n      return this;\n    };\n    $.fn.foundation = foundation;\n    return $;\n  }\n};\n\nFoundation.util = {\n  /**\n   * Function for applying a debounce effect to a function call.\n   * @function\n   * @param {Function} func - Function to be called at end of timeout.\n   * @param {Number} delay - Time in ms to delay the call of `func`.\n   * @returns function\n   */\n  throttle: function (func, delay) {\n    var timer = null;\n\n    return function () {\n      var context = this, args = arguments;\n\n      if (timer === null) {\n        timer = setTimeout(function () {\n          func.apply(context, args);\n          timer = null;\n        }, delay);\n      }\n    };\n  }\n};\n\nwindow.Foundation = Foundation;\n\n// Polyfill for requestAnimationFrame\n(function() {\n  if (!Date.now || !window.Date.now)\n    window.Date.now = Date.now = function() { return new Date().getTime(); };\n\n  var vendors = ['webkit', 'moz'];\n  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n      var vp = vendors[i];\n      window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];\n      window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']\n                                 || window[vp+'CancelRequestAnimationFrame']);\n  }\n  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)\n    || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n    var lastTime = 0;\n    window.requestAnimationFrame = function(callback) {\n        var now = Date.now();\n        var nextTime = Math.max(lastTime + 16, now);\n        return setTimeout(function() { callback(lastTime = nextTime); },\n                          nextTime - now);\n    };\n    window.cancelAnimationFrame = clearTimeout;\n  }\n  /**\n   * Polyfill for performance.now, required by rAF\n   */\n  if(!window.performance || !window.performance.now){\n    window.performance = {\n      start: Date.now(),\n      now: function(){ return Date.now() - this.start; }\n    };\n  }\n})();\nif (!Function.prototype.bind) {\n  Function.prototype.bind = function(oThis) {\n    if (typeof this !== 'function') {\n      // closest thing possible to the ECMAScript 5\n      // internal IsCallable function\n      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n    }\n\n    var aArgs   = Array.prototype.slice.call(arguments, 1),\n        fToBind = this,\n        fNOP    = function() {},\n        fBound  = function() {\n          return fToBind.apply(this instanceof fNOP\n                 ? this\n                 : oThis,\n                 aArgs.concat(Array.prototype.slice.call(arguments)));\n        };\n\n    if (this.prototype) {\n      // native functions don't have a prototype\n      fNOP.prototype = this.prototype;\n    }\n    fBound.prototype = new fNOP();\n\n    return fBound;\n  };\n}\n// Polyfill to get the name of a function in IE9\nfunction functionName(fn) {\n  if (typeof Function.prototype.name === 'undefined') {\n    var funcNameRegex = /function\\s([^(]{1,})\\(/;\n    var results = (funcNameRegex).exec((fn).toString());\n    return (results && results.length > 1) ? results[1].trim() : \"\";\n  }\n  else if (typeof fn.prototype === 'undefined') {\n    return fn.constructor.name;\n  }\n  else {\n    return fn.prototype.constructor.name;\n  }\n}\nfunction parseValue(str){\n  if ('true' === str) return true;\n  else if ('false' === str) return false;\n  else if (!isNaN(str * 1)) return parseFloat(str);\n  return str;\n}\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nexport {Foundation};\n","'use strict';\n\n\nimport { rtl as Rtl } from \"./foundation.core.utils\";\n\nvar Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  OverlapArea: OverlapArea,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets,\n  GetExplicitOffsets: GetExplicitOffsets\n}\n\n/**\n * Compares the dimensions of an element to a container and determines collision events with container.\n * @function\n * @param {jQuery} element - jQuery object to test for collisions.\n * @param {jQuery} parent - jQuery object to use as bounding container.\n * @param {Boolean} lrOnly - set to true to check left and right values only.\n * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n * @default if no parent object passed, detects collisions with `window`.\n * @returns {Boolean} - true if collision free, false if a collision in any direction.\n */\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n};\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  var eleDims = GetDimensions(element),\n  topOver, bottomOver, leftOver, rightOver;\n  if (parent) {\n    var parDims = GetDimensions(parent);\n\n    bottomOver = (parDims.height + parDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - parDims.offset.top;\n    leftOver   = eleDims.offset.left - parDims.offset.left;\n    rightOver  = (parDims.width + parDims.offset.left) - (eleDims.offset.left + eleDims.width);\n  }\n  else {\n    bottomOver = (eleDims.windowDims.height + eleDims.windowDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - eleDims.windowDims.offset.top;\n    leftOver   = eleDims.offset.left - eleDims.windowDims.offset.left;\n    rightOver  = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n  }\n\n  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n  topOver    = Math.min(topOver, 0);\n  leftOver   = Math.min(leftOver, 0);\n  rightOver  = Math.min(rightOver, 0);\n\n  if (lrOnly) {\n    return leftOver + rightOver;\n  }\n  if (tbOnly) {\n    return topOver + bottomOver;\n  }\n\n  // use sum of squares b/c we care about overlap area.\n  return Math.sqrt((topOver * topOver) + (bottomOver * bottomOver) + (leftOver * leftOver) + (rightOver * rightOver));\n}\n\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\nfunction GetDimensions(elem){\n  elem = elem.length ? elem[0] : elem;\n\n  if (elem === window || elem === document) {\n    throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n  }\n\n  var rect = elem.getBoundingClientRect(),\n      parRect = elem.parentNode.getBoundingClientRect(),\n      winRect = document.body.getBoundingClientRect(),\n      winY = window.pageYOffset,\n      winX = window.pageXOffset;\n\n  return {\n    width: rect.width,\n    height: rect.height,\n    offset: {\n      top: rect.top + winY,\n      left: rect.left + winX\n    },\n    parentDims: {\n      width: parRect.width,\n      height: parRect.height,\n      offset: {\n        top: parRect.top + winY,\n        left: parRect.left + winX\n      }\n    },\n    windowDims: {\n      width: winRect.width,\n      height: winRect.height,\n      offset: {\n        top: winY,\n        left: winX\n      }\n    }\n  }\n}\n\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\nfunction GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {\n  console.log(\"NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5\");\n  switch (position) {\n    case 'top':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);\n    case 'bottom':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    case 'center top':\n      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);\n    case 'center bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);\n    case 'center left':\n      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);\n    case 'center right':\n      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);\n    case 'left bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);\n    case 'right bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    // Backwards compatibility... this along with the reveal and reveal full\n    // classes are the only ones that didn't reference anchor\n    case 'center':\n      return {\n        left: ($eleDims.windowDims.offset.left + ($eleDims.windowDims.width / 2)) - ($eleDims.width / 2) + hOffset,\n        top: ($eleDims.windowDims.offset.top + ($eleDims.windowDims.height / 2)) - ($eleDims.height / 2 + vOffset)\n      }\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + vOffset\n      }\n    case 'reveal full':\n      return {\n        left: $eleDims.windowDims.offset.left,\n        top: $eleDims.windowDims.offset.top\n      }\n      break;\n    default:\n      return {\n        left: (Rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset: $anchorDims.offset.left + hOffset),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n\n  }\n\n}\n\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n      var topVal, leftVal;\n\n  // set position related attribute\n\n  switch (position) {\n    case 'top':\n      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n      break;\n    case 'bottom':\n      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n      break;\n    case 'left':\n      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n      break;\n    case 'right':\n      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n      break;\n  }\n\n\n  // set alignment related attribute\n  switch (position) {\n    case 'top':\n    case 'bottom':\n      switch (alignment) {\n        case 'left':\n          leftVal = $anchorDims.offset.left + hOffset;\n          break;\n        case 'right':\n          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n          break;\n        case 'center':\n          leftVal = isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)) + hOffset;\n          break;\n      }\n      break;\n    case 'right':\n    case 'left':\n      switch (alignment) {\n        case 'bottom':\n          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n          break;\n        case 'top':\n          topVal = $anchorDims.offset.top + vOffset\n          break;\n        case 'center':\n          topVal = ($anchorDims.offset.top + vOffset + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n          break;\n      }\n      break;\n  }\n  return {top: topVal, left: leftVal};\n}\n\nexport {Box};\n","'use strict';\n\nimport $ from 'jquery';\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\nfunction onImagesLoaded(images, callback){\n  var self = this,\n      unloaded = images.length;\n\n  if (unloaded === 0) {\n    callback();\n  }\n\n  images.each(function(){\n    // Check if image is loaded\n    if (this.complete && typeof this.naturalWidth !== 'undefined') {\n      singleImageLoaded();\n    }\n    else {\n      // If the above check failed, simulate loading on detached element.\n      var image = new Image();\n      // Still count image as loaded if it finalizes with an error.\n      var events = \"load.zf.images error.zf.images\";\n      $(image).one(events, function me(event){\n        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n        $(this).off(events, me);\n        singleImageLoaded();\n      });\n      image.src = $(this).attr('src');\n    }\n  });\n\n  function singleImageLoaded() {\n    unloaded--;\n    if (unloaded === 0) {\n      callback();\n    }\n  }\n}\n\nexport { onImagesLoaded };\n","/*******************************************\n *                                         *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n *                                         *\n ******************************************/\n\n'use strict';\n\nimport $ from 'jquery';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  35: 'END',\n  36: 'HOME',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n}\n\nvar commands = {}\n\n// Functions pulled out to be referenceable from internals\nfunction findFocusable($element) {\n  if(!$element) {return false; }\n  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function() {\n    if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) { return false; } //only have visible elements and those that have a tabindex greater or equal 0\n    return true;\n  });\n}\n\nfunction parseKey(event) {\n  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();\n\n  // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n  key = key.replace(/\\W+/, '');\n\n  if (event.shiftKey) key = `SHIFT_${key}`;\n  if (event.ctrlKey) key = `CTRL_${key}`;\n  if (event.altKey) key = `ALT_${key}`;\n\n  // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n  key = key.replace(/_$/, '');\n\n  return key;\n}\n\nvar Keyboard = {\n  keys: getKeyCodes(keyCodes),\n\n  /**\n   * Parses the (keyboard) event and returns a String that represents its key\n   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n   * @param {Event} event - the event generated by the event handler\n   * @return String key - String that represents the key pressed\n   */\n  parseKey: parseKey,\n\n  /**\n   * Handles the given (keyboard) event\n   * @param {Event} event - the event generated by the event handler\n   * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n   * @param {Objects} functions - collection of functions that are to be executed\n   */\n  handleKey(event, component, functions) {\n    var commandList = commands[component],\n      keyCode = this.parseKey(event),\n      cmds,\n      command,\n      fn;\n\n    if (!commandList) return console.warn('Component not defined!');\n\n    if (typeof commandList.ltr === 'undefined') { // this component does not differentiate between ltr and rtl\n        cmds = commandList; // use plain list\n    } else { // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n        if (Rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);\n\n        else cmds = $.extend({}, commandList.rtl, commandList.ltr);\n    }\n    command = cmds[keyCode];\n\n    fn = functions[command];\n    if (fn && typeof fn === 'function') { // execute function  if exists\n      var returnValue = fn.apply();\n      if (functions.handled || typeof functions.handled === 'function') { // execute function when event was handled\n          functions.handled(returnValue);\n      }\n    } else {\n      if (functions.unhandled || typeof functions.unhandled === 'function') { // execute function when event was not handled\n          functions.unhandled();\n      }\n    }\n  },\n\n  /**\n   * Finds all focusable elements within the given `$element`\n   * @param {jQuery} $element - jQuery object to search within\n   * @return {jQuery} $focusable - all focusable elements within `$element`\n   */\n\n  findFocusable: findFocusable,\n\n  /**\n   * Returns the component name name\n   * @param {Object} component - Foundation component, e.g. Slider or Reveal\n   * @return String componentName\n   */\n\n  register(componentName, cmds) {\n    commands[componentName] = cmds;\n  },\n\n\n  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n  //\n  /**\n   * Traps the focus in the given element.\n   * @param  {jQuery} $element  jQuery object to trap the foucs into.\n   */\n  trapFocus($element) {\n    var $focusable = findFocusable($element),\n        $firstFocusable = $focusable.eq(0),\n        $lastFocusable = $focusable.eq(-1);\n\n    $element.on('keydown.zf.trapfocus', function(event) {\n      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      }\n      else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n        event.preventDefault();\n        $lastFocusable.focus();\n      }\n    });\n  },\n  /**\n   * Releases the trapped focus from the given element.\n   * @param  {jQuery} $element  jQuery object to release the focus for.\n   */\n  releaseFocus($element) {\n    $element.off('keydown.zf.trapfocus');\n  }\n}\n\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\nfunction getKeyCodes(kcs) {\n  var k = {};\n  for (var kc in kcs) k[kcs[kc]] = kcs[kc];\n  return k;\n}\n\nexport {Keyboard};\n","'use strict';\n\nimport $ from 'jquery';\nimport { transitionend } from './foundation.core.utils';\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nconst initClasses   = ['mui-enter', 'mui-leave'];\nconst activeClasses = ['mui-enter-active', 'mui-leave-active'];\n\nconst Motion = {\n  animateIn: function(element, animation, cb) {\n    animate(true, element, animation, cb);\n  },\n\n  animateOut: function(element, animation, cb) {\n    animate(false, element, animation, cb);\n  }\n}\n\nfunction Move(duration, elem, fn){\n  var anim, prog, start = null;\n  // console.log('called');\n\n  if (duration === 0) {\n    fn.apply(elem);\n    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    return;\n  }\n\n  function move(ts){\n    if(!start) start = ts;\n    // console.log(start, ts);\n    prog = ts - start;\n    fn.apply(elem);\n\n    if(prog < duration){ anim = window.requestAnimationFrame(move, elem); }\n    else{\n      window.cancelAnimationFrame(anim);\n      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    }\n  }\n  anim = window.requestAnimationFrame(move);\n}\n\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\nfunction animate(isIn, element, animation, cb) {\n  element = $(element).eq(0);\n\n  if (!element.length) return;\n\n  var initClass = isIn ? initClasses[0] : initClasses[1];\n  var activeClass = isIn ? activeClasses[0] : activeClasses[1];\n\n  // Set up the animation\n  reset();\n\n  element\n    .addClass(animation)\n    .css('transition', 'none');\n\n  requestAnimationFrame(() => {\n    element.addClass(initClass);\n    if (isIn) element.show();\n  });\n\n  // Start the animation\n  requestAnimationFrame(() => {\n    element[0].offsetWidth;\n    element\n      .css('transition', '')\n      .addClass(activeClass);\n  });\n\n  // Clean up the animation when it finishes\n  element.one(transitionend(element), finish);\n\n  // Hides the element (for out animations), resets the element, and runs a callback\n  function finish() {\n    if (!isIn) element.hide();\n    reset();\n    if (cb) cb.apply(element);\n  }\n\n  // Resets transitions and removes motion-specific classes\n  function reset() {\n    element[0].style.transitionDuration = 0;\n    element.removeClass(`${initClass} ${activeClass} ${animation}`);\n  }\n}\n\nexport { Move, Motion };\n\n","'use strict';\n\nimport $ from 'jquery';\n\nconst Nest = {\n  Feather(menu, type = 'zf') {\n    menu.attr('role', 'menubar');\n\n    var items = menu.find('li').attr({'role': 'menuitem'}),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`,\n        applyAria = (type !== 'accordion'); // Accordions handle their own ARIA attriutes.\n\n    items.each(function() {\n      var $item = $(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item.addClass(hasSubClass);\n        if(applyAria) {\n          $item.attr({\n            'aria-haspopup': true,\n            'aria-label': $item.children('a:first').text()\n          });\n          // Note:  Drilldowns behave differently in how they hide, and so need\n          // additional attributes.  We should look if this possibly over-generalized\n          // utility (Nest) is appropriate when we rework menus in 6.4\n          if(type === 'drilldown') {\n            $item.attr({'aria-expanded': false});\n          }\n        }\n        $sub\n          .addClass(`submenu ${subMenuClass}`)\n          .attr({\n            'data-submenu': '',\n            'role': 'menubar'\n          });\n        if(type === 'drilldown') {\n          $sub.attr({'aria-hidden': true});\n        }\n      }\n\n      if ($item.parent('[data-submenu]').length) {\n        $item.addClass(`is-submenu-item ${subItemClass}`);\n      }\n    });\n\n    return;\n  },\n\n  Burn(menu, type) {\n    var //items = menu.find('li'),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`;\n\n    menu\n      .find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li')\n      .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n      .removeAttr('data-submenu').css('display', '');\n\n  }\n}\n\nexport {Nest};\n","'use strict';\n\nimport $ from 'jquery';\n\nfunction Timer(elem, options, cb) {\n  var _this = this,\n      duration = options.duration,//options is an object for easily adding features later.\n      nameSpace = Object.keys(elem.data())[0] || 'timer',\n      remain = -1,\n      start,\n      timer;\n\n  this.isPaused = false;\n\n  this.restart = function() {\n    remain = -1;\n    clearTimeout(timer);\n    this.start();\n  }\n\n  this.start = function() {\n    this.isPaused = false;\n    // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    remain = remain <= 0 ? duration : remain;\n    elem.data('paused', false);\n    start = Date.now();\n    timer = setTimeout(function(){\n      if(options.infinite){\n        _this.restart();//rerun the timer.\n      }\n      if (cb && typeof cb === 'function') { cb(); }\n    }, remain);\n    elem.trigger(`timerstart.zf.${nameSpace}`);\n  }\n\n  this.pause = function() {\n    this.isPaused = true;\n    //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    elem.data('paused', true);\n    var end = Date.now();\n    remain = remain - (end - start);\n    elem.trigger(`timerpaused.zf.${nameSpace}`);\n  }\n}\n\nexport {Timer};\n","//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nimport $ from 'jquery';\n\nvar Touch = {};\n\nvar startPosX,\n    startPosY,\n    startTime,\n    elapsedTime,\n    startEvent,\n    isMoving = false,\n    didMoved = false;\n\nfunction onTouchEnd(e) {\n  this.removeEventListener('touchmove', onTouchMove);\n  this.removeEventListener('touchend', onTouchEnd);\n\n  // If the touch did not move, consider it as a \"tap\"\n  if (!didMoved) {\n    var tapEvent = $.Event('tap', startEvent || e);\n    $(this).trigger(tapEvent);\n  }\n\n  startEvent = null;\n  isMoving = false;\n  didMoved = false;\n}\n\nfunction onTouchMove(e) {\n  if ($.spotSwipe.preventDefault) { e.preventDefault(); }\n\n  if(isMoving) {\n    var x = e.touches[0].pageX;\n    var y = e.touches[0].pageY;\n    var dx = startPosX - x;\n    var dy = startPosY - y;\n    var dir;\n    didMoved = true;\n    elapsedTime = new Date().getTime() - startTime;\n    if(Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n      dir = dx > 0 ? 'left' : 'right';\n    }\n    // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n    //   dir = dy > 0 ? 'down' : 'up';\n    // }\n    if(dir) {\n      e.preventDefault();\n      onTouchEnd.apply(this, arguments);\n      $(this)\n        .trigger($.Event('swipe', e), dir)\n        .trigger($.Event(`swipe${dir}`, e));\n    }\n  }\n\n}\n\nfunction onTouchStart(e) {\n\n  if (e.touches.length == 1) {\n    startPosX = e.touches[0].pageX;\n    startPosY = e.touches[0].pageY;\n    startEvent = e;\n    isMoving = true;\n    didMoved = false;\n    startTime = new Date().getTime();\n    this.addEventListener('touchmove', onTouchMove, false);\n    this.addEventListener('touchend', onTouchEnd, false);\n  }\n}\n\nfunction init() {\n  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);\n}\n\nfunction teardown() {\n  this.removeEventListener('touchstart', onTouchStart);\n}\n\nclass SpotSwipe {\n  constructor($) {\n    this.version = '1.0.0';\n    this.enabled = 'ontouchstart' in document.documentElement;\n    this.preventDefault = false;\n    this.moveThreshold = 75;\n    this.timeThreshold = 200;\n    this.$ = $;\n    this._init();\n  }\n\n  _init() {\n    var $ = this.$;\n    $.event.special.swipe = { setup: init };\n    $.event.special.tap = { setup: init };\n\n    $.each(['left', 'up', 'down', 'right'], function () {\n      $.event.special[`swipe${this}`] = { setup: function(){\n        $(this).on('swipe', $.noop);\n      } };\n    });\n  }\n}\n\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and    *\n * setupTouchHandler should be idempotent,          *\n * because they directly replace functions &        *\n * values, and do not add event handlers directly.  *\n ****************************************************/\n\nTouch.setupSpotSwipe = function($) {\n  $.spotSwipe = new SpotSwipe($);\n};\n\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\nTouch.setupTouchHandler = function($) {\n  $.fn.addTouch = function(){\n    this.each(function(i,el){\n      $(el).bind('touchstart touchmove touchend touchcancel', function(event)  {\n        //we pass the original event object because the jQuery event\n        //object is normalized to w3c specs and does not provide the TouchList\n        handleTouch(event);\n      });\n    });\n\n    var handleTouch = function(event){\n      var touches = event.changedTouches,\n          first = touches[0],\n          eventTypes = {\n            touchstart: 'mousedown',\n            touchmove: 'mousemove',\n            touchend: 'mouseup'\n          },\n          type = eventTypes[event.type],\n          simulatedEvent\n        ;\n\n      if('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n        simulatedEvent = new window.MouseEvent(type, {\n          'bubbles': true,\n          'cancelable': true,\n          'screenX': first.screenX,\n          'screenY': first.screenY,\n          'clientX': first.clientX,\n          'clientY': first.clientY\n        });\n      } else {\n        simulatedEvent = document.createEvent('MouseEvent');\n        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0/*left*/, null);\n      }\n      first.target.dispatchEvent(simulatedEvent);\n    };\n  };\n};\n\nTouch.init = function ($) {\n\n  if(typeof($.spotSwipe) === 'undefined') {\n    Touch.setupSpotSwipe($);\n    Touch.setupTouchHandler($);\n  }\n};\n\nexport {Touch};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","'use strict';\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\n\n// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\nclass Plugin {\n\n  constructor(element, options) {\n    this._setup(element, options);\n    var pluginName = getPluginName(this);\n    this.uuid = GetYoDigits(6, pluginName);\n\n    if(!this.$element.attr(`data-${pluginName}`)){ this.$element.attr(`data-${pluginName}`, this.uuid); }\n    if(!this.$element.data('zfPlugin')){ this.$element.data('zfPlugin', this); }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n    this.$element.trigger(`init.zf.${pluginName}`);\n  }\n\n  destroy() {\n    this._destroy();\n    var pluginName = getPluginName(this);\n    this.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n        /**\n         * Fires when the plugin has been destroyed.\n         * @event Plugin#destroyed\n         */\n        .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in this){\n      this[prop] = null;//clean up script to prep for garbage collection.\n    }\n  }\n}\n\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n  if(typeof(obj.constructor.name) !== 'undefined') {\n    return hyphenate(obj.constructor.name);\n  } else {\n    return hyphenate(obj.className);\n  }\n}\n\nexport {Plugin};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nclass Abide extends Plugin {\n  /**\n   * Creates a new instance of Abide.\n   * @class\n   * @name Abide\n   * @fires Abide#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options = {}) {\n    this.$element = element;\n    this.options  = $.extend(true, {}, Abide.defaults, this.$element.data(), options);\n\n    this.className = 'Abide'; // ie9 back compat\n    this._init();\n  }\n\n  /**\n   * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n   * @private\n   */\n  _init() {\n    this.$inputs = $.merge(                               // Consider as input to validate:\n      this.$element.find('input').not('[type=submit]'),   // * all input fields expect submit\n      this.$element.find('textarea, select')              // * all textareas and select fields\n    );\n    const $globalErrors = this.$element.find('[data-abide-error]');\n\n    // Add a11y attributes to all fields\n    if (this.options.a11yAttributes) {\n      this.$inputs.each((i, input) => this.addA11yAttributes($(input)));\n      $globalErrors.each((i, error) => this.addGlobalErrorA11yAttributes($(error)));\n    }\n\n    this._events();\n  }\n\n  /**\n   * Initializes events for Abide.\n   * @private\n   */\n  _events() {\n    this.$element.off('.abide')\n      .on('reset.zf.abide', () => {\n        this.resetForm();\n      })\n      .on('submit.zf.abide', () => {\n        return this.validateForm();\n      });\n\n    if (this.options.validateOn === 'fieldChange') {\n      this.$inputs\n        .off('change.zf.abide')\n        .on('change.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.liveValidate) {\n      this.$inputs\n        .off('input.zf.abide')\n        .on('input.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.validateOnBlur) {\n      this.$inputs\n        .off('blur.zf.abide')\n        .on('blur.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n  }\n\n  /**\n   * Calls necessary functions to update Abide upon DOM change\n   * @private\n   */\n  _reflow() {\n    this._init();\n  }\n\n  /**\n   * Checks whether or not a form element has the required attribute and if it's checked or not\n   * @param {Object} element - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  requiredCheck($el) {\n    if (!$el.attr('required')) return true;\n\n    var isGood = true;\n\n    switch ($el[0].type) {\n      case 'checkbox':\n        isGood = $el[0].checked;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        var opt = $el.find('option:selected');\n        if (!opt.length || !opt.val()) isGood = false;\n        break;\n\n      default:\n        if(!$el.val() || !$el.val().length) isGood = false;\n    }\n\n    return isGood;\n  }\n\n  /**\n   * Get:\n   * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n   *   1. The element's direct sibling('s).\n   *   2. The element's parent's children.\n   * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n   *\n   * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n   *\n   * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n   * @returns {Object} jQuery object with the selector.\n   */\n  findFormError($el) {\n    var id = $el[0].id;\n    var $error = $el.siblings(this.options.formErrorSelector);\n\n    if (!$error.length) {\n      $error = $el.parent().find(this.options.formErrorSelector);\n    }\n\n    if (id) {\n      $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"]`));\n    }\n\n    return $error;\n  }\n\n  /**\n   * Get the first element in this order:\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findLabel($el) {\n    var id = $el[0].id;\n    var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n    if (!$label.length) {\n      return $el.closest('label');\n    }\n\n    return $label;\n  }\n\n  /**\n   * Get the set of labels associated with a set of radio els in this order\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findRadioLabels($els) {\n    var labels = $els.map((i, el) => {\n      var id = el.id;\n      var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n      if (!$label.length) {\n        $label = $(el).closest('label');\n      }\n      return $label[0];\n    });\n\n    return $(labels);\n  }\n\n  /**\n   * Adds the CSS error class as specified by the Abide settings to the label, input, and the form\n   * @param {Object} $el - jQuery object to add the class to\n   */\n  addErrorClasses($el) {\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.addClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.addClass(this.options.formErrorClass);\n    }\n\n    $el.addClass(this.options.inputErrorClass).attr({\n      'data-invalid': '',\n      'aria-invalid': true\n    });\n  }\n\n  /**\n   * Adds [for] and [role=alert] attributes to all form error targetting $el,\n   * and [aria-describedby] attribute to $el toward the first form error.\n   * @param {Object} $el - jQuery object\n   */\n  addA11yAttributes($el) {\n    let $errors = this.findFormError($el);\n    let $labels = $errors.filter('label');\n    let $error = $errors.first();\n    if (!$errors.length) return;\n\n    // Set [aria-describedby] on the input toward the first form error if it is not set\n    if (typeof $el.attr('aria-describedby') === 'undefined') {\n      // Get the first error ID or create one\n      let errorId = $error.attr('id');\n      if (typeof errorId === 'undefined') {\n        errorId = GetYoDigits(6, 'abide-error');\n        $error.attr('id', errorId);\n      };\n\n      $el.attr('aria-describedby', errorId);\n    }\n\n    if ($labels.filter('[for]').length < $labels.length) {\n      // Get the input ID or create one\n      let elemId = $el.attr('id');\n      if (typeof elemId === 'undefined') {\n        elemId = GetYoDigits(6, 'abide-input');\n        $el.attr('id', elemId);\n      };\n\n      // For each label targeting $el, set [for] if it is not set.\n      $labels.each((i, label) => {\n        const $label = $(label);\n        if (typeof $label.attr('for') === 'undefined')\n          $label.attr('for', elemId);\n      });\n    }\n\n    // For each error targeting $el, set [role=alert] if it is not set.\n    $errors.each((i, label) => {\n      const $label = $(label);\n      if (typeof $label.attr('role') === 'undefined')\n        $label.attr('role', 'alert');\n    }).end();\n  }\n\n  /**\n   * Adds [aria-live] attribute to the given global form error $el.\n   * @param {Object} $el - jQuery object to add the attribute to\n   */\n  addGlobalErrorA11yAttributes($el) {\n    if (typeof $el.attr('aria-live') === 'undefined')\n      $el.attr('aria-live', this.options.a11yErrorLevel);\n  }\n\n  /**\n   * Remove CSS error classes etc from an entire radio button group\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   *\n   */\n  removeRadioErrorClasses(groupName) {\n    var $els = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var $labels = this.findRadioLabels($els);\n    var $formErrors = this.findFormError($els);\n\n    if ($labels.length) {\n      $labels.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formErrors.length) {\n      $formErrors.removeClass(this.options.formErrorClass);\n    }\n\n    $els.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n\n  }\n\n  /**\n   * Removes CSS error class as specified by the Abide settings from the label, input, and the form\n   * @param {Object} $el - jQuery object to remove the class from\n   */\n  removeErrorClasses($el) {\n    // radios need to clear all of the els\n    if($el[0].type == 'radio') {\n      return this.removeRadioErrorClasses($el.attr('name'));\n    }\n\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.removeClass(this.options.formErrorClass);\n    }\n\n    $el.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n  }\n\n  /**\n   * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.\n   * Ignores inputs with data-abide-ignore, type=\"hidden\" or disabled attributes set\n   * @fires Abide#invalid\n   * @fires Abide#valid\n   * @param {Object} element - jQuery object to validate, should be an HTML input\n   * @returns {Boolean} goodToGo - If the input is valid or not.\n   */\n  validateInput($el) {\n    var clearRequire = this.requiredCheck($el),\n        validated = false,\n        customValidator = true,\n        validator = $el.attr('data-validator'),\n        equalTo = true;\n\n    // don't validate ignored inputs or hidden inputs or disabled inputs\n    if ($el.is('[data-abide-ignore]') || $el.is('[type=\"hidden\"]') || $el.is('[disabled]')) {\n      return true;\n    }\n\n    switch ($el[0].type) {\n      case 'radio':\n        validated = this.validateRadio($el.attr('name'));\n        break;\n\n      case 'checkbox':\n        validated = clearRequire;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        validated = clearRequire;\n        break;\n\n      default:\n        validated = this.validateText($el);\n    }\n\n    if (validator) {\n      customValidator = this.matchValidation($el, validator, $el.attr('required'));\n    }\n\n    if ($el.attr('data-equalto')) {\n      equalTo = this.options.validators.equalTo($el);\n    }\n\n\n    var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;\n    var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';\n\n    if (goodToGo) {\n      // Re-validate inputs that depend on this one with equalto\n      const dependentElements = this.$element.find(`[data-equalto=\"${$el.attr('id')}\"]`);\n      if (dependentElements.length) {\n        let _this = this;\n        dependentElements.each(function() {\n          if ($(this).val()) {\n            _this.validateInput($(this));\n          }\n        });\n      }\n    }\n\n    this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);\n\n    /**\n     * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`\n     * Trigger includes the DOM element of the input.\n     * @event Abide#valid\n     * @event Abide#invalid\n     */\n    $el.trigger(message, [$el]);\n\n    return goodToGo;\n  }\n\n  /**\n   * Goes through a form and if there are any invalid inputs, it will display the form error element\n   * @returns {Boolean} noError - true if no errors were detected...\n   * @fires Abide#formvalid\n   * @fires Abide#forminvalid\n   */\n  validateForm() {\n    var acc = [];\n    var _this = this;\n\n    this.$inputs.each(function() {\n      acc.push(_this.validateInput($(this)));\n    });\n\n    var noError = acc.indexOf(false) === -1;\n\n    this.$element.find('[data-abide-error]').each((i, elem) => {\n      const $elem = $(elem);\n      // Ensure a11y attributes are set\n      if (this.options.a11yAttributes) this.addGlobalErrorA11yAttributes($elem);\n      // Show or hide the error\n      $elem.css('display', (noError ? 'none' : 'block'));\n    });\n\n    /**\n     * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.\n     * Trigger includes the element of the form.\n     * @event Abide#formvalid\n     * @event Abide#forminvalid\n     */\n    this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);\n\n    return noError;\n  }\n\n  /**\n   * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.\n   * @param {Object} $el - jQuery object to validate, should be a text input HTML element\n   * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns\n   * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified\n   */\n  validateText($el, pattern) {\n    // A pattern can be passed to this function, or it will be infered from the input's \"pattern\" attribute, or it's \"type\" attribute\n    pattern = (pattern || $el.attr('pattern') || $el.attr('type'));\n    var inputText = $el.val();\n    var valid = false;\n\n    if (inputText.length) {\n      // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp\n      if (this.options.patterns.hasOwnProperty(pattern)) {\n        valid = this.options.patterns[pattern].test(inputText);\n      }\n      // If the pattern name isn't also the type attribute of the field, then test it as a regexp\n      else if (pattern !== $el.attr('type')) {\n        valid = new RegExp(pattern).test(inputText);\n      }\n      else {\n        valid = true;\n      }\n    }\n    // An empty field is valid if it's not required\n    else if (!$el.prop('required')) {\n      valid = true;\n    }\n\n    return valid;\n   }\n\n  /**\n   * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)\n   */\n  validateRadio(groupName) {\n    // If at least one radio in the group has the `required` attribute, the group is considered required\n    // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice\n    var $group = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var valid = false, required = false;\n\n    // For the group to be required, at least one radio needs to be required\n    $group.each((i, e) => {\n      if ($(e).attr('required')) {\n        required = true;\n      }\n    });\n    if(!required) valid=true;\n\n    if (!valid) {\n      // For the group to be valid, at least one radio needs to be checked\n      $group.each((i, e) => {\n        if ($(e).prop('checked')) {\n          valid = true;\n        }\n      });\n    };\n\n    return valid;\n  }\n\n  /**\n   * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator=\"foo bar baz\"` in a space separated listed.\n   * @param {Object} $el - jQuery input element.\n   * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.\n   * @param {Boolean} required - self explanatory?\n   * @returns {Boolean} - true if validations passed.\n   */\n  matchValidation($el, validators, required) {\n    required = required ? true : false;\n\n    var clear = validators.split(' ').map((v) => {\n      return this.options.validators[v]($el, required, $el.parent());\n    });\n    return clear.indexOf(false) === -1;\n  }\n\n  /**\n   * Resets form inputs and styles\n   * @fires Abide#formreset\n   */\n  resetForm() {\n    var $form = this.$element,\n        opts = this.options;\n\n    $(`.${opts.labelErrorClass}`, $form).not('small').removeClass(opts.labelErrorClass);\n    $(`.${opts.inputErrorClass}`, $form).not('small').removeClass(opts.inputErrorClass);\n    $(`${opts.formErrorSelector}.${opts.formErrorClass}`).removeClass(opts.formErrorClass);\n    $form.find('[data-abide-error]').css('display', 'none');\n    $(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:radio', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    /**\n     * Fires when the form has been reset.\n     * @event Abide#formreset\n     */\n    $form.trigger('formreset.zf.abide', [$form]);\n  }\n\n  /**\n   * Destroys an instance of Abide.\n   * Removes error styles and classes from elements, without resetting their values.\n   */\n  _destroy() {\n    var _this = this;\n    this.$element\n      .off('.abide')\n      .find('[data-abide-error]')\n        .css('display', 'none');\n\n    this.$inputs\n      .off('.abide')\n      .each(function() {\n        _this.removeErrorClasses($(this));\n      });\n  }\n}\n\n/**\n * Default settings for plugin\n */\nAbide.defaults = {\n  /**\n   * The default event to validate inputs. Checkboxes and radios validate immediately.\n   * Remove or change this value for manual validation.\n   * @option\n   * @type {?string}\n   * @default 'fieldChange'\n   */\n  validateOn: 'fieldChange',\n\n  /**\n   * Class to be applied to input labels on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-label'\n   */\n  labelErrorClass: 'is-invalid-label',\n\n  /**\n   * Class to be applied to inputs on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-input'\n   */\n  inputErrorClass: 'is-invalid-input',\n\n  /**\n   * Class selector to use to target Form Errors for show/hide.\n   * @option\n   * @type {string}\n   * @default '.form-error'\n   */\n  formErrorSelector: '.form-error',\n\n  /**\n   * Class added to Form Errors on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-visible'\n   */\n  formErrorClass: 'is-visible',\n\n  /**\n   * If true, automatically insert when possible:\n   * - `[aria-describedby]` on fields\n   * - `[role=alert]` on form errors and `[for]` on form error labels\n   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  a11yAttributes: true,\n\n  /**\n   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.\n   * Options are: 'assertive', 'polite' and 'off'/null\n   * @option\n   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions\n   * @type {string}\n   * @default 'assertive'\n   */\n  a11yErrorLevel: 'assertive',\n\n  /**\n   * Set to true to validate text inputs on any value change.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  liveValidate: false,\n\n  /**\n   * Set to true to validate inputs on blur.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  validateOnBlur: false,\n\n  patterns: {\n    alpha : /^[a-zA-Z]+$/,\n    alpha_numeric : /^[a-zA-Z0-9]+$/,\n    integer : /^[-+]?\\d+$/,\n    number : /^[-+]?\\d*(?:[\\.\\,]\\d+)?$/,\n\n    // amex, visa, diners\n    card : /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\\d{3})\\d{11})$/,\n    cvv : /^([0-9]){3,4}$/,\n\n    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address\n    email : /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,\n\n    // From CommonRegexJS (@talyssonoc)\n    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76\n    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.\n    url: /^((?:(https?|ftps?|file|ssh|sftp):\\/\\/|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}\\/)(?:[^\\s()<>]+|\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\))+(?:\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:\\'\".,<>?\\xab\\xbb\\u201c\\u201d\\u2018\\u2019]))$/,\n\n    // abc.de\n    domain : /^([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,8}$/,\n\n    datetime : /^([0-2][0-9]{3})\\-([0-1][0-9])\\-([0-3][0-9])T([0-5][0-9])\\:([0-5][0-9])\\:([0-5][0-9])(Z|([\\-\\+]([0-1][0-9])\\:00))$/,\n    // YYYY-MM-DD\n    date : /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,\n    // HH:MM:SS\n    time : /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,\n    dateISO : /^\\d{4}[\\/\\-]\\d{1,2}[\\/\\-]\\d{1,2}$/,\n    // MM/DD/YYYY\n    month_day_year : /^(0[1-9]|1[012])[- \\/.](0[1-9]|[12][0-9]|3[01])[- \\/.]\\d{4}$/,\n    // DD/MM/YYYY\n    day_month_year : /^(0[1-9]|[12][0-9]|3[01])[- \\/.](0[1-9]|1[012])[- \\/.]\\d{4}$/,\n\n    // #FFF or #FFFFFF\n    color : /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,\n\n    // Domain || URL\n    website: {\n      test: (text) => {\n        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);\n      }\n    }\n  },\n\n  /**\n   * Optional validation functions to be used. `equalTo` being the only default included function.\n   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:\n   * el : The jQuery element to validate.\n   * required : Boolean value of the required attribute be present or not.\n   * parent : The direct parent of the input.\n   * @option\n   */\n  validators: {\n    equalTo: function (el, required, parent) {\n      return $(`#${el.attr('data-equalto')}`).val() === el.val();\n    }\n  }\n}\n\nexport {Abide};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Accordion module.\n * @module foundation.accordion\n * @requires foundation.util.keyboard\n */\n\nclass Accordion extends Plugin {\n  /**\n   * Creates a new instance of an accordion.\n   * @class\n   * @name Accordion\n   * @fires Accordion#init\n   * @param {jQuery} element - jQuery object to make into an accordion.\n   * @param {Object} options - a plain object with settings to override the default options.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);\n\n    this.className = 'Accordion'; // ie9 back compat\n    this._init();\n\n    Keyboard.register('Accordion', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_DOWN': 'next',\n      'ARROW_UP': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the accordion by animating the preset active pane(s).\n   * @private\n   */\n  _init() {\n    this._isInitializing = true;\n\n    this.$element.attr('role', 'tablist');\n    this.$tabs = this.$element.children('[data-accordion-item]');\n\n    this.$tabs.each(function(idx, el) {\n      var $el = $(el),\n          $content = $el.children('[data-tab-content]'),\n          id = $content[0].id || GetYoDigits(6, 'accordion'),\n          linkId = (el.id) ? `${el.id}-label` : `${id}-label`;\n\n      $el.find('a:first').attr({\n        'aria-controls': id,\n        'role': 'tab',\n        'id': linkId,\n        'aria-expanded': false,\n        'aria-selected': false\n      });\n\n      $content.attr({'role': 'tabpanel', 'aria-labelledby': linkId, 'aria-hidden': true, 'id': id});\n    });\n\n    var $initActive = this.$element.find('.is-active').children('[data-tab-content]');\n    if ($initActive.length) {\n      // Save up the initial hash to return to it later when going back in history\n      this._initialAnchor = $initActive.prev('a').attr('href');\n      this._openSingleTab($initActive);\n    }\n\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find(`[href$=\"${anchor}\"]`);\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, open it (if not already active)\n      if ($anchor && $link && $link.length) {\n        if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {\n          this._openSingleTab($anchor);\n        };\n      }\n      // Otherwise, close everything\n      else {\n        this._closeAllTabs();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          onLoad($(window), () => {\n            var offset = this.$element.offset();\n            $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n          });\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Accordion#deeplink\n         */\n        this.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the accordion.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$tabs.each(function() {\n      var $elem = $(this);\n      var $tabContent = $elem.children('[data-tab-content]');\n      if ($tabContent.length) {\n        $elem.children('a').off('click.zf.accordion keydown.zf.accordion')\n               .on('click.zf.accordion', function(e) {\n          e.preventDefault();\n          _this.toggle($tabContent);\n        }).on('keydown.zf.accordion', function(e){\n          Keyboard.handleKey(e, 'Accordion', {\n            toggle: function() {\n              _this.toggle($tabContent);\n            },\n            next: function() {\n              var $a = $elem.next().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            previous: function() {\n              var $a = $elem.prev().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            handled: function() {\n              e.preventDefault();\n              e.stopPropagation();\n            }\n          });\n        });\n      }\n    });\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Toggles the selected content pane's open/close state.\n   * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).\n   * @function\n   */\n  toggle($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]')) {\n      console.info('Cannot toggle an accordion that is disabled.');\n      return;\n    }\n    if($target.parent().hasClass('is-active')) {\n      this.up($target);\n    } else {\n      this.down($target);\n    }\n    //either replace or update browser history\n    if (this.options.deepLink) {\n      var anchor = $target.prev('a').attr('href');\n\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n  }\n\n  /**\n   * Opens the accordion tab defined by `$target`.\n   * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   */\n  down($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]'))  {\n      console.info('Cannot call down on an accordion that is disabled.');\n      return;\n    }\n\n    if (this.options.multiExpand)\n      this._openTab($target);\n    else\n      this._openSingleTab($target);\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * It may be ignored if the Accordion options don't allow it.\n   *\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   */\n  up($target) {\n    if (this.$element.is('[disabled]')) {\n      console.info('Cannot call up on an accordion that is disabled.');\n      return;\n    }\n\n    // Don't close the item if it is already closed\n    const $targetItem = $target.parent();\n    if (!$targetItem.hasClass('is-active')) return;\n\n    // Don't close the item if there is no other active item (unless with `allowAllClosed`)\n    const $othersItems = $targetItem.siblings();\n    if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;\n\n    this._closeTab($target);\n  }\n\n  /**\n   * Make the tab defined by `$target` the only opened tab, closing all others tabs.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @function\n   * @private\n   */\n  _openSingleTab($target) {\n    // Close all the others active tabs.\n    const $activeContents = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeContents.length) {\n      this._closeTab($activeContents.not($target));\n    }\n\n    // Then open the target.\n    this._openTab($target);\n  }\n\n  /**\n   * Opens the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   * @private\n   */\n  _openTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', false);\n    $targetItem.addClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n      'aria-expanded': true,\n      'aria-selected': true\n    });\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done opening.\n       * @event Accordion#down\n       */\n      this.$element.trigger('down.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', true)\n    $targetItem.removeClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n     'aria-expanded': false,\n     'aria-selected': false\n    });\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done collapsing up.\n       * @event Accordion#up\n       */\n      this.$element.trigger('up.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes all active tabs\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeAllTabs() {\n    var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeTabs.length) {\n      this._closeTab($activeTabs);\n    }\n  }\n\n  /**\n   * Destroys an instance of an accordion.\n   * @fires Accordion#destroyed\n   * @function\n   */\n  _destroy() {\n    this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');\n    this.$element.find('a').off('.zf.accordion');\n    if(this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n  }\n}\n\nAccordion.defaults = {\n  /**\n   * Amount of time to animate the opening of an accordion pane.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Allow the accordion to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multiExpand: false,\n  /**\n   * Allow the accordion to close all panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowAllClosed: false,\n  /**\n   * Link the location hash to the open pane.\n   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open accordion\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false\n};\n\nexport {Accordion};\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n */\n\nclass AccordionMenu extends Plugin {\n  /**\n   * Creates a new instance of an accordion menu.\n   * @class\n   * @name AccordionMenu\n   * @fires AccordionMenu#init\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n    this.className = 'AccordionMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('AccordionMenu', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_RIGHT': 'open',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'close',\n      'ESCAPE': 'closeAll'\n    });\n  }\n\n\n\n  /**\n   * Initializes the accordion menu by hiding all nested menus.\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'accordion');\n\n    var _this = this;\n\n    this.$element.find('[data-submenu]').not('.is-active').slideUp(0);//.find('a').css('padding-left', '1rem');\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': this.options.multiOpen\n    });\n\n    this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');\n    this.$menuLinks.each(function(){\n      var linkId = this.id || GetYoDigits(6, 'acc-menu-link'),\n          $elem = $(this),\n          $sub = $elem.children('[data-submenu]'),\n          subId = $sub[0].id || GetYoDigits(6, 'acc-menu'),\n          isActive = $sub.hasClass('is-active');\n\n      if(_this.options.parentLink) {\n        let $anchor = $elem.children('a');\n        $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-accordion-submenu-item\"></li>');\n      }\n\n      if(_this.options.submenuToggle) {\n        $elem.addClass('has-submenu-toggle');\n        $elem.children('a').after('<button id=\"' + linkId + '\" class=\"submenu-toggle\" aria-controls=\"' + subId + '\" aria-expanded=\"' + isActive + '\" title=\"' + _this.options.submenuToggleText + '\"><span class=\"submenu-toggle-text\">' + _this.options.submenuToggleText + '</span></button>');\n      } else {\n        $elem.attr({\n          'aria-controls': subId,\n          'aria-expanded': isActive,\n          'id': linkId\n        });\n      }\n      $sub.attr({\n        'aria-labelledby': linkId,\n        'aria-hidden': !isActive,\n        'role': 'group',\n        'id': subId\n      });\n    });\n    this.$element.find('li').attr({\n      'role': 'treeitem'\n    });\n    var initPanes = this.$element.find('.is-active');\n    if(initPanes.length){\n      var _this = this;\n      initPanes.each(function(){\n        _this.down($(this));\n      });\n    }\n    this._events();\n  }\n\n  /**\n   * Adds event handlers for items within the menu.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.find('li').each(function() {\n      var $submenu = $(this).children('[data-submenu]');\n\n      if ($submenu.length) {\n        if(_this.options.submenuToggle) {\n          $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n            _this.toggle($submenu);\n          });\n        } else {\n            $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n              e.preventDefault();\n              _this.toggle($submenu);\n            });\n        }\n      }\n    }).on('keydown.zf.accordionmenu', function(e){\n      var $element = $(this),\n          $elements = $element.parent('ul').children('li'),\n          $prevElement,\n          $nextElement,\n          $target = $element.children('[data-submenu]');\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1)).find('a').first();\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1)).find('a').first();\n\n          if ($(this).children('[data-submenu]:visible').length) { // has open sub menu\n            $nextElement = $element.find('li:first-child').find('a').first();\n          }\n          if ($(this).is(':first-child')) { // is first element of sub menu\n            $prevElement = $element.parents('li').first().find('a').first();\n          } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) { // if previous element has open sub menu\n            $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();\n          }\n          if ($(this).is(':last-child')) { // is last element of sub menu\n            $nextElement = $element.parents('li').first().next('li').find('a').first();\n          }\n\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'AccordionMenu', {\n        open: function() {\n          if ($target.is(':hidden')) {\n            _this.down($target);\n            $target.find('li').first().find('a').first().focus();\n          }\n        },\n        close: function() {\n          if ($target.length && !$target.is(':hidden')) { // close active sub of this item\n            _this.up($target);\n          } else if ($element.parent('[data-submenu]').length) { // close currently open sub\n            _this.up($element.parent('[data-submenu]'));\n            $element.parents('li').first().find('a').first().focus();\n          }\n        },\n        up: function() {\n          $prevElement.focus();\n          return true;\n        },\n        down: function() {\n          $nextElement.focus();\n          return true;\n        },\n        toggle: function() {\n          if (_this.options.submenuToggle) {\n            return false;\n          }\n          if ($element.children('[data-submenu]').length) {\n            _this.toggle($element.children('[data-submenu]'));\n            return true;\n          }\n        },\n        closeAll: function() {\n          _this.hideAll();\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    });//.attr('tabindex', 0);\n  }\n\n  /**\n   * Closes all panes of the menu.\n   * @function\n   */\n  hideAll() {\n    this.up(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Opens all panes of the menu.\n   * @function\n   */\n  showAll() {\n    this.down(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Toggles the open/close state of a submenu.\n   * @function\n   * @param {jQuery} $target - the submenu to toggle\n   */\n  toggle($target){\n    if(!$target.is(':animated')) {\n      if (!$target.is(':hidden')) {\n        this.up($target);\n      }\n      else {\n        this.down($target);\n      }\n    }\n  }\n\n  /**\n   * Opens the sub-menu defined by `$target`.\n   * @param {jQuery} $target - Sub-menu to open.\n   * @fires AccordionMenu#down\n   */\n  down($target) {\n    // If having multiple submenus active is disabled, close all the submenus\n    // that are not parents or children of the targeted submenu.\n    if (!this.options.multiOpen) {\n      // The \"branch\" of the targetted submenu, from the component root to\n      // the active submenus nested in it.\n      const $targetBranch = $target.parentsUntil(this.$element)\n        .add($target)\n        .add($target.find('.is-active'));\n      // All the active submenus that are not in the branch.\n      const $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);\n\n      this.up($othersActiveSubmenus);\n    }\n\n    $target\n      .addClass('is-active')\n      .attr({ 'aria-hidden': false });\n\n    if(this.options.submenuToggle) {\n      $target.prev('.submenu-toggle').attr({'aria-expanded': true});\n    }\n    else {\n      $target.parent('.is-accordion-submenu-parent').attr({'aria-expanded': true});\n    }\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done opening.\n       * @event AccordionMenu#down\n       */\n      this.$element.trigger('down.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.\n   * @param {jQuery} $target - Sub-menu to close.\n   * @fires AccordionMenu#up\n   */\n  up($target) {\n    const $submenus = $target.find('[data-submenu]');\n    const $allmenus = $target.add($submenus);\n\n    $submenus.slideUp(0);\n    $allmenus\n      .removeClass('is-active')\n      .attr('aria-hidden', true);\n\n    if(this.options.submenuToggle) {\n      $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);\n    }\n    else {\n      $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\n    }\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done collapsing up.\n       * @event AccordionMenu#up\n       */\n      this.$element.trigger('up.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Destroys an instance of accordion menu.\n   * @fires AccordionMenu#destroyed\n   */\n  _destroy() {\n    this.$element.find('[data-submenu]').slideDown(0).css('display', '');\n    this.$element.find('a').off('click.zf.accordionMenu');\n    this.$element.find('[data-is-parent-link]').detach();\n\n    if(this.options.submenuToggle) {\n      this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');\n      this.$element.find('.submenu-toggle').remove();\n    }\n\n    Nest.Burn(this.$element, 'accordion');\n  }\n}\n\nAccordionMenu.defaults = {\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Amount of time to animate the opening of a submenu in ms.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Adds a separate submenu toggle button. This allows the parent item to have a link.\n   * @option\n   * @example true\n   */\n  submenuToggle: false,\n  /**\n   * The text used for the submenu toggle if enabled. This is used for screen readers only.\n   * @option\n   * @example true\n   */\n  submenuToggleText: 'Toggle menu',\n  /**\n   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\nexport {AccordionMenu};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits, transitionend } from './foundation.core.utils';\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Drilldown module.\n * @module foundation.drilldown\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n * @requires foundation.util.box\n */\n\nclass Drilldown extends Plugin {\n  /**\n   * Creates a new instance of a drilldown menu.\n   * @class\n   * @name Drilldown\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);\n    this.className = 'Drilldown'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('Drilldown', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close',\n      'TAB': 'down',\n      'SHIFT_TAB': 'up'\n    });\n  }\n\n  /**\n   * Initializes the drilldown by creating jQuery collections of elements\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'drilldown');\n\n    if(this.options.autoApplyClass) {\n      this.$element.addClass('drilldown');\n    }\n\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': false\n    });\n    this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');\n    this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');\n    this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a');\n\n    // Set the main menu as current by default (unless a submenu is selected)\n    // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu\n    this.$currentMenu = this.$element;\n\n    this.$element.attr('data-mutate', (this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown')));\n\n    this._prepareMenu();\n    this._registerEvents();\n\n    this._keyboardEvents();\n  }\n\n  /**\n   * prepares drilldown menu by setting attributes to links and elements\n   * sets a min height to prevent content jumping\n   * wraps the element if not already wrapped\n   * @private\n   * @function\n   */\n  _prepareMenu() {\n    var _this = this;\n    // if(!this.options.holdOpen){\n    //   this._menuLinkEvents();\n    // }\n    this.$submenuAnchors.each(function(){\n      var $link = $(this);\n      var $sub = $link.parent();\n      if(_this.options.parentLink){\n        $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-drilldown-submenu-item\" role=\"menuitem\"></li>');\n      }\n      $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);\n      $link.children('[data-submenu]')\n          .attr({\n            'aria-hidden': true,\n            'tabindex': 0,\n            'role': 'group'\n          });\n      _this._events($link);\n    });\n    this.$submenus.each(function(){\n      var $menu = $(this),\n          $back = $menu.find('.js-drilldown-back');\n      if(!$back.length){\n        switch (_this.options.backButtonPosition) {\n          case \"bottom\":\n            $menu.append(_this.options.backButton);\n            break;\n          case \"top\":\n            $menu.prepend(_this.options.backButton);\n            break;\n          default:\n            console.error(\"Unsupported backButtonPosition value '\" + _this.options.backButtonPosition + \"'\");\n        }\n      }\n      _this._back($menu);\n    });\n\n    this.$submenus.addClass('invisible');\n    if(!this.options.autoHeight) {\n      this.$submenus.addClass('drilldown-submenu-cover-previous');\n    }\n\n    // create a wrapper on element if it doesn't exist.\n    if(!this.$element.parent().hasClass('is-drilldown')){\n      this.$wrapper = $(this.options.wrapper).addClass('is-drilldown');\n      if(this.options.animateHeight) this.$wrapper.addClass('animate-height');\n      this.$element.wrap(this.$wrapper);\n    }\n    // set wrapper\n    this.$wrapper = this.$element.parent();\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  _resize() {\n    this.$wrapper.css({'max-width': 'none', 'min-height': 'none'});\n    // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  /**\n   * Adds event handlers to elements in the menu.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the current menu item to add handlers to.\n   */\n  _events($elem) {\n    var _this = this;\n\n    $elem.off('click.zf.drilldown')\n    .on('click.zf.drilldown', function(e){\n      if($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')){\n        e.stopImmediatePropagation();\n        e.preventDefault();\n      }\n\n      // if(e.target !== e.currentTarget.firstElementChild){\n      //   return false;\n      // }\n      _this._show($elem.parent('li'));\n\n      if(_this.options.closeOnClick){\n        var $body = $('body');\n        $body.off('.zf.drilldown').on('click.zf.drilldown', function(e){\n          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target)) { return; }\n          e.preventDefault();\n          _this._hideAll();\n          $body.off('.zf.drilldown');\n        });\n      }\n    });\n  }\n\n  /**\n   * Adds event handlers to the menu element.\n   * @function\n   * @private\n   */\n  _registerEvents() {\n    if(this.options.scrollTop){\n      this._bindHandler = this._scrollTop.bind(this);\n      this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown',this._bindHandler);\n    }\n    this.$element.on('mutateme.zf.trigger', this._resize.bind(this));\n  }\n\n  /**\n   * Scroll to Top of Element or data-scroll-top-element\n   * @function\n   * @fires Drilldown#scrollme\n   */\n  _scrollTop() {\n    var _this = this;\n    var $scrollTopElement = _this.options.scrollTopElement!=''?$(_this.options.scrollTopElement):_this.$element,\n        scrollPos = parseInt($scrollTopElement.offset().top+_this.options.scrollTopOffset, 10);\n    $('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing,function(){\n      /**\n        * Fires after the menu has scrolled\n        * @event Drilldown#scrollme\n        */\n      if(this===$('html')[0])_this.$element.trigger('scrollme.zf.drilldown');\n    });\n  }\n\n  /**\n   * Adds keydown event listener to `li`'s in the menu.\n   * @private\n   */\n  _keyboardEvents() {\n    var _this = this;\n\n    this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function(e){\n      var $element = $(this),\n          $elements = $element.parent('li').parent('ul').children('li').children('a'),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1));\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'Drilldown', {\n        next: function() {\n          if ($element.is(_this.$submenuAnchors)) {\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        previous: function() {\n          _this._hide($element.parent('li').parent('ul'));\n          $element.parent('li').parent('ul').one(transitionend($element), function(){\n            setTimeout(function() {\n              $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n            }, 1);\n          });\n          return true;\n        },\n        up: function() {\n          $prevElement.focus();\n          // Don't tap focus on first element in root ul\n          return !$element.is(_this.$element.find('> li:first-child > a'));\n        },\n        down: function() {\n          $nextElement.focus();\n          // Don't tap focus on last element in root ul\n          return !$element.is(_this.$element.find('> li:last-child > a'));\n        },\n        close: function() {\n          // Don't close on element in root ul\n          if (!$element.is(_this.$element.find('> li > a'))) {\n            _this._hide($element.parent().parent());\n            $element.parent().parent().siblings('a').focus();\n          }\n        },\n        open: function() {\n          if (_this.options.parentLink && $element.attr('href')) { // Link with href\n            return false;\n          } else if (!$element.is(_this.$menuItems)) { // not menu item means back button\n            _this._hide($element.parent('li').parent('ul'));\n            $element.parent('li').parent('ul').one(transitionend($element), function(){\n              setTimeout(function() {\n                $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n              }, 1);\n            });\n            return true;\n          } else if ($element.is(_this.$submenuAnchors)) { // Sub menu item\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    }); // end keyboardAccess\n  }\n\n  /**\n   * Closes all open elements, and returns to root menu.\n   * @function\n   * @fires Drilldown#closed\n   */\n  _hideAll() {\n    var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    $elem.one(transitionend($elem), function(e){\n      $elem.removeClass('is-active is-closing');\n    });\n        /**\n         * Fires when the menu is fully closed.\n         * @event Drilldown#closed\n         */\n    this.$element.trigger('closed.zf.drilldown');\n  }\n\n  /**\n   * Adds event listener for each `back` button, and closes open menus.\n   * @function\n   * @fires Drilldown#back\n   * @param {jQuery} $elem - the current sub-menu to add `back` event.\n   */\n  _back($elem) {\n    var _this = this;\n    $elem.off('click.zf.drilldown');\n    $elem.children('.js-drilldown-back')\n      .on('click.zf.drilldown', function(e){\n        e.stopImmediatePropagation();\n        // console.log('mouseup on back');\n        _this._hide($elem);\n\n        // If there is a parent submenu, call show\n        let parentSubMenu = $elem.parent('li').parent('ul').parent('li');\n        if (parentSubMenu.length) {\n          _this._show(parentSubMenu);\n        }\n      });\n  }\n\n  /**\n   * Adds event listener to menu items w/o submenus to close open menus on click.\n   * @function\n   * @private\n   */\n  _menuLinkEvents() {\n    var _this = this;\n    this.$menuItems.not('.is-drilldown-submenu-parent')\n        .off('click.zf.drilldown')\n        .on('click.zf.drilldown', function(e){\n          // e.stopImmediatePropagation();\n          setTimeout(function(){\n            _this._hideAll();\n          }, 0);\n      });\n  }\n\n  /**\n   * Sets the CSS classes for submenu to show it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setShowSubMenuClasses($elem, trigger) {\n    $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    $elem.parent('li').attr('aria-expanded', true);\n    if (trigger === true) {\n      this.$element.trigger('open.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Sets the CSS classes for submenu to hide it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setHideSubMenuClasses($elem, trigger) {\n    $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);\n    $elem.parent('li').attr('aria-expanded', false);\n    if (trigger === true) {\n      $elem.trigger('hide.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.\n   * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the target (sub)menu (`ul` tag)\n   * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused\n   */\n  _showMenu($elem, autoFocus) {\n\n    var _this = this;\n\n    // Reset drilldown\n    var $expandedSubmenus = this.$element.find('li[aria-expanded=\"true\"] > ul[data-submenu]');\n    $expandedSubmenus.each(function(index) {\n      _this._setHideSubMenuClasses($(this));\n    });\n\n    // Save the menu as the currently displayed one.\n    this.$currentMenu = $elem;\n\n    // If target menu is root, focus first link & exit\n    if ($elem.is('[data-drilldown]')) {\n      if (autoFocus === true) $elem.find('li[role=\"treeitem\"] > a').first().focus();\n      if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));\n      return;\n    }\n\n    // Find all submenus on way to root incl. the element itself\n    var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]');\n\n    // Open target menu and all submenus on its way to root\n    $submenus.each(function(index) {\n\n      // Update height of first child (target menu) if autoHeight option true\n      if (index === 0 && _this.options.autoHeight) {\n        _this.$wrapper.css('height', $(this).data('calcHeight'));\n      }\n\n      var isLastChild = index == $submenus.length - 1;\n\n      // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link\n      // Last child makes sure the event gets always triggered even if going through several menus\n      if (isLastChild === true) {\n        $(this).one(transitionend($(this)), () => {\n          if (autoFocus === true) {\n            $elem.find('li[role=\"treeitem\"] > a').first().focus();\n          }\n        });\n      }\n\n      _this._setShowSubMenuClasses($(this), isLastChild);\n    });\n  }\n\n  /**\n   * Opens a submenu.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.\n   */\n  _show($elem) {\n    const $submenu = $elem.children('[data-submenu]');\n\n    $elem.attr('aria-expanded', true);\n\n    this.$currentMenu = $submenu;\n    $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    if (this.options.autoHeight) {\n      this.$wrapper.css({ height: $submenu.data('calcHeight') });\n    }\n\n    /**\n     * Fires when the submenu has opened.\n     * @event Drilldown#open\n     */\n    this.$element.trigger('open.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Hides a submenu\n   * @function\n   * @fires Drilldown#hide\n   * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.\n   */\n  _hide($elem) {\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    var _this = this;\n    $elem.parent('li').attr('aria-expanded', false);\n    $elem.attr('aria-hidden', true);\n    $elem.addClass('is-closing')\n         .one(transitionend($elem), function(){\n           $elem.removeClass('is-active is-closing');\n           $elem.blur().addClass('invisible');\n         });\n    /**\n     * Fires when the submenu has closed.\n     * @event Drilldown#hide\n     */\n    $elem.trigger('hide.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Iterates through the nested menus to calculate the min-height, and max-width for the menu.\n   * Prevents content jumping.\n   * @function\n   * @private\n   */\n  _getMaxDims() {\n    var maxHeight = 0, result = {}, _this = this;\n\n    // Recalculate menu heights and total max height\n    this.$submenus.add(this.$element).each(function(){\n      var numOfElems = $(this).children('li').length;\n      var height = Box.GetDimensions(this).height;\n\n      maxHeight = height > maxHeight ? height : maxHeight;\n\n      if(_this.options.autoHeight) {\n        $(this).data('calcHeight',height);\n      }\n    });\n\n    if (this.options.autoHeight)\n      result['height'] = this.$currentMenu.data('calcHeight');\n    else\n      result['min-height'] = `${maxHeight}px`;\n\n    result['max-width'] = `${this.$element[0].getBoundingClientRect().width}px`;\n\n    return result;\n  }\n\n  /**\n   * Destroys the Drilldown Menu\n   * @function\n   */\n  _destroy() {\n    if(this.options.scrollTop) this.$element.off('.zf.drilldown',this._bindHandler);\n    this._hideAll();\n\t  this.$element.off('mutateme.zf.trigger');\n    Nest.Burn(this.$element, 'drilldown');\n    this.$element.unwrap()\n                 .find('.js-drilldown-back, .is-submenu-parent-item').remove()\n                 .end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu')\n                 .end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');\n    this.$submenuAnchors.each(function() {\n      $(this).off('.zf.drilldown');\n    });\n\n    this.$element.find('[data-is-parent-link]').detach();\n    this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');\n\n    this.$element.find('a').each(function(){\n      var $link = $(this);\n      $link.removeAttr('tabindex');\n      if($link.data('savedHref')){\n        $link.attr('href', $link.data('savedHref')).removeData('savedHref');\n      }else{ return; }\n    });\n  };\n}\n\nDrilldown.defaults = {\n  /**\n   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are\n   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.\n   * @option\n   * @type {boolian}\n   * @default true\n   */\n  autoApplyClass: true,\n  /**\n   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>'\n   */\n  backButton: '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>',\n  /**\n   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default top\n   */\n  backButtonPosition: 'top',\n  /**\n   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<div></div>'\n   */\n  wrapper: '<div></div>',\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Allow the menu to return to root list on body click.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false,\n  /**\n   * Allow the menu to auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoHeight: false,\n  /**\n   * Animate the auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animateHeight: false,\n  /**\n   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  scrollTop: false,\n  /**\n   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  scrollTopElement: '',\n  /**\n   * ScrollTop offset\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  scrollTopOffset: 0,\n  /**\n   * Scroll animation duration\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Scroll animation easing. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @see {@link https://api.jquery.com/animate|JQuery animate}\n   * @default 'swing'\n   */\n  animationEasing: 'swing'\n  // holdOpen: false\n};\n\nexport {Drilldown};\n","'use strict';\n\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst POSITIONS = ['left', 'right', 'top', 'bottom'];\nconst VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nconst HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\n\nconst ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n}\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n  if(currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\n\nclass Positionable extends Plugin {\n  /**\n   * Abstract class encapsulating the tether-like explicit positioning logic\n   * including repositioning based on overlap.\n   * Expects classes to define defaults for vOffset, hOffset, position,\n   * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n   * extending the defaults, or (for now recommended due to the way docs are\n   * generated) by explicitly declaring them.\n   *\n   **/\n\n  _init() {\n    this.triedPositions = {};\n    this.position  = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n    this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n    this.originalPosition = this.position;\n    this.originalAlignment = this.alignment;\n  }\n\n  _getDefaultPosition () {\n    return 'bottom';\n  }\n\n  _getDefaultAlignment() {\n    switch(this.position) {\n      case 'bottom':\n      case 'top':\n        return Rtl() ? 'right' : 'left';\n      case 'left':\n      case 'right':\n        return 'bottom';\n    }\n  }\n\n  /**\n   * Adjusts the positionable possible positions by iterating through alignments\n   * and positions.\n   * @function\n   * @private\n   */\n  _reposition() {\n    if(this._alignmentsExhausted(this.position)) {\n      this.position = nextItem(this.position, POSITIONS);\n      this.alignment = ALIGNMENTS[this.position][0];\n    } else {\n      this._realign();\n    }\n  }\n\n  /**\n   * Adjusts the dropdown pane possible positions by iterating through alignments\n   * on the current position.\n   * @function\n   * @private\n   */\n  _realign() {\n    this._addTriedPosition(this.position, this.alignment)\n    this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position])\n  }\n\n  _addTriedPosition(position, alignment) {\n    this.triedPositions[position] = this.triedPositions[position] || []\n    this.triedPositions[position].push(alignment);\n  }\n\n  _positionsExhausted() {\n    var isExhausted = true;\n    for(var i = 0; i < POSITIONS.length; i++) {\n      isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n    }\n    return isExhausted;\n  }\n\n  _alignmentsExhausted(position) {\n    return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n  }\n\n\n  // When we're trying to center, we don't want to apply offset that's going to\n  // take us just off center, so wrap around to return 0 for the appropriate\n  // offset in those alignments.  TODO: Figure out if we want to make this\n  // configurable behavior... it feels more intuitive, especially for tooltips, but\n  // it's possible someone might actually want to start from center and then nudge\n  // slightly off.\n  _getVOffset() {\n    return this.options.vOffset;\n  }\n\n  _getHOffset() {\n    return this.options.hOffset;\n  }\n\n\n  _setPosition($anchor, $element, $parent) {\n    if($anchor.attr('aria-expanded') === 'false'){ return false; }\n    var $eleDims = Box.GetDimensions($element),\n        $anchorDims = Box.GetDimensions($anchor);\n\n\n    if (!this.options.allowOverlap) {\n      // restore original position & alignment before checking overlap\n      this.position = this.originalPosition;\n      this.alignment = this.originalAlignment;\n    }\n\n    $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n    if(!this.options.allowOverlap) {\n      var overlaps = {};\n      var minOverlap = 100000000;\n      // default coordinates to how we start, in case we can't figure out better\n      var minCoordinates = {position: this.position, alignment: this.alignment};\n      while(!this._positionsExhausted()) {\n        let overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n        if(overlap === 0) {\n          return;\n        }\n\n        if(overlap < minOverlap) {\n          minOverlap = overlap;\n          minCoordinates = {position: this.position, alignment: this.alignment};\n        }\n\n        this._reposition();\n\n        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n      // If we get through the entire loop, there was no non-overlapping\n      // position available. Pick the version with least overlap.\n      this.position = minCoordinates.position;\n      this.alignment = minCoordinates.alignment;\n      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n    }\n  }\n\n}\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n}\n\nexport {Positionable};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { Positionable } from './foundation.positionable';\n\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Dropdown module.\n * @module foundation.dropdown\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.triggers\n */\nclass Dropdown extends Positionable {\n  /**\n   * Creates a new instance of a dropdown.\n   * @class\n   * @name Dropdown\n   * @param {jQuery} element - jQuery object to make into a dropdown.\n   *        Object should be of the dropdown panel, rather than its anchor.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);\n    this.className = 'Dropdown'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Dropdown', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.\n   * @function\n   * @private\n   */\n  _init() {\n    var $id = this.$element.attr('id');\n\n    this.$anchors = $(`[data-toggle=\"${$id}\"]`).length ? $(`[data-toggle=\"${$id}\"]`) : $(`[data-open=\"${$id}\"]`);\n    this.$anchors.attr({\n      'aria-controls': $id,\n      'data-is-focus': false,\n      'data-yeti-box': $id,\n      'aria-haspopup': true,\n      'aria-expanded': false\n    });\n\n    this._setCurrentAnchor(this.$anchors.first());\n\n    if(this.options.parentClass){\n      this.$parent = this.$element.parents('.' + this.options.parentClass);\n    }else{\n      this.$parent = null;\n    }\n\n    // Set [aria-labelledby] on the Dropdown if it is not set\n    if (typeof this.$element.attr('aria-labelledby') === 'undefined') {\n      // Get the anchor ID or create one\n      if (typeof this.$currentAnchor.attr('id') === 'undefined') {\n        this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));\n      };\n\n      this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));\n    }\n\n    this.$element.attr({\n      'aria-hidden': 'true',\n      'data-yeti-box': $id,\n      'data-resize': $id,\n    });\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/(top|left|right|bottom)/g);\n    if(position) {\n      return position[0];\n    } else {\n      return 'bottom'\n    }\n  }\n\n  _getDefaultAlignment() {\n    // handle legacy float approach\n    var horizontalPosition = /float-(\\S+)/.exec(this.$currentAnchor.attr('class'));\n    if(horizontalPosition) {\n      return horizontalPosition[1];\n    }\n\n    return super._getDefaultAlignment();\n  }\n\n\n\n  /**\n   * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.\n   * Recursively calls itself if a collision is detected, with a new position class.\n   * @function\n   * @private\n   */\n  _setPosition() {\n    this.$element.removeClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n    super._setPosition(this.$currentAnchor, this.$element, this.$parent);\n    this.$element.addClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n  }\n\n  /**\n   * Make it a current anchor.\n   * Current anchor as the reference for the position of Dropdown panes.\n   * @param {HTML} el - DOM element of the anchor.\n   * @function\n   * @private\n   */\n  _setCurrentAnchor(el) {\n    this.$currentAnchor = $(el);\n  }\n\n  /**\n   * Adds event listeners to the element utilizing the triggers utility library.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': this._setPosition.bind(this)\n    });\n\n    this.$anchors.off('click.zf.trigger')\n      .on('click.zf.trigger', function() { _this._setCurrentAnchor(this); });\n\n    if(this.options.hover){\n      this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n      .on('mouseenter.zf.dropdown', function(){\n        _this._setCurrentAnchor(this);\n\n        var bodyData = $('body').data();\n        if(typeof(bodyData.whatinput) === 'undefined' || bodyData.whatinput === 'mouse') {\n          clearTimeout(_this.timeout);\n          _this.timeout = setTimeout(function(){\n            _this.open();\n            _this.$anchors.data('hover', true);\n          }, _this.options.hoverDelay);\n        }\n      }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n        clearTimeout(_this.timeout);\n        _this.timeout = setTimeout(function(){\n          _this.close();\n          _this.$anchors.data('hover', false);\n        }, _this.options.hoverDelay);\n      }));\n      if(this.options.hoverPane){\n        this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n            .on('mouseenter.zf.dropdown', function(){\n              clearTimeout(_this.timeout);\n            }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n              clearTimeout(_this.timeout);\n              _this.timeout = setTimeout(function(){\n                _this.close();\n                _this.$anchors.data('hover', false);\n              }, _this.options.hoverDelay);\n            }));\n      }\n    }\n    this.$anchors.add(this.$element).on('keydown.zf.dropdown', function(e) {\n\n      var $target = $(this),\n        visibleFocusableElements = Keyboard.findFocusable(_this.$element);\n\n      Keyboard.handleKey(e, 'Dropdown', {\n        open: function() {\n          if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {\n            _this.open();\n            _this.$element.attr('tabindex', -1).focus();\n            e.preventDefault();\n          }\n        },\n        close: function() {\n          _this.close();\n          _this.$anchors.focus();\n        }\n      });\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n     var $body = $(document.body).not(this.$element),\n         _this = this;\n     $body.off('click.zf.dropdown')\n          .on('click.zf.dropdown', function(e){\n            if(_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {\n              return;\n            }\n            if(_this.$element.is(e.target) || _this.$element.find(e.target).length) {\n              return;\n            }\n            _this.close();\n            $body.off('click.zf.dropdown');\n          });\n  }\n\n  /**\n   * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.\n   * @function\n   * @fires Dropdown#closeme\n   * @fires Dropdown#show\n   */\n  open() {\n    // var _this = this;\n    /**\n     * Fires to close other open dropdowns, typically when dropdown is opening\n     * @event Dropdown#closeme\n     */\n    this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));\n    this.$anchors.addClass('hover')\n        .attr({'aria-expanded': true});\n    // this.$element/*.show()*/;\n\n    this.$element.addClass('is-opening');\n    this._setPosition();\n    this.$element.removeClass('is-opening').addClass('is-open')\n        .attr({'aria-hidden': false});\n\n    if(this.options.autoFocus){\n      var $focusable = Keyboard.findFocusable(this.$element);\n      if($focusable.length){\n        $focusable.eq(0).focus();\n      }\n    }\n\n    if(this.options.closeOnClick){ this._addBodyHandler(); }\n\n    if (this.options.trapFocus) {\n      Keyboard.trapFocus(this.$element);\n    }\n\n    /**\n     * Fires once the dropdown is visible.\n     * @event Dropdown#show\n     */\n    this.$element.trigger('show.zf.dropdown', [this.$element]);\n  }\n\n  /**\n   * Closes the open dropdown pane.\n   * @function\n   * @fires Dropdown#hide\n   */\n  close() {\n    if(!this.$element.hasClass('is-open')){\n      return false;\n    }\n    this.$element.removeClass('is-open')\n        .attr({'aria-hidden': true});\n\n    this.$anchors.removeClass('hover')\n        .attr('aria-expanded', false);\n\n    /**\n     * Fires once the dropdown is no longer visible.\n     * @event Dropdown#hide\n     */\n    this.$element.trigger('hide.zf.dropdown', [this.$element]);\n\n    if (this.options.trapFocus) {\n      Keyboard.releaseFocus(this.$element);\n    }\n  }\n\n  /**\n   * Toggles the dropdown pane's visibility.\n   * @function\n   */\n  toggle() {\n    if(this.$element.hasClass('is-open')){\n      if(this.$anchors.data('hover')) return;\n      this.close();\n    }else{\n      this.open();\n    }\n  }\n\n  /**\n   * Destroys the dropdown.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger').hide();\n    this.$anchors.off('.zf.dropdown');\n    $(document.body).off('click.zf.dropdown');\n\n  }\n}\n\nDropdown.defaults = {\n  /**\n   * Class that designates bounding container of Dropdown (default: window)\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  parentClass: null,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  hoverDelay: 250,\n  /**\n   * Allow submenus to open on hover events\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hover: false,\n  /**\n   * Don't close dropdown when hovering over dropdown pane\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hoverPane: false,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Position of dropdown. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false,\n  /**\n   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n  /**\n   * Allows a click on the body to close the dropdown.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false\n};\n\nexport {Dropdown};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl, ignoreMousedisappear } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { Box } from './foundation.util.box';\n\n/**\n * DropdownMenu module.\n * @module foundation.dropdown-menu\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.nest\n */\n\nclass DropdownMenu extends Plugin {\n  /**\n   * Creates a new instance of DropdownMenu.\n   * @class\n   * @name DropdownMenu\n   * @fires DropdownMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n    this.className = 'DropdownMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('DropdownMenu', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin, and calls _prepareMenu\n   * @private\n   * @function\n   */\n  _init() {\n    Nest.Feather(this.$element, 'dropdown');\n\n    var subs = this.$element.find('li.is-dropdown-submenu-parent');\n    this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');\n\n    this.$menuItems = this.$element.find('[role=\"menuitem\"]');\n    this.$tabs = this.$element.children('[role=\"menuitem\"]');\n    this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);\n\n    if (this.options.alignment === 'auto') {\n        if (this.$element.hasClass(this.options.rightClass) || Rtl() || this.$element.parents('.top-bar-right').is('*')) {\n            this.options.alignment = 'right';\n            subs.addClass('opens-left');\n        } else {\n            this.options.alignment = 'left';\n            subs.addClass('opens-right');\n        }\n    } else {\n      if (this.options.alignment === 'right') {\n          subs.addClass('opens-left');\n      } else {\n          subs.addClass('opens-right');\n      }\n    }\n    this.changed = false;\n    this._events();\n  };\n\n  _isVertical() {\n    return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';\n  }\n\n  _isRtl() {\n    return this.$element.hasClass('align-right') || (Rtl() && !this.$element.hasClass('align-left'));\n  }\n\n  /**\n   * Adds event listeners to elements within the menu\n   * @private\n   * @function\n   */\n  _events() {\n    var _this = this,\n        hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined'),\n        parClass = 'is-dropdown-submenu-parent';\n\n    // used for onClick and in the keyboard handlers\n    var handleClickFn = function(e) {\n      var $elem = $(e.target).parentsUntil('ul', `.${parClass}`),\n          hasSub = $elem.hasClass(parClass),\n          hasClicked = $elem.attr('data-is-click') === 'true',\n          $sub = $elem.children('.is-dropdown-submenu');\n\n      if (hasSub) {\n        if (hasClicked) {\n          if (!_this.options.closeOnClick || (!_this.options.clickOpen && !hasTouch) || (_this.options.forceFollow && hasTouch)) { return; }\n          else {\n            e.stopImmediatePropagation();\n            e.preventDefault();\n            _this._hide($elem);\n          }\n        } else {\n          e.preventDefault();\n          e.stopImmediatePropagation();\n          _this._show($sub);\n          $elem.add($elem.parentsUntil(_this.$element, `.${parClass}`)).attr('data-is-click', true);\n        }\n      }\n    };\n\n    if (this.options.clickOpen || hasTouch) {\n      this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);\n    }\n\n    // Handle Leaf element Clicks\n    if(_this.options.closeOnClickInside){\n      this.$menuItems.on('click.zf.dropdownmenu', function(e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if(!hasSub){\n          _this._hide();\n        }\n      });\n    }\n\n    if (!this.options.disableHover) {\n      this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {\n        var $elem = $(this),\n          hasSub = $elem.hasClass(parClass);\n\n        if (hasSub) {\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._show($elem.children('.is-dropdown-submenu'));\n          }, _this.options.hoverDelay));\n        }\n      }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if (hasSub && _this.options.autoclose) {\n          if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { return false; }\n\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._hide($elem);\n          }, _this.options.closingTime));\n        }\n      }));\n    }\n    this.$menuItems.on('keydown.zf.dropdownmenu', function(e) {\n      var $element = $(e.target).parentsUntil('ul', '[role=\"menuitem\"]'),\n          isTab = _this.$tabs.index($element) > -1,\n          $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(i-1);\n          $nextElement = $elements.eq(i+1);\n          return;\n        }\n      });\n\n      var nextSibling = function() {\n        $nextElement.children('a:first').focus();\n        e.preventDefault();\n      }, prevSibling = function() {\n        $prevElement.children('a:first').focus();\n        e.preventDefault();\n      }, openSub = function() {\n        var $sub = $element.children('ul.is-dropdown-submenu');\n        if ($sub.length) {\n          _this._show($sub);\n          $element.find('li > a:first').focus();\n          e.preventDefault();\n        } else { return; }\n      }, closeSub = function() {\n        //if ($element.is(':first-child')) {\n        var close = $element.parent('ul').parent('li');\n        close.children('a:first').focus();\n        _this._hide(close);\n        e.preventDefault();\n        //}\n      };\n      var functions = {\n        open: openSub,\n        close: function() {\n          _this._hide(_this.$element);\n          _this.$menuItems.eq(0).children('a').focus(); // focus to first element\n          e.preventDefault();\n        },\n        handled: function() {\n          e.stopImmediatePropagation();\n        }\n      };\n\n      if (isTab) {\n        if (_this._isVertical()) { // vertical menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: closeSub,\n              previous: openSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: openSub,\n              previous: closeSub\n            });\n          }\n        } else { // horizontal menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              next: prevSibling,\n              previous: nextSibling,\n              down: openSub,\n              up: closeSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              next: nextSibling,\n              previous: prevSibling,\n              down: openSub,\n              up: closeSub\n            });\n          }\n        }\n      } else { // not tabs -> one sub\n        if (_this._isRtl()) { // right aligned\n          $.extend(functions, {\n            next: closeSub,\n            previous: openSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        } else { // left aligned\n          $.extend(functions, {\n            next: openSub,\n            previous: closeSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        }\n      }\n      Keyboard.handleKey(e, 'DropdownMenu', functions);\n\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n    var $body = $(document.body),\n        _this = this;\n    $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu')\n         .on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function(e) {\n           var $link = _this.$element.find(e.target);\n           if ($link.length) { return; }\n\n           _this._hide();\n           $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');\n         });\n  }\n\n  /**\n   * Opens a dropdown pane, and checks for collisions first.\n   * @param {jQuery} $sub - ul element that is a submenu to show\n   * @function\n   * @private\n   * @fires Dropdownmenu#show\n   */\n  _show($sub) {\n    var idx = this.$tabs.index(this.$tabs.filter(function(i, el) {\n      return $(el).find($sub).length > 0;\n    }));\n    var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');\n    this._hide($sibs, idx);\n    $sub.css('visibility', 'hidden').addClass('js-dropdown-active')\n        .parent('li.is-dropdown-submenu-parent').addClass('is-active');\n    var clear = Box.ImNotTouchingYou($sub, null, true);\n    if (!clear) {\n      var oldClass = this.options.alignment === 'left' ? '-right' : '-left',\n          $parentLi = $sub.parent('.is-dropdown-submenu-parent');\n      $parentLi.removeClass(`opens${oldClass}`).addClass(`opens-${this.options.alignment}`);\n      clear = Box.ImNotTouchingYou($sub, null, true);\n      if (!clear) {\n        $parentLi.removeClass(`opens-${this.options.alignment}`).addClass('opens-inner');\n      }\n      this.changed = true;\n    }\n    $sub.css('visibility', '');\n    if (this.options.closeOnClick) { this._addBodyHandler(); }\n    /**\n     * Fires when the new dropdown pane is visible.\n     * @event Dropdownmenu#show\n     */\n    this.$element.trigger('show.zf.dropdownmenu', [$sub]);\n  }\n\n  /**\n   * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.\n   * @function\n   * @param {jQuery} $elem - element with a submenu to hide\n   * @param {Number} idx - index of the $tabs collection to hide\n   * @private\n   */\n  _hide($elem, idx) {\n    var $toClose;\n    if ($elem && $elem.length) {\n      $toClose = $elem;\n    } else if (typeof idx !== 'undefined') {\n      $toClose = this.$tabs.not(function(i, el) {\n        return i === idx;\n      });\n    }\n    else {\n      $toClose = this.$element;\n    }\n    var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;\n\n    if (somethingToClose) {\n      $toClose.find('li.is-active').add($toClose).attr({\n        'data-is-click': false\n      }).removeClass('is-active');\n\n      $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');\n\n      if (this.changed || $toClose.find('opens-inner').length) {\n        var oldClass = this.options.alignment === 'left' ? 'right' : 'left';\n        $toClose.find('li.is-dropdown-submenu-parent').add($toClose)\n                .removeClass(`opens-inner opens-${this.options.alignment}`)\n                .addClass(`opens-${oldClass}`);\n        this.changed = false;\n      }\n      /**\n       * Fires when the open menus are closed.\n       * @event Dropdownmenu#hide\n       */\n      this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);\n    }\n  }\n\n  /**\n   * Destroys the plugin.\n   * @function\n   */\n  _destroy() {\n    this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click')\n        .removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');\n    $(document.body).off('.zf.dropdownmenu');\n    Nest.Burn(this.$element, 'dropdown');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nDropdownMenu.defaults = {\n  /**\n   * Disallows hover events from opening submenus\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoclose: true,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  hoverDelay: 50,\n  /**\n   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  clickOpen: false,\n  /**\n   * Amount of time to delay closing a submenu on a mouseleave event.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n\n  closingTime: 500,\n  /**\n   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow clicks on the body to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allow clicks on leaf anchor links to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClickInside: true,\n  /**\n   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'vertical'\n   */\n  verticalClass: 'vertical',\n  /**\n   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'align-right'\n   */\n  rightClass: 'align-right',\n  /**\n   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  forceFollow: true\n};\n\nexport {DropdownMenu};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.imageLoader if equalizer contains images\n */\n\nclass Equalizer extends Plugin {\n  /**\n   * Creates a new instance of Equalizer.\n   * @class\n   * @name Equalizer\n   * @fires Equalizer#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options){\n    this.$element = element;\n    this.options  = $.extend({}, Equalizer.defaults, this.$element.data(), options);\n    this.className = 'Equalizer'; // ie9 back compat\n\n    this._init();\n  }\n\n  /**\n   * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var eqId = this.$element.attr('data-equalizer') || '';\n    var $watched = this.$element.find(`[data-equalizer-watch=\"${eqId}\"]`);\n\n    MediaQuery._init();\n\n    this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n    this.$element.attr('data-resize', (eqId || GetYoDigits(6, 'eq')));\n    this.$element.attr('data-mutate', (eqId || GetYoDigits(6, 'eq')));\n\n    this.hasNested = this.$element.find('[data-equalizer]').length > 0;\n    this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;\n    this.isOn = false;\n    this._bindHandler = {\n      onResizeMeBound: this._onResizeMe.bind(this),\n      onPostEqualizedBound: this._onPostEqualized.bind(this)\n    };\n\n    var imgs = this.$element.find('img');\n    var tooSmall;\n    if(this.options.equalizeOn){\n      tooSmall = this._checkMQ();\n      $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));\n    }else{\n      this._events();\n    }\n    if((typeof tooSmall !== 'undefined' && tooSmall === false) || typeof tooSmall === 'undefined'){\n      if(imgs.length){\n        onImagesLoaded(imgs, this._reflow.bind(this));\n      }else{\n        this._reflow();\n      }\n    }\n  }\n\n  /**\n   * Removes event listeners if the breakpoint is too small.\n   * @private\n   */\n  _pauseEvents() {\n    this.isOn = false;\n    this.$element.off({\n      '.zf.equalizer': this._bindHandler.onPostEqualizedBound,\n      'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,\n\t  'mutateme.zf.trigger': this._bindHandler.onResizeMeBound\n    });\n  }\n\n  /**\n   * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound\n   * @private\n   */\n  _onResizeMe(e) {\n    this._reflow();\n  }\n\n  /**\n   * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound\n   * @private\n   */\n  _onPostEqualized(e) {\n    if(e.target !== this.$element[0]){ this._reflow(); }\n  }\n\n  /**\n   * Initializes events for Equalizer.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this._pauseEvents();\n    if(this.hasNested){\n      this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);\n    }else{\n      this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);\n\t  this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);\n    }\n    this.isOn = true;\n  }\n\n  /**\n   * Checks the current breakpoint to the minimum required size.\n   * @private\n   */\n  _checkMQ() {\n    var tooSmall = !MediaQuery.is(this.options.equalizeOn);\n    if(tooSmall){\n      if(this.isOn){\n        this._pauseEvents();\n        this.$watched.css('height', 'auto');\n      }\n    }else{\n      if(!this.isOn){\n        this._events();\n      }\n    }\n    return tooSmall;\n  }\n\n  /**\n   * A noop version for the plugin\n   * @private\n   */\n  _killswitch() {\n    return;\n  }\n\n  /**\n   * Calls necessary functions to update Equalizer upon DOM change\n   * @private\n   */\n  _reflow() {\n    if(!this.options.equalizeOnStack){\n      if(this._isStacked()){\n        this.$watched.css('height', 'auto');\n        return false;\n      }\n    }\n    if (this.options.equalizeByRow) {\n      this.getHeightsByRow(this.applyHeightByRow.bind(this));\n    }else{\n      this.getHeights(this.applyHeight.bind(this));\n    }\n  }\n\n  /**\n   * Manually determines if the first 2 elements are *NOT* stacked.\n   * @private\n   */\n  _isStacked() {\n    if (!this.$watched[0] || !this.$watched[1]) {\n      return true;\n    }\n    return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} heights - An array of heights of children within Equalizer container\n   */\n  getHeights(cb) {\n    var heights = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      heights.push(this.$watched[i].offsetHeight);\n    }\n    cb(heights);\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   */\n  getHeightsByRow(cb) {\n    var lastElTopOffset = (this.$watched.length ? this.$watched.first().offset().top : 0),\n        groups = [],\n        group = 0;\n    //group by Row\n    groups[group] = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      //maybe could use this.$watched[i].offsetTop\n      var elOffsetTop = $(this.$watched[i]).offset().top;\n      if (elOffsetTop!=lastElTopOffset) {\n        group++;\n        groups[group] = [];\n        lastElTopOffset=elOffsetTop;\n      }\n      groups[group].push([this.$watched[i],this.$watched[i].offsetHeight]);\n    }\n\n    for (var j = 0, ln = groups.length; j < ln; j++) {\n      var heights = $(groups[j]).map(function(){ return this[1]; }).get();\n      var max         = Math.max.apply(null, heights);\n      groups[j].push(max);\n    }\n    cb(groups);\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest\n   * @param {array} heights - An array of heights of children within Equalizer container\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#postequalized\n   */\n  applyHeight(heights) {\n    var max = Math.max.apply(null, heights);\n    /**\n     * Fires before the heights are applied\n     * @event Equalizer#preequalized\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n\n    this.$watched.css('height', max);\n\n    /**\n     * Fires when the heights have been applied\n     * @event Equalizer#postequalized\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row\n   * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#preequalizedrow\n   * @fires Equalizer#postequalizedrow\n   * @fires Equalizer#postequalized\n   */\n  applyHeightByRow(groups) {\n    /**\n     * Fires before the heights are applied\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n    for (var i = 0, len = groups.length; i < len ; i++) {\n      var groupsILength = groups[i].length,\n          max = groups[i][groupsILength - 1];\n      if (groupsILength<=2) {\n        $(groups[i][0][0]).css({'height':'auto'});\n        continue;\n      }\n      /**\n        * Fires before the heights per row are applied\n        * @event Equalizer#preequalizedrow\n        */\n      this.$element.trigger('preequalizedrow.zf.equalizer');\n      for (var j = 0, lenJ = (groupsILength-1); j < lenJ ; j++) {\n        $(groups[i][j][0]).css({'height':max});\n      }\n      /**\n        * Fires when the heights per row have been applied\n        * @event Equalizer#postequalizedrow\n        */\n      this.$element.trigger('postequalizedrow.zf.equalizer');\n    }\n    /**\n     * Fires when the heights have been applied\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Destroys an instance of Equalizer.\n   * @function\n   */\n  _destroy() {\n    this._pauseEvents();\n    this.$watched.css('height', 'auto');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nEqualizer.defaults = {\n  /**\n   * Enable height equalization when stacked on smaller screens.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeOnStack: false,\n  /**\n   * Enable height equalization row by row.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeByRow: false,\n  /**\n   * String representing the minimum breakpoint size the plugin should equalize heights on.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  equalizeOn: ''\n};\n\nexport {Equalizer};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n */\n\nclass Interchange extends Plugin {\n  /**\n   * Creates a new instance of Interchange.\n   * @class\n   * @name Interchange\n   * @fires Interchange#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Interchange.defaults, options);\n    this.rules = [];\n    this.currentPath = '';\n    this.className = 'Interchange'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Interchange plugin and calls functions to get interchange functioning on load.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var id = this.$element[0].id || GetYoDigits(6, 'interchange');\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    this._addBreakpoints();\n    this._generateRules();\n    this._reflow();\n  }\n\n  /**\n   * Initializes events for Interchange.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', () => this._reflow());\n  }\n\n  /**\n   * Calls necessary functions to update Interchange upon DOM change\n   * @function\n   * @private\n   */\n  _reflow() {\n    var match;\n\n    // Iterate through each rule, but only save the last match\n    for (var i in this.rules) {\n      if(this.rules.hasOwnProperty(i)) {\n        var rule = this.rules[i];\n        if (window.matchMedia(rule.query).matches) {\n          match = rule;\n        }\n      }\n    }\n\n    if (match) {\n      this.replace(match.path);\n    }\n  }\n\n  /**\n   * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.\n   * @function\n   * @private\n   */\n  _addBreakpoints() {\n    for (var i in MediaQuery.queries) {\n      if (MediaQuery.queries.hasOwnProperty(i)) {\n        var query = MediaQuery.queries[i];\n        Interchange.SPECIAL_QUERIES[query.name] = query.value;\n      }\n    }\n  }\n\n  /**\n   * Checks the Interchange element for the provided media query + content pairings\n   * @function\n   * @private\n   * @param {Object} element - jQuery object that is an Interchange instance\n   * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys\n   */\n  _generateRules(element) {\n    var rulesList = [];\n    var rules;\n\n    if (this.options.rules) {\n      rules = this.options.rules;\n    }\n    else {\n      rules = this.$element.data('interchange');\n    }\n\n    rules =  typeof rules === 'string' ? rules.match(/\\[.*?, .*?\\]/g) : rules;\n\n    for (var i in rules) {\n      if(rules.hasOwnProperty(i)) {\n        var rule = rules[i].slice(1, -1).split(', ');\n        var path = rule.slice(0, -1).join('');\n        var query = rule[rule.length - 1];\n\n        if (Interchange.SPECIAL_QUERIES[query]) {\n          query = Interchange.SPECIAL_QUERIES[query];\n        }\n\n        rulesList.push({\n          path: path,\n          query: query\n        });\n      }\n    }\n\n    this.rules = rulesList;\n  }\n\n  /**\n   * Update the `src` property of an image, or change the HTML of a container, to the specified path.\n   * @function\n   * @param {String} path - Path to the image or HTML partial.\n   * @fires Interchange#replaced\n   */\n  replace(path) {\n    if (this.currentPath === path) return;\n\n    var _this = this,\n        trigger = 'replaced.zf.interchange';\n\n    // Replacing images\n    if (this.$element[0].nodeName === 'IMG') {\n      this.$element.attr('src', path).on('load', function() {\n        _this.currentPath = path;\n      })\n      .trigger(trigger);\n    }\n    // Replacing background images\n    else if (path.match(/\\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {\n      path = path.replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n      this.$element.css({ 'background-image': 'url('+path+')' })\n          .trigger(trigger);\n    }\n    // Replacing HTML\n    else {\n      $.get(path, function(response) {\n        _this.$element.html(response)\n             .trigger(trigger);\n        $(response).foundation();\n        _this.currentPath = path;\n      });\n    }\n\n    /**\n     * Fires when content in an Interchange element is done being loaded.\n     * @event Interchange#replaced\n     */\n    // this.$element.trigger('replaced.zf.interchange');\n  }\n\n  /**\n   * Destroys an instance of interchange.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('resizeme.zf.trigger')\n  }\n}\n\n/**\n * Default settings for plugin\n */\nInterchange.defaults = {\n  /**\n   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.\n   * @option\n   * @type {?array}\n   * @default null\n   */\n  rules: null\n};\n\nInterchange.SPECIAL_QUERIES = {\n  'landscape': 'screen and (orientation: landscape)',\n  'portrait': 'screen and (orientation: portrait)',\n  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'\n};\n\nexport {Interchange};\n","import $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * SmoothScroll module.\n * @module foundation.smooth-scroll\n */\nclass SmoothScroll extends Plugin {\n  /**\n   * Creates a new instance of SmoothScroll.\n   * @class\n   * @name SmoothScroll\n   * @fires SmoothScroll#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n    _setup(element, options) {\n        this.$element = element;\n        this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);\n        this.className = 'SmoothScroll'; // ie9 back compat\n\n        this._init();\n    }\n\n    /**\n     * Initialize the SmoothScroll plugin\n     * @private\n     */\n    _init() {\n        const id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');\n        this.$element.attr({ id });\n\n        this._events();\n    }\n\n    /**\n     * Initializes events for SmoothScroll.\n     * @private\n     */\n    _events() {\n        this._linkClickListener = this._handleLinkClick.bind(this);\n        this.$element.on('click.zf.smoothScroll', this._linkClickListener);\n        this.$element.on('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n\n    /**\n     * Handle the given event to smoothly scroll to the anchor pointed by the event target.\n     * @param {*} e - event\n     * @function\n     * @private\n     */\n    _handleLinkClick(e) {\n        // Follow the link if it does not point to an anchor.\n        if (!$(e.currentTarget).is('a[href^=\"#\"]')) return;\n\n        const arrival = e.currentTarget.getAttribute('href');\n\n        this._inTransition = true;\n\n        SmoothScroll.scrollToLoc(arrival, this.options, () => {\n            this._inTransition = false;\n        });\n\n        e.preventDefault();\n    };\n\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'\n     * @param {Object} options - The options to use.\n     * @param {Function} callback - The callback function.\n     * @static\n     * @function\n     */\n    static scrollToLoc(loc, options = SmoothScroll.defaults, callback) {\n        const $loc = $(loc);\n\n        // Do nothing if target does not exist to prevent errors\n        if (!$loc.length) return false;\n\n        var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);\n\n        $('html, body').stop(true).animate(\n            { scrollTop: scrollPos },\n            options.animationDuration,\n            options.animationEasing,\n            () => {\n                if (typeof callback === 'function'){\n                    callback();\n                }\n            }\n        );\n    }\n\n    /**\n     * Destroys the SmoothScroll instance.\n     * @function\n     */\n    _destroy() {\n        this.$element.off('click.zf.smoothScroll', this._linkClickListener)\n        this.$element.off('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n}\n\n/**\n * Default settings for plugin.\n */\nSmoothScroll.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {SmoothScroll}\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { SmoothScroll } from './foundation.smoothScroll';\n\n/**\n * Magellan module.\n * @module foundation.magellan\n * @requires foundation.smoothScroll\n */\n\nclass Magellan extends Plugin {\n  /**\n   * Creates a new instance of Magellan.\n   * @class\n   * @name Magellan\n   * @fires Magellan#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options  = $.extend({}, Magellan.defaults, this.$element.data(), options);\n    this.className = 'Magellan'; // ie9 back compat\n\n    this._init();\n    this.calcPoints();\n  }\n\n  /**\n   * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var id = this.$element[0].id || GetYoDigits(6, 'magellan');\n    var _this = this;\n    this.$targets = $('[data-magellan-target]');\n    this.$links = this.$element.find('a');\n    this.$element.attr({\n      'data-resize': id,\n      'data-scroll': id,\n      'id': id\n    });\n    this.$active = $();\n    this.scrollPos = parseInt(window.pageYOffset, 10);\n\n    this._events();\n  }\n\n  /**\n   * Calculates an array of pixel values that are the demarcation lines between locations on the page.\n   * Can be invoked if new elements are added or the size of a location changes.\n   * @function\n   */\n  calcPoints() {\n    var _this = this,\n        body = document.body,\n        html = document.documentElement;\n\n    this.points = [];\n    this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));\n    this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));\n\n    this.$targets.each(function(){\n      var $tar = $(this),\n          pt = Math.round($tar.offset().top - _this.options.threshold);\n      $tar.targetPoint = pt;\n      _this.points.push(pt);\n    });\n  }\n\n  /**\n   * Initializes events for Magellan.\n   * @private\n   */\n  _events() {\n    var _this = this,\n        $body = $('html, body'),\n        opts = {\n          duration: _this.options.animationDuration,\n          easing:   _this.options.animationEasing\n        };\n\n    $(window).one('load', function(){\n      if(_this.options.deepLinking){\n        if(location.hash){\n          _this.scrollToLoc(location.hash);\n        }\n      }\n      _this.calcPoints();\n      _this._updateActive();\n    });\n\n    _this.onLoadListener = onLoad($(window), function () {\n      _this.$element\n        .on({\n          'resizeme.zf.trigger': _this.reflow.bind(_this),\n          'scrollme.zf.trigger': _this._updateActive.bind(_this)\n        })\n        .on('click.zf.magellan', 'a[href^=\"#\"]', function (e) {\n          e.preventDefault();\n          var arrival   = this.getAttribute('href');\n          _this.scrollToLoc(arrival);\n        });\n    });\n\n    this._deepLinkScroll = function(e) {\n      if(_this.options.deepLinking) {\n        _this.scrollToLoc(window.location.hash);\n      }\n    };\n\n    $(window).on('hashchange', this._deepLinkScroll);\n  }\n\n  /**\n   * Function to scroll to a given location on the page.\n   * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'\n   * @function\n   */\n  scrollToLoc(loc) {\n    this._inTransition = true;\n    var _this = this;\n\n    var options = {\n      animationEasing: this.options.animationEasing,\n      animationDuration: this.options.animationDuration,\n      threshold: this.options.threshold,\n      offset: this.options.offset\n    };\n\n    SmoothScroll.scrollToLoc(loc, options, function() {\n      _this._inTransition = false;\n    })\n  }\n\n  /**\n   * Calls necessary functions to update Magellan upon DOM change\n   * @function\n   */\n  reflow() {\n    this.calcPoints();\n    this._updateActive();\n  }\n\n  /**\n   * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.\n   * @private\n   * @function\n   * @fires Magellan#update\n   */\n  _updateActive(/*evt, elem, scrollPos*/) {\n    if(this._inTransition) return;\n\n    const newScrollPos = parseInt(window.pageYOffset, 10);\n    const isScrollingUp = this.scrollPos > newScrollPos;\n    this.scrollPos = newScrollPos;\n\n    let activeIdx;\n    // Before the first point: no link\n    if(newScrollPos < this.points[0]){ /* do nothing */ }\n    // At the bottom of the page: last link\n    else if(newScrollPos + this.winHeight === this.docHeight){ activeIdx = this.points.length - 1; }\n    // Otherwhise, use the last visible link\n    else{\n      const visibleLinks = this.points.filter((p, i) => {\n        return (p - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) <= newScrollPos;\n      });\n      activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;\n    }\n\n    // Get the new active link\n    const $oldActive = this.$active;\n    let activeHash = '';\n    if(typeof activeIdx !== 'undefined'){\n      this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(activeIdx).data('magellan-target') + '\"]');\n      if (this.$active.length) activeHash = this.$active[0].getAttribute('href');\n    }else{\n      this.$active = $();\n    }\n    const isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);\n    const isNewHash = activeHash !== window.location.hash;\n\n    // Update the active link element\n    if(isNewActive) {\n      $oldActive.removeClass(this.options.activeClass);\n      this.$active.addClass(this.options.activeClass);\n    }\n\n    // Update the hash (it may have changed with the same active link)\n    if(this.options.deepLinking && isNewHash){\n      if(window.history.pushState){\n        // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384\n        const url = activeHash ? activeHash : window.location.pathname + window.location.search;\n        window.history.pushState(null, null, url);\n      }else{\n        window.location.hash = activeHash;\n      }\n    }\n\n    if (isNewActive) {\n      /**\n       * Fires when magellan is finished updating to the new active element.\n       * @event Magellan#update\n       */\n    \tthis.$element.trigger('update.zf.magellan', [this.$active]);\n\t  }\n  }\n\n  /**\n   * Destroys an instance of Magellan and resets the url of the window.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger .zf.magellan')\n        .find(`.${this.options.activeClass}`).removeClass(this.options.activeClass);\n\n    if(this.options.deepLinking){\n      var hash = this.$active[0].getAttribute('href');\n      window.location.hash.replace(hash, '');\n    }\n\n    $(window).off('hashchange', this._deepLinkScroll)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\n/**\n * Default settings for plugin\n */\nMagellan.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Class applied to the active locations link on the magellan container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  activeClass: 'is-active',\n  /**\n   * Allows the script to manipulate the url of the current page, and if supported, alter the history.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinking: false,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {Magellan};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, transitionend, RegExpEscape } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * OffCanvas module.\n * @module foundation.offcanvas\n * @requires foundation.util.keyboard\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass OffCanvas extends Plugin {\n  /**\n   * Creates a new instance of an off-canvas wrapper.\n   * @class\n   * @name OffCanvas\n   * @fires OffCanvas#init\n   * @param {Object} element - jQuery object to initialize.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.className = 'OffCanvas'; // ie9 back compat\n    this.$element = element;\n    this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);\n    this.contentClasses = { base: [], reveal: [] };\n    this.$lastTrigger = $();\n    this.$triggers = $();\n    this.position = 'left';\n    this.$content = $();\n    this.nested = !!(this.options.nested);\n\n    // Defines the CSS transition/position classes of the off-canvas content container.\n    $(['push', 'overlap']).each((index, val) => {\n      this.contentClasses.base.push('has-transition-'+val);\n    });\n    $(['left', 'right', 'top', 'bottom']).each((index, val) => {\n      this.contentClasses.base.push('has-position-'+val);\n      this.contentClasses.reveal.push('has-reveal-'+val);\n    });\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n    MediaQuery._init();\n\n    this._init();\n    this._events();\n\n    Keyboard.register('OffCanvas', {\n      'ESCAPE': 'close'\n    });\n\n  }\n\n  /**\n   * Initializes the off-canvas wrapper by adding the exit overlay (if needed).\n   * @function\n   * @private\n   */\n  _init() {\n    var id = this.$element.attr('id');\n\n    this.$element.attr('aria-hidden', 'true');\n\n    // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)\n    if (this.options.contentId) {\n      this.$content = $('#'+this.options.contentId);\n    } else if (this.$element.siblings('[data-off-canvas-content]').length) {\n      this.$content = this.$element.siblings('[data-off-canvas-content]').first();\n    } else {\n      this.$content = this.$element.closest('[data-off-canvas-content]').first();\n    }\n\n    if (!this.options.contentId) {\n      // Assume that the off-canvas element is nested if it isn't a sibling of the content\n      this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;\n\n    } else if (this.options.contentId && this.options.nested === null) {\n      // Warning if using content ID without setting the nested option\n      // Once the element is nested it is required to work properly in this case\n      console.warn('Remember to use the nested option if using the content ID option!');\n    }\n\n    if (this.nested === true) {\n      // Force transition overlap if nested\n      this.options.transition = 'overlap';\n      // Remove appropriate classes if already assigned in markup\n      this.$element.removeClass('is-transition-push');\n    }\n\n    this.$element.addClass(`is-transition-${this.options.transition} is-closed`);\n\n    // Find triggers that affect this element and add aria-expanded to them\n    this.$triggers = $(document)\n      .find('[data-open=\"'+id+'\"], [data-close=\"'+id+'\"], [data-toggle=\"'+id+'\"]')\n      .attr('aria-expanded', 'false')\n      .attr('aria-controls', id);\n\n    // Get position by checking for related CSS class\n    this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\\-(left|top|right|bottom)/)[1] : this.position;\n\n    // Add an overlay over the content if necessary\n    if (this.options.contentOverlay === true) {\n      var overlay = document.createElement('div');\n      var overlayPosition = $(this.$element).css(\"position\") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';\n      overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);\n      this.$overlay = $(overlay);\n      if(overlayPosition === 'is-overlay-fixed') {\n        $(this.$overlay).insertAfter(this.$element);\n      } else {\n        this.$content.append(this.$overlay);\n      }\n    }\n\n    // Get the revealOn option from the class.\n    var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\\\s]+)', 'g');\n    var revealOnClass = revealOnRegExp.exec(this.$element[0].className);\n    if (revealOnClass) {\n      this.options.isRevealed = true;\n      this.options.revealOn = this.options.revealOn || revealOnClass[1];\n    }\n\n    // Ensure the `reveal-on-*` class is set.\n    if (this.options.isRevealed === true && this.options.revealOn) {\n      this.$element.first().addClass(`${this.options.revealClass}${this.options.revealOn}`);\n      this._setMQChecker();\n    }\n\n    if (this.options.transitionTime) {\n      this.$element.css('transition-duration', this.options.transitionTime);\n    }\n\n    // Initally remove all transition/position CSS classes from off-canvas content container.\n    this._removeContentClasses();\n  }\n\n  /**\n   * Adds event handlers to the off-canvas wrapper and the exit overlay.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('.zf.trigger .zf.offcanvas').on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'keydown.zf.offcanvas': this._handleKeyboard.bind(this)\n    });\n\n    if (this.options.closeOnClick === true) {\n      var $target = this.options.contentOverlay ? this.$overlay : this.$content;\n      $target.on({'click.zf.offcanvas': this.close.bind(this)});\n    }\n  }\n\n  /**\n   * Applies event listener for elements that will reveal at certain breakpoints.\n   * @private\n   */\n  _setMQChecker() {\n    var _this = this;\n\n    this.onLoadListener = onLoad($(window), function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      }\n    });\n\n    $(window).on('changed.zf.mediaquery', function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      } else {\n        _this.reveal(false);\n      }\n    });\n  }\n\n  /**\n   * Removes the CSS transition/position classes of the off-canvas content container.\n   * Removing the classes is important when another off-canvas gets opened that uses the same content container.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _removeContentClasses(hasReveal) {\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.removeClass(this.contentClasses.base.join(' '));\n    } else if (hasReveal === false) {\n      this.$content.removeClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.\n   * Beforehand any transition/position class gets removed.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _addContentClasses(hasReveal) {\n    this._removeContentClasses(hasReveal);\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.addClass(`has-transition-${this.options.transition} has-position-${this.position}`);\n    } else if (hasReveal === true) {\n      this.$content.addClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.\n   * @param {Boolean} isRevealed - true if element should be revealed.\n   * @function\n   */\n  reveal(isRevealed) {\n    if (isRevealed) {\n      this.close();\n      this.isRevealed = true;\n      this.$element.attr('aria-hidden', 'false');\n      this.$element.off('open.zf.trigger toggle.zf.trigger');\n      this.$element.removeClass('is-closed');\n    } else {\n      this.isRevealed = false;\n      this.$element.attr('aria-hidden', 'true');\n      this.$element.off('open.zf.trigger toggle.zf.trigger').on({\n        'open.zf.trigger': this.open.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this)\n      });\n      this.$element.addClass('is-closed');\n    }\n    this._addContentClasses(isRevealed);\n  }\n\n  /**\n   * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.\n   * @private\n   */\n  _stopScrolling(event) {\n    return false;\n  }\n\n  // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios\n  // Only really works for y, not sure how to extend to x or if we need to.\n  _recordScrollable(event) {\n    let elem = this; // called from event handler context with this as elem\n\n     // If the element is scrollable (content overflows), then...\n    if (elem.scrollHeight !== elem.clientHeight) {\n      // If we're at the top, scroll down one pixel to allow scrolling up\n      if (elem.scrollTop === 0) {\n        elem.scrollTop = 1;\n      }\n      // If we're at the bottom, scroll up one pixel to allow scrolling down\n      if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {\n        elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;\n      }\n    }\n    elem.allowUp = elem.scrollTop > 0;\n    elem.allowDown = elem.scrollTop < (elem.scrollHeight - elem.clientHeight);\n    elem.lastY = event.originalEvent.pageY;\n  }\n\n  _stopScrollPropagation(event) {\n    let elem = this; // called from event handler context with this as elem\n    let up = event.pageY < elem.lastY;\n    let down = !up;\n    elem.lastY = event.pageY;\n\n    if((up && elem.allowUp) || (down && elem.allowDown)) {\n      event.stopPropagation();\n    } else {\n      event.preventDefault();\n    }\n  }\n\n  /**\n   * Opens the off-canvas menu.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   * @fires Offcanvas#opened\n   * @todo also trigger 'open' event?\n   */\n  open(event, trigger) {\n    if (this.$element.hasClass('is-open') || this.isRevealed) { return; }\n    var _this = this;\n\n    if (trigger) {\n      this.$lastTrigger = trigger;\n    }\n\n    if (this.options.forceTo === 'top') {\n      window.scrollTo(0, 0);\n    } else if (this.options.forceTo === 'bottom') {\n      window.scrollTo(0,document.body.scrollHeight);\n    }\n\n    if (this.options.transitionTime && this.options.transition !== 'overlap') {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);\n    } else {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');\n    }\n\n    this.$element.addClass('is-open').removeClass('is-closed');\n\n    this.$triggers.attr('aria-expanded', 'true');\n    this.$element.attr('aria-hidden', 'false');\n\n    this.$content.addClass('is-open-' + this.position);\n\n    // If `contentScroll` is set to false, add class and disable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);\n      this.$element.on('touchstart', this._recordScrollable);\n      this.$element.on('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-closable');\n    }\n\n    if (this.options.autoFocus === true) {\n      this.$element.one(transitionend(this.$element), function() {\n        if (!_this.$element.hasClass('is-open')) {\n          return; // exit if prematurely closed\n        }\n        var canvasFocus = _this.$element.find('[data-autofocus]');\n        if (canvasFocus.length) {\n            canvasFocus.eq(0).focus();\n        } else {\n            _this.$element.find('a, button').eq(0).focus();\n        }\n      });\n    }\n\n    if (this.options.trapFocus === true) {\n      this.$content.attr('tabindex', '-1');\n      Keyboard.trapFocus(this.$element);\n    }\n\n    this._addContentClasses();\n\n    /**\n     * Fires when the off-canvas menu opens.\n     * @event Offcanvas#opened\n     */\n    this.$element.trigger('opened.zf.offcanvas');\n  }\n\n  /**\n   * Closes the off-canvas menu.\n   * @function\n   * @param {Function} cb - optional cb to fire after closure.\n   * @fires Offcanvas#closed\n   */\n  close(cb) {\n    if (!this.$element.hasClass('is-open') || this.isRevealed) { return; }\n\n    var _this = this;\n\n    this.$element.removeClass('is-open');\n\n    this.$element.attr('aria-hidden', 'true')\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#closed\n       */\n        .trigger('closed.zf.offcanvas');\n\n    this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');\n\n    // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);\n      this.$element.off('touchstart', this._recordScrollable);\n      this.$element.off('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-closable');\n    }\n\n    this.$triggers.attr('aria-expanded', 'false');\n\n    if (this.options.trapFocus === true) {\n      this.$content.removeAttr('tabindex');\n      Keyboard.releaseFocus(this.$element);\n    }\n\n    // Listen to transitionEnd and add class when done.\n    this.$element.one(transitionend(this.$element), function(e) {\n      _this.$element.addClass('is-closed');\n      _this._removeContentClasses();\n    });\n  }\n\n  /**\n   * Toggles the off-canvas menu open or closed.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   */\n  toggle(event, trigger) {\n    if (this.$element.hasClass('is-open')) {\n      this.close(event, trigger);\n    }\n    else {\n      this.open(event, trigger);\n    }\n  }\n\n  /**\n   * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.\n   * @function\n   * @private\n   */\n  _handleKeyboard(e) {\n    Keyboard.handleKey(e, 'OffCanvas', {\n      close: () => {\n        this.close();\n        this.$lastTrigger.focus();\n        return true;\n      },\n      handled: () => {\n        e.stopPropagation();\n        e.preventDefault();\n      }\n    });\n  }\n\n  /**\n   * Destroys the offcanvas plugin.\n   * @function\n   */\n  _destroy() {\n    this.close();\n    this.$element.off('.zf.trigger .zf.offcanvas');\n    this.$overlay.off('.zf.offcanvas');\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\nOffCanvas.defaults = {\n  /**\n   * Allow the user to click outside of the menu to close it.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Adds an overlay on top of `[data-off-canvas-content]`.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentOverlay: true,\n\n  /**\n   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  contentId: null,\n\n  /**\n   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.\n   * @option\n   * @type {boolean}\n   * @default null\n   */\n  nested: null,\n\n  /**\n   * Enable/disable scrolling of the main content when an off canvas panel is open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentScroll: true,\n\n  /**\n   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.\n   * @option\n   * @type {number}\n   * @default null\n   */\n  transitionTime: null,\n\n  /**\n   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.\n   * @option\n   * @type {string}\n   * @default push\n   */\n  transition: 'push',\n\n  /**\n   * Force the page to scroll to top or bottom on open.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  forceTo: null,\n\n  /**\n   * Allow the offcanvas to remain open for certain breakpoints.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  isRevealed: false,\n\n  /**\n   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  revealOn: null,\n\n  /**\n   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoFocus: true,\n\n  /**\n   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.\n   * @option\n   * @type {string}\n   * @default reveal-for-\n   * @todo improve the regex testing for this.\n   */\n  revealClass: 'reveal-for-',\n\n  /**\n   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false\n}\n\nexport {OffCanvas};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Motion } from './foundation.util.motion';\nimport { Timer } from './foundation.util.timer';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { Touch } from './foundation.util.touch'\n\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timer\n * @requires foundation.util.imageLoader\n * @requires foundation.util.touch\n */\n\nclass Orbit extends Plugin {\n  /**\n  * Creates a new instance of an orbit carousel.\n  * @class\n  * @name Orbit\n  * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n  * @param {Object} options - Overrides to the default plugin settings.\n  */\n  _setup(element, options){\n    this.$element = element;\n    this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);\n    this.className = 'Orbit'; // ie9 back compat\n\n    Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.\n\n    this._init();\n\n    Keyboard.register('Orbit', {\n      'ltr': {\n        'ARROW_RIGHT': 'next',\n        'ARROW_LEFT': 'previous'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'next',\n        'ARROW_RIGHT': 'previous'\n      }\n    });\n  }\n\n  /**\n  * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.\n  * @function\n  * @private\n  */\n  _init() {\n    // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide\n    this._reset();\n\n    this.$wrapper = this.$element.find(`.${this.options.containerClass}`);\n    this.$slides = this.$element.find(`.${this.options.slideClass}`);\n\n    var $images = this.$element.find('img'),\n        initActive = this.$slides.filter('.is-active'),\n        id = this.$element[0].id || GetYoDigits(6, 'orbit');\n\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    if (!initActive.length) {\n      this.$slides.eq(0).addClass('is-active');\n    }\n\n    if (!this.options.useMUI) {\n      this.$slides.addClass('no-motionui');\n    }\n\n    if ($images.length) {\n      onImagesLoaded($images, this._prepareForOrbit.bind(this));\n    } else {\n      this._prepareForOrbit();//hehe\n    }\n\n    if (this.options.bullets) {\n      this._loadBullets();\n    }\n\n    this._events();\n\n    if (this.options.autoPlay && this.$slides.length > 1) {\n      this.geoSync();\n    }\n\n    if (this.options.accessible) { // allow wrapper to be focusable to enable arrow navigation\n      this.$wrapper.attr('tabindex', 0);\n    }\n  }\n\n  /**\n  * Creates a jQuery collection of bullets, if they are being used.\n  * @function\n  * @private\n  */\n  _loadBullets() {\n    this.$bullets = this.$element.find(`.${this.options.boxOfBullets}`).find('button');\n  }\n\n  /**\n  * Sets a `timer` object on the orbit, and starts the counter for the next slide.\n  * @function\n  */\n  geoSync() {\n    var _this = this;\n    this.timer = new Timer(\n      this.$element,\n      {\n        duration: this.options.timerDelay,\n        infinite: false\n      },\n      function() {\n        _this.changeSlide(true);\n      });\n    this.timer.start();\n  }\n\n  /**\n  * Sets wrapper and slide heights for the orbit.\n  * @function\n  * @private\n  */\n  _prepareForOrbit() {\n    var _this = this;\n    this._setWrapperHeight();\n  }\n\n  /**\n  * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.\n  * @function\n  * @private\n  * @param {Function} cb - a callback function to fire when complete.\n  */\n  _setWrapperHeight(cb) {//rewrite this to `for` loop\n    var max = 0, temp, counter = 0, _this = this;\n\n    this.$slides.each(function() {\n      temp = this.getBoundingClientRect().height;\n      $(this).attr('data-slide', counter);\n\n      // hide all slides but the active one\n      if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {\n        $(this).css({'display': 'none'});\n      }\n      max = temp > max ? temp : max;\n      counter++;\n    });\n\n    if (counter === this.$slides.length) {\n      this.$wrapper.css({'height': max}); //only change the wrapper height property once.\n      if(cb) {cb(max);} //fire callback with max height dimension.\n    }\n  }\n\n  /**\n  * Sets the max-height of each slide.\n  * @function\n  * @private\n  */\n  _setSlideHeight(height) {\n    this.$slides.each(function() {\n      $(this).css('max-height', height);\n    });\n  }\n\n  /**\n  * Adds event listeners to basically everything within the element.\n  * @function\n  * @private\n  */\n  _events() {\n    var _this = this;\n\n    //***************************************\n    //**Now using custom event - thanks to:**\n    //**      Yohai Ararat of Toronto      **\n    //***************************************\n    //\n    this.$element.off('.resizeme.zf.trigger').on({\n      'resizeme.zf.trigger': this._prepareForOrbit.bind(this)\n    })\n    if (this.$slides.length > 1) {\n\n      if (this.options.swipe) {\n        this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit')\n        .on('swipeleft.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(true);\n        }).on('swiperight.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(false);\n        });\n      }\n      //***************************************\n\n      if (this.options.autoPlay) {\n        this.$slides.on('click.zf.orbit', function() {\n          _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);\n          _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();\n        });\n\n        if (this.options.pauseOnHover) {\n          this.$element.on('mouseenter.zf.orbit', function() {\n            _this.timer.pause();\n          }).on('mouseleave.zf.orbit', function() {\n            if (!_this.$element.data('clickedOn')) {\n              _this.timer.start();\n            }\n          });\n        }\n      }\n\n      if (this.options.navButtons) {\n        var $controls = this.$element.find(`.${this.options.nextClass}, .${this.options.prevClass}`);\n        $controls.attr('tabindex', 0)\n        //also need to handle enter/return and spacebar key presses\n        .on('click.zf.orbit touchend.zf.orbit', function(e){\n\t  e.preventDefault();\n          _this.changeSlide($(this).hasClass(_this.options.nextClass));\n        });\n      }\n\n      if (this.options.bullets) {\n        this.$bullets.on('click.zf.orbit touchend.zf.orbit', function() {\n          if (/is-active/g.test(this.className)) { return false; }//if this is active, kick out of function.\n          var idx = $(this).data('slide'),\n          ltr = idx > _this.$slides.filter('.is-active').data('slide'),\n          $slide = _this.$slides.eq(idx);\n\n          _this.changeSlide(ltr, $slide, idx);\n        });\n      }\n\n      if (this.options.accessible) {\n        this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function(e) {\n          // handle keyboard event with keyboard util\n          Keyboard.handleKey(e, 'Orbit', {\n            next: function() {\n              _this.changeSlide(true);\n            },\n            previous: function() {\n              _this.changeSlide(false);\n            },\n            handled: function() { // if bullet is focused, make sure focus moves\n              if ($(e.target).is(_this.$bullets)) {\n                _this.$bullets.filter('.is-active').focus();\n              }\n            }\n          });\n        });\n      }\n    }\n  }\n\n  /**\n   * Resets Orbit so it can be reinitialized\n   */\n  _reset() {\n    // Don't do anything if there are no slides (first run)\n    if (typeof this.$slides == 'undefined') {\n      return;\n    }\n\n    if (this.$slides.length > 1) {\n      // Remove old events\n      this.$element.off('.zf.orbit').find('*').off('.zf.orbit')\n\n      // Restart timer if autoPlay is enabled\n      if (this.options.autoPlay) {\n        this.timer.restart();\n      }\n\n      // Reset all sliddes\n      this.$slides.each(function(el) {\n        $(el).removeClass('is-active is-active is-in')\n          .removeAttr('aria-live')\n          .hide();\n      });\n\n      // Show the first slide\n      this.$slides.first().addClass('is-active').show();\n\n      // Triggers when the slide has finished animating\n      this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);\n\n      // Select first bullet if bullets are present\n      if (this.options.bullets) {\n        this._updateBullets(0);\n      }\n    }\n  }\n\n  /**\n  * Changes the current slide to a new one.\n  * @function\n  * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.\n  * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.\n  * @param {Number} idx - the index of the new slide in its collection, if one chosen.\n  * @fires Orbit#slidechange\n  */\n  changeSlide(isLTR, chosenSlide, idx) {\n    if (!this.$slides) {return; } // Don't freak out if we're in the middle of cleanup\n    var $curSlide = this.$slides.filter('.is-active').eq(0);\n\n    if (/mui/g.test($curSlide[0].className)) { return false; } //if the slide is currently animating, kick out of the function\n\n    var $firstSlide = this.$slides.first(),\n    $lastSlide = this.$slides.last(),\n    dirIn = isLTR ? 'Right' : 'Left',\n    dirOut = isLTR ? 'Left' : 'Right',\n    _this = this,\n    $newSlide;\n\n    if (!chosenSlide) { //most of the time, this will be auto played or clicked from the navButtons.\n      $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!\n      (this.options.infiniteWrap ? $curSlide.next(`.${this.options.slideClass}`).length ? $curSlide.next(`.${this.options.slideClass}`) : $firstSlide : $curSlide.next(`.${this.options.slideClass}`))//pick next slide if moving left to right\n      :\n      (this.options.infiniteWrap ? $curSlide.prev(`.${this.options.slideClass}`).length ? $curSlide.prev(`.${this.options.slideClass}`) : $lastSlide : $curSlide.prev(`.${this.options.slideClass}`));//pick prev slide if moving right to left\n    } else {\n      $newSlide = chosenSlide;\n    }\n\n    if ($newSlide.length) {\n      /**\n      * Triggers before the next slide starts animating in and only if a next slide has been found.\n      * @event Orbit#beforeslidechange\n      */\n      this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);\n\n      if (this.options.bullets) {\n        idx = idx || this.$slides.index($newSlide); //grab index to update bullets\n        this._updateBullets(idx);\n      }\n\n      if (this.options.useMUI && !this.$element.is(':hidden')) {\n        Motion.animateIn(\n          $newSlide.addClass('is-active'),\n          this.options[`animInFrom${dirIn}`],\n          function(){\n            $newSlide.css({'display': 'block'}).attr('aria-live', 'polite');\n        });\n\n        Motion.animateOut(\n          $curSlide.removeClass('is-active'),\n          this.options[`animOutTo${dirOut}`],\n          function(){\n            $curSlide.removeAttr('aria-live');\n            if(_this.options.autoPlay && !_this.timer.isPaused){\n              _this.timer.restart();\n            }\n            //do stuff?\n          });\n      } else {\n        $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();\n        $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();\n        if (this.options.autoPlay && !this.timer.isPaused) {\n          this.timer.restart();\n        }\n      }\n    /**\n    * Triggers when the slide has finished animating in.\n    * @event Orbit#slidechange\n    */\n      this.$element.trigger('slidechange.zf.orbit', [$newSlide]);\n    }\n  }\n\n  /**\n  * Updates the active state of the bullets, if displayed.\n  * @function\n  * @private\n  * @param {Number} idx - the index of the current slide.\n  */\n  _updateBullets(idx) {\n    var $oldBullet = this.$element.find(`.${this.options.boxOfBullets}`)\n    .find('.is-active').removeClass('is-active').blur(),\n    span = $oldBullet.find('span:last').detach(),\n    $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);\n  }\n\n  /**\n  * Destroys the carousel and hides the element.\n  * @function\n  */\n  _destroy() {\n    this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();\n  }\n}\n\nOrbit.defaults = {\n  /**\n  * Tells the JS to look for and loadBullets.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  bullets: true,\n  /**\n  * Tells the JS to apply event listeners to nav buttons\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  navButtons: true,\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-right'\n  */\n  animInFromRight: 'slide-in-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-right'\n  */\n  animOutToRight: 'slide-out-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-left'\n  *\n  */\n  animInFromLeft: 'slide-in-left',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-left'\n  */\n  animOutToLeft: 'slide-out-left',\n  /**\n  * Allows Orbit to automatically animate on page load.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  autoPlay: true,\n  /**\n  * Amount of time, in ms, between slide transitions\n  * @option\n   * @type {number}\n  * @default 5000\n  */\n  timerDelay: 5000,\n  /**\n  * Allows Orbit to infinitely loop through the slides\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  infiniteWrap: true,\n  /**\n  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  swipe: true,\n  /**\n  * Allows the timing function to pause animation on hover.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  pauseOnHover: true,\n  /**\n  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  accessible: true,\n  /**\n  * Class applied to the container of Orbit\n  * @option\n   * @type {string}\n  * @default 'orbit-container'\n  */\n  containerClass: 'orbit-container',\n  /**\n  * Class applied to individual slides.\n  * @option\n   * @type {string}\n  * @default 'orbit-slide'\n  */\n  slideClass: 'orbit-slide',\n  /**\n  * Class applied to the bullet container. You're welcome.\n  * @option\n   * @type {string}\n  * @default 'orbit-bullets'\n  */\n  boxOfBullets: 'orbit-bullets',\n  /**\n  * Class applied to the `next` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-next'\n  */\n  nextClass: 'orbit-next',\n  /**\n  * Class applied to the `previous` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-previous'\n  */\n  prevClass: 'orbit-previous',\n  /**\n  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  useMUI: true\n};\n\nexport {Orbit};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { DropdownMenu } from './foundation.dropdownMenu';\nimport { Drilldown } from './foundation.drilldown';\nimport { AccordionMenu } from './foundation.accordionMenu';\n\nlet MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: DropdownMenu\n  },\n drilldown: {\n    cssClass: 'drilldown',\n    plugin: Drilldown\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: AccordionMenu\n  }\n};\n\n  // import \"foundation.util.triggers.js\";\n\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveMenu extends Plugin {\n  /**\n   * Creates a new instance of a responsive menu.\n   * @class\n   * @name ResponsiveMenu\n   * @fires ResponsiveMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.rules = this.$element.data('responsive-menu');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveMenu'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n\n    MediaQuery._init();\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n    // Add data-mutate since children may need it.\n    this.$element.attr('data-mutate', (this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')));\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    $(window).on('changed.zf.mediaquery', function() {\n      _this._checkMediaQueries();\n    });\n    // $(window).on('resize.zf.ResponsiveMenu', function() {\n    //   _this._checkMediaQueries();\n    // });\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    this.currentPlugin.destroy();\n    $(window).off('.zf.ResponsiveMenu');\n  }\n}\n\nResponsiveMenu.defaults = {};\n\nexport {ResponsiveMenu};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion\n */\n\nclass ResponsiveToggle extends Plugin {\n  /**\n   * Creates a new instance of Tab Bar.\n   * @class\n   * @name ResponsiveToggle\n   * @fires ResponsiveToggle#init\n   * @param {jQuery} element - jQuery object to attach tab bar functionality to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n    this.className = 'ResponsiveToggle'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the tab bar by finding the target element, toggling element, and running update().\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var targetID = this.$element.data('responsive-toggle');\n    if (!targetID) {\n      console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');\n    }\n\n    this.$targetMenu = $(`#${targetID}`);\n    this.$toggler = this.$element.find('[data-toggle]').filter(function() {\n      var target = $(this).data('toggle');\n      return (target === targetID || target === \"\");\n    });\n    this.options = $.extend({}, this.options, this.$targetMenu.data());\n\n    // If they were set, parse the animation classes\n    if(this.options.animate) {\n      let input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n\n    this._update();\n  }\n\n  /**\n   * Adds necessary event handlers for the tab bar to work.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this._updateMqHandler = this._update.bind(this);\n\n    $(window).on('changed.zf.mediaquery', this._updateMqHandler);\n\n    this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));\n  }\n\n  /**\n   * Checks the current media query to determine if the tab bar should be visible or hidden.\n   * @function\n   * @private\n   */\n  _update() {\n    // Mobile\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      this.$element.show();\n      this.$targetMenu.hide();\n    }\n\n    // Desktop\n    else {\n      this.$element.hide();\n      this.$targetMenu.show();\n    }\n  }\n\n  /**\n   * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.\n   * @function\n   * @fires ResponsiveToggle#toggled\n   */\n  toggleMenu() {\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      /**\n       * Fires when the element attached to the tab bar toggles.\n       * @event ResponsiveToggle#toggled\n       */\n      if(this.options.animate) {\n        if (this.$targetMenu.is(':hidden')) {\n          Motion.animateIn(this.$targetMenu, this.animationIn, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n            this.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');\n          });\n        }\n        else {\n          Motion.animateOut(this.$targetMenu, this.animationOut, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n          });\n        }\n      }\n      else {\n        this.$targetMenu.toggle(0);\n        this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        this.$element.trigger('toggled.zf.responsiveToggle');\n      }\n    }\n  };\n\n  _destroy() {\n    this.$element.off('.zf.responsiveToggle');\n    this.$toggler.off('.zf.responsiveToggle');\n\n    $(window).off('changed.zf.mediaquery', this._updateMqHandler);\n  }\n}\n\nResponsiveToggle.defaults = {\n  /**\n   * The breakpoint after which the menu is always shown, and the tab bar is hidden.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  hideFor: 'medium',\n\n  /**\n   * To decide if the toggle should be animated or not.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport { ResponsiveToggle };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nclass Reveal extends Plugin {\n  /**\n   * Creates a new instance of Reveal.\n   * @class\n   * @name Reveal\n   * @param {jQuery} element - jQuery object to use for the modal.\n   * @param {Object} options - optional parameters.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);\n    this.className = 'Reveal'; // ie9 back compat\n    this._init();\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    Keyboard.register('Reveal', {\n      'ESCAPE': 'close',\n    });\n  }\n\n  /**\n   * Initializes the modal by adding the overlay and close buttons, (if selected).\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    this.id = this.$element.attr('id');\n    this.isActive = false;\n    this.cached = {mq: MediaQuery.current};\n\n    this.$anchor = $(`[data-open=\"${this.id}\"]`).length ? $(`[data-open=\"${this.id}\"]`) : $(`[data-toggle=\"${this.id}\"]`);\n    this.$anchor.attr({\n      'aria-controls': this.id,\n      'aria-haspopup': true,\n      'tabindex': 0\n    });\n\n    if (this.options.fullScreen || this.$element.hasClass('full')) {\n      this.options.fullScreen = true;\n      this.options.overlay = false;\n    }\n    if (this.options.overlay && !this.$overlay) {\n      this.$overlay = this._makeOverlay(this.id);\n    }\n\n    this.$element.attr({\n        'role': 'dialog',\n        'aria-hidden': true,\n        'data-yeti-box': this.id,\n        'data-resize': this.id\n    });\n\n    if(this.$overlay) {\n      this.$element.detach().appendTo(this.$overlay);\n    } else {\n      this.$element.detach().appendTo($(this.options.appendTo));\n      this.$element.addClass('without-overlay');\n    }\n    this._events();\n    if (this.options.deepLink && window.location.hash === ( `#${this.id}`)) {\n      this.onLoadListener = onLoad($(window), () => this.open());\n    }\n  }\n\n  /**\n   * Creates an overlay div to display behind the modal.\n   * @private\n   */\n  _makeOverlay() {\n    var additionalOverlayClasses = '';\n\n    if (this.options.additionalOverlayClasses) {\n      additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;\n    }\n\n    return $('<div></div>')\n      .addClass('reveal-overlay' + additionalOverlayClasses)\n      .appendTo(this.options.appendTo);\n  }\n\n  /**\n   * Updates position of modal\n   * TODO:  Figure out if we actually need to cache these values or if it doesn't matter\n   * @private\n   */\n  _updatePosition() {\n    var width = this.$element.outerWidth();\n    var outerWidth = $(window).width();\n    var height = this.$element.outerHeight();\n    var outerHeight = $(window).height();\n    var left, top = null;\n    if (this.options.hOffset === 'auto') {\n      left = parseInt((outerWidth - width) / 2, 10);\n    } else {\n      left = parseInt(this.options.hOffset, 10);\n    }\n    if (this.options.vOffset === 'auto') {\n      if (height > outerHeight) {\n        top = parseInt(Math.min(100, outerHeight / 10), 10);\n      } else {\n        top = parseInt((outerHeight - height) / 4, 10);\n      }\n    } else if (this.options.vOffset !== null) {\n      top = parseInt(this.options.vOffset, 10);\n    }\n\n    if (top !== null) {\n      this.$element.css({top: top + 'px'});\n    }\n\n    // only worry about left if we don't have an overlay or we have a horizontal offset,\n    // otherwise we're perfectly in the middle\n    if (!this.$overlay || (this.options.hOffset !== 'auto')) {\n      this.$element.css({left: left + 'px'});\n      this.$element.css({margin: '0px'});\n    }\n\n  }\n\n  /**\n   * Adds event handlers for the modal.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': (event, $element) => {\n        if ((event.target === _this.$element[0]) ||\n            ($(event.target).parents('[data-closable]')[0] === $element)) { // only close reveal when it's explicitly called\n          return this.close.apply(this);\n        }\n      },\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': function() {\n        _this._updatePosition();\n      }\n    });\n\n    if (this.options.closeOnClick && this.options.overlay) {\n      this.$overlay.off('.zf.reveal').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) {\n              return;\n        }\n        _this.close();\n      });\n    }\n    if (this.options.deepLink) {\n      $(window).on(`hashchange.zf.reveal:${this.id}`, this._handleState.bind(this));\n    }\n  }\n\n  /**\n   * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.\n   * @private\n   */\n  _handleState(e) {\n    if(window.location.hash === ( '#' + this.id) && !this.isActive){ this.open(); }\n    else{ this.close(); }\n  }\n\n  /**\n  * Disables the scroll when Reveal is shown to prevent the background from shifting\n  * @param {number} scrollTop - Scroll to visually apply, window current scroll by default\n  */\n  _disableScroll(scrollTop) {\n    scrollTop = scrollTop || $(window).scrollTop();\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", -scrollTop);\n    }\n  }\n\n  /**\n  * Reenables the scroll when Reveal closes\n  * @param {number} scrollTop - Scroll to restore, html \"top\" property by default (as set by `_disableScroll`)\n  */\n  _enableScroll(scrollTop) {\n    scrollTop = scrollTop || parseInt($(\"html\").css(\"top\"));\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", \"\");\n      $(window).scrollTop(-scrollTop);\n    }\n  }\n\n\n  /**\n   * Opens the modal controlled by `this.$anchor`, and closes all others by default.\n   * @function\n   * @fires Reveal#closeme\n   * @fires Reveal#open\n   */\n  open() {\n    // either update or replace browser history\n    const hash = `#${this.id}`;\n    if (this.options.deepLink && window.location.hash !== hash) {\n\n      if (window.history.pushState) {\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', hash);\n        } else {\n          window.history.replaceState({}, '', hash);\n        }\n      } else {\n        window.location.hash = hash;\n      }\n    }\n\n    // Remember anchor that opened it to set focus back later, have general anchors as fallback\n    this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;\n\n    this.isActive = true;\n\n    // Make elements invisible, but remove display: none so we can get size and positioning\n    this.$element\n        .css({ 'visibility': 'hidden' })\n        .show()\n        .scrollTop(0);\n    if (this.options.overlay) {\n      this.$overlay.css({'visibility': 'hidden'}).show();\n    }\n\n    this._updatePosition();\n\n    this.$element\n      .hide()\n      .css({ 'visibility': '' });\n\n    if(this.$overlay) {\n      this.$overlay.css({'visibility': ''}).hide();\n      if(this.$element.hasClass('fast')) {\n        this.$overlay.addClass('fast');\n      } else if (this.$element.hasClass('slow')) {\n        this.$overlay.addClass('slow');\n      }\n    }\n\n\n    if (!this.options.multipleOpened) {\n      /**\n       * Fires immediately before the modal opens.\n       * Closes any other modals that are currently open\n       * @event Reveal#closeme\n       */\n      this.$element.trigger('closeme.zf.reveal', this.id);\n    }\n\n    this._disableScroll();\n\n    var _this = this;\n\n    // Motion UI method of reveal\n    if (this.options.animationIn) {\n      function afterAnimation(){\n        _this.$element\n          .attr({\n            'aria-hidden': false,\n            'tabindex': -1\n          })\n          .focus();\n        _this._addGlobalClasses();\n        Keyboard.trapFocus(_this.$element);\n      }\n      if (this.options.overlay) {\n        Motion.animateIn(this.$overlay, 'fade-in');\n      }\n      Motion.animateIn(this.$element, this.options.animationIn, () => {\n        if(this.$element) { // protect against object having been removed\n          this.focusableElements = Keyboard.findFocusable(this.$element);\n          afterAnimation();\n        }\n      });\n    }\n    // jQuery method of reveal\n    else {\n      if (this.options.overlay) {\n        this.$overlay.show(0);\n      }\n      this.$element.show(this.options.showDelay);\n    }\n\n    // handle accessibility\n    this.$element\n      .attr({\n        'aria-hidden': false,\n        'tabindex': -1\n      })\n      .focus();\n    Keyboard.trapFocus(this.$element);\n\n    this._addGlobalClasses();\n\n    this._addGlobalListeners();\n\n    /**\n     * Fires when the modal has successfully opened.\n     * @event Reveal#open\n     */\n    this.$element.trigger('open.zf.reveal');\n  }\n\n  /**\n   * Adds classes and listeners on document required by open modals.\n   *\n   * The following classes are added and updated:\n   * - `.is-reveal-open` - Prevents the scroll on document\n   * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the\n   *                       scroll was not disabled. This prevent a \"shift\" of the page content due\n   *                       the scrollbar disappearing when the modal opens.\n   *\n   * @private\n   */\n  _addGlobalClasses() {\n    const updateScrollbarClass = () => {\n      $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));\n    };\n\n    this.$element.on('resizeme.zf.trigger.revealScrollbarListener', () => updateScrollbarClass());\n    updateScrollbarClass();\n    $('html').addClass('is-reveal-open');\n  }\n\n  /**\n   * Removes classes and listeners on document that were required by open modals.\n   * @private\n   */\n  _removeGlobalClasses() {\n    this.$element.off('resizeme.zf.trigger.revealScrollbarListener');\n    $('html').removeClass('is-reveal-open');\n    $('html').removeClass('zf-has-scroll');\n  }\n\n  /**\n   * Adds extra event handlers for the body and window if necessary.\n   * @private\n   */\n  _addGlobalListeners() {\n    var _this = this;\n    if(!this.$element) { return; } // If we're in the middle of cleanup, don't freak out\n    this.focusableElements = Keyboard.findFocusable(this.$element);\n\n    if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {\n      $('body').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) { return; }\n        _this.close();\n      });\n    }\n\n    if (this.options.closeOnEsc) {\n      $(window).on('keydown.zf.reveal', function(e) {\n        Keyboard.handleKey(e, 'Reveal', {\n          close: function() {\n            if (_this.options.closeOnEsc) {\n              _this.close();\n            }\n          }\n        });\n      });\n    }\n  }\n\n  /**\n   * Closes the modal.\n   * @function\n   * @fires Reveal#closed\n   */\n  close() {\n    if (!this.isActive || !this.$element.is(':visible')) {\n      return false;\n    }\n    var _this = this;\n\n    // Motion UI method of hiding\n    if (this.options.animationOut) {\n      if (this.options.overlay) {\n        Motion.animateOut(this.$overlay, 'fade-out');\n      }\n\n      Motion.animateOut(this.$element, this.options.animationOut, finishUp);\n    }\n    // jQuery method of hiding\n    else {\n      this.$element.hide(this.options.hideDelay);\n\n      if (this.options.overlay) {\n        this.$overlay.hide(0, finishUp);\n      }\n      else {\n        finishUp();\n      }\n    }\n\n    // Conditionals to remove extra event listeners added on open\n    if (this.options.closeOnEsc) {\n      $(window).off('keydown.zf.reveal');\n    }\n\n    if (!this.options.overlay && this.options.closeOnClick) {\n      $('body').off('click.zf.reveal');\n    }\n\n    this.$element.off('keydown.zf.reveal');\n\n    function finishUp() {\n\n      // Get the current top before the modal is closed and restore the scroll after.\n      // TODO: use component properties instead of HTML properties\n      // See https://github.com/zurb/foundation-sites/pull/10786\n      var scrollTop = parseInt($(\"html\").css(\"top\"));\n\n      if ($('.reveal:visible').length  === 0) {\n        _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n      }\n\n      Keyboard.releaseFocus(_this.$element);\n\n      _this.$element.attr('aria-hidden', true);\n\n      _this._enableScroll(scrollTop);\n\n      /**\n      * Fires when the modal is done closing.\n      * @event Reveal#closed\n      */\n      _this.$element.trigger('closed.zf.reveal');\n    }\n\n    /**\n    * Resets the modal content\n    * This prevents a running video to keep going in the background\n    */\n    if (this.options.resetOnClose) {\n      this.$element.html(this.$element.html());\n    }\n\n    this.isActive = false;\n    // If deepLink and we did not switched to an other modal...\n    if (_this.options.deepLink && window.location.hash === `#${this.id}`) {\n      // Remove the history hash\n      if (window.history.replaceState) {\n        const urlWithoutHash = window.location.pathname + window.location.search;\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', urlWithoutHash); // remove the hash\n        } else {\n          window.history.replaceState('', document.title, urlWithoutHash);\n        }\n      } else {\n        window.location.hash = '';\n      }\n    }\n\n    this.$activeAnchor.focus();\n  }\n\n  /**\n   * Toggles the open/closed state of a modal.\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.close();\n    } else {\n      this.open();\n    }\n  };\n\n  /**\n   * Destroys an instance of a modal.\n   * @function\n   */\n  _destroy() {\n    if (this.options.overlay) {\n      this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()\n      this.$overlay.hide().off().remove();\n    }\n    this.$element.hide().off();\n    this.$anchor.off('.zf');\n    $(window).off(`.zf.reveal:${this.id}`)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n\n    if ($('.reveal:visible').length  === 0) {\n      this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n    }\n  };\n}\n\nReveal.defaults = {\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationIn: '',\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationOut: '',\n  /**\n   * Time, in ms, to delay the opening of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  showDelay: 0,\n  /**\n   * Time, in ms, to delay the closing of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hideDelay: 0,\n  /**\n   * Allows a click on the body/overlay to close the modal.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allows the modal to close if the user presses the `ESCAPE` key.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnEsc: true,\n  /**\n   * If true, allows multiple modals to be displayed at once.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multipleOpened: false,\n  /**\n   * Distance, in pixels, the modal should push down from the top of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  vOffset: 'auto',\n  /**\n   * Distance, in pixels, the modal should push in from the side of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  hOffset: 'auto',\n  /**\n   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  fullScreen: false,\n  /**\n   * Allows the modal to generate an overlay div, which will cover the view when modal opens.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  overlay: true,\n  /**\n   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  resetOnClose: false,\n  /**\n   * Link the location hash to the modal.\n   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open modal\n   * @option\n   * @default false\n   */\n  updateHistory: false,\n    /**\n   * Allows the modal to append to custom div.\n   * @option\n   * @type {string}\n   * @default \"body\"\n   */\n  appendTo: \"body\",\n  /**\n   * Allows adding additional class names to the reveal overlay.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  additionalOverlayClasses: ''\n};\n\nexport {Reveal};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Move } from './foundation.util.motion';\nimport { GetYoDigits, rtl as Rtl } from './foundation.core.utils';\n\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Touch } from './foundation.util.touch';\n\nimport { Triggers } from './foundation.util.triggers';\n/**\n * Slider module.\n * @module foundation.slider\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n */\n\nclass Slider extends Plugin {\n  /**\n   * Creates a new instance of a slider control.\n   * @class\n   * @name Slider\n   * @param {jQuery} element - jQuery object to make into a slider control.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Slider.defaults, this.$element.data(), options);\n    this.className = 'Slider'; // ie9 back compat\n\n  // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.\n    Touch.init($);\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Slider', {\n      'ltr': {\n        'ARROW_RIGHT': 'increase',\n        'ARROW_UP': 'increase',\n        'ARROW_DOWN': 'decrease',\n        'ARROW_LEFT': 'decrease',\n        'SHIFT_ARROW_RIGHT': 'increase_fast',\n        'SHIFT_ARROW_UP': 'increase_fast',\n        'SHIFT_ARROW_DOWN': 'decrease_fast',\n        'SHIFT_ARROW_LEFT': 'decrease_fast',\n        'HOME': 'min',\n        'END': 'max'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'increase',\n        'ARROW_RIGHT': 'decrease',\n        'SHIFT_ARROW_LEFT': 'increase_fast',\n        'SHIFT_ARROW_RIGHT': 'decrease_fast'\n      }\n    });\n  }\n\n  /**\n   * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).\n   * @function\n   * @private\n   */\n  _init() {\n    this.inputs = this.$element.find('input');\n    this.handles = this.$element.find('[data-slider-handle]');\n\n    this.$handle = this.handles.eq(0);\n    this.$input = this.inputs.length ? this.inputs.eq(0) : $(`#${this.$handle.attr('aria-controls')}`);\n    this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);\n\n    var isDbl = false,\n        _this = this;\n    if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {\n      this.options.disabled = true;\n      this.$element.addClass(this.options.disabledClass);\n    }\n    if (!this.inputs.length) {\n      this.inputs = $().add(this.$input);\n      this.options.binding = true;\n    }\n\n    this._setInitAttr(0);\n\n    if (this.handles[1]) {\n      this.options.doubleSided = true;\n      this.$handle2 = this.handles.eq(1);\n      this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $(`#${this.$handle2.attr('aria-controls')}`);\n\n      if (!this.inputs[1]) {\n        this.inputs = this.inputs.add(this.$input2);\n      }\n      isDbl = true;\n\n      // this.$handle.triggerHandler('click.zf.slider');\n      this._setInitAttr(1);\n    }\n\n    // Set handle positions\n    this.setHandles();\n\n    this._events();\n  }\n\n  setHandles() {\n    if(this.handles[1]) {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, () => {\n        this._setHandlePos(this.$handle2, this.inputs.eq(1).val(), true);\n      });\n    } else {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);\n    }\n  }\n\n  _reflow() {\n    this.setHandles();\n  }\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)\n  */\n  _pctOfBar(value) {\n    var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start)\n\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    }\n\n    return pctOfBar.toFixed(2)\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value\n  */\n  _value(pctOfBar) {\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    }\n    var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);\n\n    return value\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function\n  */\n  _logTransform(value) {\n    return baseLog(this.options.nonLinearBase, ((value*(this.options.nonLinearBase-1))+1))\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function\n  */\n  _powTransform(value) {\n    return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1)\n  }\n\n  /**\n   * Sets the position of the selected handle and fill bar.\n   * @function\n   * @private\n   * @param {jQuery} $hndl - the selected handle to move.\n   * @param {Number} location - floating point between the start and end values of the slider bar.\n   * @param {Function} cb - callback function to fire on completion.\n   * @fires Slider#moved\n   * @fires Slider#changed\n   */\n  _setHandlePos($hndl, location, noInvert, cb) {\n    // don't move if the slider has been disabled since its initialization\n    if (this.$element.hasClass(this.options.disabledClass)) {\n      return;\n    }\n    //might need to alter that slightly for bars that will have odd number selections.\n    location = parseFloat(location);//on input change events, convert string to number...grumble.\n\n    // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max\n    if (location < this.options.start) { location = this.options.start; }\n    else if (location > this.options.end) { location = this.options.end; }\n\n    var isDbl = this.options.doubleSided;\n\n    //this is for single-handled vertical sliders, it adjusts the value to account for the slider being \"upside-down\"\n    //for click and drag events, it's weird due to the scale(-1, 1) css property\n    if (this.options.vertical && !noInvert) {\n      location = this.options.end - location;\n    }\n\n    if (isDbl) { //this block is to prevent 2 handles from crossing eachother. Could/should be improved.\n      if (this.handles.index($hndl) === 0) {\n        var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));\n        location = location >= h2Val ? h2Val - this.options.step : location;\n      } else {\n        var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));\n        location = location <= h1Val ? h1Val + this.options.step : location;\n      }\n    }\n\n    var _this = this,\n        vert = this.options.vertical,\n        hOrW = vert ? 'height' : 'width',\n        lOrT = vert ? 'top' : 'left',\n        handleDim = $hndl[0].getBoundingClientRect()[hOrW],\n        elemDim = this.$element[0].getBoundingClientRect()[hOrW],\n        //percentage of bar min/max value based on click or drag point\n        pctOfBar = this._pctOfBar(location),\n        //number of actual pixels to shift the handle, based on the percentage obtained above\n        pxToMove = (elemDim - handleDim) * pctOfBar,\n        //percentage of bar to shift the handle\n        movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);\n        //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value\n        location = parseFloat(location.toFixed(this.options.decimal));\n        // declare empty object for css adjustments, only used with 2 handled-sliders\n    var css = {};\n\n    this._setValues($hndl, location);\n\n    // TODO update to calculate based on values set to respective inputs??\n    if (isDbl) {\n      var isLeftHndl = this.handles.index($hndl) === 0,\n          //empty variable, will be used for min-height/width for fill bar\n          dim,\n          //percentage w/h of the handle compared to the slider bar\n          handlePct =  ~~(percent(handleDim, elemDim) * 100);\n      //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar\n      if (isLeftHndl) {\n        //left or top percentage value to apply to the fill bar.\n        css[lOrT] = `${movement}%`;\n        //calculate the new min-height/width for the fill bar.\n        dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;\n        //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider\n        //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.\n        if (cb && typeof cb === 'function') { cb(); }//this is only needed for the initialization of 2 handled sliders\n      } else {\n        //just caching the value of the left/bottom handle's left/top property\n        var handlePos = parseFloat(this.$handle[0].style[lOrT]);\n        //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0\n        //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself\n        dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start)/((this.options.end-this.options.start)/100) : handlePos) + handlePct;\n      }\n      // assign the min-height/width to our css object\n      css[`min-${hOrW}`] = `${dim}%`;\n    }\n\n    this.$element.one('finished.zf.animate', function() {\n                    /**\n                     * Fires when the handle is done moving.\n                     * @event Slider#moved\n                     */\n                    _this.$element.trigger('moved.zf.slider', [$hndl]);\n                });\n\n    //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.\n    var moveTime = this.$element.data('dragging') ? 1000/60 : this.options.moveTime;\n\n    Move(moveTime, $hndl, function() {\n      // adjusting the left/top property of the handle, based on the percentage calculated above\n      // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,\n      // fall back to next best guess.\n      if (isNaN(movement)) {\n        $hndl.css(lOrT, `${pctOfBar * 100}%`);\n      }\n      else {\n        $hndl.css(lOrT, `${movement}%`);\n      }\n\n      if (!_this.options.doubleSided) {\n        //if single-handled, a simple method to expand the fill bar\n        _this.$fill.css(hOrW, `${pctOfBar * 100}%`);\n      } else {\n        //otherwise, use the css object we created above\n        _this.$fill.css(css);\n      }\n    });\n\n\n    /**\n     * Fires when the value has not been change for a given time.\n     * @event Slider#changed\n     */\n    clearTimeout(_this.timeout);\n    _this.timeout = setTimeout(function(){\n      _this.$element.trigger('changed.zf.slider', [$hndl]);\n    }, _this.options.changedDelay);\n  }\n\n  /**\n   * Sets the initial attribute for the slider element.\n   * @function\n   * @private\n   * @param {Number} idx - index of the current handle/input to use.\n   */\n  _setInitAttr(idx) {\n    var initVal = (idx === 0 ? this.options.initialStart : this.options.initialEnd)\n    var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');\n    this.inputs.eq(idx).attr({\n      'id': id,\n      'max': this.options.end,\n      'min': this.options.start,\n      'step': this.options.step\n    });\n    this.inputs.eq(idx).val(initVal);\n    this.handles.eq(idx).attr({\n      'role': 'slider',\n      'aria-controls': id,\n      'aria-valuemax': this.options.end,\n      'aria-valuemin': this.options.start,\n      'aria-valuenow': initVal,\n      'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',\n      'tabindex': 0\n    });\n  }\n\n  /**\n   * Sets the input and `aria-valuenow` values for the slider element.\n   * @function\n   * @private\n   * @param {jQuery} $handle - the currently selected handle.\n   * @param {Number} val - floating point of the new value.\n   */\n  _setValues($handle, val) {\n    var idx = this.options.doubleSided ? this.handles.index($handle) : 0;\n    this.inputs.eq(idx).val(val);\n    $handle.attr('aria-valuenow', val);\n  }\n\n  /**\n   * Handles events on the slider element.\n   * Calculates the new location of the current handle.\n   * If there are two handles and the bar was clicked, it determines which handle to move.\n   * @function\n   * @private\n   * @param {Object} e - the `event` object passed from the listener.\n   * @param {jQuery} $handle - the current handle to calculate for, if selected.\n   * @param {Number} val - floating point number for the new value of the slider.\n   * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.\n   */\n  _handleEvent(e, $handle, val) {\n    var value, hasVal;\n    if (!val) {//click or drag events\n      e.preventDefault();\n      var _this = this,\n          vertical = this.options.vertical,\n          param = vertical ? 'height' : 'width',\n          direction = vertical ? 'top' : 'left',\n          eventOffset = vertical ? e.pageY : e.pageX,\n          halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,\n          barDim = this.$element[0].getBoundingClientRect()[param],\n          windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();\n\n\n      var elemOffset = this.$element.offset()[direction];\n\n      // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...\n      // best way to guess this is simulated is if clientY == pageY\n      if (e.clientY === e.pageY) { eventOffset = eventOffset + windowScroll; }\n      var eventFromBar = eventOffset - elemOffset;\n      var barXY;\n      if (eventFromBar < 0) {\n        barXY = 0;\n      } else if (eventFromBar > barDim) {\n        barXY = barDim;\n      } else {\n        barXY = eventFromBar;\n      }\n      var offsetPct = percent(barXY, barDim);\n\n      value = this._value(offsetPct);\n\n      // turn everything around for RTL, yay math!\n      if (Rtl() && !this.options.vertical) {value = this.options.end - value;}\n\n      value = _this._adjustValue(null, value);\n      //boolean flag for the setHandlePos fn, specifically for vertical sliders\n      hasVal = false;\n\n      if (!$handle) {//figure out which handle it is, pass it to the next function.\n        var firstHndlPos = absPosition(this.$handle, direction, barXY, param),\n            secndHndlPos = absPosition(this.$handle2, direction, barXY, param);\n            $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;\n      }\n\n    } else {//change event on input\n      value = this._adjustValue(null, val);\n      hasVal = true;\n    }\n\n    this._setHandlePos($handle, value, hasVal);\n  }\n\n  /**\n   * Adjustes value for handle in regard to step value. returns adjusted value\n   * @function\n   * @private\n   * @param {jQuery} $handle - the selected handle.\n   * @param {Number} value - value to adjust. used if $handle is falsy\n   */\n  _adjustValue($handle, value) {\n    var val,\n      step = this.options.step,\n      div = parseFloat(step/2),\n      left, prev_val, next_val;\n    if (!!$handle) {\n      val = parseFloat($handle.attr('aria-valuenow'));\n    }\n    else {\n      val = value;\n    }\n    if (val >= 0) {\n      left = val % step;\n    } else {\n      left = step + (val % step);\n    }\n    prev_val = val - left;\n    next_val = prev_val + step;\n    if (left === 0) {\n      return val;\n    }\n    val = val >= prev_val + div ? next_val : prev_val;\n    return val;\n  }\n\n  /**\n   * Adds event listeners to the slider elements.\n   * @function\n   * @private\n   */\n  _events() {\n    this._eventsForHandle(this.$handle);\n    if(this.handles[1]) {\n      this._eventsForHandle(this.$handle2);\n    }\n  }\n\n\n  /**\n   * Adds event listeners a particular handle\n   * @function\n   * @private\n   * @param {jQuery} $handle - the current handle to apply listeners to.\n   */\n  _eventsForHandle($handle) {\n    var _this = this,\n        curHandle,\n        timer;\n\n      const handleChangeEvent = function(e) {\n        const idx = _this.inputs.index($(this));\n        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());\n      };\n\n      // IE only triggers the change event when the input loses focus which strictly follows the HTML specification\n      // listen for the enter key and trigger a change\n      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events\n      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {\n        if(e.keyCode == 13) handleChangeEvent.call(this, e);\n      });\n\n      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);\n\n      if (this.options.clickSelect) {\n        this.$element.off('click.zf.slider').on('click.zf.slider', function(e) {\n          if (_this.$element.data('dragging')) { return false; }\n\n          if (!$(e.target).is('[data-slider-handle]')) {\n            if (_this.options.doubleSided) {\n              _this._handleEvent(e);\n            } else {\n              _this._handleEvent(e, _this.$handle);\n            }\n          }\n        });\n      }\n\n    if (this.options.draggable) {\n      this.handles.addTouch();\n\n      var $body = $('body');\n      $handle\n        .off('mousedown.zf.slider')\n        .on('mousedown.zf.slider', function(e) {\n          $handle.addClass('is-dragging');\n          _this.$fill.addClass('is-dragging');//\n          _this.$element.data('dragging', true);\n\n          curHandle = $(e.currentTarget);\n\n          $body.on('mousemove.zf.slider', function(e) {\n            e.preventDefault();\n            _this._handleEvent(e, curHandle);\n\n          }).on('mouseup.zf.slider', function(e) {\n            _this._handleEvent(e, curHandle);\n\n            $handle.removeClass('is-dragging');\n            _this.$fill.removeClass('is-dragging');\n            _this.$element.data('dragging', false);\n\n            $body.off('mousemove.zf.slider mouseup.zf.slider');\n          });\n      })\n      // prevent events triggered by touch\n      .on('selectstart.zf.slider touchmove.zf.slider', function(e) {\n        e.preventDefault();\n      });\n    }\n\n    $handle.off('keydown.zf.slider').on('keydown.zf.slider', function(e) {\n      var _$handle = $(this),\n          idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,\n          oldValue = parseFloat(_this.inputs.eq(idx).val()),\n          newValue;\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Slider', {\n        decrease: function() {\n          newValue = oldValue - _this.options.step;\n        },\n        increase: function() {\n          newValue = oldValue + _this.options.step;\n        },\n        decrease_fast: function() {\n          newValue = oldValue - _this.options.step * 10;\n        },\n        increase_fast: function() {\n          newValue = oldValue + _this.options.step * 10;\n        },\n        min: function() {\n          newValue = _this.options.start;\n        },\n        max: function() {\n          newValue = _this.options.end;\n        },\n        handled: function() { // only set handle pos when event was handled specially\n          e.preventDefault();\n          _this._setHandlePos(_$handle, newValue, true);\n        }\n      });\n      /*if (newValue) { // if pressed key has special function, update value\n        e.preventDefault();\n        _this._setHandlePos(_$handle, newValue);\n      }*/\n    });\n  }\n\n  /**\n   * Destroys the slider plugin.\n   */\n  _destroy() {\n    this.handles.off('.zf.slider');\n    this.inputs.off('.zf.slider');\n    this.$element.off('.zf.slider');\n\n    clearTimeout(this.timeout);\n  }\n}\n\nSlider.defaults = {\n  /**\n   * Minimum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  start: 0,\n  /**\n   * Maximum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  end: 100,\n  /**\n   * Minimum value change per change event.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  step: 1,\n  /**\n   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  initialStart: 0,\n  /**\n   * Value at which the right handle/second input should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  initialEnd: 100,\n  /**\n   * Allows the input to be located outside the container and visible. Set to by the JS\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  binding: false,\n  /**\n   * Allows the user to click/tap on the slider bar to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickSelect: true,\n  /**\n   * Set to true and use the `vertical` class to change alignment to vertical.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  vertical: false,\n  /**\n   * Allows the user to drag the slider handle(s) to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  draggable: true,\n  /**\n   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disabled: false,\n  /**\n   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  doubleSided: false,\n  /**\n   * Potential future feature.\n   */\n  // steps: 100,\n  /**\n   * Number of decimal places the plugin should go to for floating point precision.\n   * @option\n   * @type {number}\n   * @default 2\n   */\n  decimal: 2,\n  /**\n   * Time delay for dragged elements.\n   */\n  // dragDelay: 0,\n  /**\n   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  moveTime: 200,//update this if changing the transition time in the sass\n  /**\n   * Class applied to disabled sliders.\n   * @option\n   * @type {string}\n   * @default 'disabled'\n   */\n  disabledClass: 'disabled',\n  /**\n   * Will invert the default layout for a vertical<span data-tooltip title=\"who would do this???\"> </span>slider.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  invertVertical: false,\n  /**\n   * Milliseconds before the `changed.zf-slider` event is triggered after value change.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  changedDelay: 500,\n  /**\n  * Basevalue for non-linear sliders\n  * @option\n  * @type {number}\n  * @default 5\n  */\n  nonLinearBase: 5,\n  /**\n  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.\n  * @option\n  * @type {string}\n  * @default 'linear'\n  */\n  positionValueFunction: 'linear',\n};\n\nfunction percent(frac, num) {\n  return (frac / num);\n}\nfunction absPosition($handle, dir, clickPos, param) {\n  return Math.abs(($handle.position()[dir] + ($handle[param]() / 2)) - clickPos);\n}\nfunction baseLog(base, value) {\n  return Math.log(value)/Math.log(base)\n}\n\nexport {Slider};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass Sticky extends Plugin {\n  /**\n   * Creates a new instance of a sticky thing.\n   * @class\n   * @name Sticky\n   * @param {jQuery} element - jQuery object to make sticky.\n   * @param {Object} options - options object passed when creating the element programmatically.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);\n    this.className = 'Sticky'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var $parent = this.$element.parent('[data-sticky-container]'),\n        id = this.$element[0].id || GetYoDigits(6, 'sticky'),\n        _this = this;\n\n    if($parent.length){\n      this.$container = $parent;\n    } else {\n      this.wasWrapped = true;\n      this.$element.wrap(this.options.container);\n      this.$container = this.$element.parent();\n    }\n    this.$container.addClass(this.options.containerClass);\n\n    this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });\n    if (this.options.anchor !== '') {\n        $('#' + _this.options.anchor).attr({ 'data-mutate': id });\n    }\n\n    this.scrollCount = this.options.checkEvery;\n    this.isStuck = false;\n    this.onLoadListener = onLoad($(window), function () {\n      //We calculate the container height to have correct values for anchor points offset calculation.\n      _this.containerHeight = _this.$element.css(\"display\") == \"none\" ? 0 : _this.$element[0].getBoundingClientRect().height;\n      _this.$container.css('height', _this.containerHeight);\n      _this.elemHeight = _this.containerHeight;\n      if (_this.options.anchor !== '') {\n        _this.$anchor = $('#' + _this.options.anchor);\n      } else {\n        _this._parsePoints();\n      }\n\n      _this._setSizes(function () {\n        var scroll = window.pageYOffset;\n        _this._calc(false, scroll);\n        //Unstick the element will ensure that proper classes are set.\n        if (!_this.isStuck) {\n          _this._removeSticky((scroll >= _this.topPoint) ? false : true);\n        }\n      });\n      _this._events(id.split('-').reverse().join('-'));\n    });\n  }\n\n  /**\n   * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.\n   * @function\n   * @private\n   */\n  _parsePoints() {\n    var top = this.options.topAnchor == \"\" ? 1 : this.options.topAnchor,\n        btm = this.options.btmAnchor== \"\" ? document.documentElement.scrollHeight : this.options.btmAnchor,\n        pts = [top, btm],\n        breaks = {};\n    for (var i = 0, len = pts.length; i < len && pts[i]; i++) {\n      var pt;\n      if (typeof pts[i] === 'number') {\n        pt = pts[i];\n      } else {\n        var place = pts[i].split(':'),\n            anchor = $(`#${place[0]}`);\n\n        pt = anchor.offset().top;\n        if (place[1] && place[1].toLowerCase() === 'bottom') {\n          pt += anchor[0].getBoundingClientRect().height;\n        }\n      }\n      breaks[i] = pt;\n    }\n\n\n    this.points = breaks;\n    return;\n  }\n\n  /**\n   * Adds event handlers for the scrolling element.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _events(id) {\n    var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n    if (this.isOn) { return; }\n    if (this.canStick) {\n      this.isOn = true;\n      $(window).off(scrollListener)\n               .on(scrollListener, function(e) {\n                 if (_this.scrollCount === 0) {\n                   _this.scrollCount = _this.options.checkEvery;\n                   _this._setSizes(function() {\n                     _this._calc(false, window.pageYOffset);\n                   });\n                 } else {\n                   _this.scrollCount--;\n                   _this._calc(false, window.pageYOffset);\n                 }\n              });\n    }\n\n    this.$element.off('resizeme.zf.trigger')\n                 .on('resizeme.zf.trigger', function(e, el) {\n                    _this._eventsHandler(id);\n    });\n\n    this.$element.on('mutateme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n    });\n\n    if(this.$anchor) {\n      this.$anchor.on('mutateme.zf.trigger', function (e, el) {\n          _this._eventsHandler(id);\n      });\n    }\n  }\n\n  /**\n   * Handler for events.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _eventsHandler(id) {\n       var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n\n       _this._setSizes(function() {\n       _this._calc(false);\n       if (_this.canStick) {\n         if (!_this.isOn) {\n           _this._events(id);\n         }\n       } else if (_this.isOn) {\n         _this._pauseListeners(scrollListener);\n       }\n     });\n  }\n\n  /**\n   * Removes event handlers for scroll and change events on anchor.\n   * @fires Sticky#pause\n   * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`\n   */\n  _pauseListeners(scrollListener) {\n    this.isOn = false;\n    $(window).off(scrollListener);\n\n    /**\n     * Fires when the plugin is paused due to resize event shrinking the view.\n     * @event Sticky#pause\n     * @private\n     */\n     this.$element.trigger('pause.zf.sticky');\n  }\n\n  /**\n   * Called on every `scroll` event and on `_init`\n   * fires functions based on booleans and cached values\n   * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.\n   * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.\n   */\n  _calc(checkSizes, scroll) {\n    if (checkSizes) { this._setSizes(); }\n\n    if (!this.canStick) {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n      return false;\n    }\n\n    if (!scroll) { scroll = window.pageYOffset; }\n\n    if (scroll >= this.topPoint) {\n      if (scroll <= this.bottomPoint) {\n        if (!this.isStuck) {\n          this._setSticky();\n        }\n      } else {\n        if (this.isStuck) {\n          this._removeSticky(false);\n        }\n      }\n    } else {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n    }\n  }\n\n  /**\n   * Causes the $element to become stuck.\n   * Adds `position: fixed;`, and helper classes.\n   * @fires Sticky#stuckto\n   * @function\n   * @private\n   */\n  _setSticky() {\n    var _this = this,\n        stickTo = this.options.stickTo,\n        mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickTo === 'top' ? 'bottom' : 'top',\n        css = {};\n\n    css[mrgn] = `${this.options[mrgn]}em`;\n    css[stickTo] = 0;\n    css[notStuckTo] = 'auto';\n    this.isStuck = true;\n    this.$element.removeClass(`is-anchored is-at-${notStuckTo}`)\n                 .addClass(`is-stuck is-at-${stickTo}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become `position: fixed;`\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`\n                  * @event Sticky#stuckto\n                  */\n                 .trigger(`sticky.zf.stuckto:${stickTo}`);\n    this.$element.on(\"transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd\", function() {\n      _this._setSizes();\n    });\n  }\n\n  /**\n   * Causes the $element to become unstuck.\n   * Removes `position: fixed;`, and helper classes.\n   * Adds other helper classes.\n   * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.\n   * @fires Sticky#unstuckfrom\n   * @private\n   */\n  _removeSticky(isTop) {\n    var stickTo = this.options.stickTo,\n        stickToTop = stickTo === 'top',\n        css = {},\n        anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,\n        mrgn = stickToTop ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickToTop ? 'bottom' : 'top',\n        topOrBottom = isTop ? 'top' : 'bottom';\n\n    css[mrgn] = 0;\n\n    css['bottom'] = 'auto';\n    if(isTop) {\n      css['top'] = 0;\n    } else {\n      css['top'] = anchorPt;\n    }\n\n    this.isStuck = false;\n    this.$element.removeClass(`is-stuck is-at-${stickTo}`)\n                 .addClass(`is-anchored is-at-${topOrBottom}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become anchored.\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`\n                  * @event Sticky#unstuckfrom\n                  */\n                 .trigger(`sticky.zf.unstuckfrom:${topOrBottom}`);\n  }\n\n  /**\n   * Sets the $element and $container sizes for plugin.\n   * Calls `_setBreakPoints`.\n   * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.\n   * @private\n   */\n  _setSizes(cb) {\n    this.canStick = MediaQuery.is(this.options.stickyOn);\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n    }\n    var _this = this,\n        newElemWidth = this.$container[0].getBoundingClientRect().width,\n        comp = window.getComputedStyle(this.$container[0]),\n        pdngl = parseInt(comp['padding-left'], 10),\n        pdngr = parseInt(comp['padding-right'], 10);\n\n    if (this.$anchor && this.$anchor.length) {\n      this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;\n    } else {\n      this._parsePoints();\n    }\n\n    this.$element.css({\n      'max-width': `${newElemWidth - pdngl - pdngr}px`\n    });\n\n    var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;\n    if (this.$element.css(\"display\") == \"none\") {\n      newContainerHeight = 0;\n    }\n    this.containerHeight = newContainerHeight;\n    this.$container.css({\n      height: newContainerHeight\n    });\n    this.elemHeight = newContainerHeight;\n\n    if (!this.isStuck) {\n      if (this.$element.hasClass('is-at-bottom')) {\n        var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;\n        this.$element.css('top', anchorPt);\n      }\n    }\n\n    this._setBreakPoints(newContainerHeight, function() {\n      if (cb && typeof cb === 'function') { cb(); }\n    });\n  }\n\n  /**\n   * Sets the upper and lower breakpoints for the element to become sticky/unsticky.\n   * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.\n   * @param {Function} cb - optional callback function to be called on completion.\n   * @private\n   */\n  _setBreakPoints(elemHeight, cb) {\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n      else { return false; }\n    }\n    var mTop = emCalc(this.options.marginTop),\n        mBtm = emCalc(this.options.marginBottom),\n        topPoint = this.points ? this.points[0] : this.$anchor.offset().top,\n        bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,\n        // topPoint = this.$anchor.offset().top || this.points[0],\n        // bottomPoint = topPoint + this.anchorHeight || this.points[1],\n        winHeight = window.innerHeight;\n\n    if (this.options.stickTo === 'top') {\n      topPoint -= mTop;\n      bottomPoint -= (elemHeight + mTop);\n    } else if (this.options.stickTo === 'bottom') {\n      topPoint -= (winHeight - (elemHeight + mBtm));\n      bottomPoint -= (winHeight - mBtm);\n    } else {\n      //this would be the stickTo: both option... tricky\n    }\n\n    this.topPoint = topPoint;\n    this.bottomPoint = bottomPoint;\n\n    if (cb && typeof cb === 'function') { cb(); }\n  }\n\n  /**\n   * Destroys the current sticky element.\n   * Resets the element to the top position first.\n   * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.\n   * @function\n   */\n  _destroy() {\n    this._removeSticky(true);\n\n    this.$element.removeClass(`${this.options.stickyClass} is-anchored is-at-top`)\n                 .css({\n                   height: '',\n                   top: '',\n                   bottom: '',\n                   'max-width': ''\n                 })\n                 .off('resizeme.zf.trigger')\n                 .off('mutateme.zf.trigger');\n    if (this.$anchor && this.$anchor.length) {\n      this.$anchor.off('change.zf.sticky');\n    }\n    if (this.scrollListener) $(window).off(this.scrollListener)\n    if (this.onLoadListener) $(window).off(this.onLoadListener)\n\n    if (this.wasWrapped) {\n      this.$element.unwrap();\n    } else {\n      this.$container.removeClass(this.options.containerClass)\n                     .css({\n                       height: ''\n                     });\n    }\n  }\n}\n\nSticky.defaults = {\n  /**\n   * Customizable container template. Add your own classes for styling and sizing.\n   * @option\n   * @type {string}\n   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'\n   */\n  container: '<div data-sticky-container></div>',\n  /**\n   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default 'top'\n   */\n  stickTo: 'top',\n  /**\n   * If anchored to a single element, the id of that element.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  anchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the top anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  topAnchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the bottom anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  btmAnchor: '',\n  /**\n   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginTop: 1,\n  /**\n   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginBottom: 1,\n  /**\n   * Breakpoint string that is the minimum screen size an element should become sticky.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  stickyOn: 'medium',\n  /**\n   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.\n   * @option\n   * @type {string}\n   * @default 'sticky'\n   */\n  stickyClass: 'sticky',\n  /**\n   * Class applied to sticky container. Foundation defaults to `sticky-container`.\n   * @option\n   * @type {string}\n   * @default 'sticky-container'\n   */\n  containerClass: 'sticky-container',\n  /**\n   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.\n   * @option\n   * @type {number}\n   * @default -1\n   */\n  checkEvery: -1\n};\n\n/**\n * Helper function to calculate em values\n * @param Number {em} - number of em's to calculate into pixels\n */\nfunction emCalc(em) {\n  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;\n}\n\nexport {Sticky};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { Plugin } from './foundation.core.plugin';\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.imageLoader if tabs contain images\n */\n\nclass Tabs extends Plugin {\n  /**\n   * Creates a new instance of tabs.\n   * @class\n   * @name Tabs\n   * @fires Tabs#init\n   * @param {jQuery} element - jQuery object to make into tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);\n    this.className = 'Tabs'; // ie9 back compat\n\n    this._init();\n    Keyboard.register('Tabs', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'previous',\n      'ARROW_DOWN': 'next',\n      'ARROW_LEFT': 'previous'\n      // 'TAB': 'next',\n      // 'SHIFT_TAB': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.\n   * @private\n   */\n  _init() {\n    var _this = this;\n    this._isInitializing = true;\n\n    this.$element.attr({'role': 'tablist'});\n    this.$tabTitles = this.$element.find(`.${this.options.linkClass}`);\n    this.$tabContent = $(`[data-tabs-content=\"${this.$element[0].id}\"]`);\n\n    this.$tabTitles.each(function(){\n      var $elem = $(this),\n          $link = $elem.find('a'),\n          isActive = $elem.hasClass(`${_this.options.linkActiveClass}`),\n          hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),\n          linkId = $link[0].id ? $link[0].id : `${hash}-label`,\n          $tabContent = $(`#${hash}`);\n\n      $elem.attr({'role': 'presentation'});\n\n      $link.attr({\n        'role': 'tab',\n        'aria-controls': hash,\n        'aria-selected': isActive,\n        'id': linkId,\n        'tabindex': isActive ? '0' : '-1'\n      });\n\n      $tabContent.attr({\n        'role': 'tabpanel',\n        'aria-labelledby': linkId\n      });\n\n      // Save up the initial hash to return to it later when going back in history\n      if (isActive) {\n        _this._initialAnchor = `#${hash}`;\n      }\n\n      if(!isActive) {\n        $tabContent.attr('aria-hidden', 'true');\n      }\n\n      if(isActive && _this.options.autoFocus){\n        _this.onLoadListener = onLoad($(window), function() {\n          $('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, () => {\n            $link.focus();\n          });\n        });\n      }\n    });\n\n    if(this.options.matchHeight) {\n      var $images = this.$tabContent.find('img');\n\n      if ($images.length) {\n        onImagesLoaded($images, this._setHeight.bind(this));\n      } else {\n        this._setHeight();\n      }\n    }\n\n     // Current context-bound function to open tabs on page load or history hashchange\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find('[href$=\"'+anchor+'\"]');\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, select it\n      if ($anchor && $anchor.length && $link && $link.length) {\n        this.selectTab($anchor, true);\n      }\n      // Otherwise, collapse everything\n      else {\n        this._collapse();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          var offset = this.$element.offset();\n          $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Tabs#deeplink\n         */\n        this.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the tabs.\n   * @private\n   */\n  _events() {\n    this._addKeyHandler();\n    this._addClickHandler();\n    this._setHeightMqHandler = null;\n\n    if (this.options.matchHeight) {\n      this._setHeightMqHandler = this._setHeight.bind(this);\n\n      $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);\n    }\n\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Adds click handlers for items within the tabs.\n   * @private\n   */\n  _addClickHandler() {\n    var _this = this;\n\n    this.$element\n      .off('click.zf.tabs')\n      .on('click.zf.tabs', `.${this.options.linkClass}`, function(e){\n        e.preventDefault();\n        e.stopPropagation();\n        _this._handleTabChange($(this));\n      });\n  }\n\n  /**\n   * Adds keyboard event handlers for items within the tabs.\n   * @private\n   */\n  _addKeyHandler() {\n    var _this = this;\n\n    this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function(e){\n      if (e.which === 9) return;\n\n\n      var $element = $(this),\n        $elements = $element.parent('ul').children('li'),\n        $prevElement,\n        $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          if (_this.options.wrapOnKeys) {\n            $prevElement = i === 0 ? $elements.last() : $elements.eq(i-1);\n            $nextElement = i === $elements.length -1 ? $elements.first() : $elements.eq(i+1);\n          } else {\n            $prevElement = $elements.eq(Math.max(0, i-1));\n            $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          }\n          return;\n        }\n      });\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Tabs', {\n        open: function() {\n          $element.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($element);\n        },\n        previous: function() {\n          $prevElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($prevElement);\n        },\n        next: function() {\n          $nextElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($nextElement);\n        },\n        handled: function() {\n          e.stopPropagation();\n          e.preventDefault();\n        }\n      });\n    });\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.\n   * @param {jQuery} $target - Tab to open.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @fires Tabs#change\n   * @function\n   */\n  _handleTabChange($target, historyHandled) {\n\n    // With `activeCollapse`, if the target is the active Tab, collapse it.\n    if ($target.hasClass(`${this.options.linkActiveClass}`)) {\n        if(this.options.activeCollapse) {\n            this._collapse();\n        }\n        return;\n    }\n\n    var $oldTab = this.$element.\n          find(`.${this.options.linkClass}.${this.options.linkActiveClass}`),\n          $tabLink = $target.find('[role=\"tab\"]'),\n          target = $tabLink.attr('data-tabs-target'),\n          anchor = target && target.length ? `#${target}` : $tabLink[0].hash,\n          $targetContent = this.$tabContent.find(anchor);\n\n    //close old tab\n    this._collapseTab($oldTab);\n\n    //open new tab\n    this._openTab($target);\n\n    //either replace or update browser history\n    if (this.options.deepLink && !historyHandled) {\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n\n    /**\n     * Fires when the plugin has successfully changed tabs.\n     * @event Tabs#change\n     */\n    this.$element.trigger('change.zf.tabs', [$target, $targetContent]);\n\n    //fire to children a mutation event\n    $targetContent.find(\"[data-mutate]\").trigger(\"mutateme.zf.trigger\");\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to open.\n   * @function\n   */\n  _openTab($target) {\n      var $tabLink = $target.find('[role=\"tab\"]'),\n          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),\n          $targetContent = this.$tabContent.find(`#${hash}`);\n\n      $target.addClass(`${this.options.linkActiveClass}`);\n\n      $tabLink.attr({\n        'aria-selected': 'true',\n        'tabindex': '0'\n      });\n\n      $targetContent\n        .addClass(`${this.options.panelActiveClass}`).removeAttr('aria-hidden');\n  }\n\n  /**\n   * Collapses `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to collapse.\n   * @function\n   */\n  _collapseTab($target) {\n    var $target_anchor = $target\n      .removeClass(`${this.options.linkActiveClass}`)\n      .find('[role=\"tab\"]')\n      .attr({\n        'aria-selected': 'false',\n        'tabindex': -1\n      });\n\n    $(`#${$target_anchor.attr('aria-controls')}`)\n      .removeClass(`${this.options.panelActiveClass}`)\n      .attr({ 'aria-hidden': 'true' })\n  }\n\n  /**\n   * Collapses the active Tab.\n   * @fires Tabs#collapse\n   * @function\n   */\n  _collapse() {\n    var $activeTab = this.$element.find(`.${this.options.linkClass}.${this.options.linkActiveClass}`);\n\n    if ($activeTab.length) {\n      this._collapseTab($activeTab);\n\n      /**\n      * Fires when the plugin has successfully collapsed tabs.\n      * @event Tabs#collapse\n      */\n      this.$element.trigger('collapse.zf.tabs', [$activeTab]);\n    }\n  }\n\n  /**\n   * Public method for selecting a content pane to display.\n   * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @function\n   */\n  selectTab(elem, historyHandled) {\n    var idStr;\n\n    if (typeof elem === 'object') {\n      idStr = elem[0].id;\n    } else {\n      idStr = elem;\n    }\n\n    if (idStr.indexOf('#') < 0) {\n      idStr = `#${idStr}`;\n    }\n\n    var $target = this.$tabTitles.has(`[href$=\"${idStr}\"]`);\n\n    this._handleTabChange($target, historyHandled);\n  };\n\n  /**\n   * Sets the height of each panel to the height of the tallest panel.\n   * If enabled in options, gets called on media query change.\n   * If loading content via external source, can be called directly or with _reflow.\n   * If enabled with `data-match-height=\"true\"`, tabs sets to equal height\n   * @function\n   * @private\n   */\n  _setHeight() {\n    var max = 0,\n        _this = this; // Lock down the `this` value for the root tabs object\n\n    this.$tabContent\n      .find(`.${this.options.panelClass}`)\n      .css('height', '')\n      .each(function() {\n\n        var panel = $(this),\n            isActive = panel.hasClass(`${_this.options.panelActiveClass}`); // get the options from the parent instead of trying to get them from the child\n\n        if (!isActive) {\n          panel.css({'visibility': 'hidden', 'display': 'block'});\n        }\n\n        var temp = this.getBoundingClientRect().height;\n\n        if (!isActive) {\n          panel.css({\n            'visibility': '',\n            'display': ''\n          });\n        }\n\n        max = temp > max ? temp : max;\n      })\n      .css('height', `${max}px`);\n  }\n\n  /**\n   * Destroys an instance of tabs.\n   * @fires Tabs#destroyed\n   */\n  _destroy() {\n    this.$element\n      .find(`.${this.options.linkClass}`)\n      .off('.zf.tabs').hide().end()\n      .find(`.${this.options.panelClass}`)\n      .hide();\n\n    if (this.options.matchHeight) {\n      if (this._setHeightMqHandler != null) {\n         $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);\n      }\n    }\n\n    if (this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n    if (this.onLoadListener) {\n      $(window).off(this.onLoadListener);\n    }\n  }\n}\n\nTabs.defaults = {\n  /**\n   * Link the location hash to the active pane.\n   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open tab\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n   * Allows the window to scroll to content of active pane on load.\n   * Not recommended if more than one tab panel per page.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows keyboard input to 'wrap' around the tab links.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  wrapOnKeys: true,\n\n  /**\n   * Allows the tab content panes to match heights if set to true.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  matchHeight: false,\n\n  /**\n   * Allows active tabs to collapse when clicked.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  activeCollapse: false,\n\n  /**\n   * Class applied to `li`'s in tab link list.\n   * @option\n   * @type {string}\n   * @default 'tabs-title'\n   */\n  linkClass: 'tabs-title',\n\n  /**\n   * Class applied to the active `li` in tab link list.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  linkActiveClass: 'is-active',\n\n  /**\n   * Class applied to the content containers.\n   * @option\n   * @type {string}\n   * @default 'tabs-panel'\n   */\n  panelClass: 'tabs-panel',\n\n  /**\n   * Class applied to the active content container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  panelActiveClass: 'is-active'\n};\n\nexport {Tabs};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { RegExpEscape } from './foundation.core.utils';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nclass Toggler extends Plugin {\n  /**\n   * Creates a new instance of Toggler.\n   * @class\n   * @name Toggler\n   * @fires Toggler#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Toggler.defaults, element.data(), options);\n    this.className = '';\n    this.className = 'Toggler'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.\n   * @function\n   * @private\n   */\n  _init() {\n    var input;\n    // Parse animation classes if they were set\n    if (this.options.animate) {\n      input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n    // Otherwise, parse toggle class\n    else {\n      input = this.$element.data('toggler');\n      // Allow for a . at the beginning of the string\n      this.className = input[0] === '.' ? input.slice(1) : input;\n    }\n\n    // Add ARIA attributes to triggers:\n    var id = this.$element[0].id,\n      $triggers = $(`[data-open~=\"${id}\"], [data-close~=\"${id}\"], [data-toggle~=\"${id}\"]`);\n\n    // - aria-expanded: according to the element visibility.\n    $triggers.attr('aria-expanded', !this.$element.is(':hidden'));\n    // - aria-controls: adding the element id to it if not already in it.\n    $triggers.each((index, trigger) => {\n      const $trigger = $(trigger);\n      const controls = $trigger.attr('aria-controls') || '';\n\n      const containsId = new RegExp(`\\\\b${RegExpEscape(id)}\\\\b`).test(controls);\n      if (!containsId) $trigger.attr('aria-controls', controls ? `${controls} ${id}` : id);\n    });\n  }\n\n  /**\n   * Initializes events for the toggle trigger.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));\n  }\n\n  /**\n   * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was \"on\" or \"off\".\n   * @function\n   * @fires Toggler#on\n   * @fires Toggler#off\n   */\n  toggle() {\n    this[ this.options.animate ? '_toggleAnimate' : '_toggleClass']();\n  }\n\n  _toggleClass() {\n    this.$element.toggleClass(this.className);\n\n    var isOn = this.$element.hasClass(this.className);\n    if (isOn) {\n      /**\n       * Fires if the target element has the class after a toggle.\n       * @event Toggler#on\n       */\n      this.$element.trigger('on.zf.toggler');\n    }\n    else {\n      /**\n       * Fires if the target element does not have the class after a toggle.\n       * @event Toggler#off\n       */\n      this.$element.trigger('off.zf.toggler');\n    }\n\n    this._updateARIA(isOn);\n    this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');\n  }\n\n  _toggleAnimate() {\n    var _this = this;\n\n    if (this.$element.is(':hidden')) {\n      Motion.animateIn(this.$element, this.animationIn, function() {\n        _this._updateARIA(true);\n        this.trigger('on.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n    else {\n      Motion.animateOut(this.$element, this.animationOut, function() {\n        _this._updateARIA(false);\n        this.trigger('off.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n  }\n\n  _updateARIA(isOn) {\n    var id = this.$element[0].id;\n    $(`[data-open=\"${id}\"], [data-close=\"${id}\"], [data-toggle=\"${id}\"]`)\n      .attr({\n        'aria-expanded': isOn ? true : false\n      });\n  }\n\n  /**\n   * Destroys the instance of Toggler on the element.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.toggler');\n  }\n}\n\nToggler.defaults = {\n  /**\n   * Tells the plugin if the element should animated when toggled.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport {Toggler};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Triggers } from './foundation.util.triggers';\nimport { Positionable } from './foundation.positionable';\n\n/**\n * Tooltip module.\n * @module foundation.tooltip\n * @requires foundation.util.box\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass Tooltip extends Positionable {\n  /**\n   * Creates a new instance of a Tooltip.\n   * @class\n   * @name Tooltip\n   * @fires Tooltip#init\n   * @param {jQuery} element - jQuery object to attach a tooltip to.\n   * @param {Object} options - object to extend the default configuration.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);\n    this.className = 'Tooltip'; // ie9 back compat\n\n    this.isActive = false;\n    this.isClick = false;\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');\n\n    this.options.tipText = this.options.tipText || this.$element.attr('title');\n    this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);\n\n    if (this.options.allowHtml) {\n      this.template.appendTo(document.body)\n        .html(this.options.tipText)\n        .hide();\n    } else {\n      this.template.appendTo(document.body)\n        .text(this.options.tipText)\n        .hide();\n    }\n\n    this.$element.attr({\n      'title': '',\n      'aria-describedby': elemId,\n      'data-yeti-box': elemId,\n      'data-toggle': elemId,\n      'data-resize': elemId\n    }).addClass(this.options.triggerClass);\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/\\b(top|left|right|bottom)\\b/g);\n    return position ? position[0] : 'top';\n  }\n\n  _getDefaultAlignment() {\n    return 'center';\n  }\n\n  _getHOffset() {\n    if(this.position === 'left' || this.position === 'right') {\n      return this.options.hOffset + this.options.tooltipWidth;\n    } else {\n      return this.options.hOffset\n    }\n  }\n\n  _getVOffset() {\n    if(this.position === 'top' || this.position === 'bottom') {\n      return this.options.vOffset + this.options.tooltipHeight;\n    } else {\n      return this.options.vOffset\n    }\n  }\n\n  /**\n   * builds the tooltip element, adds attributes, and returns the template.\n   * @private\n   */\n  _buildTemplate(id) {\n    var templateClasses = (`${this.options.tooltipClass} ${this.options.templateClasses}`).trim();\n    var $template =  $('<div></div>').addClass(templateClasses).attr({\n      'role': 'tooltip',\n      'aria-hidden': true,\n      'data-is-active': false,\n      'data-is-focus': false,\n      'id': id\n    });\n    return $template;\n  }\n\n  /**\n   * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.\n   * if the tooltip is larger than the screen width, default to full width - any user selected margin\n   * @private\n   */\n  _setPosition() {\n    super._setPosition(this.$element, this.template);\n  }\n\n  /**\n   * reveals the tooltip, and fires an event to close any other open tooltips on the page\n   * @fires Tooltip#closeme\n   * @fires Tooltip#show\n   * @function\n   */\n  show() {\n    if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {\n      // console.error('The screen is too small to display this tooltip');\n      return false;\n    }\n\n    var _this = this;\n    this.template.css('visibility', 'hidden').show();\n    this._setPosition();\n    this.template.removeClass('top bottom left right').addClass(this.position)\n    this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);\n\n    /**\n     * Fires to close all other open tooltips on the page\n     * @event Closeme#tooltip\n     */\n    this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));\n\n\n    this.template.attr({\n      'data-is-active': true,\n      'aria-hidden': false\n    });\n    _this.isActive = true;\n    // console.log(this.template);\n    this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function() {\n      //maybe do stuff?\n    });\n    /**\n     * Fires when the tooltip is shown\n     * @event Tooltip#show\n     */\n    this.$element.trigger('show.zf.tooltip');\n  }\n\n  /**\n   * Hides the current tooltip, and resets the positioning class if it was changed due to collision\n   * @fires Tooltip#hide\n   * @function\n   */\n  hide() {\n    // console.log('hiding', this.$element.data('yeti-box'));\n    var _this = this;\n    this.template.stop().attr({\n      'aria-hidden': true,\n      'data-is-active': false\n    }).fadeOut(this.options.fadeOutDuration, function() {\n      _this.isActive = false;\n      _this.isClick = false;\n    });\n    /**\n     * fires when the tooltip is hidden\n     * @event Tooltip#hide\n     */\n    this.$element.trigger('hide.zf.tooltip');\n  }\n\n  /**\n   * adds event listeners for the tooltip and its anchor\n   * TODO combine some of the listeners like focus and mouseenter, etc.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    var $template = this.template;\n    var isFocus = false;\n\n    if (!this.options.disableHover) {\n\n      this.$element\n      .on('mouseenter.zf.tooltip', function(e) {\n        if (!_this.isActive) {\n          _this.timeout = setTimeout(function() {\n            _this.show();\n          }, _this.options.hoverDelay);\n        }\n      })\n      .on('mouseleave.zf.tooltip', ignoreMousedisappear(function(e) {\n        clearTimeout(_this.timeout);\n        if (!isFocus || (_this.isClick && !_this.options.clickOpen)) {\n          _this.hide();\n        }\n      }));\n    }\n\n    if (this.options.clickOpen) {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        if (_this.isClick) {\n          //_this.hide();\n          // _this.isClick = false;\n        } else {\n          _this.isClick = true;\n          if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {\n            _this.show();\n          }\n        }\n      });\n    } else {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        _this.isClick = true;\n      });\n    }\n\n    if (!this.options.disableForTouch) {\n      this.$element\n      .on('tap.zf.tooltip touchend.zf.tooltip', function(e) {\n        _this.isActive ? _this.hide() : _this.show();\n      });\n    }\n\n    this.$element.on({\n      // 'toggle.zf.trigger': this.toggle.bind(this),\n      // 'close.zf.trigger': this.hide.bind(this)\n      'close.zf.trigger': this.hide.bind(this)\n    });\n\n    this.$element\n      .on('focus.zf.tooltip', function(e) {\n        isFocus = true;\n        if (_this.isClick) {\n          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't\n          // a real focus, otherwise on hover and come back we get bad behavior\n          if(!_this.options.clickOpen) { isFocus = false; }\n          return false;\n        } else {\n          _this.show();\n        }\n      })\n\n      .on('focusout.zf.tooltip', function(e) {\n        isFocus = false;\n        _this.isClick = false;\n        _this.hide();\n      })\n\n      .on('resizeme.zf.trigger', function() {\n        if (_this.isActive) {\n          _this._setPosition();\n        }\n      });\n  }\n\n  /**\n   * adds a toggle method, in addition to the static show() & hide() functions\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  /**\n   * Destroys an instance of tooltip, removes template element from the view.\n   * @function\n   */\n  _destroy() {\n    this.$element.attr('title', this.template.text())\n                 .off('.zf.trigger .zf.tooltip')\n                 .removeClass(this.options.triggerClass)\n                 .removeClass('top right left bottom')\n                 .removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n\n    this.template.remove();\n  }\n}\n\nTooltip.defaults = {\n  disableForTouch: false,\n  /**\n   * Time, in ms, before a tooltip should open on hover.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  hoverDelay: 200,\n  /**\n   * Time, in ms, a tooltip should take to fade into view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeInDuration: 150,\n  /**\n   * Time, in ms, a tooltip should take to fade out of view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeOutDuration: 150,\n  /**\n   * Disables hover events from opening the tooltip if set to true\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Optional addtional classes to apply to the tooltip template on init.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  templateClasses: '',\n  /**\n   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.\n   * @option\n   * @type {string}\n   * @default 'tooltip'\n   */\n  tooltipClass: 'tooltip',\n  /**\n   * Class applied to the tooltip anchor element.\n   * @option\n   * @type {string}\n   * @default 'has-tip'\n   */\n  triggerClass: 'has-tip',\n  /**\n   * Minimum breakpoint size at which to open the tooltip.\n   * @option\n   * @type {string}\n   * @default 'small'\n   */\n  showOn: 'small',\n  /**\n   * Custom template to be used to generate markup for tooltip.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  template: '',\n  /**\n   * Text displayed in the tooltip template on open.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  tipText: '',\n  touchCloseText: 'Tap to close.',\n  /**\n   * Allows the tooltip to remain open if triggered with a click or touch event.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickOpen: true,\n  /**\n   * Position of tooltip. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, tooltip will first try to\n   * position as defined by data-position and data-alignment, but reposition if\n   * it would cause an overflow.  @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * Less common for tooltips.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowBottomOverlap: false,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the Y axis.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the X axis\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip\n   * @option\n   * @type {number}\n   * @default 14\n   */\n  tooltipHeight: 14,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip\n   * @option\n   * @type {number}\n   * @default 12\n   */\n  tooltipWidth: 12,\n    /**\n   * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,\n   * allowing HTML may open yourself up to XSS attacks.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowHtml: false\n};\n\n/**\n * TODO utilize resize event trigger\n */\n\nexport {Tooltip};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin }from './foundation.core.plugin';\n\nimport { Accordion } from './foundation.accordion';\nimport { Tabs } from './foundation.tabs';\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n  tabs: {\n    cssClass: 'tabs',\n    plugin: Tabs\n  },\n  accordion: {\n    cssClass: 'accordion',\n    plugin: Accordion\n  }\n};\n\n\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nclass ResponsiveAccordionTabs extends Plugin{\n  /**\n   * Creates a new instance of a responsive accordion tabs.\n   * @class\n   * @name ResponsiveAccordionTabs\n   * @fires ResponsiveAccordionTabs#init\n   * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options  = $.extend({}, this.$element.data(), options);\n    this.rules = this.$element.data('responsive-accordion-tabs');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveAccordionTabs'; // ie9 back compat\n    if (!this.$element.attr('id')) {\n      this.$element.attr('id',GetYoDigits(6, 'responsiveaccordiontabs'));\n    };\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    this._getAllOptions();\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n  }\n\n  _getAllOptions() {\n    //get all defaults and options\n    var _this = this;\n    _this.allOptions = {};\n    for (var key in MenuPlugins) {\n      if (MenuPlugins.hasOwnProperty(key)) {\n        var obj = MenuPlugins[key];\n        try {\n          var dummyPlugin = $('<ul></ul>');\n          var tmpPlugin = new obj.plugin(dummyPlugin,_this.options);\n          for (var keyKey in tmpPlugin.options) {\n            if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {\n              var objObj = tmpPlugin.options[keyKey];\n              _this.allOptions[keyKey] = objObj;\n            }\n          }\n          tmpPlugin.destroy();\n        }\n        catch(e) {\n        }\n      }\n    }\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);\n    $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) {\n      //don't know why but on nested elements data zfPlugin get's lost\n      if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin',this.storezfData);\n      this.currentPlugin.destroy();\n    }\n    this._handleMarkup(this.rules[matchedMq].cssClass);\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n    this.storezfData = this.currentPlugin.$element.data('zfPlugin');\n\n  }\n\n  _handleMarkup(toSet){\n    var _this = this, fromString = 'accordion';\n    var $panels = $('[data-tabs-content='+this.$element.attr('id')+']');\n    if ($panels.length) fromString = 'tabs';\n    if (fromString === toSet) {\n      return;\n    };\n\n    var tabsTitle = _this.allOptions.linkClass?_this.allOptions.linkClass:'tabs-title';\n    var tabsPanel = _this.allOptions.panelClass?_this.allOptions.panelClass:'tabs-panel';\n\n    this.$element.removeAttr('role');\n    var $liHeads = this.$element.children('.'+tabsTitle+',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');\n    var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');\n\n    if (fromString === 'tabs') {\n      $panels = $panels.children('.'+tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');\n      $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');\n    }else{\n      $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');\n    };\n\n    $panels.css({display:'',visibility:''});\n    $liHeads.css({display:'',visibility:''});\n    if (toSet === 'accordion') {\n      $panels.each(function(key,value){\n        $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content','').removeClass('is-active').css({height:''});\n        $('[data-tabs-content='+_this.$element.attr('id')+']').after('<div id=\"tabs-placeholder-'+_this.$element.attr('id')+'\"></div>').detach();\n        $liHeads.addClass('accordion-item').attr('data-accordion-item','');\n        $liHeadsA.addClass('accordion-title');\n      });\n    }else if (toSet === 'tabs'){\n      var $tabsContent = $('[data-tabs-content='+_this.$element.attr('id')+']');\n      var $placeholder = $('#tabs-placeholder-'+_this.$element.attr('id'));\n      if ($placeholder.length) {\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter($placeholder).attr('data-tabs-content',_this.$element.attr('id'));\n        $placeholder.remove();\n      }else{\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter(_this.$element).attr('data-tabs-content',_this.$element.attr('id'));\n      };\n      $panels.each(function(key,value){\n        var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);\n        var hash = $liHeadsA.get(key).hash.slice(1);\n        var id = $(value).attr('id') || GetYoDigits(6, 'accordion');\n        if (hash !== id) {\n          if (hash !== '') {\n            $(value).attr('id',hash);\n          }else{\n            hash = id;\n            $(value).attr('id',hash);\n            $($liHeadsA.get(key)).attr('href',$($liHeadsA.get(key)).attr('href').replace('#','')+'#'+hash);\n          };\n        };\n        var isActive = $($liHeads.get(key)).hasClass('is-active');\n        if (isActive) {\n          tempValue.addClass('is-active');\n        };\n      });\n      $liHeads.addClass(tabsTitle);\n    };\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n}\n\nResponsiveAccordionTabs.defaults = {};\n\nexport {ResponsiveAccordionTabs};\n","import $ from 'jquery';\n\nimport { Foundation } from '../foundation.core';\nimport * as CoreUtils from '../foundation.core.utils';\nimport { Box } from '../foundation.util.box'\nimport { onImagesLoaded } from '../foundation.util.imageLoader';\nimport { Keyboard } from '../foundation.util.keyboard';\nimport { MediaQuery } from '../foundation.util.mediaQuery';\nimport { Motion, Move } from '../foundation.util.motion';\nimport { Nest } from '../foundation.util.nest';\nimport { Timer } from '../foundation.util.timer';\nimport { Touch } from '../foundation.util.touch';\nimport { Triggers } from '../foundation.util.triggers';\nimport { Abide } from '../foundation.abide';\nimport { Accordion } from '../foundation.accordion';\nimport { AccordionMenu } from '../foundation.accordionMenu';\nimport { Drilldown } from '../foundation.drilldown';\nimport { Dropdown } from '../foundation.dropdown';\nimport { DropdownMenu } from '../foundation.dropdownMenu';\nimport { Equalizer } from '../foundation.equalizer';\nimport { Interchange } from '../foundation.interchange';\nimport { Magellan } from '../foundation.magellan';\nimport { OffCanvas } from '../foundation.offcanvas';\nimport { Orbit } from '../foundation.orbit';\nimport { ResponsiveMenu } from '../foundation.responsiveMenu';\nimport { ResponsiveToggle } from '../foundation.responsiveToggle';\nimport { Reveal } from '../foundation.reveal';\nimport { Slider } from '../foundation.slider';\nimport { SmoothScroll } from '../foundation.smoothScroll';\nimport { Sticky } from '../foundation.sticky';\nimport { Tabs } from '../foundation.tabs';\nimport { Toggler } from '../foundation.toggler';\nimport { Tooltip } from '../foundation.tooltip';\nimport { ResponsiveAccordionTabs } from '../foundation.responsiveAccordionTabs';\n\nFoundation.addToJquery($);\n\n// Add Foundation Utils to Foundation global namespace for backwards\n// compatibility.\nFoundation.rtl = CoreUtils.rtl;\nFoundation.GetYoDigits = CoreUtils.GetYoDigits;\nFoundation.transitionend = CoreUtils.transitionend;\nFoundation.RegExpEscape = CoreUtils.RegExpEscape;\nFoundation.onLoad = CoreUtils.onLoad;\n\nFoundation.Box = Box;\nFoundation.onImagesLoaded = onImagesLoaded;\nFoundation.Keyboard = Keyboard;\nFoundation.MediaQuery = MediaQuery;\nFoundation.Motion = Motion;\nFoundation.Move = Move;\nFoundation.Nest = Nest;\nFoundation.Timer = Timer;\n\n// Touch and Triggers previously were almost purely sede effect driven,\n// so no need to add it to Foundation, just init them.\nTouch.init($);\nTriggers.init($, Foundation);\nMediaQuery._init();\n\nFoundation.plugin(Abide, 'Abide');\nFoundation.plugin(Accordion, 'Accordion');\nFoundation.plugin(AccordionMenu, 'AccordionMenu');\nFoundation.plugin(Drilldown, 'Drilldown');\nFoundation.plugin(Dropdown, 'Dropdown');\nFoundation.plugin(DropdownMenu, 'DropdownMenu');\nFoundation.plugin(Equalizer, 'Equalizer');\nFoundation.plugin(Interchange, 'Interchange');\nFoundation.plugin(Magellan, 'Magellan');\nFoundation.plugin(OffCanvas, 'OffCanvas');\nFoundation.plugin(Orbit, 'Orbit');\nFoundation.plugin(ResponsiveMenu, 'ResponsiveMenu');\nFoundation.plugin(ResponsiveToggle, 'ResponsiveToggle');\nFoundation.plugin(Reveal, 'Reveal');\nFoundation.plugin(Slider, 'Slider');\nFoundation.plugin(SmoothScroll, 'SmoothScroll');\nFoundation.plugin(Sticky, 'Sticky');\nFoundation.plugin(Tabs, 'Tabs');\nFoundation.plugin(Toggler, 'Toggler');\nFoundation.plugin(Tooltip, 'Tooltip');\nFoundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');\n\nexport {\n  Foundation,\n  CoreUtils,\n  Box,\n  onImagesLoaded,\n  Keyboard,\n  MediaQuery,\n  Motion,\n  Nest,\n  Timer,\n  Touch,\n  Triggers,\n  Abide,\n  Accordion,\n  AccordionMenu,\n  Drilldown,\n  Dropdown,\n  DropdownMenu,\n  Equalizer,\n  Interchange,\n  Magellan,\n  OffCanvas,\n  Orbit,\n  ResponsiveMenu,\n  ResponsiveToggle,\n  Reveal,\n  Slider,\n  SmoothScroll,\n  Sticky,\n  Tabs,\n  Toggler,\n  Tooltip,\n  ResponsiveAccordionTabs\n}\n\nexport default Foundation;\n\n"],"names":["rtl","$","attr","GetYoDigits","length","namespace","Math","round","pow","random","toString","slice","RegExpEscape","str","replace","transitionend","$elem","transitions","elem","document","createElement","end","t","style","setTimeout","triggerHandler","onLoad","handler","didLoad","readyState","eventType","cb","one","window","ignoreMousedisappear","ignoreLeaveWindow","ignoreReappear","leaveEventHandler","eLeave","rest","callback","bind","relatedTarget","leaveEventDebouncer","hasFocus","reenterEventHandler","eReenter","currentTarget","has","target","matchMedia","styleMedia","media","script","getElementsByTagName","info","type","id","head","appendChild","parentNode","insertBefore","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","matches","MediaQuery","queries","current","_init","self","$meta","appendTo","extractedStyles","css","namedQueries","parseStyleToObject","key","hasOwnProperty","push","name","value","_getCurrentSize","_watcher","atLeast","size","query","get","is","trim","split","i","matched","off","on","newSize","currentSize","trigger","styleObject","reduce","ret","param","parts","val","decodeURIComponent","Array","isArray","FOUNDATION_VERSION","Foundation","version","_plugins","_uuids","plugin","className","functionName","attrName","hyphenate","registerPlugin","pluginName","constructor","toLowerCase","uuid","$element","data","unregisterPlugin","splice","indexOf","removeAttr","removeData","prop","reInit","plugins","isJQ","each","_this","fns","plgs","forEach","p","foundation","Object","keys","err","console","error","reflow","find","addBack","$el","opts","warn","thing","e","opt","map","el","parseValue","er","getFnName","addToJquery","method","$noJS","removeClass","args","prototype","call","arguments","plugClass","apply","ReferenceError","TypeError","fn","util","throttle","func","delay","timer","context","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","test","navigator","userAgent","lastTime","nextTime","max","clearTimeout","performance","start","Function","oThis","aArgs","fToBind","fNOP","fBound","concat","funcNameRegex","results","exec","isNaN","parseFloat","Box","ImNotTouchingYou","OverlapArea","GetDimensions","GetOffsets","GetExplicitOffsets","element","parent","lrOnly","tbOnly","ignoreBottom","eleDims","topOver","bottomOver","leftOver","rightOver","parDims","height","offset","top","left","windowDims","min","sqrt","Error","rect","getBoundingClientRect","parRect","winRect","body","winY","pageYOffset","winX","pageXOffset","parentDims","anchor","position","vOffset","hOffset","isOverflow","log","Rtl","$eleDims","$anchorDims","alignment","topVal","leftVal","onImagesLoaded","images","unloaded","complete","naturalWidth","singleImageLoaded","image","Image","events","me","event","src","keyCodes","commands","findFocusable","filter","parseKey","which","keyCode","String","fromCharCode","toUpperCase","shiftKey","ctrlKey","altKey","Keyboard","getKeyCodes","handleKey","component","functions","commandList","cmds","command","ltr","extend","returnValue","handled","unhandled","register","componentName","trapFocus","$focusable","$firstFocusable","eq","$lastFocusable","preventDefault","focus","releaseFocus","kcs","k","kc","initClasses","activeClasses","Motion","animateIn","animation","animate","animateOut","Move","duration","anim","prog","move","ts","isIn","initClass","activeClass","reset","addClass","show","offsetWidth","finish","hide","transitionDuration","Nest","Feather","menu","items","subMenuClass","subItemClass","hasSubClass","applyAria","$item","$sub","children","Burn","Timer","options","nameSpace","remain","isPaused","restart","infinite","pause","Touch","startPosX","startPosY","startTime","elapsedTime","startEvent","isMoving","didMoved","onTouchEnd","removeEventListener","onTouchMove","tapEvent","Event","spotSwipe","x","touches","pageX","y","pageY","dx","dir","abs","moveThreshold","timeThreshold","onTouchStart","addEventListener","init","SpotSwipe","enabled","documentElement","special","swipe","setup","tap","noop","setupSpotSwipe","setupTouchHandler","addTouch","handleTouch","changedTouches","first","eventTypes","touchstart","touchmove","touchend","simulatedEvent","MouseEvent","screenX","screenY","clientX","clientY","createEvent","initMouseEvent","dispatchEvent","MutationObserver","prefixes","triggers","Triggers","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","stopPropagation","fadeOut","toggleFocusListener","addOpenListener","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","scrollListener","closeMeListener","pluginId","not","addClosemeListener","yetiBoxes","plugNames","listeners","join","debounceGlobalListener","debounce","listener","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","$target","attributeName","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","triggersInitialized","IHearYou","Plugin","_setup","getPluginName","_destroy","obj","Abide","defaults","$inputs","merge","$globalErrors","a11yAttributes","input","addA11yAttributes","addGlobalErrorA11yAttributes","_events","resetForm","validateForm","validateOn","validateInput","liveValidate","validateOnBlur","isGood","checked","$error","siblings","formErrorSelector","add","$label","$els","labels","findLabel","$formError","findFormError","labelErrorClass","formErrorClass","inputErrorClass","$errors","$labels","errorId","elemId","label","a11yErrorLevel","groupName","findRadioLabels","$formErrors","removeRadioErrorClasses","clearRequire","requiredCheck","validated","customValidator","validator","equalTo","validateRadio","validateText","matchValidation","validators","goodToGo","message","dependentElements","acc","noError","pattern","inputText","valid","patterns","RegExp","$group","required","clear","v","$form","removeErrorClasses","alpha","alpha_numeric","integer","number","card","cvv","email","url","domain","datetime","date","time","dateISO","month_day_year","day_month_year","color","website","Accordion","_isInitializing","$tabs","idx","$content","linkId","$initActive","_initialAnchor","prev","_openSingleTab","_checkDeepLink","location","hash","$anchor","$link","isOwnAnchor","hasClass","_closeAllTabs","deepLinkSmudge","scrollTop","deepLinkSmudgeDelay","deepLink","$tabContent","toggle","next","$a","multiExpand","previous","up","down","updateHistory","history","pushState","replaceState","_openTab","$targetItem","$othersItems","allowAllClosed","_closeTab","$activeContents","targetContentId","slideDown","slideSpeed","slideUp","$activeTabs","stop","AccordionMenu","multiOpen","$menuLinks","subId","isActive","parentLink","clone","prependTo","wrap","submenuToggle","after","submenuToggleText","initPanes","$submenu","$elements","$prevElement","$nextElement","parents","open","close","closeAll","hideAll","stopImmediatePropagation","$targetBranch","parentsUntil","$othersActiveSubmenus","$submenus","$allmenus","detach","remove","Drilldown","autoApplyClass","$submenuAnchors","$menuItems","$currentMenu","_prepareMenu","_registerEvents","_keyboardEvents","$menu","$back","backButtonPosition","append","backButton","prepend","_back","autoHeight","$wrapper","wrapper","animateHeight","_getMaxDims","_show","closeOnClick","$body","contains","_hideAll","_bindHandler","_scrollTop","_resize","$scrollTopElement","scrollTopElement","scrollPos","parseInt","scrollTopOffset","animationDuration","animationEasing","_hide","parentSubMenu","autoFocus","$expandedSubmenus","index","_setHideSubMenuClasses","isLastChild","_setShowSubMenuClasses","blur","maxHeight","result","numOfElems","unwrap","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","nextItem","item","array","currentIdx","Positionable","triedPositions","_getDefaultPosition","_getDefaultAlignment","originalPosition","originalAlignment","_alignmentsExhausted","_realign","_addTriedPosition","isExhausted","$parent","allowOverlap","_getVOffset","_getHOffset","minOverlap","minCoordinates","_positionsExhausted","overlap","allowBottomOverlap","_reposition","Dropdown","$id","$anchors","_setCurrentAnchor","parentClass","$currentAnchor","match","horizontalPosition","_setPosition","hover","bodyData","whatinput","timeout","hoverDelay","hoverPane","visibleFocusableElements","_addBodyHandler","DropdownMenu","subs","verticalClass","rightClass","changed","hasTouch","ontouchstart","parClass","handleClickFn","hasSub","hasClicked","clickOpen","forceFollow","closeOnClickInside","disableHover","autoclose","closingTime","isTab","nextSibling","prevSibling","openSub","closeSub","_isVertical","_isRtl","$sibs","oldClass","$parentLi","$toClose","somethingToClose","Equalizer","eqId","$watched","hasNested","isNested","isOn","onResizeMeBound","_onResizeMe","onPostEqualizedBound","_onPostEqualized","imgs","tooSmall","equalizeOn","_checkMQ","_reflow","_pauseEvents","equalizeOnStack","_isStacked","equalizeByRow","getHeightsByRow","applyHeightByRow","getHeights","applyHeight","heights","len","offsetHeight","lastElTopOffset","groups","group","elOffsetTop","j","ln","groupsILength","lenJ","Interchange","rules","currentPath","_addBreakpoints","_generateRules","rule","path","SPECIAL_QUERIES","rulesList","nodeName","response","html","SmoothScroll","_linkClickListener","_handleLinkClick","arrival","getAttribute","_inTransition","scrollToLoc","loc","$loc","threshold","Magellan","calcPoints","$targets","$links","$active","points","winHeight","innerHeight","clientHeight","docHeight","scrollHeight","$tar","pt","targetPoint","easing","deepLinking","_updateActive","onLoadListener","_deepLinkScroll","newScrollPos","isScrollingUp","activeIdx","visibleLinks","$oldActive","activeHash","isNewActive","isNewHash","pathname","search","OffCanvas","contentClasses","base","reveal","$lastTrigger","$triggers","nested","contentId","transition","contentOverlay","overlay","overlayPosition","setAttribute","$overlay","insertAfter","revealOnRegExp","revealClass","revealOnClass","isRevealed","revealOn","_setMQChecker","transitionTime","_removeContentClasses","_handleKeyboard","hasReveal","_addContentClasses","allowUp","allowDown","lastY","originalEvent","forceTo","scrollTo","contentScroll","_stopScrolling","_recordScrollable","_stopScrollPropagation","canvasFocus","Orbit","_reset","containerClass","$slides","slideClass","$images","initActive","useMUI","_prepareForOrbit","bullets","_loadBullets","autoPlay","geoSync","accessible","$bullets","boxOfBullets","timerDelay","changeSlide","_setWrapperHeight","temp","counter","pauseOnHover","navButtons","$controls","nextClass","prevClass","$slide","_updateBullets","isLTR","chosenSlide","$curSlide","$firstSlide","$lastSlide","last","dirIn","dirOut","$newSlide","infiniteWrap","$oldBullet","span","$newBullet","animInFromRight","animOutToRight","animInFromLeft","animOutToLeft","MenuPlugins","dropdown","cssClass","drilldown","accordion","ResponsiveMenu","currentMq","currentPlugin","rulesTree","ruleSize","rulePlugin","isEmptyObject","_checkMediaQueries","matchedMq","destroy","ResponsiveToggle","targetID","$targetMenu","$toggler","animationIn","animationOut","_update","_updateMqHandler","toggleMenu","hideFor","Reveal","cached","mq","fullScreen","_makeOverlay","additionalOverlayClasses","outerWidth","outerHeight","margin","_updatePosition","_handleState","$activeAnchor","activeElement","multipleOpened","_disableScroll","afterAnimation","_addGlobalClasses","focusableElements","showDelay","_addGlobalListeners","updateScrollbarClass","toggleClass","closeOnEsc","finishUp","hideDelay","_removeGlobalClasses","_enableScroll","resetOnClose","urlWithoutHash","title","Slider","inputs","handles","$handle","$input","$fill","vertical","disabled","disabledClass","binding","_setInitAttr","doubleSided","$handle2","$input2","setHandles","_setHandlePos","pctOfBar","percent","positionValueFunction","_logTransform","_powTransform","toFixed","baseLog","nonLinearBase","$hndl","noInvert","isDbl","h2Val","step","h1Val","vert","hOrW","lOrT","handleDim","elemDim","_pctOfBar","pxToMove","movement","decimal","_setValues","isLeftHndl","dim","handlePct","handlePos","initialStart","moveTime","changedDelay","initVal","initialEnd","hasVal","direction","eventOffset","halfOfHandle","barDim","windowScroll","scrollLeft","elemOffset","eventFromBar","barXY","offsetPct","_value","_adjustValue","firstHndlPos","absPosition","secndHndlPos","div","prev_val","next_val","_eventsForHandle","curHandle","handleChangeEvent","_handleEvent","clickSelect","draggable","_$handle","oldValue","newValue","decrease","increase","decrease_fast","increase_fast","invertVertical","frac","num","clickPos","Sticky","$container","wasWrapped","container","stickyClass","scrollCount","checkEvery","isStuck","containerHeight","elemHeight","_parsePoints","_setSizes","scroll","_calc","_removeSticky","topPoint","reverse","topAnchor","btm","btmAnchor","pts","breaks","place","canStick","_eventsHandler","_pauseListeners","checkSizes","bottomPoint","_setSticky","stickTo","mrgn","notStuckTo","isTop","stickToTop","anchorPt","anchorHeight","topOrBottom","stickyOn","newElemWidth","comp","pdngl","pdngr","newContainerHeight","_setBreakPoints","mTop","emCalc","marginTop","mBtm","marginBottom","bottom","em","fontSize","Tabs","$tabTitles","linkClass","linkActiveClass","matchHeight","_setHeight","selectTab","_collapse","_addKeyHandler","_addClickHandler","_setHeightMqHandler","_handleTabChange","wrapOnKeys","historyHandled","activeCollapse","$oldTab","$tabLink","$targetContent","_collapseTab","panelActiveClass","$target_anchor","$activeTab","idStr","panelClass","panel","Toggler","$trigger","controls","containsId","_updateARIA","Tooltip","isClick","tipText","template","_buildTemplate","allowHtml","triggerClass","tooltipWidth","tooltipHeight","templateClasses","tooltipClass","$template","showOn","fadeIn","fadeInDuration","fadeOutDuration","isFocus","disableForTouch","touchCloseText","tabs","ResponsiveAccordionTabs","_getAllOptions","allOptions","dummyPlugin","tmpPlugin","keyKey","objObj","_changedZfMediaQueryHandler","storezfData","_handleMarkup","toSet","fromString","$panels","tabsTitle","tabsPanel","$liHeads","$liHeadsA","display","visibility","$tabsContent","$placeholder","tempValue","CoreUtils"],"mappings":"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"}
\ No newline at end of file
index 6c5a47987dd6e2b12ae7f2ba24694b9d1fca3da4..a0f231d9aa3142f77466be16668038661a5466c7 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["jquery"], factory);
+       else {
+               var a = typeof exports === 'object' ? factory(require("jquery")) : factory(root["jQuery"]);
+               for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
+       }
+})(window, function(__WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 36);
+/******/       return __webpack_require__(__webpack_require__.s = 0);
 /******/ })
 /************************************************************************/
-/******/ ([
-/* 0 */
-/***/ (function(module, exports) {
+/******/ ({
 
-module.exports = jQuery;
-
-/***/ }),
-/* 1 */
+/***/ "./js/entries/foundation.js":
+/*!**********************************!*\
+  !*** ./js/entries/foundation.js ***!
+  \**********************************/
+/*! exports provided: Foundation, CoreUtils, Box, onImagesLoaded, Keyboard, MediaQuery, Motion, Nest, Timer, Touch, Triggers, Abide, Accordion, AccordionMenu, Drilldown, Dropdown, DropdownMenu, Equalizer, Interchange, Magellan, OffCanvas, Orbit, ResponsiveMenu, ResponsiveToggle, Reveal, Slider, SmoothScroll, Sticky, Tabs, Toggler, Tooltip, ResponsiveAccordionTabs, default */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return rtl; });
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return GetYoDigits; });
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return transitionend; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../foundation.core */ "./js/foundation.core.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"]; });
 
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, "CoreUtils", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__; });
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../foundation.util.box */ "./js/foundation.util.box.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Box", function() { return _foundation_util_box__WEBPACK_IMPORTED_MODULE_3__["Box"]; });
 
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../foundation.util.imageLoader */ "./js/foundation.util.imageLoader.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onImagesLoaded", function() { return _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__["onImagesLoaded"]; });
 
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Keyboard", function() { return _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_5__["Keyboard"]; });
 
-// Core Foundation Utilities, utilized in a number of places.
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MediaQuery", function() { return _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__["MediaQuery"]; });
 
-/**
- * Returns a boolean for RTL support
- */
-function rtl() {
-  return __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html').attr('dir') === 'rtl';
-}
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../foundation.util.motion */ "./js/foundation.util.motion.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Motion", function() { return _foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__["Motion"]; });
 
-/**
- * returns a random base-36 uid with namespacing
- * @function
- * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.
- * @param {String} namespace - name of plugin to be incorporated in uid, optional.
- * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.
- * @returns {String} - unique id
- */
-function GetYoDigits(length, namespace) {
-  length = length || 6;
-  return Math.round(Math.pow(36, length + 1) - Math.random() * Math.pow(36, length)).toString(36).slice(1) + (namespace ? '-' + namespace : '');
-}
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../foundation.util.nest */ "./js/foundation.util.nest.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Nest", function() { return _foundation_util_nest__WEBPACK_IMPORTED_MODULE_8__["Nest"]; });
 
-function transitionend($elem) {
-  var transitions = {
-    'transition': 'transitionend',
-    'WebkitTransition': 'webkitTransitionEnd',
-    'MozTransition': 'transitionend',
-    'OTransition': 'otransitionend'
-  };
-  var elem = document.createElement('div'),
-      end;
+/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../foundation.util.timer */ "./js/foundation.util.timer.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _foundation_util_timer__WEBPACK_IMPORTED_MODULE_9__["Timer"]; });
 
-  for (var t in transitions) {
-    if (typeof elem.style[t] !== 'undefined') {
-      end = transitions[t];
-    }
-  }
-  if (end) {
-    return end;
-  } else {
-    end = setTimeout(function () {
-      $elem.triggerHandler('transitionend', [$elem]);
-    }, 1);
-    return 'transitionend';
-  }
-}
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../foundation.util.touch */ "./js/foundation.util.touch.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Touch", function() { return _foundation_util_touch__WEBPACK_IMPORTED_MODULE_10__["Touch"]; });
 
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../foundation.util.triggers */ "./js/foundation.util.triggers.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_11__["Triggers"]; });
 
+/* harmony import */ var _foundation_abide__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../foundation.abide */ "./js/foundation.abide.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Abide", function() { return _foundation_abide__WEBPACK_IMPORTED_MODULE_12__["Abide"]; });
 
-/***/ }),
-/* 2 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../foundation.accordion */ "./js/foundation.accordion.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Accordion", function() { return _foundation_accordion__WEBPACK_IMPORTED_MODULE_13__["Accordion"]; });
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Plugin; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
+/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ../foundation.accordionMenu */ "./js/foundation.accordionMenu.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AccordionMenu", function() { return _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_14__["AccordionMenu"]; });
 
+/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ../foundation.drilldown */ "./js/foundation.drilldown.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Drilldown", function() { return _foundation_drilldown__WEBPACK_IMPORTED_MODULE_15__["Drilldown"]; });
 
-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; }; }();
+/* harmony import */ var _foundation_dropdown__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ../foundation.dropdown */ "./js/foundation.dropdown.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Dropdown", function() { return _foundation_dropdown__WEBPACK_IMPORTED_MODULE_16__["Dropdown"]; });
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! ../foundation.dropdownMenu */ "./js/foundation.dropdownMenu.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DropdownMenu", function() { return _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_17__["DropdownMenu"]; });
 
+/* harmony import */ var _foundation_equalizer__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! ../foundation.equalizer */ "./js/foundation.equalizer.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Equalizer", function() { return _foundation_equalizer__WEBPACK_IMPORTED_MODULE_18__["Equalizer"]; });
 
+/* harmony import */ var _foundation_interchange__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(/*! ../foundation.interchange */ "./js/foundation.interchange.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Interchange", function() { return _foundation_interchange__WEBPACK_IMPORTED_MODULE_19__["Interchange"]; });
 
+/* harmony import */ var _foundation_magellan__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(/*! ../foundation.magellan */ "./js/foundation.magellan.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Magellan", function() { return _foundation_magellan__WEBPACK_IMPORTED_MODULE_20__["Magellan"]; });
 
-// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST
-// {function} _setup (replaces previous constructor),
-// {function} _destroy (replaces previous destroy)
+/* harmony import */ var _foundation_offcanvas__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(/*! ../foundation.offcanvas */ "./js/foundation.offcanvas.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "OffCanvas", function() { return _foundation_offcanvas__WEBPACK_IMPORTED_MODULE_21__["OffCanvas"]; });
 
-var Plugin = function () {
-  function Plugin(element, options) {
-    _classCallCheck(this, Plugin);
+/* harmony import */ var _foundation_orbit__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(/*! ../foundation.orbit */ "./js/foundation.orbit.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Orbit", function() { return _foundation_orbit__WEBPACK_IMPORTED_MODULE_22__["Orbit"]; });
 
-    this._setup(element, options);
-    var pluginName = getPluginName(this);
-    this.uuid = __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["b" /* GetYoDigits */])(6, pluginName);
+/* harmony import */ var _foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(/*! ../foundation.responsiveMenu */ "./js/foundation.responsiveMenu.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResponsiveMenu", function() { return _foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_23__["ResponsiveMenu"]; });
 
-    if (!this.$element.attr('data-' + pluginName)) {
-      this.$element.attr('data-' + pluginName, this.uuid);
-    }
-    if (!this.$element.data('zfPlugin')) {
-      this.$element.data('zfPlugin', this);
-    }
-    /**
-     * Fires when the plugin has initialized.
-     * @event Plugin#init
-     */
-    this.$element.trigger('init.zf.' + pluginName);
-  }
+/* harmony import */ var _foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(/*! ../foundation.responsiveToggle */ "./js/foundation.responsiveToggle.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResponsiveToggle", function() { return _foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_24__["ResponsiveToggle"]; });
 
-  _createClass(Plugin, [{
-    key: 'destroy',
-    value: function destroy() {
-      this._destroy();
-      var pluginName = getPluginName(this);
-      this.$element.removeAttr('data-' + pluginName).removeData('zfPlugin')
-      /**
-       * Fires when the plugin has been destroyed.
-       * @event Plugin#destroyed
-       */
-      .trigger('destroyed.zf.' + pluginName);
-      for (var prop in this) {
-        this[prop] = null; //clean up script to prep for garbage collection.
-      }
-    }
-  }]);
+/* harmony import */ var _foundation_reveal__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(/*! ../foundation.reveal */ "./js/foundation.reveal.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Reveal", function() { return _foundation_reveal__WEBPACK_IMPORTED_MODULE_25__["Reveal"]; });
 
-  return Plugin;
-}();
+/* harmony import */ var _foundation_slider__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(/*! ../foundation.slider */ "./js/foundation.slider.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Slider", function() { return _foundation_slider__WEBPACK_IMPORTED_MODULE_26__["Slider"]; });
 
-// Convert PascalCase to kebab-case
-// Thank you: http://stackoverflow.com/a/8955580
+/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(/*! ../foundation.smoothScroll */ "./js/foundation.smoothScroll.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SmoothScroll", function() { return _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_27__["SmoothScroll"]; });
 
+/* harmony import */ var _foundation_sticky__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(/*! ../foundation.sticky */ "./js/foundation.sticky.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Sticky", function() { return _foundation_sticky__WEBPACK_IMPORTED_MODULE_28__["Sticky"]; });
 
-function hyphenate(str) {
-  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
-}
+/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(/*! ../foundation.tabs */ "./js/foundation.tabs.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Tabs", function() { return _foundation_tabs__WEBPACK_IMPORTED_MODULE_29__["Tabs"]; });
 
-function getPluginName(obj) {
-  if (typeof obj.constructor.name !== 'undefined') {
-    return hyphenate(obj.constructor.name);
-  } else {
-    return hyphenate(obj.className);
-  }
-}
+/* harmony import */ var _foundation_toggler__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(/*! ../foundation.toggler */ "./js/foundation.toggler.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Toggler", function() { return _foundation_toggler__WEBPACK_IMPORTED_MODULE_30__["Toggler"]; });
+
+/* harmony import */ var _foundation_tooltip__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(/*! ../foundation.tooltip */ "./js/foundation.tooltip.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Tooltip", function() { return _foundation_tooltip__WEBPACK_IMPORTED_MODULE_31__["Tooltip"]; });
+
+/* harmony import */ var _foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(/*! ../foundation.responsiveAccordionTabs */ "./js/foundation.responsiveAccordionTabs.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResponsiveAccordionTabs", function() { return _foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_32__["ResponsiveAccordionTabs"]; });
 
 
 
-/***/ }),
-/* 3 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Keyboard; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
-/*******************************************
- *                                         *
- * This util was created by Marius Olbertz *
- * Please thank Marius on GitHub /owlbertz *
- * or the web http://www.mariusolbertz.de/ *
- *                                         *
- ******************************************/
 
 
 
 
 
 
-var keyCodes = {
-  9: 'TAB',
-  13: 'ENTER',
-  27: 'ESCAPE',
-  32: 'SPACE',
-  35: 'END',
-  36: 'HOME',
-  37: 'ARROW_LEFT',
-  38: 'ARROW_UP',
-  39: 'ARROW_RIGHT',
-  40: 'ARROW_DOWN'
-};
 
-var commands = {};
 
-// Functions pulled out to be referenceable from internals
-function findFocusable($element) {
-  if (!$element) {
-    return false;
-  }
-  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function () {
-    if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is(':visible') || __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).attr('tabindex') < 0) {
-      return false;
-    } //only have visible elements and those that have a tabindex greater or equal 0
-    return true;
-  });
-}
 
-function parseKey(event) {
-  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();
 
-  // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events
-  key = key.replace(/\W+/, '');
 
-  if (event.shiftKey) key = 'SHIFT_' + key;
-  if (event.ctrlKey) key = 'CTRL_' + key;
-  if (event.altKey) key = 'ALT_' + key;
 
-  // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)
-  key = key.replace(/_$/, '');
 
-  return key;
-}
 
-var Keyboard = {
-  keys: getKeyCodes(keyCodes),
 
-  /**
-   * Parses the (keyboard) event and returns a String that represents its key
-   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
-   * @param {Event} event - the event generated by the event handler
-   * @return String key - String that represents the key pressed
-   */
-  parseKey: parseKey,
 
-  /**
-   * Handles the given (keyboard) event
-   * @param {Event} event - the event generated by the event handler
-   * @param {String} component - Foundation component's name, e.g. Slider or Reveal
-   * @param {Objects} functions - collection of functions that are to be executed
-   */
-  handleKey: function (event, component, functions) {
-    var commandList = commands[component],
-        keyCode = this.parseKey(event),
-        cmds,
-        command,
-        fn;
 
-    if (!commandList) return console.warn('Component not defined!');
 
-    if (typeof commandList.ltr === 'undefined') {
-      // this component does not differentiate between ltr and rtl
-      cmds = commandList; // use plain list
-    } else {
-      // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa
-      if (__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["a" /* rtl */])()) cmds = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, commandList.ltr, commandList.rtl);else cmds = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, commandList.rtl, commandList.ltr);
-    }
-    command = cmds[keyCode];
 
-    fn = functions[command];
-    if (fn && typeof fn === 'function') {
-      // execute function  if exists
-      var returnValue = fn.apply();
-      if (functions.handled || typeof functions.handled === 'function') {
-        // execute function when event was handled
-        functions.handled(returnValue);
-      }
-    } else {
-      if (functions.unhandled || typeof functions.unhandled === 'function') {
-        // execute function when event was not handled
-        functions.unhandled();
-      }
-    }
-  },
 
 
-  /**
-   * Finds all focusable elements within the given `$element`
-   * @param {jQuery} $element - jQuery object to search within
-   * @return {jQuery} $focusable - all focusable elements within `$element`
-   */
 
-  findFocusable: findFocusable,
 
-  /**
-   * Returns the component name name
-   * @param {Object} component - Foundation component, e.g. Slider or Reveal
-   * @return String componentName
-   */
 
-  register: function (componentName, cmds) {
-    commands[componentName] = cmds;
-  },
 
 
-  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?
-  //
-  /**
-   * Traps the focus in the given element.
-   * @param  {jQuery} $element  jQuery object to trap the foucs into.
-   */
-  trapFocus: function ($element) {
-    var $focusable = findFocusable($element),
-        $firstFocusable = $focusable.eq(0),
-        $lastFocusable = $focusable.eq(-1);
 
-    $element.on('keydown.zf.trapfocus', function (event) {
-      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {
-        event.preventDefault();
-        $firstFocusable.focus();
-      } else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {
-        event.preventDefault();
-        $lastFocusable.focus();
-      }
-    });
-  },
 
-  /**
-   * Releases the trapped focus from the given element.
-   * @param  {jQuery} $element  jQuery object to release the focus for.
-   */
-  releaseFocus: function ($element) {
-    $element.off('keydown.zf.trapfocus');
-  }
-};
 
-/*
- * Constants for easier comparing.
- * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
- */
-function getKeyCodes(kcs) {
-  var k = {};
-  for (var kc in kcs) {
-    k[kcs[kc]] = kcs[kc];
-  }return k;
-}
 
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].addToJquery(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Add Foundation Utils to Foundation global namespace for backwards
+// compatibility.
 
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].rtl = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["rtl"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].GetYoDigits = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].transitionend = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["transitionend"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].RegExpEscape = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["RegExpEscape"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].onLoad = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["onLoad"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].Box = _foundation_util_box__WEBPACK_IMPORTED_MODULE_3__["Box"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].onImagesLoaded = _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__["onImagesLoaded"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].Keyboard = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_5__["Keyboard"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].MediaQuery = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__["MediaQuery"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].Motion = _foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__["Motion"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].Move = _foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__["Move"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].Nest = _foundation_util_nest__WEBPACK_IMPORTED_MODULE_8__["Nest"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].Timer = _foundation_util_timer__WEBPACK_IMPORTED_MODULE_9__["Timer"]; // Touch and Triggers previously were almost purely sede effect driven,
+// so no need to add it to Foundation, just init them.
+
+_foundation_util_touch__WEBPACK_IMPORTED_MODULE_10__["Touch"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_11__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a, _foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"]);
+
+_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__["MediaQuery"]._init();
+
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_abide__WEBPACK_IMPORTED_MODULE_12__["Abide"], 'Abide');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_accordion__WEBPACK_IMPORTED_MODULE_13__["Accordion"], 'Accordion');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_14__["AccordionMenu"], 'AccordionMenu');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_drilldown__WEBPACK_IMPORTED_MODULE_15__["Drilldown"], 'Drilldown');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_dropdown__WEBPACK_IMPORTED_MODULE_16__["Dropdown"], 'Dropdown');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_17__["DropdownMenu"], 'DropdownMenu');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_equalizer__WEBPACK_IMPORTED_MODULE_18__["Equalizer"], 'Equalizer');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_interchange__WEBPACK_IMPORTED_MODULE_19__["Interchange"], 'Interchange');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_magellan__WEBPACK_IMPORTED_MODULE_20__["Magellan"], 'Magellan');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_offcanvas__WEBPACK_IMPORTED_MODULE_21__["OffCanvas"], 'OffCanvas');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_orbit__WEBPACK_IMPORTED_MODULE_22__["Orbit"], 'Orbit');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_23__["ResponsiveMenu"], 'ResponsiveMenu');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_24__["ResponsiveToggle"], 'ResponsiveToggle');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_reveal__WEBPACK_IMPORTED_MODULE_25__["Reveal"], 'Reveal');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_slider__WEBPACK_IMPORTED_MODULE_26__["Slider"], 'Slider');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_27__["SmoothScroll"], 'SmoothScroll');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_sticky__WEBPACK_IMPORTED_MODULE_28__["Sticky"], 'Sticky');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_tabs__WEBPACK_IMPORTED_MODULE_29__["Tabs"], 'Tabs');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_toggler__WEBPACK_IMPORTED_MODULE_30__["Toggler"], 'Toggler');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_tooltip__WEBPACK_IMPORTED_MODULE_31__["Tooltip"], 'Tooltip');
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].plugin(_foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_32__["ResponsiveAccordionTabs"], 'ResponsiveAccordionTabs');
+
+/* harmony default export */ __webpack_exports__["default"] = (_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"]);
 
 /***/ }),
-/* 4 */
+
+/***/ "./js/foundation.abide.js":
+/*!********************************!*\
+  !*** ./js/foundation.abide.js ***!
+  \********************************/
+/*! exports provided: Abide */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return MediaQuery; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Abide", function() { return Abide; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
 
 
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-// Default set of media queries
-var defaultQueries = {
-  'default': 'only screen',
-  landscape: 'only screen and (orientation: landscape)',
-  portrait: 'only screen and (orientation: portrait)',
-  retina: 'only screen and (-webkit-min-device-pixel-ratio: 2),' + 'only screen and (min--moz-device-pixel-ratio: 2),' + 'only screen and (-o-min-device-pixel-ratio: 2/1),' + 'only screen and (min-device-pixel-ratio: 2),' + 'only screen and (min-resolution: 192dpi),' + 'only screen and (min-resolution: 2dppx)'
-};
+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); } }
 
-// matchMedia() polyfill - Test a CSS media type/query in JS.
-// Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. Dual MIT/BSD license
-var matchMedia = window.matchMedia || function () {
-  'use strict';
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-  // For browsers that support matchMedium api such as IE 9 and webkit
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
-  var styleMedia = window.styleMedia || window.media;
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-  // For those that don't support matchMedium
-  if (!styleMedia) {
-    var style = document.createElement('style'),
-        script = document.getElementsByTagName('script')[0],
-        info = null;
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-    style.type = 'text/css';
-    style.id = 'matchmediajs-test';
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
-    script && script.parentNode && script.parentNode.insertBefore(style, script);
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
-    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;
 
-    styleMedia = {
-      matchMedium: function (media) {
-        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';
 
-        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
-        if (style.styleSheet) {
-          style.styleSheet.cssText = text;
-        } else {
-          style.textContent = text;
-        }
 
-        // Test if media query is true or false
-        return info.width === '1px';
-      }
-    };
-  }
+/**
+ * Abide module.
+ * @module foundation.abide
+ */
 
-  return function (media) {
-    return {
-      matches: styleMedia.matchMedium(media || 'all'),
-      media: media || 'all'
-    };
-  };
-}();
+var Abide =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Abide, _Plugin);
 
-var MediaQuery = {
-  queries: [],
+  function Abide() {
+    _classCallCheck(this, Abide);
 
-  current: '',
+    return _possibleConstructorReturn(this, _getPrototypeOf(Abide).apply(this, arguments));
+  }
 
-  /**
-   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.
-   * @function
-   * @private
-   */
-  _init: function () {
-    var self = this;
-    var $meta = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('meta.foundation-mq');
-    if (!$meta.length) {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<meta class="foundation-mq">').appendTo(document.head);
+  _createClass(Abide, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Abide.
+     * @class
+     * @name Abide
+     * @fires Abide#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element) {
+      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(true, {}, Abide.defaults, this.$element.data(), options);
+      this.className = 'Abide'; // ie9 back compat
+
+      this._init();
     }
+    /**
+     * Initializes the Abide plugin and calls functions to get Abide functioning on load.
+     * @private
+     */
 
-    var extractedStyles = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('.foundation-mq').css('font-family');
-    var namedQueries;
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
 
-    namedQueries = parseStyleToObject(extractedStyles);
+      this.$inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.merge( // Consider as input to validate:
+      this.$element.find('input').not('[type=submit]'), // * all input fields expect submit
+      this.$element.find('textarea, select') // * all textareas and select fields
+      );
+      var $globalErrors = this.$element.find('[data-abide-error]'); // Add a11y attributes to all fields
 
-    for (var key in namedQueries) {
-      if (namedQueries.hasOwnProperty(key)) {
-        self.queries.push({
-          name: key,
-          value: 'only screen and (min-width: ' + namedQueries[key] + ')'
+      if (this.options.a11yAttributes) {
+        this.$inputs.each(function (i, input) {
+          return _this2.addA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(input));
+        });
+        $globalErrors.each(function (i, error) {
+          return _this2.addGlobalErrorA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(error));
         });
       }
+
+      this._events();
     }
+    /**
+     * Initializes events for Abide.
+     * @private
+     */
 
-    this.current = this._getCurrentSize();
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this3 = this;
 
-    this._watcher();
-  },
+      this.$element.off('.abide').on('reset.zf.abide', function () {
+        _this3.resetForm();
+      }).on('submit.zf.abide', function () {
+        return _this3.validateForm();
+      });
 
+      if (this.options.validateOn === 'fieldChange') {
+        this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) {
+          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));
+        });
+      }
 
-  /**
-   * Checks if the screen is at least as wide as a breakpoint.
-   * @function
-   * @param {String} size - Name of the breakpoint to check.
-   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.
-   */
-  atLeast: function (size) {
-    var query = this.get(size);
+      if (this.options.liveValidate) {
+        this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) {
+          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));
+        });
+      }
 
-    if (query) {
-      return matchMedia(query).matches;
+      if (this.options.validateOnBlur) {
+        this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) {
+          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));
+        });
+      }
     }
+    /**
+     * Calls necessary functions to update Abide upon DOM change
+     * @private
+     */
 
-    return false;
-  },
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      this._init();
+    }
+    /**
+     * Checks whether or not a form element has the required attribute and if it's checked or not
+     * @param {Object} element - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
 
+  }, {
+    key: "requiredCheck",
+    value: function requiredCheck($el) {
+      if (!$el.attr('required')) return true;
+      var isGood = true;
 
-  /**
-   * Checks if the screen matches to a breakpoint.
-   * @function
-   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.
-   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.
-   */
-  is: function (size) {
-    size = size.trim().split(' ');
-    if (size.length > 1 && size[1] === 'only') {
-      if (size[0] === this._getCurrentSize()) return true;
-    } else {
-      return this.atLeast(size[0]);
-    }
-    return false;
-  },
+      switch ($el[0].type) {
+        case 'checkbox':
+          isGood = $el[0].checked;
+          break;
 
+        case 'select':
+        case 'select-one':
+        case 'select-multiple':
+          var opt = $el.find('option:selected');
+          if (!opt.length || !opt.val()) isGood = false;
+          break;
 
-  /**
-   * Gets the media query of a breakpoint.
-   * @function
-   * @param {String} size - Name of the breakpoint to get.
-   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.
-   */
-  get: function (size) {
-    for (var i in this.queries) {
-      if (this.queries.hasOwnProperty(i)) {
-        var query = this.queries[i];
-        if (size === query.name) return query.value;
+        default:
+          if (!$el.val() || !$el.val().length) isGood = false;
       }
+
+      return isGood;
     }
+    /**
+     * Get:
+     * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:
+     *   1. The element's direct sibling('s).
+     *   2. The element's parent's children.
+     * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.
+     *
+     * This allows for multiple form errors per input, though if none are found, no form errors will be shown.
+     *
+     * @param {Object} $el - jQuery object to use as reference to find the form error selector.
+     * @returns {Object} jQuery object with the selector.
+     */
 
-    return null;
-  },
+  }, {
+    key: "findFormError",
+    value: function findFormError($el) {
+      var id = $el[0].id;
+      var $error = $el.siblings(this.options.formErrorSelector);
 
+      if (!$error.length) {
+        $error = $el.parent().find(this.options.formErrorSelector);
+      }
 
-  /**
-   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).
-   * @function
-   * @private
-   * @returns {String} Name of the current breakpoint.
-   */
-  _getCurrentSize: function () {
-    var matched;
+      if (id) {
+        $error = $error.add(this.$element.find("[data-form-error-for=\"".concat(id, "\"]")));
+      }
 
-    for (var i = 0; i < this.queries.length; i++) {
-      var query = this.queries[i];
+      return $error;
+    }
+    /**
+     * Get the first element in this order:
+     * 2. The <label> with the attribute `[for="someInputId"]`
+     * 3. The `.closest()` <label>
+     *
+     * @param {Object} $el - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
 
-      if (matchMedia(query.value).matches) {
-        matched = query;
+  }, {
+    key: "findLabel",
+    value: function findLabel($el) {
+      var id = $el[0].id;
+      var $label = this.$element.find("label[for=\"".concat(id, "\"]"));
+
+      if (!$label.length) {
+        return $el.closest('label');
       }
-    }
 
-    if (typeof matched === 'object') {
-      return matched.name;
-    } else {
-      return matched;
+      return $label;
     }
-  },
+    /**
+     * Get the set of labels associated with a set of radio els in this order
+     * 2. The <label> with the attribute `[for="someInputId"]`
+     * 3. The `.closest()` <label>
+     *
+     * @param {Object} $el - jQuery object to check for required attribute
+     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     */
 
+  }, {
+    key: "findRadioLabels",
+    value: function findRadioLabels($els) {
+      var _this4 = this;
 
-  /**
-   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.
-   * @function
-   * @private
-   */
-  _watcher: function () {
-    var _this = this;
+      var labels = $els.map(function (i, el) {
+        var id = el.id;
 
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {
-      var newSize = _this._getCurrentSize(),
-          currentSize = _this.current;
+        var $label = _this4.$element.find("label[for=\"".concat(id, "\"]"));
 
-      if (newSize !== currentSize) {
-        // Change the current media query
-        _this.current = newSize;
+        if (!$label.length) {
+          $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).closest('label');
+        }
+
+        return $label[0];
+      });
+      return jquery__WEBPACK_IMPORTED_MODULE_0___default()(labels);
+    }
+    /**
+     * Adds the CSS error class as specified by the Abide settings to the label, input, and the form
+     * @param {Object} $el - jQuery object to add the class to
+     */
+
+  }, {
+    key: "addErrorClasses",
+    value: function addErrorClasses($el) {
+      var $label = this.findLabel($el);
+      var $formError = this.findFormError($el);
 
-        // Broadcast the media query change on the window
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
+      if ($label.length) {
+        $label.addClass(this.options.labelErrorClass);
       }
-    });
-  }
-};
 
-// Thank you: https://github.com/sindresorhus/query-string
-function parseStyleToObject(str) {
-  var styleObject = {};
+      if ($formError.length) {
+        $formError.addClass(this.options.formErrorClass);
+      }
 
-  if (typeof str !== 'string') {
-    return styleObject;
-  }
+      $el.addClass(this.options.inputErrorClass).attr({
+        'data-invalid': '',
+        'aria-invalid': true
+      });
+    }
+    /**
+     * Adds [for] and [role=alert] attributes to all form error targetting $el,
+     * and [aria-describedby] attribute to $el toward the first form error.
+     * @param {Object} $el - jQuery object
+     */
 
-  str = str.trim().slice(1, -1); // browsers re-quote string style values
+  }, {
+    key: "addA11yAttributes",
+    value: function addA11yAttributes($el) {
+      var $errors = this.findFormError($el);
+      var $labels = $errors.filter('label');
+      var $error = $errors.first();
+      if (!$errors.length) return; // Set [aria-describedby] on the input toward the first form error if it is not set
 
-  if (!str) {
-    return styleObject;
-  }
-
-  styleObject = str.split('&').reduce(function (ret, param) {
-    var parts = param.replace(/\+/g, ' ').split('=');
-    var key = parts[0];
-    var val = parts[1];
-    key = decodeURIComponent(key);
-
-    // missing `=` should be `null`:
-    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters
-    val = val === undefined ? null : decodeURIComponent(val);
-
-    if (!ret.hasOwnProperty(key)) {
-      ret[key] = val;
-    } else if (Array.isArray(ret[key])) {
-      ret[key].push(val);
-    } else {
-      ret[key] = [ret[key], val];
-    }
-    return ret;
-  }, {});
-
-  return styleObject;
-}
+      if (typeof $el.attr('aria-describedby') === 'undefined') {
+        // Get the first error ID or create one
+        var errorId = $error.attr('id');
 
+        if (typeof errorId === 'undefined') {
+          errorId = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'abide-error');
+          $error.attr('id', errorId);
+        }
 
+        ;
+        $el.attr('aria-describedby', errorId);
+      }
 
-/***/ }),
-/* 5 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+      if ($labels.filter('[for]').length < $labels.length) {
+        // Get the input ID or create one
+        var elemId = $el.attr('id');
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(6);
+        if (typeof elemId === 'undefined') {
+          elemId = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'abide-input');
+          $el.attr('id', elemId);
+        }
 
+        ; // For each label targeting $el, set [for] if it is not set.
 
+        $labels.each(function (i, label) {
+          var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label);
+          if (typeof $label.attr('for') === 'undefined') $label.attr('for', elemId);
+        });
+      } // For each error targeting $el, set [role=alert] if it is not set.
 
 
+      $errors.each(function (i, label) {
+        var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label);
+        if (typeof $label.attr('role') === 'undefined') $label.attr('role', 'alert');
+      }).end();
+    }
+    /**
+     * Adds [aria-live] attribute to the given global form error $el.
+     * @param {Object} $el - jQuery object to add the attribute to
+     */
 
-var MutationObserver = function () {
-  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
-  for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+  }, {
+    key: "addGlobalErrorA11yAttributes",
+    value: function addGlobalErrorA11yAttributes($el) {
+      if (typeof $el.attr('aria-live') === 'undefined') $el.attr('aria-live', this.options.a11yErrorLevel);
     }
-  }
-  return false;
-}();
+    /**
+     * Remove CSS error classes etc from an entire radio button group
+     * @param {String} groupName - A string that specifies the name of a radio button group
+     *
+     */
 
-var triggers = function (el, type) {
-  el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
-  });
-};
+  }, {
+    key: "removeRadioErrorClasses",
+    value: function removeRadioErrorClasses(groupName) {
+      var $els = this.$element.find(":radio[name=\"".concat(groupName, "\"]"));
+      var $labels = this.findRadioLabels($els);
+      var $formErrors = this.findFormError($els);
 
-var Triggers = {
-  Listeners: {
-    Basic: {},
-    Global: {}
-  },
-  Initializers: {}
-};
+      if ($labels.length) {
+        $labels.removeClass(this.options.labelErrorClass);
+      }
 
-Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
-  },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
-    if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
-    } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
-    }
-  },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
-    if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
-    } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
-    }
-  },
-  closeableListener: function (e) {
-    e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+      if ($formErrors.length) {
+        $formErrors.removeClass(this.options.formErrorClass);
+      }
 
-    if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["a" /* Motion */].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      $els.removeClass(this.options.inputErrorClass).attr({
+        'data-invalid': null,
+        'aria-invalid': null
       });
-    } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
     }
-  },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
-  }
-};
-
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
-Triggers.Initializers.addOpenListener = function ($elem) {
-  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
-  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
+    /**
+     * Removes CSS error class as specified by the Abide settings from the label, input, and the form
+     * @param {Object} $el - jQuery object to remove the class from
+     */
 
-// Elements with [data-close] will close a plugin that supports it when clicked.
-// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
-Triggers.Initializers.addCloseListener = function ($elem) {
-  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
-  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+  }, {
+    key: "removeErrorClasses",
+    value: function removeErrorClasses($el) {
+      // radios need to clear all of the els
+      if ($el[0].type == 'radio') {
+        return this.removeRadioErrorClasses($el.attr('name'));
+      }
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
-Triggers.Initializers.addToggleListener = function ($elem) {
-  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
-  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+      var $label = this.findLabel($el);
+      var $formError = this.findFormError($el);
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
-Triggers.Initializers.addCloseableListener = function ($elem) {
-  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
-  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+      if ($label.length) {
+        $label.removeClass(this.options.labelErrorClass);
+      }
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
-Triggers.Initializers.addToggleFocusListener = function ($elem) {
-  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
-  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+      if ($formError.length) {
+        $formError.removeClass(this.options.formErrorClass);
+      }
 
-// More Global/complex listeners and triggers
-Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
-    if (!MutationObserver) {
-      //fallback for IE 9
-      $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
-      });
-    }
-    //trigger all listening elements and signal a resize event
-    $nodes.attr('data-events', "resize");
-  },
-  scrollListener: function ($nodes) {
-    if (!MutationObserver) {
-      //fallback for IE 9
-      $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+      $el.removeClass(this.options.inputErrorClass).attr({
+        'data-invalid': null,
+        'aria-invalid': null
       });
     }
-    //trigger all listening elements and signal a scroll event
-    $nodes.attr('data-events', "scroll");
-  },
-  closeMeListener: function (e, pluginId) {
-    var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
+    /**
+     * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.
+     * Ignores inputs with data-abide-ignore, type="hidden" or disabled attributes set
+     * @fires Abide#invalid
+     * @fires Abide#valid
+     * @param {Object} element - jQuery object to validate, should be an HTML input
+     * @returns {Boolean} goodToGo - If the input is valid or not.
+     */
 
-    plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
-      _this.triggerHandler('close.zf.trigger', [_this]);
-    });
-  }
+  }, {
+    key: "validateInput",
+    value: function validateInput($el) {
+      var clearRequire = this.requiredCheck($el),
+          validated = false,
+          customValidator = true,
+          validator = $el.attr('data-validator'),
+          equalTo = true; // don't validate ignored inputs or hidden inputs or disabled inputs
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
-      plugNames = ['dropdown', 'tooltip', 'reveal'];
+      if ($el.is('[data-abide-ignore]') || $el.is('[type="hidden"]') || $el.is('[disabled]')) {
+        return true;
+      }
 
-  if (pluginName) {
-    if (typeof pluginName === 'string') {
-      plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
-    } else {
-      console.error('Plugin names must be strings');
-    }
-  }
-  if (yetiBoxes.length) {
-    var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
-    }).join(' ');
+      switch ($el[0].type) {
+        case 'radio':
+          validated = this.validateRadio($el.attr('name'));
+          break;
 
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
-  }
-};
+        case 'checkbox':
+          validated = clearRequire;
+          break;
 
-function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
-      args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
-    if (timer) {
-      clearTimeout(timer);
-    }
-    timer = setTimeout(function () {
-      listener.apply(null, args);
-    }, debounce || 10); //default time to emit scroll event
-  });
-}
+        case 'select':
+        case 'select-one':
+        case 'select-multiple':
+          validated = clearRequire;
+          break;
 
-Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
-  if ($nodes.length) {
-    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
-  }
-};
+        default:
+          validated = this.validateText($el);
+      }
 
-Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
-  if ($nodes.length) {
-    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
-  }
-};
+      if (validator) {
+        customValidator = this.matchValidation($el, validator, $el.attr('required'));
+      }
 
-Triggers.Initializers.addMutationEventsListener = function ($elem) {
-  if (!MutationObserver) {
-    return false;
-  }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
+      if ($el.attr('data-equalto')) {
+        equalTo = this.options.validators.equalTo($el);
+      }
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+      var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;
+      var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';
 
-    //trigger the event handler for the element depending on type
-    switch (mutationRecordsList[0].type) {
-      case "attributes":
-        if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
-          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
-        }
-        if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
-          $target.triggerHandler('resizeme.zf.trigger', [$target]);
-        }
-        if (mutationRecordsList[0].attributeName === "style") {
-          $target.closest("[data-mutate]").attr("data-events", "mutate");
-          $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+      if (goodToGo) {
+        // Re-validate inputs that depend on this one with equalto
+        var dependentElements = this.$element.find("[data-equalto=\"".concat($el.attr('id'), "\"]"));
+
+        if (dependentElements.length) {
+          var _this = this;
+
+          dependentElements.each(function () {
+            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val()) {
+              _this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
+            }
+          });
         }
-        break;
+      }
 
-      case "childList":
-        $target.closest("[data-mutate]").attr("data-events", "mutate");
-        $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
-        break;
+      this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);
+      /**
+       * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`
+       * Trigger includes the DOM element of the input.
+       * @event Abide#valid
+       * @event Abide#invalid
+       */
 
-      default:
-        return false;
-      //nothing
+      $el.trigger(message, [$el]);
+      return goodToGo;
     }
-  };
-
-  if ($nodes.length) {
-    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
-    for (var i = 0; i <= $nodes.length - 1; i++) {
-      var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
-    }
-  }
-};
-
-Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+    /**
+     * Goes through a form and if there are any invalid inputs, it will display the form error element
+     * @returns {Boolean} noError - true if no errors were detected...
+     * @fires Abide#formvalid
+     * @fires Abide#forminvalid
+     */
 
-  Triggers.Initializers.addOpenListener($document);
-  Triggers.Initializers.addCloseListener($document);
-  Triggers.Initializers.addToggleListener($document);
-  Triggers.Initializers.addCloseableListener($document);
-  Triggers.Initializers.addToggleFocusListener($document);
-};
+  }, {
+    key: "validateForm",
+    value: function validateForm() {
+      var _this5 = this;
 
-Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-  Triggers.Initializers.addMutationEventsListener($document);
-  Triggers.Initializers.addResizeListener();
-  Triggers.Initializers.addScrollListener();
-  Triggers.Initializers.addClosemeListener();
-};
+      var acc = [];
 
-Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
+      var _this = this;
 
-    if (document.readyState === "complete") {
-      Triggers.Initializers.addSimpleListeners();
-      Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
+      this.$inputs.each(function () {
+        acc.push(_this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)));
       });
-    }
-
-    $.triggersInitialized = true;
-  }
-
-  if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
-    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
-  }
-};
+      var noError = acc.indexOf(false) === -1;
+      this.$element.find('[data-abide-error]').each(function (i, elem) {
+        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem); // Ensure a11y attributes are set
 
+        if (_this5.options.a11yAttributes) _this5.addGlobalErrorA11yAttributes($elem); // Show or hide the error
 
+        $elem.css('display', noError ? 'none' : 'block');
+      });
+      /**
+       * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.
+       * Trigger includes the element of the form.
+       * @event Abide#formvalid
+       * @event Abide#forminvalid
+       */
 
-/***/ }),
-/* 6 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+      this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);
+      return noError;
+    }
+    /**
+     * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.
+     * @param {Object} $el - jQuery object to validate, should be a text input HTML element
+     * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns
+     * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified
+     */
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return Move; });
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Motion; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
+  }, {
+    key: "validateText",
+    value: function validateText($el, pattern) {
+      // A pattern can be passed to this function, or it will be infered from the input's "pattern" attribute, or it's "type" attribute
+      pattern = pattern || $el.attr('pattern') || $el.attr('type');
+      var inputText = $el.val();
+      var valid = false;
 
+      if (inputText.length) {
+        // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp
+        if (this.options.patterns.hasOwnProperty(pattern)) {
+          valid = this.options.patterns[pattern].test(inputText);
+        } // If the pattern name isn't also the type attribute of the field, then test it as a regexp
+        else if (pattern !== $el.attr('type')) {
+            valid = new RegExp(pattern).test(inputText);
+          } else {
+            valid = true;
+          }
+      } // An empty field is valid if it's not required
+      else if (!$el.prop('required')) {
+          valid = true;
+        }
 
+      return valid;
+    }
+    /**
+     * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.
+     * @param {String} groupName - A string that specifies the name of a radio button group
+     * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)
+     */
 
+  }, {
+    key: "validateRadio",
+    value: function validateRadio(groupName) {
+      // If at least one radio in the group has the `required` attribute, the group is considered required
+      // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice
+      var $group = this.$element.find(":radio[name=\"".concat(groupName, "\"]"));
+      var valid = false,
+          required = false; // For the group to be required, at least one radio needs to be required
 
+      $group.each(function (i, e) {
+        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).attr('required')) {
+          required = true;
+        }
+      });
+      if (!required) valid = true;
 
-/**
- * Motion module.
- * @module foundation.motion
- */
+      if (!valid) {
+        // For the group to be valid, at least one radio needs to be checked
+        $group.each(function (i, e) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).prop('checked')) {
+            valid = true;
+          }
+        });
+      }
 
-var initClasses = ['mui-enter', 'mui-leave'];
-var activeClasses = ['mui-enter-active', 'mui-leave-active'];
+      ;
+      return valid;
+    }
+    /**
+     * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator="foo bar baz"` in a space separated listed.
+     * @param {Object} $el - jQuery input element.
+     * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.
+     * @param {Boolean} required - self explanatory?
+     * @returns {Boolean} - true if validations passed.
+     */
 
-var Motion = {
-  animateIn: function (element, animation, cb) {
-    animate(true, element, animation, cb);
-  },
+  }, {
+    key: "matchValidation",
+    value: function matchValidation($el, validators, required) {
+      var _this6 = this;
 
-  animateOut: function (element, animation, cb) {
-    animate(false, element, animation, cb);
-  }
-};
+      required = required ? true : false;
+      var clear = validators.split(' ').map(function (v) {
+        return _this6.options.validators[v]($el, required, $el.parent());
+      });
+      return clear.indexOf(false) === -1;
+    }
+    /**
+     * Resets form inputs and styles
+     * @fires Abide#formreset
+     */
 
-function Move(duration, elem, fn) {
-  var anim,
-      prog,
-      start = null;
-  // console.log('called');
+  }, {
+    key: "resetForm",
+    value: function resetForm() {
+      var $form = this.$element,
+          opts = this.options;
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(".".concat(opts.labelErrorClass), $form).not('small').removeClass(opts.labelErrorClass);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(".".concat(opts.inputErrorClass), $form).not('small').removeClass(opts.inputErrorClass);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("".concat(opts.formErrorSelector, ".").concat(opts.formErrorClass)).removeClass(opts.formErrorClass);
+      $form.find('[data-abide-error]').css('display', 'none');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      /**
+       * Fires when the form has been reset.
+       * @event Abide#formreset
+       */
 
-  if (duration === 0) {
-    fn.apply(elem);
-    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
-    return;
-  }
+      $form.trigger('formreset.zf.abide', [$form]);
+    }
+    /**
+     * Destroys an instance of Abide.
+     * Removes error styles and classes from elements, without resetting their values.
+     */
 
-  function move(ts) {
-    if (!start) start = ts;
-    // console.log(start, ts);
-    prog = ts - start;
-    fn.apply(elem);
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      var _this = this;
 
-    if (prog < duration) {
-      anim = window.requestAnimationFrame(move, elem);
-    } else {
-      window.cancelAnimationFrame(anim);
-      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
+      this.$element.off('.abide').find('[data-abide-error]').css('display', 'none');
+      this.$inputs.off('.abide').each(function () {
+        _this.removeErrorClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
+      });
     }
-  }
-  anim = window.requestAnimationFrame(move);
-}
+  }]);
 
+  return Abide;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 /**
- * Animates an element in or out using a CSS transition class.
- * @function
- * @private
- * @param {Boolean} isIn - Defines if the animation is in or out.
- * @param {Object} element - jQuery or HTML object to animate.
- * @param {String} animation - CSS class to use.
- * @param {Function} cb - Callback to run when animation is finished.
+ * Default settings for plugin
  */
-function animate(isIn, element, animation, cb) {
-  element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(element).eq(0);
 
-  if (!element.length) return;
 
-  var initClass = isIn ? initClasses[0] : initClasses[1];
-  var activeClass = isIn ? activeClasses[0] : activeClasses[1];
+Abide.defaults = {
+  /**
+   * The default event to validate inputs. Checkboxes and radios validate immediately.
+   * Remove or change this value for manual validation.
+   * @option
+   * @type {?string}
+   * @default 'fieldChange'
+   */
+  validateOn: 'fieldChange',
 
-  // Set up the animation
-  reset();
+  /**
+   * Class to be applied to input labels on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-invalid-label'
+   */
+  labelErrorClass: 'is-invalid-label',
 
-  element.addClass(animation).css('transition', 'none');
+  /**
+   * Class to be applied to inputs on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-invalid-input'
+   */
+  inputErrorClass: 'is-invalid-input',
 
-  requestAnimationFrame(function () {
-    element.addClass(initClass);
-    if (isIn) element.show();
-  });
+  /**
+   * Class selector to use to target Form Errors for show/hide.
+   * @option
+   * @type {string}
+   * @default '.form-error'
+   */
+  formErrorSelector: '.form-error',
 
-  // Start the animation
-  requestAnimationFrame(function () {
-    element[0].offsetWidth;
-    element.css('transition', '').addClass(activeClass);
-  });
+  /**
+   * Class added to Form Errors on failed validation.
+   * @option
+   * @type {string}
+   * @default 'is-visible'
+   */
+  formErrorClass: 'is-visible',
 
-  // Clean up the animation when it finishes
-  element.one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["c" /* transitionend */])(element), finish);
+  /**
+   * If true, automatically insert when possible:
+   * - `[aria-describedby]` on fields
+   * - `[role=alert]` on form errors and `[for]` on form error labels
+   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  a11yAttributes: true,
 
-  // Hides the element (for out animations), resets the element, and runs a callback
-  function finish() {
-    if (!isIn) element.hide();
-    reset();
-    if (cb) cb.apply(element);
-  }
+  /**
+   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.
+   * Options are: 'assertive', 'polite' and 'off'/null
+   * @option
+   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions
+   * @type {string}
+   * @default 'assertive'
+   */
+  a11yErrorLevel: 'assertive',
 
-  // Resets transitions and removes motion-specific classes
-  function reset() {
-    element[0].style.transitionDuration = 0;
-    element.removeClass(initClass + ' ' + activeClass + ' ' + animation);
-  }
-}
+  /**
+   * Set to true to validate text inputs on any value change.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  liveValidate: false,
+
+  /**
+   * Set to true to validate inputs on blur.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  validateOnBlur: false,
+  patterns: {
+    alpha: /^[a-zA-Z]+$/,
+    alpha_numeric: /^[a-zA-Z0-9]+$/,
+    integer: /^[-+]?\d+$/,
+    number: /^[-+]?\d*(?:[\.\,]\d+)?$/,
+    // amex, visa, diners
+    card: /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,
+    cvv: /^([0-9]){3,4}$/,
+    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address
+    email: /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,
+    // From CommonRegexJS (@talyssonoc)
+    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76
+    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.
+    url: /^((?:(https?|ftps?|file|ssh|sftp):\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\))+(?:\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?\xab\xbb\u201c\u201d\u2018\u2019]))$/,
+    // abc.de
+    domain: /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,
+    datetime: /^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,
+    // YYYY-MM-DD
+    date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,
+    // HH:MM:SS
+    time: /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,
+    dateISO: /^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,
+    // MM/DD/YYYY
+    month_day_year: /^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,
+    // DD/MM/YYYY
+    day_month_year: /^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,
+    // #FFF or #FFFFFF
+    color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,
+    // Domain || URL
+    website: {
+      test: function test(text) {
+        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);
+      }
+    }
+  },
 
+  /**
+   * Optional validation functions to be used. `equalTo` being the only default included function.
+   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:
+   * el : The jQuery element to validate.
+   * required : Boolean value of the required attribute be present or not.
+   * parent : The direct parent of the input.
+   * @option
+   */
+  validators: {
+    equalTo: function equalTo(el, required, parent) {
+      return jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(el.attr('data-equalto'))).val() === el.val();
+    }
+  }
+};
 
 
 /***/ }),
-/* 7 */
+
+/***/ "./js/foundation.accordion.js":
+/*!************************************!*\
+  !*** ./js/foundation.accordion.js ***!
+  \************************************/
+/*! exports provided: Accordion */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Box; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_util_core__ = __webpack_require__(1);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Accordion", function() { return Accordion; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
 
 
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-var Box = {
-  ImNotTouchingYou: ImNotTouchingYou,
-  OverlapArea: OverlapArea,
-  GetDimensions: GetDimensions,
-  GetOffsets: GetOffsets,
-  GetExplicitOffsets: GetExplicitOffsets
+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); } }
 
-  /**
-   * Compares the dimensions of an element to a container and determines collision events with container.
-   * @function
-   * @param {jQuery} element - jQuery object to test for collisions.
-   * @param {jQuery} parent - jQuery object to use as bounding container.
-   * @param {Boolean} lrOnly - set to true to check left and right values only.
-   * @param {Boolean} tbOnly - set to true to check top and bottom values only.
-   * @default if no parent object passed, detects collisions with `window`.
-   * @returns {Boolean} - true if collision free, false if a collision in any direction.
-   */
-};function ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {
-  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;
-};
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {
-  var eleDims = GetDimensions(element),
-      topOver,
-      bottomOver,
-      leftOver,
-      rightOver;
-  if (parent) {
-    var parDims = GetDimensions(parent);
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
-    bottomOver = parDims.height + parDims.offset.top - (eleDims.offset.top + eleDims.height);
-    topOver = eleDims.offset.top - parDims.offset.top;
-    leftOver = eleDims.offset.left - parDims.offset.left;
-    rightOver = parDims.width + parDims.offset.left - (eleDims.offset.left + eleDims.width);
-  } else {
-    bottomOver = eleDims.windowDims.height + eleDims.windowDims.offset.top - (eleDims.offset.top + eleDims.height);
-    topOver = eleDims.offset.top - eleDims.windowDims.offset.top;
-    leftOver = eleDims.offset.left - eleDims.windowDims.offset.left;
-    rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);
-  }
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);
-  topOver = Math.min(topOver, 0);
-  leftOver = Math.min(leftOver, 0);
-  rightOver = Math.min(rightOver, 0);
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-  if (lrOnly) {
-    return leftOver + rightOver;
-  }
-  if (tbOnly) {
-    return topOver + bottomOver;
-  }
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
-  // use sum of squares b/c we care about overlap area.
-  return Math.sqrt(topOver * topOver + bottomOver * bottomOver + leftOver * leftOver + rightOver * rightOver);
-}
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-/**
- * Uses native methods to return an object of dimension values.
- * @function
- * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.
- * @returns {Object} - nested object of integer pixel values
- * TODO - if element is window, return only those values.
- */
-function GetDimensions(elem) {
-  elem = elem.length ? elem[0] : elem;
 
-  if (elem === window || elem === document) {
-    throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");
-  }
 
-  var rect = elem.getBoundingClientRect(),
-      parRect = elem.parentNode.getBoundingClientRect(),
-      winRect = document.body.getBoundingClientRect(),
-      winY = window.pageYOffset,
-      winX = window.pageXOffset;
 
-  return {
-    width: rect.width,
-    height: rect.height,
-    offset: {
-      top: rect.top + winY,
-      left: rect.left + winX
-    },
-    parentDims: {
-      width: parRect.width,
-      height: parRect.height,
-      offset: {
-        top: parRect.top + winY,
-        left: parRect.left + winX
-      }
-    },
-    windowDims: {
-      width: winRect.width,
-      height: winRect.height,
-      offset: {
-        top: winY,
-        left: winX
-      }
-    }
-  };
-}
 
 /**
- * Returns an object of top and left integer pixel values for dynamically rendered elements,
- * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where
- * you don't know alignment, but generally from
- * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.
- * @function
- * @param {jQuery} element - jQuery object for the element being positioned.
- * @param {jQuery} anchor - jQuery object for the element's anchor point.
- * @param {String} position - a string relating to the desired position of the element, relative to it's anchor
- * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.
- * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.
- * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.
- * TODO alter/rewrite to work with `em` values as well/instead of pixels
+ * Accordion module.
+ * @module foundation.accordion
+ * @requires foundation.util.keyboard
  */
-function GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {
-  console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5");
-  switch (position) {
-    case 'top':
-      return __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__foundation_util_core__["a" /* rtl */])() ? GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);
-    case 'bottom':
-      return __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__foundation_util_core__["a" /* rtl */])() ? GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
-    case 'center top':
-      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);
-    case 'center bottom':
-      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);
-    case 'center left':
-      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);
-    case 'center right':
-      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);
-    case 'left bottom':
-      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);
-    case 'right bottom':
-      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
-    // Backwards compatibility... this along with the reveal and reveal full
-    // classes are the only ones that didn't reference anchor
-    case 'center':
-      return {
-        left: $eleDims.windowDims.offset.left + $eleDims.windowDims.width / 2 - $eleDims.width / 2 + hOffset,
-        top: $eleDims.windowDims.offset.top + $eleDims.windowDims.height / 2 - ($eleDims.height / 2 + vOffset)
-      };
-    case 'reveal':
-      return {
-        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,
-        top: $eleDims.windowDims.offset.top + vOffset
-      };
-    case 'reveal full':
-      return {
-        left: $eleDims.windowDims.offset.left,
-        top: $eleDims.windowDims.offset.top
-      };
-      break;
-    default:
-      return {
-        left: __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__foundation_util_core__["a" /* rtl */])() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset : $anchorDims.offset.left + hOffset,
-        top: $anchorDims.offset.top + $anchorDims.height + vOffset
-      };
 
+var Accordion =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Accordion, _Plugin);
+
+  function Accordion() {
+    _classCallCheck(this, Accordion);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Accordion).apply(this, arguments));
   }
-}
 
-function GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {
-  var $eleDims = GetDimensions(element),
-      $anchorDims = anchor ? GetDimensions(anchor) : null;
+  _createClass(Accordion, [{
+    key: "_setup",
 
-  var topVal, leftVal;
+    /**
+     * Creates a new instance of an accordion.
+     * @class
+     * @name Accordion
+     * @fires Accordion#init
+     * @param {jQuery} element - jQuery object to make into an accordion.
+     * @param {Object} options - a plain object with settings to override the default options.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Accordion.defaults, this.$element.data(), options);
+      this.className = 'Accordion'; // ie9 back compat
 
-  // set position related attribute
+      this._init();
 
-  switch (position) {
-    case 'top':
-      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);
-      break;
-    case 'bottom':
-      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;
-      break;
-    case 'left':
-      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);
-      break;
-    case 'right':
-      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;
-      break;
-  }
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('Accordion', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
+        'ARROW_DOWN': 'next',
+        'ARROW_UP': 'previous'
+      });
+    }
+    /**
+     * Initializes the accordion by animating the preset active pane(s).
+     * @private
+     */
 
-  // set alignment related attribute
-  switch (position) {
-    case 'top':
-    case 'bottom':
-      switch (alignment) {
-        case 'left':
-          leftVal = $anchorDims.offset.left + hOffset;
-          break;
-        case 'right':
-          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;
-          break;
-        case 'center':
-          leftVal = isOverflow ? hOffset : $anchorDims.offset.left + $anchorDims.width / 2 - $eleDims.width / 2 + hOffset;
-          break;
-      }
-      break;
-    case 'right':
-    case 'left':
-      switch (alignment) {
-        case 'bottom':
-          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;
-          break;
-        case 'top':
-          topVal = $anchorDims.offset.top + vOffset;
-          break;
-        case 'center':
-          topVal = $anchorDims.offset.top + vOffset + $anchorDims.height / 2 - $eleDims.height / 2;
-          break;
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      this._isInitializing = true;
+      this.$element.attr('role', 'tablist');
+      this.$tabs = this.$element.children('[data-accordion-item]');
+      this.$tabs.each(function (idx, el) {
+        var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el),
+            $content = $el.children('[data-tab-content]'),
+            id = $content[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'accordion'),
+            linkId = el.id ? "".concat(el.id, "-label") : "".concat(id, "-label");
+        $el.find('a:first').attr({
+          'aria-controls': id,
+          'role': 'tab',
+          'id': linkId,
+          'aria-expanded': false,
+          'aria-selected': false
+        });
+        $content.attr({
+          'role': 'tabpanel',
+          'aria-labelledby': linkId,
+          'aria-hidden': true,
+          'id': id
+        });
+      });
+      var $initActive = this.$element.find('.is-active').children('[data-tab-content]');
+
+      if ($initActive.length) {
+        // Save up the initial hash to return to it later when going back in history
+        this._initialAnchor = $initActive.prev('a').attr('href');
+
+        this._openSingleTab($initActive);
       }
-      break;
-  }
-  return { top: topVal, left: leftVal };
-}
 
+      this._checkDeepLink = function () {
+        var anchor = window.location.hash;
 
+        if (!anchor.length) {
+          // If we are still initializing and there is no anchor, then there is nothing to do
+          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor
 
-/***/ }),
-/* 8 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+          if (_this2._initialAnchor) anchor = _this2._initialAnchor;
+        }
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return onImagesLoaded; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+        var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor);
 
+        var $link = anchor && _this2.$element.find("[href$=\"".concat(anchor, "\"]")); // Whether the anchor element that has been found is part of this element
 
 
+        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, open it (if not already active)
 
-/**
- * Runs a callback function when images are fully loaded.
- * @param {Object} images - Image(s) to check if loaded.
- * @param {Func} callback - Function to execute when image is fully loaded.
- */
-function onImagesLoaded(images, callback) {
-  var self = this,
-      unloaded = images.length;
+        if ($anchor && $link && $link.length) {
+          if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {
+            _this2._openSingleTab($anchor);
+          }
 
-  if (unloaded === 0) {
-    callback();
-  }
+          ;
+        } // Otherwise, close everything
+        else {
+            _this2._closeAllTabs();
+          }
 
-  images.each(function () {
-    // Check if image is loaded
-    if (this.complete && this.naturalWidth !== undefined) {
-      singleImageLoaded();
-    } else {
-      // If the above check failed, simulate loading on detached element.
-      var image = new Image();
-      // Still count image as loaded if it finalizes with an error.
-      var events = "load.zf.images error.zf.images";
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(image).one(events, function me(event) {
-        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).off(events, me);
-        singleImageLoaded();
-      });
-      image.src = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).attr('src');
-    }
-  });
+        if (isOwnAnchor) {
+          // Roll up a little to show the titles
+          if (_this2.options.deepLinkSmudge) {
+            Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+              var offset = _this2.$element.offset();
 
-  function singleImageLoaded() {
-    unloaded--;
-    if (unloaded === 0) {
-      callback();
-    }
-  }
-}
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({
+                scrollTop: offset.top
+              }, _this2.options.deepLinkSmudgeDelay);
+            });
+          }
+          /**
+           * Fires when the plugin has deeplinked at pageload
+           * @event Accordion#deeplink
+           */
 
 
+          _this2.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);
+        }
+      }; //use browser to open a tab, if it exists in this tabset
 
-/***/ }),
-/* 9 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Nest; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+      if (this.options.deepLink) {
+        this._checkDeepLink();
+      }
 
+      this._events();
 
+      this._isInitializing = false;
+    }
+    /**
+     * Adds event handlers for items within the accordion.
+     * @private
+     */
 
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
 
-var Nest = {
-  Feather: function (menu) {
-    var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zf';
+      this.$tabs.each(function () {
+        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+        var $tabContent = $elem.children('[data-tab-content]');
 
-    menu.attr('role', 'menubar');
+        if ($tabContent.length) {
+          $elem.children('a').off('click.zf.accordion keydown.zf.accordion').on('click.zf.accordion', function (e) {
+            e.preventDefault();
 
-    var items = menu.find('li').attr({ 'role': 'menuitem' }),
-        subMenuClass = 'is-' + type + '-submenu',
-        subItemClass = subMenuClass + '-item',
-        hasSubClass = 'is-' + type + '-submenu-parent',
-        applyAria = type !== 'accordion'; // Accordions handle their own ARIA attriutes.
+            _this.toggle($tabContent);
+          }).on('keydown.zf.accordion', function (e) {
+            _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'Accordion', {
+              toggle: function toggle() {
+                _this.toggle($tabContent);
+              },
+              next: function next() {
+                var $a = $elem.next().find('a').focus();
 
-    items.each(function () {
-      var $item = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-          $sub = $item.children('ul');
+                if (!_this.options.multiExpand) {
+                  $a.trigger('click.zf.accordion');
+                }
+              },
+              previous: function previous() {
+                var $a = $elem.prev().find('a').focus();
 
-      if ($sub.length) {
-        $item.addClass(hasSubClass);
-        $sub.addClass('submenu ' + subMenuClass).attr({ 'data-submenu': '' });
-        if (applyAria) {
-          $item.attr({
-            'aria-haspopup': true,
-            'aria-label': $item.children('a:first').text()
+                if (!_this.options.multiExpand) {
+                  $a.trigger('click.zf.accordion');
+                }
+              },
+              handled: function handled() {
+                e.preventDefault();
+                e.stopPropagation();
+              }
+            });
           });
-          // Note:  Drilldowns behave differently in how they hide, and so need
-          // additional attributes.  We should look if this possibly over-generalized
-          // utility (Nest) is appropriate when we rework menus in 6.4
-          if (type === 'drilldown') {
-            $item.attr({ 'aria-expanded': false });
-          }
-        }
-        $sub.addClass('submenu ' + subMenuClass).attr({
-          'data-submenu': '',
-          'role': 'menu'
-        });
-        if (type === 'drilldown') {
-          $sub.attr({ 'aria-hidden': true });
         }
+      });
+
+      if (this.options.deepLink) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink);
       }
+    }
+    /**
+     * Toggles the selected content pane's open/close state.
+     * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).
+     * @function
+     */
 
-      if ($item.parent('[data-submenu]').length) {
-        $item.addClass('is-submenu-item ' + subItemClass);
+  }, {
+    key: "toggle",
+    value: function toggle($target) {
+      if ($target.closest('[data-accordion]').is('[disabled]')) {
+        console.info('Cannot toggle an accordion that is disabled.');
+        return;
       }
-    });
 
-    return;
-  },
-  Burn: function (menu, type) {
-    var //items = menu.find('li'),
-    subMenuClass = 'is-' + type + '-submenu',
-        subItemClass = subMenuClass + '-item',
-        hasSubClass = 'is-' + type + '-submenu-parent';
+      if ($target.parent().hasClass('is-active')) {
+        this.up($target);
+      } else {
+        this.down($target);
+      } //either replace or update browser history
 
-    menu.find('>li, .menu, .menu > li').removeClass(subMenuClass + ' ' + subItemClass + ' ' + hasSubClass + ' is-submenu-item submenu is-active').removeAttr('data-submenu').css('display', '');
-  }
-};
 
+      if (this.options.deepLink) {
+        var anchor = $target.prev('a').attr('href');
 
+        if (this.options.updateHistory) {
+          history.pushState({}, '', anchor);
+        } else {
+          history.replaceState({}, '', anchor);
+        }
+      }
+    }
+    /**
+     * Opens the accordion tab defined by `$target`.
+     * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).
+     * @fires Accordion#down
+     * @function
+     */
 
-/***/ }),
-/* 10 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+  }, {
+    key: "down",
+    value: function down($target) {
+      if ($target.closest('[data-accordion]').is('[disabled]')) {
+        console.info('Cannot call down on an accordion that is disabled.');
+        return;
+      }
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Touch; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-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; }; }();
+      if (this.options.multiExpand) this._openTab($target);else this._openSingleTab($target);
+    }
+    /**
+     * Closes the tab defined by `$target`.
+     * It may be ignored if the Accordion options don't allow it.
+     *
+     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+     * @fires Accordion#up
+     * @function
+     */
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+  }, {
+    key: "up",
+    value: function up($target) {
+      if (this.$element.is('[disabled]')) {
+        console.info('Cannot call up on an accordion that is disabled.');
+        return;
+      } // Don't close the item if it is already closed
 
-//**************************************************
-//**Work inspired by multiple jquery swipe plugins**
-//**Done by Yohai Ararat ***************************
-//**************************************************
 
+      var $targetItem = $target.parent();
+      if (!$targetItem.hasClass('is-active')) return; // Don't close the item if there is no other active item (unless with `allowAllClosed`)
 
+      var $othersItems = $targetItem.siblings();
+      if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;
 
-var Touch = {};
+      this._closeTab($target);
+    }
+    /**
+     * Make the tab defined by `$target` the only opened tab, closing all others tabs.
+     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+     * @function
+     * @private
+     */
 
-var startPosX,
-    startPosY,
-    startTime,
-    elapsedTime,
-    isMoving = false;
+  }, {
+    key: "_openSingleTab",
+    value: function _openSingleTab($target) {
+      // Close all the others active tabs.
+      var $activeContents = this.$element.children('.is-active').children('[data-tab-content]');
 
-function onTouchEnd() {
-  //  alert(this);
-  this.removeEventListener('touchmove', onTouchMove);
-  this.removeEventListener('touchend', onTouchEnd);
-  isMoving = false;
-}
+      if ($activeContents.length) {
+        this._closeTab($activeContents.not($target));
+      } // Then open the target.
 
-function onTouchMove(e) {
-  if (__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.spotSwipe.preventDefault) {
-    e.preventDefault();
-  }
-  if (isMoving) {
-    var x = e.touches[0].pageX;
-    var y = e.touches[0].pageY;
-    var dx = startPosX - x;
-    var dy = startPosY - y;
-    var dir;
-    elapsedTime = new Date().getTime() - startTime;
-    if (Math.abs(dx) >= __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.spotSwipe.moveThreshold && elapsedTime <= __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.spotSwipe.timeThreshold) {
-      dir = dx > 0 ? 'left' : 'right';
-    }
-    // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
-    //   dir = dy > 0 ? 'down' : 'up';
-    // }
-    if (dir) {
-      e.preventDefault();
-      onTouchEnd.call(this);
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('swipe', dir).trigger('swipe' + dir);
+
+      this._openTab($target);
     }
-  }
-}
+    /**
+     * Opens the tab defined by `$target`.
+     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+     * @fires Accordion#down
+     * @function
+     * @private
+     */
 
-function onTouchStart(e) {
-  if (e.touches.length == 1) {
-    startPosX = e.touches[0].pageX;
-    startPosY = e.touches[0].pageY;
-    isMoving = true;
-    startTime = new Date().getTime();
-    this.addEventListener('touchmove', onTouchMove, false);
-    this.addEventListener('touchend', onTouchEnd, false);
-  }
-}
+  }, {
+    key: "_openTab",
+    value: function _openTab($target) {
+      var _this3 = this;
 
-function init() {
-  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);
-}
+      var $targetItem = $target.parent();
+      var targetContentId = $target.attr('aria-labelledby');
+      $target.attr('aria-hidden', false);
+      $targetItem.addClass('is-active');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetContentId)).attr({
+        'aria-expanded': true,
+        'aria-selected': true
+      });
+      $target.slideDown(this.options.slideSpeed, function () {
+        /**
+         * Fires when the tab is done opening.
+         * @event Accordion#down
+         */
+        _this3.$element.trigger('down.zf.accordion', [$target]);
+      });
+    }
+    /**
+     * Closes the tab defined by `$target`.
+     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+     * @fires Accordion#up
+     * @function
+     * @private
+     */
 
-function teardown() {
-  this.removeEventListener('touchstart', onTouchStart);
-}
+  }, {
+    key: "_closeTab",
+    value: function _closeTab($target) {
+      var _this4 = this;
 
-var SpotSwipe = function () {
-  function SpotSwipe($) {
-    _classCallCheck(this, SpotSwipe);
+      var $targetItem = $target.parent();
+      var targetContentId = $target.attr('aria-labelledby');
+      $target.attr('aria-hidden', true);
+      $targetItem.removeClass('is-active');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetContentId)).attr({
+        'aria-expanded': false,
+        'aria-selected': false
+      });
+      $target.slideUp(this.options.slideSpeed, function () {
+        /**
+         * Fires when the tab is done collapsing up.
+         * @event Accordion#up
+         */
+        _this4.$element.trigger('up.zf.accordion', [$target]);
+      });
+    }
+    /**
+     * Closes all active tabs
+     * @fires Accordion#up
+     * @function
+     * @private
+     */
 
-    this.version = '1.0.0';
-    this.enabled = 'ontouchstart' in document.documentElement;
-    this.preventDefault = false;
-    this.moveThreshold = 75;
-    this.timeThreshold = 200;
-    this.$ = $;
-    this._init();
-  }
+  }, {
+    key: "_closeAllTabs",
+    value: function _closeAllTabs() {
+      var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');
 
-  _createClass(SpotSwipe, [{
-    key: '_init',
-    value: function _init() {
-      var $ = this.$;
-      $.event.special.swipe = { setup: init };
+      if ($activeTabs.length) {
+        this._closeTab($activeTabs);
+      }
+    }
+    /**
+     * Destroys an instance of an accordion.
+     * @fires Accordion#destroyed
+     * @function
+     */
 
-      $.each(['left', 'up', 'down', 'right'], function () {
-        $.event.special['swipe' + this] = { setup: function () {
-            $(this).on('swipe', $.noop);
-          } };
-      });
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');
+      this.$element.find('a').off('.zf.accordion');
+
+      if (this.options.deepLink) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink);
+      }
     }
   }]);
 
-  return SpotSwipe;
-}();
+  return Accordion;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 
-/****************************************************
- * As far as I can tell, both setupSpotSwipe and    *
- * setupTouchHandler should be idempotent,          *
- * because they directly replace functions &        *
- * values, and do not add event handlers directly.  *
- ****************************************************/
+Accordion.defaults = {
+  /**
+   * Amount of time to animate the opening of an accordion pane.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  slideSpeed: 250,
 
-Touch.setupSpotSwipe = function ($) {
-  $.spotSwipe = new SpotSwipe($);
-};
+  /**
+   * Allow the accordion to have multiple open panes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  multiExpand: false,
 
-/****************************************************
- * Method for adding pseudo drag events to elements *
- ***************************************************/
-Touch.setupTouchHandler = function ($) {
-  $.fn.addTouch = function () {
-    this.each(function (i, el) {
-      $(el).bind('touchstart touchmove touchend touchcancel', function () {
-        //we pass the original event object because the jQuery event
-        //object is normalized to w3c specs and does not provide the TouchList
-        handleTouch(event);
-      });
-    });
+  /**
+   * Allow the accordion to close all panes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowAllClosed: false,
 
-    var handleTouch = function (event) {
-      var touches = event.changedTouches,
-          first = touches[0],
-          eventTypes = {
-        touchstart: 'mousedown',
-        touchmove: 'mousemove',
-        touchend: 'mouseup'
-      },
-          type = eventTypes[event.type],
-          simulatedEvent;
+  /**
+   * Link the location hash to the open pane.
+   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
 
-      if ('MouseEvent' in window && typeof window.MouseEvent === 'function') {
-        simulatedEvent = new window.MouseEvent(type, {
-          'bubbles': true,
-          'cancelable': true,
-          'screenX': first.screenX,
-          'screenY': first.screenY,
-          'clientX': first.clientX,
-          'clientY': first.clientY
-        });
-      } else {
-        simulatedEvent = document.createEvent('MouseEvent');
-        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0 /*left*/, null);
-      }
-      first.target.dispatchEvent(simulatedEvent);
-    };
-  };
-};
+  /**
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinkSmudge: false,
 
-Touch.init = function ($) {
-  if (typeof $.spotSwipe === 'undefined') {
-    Touch.setupSpotSwipe($);
-    Touch.setupTouchHandler($);
-  }
-};
+  /**
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
+   * @option
+   * @type {number}
+   * @default 300
+   */
+  deepLinkSmudgeDelay: 300,
 
+  /**
+   * If `deepLink` is enabled, update the browser history with the open accordion
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  updateHistory: false
+};
 
 
 /***/ }),
-/* 11 */
+
+/***/ "./js/foundation.accordionMenu.js":
+/*!****************************************!*\
+  !*** ./js/foundation.accordionMenu.js ***!
+  \****************************************/
+/*! exports provided: AccordionMenu */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Accordion; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AccordionMenu", function() { return AccordionMenu; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.nest */ "./js/foundation.util.nest.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(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 _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -1586,766 +1586,1083 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
 
 
 /**
- * Accordion module.
- * @module foundation.accordion
+ * AccordionMenu module.
+ * @module foundation.accordionMenu
  * @requires foundation.util.keyboard
+ * @requires foundation.util.nest
  */
 
-var Accordion = function (_Plugin) {
-  _inherits(Accordion, _Plugin);
+var AccordionMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(AccordionMenu, _Plugin);
 
-  function Accordion() {
-    _classCallCheck(this, Accordion);
+  function AccordionMenu() {
+    _classCallCheck(this, AccordionMenu);
 
-    return _possibleConstructorReturn(this, (Accordion.__proto__ || Object.getPrototypeOf(Accordion)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(AccordionMenu).apply(this, arguments));
   }
 
-  _createClass(Accordion, [{
-    key: '_setup',
+  _createClass(AccordionMenu, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of an accordion.
+     * Creates a new instance of an accordion menu.
      * @class
-     * @name Accordion
-     * @fires Accordion#init
-     * @param {jQuery} element - jQuery object to make into an accordion.
-     * @param {Object} options - a plain object with settings to override the default options.
+     * @name AccordionMenu
+     * @fires AccordionMenu#init
+     * @param {jQuery} element - jQuery object to make into an accordion menu.
+     * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Accordion.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, AccordionMenu.defaults, this.$element.data(), options);
+      this.className = 'AccordionMenu'; // ie9 back compat
 
-      this.className = 'Accordion'; // ie9 back compat
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('Accordion', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('AccordionMenu', {
         'ENTER': 'toggle',
         'SPACE': 'toggle',
-        'ARROW_DOWN': 'next',
-        'ARROW_UP': 'previous'
+        'ARROW_RIGHT': 'open',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'close',
+        'ESCAPE': 'closeAll'
       });
     }
-
     /**
-     * Initializes the accordion by animating the preset active pane(s).
+     * Initializes the accordion menu by hiding all nested menus.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      var _this3 = this;
-
-      this.$element.attr('role', 'tablist');
-      this.$tabs = this.$element.children('[data-accordion-item]');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__["Nest"].Feather(this.$element, 'accordion');
 
-      this.$tabs.each(function (idx, el) {
-        var $el = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el),
-            $content = $el.children('[data-tab-content]'),
-            id = $content[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["b" /* GetYoDigits */])(6, 'accordion'),
-            linkId = el.id || id + '-label';
+      var _this = this;
 
-        $el.find('a:first').attr({
-          'aria-controls': id,
-          'role': 'tab',
-          'id': linkId,
-          'aria-expanded': false,
-          'aria-selected': false
-        });
+      this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');
 
-        $content.attr({ 'role': 'tabpanel', 'aria-labelledby': linkId, 'aria-hidden': true, 'id': id });
+      this.$element.attr({
+        'role': 'tree',
+        'aria-multiselectable': this.options.multiOpen
       });
-      var $initActive = this.$element.find('.is-active').children('[data-tab-content]');
-      this.firstTimeInit = true;
-      if ($initActive.length) {
-        this.down($initActive, this.firstTimeInit);
-        this.firstTimeInit = false;
-      }
-
-      this._checkDeepLink = function () {
-        var anchor = window.location.hash;
-        //need a hash and a relevant anchor in this tabset
-        if (anchor.length) {
-          var $link = _this3.$element.find('[href$="' + anchor + '"]'),
-              $anchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(anchor);
-
-          if ($link.length && $anchor) {
-            if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {
-              _this3.down($anchor, _this3.firstTimeInit);
-              _this3.firstTimeInit = false;
-            };
-
-            //roll up a little to show the titles
-            if (_this3.options.deepLinkSmudge) {
-              var _this = _this3;
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).load(function () {
-                var offset = _this.$element.offset();
-                __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').animate({ scrollTop: offset.top }, _this.options.deepLinkSmudgeDelay);
-              });
-            }
+      this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');
+      this.$menuLinks.each(function () {
+        var linkId = this.id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'acc-menu-link'),
+            $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            $sub = $elem.children('[data-submenu]'),
+            subId = $sub[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'acc-menu'),
+            isActive = $sub.hasClass('is-active');
 
-            /**
-              * Fires when the zplugin has deeplinked at pageload
-              * @event Accordion#deeplink
-              */
-            _this3.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);
-          }
+        if (_this.options.parentLink) {
+          var $anchor = $elem.children('a');
+          $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-accordion-submenu-item"></li>');
         }
-      };
 
-      //use browser to open a tab, if it exists in this tabset
-      if (this.options.deepLink) {
-        this._checkDeepLink();
+        if (_this.options.submenuToggle) {
+          $elem.addClass('has-submenu-toggle');
+          $elem.children('a').after('<button id="' + linkId + '" class="submenu-toggle" aria-controls="' + subId + '" aria-expanded="' + isActive + '" title="' + _this.options.submenuToggleText + '"><span class="submenu-toggle-text">' + _this.options.submenuToggleText + '</span></button>');
+        } else {
+          $elem.attr({
+            'aria-controls': subId,
+            'aria-expanded': isActive,
+            'id': linkId
+          });
+        }
+
+        $sub.attr({
+          'aria-labelledby': linkId,
+          'aria-hidden': !isActive,
+          'role': 'group',
+          'id': subId
+        });
+      });
+      this.$element.find('li').attr({
+        'role': 'treeitem'
+      });
+      var initPanes = this.$element.find('.is-active');
+
+      if (initPanes.length) {
+        var _this = this;
+
+        initPanes.each(function () {
+          _this.down(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
+        });
       }
 
       this._events();
     }
-
     /**
-     * Adds event handlers for items within the accordion.
+     * Adds event handlers for items within the menu.
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this;
 
-      this.$tabs.each(function () {
-        var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
-        var $tabContent = $elem.children('[data-tab-content]');
-        if ($tabContent.length) {
-          $elem.children('a').off('click.zf.accordion keydown.zf.accordion').on('click.zf.accordion', function (e) {
-            e.preventDefault();
-            _this.toggle($tabContent);
-          }).on('keydown.zf.accordion', function (e) {
-            __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'Accordion', {
-              toggle: function () {
-                _this.toggle($tabContent);
-              },
-              next: function () {
-                var $a = $elem.next().find('a').focus();
-                if (!_this.options.multiExpand) {
-                  $a.trigger('click.zf.accordion');
-                }
-              },
-              previous: function () {
-                var $a = $elem.prev().find('a').focus();
-                if (!_this.options.multiExpand) {
-                  $a.trigger('click.zf.accordion');
-                }
-              },
-              handled: function () {
-                e.preventDefault();
-                e.stopPropagation();
-              }
+      this.$element.find('li').each(function () {
+        var $submenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]');
+
+        if ($submenu.length) {
+          if (_this.options.submenuToggle) {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
+              _this.toggle($submenu);
             });
-          });
+          } else {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
+              e.preventDefault();
+
+              _this.toggle($submenu);
+            });
+          }
         }
-      });
-      if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('popstate', this._checkDeepLink);
-      }
+      }).on('keydown.zf.accordionmenu', function (e) {
+        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            $elements = $element.parent('ul').children('li'),
+            $prevElement,
+            $nextElement,
+            $target = $element.children('[data-submenu]');
+        $elements.each(function (i) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {
+            $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first();
+            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first();
+
+            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]:visible').length) {
+              // has open sub menu
+              $nextElement = $element.find('li:first-child').find('a').first();
+            }
+
+            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':first-child')) {
+              // is first element of sub menu
+              $prevElement = $element.parents('li').first().find('a').first();
+            } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) {
+              // if previous element has open sub menu
+              $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();
+            }
+
+            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':last-child')) {
+              // is last element of sub menu
+              $nextElement = $element.parents('li').first().next('li').find('a').first();
+            }
+
+            return;
+          }
+        });
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'AccordionMenu', {
+          open: function open() {
+            if ($target.is(':hidden')) {
+              _this.down($target);
+
+              $target.find('li').first().find('a').first().focus();
+            }
+          },
+          close: function close() {
+            if ($target.length && !$target.is(':hidden')) {
+              // close active sub of this item
+              _this.up($target);
+            } else if ($element.parent('[data-submenu]').length) {
+              // close currently open sub
+              _this.up($element.parent('[data-submenu]'));
+
+              $element.parents('li').first().find('a').first().focus();
+            }
+          },
+          up: function up() {
+            $prevElement.focus();
+            return true;
+          },
+          down: function down() {
+            $nextElement.focus();
+            return true;
+          },
+          toggle: function toggle() {
+            if (_this.options.submenuToggle) {
+              return false;
+            }
+
+            if ($element.children('[data-submenu]').length) {
+              _this.toggle($element.children('[data-submenu]'));
+
+              return true;
+            }
+          },
+          closeAll: function closeAll() {
+            _this.hideAll();
+          },
+          handled: function handled(preventDefault) {
+            if (preventDefault) {
+              e.preventDefault();
+            }
+
+            e.stopImmediatePropagation();
+          }
+        });
+      }); //.attr('tabindex', 0);
     }
+    /**
+     * Closes all panes of the menu.
+     * @function
+     */
 
+  }, {
+    key: "hideAll",
+    value: function hideAll() {
+      this.up(this.$element.find('[data-submenu]'));
+    }
     /**
-     * Toggles the selected content pane's open/close state.
-     * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).
+     * Opens all panes of the menu.
      * @function
      */
 
   }, {
-    key: 'toggle',
-    value: function toggle($target) {
-      if ($target.closest('[data-accordion]').is('[disabled]')) {
-        console.info('Cannot toggle an accordion that is disabled.');
-        return;
-      }
-      if ($target.parent().hasClass('is-active')) {
-        this.up($target);
-      } else {
-        this.down($target);
-      }
-      //either replace or update browser history
-      if (this.options.deepLink) {
-        var anchor = $target.prev('a').attr('href');
+    key: "showAll",
+    value: function showAll() {
+      this.down(this.$element.find('[data-submenu]'));
+    }
+    /**
+     * Toggles the open/close state of a submenu.
+     * @function
+     * @param {jQuery} $target - the submenu to toggle
+     */
 
-        if (this.options.updateHistory) {
-          history.pushState({}, '', anchor);
+  }, {
+    key: "toggle",
+    value: function toggle($target) {
+      if (!$target.is(':animated')) {
+        if (!$target.is(':hidden')) {
+          this.up($target);
         } else {
-          history.replaceState({}, '', anchor);
+          this.down($target);
         }
       }
     }
-
     /**
-     * Opens the accordion tab defined by `$target`.
-     * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).
-     * @param {Boolean} firstTime - flag to determine if reflow should happen.
-     * @fires Accordion#down
-     * @function
+     * Opens the sub-menu defined by `$target`.
+     * @param {jQuery} $target - Sub-menu to open.
+     * @fires AccordionMenu#down
      */
 
   }, {
-    key: 'down',
-    value: function down($target, firstTime) {
-      var _this4 = this;
+    key: "down",
+    value: function down($target) {
+      var _this2 = this;
 
-      /**
-       * checking firstTime allows for initial render of the accordion
-       * to render preset is-active panes.
-       */
-      if ($target.closest('[data-accordion]').is('[disabled]') && !firstTime) {
-        console.info('Cannot call down on an accordion that is disabled.');
-        return;
+      // If having multiple submenus active is disabled, close all the submenus
+      // that are not parents or children of the targeted submenu.
+      if (!this.options.multiOpen) {
+        // The "branch" of the targetted submenu, from the component root to
+        // the active submenus nested in it.
+        var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); // All the active submenus that are not in the branch.
+
+        var $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);
+        this.up($othersActiveSubmenus);
       }
-      $target.attr('aria-hidden', false).parent('[data-tab-content]').addBack().parent().addClass('is-active');
 
-      if (!this.options.multiExpand && !firstTime) {
-        var $currentActive = this.$element.children('.is-active').children('[data-tab-content]');
-        if ($currentActive.length) {
-          this.up($currentActive.not($target));
-        }
+      $target.addClass('is-active').attr({
+        'aria-hidden': false
+      });
+
+      if (this.options.submenuToggle) {
+        $target.prev('.submenu-toggle').attr({
+          'aria-expanded': true
+        });
+      } else {
+        $target.parent('.is-accordion-submenu-parent').attr({
+          'aria-expanded': true
+        });
       }
 
       $target.slideDown(this.options.slideSpeed, function () {
         /**
-         * Fires when the tab is done opening.
-         * @event Accordion#down
+         * Fires when the menu is done opening.
+         * @event AccordionMenu#down
          */
-        _this4.$element.trigger('down.zf.accordion', [$target]);
-      });
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + $target.attr('aria-labelledby')).attr({
-        'aria-expanded': true,
-        'aria-selected': true
+        _this2.$element.trigger('down.zf.accordionMenu', [$target]);
       });
     }
-
     /**
-     * Closes the tab defined by `$target`.
-     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
-     * @fires Accordion#up
-     * @function
+     * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.
+     * @param {jQuery} $target - Sub-menu to close.
+     * @fires AccordionMenu#up
      */
 
   }, {
-    key: 'up',
+    key: "up",
     value: function up($target) {
-      if ($target.closest('[data-accordion]').is('[disabled]')) {
-        console.info('Cannot call up on an accordion that is disabled.');
-        return;
-      }
+      var _this3 = this;
 
-      var $aunts = $target.parent().siblings(),
-          _this = this;
+      var $submenus = $target.find('[data-submenu]');
+      var $allmenus = $target.add($submenus);
+      $submenus.slideUp(0);
+      $allmenus.removeClass('is-active').attr('aria-hidden', true);
 
-      if (!this.options.allowAllClosed && !$aunts.hasClass('is-active') || !$target.parent().hasClass('is-active')) {
-        return;
+      if (this.options.submenuToggle) {
+        $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);
+      } else {
+        $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);
       }
 
-      $target.slideUp(_this.options.slideSpeed, function () {
+      $target.slideUp(this.options.slideSpeed, function () {
         /**
-         * Fires when the tab is done collapsing up.
-         * @event Accordion#up
+         * Fires when the menu is done collapsing up.
+         * @event AccordionMenu#up
          */
-        _this.$element.trigger('up.zf.accordion', [$target]);
-      });
-
-      $target.attr('aria-hidden', true).parent().removeClass('is-active');
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + $target.attr('aria-labelledby')).attr({
-        'aria-expanded': false,
-        'aria-selected': false
+        _this3.$element.trigger('up.zf.accordionMenu', [$target]);
       });
     }
-
     /**
-     * Destroys an instance of an accordion.
-     * @fires Accordion#destroyed
-     * @function
+     * Destroys an instance of accordion menu.
+     * @fires AccordionMenu#destroyed
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
-      this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');
-      this.$element.find('a').off('.zf.accordion');
-      if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('popstate', this._checkDeepLink);
+      this.$element.find('[data-submenu]').slideDown(0).css('display', '');
+      this.$element.find('a').off('click.zf.accordionMenu');
+      this.$element.find('[data-is-parent-link]').detach();
+
+      if (this.options.submenuToggle) {
+        this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');
+        this.$element.find('.submenu-toggle').remove();
       }
+
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__["Nest"].Burn(this.$element, 'accordion');
     }
   }]);
 
-  return Accordion;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["a" /* Plugin */]);
+  return AccordionMenu;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__["Plugin"]);
 
-Accordion.defaults = {
-  /**
-   * Amount of time to animate the opening of an accordion pane.
-   * @option
-   * @type {number}
-   * @default 250
-   */
-  slideSpeed: 250,
-  /**
-   * Allow the accordion to have multiple open panes.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  multiExpand: false,
+AccordionMenu.defaults = {
   /**
-   * Allow the accordion to close all panes.
+   * Adds the parent link to the submenu.
    * @option
    * @type {boolean}
    * @default false
    */
-  allowAllClosed: false,
+  parentLink: false,
+
   /**
-   * Allows the window to scroll to content of pane specified by hash anchor
+   * Amount of time to animate the opening of a submenu in ms.
    * @option
-   * @type {boolean}
-   * @default false
+   * @type {number}
+   * @default 250
    */
-  deepLink: false,
+  slideSpeed: 250,
 
   /**
-   * Adjust the deep link scroll to make sure the top of the accordion panel is visible
+   * Adds a separate submenu toggle button. This allows the parent item to have a link.
    * @option
-   * @type {boolean}
-   * @default false
+   * @example true
    */
-  deepLinkSmudge: false,
+  submenuToggle: false,
 
   /**
-   * Animation time (ms) for the deep link adjustment
+   * The text used for the submenu toggle if enabled. This is used for screen readers only.
    * @option
-   * @type {number}
-   * @default 300
+   * @example true
    */
-  deepLinkSmudgeDelay: 300,
+  submenuToggleText: 'Toggle menu',
 
   /**
-   * Update the browser history with the open accordion
+   * Allow the menu to have multiple open panes.
    * @option
    * @type {boolean}
-   * @default false
+   * @default true
    */
-  updateHistory: false
+  multiOpen: true
 };
 
 
-
 /***/ }),
-/* 12 */
+
+/***/ "./js/foundation.core.js":
+/*!*******************************!*\
+  !*** ./js/foundation.core.js ***!
+  \*******************************/
+/*! exports provided: Foundation */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return AccordionMenu; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__ = __webpack_require__(9);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return Foundation; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
 
-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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
-
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-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; }
 
 
 
+var FOUNDATION_VERSION = '6.5.3'; // Global Foundation object
+// This is attached to the window, or used as a module for AMD/Browserify
 
+var Foundation = {
+  version: FOUNDATION_VERSION,
 
+  /**
+   * Stores initialized plugins.
+   */
+  _plugins: {},
 
+  /**
+   * Stores generated unique ids for plugin instances
+   */
+  _uuids: [],
 
-/**
- * AccordionMenu module.
- * @module foundation.accordionMenu
- * @requires foundation.util.keyboard
- * @requires foundation.util.nest
- */
+  /**
+   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.
+   * @param {Object} plugin - The constructor of the plugin.
+   */
+  plugin: function plugin(_plugin, name) {
+    // Object key to use when adding to global Foundation object
+    // Examples: Foundation.Reveal, Foundation.OffCanvas
+    var className = name || functionName(_plugin); // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin
+    // Examples: data-reveal, data-off-canvas
 
-var AccordionMenu = function (_Plugin) {
-  _inherits(AccordionMenu, _Plugin);
+    var attrName = hyphenate(className); // Add to the Foundation object and the plugins list (for reflowing)
 
-  function AccordionMenu() {
-    _classCallCheck(this, AccordionMenu);
+    this._plugins[attrName] = this[className] = _plugin;
+  },
 
-    return _possibleConstructorReturn(this, (AccordionMenu.__proto__ || Object.getPrototypeOf(AccordionMenu)).apply(this, arguments));
-  }
+  /**
+   * @function
+   * Populates the _uuids array with pointers to each individual plugin instance.
+   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.
+   * Also fires the initialization event for each plugin, consolidating repetitive code.
+   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
+   * @param {String} name - the name of the plugin, passed as a camelCased string.
+   * @fires Plugin#init
+   */
+  registerPlugin: function registerPlugin(plugin, name) {
+    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();
+    plugin.uuid = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, pluginName);
 
-  _createClass(AccordionMenu, [{
-    key: '_setup',
+    if (!plugin.$element.attr("data-".concat(pluginName))) {
+      plugin.$element.attr("data-".concat(pluginName), plugin.uuid);
+    }
 
+    if (!plugin.$element.data('zfPlugin')) {
+      plugin.$element.data('zfPlugin', plugin);
+    }
     /**
-     * Creates a new instance of an accordion menu.
-     * @class
-     * @name AccordionMenu
-     * @fires AccordionMenu#init
-     * @param {jQuery} element - jQuery object to make into an accordion menu.
-     * @param {Object} options - Overrides to the default plugin settings.
+     * Fires when the plugin has initialized.
+     * @event Plugin#init
      */
-    value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, AccordionMenu.defaults, this.$element.data(), options);
-      this.className = 'AccordionMenu'; // ie9 back compat
 
-      this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('AccordionMenu', {
-        'ENTER': 'toggle',
-        'SPACE': 'toggle',
-        'ARROW_RIGHT': 'open',
-        'ARROW_UP': 'up',
-        'ARROW_DOWN': 'down',
-        'ARROW_LEFT': 'close',
-        'ESCAPE': 'closeAll'
-      });
-    }
+    plugin.$element.trigger("init.zf.".concat(pluginName));
+
+    this._uuids.push(plugin.uuid);
+
+    return;
+  },
+
+  /**
+   * @function
+   * Removes the plugins uuid from the _uuids array.
+   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.
+   * Also fires the destroyed event for the plugin, consolidating repetitive code.
+   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
+   * @fires Plugin#destroyed
+   */
+  unregisterPlugin: function unregisterPlugin(plugin) {
+    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));
+
+    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);
 
+    plugin.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin')
     /**
-     * Initializes the accordion menu by hiding all nested menus.
-     * @private
+     * Fires when the plugin has been destroyed.
+     * @event Plugin#destroyed
      */
+    .trigger("destroyed.zf.".concat(pluginName));
 
-  }, {
-    key: '_init',
-    value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["a" /* Nest */].Feather(this.$element, 'accordion');
-
-      var _this = this;
+    for (var prop in plugin) {
+      plugin[prop] = null; //clean up script to prep for garbage collection.
+    }
 
-      this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');
-      this.$element.attr({
-        'role': 'tree',
-        'aria-multiselectable': this.options.multiOpen
-      });
+    return;
+  },
 
-      this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');
-      this.$menuLinks.each(function () {
-        var linkId = this.id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["b" /* GetYoDigits */])(6, 'acc-menu-link'),
-            $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            $sub = $elem.children('[data-submenu]'),
-            subId = $sub[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["b" /* GetYoDigits */])(6, 'acc-menu'),
-            isActive = $sub.hasClass('is-active');
+  /**
+   * @function
+   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.
+   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`
+   * @default If no argument is passed, reflow all currently active plugins.
+   */
+  reInit: function reInit(plugins) {
+    var isJQ = plugins instanceof jquery__WEBPACK_IMPORTED_MODULE_0___default.a;
 
-        if (_this.options.submenuToggle) {
-          $elem.addClass('has-submenu-toggle');
-          $elem.children('a').after('<button id="' + linkId + '" class="submenu-toggle" aria-controls="' + subId + '" aria-expanded="' + isActive + '" title="' + _this.options.submenuToggleText + '"><span class="submenu-toggle-text">' + _this.options.submenuToggleText + '</span></button>');
-        } else {
-          $elem.attr({
-            'aria-controls': subId,
-            'aria-expanded': isActive,
-            'id': linkId
-          });
-        }
-        $sub.attr({
-          'aria-labelledby': linkId,
-          'aria-hidden': !isActive,
-          'role': 'group',
-          'id': subId
-        });
-      });
-      this.$element.find('li').attr({
-        'role': 'treeitem'
-      });
-      var initPanes = this.$element.find('.is-active');
-      if (initPanes.length) {
-        var _this = this;
-        initPanes.each(function () {
-          _this.down(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
+    try {
+      if (isJQ) {
+        plugins.each(function () {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('zfPlugin')._init();
         });
+      } else {
+        var type = _typeof(plugins),
+            _this = this,
+            fns = {
+          'object': function object(plgs) {
+            plgs.forEach(function (p) {
+              p = hyphenate(p);
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + p + ']').foundation('_init');
+            });
+          },
+          'string': function string() {
+            plugins = hyphenate(plugins);
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + plugins + ']').foundation('_init');
+          },
+          'undefined': function undefined() {
+            this['object'](Object.keys(_this._plugins));
+          }
+        };
+
+        fns[type](plugins);
       }
-      this._events();
+    } catch (err) {
+      console.error(err);
+    } finally {
+      return plugins;
     }
+  },
 
-    /**
-     * Adds event handlers for items within the menu.
-     * @private
-     */
+  /**
+   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.
+   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.
+   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.
+   */
+  reflow: function reflow(elem, plugins) {
+    // If plugins is undefined, just grab everything
+    if (typeof plugins === 'undefined') {
+      plugins = Object.keys(this._plugins);
+    } // If plugins is a string, convert it to an array with one item
+    else if (typeof plugins === 'string') {
+        plugins = [plugins];
+      }
 
-  }, {
-    key: '_events',
-    value: function _events() {
-      var _this = this;
+    var _this = this; // Iterate through each plugin
 
-      this.$element.find('li').each(function () {
-        var $submenu = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('[data-submenu]');
 
-        if ($submenu.length) {
-          if (_this.options.submenuToggle) {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
-              _this.toggle($submenu);
-            });
-          } else {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
-              e.preventDefault();
-              _this.toggle($submenu);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(plugins, function (i, name) {
+      // Get the current plugin
+      var plugin = _this._plugins[name]; // Localize the search to all elements inside elem, as well as elem itself, unless elem === document
+
+      var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem).find('[data-' + name + ']').addBack('[data-' + name + ']'); // For each plugin found, initialize it
+
+      $elem.each(function () {
+        var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            opts = {}; // Don't double-dip on plugins
+
+        if ($el.data('zfPlugin')) {
+          console.warn("Tried to initialize " + name + " on an element that already has a Foundation plugin.");
+          return;
+        }
+
+        if ($el.attr('data-options')) {
+          var thing = $el.attr('data-options').split(';').forEach(function (e, i) {
+            var opt = e.split(':').map(function (el) {
+              return el.trim();
             });
-          }
+            if (opt[0]) opts[opt[0]] = parseValue(opt[1]);
+          });
         }
-      }).on('keydown.zf.accordionmenu', function (e) {
-        var $element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            $elements = $element.parent('ul').children('li'),
-            $prevElement,
-            $nextElement,
-            $target = $element.children('[data-submenu]');
 
-        $elements.each(function (i) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is($element)) {
-            $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first();
-            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first();
-
-            if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('[data-submenu]:visible').length) {
-              // has open sub menu
-              $nextElement = $element.find('li:first-child').find('a').first();
-            }
-            if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is(':first-child')) {
-              // is first element of sub menu
-              $prevElement = $element.parents('li').first().find('a').first();
-            } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) {
-              // if previous element has open sub menu
-              $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();
-            }
-            if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is(':last-child')) {
-              // is last element of sub menu
-              $nextElement = $element.parents('li').first().next('li').find('a').first();
-            }
-
-            return;
-          }
-        });
-
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'AccordionMenu', {
-          open: function () {
-            if ($target.is(':hidden')) {
-              _this.down($target);
-              $target.find('li').first().find('a').first().focus();
-            }
-          },
-          close: function () {
-            if ($target.length && !$target.is(':hidden')) {
-              // close active sub of this item
-              _this.up($target);
-            } else if ($element.parent('[data-submenu]').length) {
-              // close currently open sub
-              _this.up($element.parent('[data-submenu]'));
-              $element.parents('li').first().find('a').first().focus();
-            }
-          },
-          up: function () {
-            $prevElement.focus();
-            return true;
-          },
-          down: function () {
-            $nextElement.focus();
-            return true;
-          },
-          toggle: function () {
-            if (_this.options.submenuToggle) {
-              return false;
-            }
-            if ($element.children('[data-submenu]').length) {
-              _this.toggle($element.children('[data-submenu]'));
-              return true;
-            }
-          },
-          closeAll: function () {
-            _this.hideAll();
-          },
-          handled: function (preventDefault) {
-            if (preventDefault) {
-              e.preventDefault();
-            }
-            e.stopImmediatePropagation();
-          }
-        });
-      }); //.attr('tabindex', 0);
-    }
+        try {
+          $el.data('zfPlugin', new plugin(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), opts));
+        } catch (er) {
+          console.error(er);
+        } finally {
+          return;
+        }
+      });
+    });
+  },
+  getFnName: functionName,
+  addToJquery: function addToJquery($) {
+    // TODO: consider not making this a jQuery function
+    // TODO: need way to reflow vs. re-initialize
 
     /**
-     * Closes all panes of the menu.
-     * @function
+     * The Foundation jQuery method.
+     * @param {String|Array} method - An action to perform on the current jQuery object.
      */
+    var foundation = function foundation(method) {
+      var type = _typeof(method),
+          $noJS = $('.no-js');
 
-  }, {
-    key: 'hideAll',
-    value: function hideAll() {
-      this.up(this.$element.find('[data-submenu]'));
-    }
+      if ($noJS.length) {
+        $noJS.removeClass('no-js');
+      }
 
-    /**
-     * Opens all panes of the menu.
-     * @function
-     */
+      if (type === 'undefined') {
+        //needs to initialize the Foundation object, or an individual plugin.
+        _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"]._init();
 
-  }, {
-    key: 'showAll',
-    value: function showAll() {
-      this.down(this.$element.find('[data-submenu]'));
-    }
+        Foundation.reflow(this);
+      } else if (type === 'string') {
+        //an individual method to invoke on a plugin or group of plugins
+        var args = Array.prototype.slice.call(arguments, 1); //collect all the arguments, if necessary
 
-    /**
-     * Toggles the open/close state of a submenu.
-     * @function
-     * @param {jQuery} $target - the submenu to toggle
-     */
+        var plugClass = this.data('zfPlugin'); //determine the class of plugin
 
-  }, {
-    key: 'toggle',
-    value: function toggle($target) {
-      if (!$target.is(':animated')) {
-        if (!$target.is(':hidden')) {
-          this.up($target);
+        if (typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined') {
+          //make sure both the class and method exist
+          if (this.length === 1) {
+            //if there's only one, call it directly.
+            plugClass[method].apply(plugClass, args);
+          } else {
+            this.each(function (i, el) {
+              //otherwise loop through the jQuery collection and invoke the method on each
+              plugClass[method].apply($(el).data('zfPlugin'), args);
+            });
+          }
         } else {
-          this.down($target);
+          //error for no class or no method
+          throw new ReferenceError("We're sorry, '" + method + "' is not an available method for " + (plugClass ? functionName(plugClass) : 'this element') + '.');
         }
+      } else {
+        //error for invalid argument type
+        throw new TypeError("We're sorry, ".concat(type, " is not a valid parameter. You must use a string representing the method you wish to invoke."));
       }
-    }
 
-    /**
-     * Opens the sub-menu defined by `$target`.
-     * @param {jQuery} $target - Sub-menu to open.
-     * @fires AccordionMenu#down
-     */
+      return this;
+    };
 
-  }, {
-    key: 'down',
-    value: function down($target) {
-      var _this = this;
+    $.fn.foundation = foundation;
+    return $;
+  }
+};
+Foundation.util = {
+  /**
+   * Function for applying a debounce effect to a function call.
+   * @function
+   * @param {Function} func - Function to be called at end of timeout.
+   * @param {Number} delay - Time in ms to delay the call of `func`.
+   * @returns function
+   */
+  throttle: function throttle(func, delay) {
+    var timer = null;
+    return function () {
+      var context = this,
+          args = arguments;
 
-      if (!this.options.multiOpen) {
-        this.up(this.$element.find('.is-active').not($target.parentsUntil(this.$element).add($target)));
+      if (timer === null) {
+        timer = setTimeout(function () {
+          func.apply(context, args);
+          timer = null;
+        }, delay);
       }
+    };
+  }
+};
+window.Foundation = Foundation; // Polyfill for requestAnimationFrame
 
-      $target.addClass('is-active').attr({ 'aria-hidden': false });
+(function () {
+  if (!Date.now || !window.Date.now) window.Date.now = Date.now = function () {
+    return new Date().getTime();
+  };
+  var vendors = ['webkit', 'moz'];
 
-      if (this.options.submenuToggle) {
-        $target.prev('.submenu-toggle').attr({ 'aria-expanded': true });
-      } else {
-        $target.parent('.is-accordion-submenu-parent').attr({ 'aria-expanded': true });
-      }
+  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {
+    var vp = vendors[i];
+    window.requestAnimationFrame = window[vp + 'RequestAnimationFrame'];
+    window.cancelAnimationFrame = window[vp + 'CancelAnimationFrame'] || window[vp + 'CancelRequestAnimationFrame'];
+  }
 
-      $target.slideDown(_this.options.slideSpeed, function () {
-        /**
-         * Fires when the menu is done opening.
-         * @event AccordionMenu#down
-         */
-        _this.$element.trigger('down.zf.accordionMenu', [$target]);
-      });
-    }
+  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) || !window.requestAnimationFrame || !window.cancelAnimationFrame) {
+    var lastTime = 0;
 
-    /**
-     * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.
-     * @param {jQuery} $target - Sub-menu to close.
-     * @fires AccordionMenu#up
-     */
+    window.requestAnimationFrame = function (callback) {
+      var now = Date.now();
+      var nextTime = Math.max(lastTime + 16, now);
+      return setTimeout(function () {
+        callback(lastTime = nextTime);
+      }, nextTime - now);
+    };
 
-  }, {
-    key: 'up',
-    value: function up($target) {
-      var _this = this;
-      $target.slideUp(_this.options.slideSpeed, function () {
-        /**
-         * Fires when the menu is done collapsing up.
-         * @event AccordionMenu#up
-         */
-        _this.$element.trigger('up.zf.accordionMenu', [$target]);
-      });
+    window.cancelAnimationFrame = clearTimeout;
+  }
+  /**
+   * Polyfill for performance.now, required by rAF
+   */
 
-      var $menus = $target.find('[data-submenu]').slideUp(0).addBack().attr('aria-hidden', true);
 
-      if (this.options.submenuToggle) {
-        $menus.prev('.submenu-toggle').attr('aria-expanded', false);
-      } else {
-        $menus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);
+  if (!window.performance || !window.performance.now) {
+    window.performance = {
+      start: Date.now(),
+      now: function now() {
+        return Date.now() - this.start;
       }
+    };
+  }
+})();
+
+if (!Function.prototype.bind) {
+  Function.prototype.bind = function (oThis) {
+    if (typeof this !== 'function') {
+      // closest thing possible to the ECMAScript 5
+      // internal IsCallable function
+      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');
     }
 
-    /**
-     * Destroys an instance of accordion menu.
-     * @fires AccordionMenu#destroyed
-     */
+    var aArgs = Array.prototype.slice.call(arguments, 1),
+        fToBind = this,
+        fNOP = function fNOP() {},
+        fBound = function fBound() {
+      return fToBind.apply(this instanceof fNOP ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments)));
+    };
 
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$element.find('[data-submenu]').slideDown(0).css('display', '');
-      this.$element.find('a').off('click.zf.accordionMenu');
+    if (this.prototype) {
+      // native functions don't have a prototype
+      fNOP.prototype = this.prototype;
+    }
 
-      if (this.options.submenuToggle) {
-        this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');
-        this.$element.find('.submenu-toggle').remove();
-      }
+    fBound.prototype = new fNOP();
+    return fBound;
+  };
+} // Polyfill to get the name of a function in IE9
 
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["a" /* Nest */].Burn(this.$element, 'accordion');
-    }
-  }]);
 
-  return AccordionMenu;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["a" /* Plugin */]);
+function functionName(fn) {
+  if (typeof Function.prototype.name === 'undefined') {
+    var funcNameRegex = /function\s([^(]{1,})\(/;
+    var results = funcNameRegex.exec(fn.toString());
+    return results && results.length > 1 ? results[1].trim() : "";
+  } else if (typeof fn.prototype === 'undefined') {
+    return fn.constructor.name;
+  } else {
+    return fn.prototype.constructor.name;
+  }
+}
 
-AccordionMenu.defaults = {
-  /**
-   * Amount of time to animate the opening of a submenu in ms.
-   * @option
-   * @type {number}
-   * @default 250
-   */
-  slideSpeed: 250,
-  /**
-   * Adds a separate submenu toggle button. This allows the parent item to have a link.
-   * @option
-   * @example true
-   */
-  submenuToggle: false,
-  /**
-   * The text used for the submenu toggle if enabled. This is used for screen readers only.
-   * @option
-   * @example true
-   */
-  submenuToggleText: 'Toggle menu',
-  /**
-   * Allow the menu to have multiple open panes.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  multiOpen: true
-};
+function parseValue(str) {
+  if ('true' === str) return true;else if ('false' === str) return false;else if (!isNaN(str * 1)) return parseFloat(str);
+  return str;
+} // Convert PascalCase to kebab-case
+// Thank you: http://stackoverflow.com/a/8955580
+
+
+function hyphenate(str) {
+  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
+}
+
+
+
+/***/ }),
+
+/***/ "./js/foundation.core.plugin.js":
+/*!**************************************!*\
+  !*** ./js/foundation.core.plugin.js ***!
+  \**************************************/
+/*! exports provided: Plugin */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Plugin", function() { return Plugin; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+
+ // Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST
+// {function} _setup (replaces previous constructor),
+// {function} _destroy (replaces previous destroy)
+
+var Plugin =
+/*#__PURE__*/
+function () {
+  function Plugin(element, options) {
+    _classCallCheck(this, Plugin);
+
+    this._setup(element, options);
+
+    var pluginName = getPluginName(this);
+    this.uuid = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, pluginName);
+
+    if (!this.$element.attr("data-".concat(pluginName))) {
+      this.$element.attr("data-".concat(pluginName), this.uuid);
+    }
+
+    if (!this.$element.data('zfPlugin')) {
+      this.$element.data('zfPlugin', this);
+    }
+    /**
+     * Fires when the plugin has initialized.
+     * @event Plugin#init
+     */
+
+
+    this.$element.trigger("init.zf.".concat(pluginName));
+  }
+
+  _createClass(Plugin, [{
+    key: "destroy",
+    value: function destroy() {
+      this._destroy();
+
+      var pluginName = getPluginName(this);
+      this.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin')
+      /**
+       * Fires when the plugin has been destroyed.
+       * @event Plugin#destroyed
+       */
+      .trigger("destroyed.zf.".concat(pluginName));
+
+      for (var prop in this) {
+        this[prop] = null; //clean up script to prep for garbage collection.
+      }
+    }
+  }]);
+
+  return Plugin;
+}(); // Convert PascalCase to kebab-case
+// Thank you: http://stackoverflow.com/a/8955580
+
+
+function hyphenate(str) {
+  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
+}
+
+function getPluginName(obj) {
+  if (typeof obj.constructor.name !== 'undefined') {
+    return hyphenate(obj.constructor.name);
+  } else {
+    return hyphenate(obj.className);
+  }
+}
+
+
+
+/***/ }),
+
+/***/ "./js/foundation.core.utils.js":
+/*!*************************************!*\
+  !*** ./js/foundation.core.utils.js ***!
+  \*************************************/
+/*! exports provided: rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "rtl", function() { return rtl; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GetYoDigits", function() { return GetYoDigits; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RegExpEscape", function() { return RegExpEscape; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "transitionend", function() { return transitionend; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onLoad", function() { return onLoad; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ignoreMousedisappear", function() { return ignoreMousedisappear; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+
+
+ // Core Foundation Utilities, utilized in a number of places.
+
+/**
+ * Returns a boolean for RTL support
+ */
+
+function rtl() {
+  return jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').attr('dir') === 'rtl';
+}
+/**
+ * returns a random base-36 uid with namespacing
+ * @function
+ * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.
+ * @param {String} namespace - name of plugin to be incorporated in uid, optional.
+ * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.
+ * @returns {String} - unique id
+ */
+
+
+function GetYoDigits(length, namespace) {
+  length = length || 6;
+  return Math.round(Math.pow(36, length + 1) - Math.random() * Math.pow(36, length)).toString(36).slice(1) + (namespace ? "-".concat(namespace) : '');
+}
+/**
+ * Escape a string so it can be used as a regexp pattern
+ * @function
+ * @see https://stackoverflow.com/a/9310752/4317384
+ *
+ * @param {String} str - string to escape.
+ * @returns {String} - escaped string
+ */
+
+
+function RegExpEscape(str) {
+  return str.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
+}
+
+function transitionend($elem) {
+  var transitions = {
+    'transition': 'transitionend',
+    'WebkitTransition': 'webkitTransitionEnd',
+    'MozTransition': 'transitionend',
+    'OTransition': 'otransitionend'
+  };
+  var elem = document.createElement('div'),
+      end;
+
+  for (var t in transitions) {
+    if (typeof elem.style[t] !== 'undefined') {
+      end = transitions[t];
+    }
+  }
+
+  if (end) {
+    return end;
+  } else {
+    end = setTimeout(function () {
+      $elem.triggerHandler('transitionend', [$elem]);
+    }, 1);
+    return 'transitionend';
+  }
+}
+/**
+ * Return an event type to listen for window load.
+ *
+ * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.
+ * If `handler` is passed, attach it to the event on `$elem`.
+ * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.
+ * @function
+ *
+ * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.
+ * @param {Function} [] handler - function to attach to the event.
+ * @returns {String} - event type that should or will be triggered.
+ */
+
+
+function onLoad($elem, handler) {
+  var didLoad = document.readyState === 'complete';
+  var eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';
+
+  var cb = function cb() {
+    return $elem.triggerHandler(eventType);
+  };
+
+  if ($elem) {
+    if (handler) $elem.one(eventType, handler);
+    if (didLoad) setTimeout(cb);else jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', cb);
+  }
+
+  return eventType;
+}
+/**
+ * Retuns an handler for the `mouseleave` that ignore disappeared mouses.
+ *
+ * If the mouse "disappeared" from the document (like when going on a browser UI element, See https://git.io/zf-11410),
+ * the event is ignored.
+ * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window
+ *   (like by switching to an other window with [Alt]+[Tab]).
+ * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document
+ *   outside of the element it left.
+ *
+ * @function
+ *
+ * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.
+ * @param {Object} [] options - object of options:
+ * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.
+ * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.
+ * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.
+ */
+
+
+function ignoreMousedisappear(handler) {
+  var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
+      _ref$ignoreLeaveWindo = _ref.ignoreLeaveWindow,
+      ignoreLeaveWindow = _ref$ignoreLeaveWindo === void 0 ? false : _ref$ignoreLeaveWindo,
+      _ref$ignoreReappear = _ref.ignoreReappear,
+      ignoreReappear = _ref$ignoreReappear === void 0 ? false : _ref$ignoreReappear;
+
+  return function leaveEventHandler(eLeave) {
+    for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
+      rest[_key - 1] = arguments[_key];
+    }
+
+    var callback = handler.bind.apply(handler, [this, eLeave].concat(rest)); // The mouse left: call the given callback if the mouse entered elsewhere
+
+    if (eLeave.relatedTarget !== null) {
+      return callback();
+    } // Otherwise, check if the mouse actually left the window.
+    // In firefox if the user switched between windows, the window sill have the focus by the time
+    // the event is triggered. We have to debounce the event to test this case.
+
+
+    setTimeout(function leaveEventDebouncer() {
+      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {
+        return callback();
+      } // Otherwise, wait for the mouse to reeapear outside of the element,
+
+
+      if (!ignoreReappear) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).one('mouseenter', function reenterEventHandler(eReenter) {
+          if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(eLeave.currentTarget).has(eReenter.target).length) {
+            // Fill where the mouse finally entered.
+            eLeave.relatedTarget = eReenter.target;
+            callback();
+          }
+        });
+      }
+    }, 0);
+  };
+}
 
 
 
 /***/ }),
-/* 13 */
+
+/***/ "./js/foundation.drilldown.js":
+/*!************************************!*\
+  !*** ./js/foundation.drilldown.js ***!
+  \************************************/
+/*! exports provided: Drilldown */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Drilldown; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__ = __webpack_require__(9);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_box__ = __webpack_require__(7);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_plugin__ = __webpack_require__(2);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Drilldown", function() { return Drilldown; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.nest */ "./js/foundation.util.nest.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.box */ "./js/foundation.util.box.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return 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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -2361,17 +2678,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.box
  */
 
-var Drilldown = function (_Plugin) {
+var Drilldown =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Drilldown, _Plugin);
 
   function Drilldown() {
     _classCallCheck(this, Drilldown);
 
-    return _possibleConstructorReturn(this, (Drilldown.__proto__ || Object.getPrototypeOf(Drilldown)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Drilldown).apply(this, arguments));
   }
 
   _createClass(Drilldown, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of a drilldown menu.
@@ -2382,12 +2701,12 @@ var Drilldown = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Drilldown.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Drilldown.defaults, this.$element.data(), options);
       this.className = 'Drilldown'; // ie9 back compat
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('Drilldown', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('Drilldown', {
         'ENTER': 'open',
         'SPACE': 'open',
         'ARROW_RIGHT': 'next',
@@ -2399,16 +2718,15 @@ var Drilldown = function (_Plugin) {
         'SHIFT_TAB': 'up'
       });
     }
-
     /**
      * Initializes the drilldown by creating jQuery collections of elements
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["a" /* Nest */].Feather(this.$element, 'drilldown');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__["Nest"].Feather(this.$element, 'drilldown');
 
       if (this.options.autoApplyClass) {
         this.$element.addClass('drilldown');
@@ -2420,15 +2738,18 @@ var Drilldown = function (_Plugin) {
       });
       this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');
       this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');
-      this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a');
-      this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["b" /* GetYoDigits */])(6, 'drilldown'));
+      this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a'); // Set the main menu as current by default (unless a submenu is selected)
+      // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu
+
+      this.$currentMenu = this.$element;
+      this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'drilldown'));
 
       this._prepareMenu();
+
       this._registerEvents();
 
       this._keyboardEvents();
     }
-
     /**
      * prepares drilldown menu by setting attributes to links and elements
      * sets a min height to prevent content jumping
@@ -2438,67 +2759,78 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_prepareMenu',
+    key: "_prepareMenu",
     value: function _prepareMenu() {
-      var _this = this;
-      // if(!this.options.holdOpen){
+      var _this = this; // if(!this.options.holdOpen){
       //   this._menuLinkEvents();
       // }
+
+
       this.$submenuAnchors.each(function () {
-        var $link = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+        var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
         var $sub = $link.parent();
+
         if (_this.options.parentLink) {
-          $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>');
+          $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>');
         }
+
         $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);
         $link.children('[data-submenu]').attr({
           'aria-hidden': true,
           'tabindex': 0,
           'role': 'group'
         });
+
         _this._events($link);
       });
       this.$submenus.each(function () {
-        var $menu = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var $menu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             $back = $menu.find('.js-drilldown-back');
+
         if (!$back.length) {
           switch (_this.options.backButtonPosition) {
             case "bottom":
               $menu.append(_this.options.backButton);
               break;
+
             case "top":
               $menu.prepend(_this.options.backButton);
               break;
+
             default:
               console.error("Unsupported backButtonPosition value '" + _this.options.backButtonPosition + "'");
           }
         }
+
         _this._back($menu);
       });
-
       this.$submenus.addClass('invisible');
+
       if (!this.options.autoHeight) {
         this.$submenus.addClass('drilldown-submenu-cover-previous');
-      }
+      } // create a wrapper on element if it doesn't exist.
+
 
-      // create a wrapper on element if it doesn't exist.
       if (!this.$element.parent().hasClass('is-drilldown')) {
-        this.$wrapper = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.options.wrapper).addClass('is-drilldown');
+        this.$wrapper = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.wrapper).addClass('is-drilldown');
         if (this.options.animateHeight) this.$wrapper.addClass('animate-height');
         this.$element.wrap(this.$wrapper);
-      }
-      // set wrapper
+      } // set wrapper
+
+
       this.$wrapper = this.$element.parent();
       this.$wrapper.css(this._getMaxDims());
     }
   }, {
-    key: '_resize',
+    key: "_resize",
     value: function _resize() {
-      this.$wrapper.css({ 'max-width': 'none', 'min-height': 'none' });
-      // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths
+      this.$wrapper.css({
+        'max-width': 'none',
+        'min-height': 'none'
+      }); // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths
+
       this.$wrapper.css(this._getMaxDims());
     }
-
     /**
      * Adds event handlers to elements in the menu.
      * @function
@@ -2507,35 +2839,37 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events($elem) {
       var _this = this;
 
       $elem.off('click.zf.drilldown').on('click.zf.drilldown', function (e) {
-        if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) {
+        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) {
           e.stopImmediatePropagation();
           e.preventDefault();
-        }
-
-        // if(e.target !== e.currentTarget.firstElementChild){
+        } // if(e.target !== e.currentTarget.firstElementChild){
         //   return false;
         // }
+
+
         _this._show($elem.parent('li'));
 
         if (_this.options.closeOnClick) {
-          var $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body');
+          var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');
           $body.off('.zf.drilldown').on('click.zf.drilldown', function (e) {
-            if (e.target === _this.$element[0] || __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(_this.$element[0], e.target)) {
+            if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target)) {
               return;
             }
+
             e.preventDefault();
+
             _this._hideAll();
+
             $body.off('.zf.drilldown');
           });
         }
       });
     }
-
     /**
      * Adds event handlers to the menu element.
      * @function
@@ -2543,15 +2877,15 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_registerEvents',
+    key: "_registerEvents",
     value: function _registerEvents() {
       if (this.options.scrollTop) {
         this._bindHandler = this._scrollTop.bind(this);
         this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown', this._bindHandler);
       }
+
       this.$element.on('mutateme.zf.trigger', this._resize.bind(this));
     }
-
     /**
      * Scroll to Top of Element or data-scroll-top-element
      * @function
@@ -2559,108 +2893,117 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_scrollTop',
+    key: "_scrollTop",
     value: function _scrollTop() {
       var _this = this;
-      var $scrollTopElement = _this.options.scrollTopElement != '' ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()(_this.options.scrollTopElement) : _this.$element,
+
+      var $scrollTopElement = _this.options.scrollTopElement != '' ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(_this.options.scrollTopElement) : _this.$element,
           scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10);
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing, function () {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({
+        scrollTop: scrollPos
+      }, _this.options.animationDuration, _this.options.animationEasing, function () {
         /**
           * Fires after the menu has scrolled
           * @event Drilldown#scrollme
           */
-        if (this === __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html')[0]) _this.$element.trigger('scrollme.zf.drilldown');
+        if (this === jquery__WEBPACK_IMPORTED_MODULE_0___default()('html')[0]) _this.$element.trigger('scrollme.zf.drilldown');
       });
     }
-
     /**
      * Adds keydown event listener to `li`'s in the menu.
      * @private
      */
 
   }, {
-    key: '_keyboardEvents',
+    key: "_keyboardEvents",
     value: function _keyboardEvents() {
       var _this = this;
 
       this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function (e) {
-        var $element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             $elements = $element.parent('li').parent('ul').children('li').children('a'),
             $prevElement,
             $nextElement;
-
         $elements.each(function (i) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is($element)) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {
             $prevElement = $elements.eq(Math.max(0, i - 1));
             $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
             return;
           }
         });
-
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'Drilldown', {
-          next: function () {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'Drilldown', {
+          next: function next() {
             if ($element.is(_this.$submenuAnchors)) {
               _this._show($element.parent('li'));
-              $element.parent('li').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["c" /* transitionend */])($element), function () {
-                $element.parent('li').find('ul li a').filter(_this.$menuItems).first().focus();
+
+              $element.parent('li').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($element), function () {
+                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
               });
               return true;
             }
           },
-          previous: function () {
+          previous: function previous() {
             _this._hide($element.parent('li').parent('ul'));
-            $element.parent('li').parent('ul').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["c" /* transitionend */])($element), function () {
+
+            $element.parent('li').parent('ul').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($element), function () {
               setTimeout(function () {
                 $element.parent('li').parent('ul').parent('li').children('a').first().focus();
               }, 1);
             });
             return true;
           },
-          up: function () {
-            $prevElement.focus();
-            // Don't tap focus on first element in root ul
+          up: function up() {
+            $prevElement.focus(); // Don't tap focus on first element in root ul
+
             return !$element.is(_this.$element.find('> li:first-child > a'));
           },
-          down: function () {
-            $nextElement.focus();
-            // Don't tap focus on last element in root ul
+          down: function down() {
+            $nextElement.focus(); // Don't tap focus on last element in root ul
+
             return !$element.is(_this.$element.find('> li:last-child > a'));
           },
-          close: function () {
+          close: function close() {
             // Don't close on element in root ul
             if (!$element.is(_this.$element.find('> li > a'))) {
               _this._hide($element.parent().parent());
+
               $element.parent().parent().siblings('a').focus();
             }
           },
-          open: function () {
-            if (!$element.is(_this.$menuItems)) {
+          open: function open() {
+            if (_this.options.parentLink && $element.attr('href')) {
+              // Link with href
+              return false;
+            } else if (!$element.is(_this.$menuItems)) {
               // not menu item means back button
               _this._hide($element.parent('li').parent('ul'));
-              $element.parent('li').parent('ul').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["c" /* transitionend */])($element), function () {
+
+              $element.parent('li').parent('ul').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($element), function () {
                 setTimeout(function () {
                   $element.parent('li').parent('ul').parent('li').children('a').first().focus();
                 }, 1);
               });
               return true;
             } else if ($element.is(_this.$submenuAnchors)) {
+              // Sub menu item
               _this._show($element.parent('li'));
-              $element.parent('li').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["c" /* transitionend */])($element), function () {
-                $element.parent('li').find('ul li a').filter(_this.$menuItems).first().focus();
+
+              $element.parent('li').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($element), function () {
+                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
               });
               return true;
             }
           },
-          handled: function (preventDefault) {
+          handled: function handled(preventDefault) {
             if (preventDefault) {
               e.preventDefault();
             }
+
             e.stopImmediatePropagation();
           }
         });
       }); // end keyboardAccess
     }
-
     /**
      * Closes all open elements, and returns to root menu.
      * @function
@@ -2668,20 +3011,22 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_hideAll',
+    key: "_hideAll",
     value: function _hideAll() {
       var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');
-      if (this.options.autoHeight) this.$wrapper.css({ height: $elem.parent().closest('ul').data('calcHeight') });
-      $elem.one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["c" /* transitionend */])($elem), function (e) {
+      if (this.options.autoHeight) this.$wrapper.css({
+        height: $elem.parent().closest('ul').data('calcHeight')
+      });
+      $elem.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($elem), function (e) {
         $elem.removeClass('is-active is-closing');
       });
       /**
        * Fires when the menu is fully closed.
        * @event Drilldown#closed
        */
+
       this.$element.trigger('closed.zf.drilldown');
     }
-
     /**
      * Adds event listener for each `back` button, and closes open menus.
      * @function
@@ -2690,23 +3035,24 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_back',
+    key: "_back",
     value: function _back($elem) {
       var _this = this;
+
       $elem.off('click.zf.drilldown');
       $elem.children('.js-drilldown-back').on('click.zf.drilldown', function (e) {
-        e.stopImmediatePropagation();
-        // console.log('mouseup on back');
-        _this._hide($elem);
+        e.stopImmediatePropagation(); // console.log('mouseup on back');
+
+        _this._hide($elem); // If there is a parent submenu, call show
+
 
-        // If there is a parent submenu, call show
         var parentSubMenu = $elem.parent('li').parent('ul').parent('li');
+
         if (parentSubMenu.length) {
           _this._show(parentSubMenu);
         }
       });
     }
-
     /**
      * Adds event listener to menu items w/o submenus to close open menus on click.
      * @function
@@ -2714,9 +3060,10 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_menuLinkEvents',
+    key: "_menuLinkEvents",
     value: function _menuLinkEvents() {
       var _this = this;
+
       this.$menuItems.not('.is-drilldown-submenu-parent').off('click.zf.drilldown').on('click.zf.drilldown', function (e) {
         // e.stopImmediatePropagation();
         setTimeout(function () {
@@ -2724,7 +3071,93 @@ var Drilldown = function (_Plugin) {
         }, 0);
       });
     }
+    /**
+     * Sets the CSS classes for submenu to show it.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the target submenu (`ul` tag)
+     * @param {boolean} trigger - trigger drilldown event
+     */
+
+  }, {
+    key: "_setShowSubMenuClasses",
+    value: function _setShowSubMenuClasses($elem, trigger) {
+      $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+      $elem.parent('li').attr('aria-expanded', true);
+
+      if (trigger === true) {
+        this.$element.trigger('open.zf.drilldown', [$elem]);
+      }
+    }
+    /**
+     * Sets the CSS classes for submenu to hide it.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the target submenu (`ul` tag)
+     * @param {boolean} trigger - trigger drilldown event
+     */
+
+  }, {
+    key: "_setHideSubMenuClasses",
+    value: function _setHideSubMenuClasses($elem, trigger) {
+      $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);
+      $elem.parent('li').attr('aria-expanded', false);
+
+      if (trigger === true) {
+        $elem.trigger('hide.zf.drilldown', [$elem]);
+      }
+    }
+    /**
+     * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.
+     * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.
+     * @function
+     * @fires Drilldown#open
+     * @param {jQuery} $elem - the target (sub)menu (`ul` tag)
+     * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused
+     */
+
+  }, {
+    key: "_showMenu",
+    value: function _showMenu($elem, autoFocus) {
+      var _this = this; // Reset drilldown
+
+
+      var $expandedSubmenus = this.$element.find('li[aria-expanded="true"] > ul[data-submenu]');
+      $expandedSubmenus.each(function (index) {
+        _this._setHideSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
+      }); // Save the menu as the currently displayed one.
+
+      this.$currentMenu = $elem; // If target menu is root, focus first link & exit
+
+      if ($elem.is('[data-drilldown]')) {
+        if (autoFocus === true) $elem.find('li[role="treeitem"] > a').first().focus();
+        if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));
+        return;
+      } // Find all submenus on way to root incl. the element itself
+
+
+      var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); // Open target menu and all submenus on its way to root
+
+      $submenus.each(function (index) {
+        // Update height of first child (target menu) if autoHeight option true
+        if (index === 0 && _this.options.autoHeight) {
+          _this.$wrapper.css('height', jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight'));
+        }
+
+        var isLastChild = index == $submenus.length - 1; // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link
+        // Last child makes sure the event gets always triggered even if going through several menus
+
+        if (isLastChild === true) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)), function () {
+            if (autoFocus === true) {
+              $elem.find('li[role="treeitem"] > a').first().focus();
+            }
+          });
+        }
 
+        _this._setShowSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), isLastChild);
+      });
+    }
     /**
      * Opens a submenu.
      * @function
@@ -2733,33 +3166,45 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_show',
+    key: "_show",
     value: function _show($elem) {
-      if (this.options.autoHeight) this.$wrapper.css({ height: $elem.children('[data-submenu]').data('calcHeight') });
+      var $submenu = $elem.children('[data-submenu]');
       $elem.attr('aria-expanded', true);
-      $elem.children('[data-submenu]').addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+      this.$currentMenu = $submenu;
+      $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+
+      if (this.options.autoHeight) {
+        this.$wrapper.css({
+          height: $submenu.data('calcHeight')
+        });
+      }
       /**
        * Fires when the submenu has opened.
        * @event Drilldown#open
        */
-      this.$element.trigger('open.zf.drilldown', [$elem]);
-    }
-  }, {
-    key: '_hide',
 
 
+      this.$element.trigger('open.zf.drilldown', [$elem]);
+    }
     /**
      * Hides a submenu
      * @function
      * @fires Drilldown#hide
      * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.
      */
+
+  }, {
+    key: "_hide",
     value: function _hide($elem) {
-      if (this.options.autoHeight) this.$wrapper.css({ height: $elem.parent().closest('ul').data('calcHeight') });
+      if (this.options.autoHeight) this.$wrapper.css({
+        height: $elem.parent().closest('ul').data('calcHeight')
+      });
+
       var _this = this;
+
       $elem.parent('li').attr('aria-expanded', false);
-      $elem.attr('aria-hidden', true).addClass('is-closing');
-      $elem.addClass('is-closing').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["c" /* transitionend */])($elem), function () {
+      $elem.attr('aria-hidden', true);
+      $elem.addClass('is-closing').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($elem), function () {
         $elem.removeClass('is-active is-closing');
         $elem.blur().addClass('invisible');
       });
@@ -2767,9 +3212,9 @@ var Drilldown = function (_Plugin) {
        * Fires when the submenu has closed.
        * @event Drilldown#hide
        */
+
       $elem.trigger('hide.zf.drilldown', [$elem]);
     }
-
     /**
      * Iterates through the nested menus to calculate the min-height, and max-width for the menu.
      * Prevents content jumping.
@@ -2778,50 +3223,50 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_getMaxDims',
+    key: "_getMaxDims",
     value: function _getMaxDims() {
       var maxHeight = 0,
           result = {},
-          _this = this;
+          _this = this; // Recalculate menu heights and total max height
+
+
       this.$submenus.add(this.$element).each(function () {
-        var numOfElems = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('li').length;
-        var height = __WEBPACK_IMPORTED_MODULE_4__foundation_util_box__["a" /* Box */].GetDimensions(this).height;
+        var numOfElems = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('li').length;
+        var height = _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__["Box"].GetDimensions(this).height;
         maxHeight = height > maxHeight ? height : maxHeight;
+
         if (_this.options.autoHeight) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('calcHeight', height);
-          if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).hasClass('is-drilldown-submenu')) result['height'] = height;
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight', height);
         }
       });
-
-      if (!this.options.autoHeight) result['min-height'] = maxHeight + 'px';
-
-      result['max-width'] = this.$element[0].getBoundingClientRect().width + 'px';
-
+      if (this.options.autoHeight) result['height'] = this.$currentMenu.data('calcHeight');else result['min-height'] = "".concat(maxHeight, "px");
+      result['max-width'] = "".concat(this.$element[0].getBoundingClientRect().width, "px");
       return result;
     }
-
     /**
      * Destroys the Drilldown Menu
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       if (this.options.scrollTop) this.$element.off('.zf.drilldown', this._bindHandler);
+
       this._hideAll();
+
       this.$element.off('mutateme.zf.trigger');
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["a" /* Nest */].Burn(this.$element, 'drilldown');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__["Nest"].Burn(this.$element, 'drilldown');
       this.$element.unwrap().find('.js-drilldown-back, .is-submenu-parent-item').remove().end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu').end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');
       this.$submenuAnchors.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).off('.zf.drilldown');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off('.zf.drilldown');
       });
-
+      this.$element.find('[data-is-parent-link]').detach();
       this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');
-
       this.$element.find('a').each(function () {
-        var $link = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+        var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
         $link.removeAttr('tabindex');
+
         if ($link.data('savedHref')) {
           $link.attr('href', $link.data('savedHref')).removeData('savedHref');
         } else {
@@ -2832,7 +3277,7 @@ var Drilldown = function (_Plugin) {
   }]);
 
   return Drilldown;
-}(__WEBPACK_IMPORTED_MODULE_5__foundation_plugin__["a" /* Plugin */]);
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__["Plugin"]);
 
 Drilldown.defaults = {
   /**
@@ -2843,6 +3288,7 @@ Drilldown.defaults = {
    * @default true
    */
   autoApplyClass: true,
+
   /**
    * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\`) if copy and pasting.
    * @option
@@ -2850,6 +3296,7 @@ Drilldown.defaults = {
    * @default '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>'
    */
   backButton: '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',
+
   /**
    * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.
    * @option
@@ -2857,6 +3304,7 @@ Drilldown.defaults = {
    * @default top
    */
   backButtonPosition: 'top',
+
   /**
    * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\`) if copy and pasting.
    * @option
@@ -2864,6 +3312,7 @@ Drilldown.defaults = {
    * @default '<div></div>'
    */
   wrapper: '<div></div>',
+
   /**
    * Adds the parent link to the submenu.
    * @option
@@ -2871,6 +3320,7 @@ Drilldown.defaults = {
    * @default false
    */
   parentLink: false,
+
   /**
    * Allow the menu to return to root list on body click.
    * @option
@@ -2878,6 +3328,7 @@ Drilldown.defaults = {
    * @default false
    */
   closeOnClick: false,
+
   /**
    * Allow the menu to auto adjust height.
    * @option
@@ -2885,6 +3336,7 @@ Drilldown.defaults = {
    * @default false
    */
   autoHeight: false,
+
   /**
    * Animate the auto adjust height.
    * @option
@@ -2892,6 +3344,7 @@ Drilldown.defaults = {
    * @default false
    */
   animateHeight: false,
+
   /**
    * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button
    * @option
@@ -2899,6 +3352,7 @@ Drilldown.defaults = {
    * @default false
    */
   scrollTop: false,
+
   /**
    * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken
    * @option
@@ -2906,6 +3360,7 @@ Drilldown.defaults = {
    * @default ''
    */
   scrollTopElement: '',
+
   /**
    * ScrollTop offset
    * @option
@@ -2913,6 +3368,7 @@ Drilldown.defaults = {
    * @default 0
    */
   scrollTopOffset: 0,
+
   /**
    * Scroll animation duration
    * @option
@@ -2920,6 +3376,7 @@ Drilldown.defaults = {
    * @default 500
    */
   animationDuration: 500,
+
   /**
    * Scroll animation easing. Can be `'swing'` or `'linear'`.
    * @option
@@ -2927,35 +3384,53 @@ Drilldown.defaults = {
    * @see {@link https://api.jquery.com/animate|JQuery animate}
    * @default 'swing'
    */
-  animationEasing: 'swing'
-  // holdOpen: false
-};
+  animationEasing: 'swing' // holdOpen: false
 
+};
 
 
 /***/ }),
-/* 14 */
+
+/***/ "./js/foundation.dropdown.js":
+/*!***********************************!*\
+  !*** ./js/foundation.dropdown.js ***!
+  \***********************************/
+/*! exports provided: Dropdown */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return DropdownMenu; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__ = __webpack_require__(9);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_box__ = __webpack_require__(7);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_plugin__ = __webpack_require__(2);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Dropdown", function() { return Dropdown; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_positionable__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.positionable */ "./js/foundation.positionable.js");
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.touch */ "./js/foundation.util.touch.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-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 _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); }
+
+function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -2964,294 +3439,231 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
 
 
 /**
- * DropdownMenu module.
- * @module foundation.dropdown-menu
+ * Dropdown module.
+ * @module foundation.dropdown
  * @requires foundation.util.keyboard
  * @requires foundation.util.box
- * @requires foundation.util.nest
+ * @requires foundation.util.triggers
  */
 
-var DropdownMenu = function (_Plugin) {
-  _inherits(DropdownMenu, _Plugin);
+var Dropdown =
+/*#__PURE__*/
+function (_Positionable) {
+  _inherits(Dropdown, _Positionable);
 
-  function DropdownMenu() {
-    _classCallCheck(this, DropdownMenu);
+  function Dropdown() {
+    _classCallCheck(this, Dropdown);
 
-    return _possibleConstructorReturn(this, (DropdownMenu.__proto__ || Object.getPrototypeOf(DropdownMenu)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Dropdown).apply(this, arguments));
   }
 
-  _createClass(DropdownMenu, [{
-    key: '_setup',
+  _createClass(Dropdown, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of DropdownMenu.
+     * Creates a new instance of a dropdown.
      * @class
-     * @name DropdownMenu
-     * @fires DropdownMenu#init
-     * @param {jQuery} element - jQuery object to make into a dropdown menu.
+     * @name Dropdown
+     * @param {jQuery} element - jQuery object to make into a dropdown.
+     *        Object should be of the dropdown panel, rather than its anchor.
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, DropdownMenu.defaults, this.$element.data(), options);
-      this.className = 'DropdownMenu'; // ie9 back compat
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Dropdown.defaults, this.$element.data(), options);
+      this.className = 'Dropdown'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
+
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('DropdownMenu', {
-        'ENTER': 'open',
-        'SPACE': 'open',
-        'ARROW_RIGHT': 'next',
-        'ARROW_UP': 'up',
-        'ARROW_DOWN': 'down',
-        'ARROW_LEFT': 'previous',
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('Dropdown', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
         'ESCAPE': 'close'
       });
     }
-
     /**
-     * Initializes the plugin, and calls _prepareMenu
-     * @private
+     * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.
      * @function
+     * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["a" /* Nest */].Feather(this.$element, 'dropdown');
-
-      var subs = this.$element.find('li.is-dropdown-submenu-parent');
-      this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');
+      var $id = this.$element.attr('id');
+      this.$anchors = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat($id, "\"]")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat($id, "\"]")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat($id, "\"]"));
+      this.$anchors.attr({
+        'aria-controls': $id,
+        'data-is-focus': false,
+        'data-yeti-box': $id,
+        'aria-haspopup': true,
+        'aria-expanded': false
+      });
 
-      this.$menuItems = this.$element.find('[role="menuitem"]');
-      this.$tabs = this.$element.children('[role="menuitem"]');
-      this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);
+      this._setCurrentAnchor(this.$anchors.first());
 
-      if (this.options.alignment === 'auto') {
-        if (this.$element.hasClass(this.options.rightClass) || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_4__foundation_util_core__["a" /* rtl */])() || this.$element.parents('.top-bar-right').is('*')) {
-          this.options.alignment = 'right';
-          subs.addClass('opens-left');
-        } else {
-          this.options.alignment = 'left';
-          subs.addClass('opens-right');
-        }
+      if (this.options.parentClass) {
+        this.$parent = this.$element.parents('.' + this.options.parentClass);
       } else {
-        if (this.options.alignment === 'right') {
-          subs.addClass('opens-left');
-        } else {
-          subs.addClass('opens-right');
+        this.$parent = null;
+      } // Set [aria-labelledby] on the Dropdown if it is not set
+
+
+      if (typeof this.$element.attr('aria-labelledby') === 'undefined') {
+        // Get the anchor ID or create one
+        if (typeof this.$currentAnchor.attr('id') === 'undefined') {
+          this.$currentAnchor.attr('id', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'dd-anchor'));
         }
+
+        ;
+        this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));
       }
-      this.changed = false;
+
+      this.$element.attr({
+        'aria-hidden': 'true',
+        'data-yeti-box': $id,
+        'data-resize': $id
+      });
+
+      _get(_getPrototypeOf(Dropdown.prototype), "_init", this).call(this);
+
       this._events();
     }
   }, {
-    key: '_isVertical',
-    value: function _isVertical() {
-      return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      // handle legacy classnames
+      var position = this.$element[0].className.match(/(top|left|right|bottom)/g);
+
+      if (position) {
+        return position[0];
+      } else {
+        return 'bottom';
+      }
     }
   }, {
-    key: '_isRtl',
-    value: function _isRtl() {
-      return this.$element.hasClass('align-right') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_4__foundation_util_core__["a" /* rtl */])() && !this.$element.hasClass('align-left');
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      // handle legacy float approach
+      var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.attr('class'));
+
+      if (horizontalPosition) {
+        return horizontalPosition[1];
+      }
+
+      return _get(_getPrototypeOf(Dropdown.prototype), "_getDefaultAlignment", this).call(this);
     }
+    /**
+     * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.
+     * Recursively calls itself if a collision is detected, with a new position class.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_setPosition",
+    value: function _setPosition() {
+      this.$element.removeClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment));
 
+      _get(_getPrototypeOf(Dropdown.prototype), "_setPosition", this).call(this, this.$currentAnchor, this.$element, this.$parent);
+
+      this.$element.addClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment));
+    }
     /**
-     * Adds event listeners to elements within the menu
+     * Make it a current anchor.
+     * Current anchor as the reference for the position of Dropdown panes.
+     * @param {HTML} el - DOM element of the anchor.
+     * @function
      * @private
+     */
+
+  }, {
+    key: "_setCurrentAnchor",
+    value: function _setCurrentAnchor(el) {
+      this.$currentAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el);
+    }
+    /**
+     * Adds event listeners to the element utilizing the triggers utility library.
      * @function
+     * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
-      var _this = this,
-          hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined',
-          parClass = 'is-dropdown-submenu-parent';
+      var _this = this;
 
-      // used for onClick and in the keyboard handlers
-      var handleClickFn = function (e) {
-        var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).parentsUntil('ul', '.' + parClass),
-            hasSub = $elem.hasClass(parClass),
-            hasClicked = $elem.attr('data-is-click') === 'true',
-            $sub = $elem.children('.is-dropdown-submenu');
+      this.$element.on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': this.close.bind(this),
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'resizeme.zf.trigger': this._setPosition.bind(this)
+      });
+      this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function () {
+        _this._setCurrentAnchor(this);
+      });
 
-        if (hasSub) {
-          if (hasClicked) {
-            if (!_this.options.closeOnClick || !_this.options.clickOpen && !hasTouch || _this.options.forceFollow && hasTouch) {
-              return;
-            } else {
-              e.stopImmediatePropagation();
-              e.preventDefault();
-              _this._hide($elem);
-            }
-          } else {
-            e.preventDefault();
-            e.stopImmediatePropagation();
-            _this._show($sub);
-            $elem.add($elem.parentsUntil(_this.$element, '.' + parClass)).attr('data-is-click', true);
-          }
-        }
-      };
+      if (this.options.hover) {
+        this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
+          _this._setCurrentAnchor(this);
 
-      if (this.options.clickOpen || hasTouch) {
-        this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);
-      }
+          var bodyData = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').data();
 
-      // Handle Leaf element Clicks
-      if (_this.options.closeOnClickInside) {
-        this.$menuItems.on('click.zf.dropdownmenu', function (e) {
-          var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-              hasSub = $elem.hasClass(parClass);
-          if (!hasSub) {
-            _this._hide();
+          if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') {
+            clearTimeout(_this.timeout);
+            _this.timeout = setTimeout(function () {
+              _this.open();
+
+              _this.$anchors.data('hover', true);
+            }, _this.options.hoverDelay);
           }
-        });
-      }
+        }).on('mouseleave.zf.dropdown', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["ignoreMousedisappear"])(function () {
+          clearTimeout(_this.timeout);
+          _this.timeout = setTimeout(function () {
+            _this.close();
 
-      if (!this.options.disableHover) {
-        this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {
-          var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-              hasSub = $elem.hasClass(parClass);
+            _this.$anchors.data('hover', false);
+          }, _this.options.hoverDelay);
+        }));
 
-          if (hasSub) {
-            clearTimeout($elem.data('_delay'));
-            $elem.data('_delay', setTimeout(function () {
-              _this._show($elem.children('.is-dropdown-submenu'));
-            }, _this.options.hoverDelay));
-          }
-        }).on('mouseleave.zf.dropdownmenu', function (e) {
-          var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-              hasSub = $elem.hasClass(parClass);
-          if (hasSub && _this.options.autoclose) {
-            if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) {
-              return false;
-            }
+        if (this.options.hoverPane) {
+          this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
+            clearTimeout(_this.timeout);
+          }).on('mouseleave.zf.dropdown', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["ignoreMousedisappear"])(function () {
+            clearTimeout(_this.timeout);
+            _this.timeout = setTimeout(function () {
+              _this.close();
 
-            clearTimeout($elem.data('_delay'));
-            $elem.data('_delay', setTimeout(function () {
-              _this._hide($elem);
-            }, _this.options.closingTime));
-          }
-        });
+              _this.$anchors.data('hover', false);
+            }, _this.options.hoverDelay);
+          }));
+        }
       }
-      this.$menuItems.on('keydown.zf.dropdownmenu', function (e) {
-        var $element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).parentsUntil('ul', '[role="menuitem"]'),
-            isTab = _this.$tabs.index($element) > -1,
-            $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),
-            $prevElement,
-            $nextElement;
 
-        $elements.each(function (i) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is($element)) {
-            $prevElement = $elements.eq(i - 1);
-            $nextElement = $elements.eq(i + 1);
-            return;
-          }
-        });
+      this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) {
+        var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            visibleFocusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].findFocusable(_this.$element);
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'Dropdown', {
+          open: function open() {
+            if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {
+              _this.open();
 
-        var nextSibling = function () {
-          $nextElement.children('a:first').focus();
-          e.preventDefault();
-        },
-            prevSibling = function () {
-          $prevElement.children('a:first').focus();
-          e.preventDefault();
-        },
-            openSub = function () {
-          var $sub = $element.children('ul.is-dropdown-submenu');
-          if ($sub.length) {
-            _this._show($sub);
-            $element.find('li > a:first').focus();
-            e.preventDefault();
-          } else {
-            return;
-          }
-        },
-            closeSub = function () {
-          //if ($element.is(':first-child')) {
-          var close = $element.parent('ul').parent('li');
-          close.children('a:first').focus();
-          _this._hide(close);
-          e.preventDefault();
-          //}
-        };
-        var functions = {
-          open: openSub,
-          close: function () {
-            _this._hide(_this.$element);
-            _this.$menuItems.eq(0).children('a').focus(); // focus to first element
-            e.preventDefault();
-          },
-          handled: function () {
-            e.stopImmediatePropagation();
-          }
-        };
+              _this.$element.attr('tabindex', -1).focus();
 
-        if (isTab) {
-          if (_this._isVertical()) {
-            // vertical menu
-            if (_this._isRtl()) {
-              // right aligned
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
-                down: nextSibling,
-                up: prevSibling,
-                next: closeSub,
-                previous: openSub
-              });
-            } else {
-              // left aligned
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
-                down: nextSibling,
-                up: prevSibling,
-                next: openSub,
-                previous: closeSub
-              });
-            }
-          } else {
-            // horizontal menu
-            if (_this._isRtl()) {
-              // right aligned
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
-                next: prevSibling,
-                previous: nextSibling,
-                down: openSub,
-                up: closeSub
-              });
-            } else {
-              // left aligned
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
-                next: nextSibling,
-                previous: prevSibling,
-                down: openSub,
-                up: closeSub
-              });
+              e.preventDefault();
             }
+          },
+          close: function close() {
+            _this.close();
+
+            _this.$anchors.focus();
           }
-        } else {
-          // not tabs -> one sub
-          if (_this._isRtl()) {
-            // right aligned
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
-              next: closeSub,
-              previous: openSub,
-              down: nextSibling,
-              up: prevSibling
-            });
-          } else {
-            // left aligned
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
-              next: openSub,
-              previous: closeSub,
-              down: nextSibling,
-              up: prevSibling
-            });
-          }
-        }
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'DropdownMenu', functions);
+        });
       });
     }
-
     /**
      * Adds an event handler to the body to close any dropdowns on a click.
      * @function
@@ -3259,2428 +3671,2577 @@ var DropdownMenu = function (_Plugin) {
      */
 
   }, {
-    key: '_addBodyHandler',
+    key: "_addBodyHandler",
     value: function _addBodyHandler() {
-      var $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document.body),
+      var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).not(this.$element),
           _this = this;
-      $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu').on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function (e) {
-        var $link = _this.$element.find(e.target);
-        if ($link.length) {
+
+      $body.off('click.zf.dropdown').on('click.zf.dropdown', function (e) {
+        if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {
           return;
         }
 
-        _this._hide();
-        $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');
+        if (_this.$element.is(e.target) || _this.$element.find(e.target).length) {
+          return;
+        }
+
+        _this.close();
+
+        $body.off('click.zf.dropdown');
       });
     }
-
     /**
-     * Opens a dropdown pane, and checks for collisions first.
-     * @param {jQuery} $sub - ul element that is a submenu to show
+     * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.
      * @function
-     * @private
-     * @fires DropdownMenu#show
+     * @fires Dropdown#closeme
+     * @fires Dropdown#show
      */
 
   }, {
-    key: '_show',
-    value: function _show($sub) {
-      var idx = this.$tabs.index(this.$tabs.filter(function (i, el) {
-        return __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el).find($sub).length > 0;
-      }));
-      var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');
-      this._hide($sibs, idx);
-      $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active');
-      var clear = __WEBPACK_IMPORTED_MODULE_3__foundation_util_box__["a" /* Box */].ImNotTouchingYou($sub, null, true);
-      if (!clear) {
-        var oldClass = this.options.alignment === 'left' ? '-right' : '-left',
-            $parentLi = $sub.parent('.is-dropdown-submenu-parent');
-        $parentLi.removeClass('opens' + oldClass).addClass('opens-' + this.options.alignment);
-        clear = __WEBPACK_IMPORTED_MODULE_3__foundation_util_box__["a" /* Box */].ImNotTouchingYou($sub, null, true);
-        if (!clear) {
-          $parentLi.removeClass('opens-' + this.options.alignment).addClass('opens-inner');
+    key: "open",
+    value: function open() {
+      // var _this = this;
+
+      /**
+       * Fires to close other open dropdowns, typically when dropdown is opening
+       * @event Dropdown#closeme
+       */
+      this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));
+      this.$anchors.addClass('hover').attr({
+        'aria-expanded': true
+      }); // this.$element/*.show()*/;
+
+      this.$element.addClass('is-opening');
+
+      this._setPosition();
+
+      this.$element.removeClass('is-opening').addClass('is-open').attr({
+        'aria-hidden': false
+      });
+
+      if (this.options.autoFocus) {
+        var $focusable = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].findFocusable(this.$element);
+
+        if ($focusable.length) {
+          $focusable.eq(0).focus();
         }
-        this.changed = true;
       }
-      $sub.css('visibility', '');
+
       if (this.options.closeOnClick) {
         this._addBodyHandler();
       }
+
+      if (this.options.trapFocus) {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].trapFocus(this.$element);
+      }
       /**
-       * Fires when the new dropdown pane is visible.
-       * @event DropdownMenu#show
+       * Fires once the dropdown is visible.
+       * @event Dropdown#show
        */
-      this.$element.trigger('show.zf.dropdownmenu', [$sub]);
-    }
 
+
+      this.$element.trigger('show.zf.dropdown', [this.$element]);
+    }
     /**
-     * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.
+     * Closes the open dropdown pane.
      * @function
-     * @param {jQuery} $elem - element with a submenu to hide
-     * @param {Number} idx - index of the $tabs collection to hide
-     * @private
+     * @fires Dropdown#hide
      */
 
   }, {
-    key: '_hide',
-    value: function _hide($elem, idx) {
-      var $toClose;
-      if ($elem && $elem.length) {
-        $toClose = $elem;
-      } else if (idx !== undefined) {
-        $toClose = this.$tabs.not(function (i, el) {
-          return i === idx;
-        });
-      } else {
-        $toClose = this.$element;
+    key: "close",
+    value: function close() {
+      if (!this.$element.hasClass('is-open')) {
+        return false;
       }
-      var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;
 
-      if (somethingToClose) {
-        $toClose.find('li.is-active').add($toClose).attr({
-          'data-is-click': false
-        }).removeClass('is-active');
+      this.$element.removeClass('is-open').attr({
+        'aria-hidden': true
+      });
+      this.$anchors.removeClass('hover').attr('aria-expanded', false);
+      /**
+       * Fires once the dropdown is no longer visible.
+       * @event Dropdown#hide
+       */
 
-        $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');
+      this.$element.trigger('hide.zf.dropdown', [this.$element]);
 
-        if (this.changed || $toClose.find('opens-inner').length) {
-          var oldClass = this.options.alignment === 'left' ? 'right' : 'left';
-          $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass('opens-inner opens-' + this.options.alignment).addClass('opens-' + oldClass);
-          this.changed = false;
-        }
-        /**
-         * Fires when the open menus are closed.
-         * @event DropdownMenu#hide
-         */
-        this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);
+      if (this.options.trapFocus) {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].releaseFocus(this.$element);
       }
     }
-
     /**
-     * Destroys the plugin.
+     * Toggles the dropdown pane's visibility.
      * @function
      */
 
   }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click').removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document.body).off('.zf.dropdownmenu');
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["a" /* Nest */].Burn(this.$element, 'dropdown');
+    key: "toggle",
+    value: function toggle() {
+      if (this.$element.hasClass('is-open')) {
+        if (this.$anchors.data('hover')) return;
+        this.close();
+      } else {
+        this.open();
+      }
+    }
+    /**
+     * Destroys the dropdown.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.trigger').hide();
+      this.$anchors.off('.zf.dropdown');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('click.zf.dropdown');
     }
   }]);
 
-  return DropdownMenu;
-}(__WEBPACK_IMPORTED_MODULE_5__foundation_plugin__["a" /* Plugin */]);
+  return Dropdown;
+}(_foundation_positionable__WEBPACK_IMPORTED_MODULE_3__["Positionable"]);
 
-/**
- * Default settings for plugin
- */
+Dropdown.defaults = {
+  /**
+   * Class that designates bounding container of Dropdown (default: window)
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  parentClass: null,
 
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  hoverDelay: 250,
 
-DropdownMenu.defaults = {
   /**
-   * Disallows hover events from opening submenus
+   * Allow submenus to open on hover events
    * @option
    * @type {boolean}
    * @default false
    */
-  disableHover: false,
+  hover: false,
+
   /**
-   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.
+   * Don't close dropdown when hovering over dropdown pane
    * @option
    * @type {boolean}
-   * @default true
+   * @default false
    */
-  autoclose: true,
+  hoverPane: false,
+
   /**
-   * Amount of time to delay opening a submenu on hover event.
+   * Number of pixels between the dropdown pane and the triggering element on open.
    * @option
    * @type {number}
-   * @default 50
+   * @default 0
    */
-  hoverDelay: 50,
+  vOffset: 0,
+
   /**
-   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.
+   * Number of pixels between the dropdown pane and the triggering element on open.
    * @option
-   * @type {boolean}
-   * @default false
+   * @type {number}
+   * @default 0
    */
-  clickOpen: false,
+  hOffset: 0,
+
   /**
-   * Amount of time to delay closing a submenu on a mouseleave event.
+   * Position of dropdown. Can be left, right, bottom, top, or auto.
    * @option
-   * @type {number}
-   * @default 500
+   * @type {string}
+   * @default 'auto'
    */
+  position: 'auto',
 
-  closingTime: 500,
   /**
-   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.
+   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.
    * @option
    * @type {string}
    * @default 'auto'
    */
   alignment: 'auto',
+
   /**
-   * Allow clicks on the body to close any open submenus.
+   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.
    * @option
    * @type {boolean}
-   * @default true
+   * @default false
    */
-  closeOnClick: true,
+  allowOverlap: false,
+
   /**
-   * Allow clicks on leaf anchor links to close any open submenus.
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
    * @option
    * @type {boolean}
    * @default true
    */
-  closeOnClickInside: true,
+  allowBottomOverlap: true,
+
   /**
-   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.
+   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.
    * @option
-   * @type {string}
-   * @default 'vertical'
+   * @type {boolean}
+   * @default false
    */
-  verticalClass: 'vertical',
+  trapFocus: false,
+
   /**
-   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.
+   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.
    * @option
-   * @type {string}
-   * @default 'align-right'
+   * @type {boolean}
+   * @default false
    */
-  rightClass: 'align-right',
+  autoFocus: false,
+
   /**
-   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.
+   * Allows a click on the body to close the dropdown.
    * @option
    * @type {boolean}
-   * @default true
+   * @default false
    */
-  forceFollow: true
+  closeOnClick: false
 };
 
 
-
 /***/ }),
-/* 15 */
+
+/***/ "./js/foundation.dropdownMenu.js":
+/*!***************************************!*\
+  !*** ./js/foundation.dropdownMenu.js ***!
+  \***************************************/
+/*! exports provided: DropdownMenu */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Positionable; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__ = __webpack_require__(7);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(1);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DropdownMenu", function() { return DropdownMenu; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.nest */ "./js/foundation.util.nest.js");
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.box */ "./js/foundation.util.box.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
 
-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 _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
-var POSITIONS = ['left', 'right', 'top', 'bottom'];
-var VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];
-var HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-var ALIGNMENTS = {
-  'left': VERTICAL_ALIGNMENTS,
-  'right': VERTICAL_ALIGNMENTS,
-  'top': HORIZONTAL_ALIGNMENTS,
-  'bottom': HORIZONTAL_ALIGNMENTS
-};
 
-function nextItem(item, array) {
-  var currentIdx = array.indexOf(item);
-  if (currentIdx === array.length - 1) {
-    return array[0];
-  } else {
-    return array[currentIdx + 1];
-  }
-}
 
-var Positionable = function (_Plugin) {
-  _inherits(Positionable, _Plugin);
 
-  function Positionable() {
-    _classCallCheck(this, Positionable);
 
-    return _possibleConstructorReturn(this, (Positionable.__proto__ || Object.getPrototypeOf(Positionable)).apply(this, arguments));
+
+
+/**
+ * DropdownMenu module.
+ * @module foundation.dropdown-menu
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.box
+ * @requires foundation.util.nest
+ */
+
+var DropdownMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(DropdownMenu, _Plugin);
+
+  function DropdownMenu() {
+    _classCallCheck(this, DropdownMenu);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(DropdownMenu).apply(this, arguments));
   }
 
-  _createClass(Positionable, [{
-    key: '_init',
+  _createClass(DropdownMenu, [{
+    key: "_setup",
 
     /**
-     * Abstract class encapsulating the tether-like explicit positioning logic
-     * including repositioning based on overlap.
-     * Expects classes to define defaults for vOffset, hOffset, position,
-     * alignment, allowOverlap, and allowBottomOverlap. They can do this by
-     * extending the defaults, or (for now recommended due to the way docs are
-     * generated) by explicitly declaring them.
-     *
-     **/
+     * Creates a new instance of DropdownMenu.
+     * @class
+     * @name DropdownMenu
+     * @fires DropdownMenu#init
+     * @param {jQuery} element - jQuery object to make into a dropdown menu.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, DropdownMenu.defaults, this.$element.data(), options);
+      this.className = 'DropdownMenu'; // ie9 back compat
 
-    value: function _init() {
-      this.triedPositions = {};
-      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;
-      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;
-    }
-  }, {
-    key: '_getDefaultPosition',
-    value: function _getDefaultPosition() {
-      return 'bottom';
-    }
-  }, {
-    key: '_getDefaultAlignment',
-    value: function _getDefaultAlignment() {
-      switch (this.position) {
-        case 'bottom':
-        case 'top':
-          return __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["a" /* rtl */])() ? 'right' : 'left';
-        case 'left':
-        case 'right':
-          return 'bottom';
-      }
-    }
+      this._init();
 
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_3__["Keyboard"].register('DropdownMenu', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'up',
+        'ARROW_DOWN': 'down',
+        'ARROW_LEFT': 'previous',
+        'ESCAPE': 'close'
+      });
+    }
     /**
-     * Adjusts the positionable possible positions by iterating through alignments
-     * and positions.
-     * @function
+     * Initializes the plugin, and calls _prepareMenu
      * @private
+     * @function
      */
 
   }, {
-    key: '_reposition',
-    value: function _reposition() {
-      if (this._alignmentsExhausted(this.position)) {
-        this.position = nextItem(this.position, POSITIONS);
-        this.alignment = ALIGNMENTS[this.position][0];
+    key: "_init",
+    value: function _init() {
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_4__["Nest"].Feather(this.$element, 'dropdown');
+      var subs = this.$element.find('li.is-dropdown-submenu-parent');
+      this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');
+      this.$menuItems = this.$element.find('[role="menuitem"]');
+      this.$tabs = this.$element.children('[role="menuitem"]');
+      this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);
+
+      if (this.options.alignment === 'auto') {
+        if (this.$element.hasClass(this.options.rightClass) || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["rtl"])() || this.$element.parents('.top-bar-right').is('*')) {
+          this.options.alignment = 'right';
+          subs.addClass('opens-left');
+        } else {
+          this.options.alignment = 'left';
+          subs.addClass('opens-right');
+        }
       } else {
-        this._realign();
+        if (this.options.alignment === 'right') {
+          subs.addClass('opens-left');
+        } else {
+          subs.addClass('opens-right');
+        }
       }
-    }
 
-    /**
-     * Adjusts the dropdown pane possible positions by iterating through alignments
-     * on the current position.
-     * @function
-     * @private
-     */
+      this.changed = false;
 
-  }, {
-    key: '_realign',
-    value: function _realign() {
-      this._addTriedPosition(this.position, this.alignment);
-      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);
+      this._events();
     }
   }, {
-    key: '_addTriedPosition',
-    value: function _addTriedPosition(position, alignment) {
-      this.triedPositions[position] = this.triedPositions[position] || [];
-      this.triedPositions[position].push(alignment);
+    key: "_isVertical",
+    value: function _isVertical() {
+      return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';
     }
   }, {
-    key: '_positionsExhausted',
-    value: function _positionsExhausted() {
-      var isExhausted = true;
-      for (var i = 0; i < POSITIONS.length; i++) {
-        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);
-      }
-      return isExhausted;
+    key: "_isRtl",
+    value: function _isRtl() {
+      return this.$element.hasClass('align-right') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["rtl"])() && !this.$element.hasClass('align-left');
     }
-  }, {
-    key: '_alignmentsExhausted',
-    value: function _alignmentsExhausted(position) {
-      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;
-    }
-
-    // When we're trying to center, we don't want to apply offset that's going to
-    // take us just off center, so wrap around to return 0 for the appropriate
-    // offset in those alignments.  TODO: Figure out if we want to make this
-    // configurable behavior... it feels more intuitive, especially for tooltips, but
-    // it's possible someone might actually want to start from center and then nudge
-    // slightly off.
+    /**
+     * Adds event listeners to elements within the menu
+     * @private
+     * @function
+     */
 
   }, {
-    key: '_getVOffset',
-    value: function _getVOffset() {
-      return this.options.vOffset;
-    }
-  }, {
-    key: '_getHOffset',
-    value: function _getHOffset() {
-      return this.options.hOffset;
-    }
-  }, {
-    key: '_setPosition',
-    value: function _setPosition($anchor, $element, $parent) {
-      if ($anchor.attr('aria-expanded') === 'false') {
-        return false;
-      }
-      var $eleDims = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["a" /* Box */].GetDimensions($element),
-          $anchorDims = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["a" /* Box */].GetDimensions($anchor);
-
-      $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["a" /* Box */].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
-
-      if (!this.options.allowOverlap) {
-        var overlaps = {};
-        var minOverlap = 100000000;
-        // default coordinates to how we start, in case we can't figure out better
-        var minCoordinates = { position: this.position, alignment: this.alignment };
-        while (!this._positionsExhausted()) {
-          var overlap = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["a" /* Box */].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
-          if (overlap === 0) {
-            return;
-          }
-
-          if (overlap < minOverlap) {
-            minOverlap = overlap;
-            minCoordinates = { position: this.position, alignment: this.alignment };
-          }
-
-          this._reposition();
+    key: "_events",
+    value: function _events() {
+      var _this = this,
+          hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined',
+          parClass = 'is-dropdown-submenu-parent'; // used for onClick and in the keyboard handlers
 
-          $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["a" /* Box */].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
-        }
-        // If we get through the entire loop, there was no non-overlapping
-        // position available. Pick the version with least overlap.
-        this.position = minCoordinates.position;
-        this.alignment = minCoordinates.alignment;
-        $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["a" /* Box */].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
-      }
-    }
-  }]);
 
-  return Positionable;
-}(__WEBPACK_IMPORTED_MODULE_1__foundation_plugin__["a" /* Plugin */]);
+      var handleClickFn = function handleClickFn(e) {
+        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', ".".concat(parClass)),
+            hasSub = $elem.hasClass(parClass),
+            hasClicked = $elem.attr('data-is-click') === 'true',
+            $sub = $elem.children('.is-dropdown-submenu');
 
-Positionable.defaults = {
-  /**
-   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.
-   * @option
-   * @type {string}
-   * @default 'auto'
-   */
-  position: 'auto',
-  /**
-   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.
-   * @option
-   * @type {string}
-   * @default 'auto'
-   */
-  alignment: 'auto',
-  /**
-   * Allow overlap of container/window. If false, dropdown positionable first
-   * try to position as defined by data-position and data-alignment, but
-   * reposition if it would cause an overflow.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  allowOverlap: false,
-  /**
-   * Allow overlap of only the bottom of the container. This is the most common
-   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
-   * screen but not otherwise influence or break out of the container.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  allowBottomOverlap: true,
-  /**
-   * Number of pixels the positionable should be separated vertically from anchor
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  vOffset: 0,
-  /**
-   * Number of pixels the positionable should be separated horizontally from anchor
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  hOffset: 0
-};
+        if (hasSub) {
+          if (hasClicked) {
+            if (!_this.options.closeOnClick || !_this.options.clickOpen && !hasTouch || _this.options.forceFollow && hasTouch) {
+              return;
+            } else {
+              e.stopImmediatePropagation();
+              e.preventDefault();
 
+              _this._hide($elem);
+            }
+          } else {
+            e.preventDefault();
+            e.stopImmediatePropagation();
 
+            _this._show($sub);
 
-/***/ }),
-/* 16 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+            $elem.add($elem.parentsUntil(_this.$element, ".".concat(parClass))).attr('data-is-click', true);
+          }
+        }
+      };
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return SmoothScroll; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin__ = __webpack_require__(2);
+      if (this.options.clickOpen || hasTouch) {
+        this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);
+      } // Handle Leaf element Clicks
 
 
-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; }; }();
+      if (_this.options.closeOnClickInside) {
+        this.$menuItems.on('click.zf.dropdownmenu', function (e) {
+          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+              hasSub = $elem.hasClass(parClass);
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+          if (!hasSub) {
+            _this._hide();
+          }
+        });
+      }
 
-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; }
+      if (!this.options.disableHover) {
+        this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {
+          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+              hasSub = $elem.hasClass(parClass);
 
-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; }
+          if (hasSub) {
+            clearTimeout($elem.data('_delay'));
+            $elem.data('_delay', setTimeout(function () {
+              _this._show($elem.children('.is-dropdown-submenu'));
+            }, _this.options.hoverDelay));
+          }
+        }).on('mouseleave.zf.dropdownMenu', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["ignoreMousedisappear"])(function (e) {
+          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+              hasSub = $elem.hasClass(parClass);
 
+          if (hasSub && _this.options.autoclose) {
+            if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) {
+              return false;
+            }
 
+            clearTimeout($elem.data('_delay'));
+            $elem.data('_delay', setTimeout(function () {
+              _this._hide($elem);
+            }, _this.options.closingTime));
+          }
+        }));
+      }
 
+      this.$menuItems.on('keydown.zf.dropdownmenu', function (e) {
+        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', '[role="menuitem"]'),
+            isTab = _this.$tabs.index($element) > -1,
+            $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),
+            $prevElement,
+            $nextElement;
+        $elements.each(function (i) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {
+            $prevElement = $elements.eq(i - 1);
+            $nextElement = $elements.eq(i + 1);
+            return;
+          }
+        });
 
+        var nextSibling = function nextSibling() {
+          $nextElement.children('a:first').focus();
+          e.preventDefault();
+        },
+            prevSibling = function prevSibling() {
+          $prevElement.children('a:first').focus();
+          e.preventDefault();
+        },
+            openSub = function openSub() {
+          var $sub = $element.children('ul.is-dropdown-submenu');
 
-/**
- * SmoothScroll module.
- * @module foundation.smooth-scroll
- */
+          if ($sub.length) {
+            _this._show($sub);
 
-var SmoothScroll = function (_Plugin) {
-    _inherits(SmoothScroll, _Plugin);
+            $element.find('li > a:first').focus();
+            e.preventDefault();
+          } else {
+            return;
+          }
+        },
+            closeSub = function closeSub() {
+          //if ($element.is(':first-child')) {
+          var close = $element.parent('ul').parent('li');
+          close.children('a:first').focus();
 
-    function SmoothScroll() {
-        _classCallCheck(this, SmoothScroll);
+          _this._hide(close);
 
-        return _possibleConstructorReturn(this, (SmoothScroll.__proto__ || Object.getPrototypeOf(SmoothScroll)).apply(this, arguments));
-    }
+          e.preventDefault(); //}
+        };
 
-    _createClass(SmoothScroll, [{
-        key: '_setup',
+        var functions = {
+          open: openSub,
+          close: function close() {
+            _this._hide(_this.$element);
 
-        /**
-         * Creates a new instance of SmoothScroll.
-         * @class
-         * @name SmoothScroll
-         * @fires SmoothScroll#init
-         * @param {Object} element - jQuery object to add the trigger to.
-         * @param {Object} options - Overrides to the default plugin settings.
-         */
-        value: function _setup(element, options) {
-            this.$element = element;
-            this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, SmoothScroll.defaults, this.$element.data(), options);
-            this.className = 'SmoothScroll'; // ie9 back compat
+            _this.$menuItems.eq(0).children('a').focus(); // focus to first element
 
-            this._init();
-        }
 
-        /**
-         * Initialize the SmoothScroll plugin
-         * @private
-         */
+            e.preventDefault();
+          },
+          handled: function handled() {
+            e.stopImmediatePropagation();
+          }
+        };
 
-    }, {
-        key: '_init',
-        value: function _init() {
-            var id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["b" /* GetYoDigits */])(6, 'smooth-scroll');
-            var _this = this;
-            this.$element.attr({
-                'id': id
+        if (isTab) {
+          if (_this._isVertical()) {
+            // vertical menu
+            if (_this._isRtl()) {
+              // right aligned
+              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
+                down: nextSibling,
+                up: prevSibling,
+                next: closeSub,
+                previous: openSub
+              });
+            } else {
+              // left aligned
+              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
+                down: nextSibling,
+                up: prevSibling,
+                next: openSub,
+                previous: closeSub
+              });
+            }
+          } else {
+            // horizontal menu
+            if (_this._isRtl()) {
+              // right aligned
+              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
+                next: prevSibling,
+                previous: nextSibling,
+                down: openSub,
+                up: closeSub
+              });
+            } else {
+              // left aligned
+              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
+                next: nextSibling,
+                previous: prevSibling,
+                down: openSub,
+                up: closeSub
+              });
+            }
+          }
+        } else {
+          // not tabs -> one sub
+          if (_this._isRtl()) {
+            // right aligned
+            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
+              next: closeSub,
+              previous: openSub,
+              down: nextSibling,
+              up: prevSibling
             });
-
-            this._events();
+          } else {
+            // left aligned
+            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
+              next: openSub,
+              previous: closeSub,
+              down: nextSibling,
+              up: prevSibling
+            });
+          }
         }
 
-        /**
-         * Initializes events for SmoothScroll.
-         * @private
-         */
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_3__["Keyboard"].handleKey(e, 'DropdownMenu', functions);
+      });
+    }
+    /**
+     * Adds an event handler to the body to close any dropdowns on a click.
+     * @function
+     * @private
+     */
 
-    }, {
-        key: '_events',
-        value: function _events() {
-            var _this = this;
+  }, {
+    key: "_addBodyHandler",
+    value: function _addBodyHandler() {
+      var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body),
+          _this = this;
 
-            // click handler function.
-            var handleLinkClick = function (e) {
-                // exit function if the event source isn't coming from an anchor with href attribute starts with '#'
-                if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is('a[href^="#"]')) {
-                    return false;
-                }
+      $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu').on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function (e) {
+        var $link = _this.$element.find(e.target);
 
-                var arrival = this.getAttribute('href');
+        if ($link.length) {
+          return;
+        }
 
-                _this._inTransition = true;
+        _this._hide();
 
-                SmoothScroll.scrollToLoc(arrival, _this.options, function () {
-                    _this._inTransition = false;
-                });
+        $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');
+      });
+    }
+    /**
+     * Opens a dropdown pane, and checks for collisions first.
+     * @param {jQuery} $sub - ul element that is a submenu to show
+     * @function
+     * @private
+     * @fires Dropdownmenu#show
+     */
 
-                e.preventDefault();
-            };
+  }, {
+    key: "_show",
+    value: function _show($sub) {
+      var idx = this.$tabs.index(this.$tabs.filter(function (i, el) {
+        return jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).find($sub).length > 0;
+      }));
+      var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');
+
+      this._hide($sibs, idx);
+
+      $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active');
+      var clear = _foundation_util_box__WEBPACK_IMPORTED_MODULE_5__["Box"].ImNotTouchingYou($sub, null, true);
+
+      if (!clear) {
+        var oldClass = this.options.alignment === 'left' ? '-right' : '-left',
+            $parentLi = $sub.parent('.is-dropdown-submenu-parent');
+        $parentLi.removeClass("opens".concat(oldClass)).addClass("opens-".concat(this.options.alignment));
+        clear = _foundation_util_box__WEBPACK_IMPORTED_MODULE_5__["Box"].ImNotTouchingYou($sub, null, true);
 
-            this.$element.on('click.zf.smoothScroll', handleLinkClick);
-            this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', handleLinkClick);
+        if (!clear) {
+          $parentLi.removeClass("opens-".concat(this.options.alignment)).addClass('opens-inner');
         }
 
-        /**
-         * Function to scroll to a given location on the page.
-         * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'
-         * @param {Object} options - The options to use.
-         * @param {Function} callback - The callback function.
-         * @static
-         * @function
-         */
+        this.changed = true;
+      }
 
-    }], [{
-        key: 'scrollToLoc',
-        value: function scrollToLoc(loc) {
-            var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults;
-            var callback = arguments[2];
+      $sub.css('visibility', '');
 
-            // Do nothing if target does not exist to prevent errors
-            if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(loc).length) {
-                return false;
-            }
+      if (this.options.closeOnClick) {
+        this._addBodyHandler();
+      }
+      /**
+       * Fires when the new dropdown pane is visible.
+       * @event Dropdownmenu#show
+       */
 
-            var scrollPos = Math.round(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(loc).offset().top - options.threshold / 2 - options.offset);
 
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').stop(true).animate({ scrollTop: scrollPos }, options.animationDuration, options.animationEasing, function () {
-                if (callback && typeof callback == "function") {
-                    callback();
-                }
-            });
+      this.$element.trigger('show.zf.dropdownmenu', [$sub]);
+    }
+    /**
+     * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.
+     * @function
+     * @param {jQuery} $elem - element with a submenu to hide
+     * @param {Number} idx - index of the $tabs collection to hide
+     * @private
+     */
+
+  }, {
+    key: "_hide",
+    value: function _hide($elem, idx) {
+      var $toClose;
+
+      if ($elem && $elem.length) {
+        $toClose = $elem;
+      } else if (typeof idx !== 'undefined') {
+        $toClose = this.$tabs.not(function (i, el) {
+          return i === idx;
+        });
+      } else {
+        $toClose = this.$element;
+      }
+
+      var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;
+
+      if (somethingToClose) {
+        $toClose.find('li.is-active').add($toClose).attr({
+          'data-is-click': false
+        }).removeClass('is-active');
+        $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');
+
+        if (this.changed || $toClose.find('opens-inner').length) {
+          var oldClass = this.options.alignment === 'left' ? 'right' : 'left';
+          $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass("opens-inner opens-".concat(this.options.alignment)).addClass("opens-".concat(oldClass));
+          this.changed = false;
         }
-    }]);
+        /**
+         * Fires when the open menus are closed.
+         * @event Dropdownmenu#hide
+         */
+
 
-    return SmoothScroll;
-}(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__["a" /* Plugin */]);
+        this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);
+      }
+    }
+    /**
+     * Destroys the plugin.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click').removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('.zf.dropdownmenu');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_4__["Nest"].Burn(this.$element, 'dropdown');
+    }
+  }]);
 
+  return DropdownMenu;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 /**
- * Default settings for plugin.
+ * Default settings for plugin
  */
 
 
-SmoothScroll.defaults = {
-    /**
-     * Amount of time, in ms, the animated scrolling should take between locations.
-     * @option
-     * @type {number}
-     * @default 500
-     */
-    animationDuration: 500,
-    /**
-     * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
-     * @option
-     * @type {string}
-     * @default 'linear'
-     * @see {@link https://api.jquery.com/animate|Jquery animate}
-     */
-    animationEasing: 'linear',
-    /**
-     * Number of pixels to use as a marker for location changes.
-     * @option
-     * @type {number}
-     * @default 50
-     */
-    threshold: 50,
-    /**
-     * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
-     * @option
-     * @type {number}
-     * @default 0
-     */
-    offset: 0
-};
+DropdownMenu.defaults = {
+  /**
+   * Disallows hover events from opening submenus
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disableHover: false,
+
+  /**
+   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  autoclose: true,
+
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  hoverDelay: 50,
+
+  /**
+   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  clickOpen: false,
+
+  /**
+   * Amount of time to delay closing a submenu on a mouseleave event.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  closingTime: 500,
+
+  /**
+   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow clicks on the body to close any open submenus.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Allow clicks on leaf anchor links to close any open submenus.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClickInside: true,
+
+  /**
+   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.
+   * @option
+   * @type {string}
+   * @default 'vertical'
+   */
+  verticalClass: 'vertical',
+
+  /**
+   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.
+   * @option
+   * @type {string}
+   * @default 'align-right'
+   */
+  rightClass: 'align-right',
 
+  /**
+   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  forceFollow: true
+};
 
 
 /***/ }),
-/* 17 */
+
+/***/ "./js/foundation.equalizer.js":
+/*!************************************!*\
+  !*** ./js/foundation.equalizer.js ***!
+  \************************************/
+/*! exports provided: Equalizer */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Tabs; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__ = __webpack_require__(8);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Equalizer", function() { return Equalizer; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.imageLoader */ "./js/foundation.util.imageLoader.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-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; }
 
 
 
 
 
 /**
- * Tabs module.
- * @module foundation.tabs
- * @requires foundation.util.keyboard
- * @requires foundation.util.imageLoader if tabs contain images
+ * Equalizer module.
+ * @module foundation.equalizer
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.imageLoader if equalizer contains images
  */
 
-var Tabs = function (_Plugin) {
-  _inherits(Tabs, _Plugin);
+var Equalizer =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Equalizer, _Plugin);
 
-  function Tabs() {
-    _classCallCheck(this, Tabs);
+  function Equalizer() {
+    _classCallCheck(this, Equalizer);
 
-    return _possibleConstructorReturn(this, (Tabs.__proto__ || Object.getPrototypeOf(Tabs)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Equalizer).apply(this, arguments));
   }
 
-  _createClass(Tabs, [{
-    key: '_setup',
+  _createClass(Equalizer, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of tabs.
+     * Creates a new instance of Equalizer.
      * @class
-     * @name Tabs
-     * @fires Tabs#init
-     * @param {jQuery} element - jQuery object to make into tabs.
+     * @name Equalizer
+     * @fires Equalizer#init
+     * @param {Object} element - jQuery object to add the trigger to.
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Tabs.defaults, this.$element.data(), options);
-      this.className = 'Tabs'; // ie9 back compat
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Equalizer.defaults, this.$element.data(), options);
+      this.className = 'Equalizer'; // ie9 back compat
 
       this._init();
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('Tabs', {
-        'ENTER': 'open',
-        'SPACE': 'open',
-        'ARROW_RIGHT': 'next',
-        'ARROW_UP': 'previous',
-        'ARROW_DOWN': 'next',
-        'ARROW_LEFT': 'previous'
-        // 'TAB': 'next',
-        // 'SHIFT_TAB': 'previous'
-      });
     }
-
     /**
-     * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.
+     * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      var _this3 = this;
+      var eqId = this.$element.attr('data-equalizer') || '';
+      var $watched = this.$element.find("[data-equalizer-watch=\"".concat(eqId, "\"]"));
 
-      var _this = this;
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init();
 
-      this.$element.attr({ 'role': 'tablist' });
-      this.$tabTitles = this.$element.find('.' + this.options.linkClass);
-      this.$tabContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-tabs-content="' + this.$element[0].id + '"]');
-
-      this.$tabTitles.each(function () {
-        var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            $link = $elem.find('a'),
-            isActive = $elem.hasClass('' + _this.options.linkActiveClass),
-            hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),
-            linkId = $link[0].id ? $link[0].id : hash + '-label',
-            $tabContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + hash);
-
-        $elem.attr({ 'role': 'presentation' });
-
-        $link.attr({
-          'role': 'tab',
-          'aria-controls': hash,
-          'aria-selected': isActive,
-          'id': linkId,
-          'tabindex': isActive ? '0' : '-1'
-        });
-
-        $tabContent.attr({
-          'role': 'tabpanel',
-          'aria-labelledby': linkId
-        });
-
-        if (!isActive) {
-          $tabContent.attr('aria-hidden', 'true');
-        }
-
-        if (isActive && _this.options.autoFocus) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).load(function () {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, function () {
-              $link.focus();
-            });
-          });
-        }
-      });
-      if (this.options.matchHeight) {
-        var $images = this.$tabContent.find('img');
+      this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');
+      this.$element.attr('data-resize', eqId || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'eq'));
+      this.$element.attr('data-mutate', eqId || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'eq'));
+      this.hasNested = this.$element.find('[data-equalizer]').length > 0;
+      this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;
+      this.isOn = false;
+      this._bindHandler = {
+        onResizeMeBound: this._onResizeMe.bind(this),
+        onPostEqualizedBound: this._onPostEqualized.bind(this)
+      };
+      var imgs = this.$element.find('img');
+      var tooSmall;
 
-        if ($images.length) {
-          __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__["a" /* onImagesLoaded */])($images, this._setHeight.bind(this));
-        } else {
-          this._setHeight();
-        }
+      if (this.options.equalizeOn) {
+        tooSmall = this._checkMQ();
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));
+      } else {
+        this._events();
       }
 
-      //current context-bound function to open tabs on page load or history popstate
-      this._checkDeepLink = function () {
-        var anchor = window.location.hash;
-        //need a hash and a relevant anchor in this tabset
-        if (anchor.length) {
-          var $link = _this3.$element.find('[href$="' + anchor + '"]');
-          if ($link.length) {
-            _this3.selectTab(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(anchor), true);
-
-            //roll up a little to show the titles
-            if (_this3.options.deepLinkSmudge) {
-              var offset = _this3.$element.offset();
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').animate({ scrollTop: offset.top }, _this3.options.deepLinkSmudgeDelay);
-            }
-
-            /**
-              * Fires when the zplugin has deeplinked at pageload
-              * @event Tabs#deeplink
-              */
-            _this3.$element.trigger('deeplink.zf.tabs', [$link, __WEBPACK_IMPORTED_MODULE_0_jquery___default()(anchor)]);
-          }
+      if (typeof tooSmall !== 'undefined' && tooSmall === false || typeof tooSmall === 'undefined') {
+        if (imgs.length) {
+          Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__["onImagesLoaded"])(imgs, this._reflow.bind(this));
+        } else {
+          this._reflow();
         }
-      };
-
-      //use browser to open a tab, if it exists in this tabset
-      if (this.options.deepLink) {
-        this._checkDeepLink();
       }
-
-      this._events();
     }
-
     /**
-     * Adds event handlers for items within the tabs.
+     * Removes event listeners if the breakpoint is too small.
      * @private
      */
 
   }, {
-    key: '_events',
-    value: function _events() {
-      this._addKeyHandler();
-      this._addClickHandler();
-      this._setHeightMqHandler = null;
-
-      if (this.options.matchHeight) {
-        this._setHeightMqHandler = this._setHeight.bind(this);
-
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', this._setHeightMqHandler);
-      }
-
-      if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('popstate', this._checkDeepLink);
-      }
+    key: "_pauseEvents",
+    value: function _pauseEvents() {
+      this.isOn = false;
+      this.$element.off({
+        '.zf.equalizer': this._bindHandler.onPostEqualizedBound,
+        'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,
+        'mutateme.zf.trigger': this._bindHandler.onResizeMeBound
+      });
     }
-
     /**
-     * Adds click handlers for items within the tabs.
+     * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound
      * @private
      */
 
   }, {
-    key: '_addClickHandler',
-    value: function _addClickHandler() {
-      var _this = this;
-
-      this.$element.off('click.zf.tabs').on('click.zf.tabs', '.' + this.options.linkClass, function (e) {
-        e.preventDefault();
-        e.stopPropagation();
-        _this._handleTabChange(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
-      });
+    key: "_onResizeMe",
+    value: function _onResizeMe(e) {
+      this._reflow();
     }
+    /**
+     * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound
+     * @private
+     */
 
+  }, {
+    key: "_onPostEqualized",
+    value: function _onPostEqualized(e) {
+      if (e.target !== this.$element[0]) {
+        this._reflow();
+      }
+    }
     /**
-     * Adds keyboard event handlers for items within the tabs.
+     * Initializes events for Equalizer.
      * @private
      */
 
   }, {
-    key: '_addKeyHandler',
-    value: function _addKeyHandler() {
+    key: "_events",
+    value: function _events() {
       var _this = this;
 
-      this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) {
-        if (e.which === 9) return;
-
-        var $element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            $elements = $element.parent('ul').children('li'),
-            $prevElement,
-            $nextElement;
+      this._pauseEvents();
 
-        $elements.each(function (i) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is($element)) {
-            if (_this.options.wrapOnKeys) {
-              $prevElement = i === 0 ? $elements.last() : $elements.eq(i - 1);
-              $nextElement = i === $elements.length - 1 ? $elements.first() : $elements.eq(i + 1);
-            } else {
-              $prevElement = $elements.eq(Math.max(0, i - 1));
-              $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
-            }
-            return;
-          }
-        });
+      if (this.hasNested) {
+        this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);
+      } else {
+        this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);
+        this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);
+      }
 
-        // handle keyboard event with keyboard util
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'Tabs', {
-          open: function () {
-            $element.find('[role="tab"]').focus();
-            _this._handleTabChange($element);
-          },
-          previous: function () {
-            $prevElement.find('[role="tab"]').focus();
-            _this._handleTabChange($prevElement);
-          },
-          next: function () {
-            $nextElement.find('[role="tab"]').focus();
-            _this._handleTabChange($nextElement);
-          },
-          handled: function () {
-            e.stopPropagation();
-            e.preventDefault();
-          }
-        });
-      });
+      this.isOn = true;
     }
-
     /**
-     * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.
-     * @param {jQuery} $target - Tab to open.
-     * @param {boolean} historyHandled - browser has already handled a history update
-     * @fires Tabs#change
-     * @function
+     * Checks the current breakpoint to the minimum required size.
+     * @private
      */
 
   }, {
-    key: '_handleTabChange',
-    value: function _handleTabChange($target, historyHandled) {
+    key: "_checkMQ",
+    value: function _checkMQ() {
+      var tooSmall = !_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].is(this.options.equalizeOn);
 
-      /**
-       * Check for active class on target. Collapse if exists.
-       */
-      if ($target.hasClass('' + this.options.linkActiveClass)) {
-        if (this.options.activeCollapse) {
-          this._collapseTab($target);
+      if (tooSmall) {
+        if (this.isOn) {
+          this._pauseEvents();
 
-          /**
-           * Fires when the zplugin has successfully collapsed tabs.
-           * @event Tabs#collapse
-           */
-          this.$element.trigger('collapse.zf.tabs', [$target]);
+          this.$watched.css('height', 'auto');
         }
-        return;
-      }
-
-      var $oldTab = this.$element.find('.' + this.options.linkClass + '.' + this.options.linkActiveClass),
-          $tabLink = $target.find('[role="tab"]'),
-          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),
-          $targetContent = this.$tabContent.find('#' + hash);
-
-      //close old tab
-      this._collapseTab($oldTab);
-
-      //open new tab
-      this._openTab($target);
-
-      //either replace or update browser history
-      if (this.options.deepLink && !historyHandled) {
-        var anchor = $target.find('a').attr('href');
-
-        if (this.options.updateHistory) {
-          history.pushState({}, '', anchor);
-        } else {
-          history.replaceState({}, '', anchor);
+      } else {
+        if (!this.isOn) {
+          this._events();
         }
       }
 
-      /**
-       * Fires when the plugin has successfully changed tabs.
-       * @event Tabs#change
-       */
-      this.$element.trigger('change.zf.tabs', [$target, $targetContent]);
-
-      //fire to children a mutation event
-      $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger");
+      return tooSmall;
     }
-
     /**
-     * Opens the tab `$targetContent` defined by `$target`.
-     * @param {jQuery} $target - Tab to Open.
-     * @function
+     * A noop version for the plugin
+     * @private
      */
 
   }, {
-    key: '_openTab',
-    value: function _openTab($target) {
-      var $tabLink = $target.find('[role="tab"]'),
-          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),
-          $targetContent = this.$tabContent.find('#' + hash);
-
-      $target.addClass('' + this.options.linkActiveClass);
-
-      $tabLink.attr({
-        'aria-selected': 'true',
-        'tabindex': '0'
-      });
-
-      $targetContent.addClass('' + this.options.panelActiveClass).removeAttr('aria-hidden');
+    key: "_killswitch",
+    value: function _killswitch() {
+      return;
     }
-
     /**
-     * Collapses `$targetContent` defined by `$target`.
-     * @param {jQuery} $target - Tab to Open.
-     * @function
+     * Calls necessary functions to update Equalizer upon DOM change
+     * @private
      */
 
   }, {
-    key: '_collapseTab',
-    value: function _collapseTab($target) {
-      var $target_anchor = $target.removeClass('' + this.options.linkActiveClass).find('[role="tab"]').attr({
-        'aria-selected': 'false',
-        'tabindex': -1
-      });
+    key: "_reflow",
+    value: function _reflow() {
+      if (!this.options.equalizeOnStack) {
+        if (this._isStacked()) {
+          this.$watched.css('height', 'auto');
+          return false;
+        }
+      }
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + $target_anchor.attr('aria-controls')).removeClass('' + this.options.panelActiveClass).attr({ 'aria-hidden': 'true' });
+      if (this.options.equalizeByRow) {
+        this.getHeightsByRow(this.applyHeightByRow.bind(this));
+      } else {
+        this.getHeights(this.applyHeight.bind(this));
+      }
     }
-
     /**
-     * Public method for selecting a content pane to display.
-     * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.
-     * @param {boolean} historyHandled - browser has already handled a history update
-     * @function
+     * Manually determines if the first 2 elements are *NOT* stacked.
+     * @private
      */
 
   }, {
-    key: 'selectTab',
-    value: function selectTab(elem, historyHandled) {
-      var idStr;
-
-      if (typeof elem === 'object') {
-        idStr = elem[0].id;
-      } else {
-        idStr = elem;
-      }
-
-      if (idStr.indexOf('#') < 0) {
-        idStr = '#' + idStr;
+    key: "_isStacked",
+    value: function _isStacked() {
+      if (!this.$watched[0] || !this.$watched[1]) {
+        return true;
       }
 
-      var $target = this.$tabTitles.find('[href$="' + idStr + '"]').parent('.' + this.options.linkClass);
-
-      this._handleTabChange($target, historyHandled);
+      return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;
     }
-  }, {
-    key: '_setHeight',
-
     /**
-     * Sets the height of each panel to the height of the tallest panel.
-     * If enabled in options, gets called on media query change.
-     * If loading content via external source, can be called directly or with _reflow.
-     * If enabled with `data-match-height="true"`, tabs sets to equal height
-     * @function
-     * @private
+     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
+     * @param {Function} cb - A non-optional callback to return the heights array to.
+     * @returns {Array} heights - An array of heights of children within Equalizer container
      */
-    value: function _setHeight() {
-      var max = 0,
-          _this = this; // Lock down the `this` value for the root tabs object
 
-      this.$tabContent.find('.' + this.options.panelClass).css('height', '').each(function () {
+  }, {
+    key: "getHeights",
+    value: function getHeights(cb) {
+      var heights = [];
 
-        var panel = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            isActive = panel.hasClass('' + _this.options.panelActiveClass); // get the options from the parent instead of trying to get them from the child
+      for (var i = 0, len = this.$watched.length; i < len; i++) {
+        this.$watched[i].style.height = 'auto';
+        heights.push(this.$watched[i].offsetHeight);
+      }
 
-        if (!isActive) {
-          panel.css({ 'visibility': 'hidden', 'display': 'block' });
-        }
+      cb(heights);
+    }
+    /**
+     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
+     * @param {Function} cb - A non-optional callback to return the heights array to.
+     * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
+     */
 
-        var temp = this.getBoundingClientRect().height;
+  }, {
+    key: "getHeightsByRow",
+    value: function getHeightsByRow(cb) {
+      var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0,
+          groups = [],
+          group = 0; //group by Row
 
-        if (!isActive) {
-          panel.css({
-            'visibility': '',
-            'display': ''
-          });
+      groups[group] = [];
+
+      for (var i = 0, len = this.$watched.length; i < len; i++) {
+        this.$watched[i].style.height = 'auto'; //maybe could use this.$watched[i].offsetTop
+
+        var elOffsetTop = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$watched[i]).offset().top;
+
+        if (elOffsetTop != lastElTopOffset) {
+          group++;
+          groups[group] = [];
+          lastElTopOffset = elOffsetTop;
         }
 
-        max = temp > max ? temp : max;
-      }).css('height', max + 'px');
+        groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]);
+      }
+
+      for (var j = 0, ln = groups.length; j < ln; j++) {
+        var heights = jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[j]).map(function () {
+          return this[1];
+        }).get();
+        var max = Math.max.apply(null, heights);
+        groups[j].push(max);
+      }
+
+      cb(groups);
     }
+    /**
+     * Changes the CSS height property of each child in an Equalizer parent to match the tallest
+     * @param {array} heights - An array of heights of children within Equalizer container
+     * @fires Equalizer#preequalized
+     * @fires Equalizer#postequalized
+     */
 
+  }, {
+    key: "applyHeight",
+    value: function applyHeight(heights) {
+      var max = Math.max.apply(null, heights);
+      /**
+       * Fires before the heights are applied
+       * @event Equalizer#preequalized
+       */
+
+      this.$element.trigger('preequalized.zf.equalizer');
+      this.$watched.css('height', max);
+      /**
+       * Fires when the heights have been applied
+       * @event Equalizer#postequalized
+       */
+
+      this.$element.trigger('postequalized.zf.equalizer');
+    }
     /**
-     * Destroys an instance of an tabs.
-     * @fires Tabs#destroyed
+     * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row
+     * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
+     * @fires Equalizer#preequalized
+     * @fires Equalizer#preequalizedrow
+     * @fires Equalizer#postequalizedrow
+     * @fires Equalizer#postequalized
      */
 
   }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$element.find('.' + this.options.linkClass).off('.zf.tabs').hide().end().find('.' + this.options.panelClass).hide();
+    key: "applyHeightByRow",
+    value: function applyHeightByRow(groups) {
+      /**
+       * Fires before the heights are applied
+       */
+      this.$element.trigger('preequalized.zf.equalizer');
 
-      if (this.options.matchHeight) {
-        if (this._setHeightMqHandler != null) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('changed.zf.mediaquery', this._setHeightMqHandler);
+      for (var i = 0, len = groups.length; i < len; i++) {
+        var groupsILength = groups[i].length,
+            max = groups[i][groupsILength - 1];
+
+        if (groupsILength <= 2) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][0][0]).css({
+            'height': 'auto'
+          });
+          continue;
         }
-      }
+        /**
+          * Fires before the heights per row are applied
+          * @event Equalizer#preequalizedrow
+          */
 
-      if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('popstate', this._checkDeepLink);
+
+        this.$element.trigger('preequalizedrow.zf.equalizer');
+
+        for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][j][0]).css({
+            'height': max
+          });
+        }
+        /**
+          * Fires when the heights per row have been applied
+          * @event Equalizer#postequalizedrow
+          */
+
+
+        this.$element.trigger('postequalizedrow.zf.equalizer');
       }
+      /**
+       * Fires when the heights have been applied
+       */
+
+
+      this.$element.trigger('postequalized.zf.equalizer');
+    }
+    /**
+     * Destroys an instance of Equalizer.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this._pauseEvents();
+
+      this.$watched.css('height', 'auto');
     }
   }]);
 
-  return Tabs;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["a" /* Plugin */]);
+  return Equalizer;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__["Plugin"]);
+/**
+ * Default settings for plugin
+ */
 
-Tabs.defaults = {
+
+Equalizer.defaults = {
   /**
-   * Allows the window to scroll to content of pane specified by hash anchor
+   * Enable height equalization when stacked on smaller screens.
    * @option
    * @type {boolean}
    * @default false
    */
-  deepLink: false,
+  equalizeOnStack: false,
 
   /**
-   * Adjust the deep link scroll to make sure the top of the tab panel is visible
+   * Enable height equalization row by row.
    * @option
    * @type {boolean}
    * @default false
    */
-  deepLinkSmudge: false,
+  equalizeByRow: false,
 
   /**
-   * Animation time (ms) for the deep link adjustment
+   * String representing the minimum breakpoint size the plugin should equalize heights on.
    * @option
-   * @type {number}
-   * @default 300
+   * @type {string}
+   * @default ''
    */
-  deepLinkSmudgeDelay: 300,
+  equalizeOn: ''
+};
 
-  /**
-   * Update the browser history with the open tab
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  updateHistory: false,
 
-  /**
-   * Allows the window to scroll to content of active pane on load if set to true.
-   * Not recommended if more than one tab panel per page.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  autoFocus: false,
+/***/ }),
 
-  /**
-   * Allows keyboard input to 'wrap' around the tab links.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  wrapOnKeys: true,
+/***/ "./js/foundation.interchange.js":
+/*!**************************************!*\
+  !*** ./js/foundation.interchange.js ***!
+  \**************************************/
+/*! exports provided: Interchange */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-  /**
-   * Allows the tab content panes to match heights if set to true.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  matchHeight: false,
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Interchange", function() { return Interchange; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
 
-  /**
-   * Allows active tabs to collapse when clicked.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  activeCollapse: false,
 
-  /**
-   * Class applied to `li`'s in tab link list.
-   * @option
-   * @type {string}
-   * @default 'tabs-title'
-   */
-  linkClass: 'tabs-title',
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-  /**
-   * Class applied to the active `li` in tab link list.
-   * @option
-   * @type {string}
-   * @default 'is-active'
-   */
-  linkActiveClass: 'is-active',
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-  /**
-   * Class applied to the content containers.
-   * @option
-   * @type {string}
-   * @default 'tabs-panel'
-   */
-  panelClass: 'tabs-panel',
+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); } }
 
-  /**
-   * Class applied to the active content container.
-   * @option
-   * @type {string}
-   * @default 'is-active'
-   */
-  panelActiveClass: 'is-active'
-};
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-/***/ }),
-/* 18 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Timer; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
-function Timer(elem, options, cb) {
-  var _this = this,
-      duration = options.duration,
-      //options is an object for easily adding features later.
-  nameSpace = Object.keys(elem.data())[0] || 'timer',
-      remain = -1,
-      start,
-      timer;
 
-  this.isPaused = false;
 
-  this.restart = function () {
-    remain = -1;
-    clearTimeout(timer);
-    this.start();
-  };
-
-  this.start = function () {
-    this.isPaused = false;
-    // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
-    clearTimeout(timer);
-    remain = remain <= 0 ? duration : remain;
-    elem.data('paused', false);
-    start = Date.now();
-    timer = setTimeout(function () {
-      if (options.infinite) {
-        _this.restart(); //rerun the timer.
-      }
-      if (cb && typeof cb === 'function') {
-        cb();
-      }
-    }, remain);
-    elem.trigger('timerstart.zf.' + nameSpace);
-  };
-
-  this.pause = function () {
-    this.isPaused = true;
-    //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
-    clearTimeout(timer);
-    elem.data('paused', true);
-    var end = Date.now();
-    remain = remain - (end - start);
-    elem.trigger('timerpaused.zf.' + nameSpace);
-  };
-}
-
-
-
-/***/ }),
-/* 19 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
-
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_core__ = __webpack_require__(21);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_box__ = __webpack_require__(7);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_imageLoader__ = __webpack_require__(8);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__foundation_util_motion__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_8__foundation_util_nest__ = __webpack_require__(9);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_9__foundation_util_timer__ = __webpack_require__(18);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_10__foundation_util_touch__ = __webpack_require__(10);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_11__foundation_util_triggers__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_12__foundation_abide__ = __webpack_require__(20);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_13__foundation_accordion__ = __webpack_require__(11);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_14__foundation_accordionMenu__ = __webpack_require__(12);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_15__foundation_drilldown__ = __webpack_require__(13);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_16__foundation_dropdown__ = __webpack_require__(22);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_17__foundation_dropdownMenu__ = __webpack_require__(14);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_18__foundation_equalizer__ = __webpack_require__(23);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_19__foundation_interchange__ = __webpack_require__(24);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_20__foundation_magellan__ = __webpack_require__(25);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_21__foundation_offcanvas__ = __webpack_require__(26);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_22__foundation_orbit__ = __webpack_require__(27);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_23__foundation_responsiveMenu__ = __webpack_require__(29);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_24__foundation_responsiveToggle__ = __webpack_require__(30);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_25__foundation_reveal__ = __webpack_require__(31);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_26__foundation_slider__ = __webpack_require__(32);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_27__foundation_smoothScroll__ = __webpack_require__(16);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_28__foundation_sticky__ = __webpack_require__(33);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_29__foundation_tabs__ = __webpack_require__(17);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_30__foundation_toggler__ = __webpack_require__(34);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_31__foundation_tooltip__ = __webpack_require__(35);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_32__foundation_responsiveAccordionTabs__ = __webpack_require__(28);
-
-
-
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].addToJquery(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
-
-// Add Foundation Utils to Foundation global namespace for backwards
-// compatibility.
-
-
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].rtl = __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["a" /* rtl */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].GetYoDigits = __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["b" /* GetYoDigits */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].transitionend = __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["c" /* transitionend */];
-
-
-
-
-
-
-
-
-
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].Box = __WEBPACK_IMPORTED_MODULE_3__foundation_util_box__["a" /* Box */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].onImagesLoaded = __WEBPACK_IMPORTED_MODULE_4__foundation_util_imageLoader__["a" /* onImagesLoaded */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].Keyboard = __WEBPACK_IMPORTED_MODULE_5__foundation_util_keyboard__["a" /* Keyboard */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].MediaQuery = __WEBPACK_IMPORTED_MODULE_6__foundation_util_mediaQuery__["a" /* MediaQuery */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].Motion = __WEBPACK_IMPORTED_MODULE_7__foundation_util_motion__["a" /* Motion */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].Move = __WEBPACK_IMPORTED_MODULE_7__foundation_util_motion__["b" /* Move */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].Nest = __WEBPACK_IMPORTED_MODULE_8__foundation_util_nest__["a" /* Nest */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].Timer = __WEBPACK_IMPORTED_MODULE_9__foundation_util_timer__["a" /* Timer */];
-
-// Touch and Triggers previously were almost purely sede effect driven,
-// so no // need to add it to Foundation, just init them.
-
-
-__WEBPACK_IMPORTED_MODULE_10__foundation_util_touch__["a" /* Touch */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+/**
+ * Interchange module.
+ * @module foundation.interchange
+ * @requires foundation.util.mediaQuery
+ */
 
+var Interchange =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Interchange, _Plugin);
 
-__WEBPACK_IMPORTED_MODULE_11__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a, __WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */]);
+  function Interchange() {
+    _classCallCheck(this, Interchange);
 
+    return _possibleConstructorReturn(this, _getPrototypeOf(Interchange).apply(this, arguments));
+  }
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_12__foundation_abide__["a" /* Abide */], 'Abide');
+  _createClass(Interchange, [{
+    key: "_setup",
 
+    /**
+     * Creates a new instance of Interchange.
+     * @class
+     * @name Interchange
+     * @fires Interchange#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Interchange.defaults, options);
+      this.rules = [];
+      this.currentPath = '';
+      this.className = 'Interchange'; // ie9 back compat
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_13__foundation_accordion__["a" /* Accordion */], 'Accordion');
+      this._init();
 
+      this._events();
+    }
+    /**
+     * Initializes the Interchange plugin and calls functions to get interchange functioning on load.
+     * @function
+     * @private
+     */
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_14__foundation_accordionMenu__["a" /* AccordionMenu */], 'AccordionMenu');
+  }, {
+    key: "_init",
+    value: function _init() {
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init();
 
+      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'interchange');
+      this.$element.attr({
+        'data-resize': id,
+        'id': id
+      });
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_15__foundation_drilldown__["a" /* Drilldown */], 'Drilldown');
+      this._addBreakpoints();
 
+      this._generateRules();
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_16__foundation_dropdown__["a" /* Dropdown */], 'Dropdown');
+      this._reflow();
+    }
+    /**
+     * Initializes events for Interchange.
+     * @function
+     * @private
+     */
 
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this2 = this;
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_17__foundation_dropdownMenu__["a" /* DropdownMenu */], 'DropdownMenu');
+      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () {
+        return _this2._reflow();
+      });
+    }
+    /**
+     * Calls necessary functions to update Interchange upon DOM change
+     * @function
+     * @private
+     */
 
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      var match; // Iterate through each rule, but only save the last match
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_18__foundation_equalizer__["a" /* Equalizer */], 'Equalizer');
+      for (var i in this.rules) {
+        if (this.rules.hasOwnProperty(i)) {
+          var rule = this.rules[i];
 
+          if (window.matchMedia(rule.query).matches) {
+            match = rule;
+          }
+        }
+      }
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_19__foundation_interchange__["a" /* Interchange */], 'Interchange');
+      if (match) {
+        this.replace(match.path);
+      }
+    }
+    /**
+     * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.
+     * @function
+     * @private
+     */
 
+  }, {
+    key: "_addBreakpoints",
+    value: function _addBreakpoints() {
+      for (var i in _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].queries) {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].queries.hasOwnProperty(i)) {
+          var query = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].queries[i];
+          Interchange.SPECIAL_QUERIES[query.name] = query.value;
+        }
+      }
+    }
+    /**
+     * Checks the Interchange element for the provided media query + content pairings
+     * @function
+     * @private
+     * @param {Object} element - jQuery object that is an Interchange instance
+     * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys
+     */
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_20__foundation_magellan__["a" /* Magellan */], 'Magellan');
+  }, {
+    key: "_generateRules",
+    value: function _generateRules(element) {
+      var rulesList = [];
+      var rules;
 
+      if (this.options.rules) {
+        rules = this.options.rules;
+      } else {
+        rules = this.$element.data('interchange');
+      }
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_21__foundation_offcanvas__["a" /* OffCanvas */], 'OffCanvas');
+      rules = typeof rules === 'string' ? rules.match(/\[.*?, .*?\]/g) : rules;
 
+      for (var i in rules) {
+        if (rules.hasOwnProperty(i)) {
+          var rule = rules[i].slice(1, -1).split(', ');
+          var path = rule.slice(0, -1).join('');
+          var query = rule[rule.length - 1];
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_22__foundation_orbit__["a" /* Orbit */], 'Orbit');
+          if (Interchange.SPECIAL_QUERIES[query]) {
+            query = Interchange.SPECIAL_QUERIES[query];
+          }
 
+          rulesList.push({
+            path: path,
+            query: query
+          });
+        }
+      }
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_23__foundation_responsiveMenu__["a" /* ResponsiveMenu */], 'ResponsiveMenu');
+      this.rules = rulesList;
+    }
+    /**
+     * Update the `src` property of an image, or change the HTML of a container, to the specified path.
+     * @function
+     * @param {String} path - Path to the image or HTML partial.
+     * @fires Interchange#replaced
+     */
 
+  }, {
+    key: "replace",
+    value: function replace(path) {
+      if (this.currentPath === path) return;
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_24__foundation_responsiveToggle__["a" /* ResponsiveToggle */], 'ResponsiveToggle');
+      var _this = this,
+          trigger = 'replaced.zf.interchange'; // Replacing images
 
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_25__foundation_reveal__["a" /* Reveal */], 'Reveal');
+      if (this.$element[0].nodeName === 'IMG') {
+        this.$element.attr('src', path).on('load', function () {
+          _this.currentPath = path;
+        }).trigger(trigger);
+      } // Replacing background images
+      else if (path.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {
+          path = path.replace(/\(/g, '%28').replace(/\)/g, '%29');
+          this.$element.css({
+            'background-image': 'url(' + path + ')'
+          }).trigger(trigger);
+        } // Replacing HTML
+        else {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.get(path, function (response) {
+              _this.$element.html(response).trigger(trigger);
 
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()(response).foundation();
+              _this.currentPath = path;
+            });
+          }
+      /**
+       * Fires when content in an Interchange element is done being loaded.
+       * @event Interchange#replaced
+       */
+      // this.$element.trigger('replaced.zf.interchange');
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_26__foundation_slider__["a" /* Slider */], 'Slider');
+    }
+    /**
+     * Destroys an instance of interchange.
+     * @function
+     */
 
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('resizeme.zf.trigger');
+    }
+  }]);
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_27__foundation_smoothScroll__["a" /* SmoothScroll */], 'SmoothScroll');
+  return Interchange;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["Plugin"]);
+/**
+ * Default settings for plugin
+ */
 
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_28__foundation_sticky__["a" /* Sticky */], 'Sticky');
+Interchange.defaults = {
+  /**
+   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.
+   * @option
+   * @type {?array}
+   * @default null
+   */
+  rules: null
+};
+Interchange.SPECIAL_QUERIES = {
+  'landscape': 'screen and (orientation: landscape)',
+  'portrait': 'screen and (orientation: portrait)',
+  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'
+};
 
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_29__foundation_tabs__["a" /* Tabs */], 'Tabs');
+/***/ }),
 
+/***/ "./js/foundation.magellan.js":
+/*!***********************************!*\
+  !*** ./js/foundation.magellan.js ***!
+  \***********************************/
+/*! exports provided: Magellan */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_30__foundation_toggler__["a" /* Toggler */], 'Toggler');
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Magellan", function() { return Magellan; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.smoothScroll */ "./js/foundation.smoothScroll.js");
 
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_31__foundation_tooltip__["a" /* Tooltip */], 'Tooltip');
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].plugin(__WEBPACK_IMPORTED_MODULE_32__foundation_responsiveAccordionTabs__["a" /* ResponsiveAccordionTabs */], 'ResponsiveAccordionTabs');
+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); } }
 
-/***/ }),
-/* 20 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Abide; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_plugin__ = __webpack_require__(2);
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
-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 _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-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; }
 
 
 
 
 /**
- * Abide module.
- * @module foundation.abide
+ * Magellan module.
+ * @module foundation.magellan
+ * @requires foundation.smoothScroll
  */
 
-var Abide = function (_Plugin) {
-  _inherits(Abide, _Plugin);
+var Magellan =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Magellan, _Plugin);
 
-  function Abide() {
-    _classCallCheck(this, Abide);
+  function Magellan() {
+    _classCallCheck(this, Magellan);
 
-    return _possibleConstructorReturn(this, (Abide.__proto__ || Object.getPrototypeOf(Abide)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Magellan).apply(this, arguments));
   }
 
-  _createClass(Abide, [{
-    key: '_setup',
+  _createClass(Magellan, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of Abide.
+     * Creates a new instance of Magellan.
      * @class
-     * @name Abide
-     * @fires Abide#init
+     * @name Magellan
+     * @fires Magellan#init
      * @param {Object} element - jQuery object to add the trigger to.
      * @param {Object} options - Overrides to the default plugin settings.
      */
-    value: function _setup(element) {
-      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
-
+    value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(true, {}, Abide.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Magellan.defaults, this.$element.data(), options);
+      this.className = 'Magellan'; // ie9 back compat
 
-      this.className = 'Abide'; // ie9 back compat
       this._init();
-    }
 
+      this.calcPoints();
+    }
     /**
-     * Initializes the Abide plugin and calls functions to get Abide functioning on load.
+     * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      this.$inputs = this.$element.find('input, textarea, select');
+      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'magellan');
+
+      var _this = this;
+
+      this.$targets = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-magellan-target]');
+      this.$links = this.$element.find('a');
+      this.$element.attr({
+        'data-resize': id,
+        'data-scroll': id,
+        'id': id
+      });
+      this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
+      this.scrollPos = parseInt(window.pageYOffset, 10);
 
       this._events();
     }
-
     /**
-     * Initializes events for Abide.
-     * @private
+     * Calculates an array of pixel values that are the demarcation lines between locations on the page.
+     * Can be invoked if new elements are added or the size of a location changes.
+     * @function
      */
 
   }, {
-    key: '_events',
-    value: function _events() {
-      var _this3 = this;
-
-      this.$element.off('.abide').on('reset.zf.abide', function () {
-        _this3.resetForm();
-      }).on('submit.zf.abide', function () {
-        return _this3.validateForm();
-      });
-
-      if (this.options.validateOn === 'fieldChange') {
-        this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) {
-          _this3.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target));
-        });
-      }
+    key: "calcPoints",
+    value: function calcPoints() {
+      var _this = this,
+          body = document.body,
+          html = document.documentElement;
 
-      if (this.options.liveValidate) {
-        this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) {
-          _this3.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target));
-        });
-      }
+      this.points = [];
+      this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));
+      this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));
+      this.$targets.each(function () {
+        var $tar = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            pt = Math.round($tar.offset().top - _this.options.threshold);
+        $tar.targetPoint = pt;
 
-      if (this.options.validateOnBlur) {
-        this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) {
-          _this3.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target));
-        });
-      }
+        _this.points.push(pt);
+      });
     }
-
     /**
-     * Calls necessary functions to update Abide upon DOM change
+     * Initializes events for Magellan.
      * @private
      */
 
   }, {
-    key: '_reflow',
-    value: function _reflow() {
-      this._init();
-    }
-
-    /**
-     * Checks whether or not a form element has the required attribute and if it's checked or not
-     * @param {Object} element - jQuery object to check for required attribute
-     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
-     */
+    key: "_events",
+    value: function _events() {
+      var _this = this,
+          $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body'),
+          opts = {
+        duration: _this.options.animationDuration,
+        easing: _this.options.animationEasing
+      };
 
-  }, {
-    key: 'requiredCheck',
-    value: function requiredCheck($el) {
-      if (!$el.attr('required')) return true;
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', function () {
+        if (_this.options.deepLinking) {
+          if (location.hash) {
+            _this.scrollToLoc(location.hash);
+          }
+        }
 
-      var isGood = true;
+        _this.calcPoints();
 
-      switch ($el[0].type) {
-        case 'checkbox':
-          isGood = $el[0].checked;
-          break;
+        _this._updateActive();
+      });
+      _this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+        _this.$element.on({
+          'resizeme.zf.trigger': _this.reflow.bind(_this),
+          'scrollme.zf.trigger': _this._updateActive.bind(_this)
+        }).on('click.zf.magellan', 'a[href^="#"]', function (e) {
+          e.preventDefault();
+          var arrival = this.getAttribute('href');
 
-        case 'select':
-        case 'select-one':
-        case 'select-multiple':
-          var opt = $el.find('option:selected');
-          if (!opt.length || !opt.val()) isGood = false;
-          break;
+          _this.scrollToLoc(arrival);
+        });
+      });
 
-        default:
-          if (!$el.val() || !$el.val().length) isGood = false;
-      }
+      this._deepLinkScroll = function (e) {
+        if (_this.options.deepLinking) {
+          _this.scrollToLoc(window.location.hash);
+        }
+      };
 
-      return isGood;
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._deepLinkScroll);
     }
-
     /**
-     * Get:
-     * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:
-     *   1. The element's direct sibling('s).
-     *   2. The element's parent's children.
-     * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.
-     *
-     * This allows for multiple form errors per input, though if none are found, no form errors will be shown.
-     *
-     * @param {Object} $el - jQuery object to use as reference to find the form error selector.
-     * @returns {Object} jQuery object with the selector.
+     * Function to scroll to a given location on the page.
+     * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'
+     * @function
      */
 
   }, {
-    key: 'findFormError',
-    value: function findFormError($el) {
-      var id = $el[0].id;
-      var $error = $el.siblings(this.options.formErrorSelector);
-
-      if (!$error.length) {
-        $error = $el.parent().find(this.options.formErrorSelector);
-      }
+    key: "scrollToLoc",
+    value: function scrollToLoc(loc) {
+      this._inTransition = true;
 
-      $error = $error.add(this.$element.find('[data-form-error-for="' + id + '"]'));
+      var _this = this;
 
-      return $error;
+      var options = {
+        animationEasing: this.options.animationEasing,
+        animationDuration: this.options.animationDuration,
+        threshold: this.options.threshold,
+        offset: this.options.offset
+      };
+      _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_3__["SmoothScroll"].scrollToLoc(loc, options, function () {
+        _this._inTransition = false;
+      });
     }
-
     /**
-     * Get the first element in this order:
-     * 2. The <label> with the attribute `[for="someInputId"]`
-     * 3. The `.closest()` <label>
-     *
-     * @param {Object} $el - jQuery object to check for required attribute
-     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     * Calls necessary functions to update Magellan upon DOM change
+     * @function
      */
 
   }, {
-    key: 'findLabel',
-    value: function findLabel($el) {
-      var id = $el[0].id;
-      var $label = this.$element.find('label[for="' + id + '"]');
-
-      if (!$label.length) {
-        return $el.closest('label');
-      }
+    key: "reflow",
+    value: function reflow() {
+      this.calcPoints();
 
-      return $label;
+      this._updateActive();
     }
-
     /**
-     * Get the set of labels associated with a set of radio els in this order
-     * 2. The <label> with the attribute `[for="someInputId"]`
-     * 3. The `.closest()` <label>
-     *
-     * @param {Object} $el - jQuery object to check for required attribute
-     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty
+     * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.
+     * @private
+     * @function
+     * @fires Magellan#update
      */
 
   }, {
-    key: 'findRadioLabels',
-    value: function findRadioLabels($els) {
-      var _this4 = this;
-
-      var labels = $els.map(function (i, el) {
-        var id = el.id;
-        var $label = _this4.$element.find('label[for="' + id + '"]');
+    key: "_updateActive",
+    value: function _updateActive()
+    /*evt, elem, scrollPos*/
+    {
+      var _this2 = this;
 
-        if (!$label.length) {
-          $label = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el).closest('label');
-        }
-        return $label[0];
-      });
+      if (this._inTransition) return;
+      var newScrollPos = parseInt(window.pageYOffset, 10);
+      var isScrollingUp = this.scrollPos > newScrollPos;
+      this.scrollPos = newScrollPos;
+      var activeIdx; // Before the first point: no link
 
-      return __WEBPACK_IMPORTED_MODULE_0_jquery___default()(labels);
-    }
-
-    /**
-     * Adds the CSS error class as specified by the Abide settings to the label, input, and the form
-     * @param {Object} $el - jQuery object to add the class to
-     */
+      if (newScrollPos < this.points[0]) {}
+      /* do nothing */
+      // At the bottom of the page: last link
+      else if (newScrollPos + this.winHeight === this.docHeight) {
+          activeIdx = this.points.length - 1;
+        } // Otherwhise, use the last visible link
+        else {
+            var visibleLinks = this.points.filter(function (p, i) {
+              return p - _this2.options.offset - (isScrollingUp ? _this2.options.threshold : 0) <= newScrollPos;
+            });
+            activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;
+          } // Get the new active link
 
-  }, {
-    key: 'addErrorClasses',
-    value: function addErrorClasses($el) {
-      var $label = this.findLabel($el);
-      var $formError = this.findFormError($el);
 
-      if ($label.length) {
-        $label.addClass(this.options.labelErrorClass);
-      }
+      var $oldActive = this.$active;
+      var activeHash = '';
 
-      if ($formError.length) {
-        $formError.addClass(this.options.formErrorClass);
+      if (typeof activeIdx !== 'undefined') {
+        this.$active = this.$links.filter('[href="#' + this.$targets.eq(activeIdx).data('magellan-target') + '"]');
+        if (this.$active.length) activeHash = this.$active[0].getAttribute('href');
+      } else {
+        this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
       }
 
-      $el.addClass(this.options.inputErrorClass).attr('data-invalid', '');
-    }
+      var isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);
+      var isNewHash = activeHash !== window.location.hash; // Update the active link element
 
-    /**
-     * Remove CSS error classes etc from an entire radio button group
-     * @param {String} groupName - A string that specifies the name of a radio button group
-     *
-     */
+      if (isNewActive) {
+        $oldActive.removeClass(this.options.activeClass);
+        this.$active.addClass(this.options.activeClass);
+      } // Update the hash (it may have changed with the same active link)
 
-  }, {
-    key: 'removeRadioErrorClasses',
-    value: function removeRadioErrorClasses(groupName) {
-      var $els = this.$element.find(':radio[name="' + groupName + '"]');
-      var $labels = this.findRadioLabels($els);
-      var $formErrors = this.findFormError($els);
 
-      if ($labels.length) {
-        $labels.removeClass(this.options.labelErrorClass);
+      if (this.options.deepLinking && isNewHash) {
+        if (window.history.pushState) {
+          // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384
+          var url = activeHash ? activeHash : window.location.pathname + window.location.search;
+          window.history.pushState(null, null, url);
+        } else {
+          window.location.hash = activeHash;
+        }
       }
 
-      if ($formErrors.length) {
-        $formErrors.removeClass(this.options.formErrorClass);
+      if (isNewActive) {
+        /**
+         * Fires when magellan is finished updating to the new active element.
+         * @event Magellan#update
+         */
+        this.$element.trigger('update.zf.magellan', [this.$active]);
       }
-
-      $els.removeClass(this.options.inputErrorClass).removeAttr('data-invalid');
     }
-
     /**
-     * Removes CSS error class as specified by the Abide settings from the label, input, and the form
-     * @param {Object} $el - jQuery object to remove the class from
+     * Destroys an instance of Magellan and resets the url of the window.
+     * @function
      */
 
   }, {
-    key: 'removeErrorClasses',
-    value: function removeErrorClasses($el) {
-      // radios need to clear all of the els
-      if ($el[0].type == 'radio') {
-        return this.removeRadioErrorClasses($el.attr('name'));
-      }
-
-      var $label = this.findLabel($el);
-      var $formError = this.findFormError($el);
-
-      if ($label.length) {
-        $label.removeClass(this.options.labelErrorClass);
-      }
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.trigger .zf.magellan').find(".".concat(this.options.activeClass)).removeClass(this.options.activeClass);
 
-      if ($formError.length) {
-        $formError.removeClass(this.options.formErrorClass);
+      if (this.options.deepLinking) {
+        var hash = this.$active[0].getAttribute('href');
+        window.location.hash.replace(hash, '');
       }
 
-      $el.removeClass(this.options.inputErrorClass).removeAttr('data-invalid');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._deepLinkScroll);
+      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
     }
+  }]);
 
-    /**
-     * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.
-     * Ignores inputs with data-abide-ignore, type="hidden" or disabled attributes set
-     * @fires Abide#invalid
-     * @fires Abide#valid
-     * @param {Object} element - jQuery object to validate, should be an HTML input
-     * @returns {Boolean} goodToGo - If the input is valid or not.
-     */
-
-  }, {
-    key: 'validateInput',
-    value: function validateInput($el) {
-      var clearRequire = this.requiredCheck($el),
-          validated = false,
-          customValidator = true,
-          validator = $el.attr('data-validator'),
-          equalTo = true;
-
-      // don't validate ignored inputs or hidden inputs or disabled inputs
-      if ($el.is('[data-abide-ignore]') || $el.is('[type="hidden"]') || $el.is('[disabled]')) {
-        return true;
-      }
+  return Magellan;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["Plugin"]);
+/**
+ * Default settings for plugin
+ */
 
-      switch ($el[0].type) {
-        case 'radio':
-          validated = this.validateRadio($el.attr('name'));
-          break;
 
-        case 'checkbox':
-          validated = clearRequire;
-          break;
+Magellan.defaults = {
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
 
-        case 'select':
-        case 'select-one':
-        case 'select-multiple':
-          validated = clearRequire;
-          break;
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
 
-        default:
-          validated = this.validateText($el);
-      }
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
 
-      if (validator) {
-        customValidator = this.matchValidation($el, validator, $el.attr('required'));
-      }
+  /**
+   * Class applied to the active locations link on the magellan container.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  activeClass: 'is-active',
 
-      if ($el.attr('data-equalto')) {
-        equalTo = this.options.validators.equalTo($el);
-      }
+  /**
+   * Allows the script to manipulate the url of the current page, and if supported, alter the history.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinking: false,
 
-      var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;
-      var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
+};
 
-      if (goodToGo) {
-        // Re-validate inputs that depend on this one with equalto
-        var dependentElements = this.$element.find('[data-equalto="' + $el.attr('id') + '"]');
-        if (dependentElements.length) {
-          var _this = this;
-          dependentElements.each(function () {
-            if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).val()) {
-              _this.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
-            }
-          });
-        }
-      }
 
-      this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);
+/***/ }),
 
-      /**
-       * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`
-       * Trigger includes the DOM element of the input.
-       * @event Abide#valid
-       * @event Abide#invalid
-       */
-      $el.trigger(message, [$el]);
+/***/ "./js/foundation.offcanvas.js":
+/*!************************************!*\
+  !*** ./js/foundation.offcanvas.js ***!
+  \************************************/
+/*! exports provided: OffCanvas */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-      return goodToGo;
-    }
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OffCanvas", function() { return OffCanvas; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
 
-    /**
-     * Goes through a form and if there are any invalid inputs, it will display the form error element
-     * @returns {Boolean} noError - true if no errors were detected...
-     * @fires Abide#formvalid
-     * @fires Abide#forminvalid
-     */
 
-  }, {
-    key: 'validateForm',
-    value: function validateForm() {
-      var acc = [];
-      var _this = this;
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-      this.$inputs.each(function () {
-        acc.push(_this.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)));
-      });
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-      var noError = acc.indexOf(false) === -1;
+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); } }
 
-      this.$element.find('[data-abide-error]').css('display', noError ? 'none' : 'block');
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-      /**
-       * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.
-       * Trigger includes the element of the form.
-       * @event Abide#formvalid
-       * @event Abide#forminvalid
-       */
-      this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
-      return noError;
-    }
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-    /**
-     * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.
-     * @param {Object} $el - jQuery object to validate, should be a text input HTML element
-     * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns
-     * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified
-     */
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-  }, {
-    key: 'validateText',
-    value: function validateText($el, pattern) {
-      // A pattern can be passed to this function, or it will be infered from the input's "pattern" attribute, or it's "type" attribute
-      pattern = pattern || $el.attr('pattern') || $el.attr('type');
-      var inputText = $el.val();
-      var valid = false;
 
-      if (inputText.length) {
-        // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp
-        if (this.options.patterns.hasOwnProperty(pattern)) {
-          valid = this.options.patterns[pattern].test(inputText);
-        }
-        // If the pattern name isn't also the type attribute of the field, then test it as a regexp
-        else if (pattern !== $el.attr('type')) {
-            valid = new RegExp(pattern).test(inputText);
-          } else {
-            valid = true;
-          }
-      }
-      // An empty field is valid if it's not required
-      else if (!$el.prop('required')) {
-          valid = true;
-        }
 
-      return valid;
-    }
+
+
+
+
+/**
+ * OffCanvas module.
+ * @module foundation.offcanvas
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.triggers
+ */
+
+var OffCanvas =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(OffCanvas, _Plugin);
+
+  function OffCanvas() {
+    _classCallCheck(this, OffCanvas);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(OffCanvas).apply(this, arguments));
+  }
+
+  _createClass(OffCanvas, [{
+    key: "_setup",
 
     /**
-     * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.
-     * @param {String} groupName - A string that specifies the name of a radio button group
-     * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)
+     * Creates a new instance of an off-canvas wrapper.
+     * @class
+     * @name OffCanvas
+     * @fires OffCanvas#init
+     * @param {Object} element - jQuery object to initialize.
+     * @param {Object} options - Overrides to the default plugin settings.
      */
+    value: function _setup(element, options) {
+      var _this2 = this;
 
-  }, {
-    key: 'validateRadio',
-    value: function validateRadio(groupName) {
-      // If at least one radio in the group has the `required` attribute, the group is considered required
-      // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice
-      var $group = this.$element.find(':radio[name="' + groupName + '"]');
-      var valid = false,
-          required = false;
+      this.className = 'OffCanvas'; // ie9 back compat
 
-      // For the group to be required, at least one radio needs to be required
-      $group.each(function (i, e) {
-        if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e).attr('required')) {
-          required = true;
-        }
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, OffCanvas.defaults, this.$element.data(), options);
+      this.contentClasses = {
+        base: [],
+        reveal: []
+      };
+      this.$lastTrigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
+      this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
+      this.position = 'left';
+      this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
+      this.nested = !!this.options.nested; // Defines the CSS transition/position classes of the off-canvas content container.
+
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(['push', 'overlap']).each(function (index, val) {
+        _this2.contentClasses.base.push('has-transition-' + val);
       });
-      if (!required) valid = true;
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(['left', 'right', 'top', 'bottom']).each(function (index, val) {
+        _this2.contentClasses.base.push('has-position-' + val);
 
-      if (!valid) {
-        // For the group to be valid, at least one radio needs to be checked
-        $group.each(function (i, e) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e).prop('checked')) {
-            valid = true;
-          }
-        });
-      };
+        _this2.contentClasses.reveal.push('has-reveal-' + val);
+      }); // Triggers init is idempotent, just need to make sure it is initialized
 
-      return valid;
-    }
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
-    /**
-     * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator="foo bar baz"` in a space separated listed.
-     * @param {Object} $el - jQuery input element.
-     * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.
-     * @param {Boolean} required - self explanatory?
-     * @returns {Boolean} - true if validations passed.
-     */
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"]._init();
 
-  }, {
-    key: 'matchValidation',
-    value: function matchValidation($el, validators, required) {
-      var _this5 = this;
+      this._init();
 
-      required = required ? true : false;
+      this._events();
 
-      var clear = validators.split(' ').map(function (v) {
-        return _this5.options.validators[v]($el, required, $el.parent());
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('OffCanvas', {
+        'ESCAPE': 'close'
       });
-      return clear.indexOf(false) === -1;
     }
-
     /**
-     * Resets form inputs and styles
-     * @fires Abide#formreset
+     * Initializes the off-canvas wrapper by adding the exit overlay (if needed).
+     * @function
+     * @private
      */
 
   }, {
-    key: 'resetForm',
-    value: function resetForm() {
-      var $form = this.$element,
-          opts = this.options;
+    key: "_init",
+    value: function _init() {
+      var id = this.$element.attr('id');
+      this.$element.attr('aria-hidden', 'true'); // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('.' + opts.labelErrorClass, $form).not('small').removeClass(opts.labelErrorClass);
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('.' + opts.inputErrorClass, $form).not('small').removeClass(opts.inputErrorClass);
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(opts.formErrorSelector + '.' + opts.formErrorClass).removeClass(opts.formErrorClass);
-      $form.find('[data-abide-error]').css('display', 'none');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').removeAttr('data-invalid');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).removeAttr('data-invalid');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).removeAttr('data-invalid');
-      /**
-       * Fires when the form has been reset.
-       * @event Abide#formreset
-       */
-      $form.trigger('formreset.zf.abide', [$form]);
-    }
+      if (this.options.contentId) {
+        this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + this.options.contentId);
+      } else if (this.$element.siblings('[data-off-canvas-content]').length) {
+        this.$content = this.$element.siblings('[data-off-canvas-content]').first();
+      } else {
+        this.$content = this.$element.closest('[data-off-canvas-content]').first();
+      }
 
-    /**
-     * Destroys an instance of Abide.
-     * Removes error styles and classes from elements, without resetting their values.
-     */
+      if (!this.options.contentId) {
+        // Assume that the off-canvas element is nested if it isn't a sibling of the content
+        this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;
+      } else if (this.options.contentId && this.options.nested === null) {
+        // Warning if using content ID without setting the nested option
+        // Once the element is nested it is required to work properly in this case
+        console.warn('Remember to use the nested option if using the content ID option!');
+      }
 
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      var _this = this;
-      this.$element.off('.abide').find('[data-abide-error]').css('display', 'none');
+      if (this.nested === true) {
+        // Force transition overlap if nested
+        this.options.transition = 'overlap'; // Remove appropriate classes if already assigned in markup
 
-      this.$inputs.off('.abide').each(function () {
-        _this.removeErrorClasses(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
-      });
-    }
-  }]);
+        this.$element.removeClass('is-transition-push');
+      }
 
-  return Abide;
-}(__WEBPACK_IMPORTED_MODULE_1__foundation_plugin__["a" /* Plugin */]);
+      this.$element.addClass("is-transition-".concat(this.options.transition, " is-closed")); // Find triggers that affect this element and add aria-expanded to them
 
-/**
- * Default settings for plugin
- */
+      this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id); // Get position by checking for related CSS class
 
+      this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position; // Add an overlay over the content if necessary
 
-Abide.defaults = {
-  /**
-   * The default event to validate inputs. Checkboxes and radios validate immediately.
-   * Remove or change this value for manual validation.
-   * @option
-   * @type {?string}
-   * @default 'fieldChange'
-   */
-  validateOn: 'fieldChange',
-
-  /**
-   * Class to be applied to input labels on failed validation.
-   * @option
-   * @type {string}
-   * @default 'is-invalid-label'
-   */
-  labelErrorClass: 'is-invalid-label',
+      if (this.options.contentOverlay === true) {
+        var overlay = document.createElement('div');
+        var overlayPosition = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';
+        overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);
+        this.$overlay = jquery__WEBPACK_IMPORTED_MODULE_0___default()(overlay);
 
-  /**
-   * Class to be applied to inputs on failed validation.
-   * @option
-   * @type {string}
-   * @default 'is-invalid-input'
-   */
-  inputErrorClass: 'is-invalid-input',
+        if (overlayPosition === 'is-overlay-fixed') {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$overlay).insertAfter(this.$element);
+        } else {
+          this.$content.append(this.$overlay);
+        }
+      } // Get the revealOn option from the class.
 
-  /**
-   * Class selector to use to target Form Errors for show/hide.
-   * @option
-   * @type {string}
-   * @default '.form-error'
-   */
-  formErrorSelector: '.form-error',
 
-  /**
-   * Class added to Form Errors on failed validation.
-   * @option
-   * @type {string}
-   * @default 'is-visible'
-   */
-  formErrorClass: 'is-visible',
+      var revealOnRegExp = new RegExp(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["RegExpEscape"])(this.options.revealClass) + '([^\\s]+)', 'g');
+      var revealOnClass = revealOnRegExp.exec(this.$element[0].className);
 
-  /**
-   * Set to true to validate text inputs on any value change.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  liveValidate: false,
+      if (revealOnClass) {
+        this.options.isRevealed = true;
+        this.options.revealOn = this.options.revealOn || revealOnClass[1];
+      } // Ensure the `reveal-on-*` class is set.
 
-  /**
-   * Set to true to validate inputs on blur.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  validateOnBlur: false,
 
-  patterns: {
-    alpha: /^[a-zA-Z]+$/,
-    alpha_numeric: /^[a-zA-Z0-9]+$/,
-    integer: /^[-+]?\d+$/,
-    number: /^[-+]?\d*(?:[\.\,]\d+)?$/,
+      if (this.options.isRevealed === true && this.options.revealOn) {
+        this.$element.first().addClass("".concat(this.options.revealClass).concat(this.options.revealOn));
 
-    // amex, visa, diners
-    card: /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,
-    cvv: /^([0-9]){3,4}$/,
+        this._setMQChecker();
+      }
 
-    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address
-    email: /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,
+      if (this.options.transitionTime) {
+        this.$element.css('transition-duration', this.options.transitionTime);
+      } // Initally remove all transition/position CSS classes from off-canvas content container.
 
-    url: /^(https?|ftp|file|ssh):\/\/(((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/,
-    // abc.de
-    domain: /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,
 
-    datetime: /^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,
-    // YYYY-MM-DD
-    date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,
-    // HH:MM:SS
-    time: /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,
-    dateISO: /^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,
-    // MM/DD/YYYY
-    month_day_year: /^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,
-    // DD/MM/YYYY
-    day_month_year: /^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,
+      this._removeContentClasses();
+    }
+    /**
+     * Adds event handlers to the off-canvas wrapper and the exit overlay.
+     * @function
+     * @private
+     */
 
-    // #FFF or #FFFFFF
-    color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,
+  }, {
+    key: "_events",
+    value: function _events() {
+      this.$element.off('.zf.trigger .zf.offcanvas').on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': this.close.bind(this),
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'keydown.zf.offcanvas': this._handleKeyboard.bind(this)
+      });
 
-    // Domain || URL
-    website: {
-      test: function (text) {
-        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);
+      if (this.options.closeOnClick === true) {
+        var $target = this.options.contentOverlay ? this.$overlay : this.$content;
+        $target.on({
+          'click.zf.offcanvas': this.close.bind(this)
+        });
       }
     }
-  },
-
-  /**
-   * Optional validation functions to be used. `equalTo` being the only default included function.
-   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:
-   * el : The jQuery element to validate.
-   * required : Boolean value of the required attribute be present or not.
-   * parent : The direct parent of the input.
-   * @option
-   */
-  validators: {
-    equalTo: function (el, required, parent) {
-      return __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + el.attr('data-equalto')).val() === el.val();
-    }
-  }
-};
-
+    /**
+     * Applies event listener for elements that will reveal at certain breakpoints.
+     * @private
+     */
 
+  }, {
+    key: "_setMQChecker",
+    value: function _setMQChecker() {
+      var _this = this;
 
-/***/ }),
-/* 21 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+      this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"].atLeast(_this.options.revealOn)) {
+          _this.reveal(true);
+        }
+      });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"].atLeast(_this.options.revealOn)) {
+          _this.reveal(true);
+        } else {
+          _this.reveal(false);
+        }
+      });
+    }
+    /**
+     * Removes the CSS transition/position classes of the off-canvas content container.
+     * Removing the classes is important when another off-canvas gets opened that uses the same content container.
+     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
+     * @private
+     */
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Foundation; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(4);
+  }, {
+    key: "_removeContentClasses",
+    value: function _removeContentClasses(hasReveal) {
+      if (typeof hasReveal !== 'boolean') {
+        this.$content.removeClass(this.contentClasses.base.join(' '));
+      } else if (hasReveal === false) {
+        this.$content.removeClass("has-reveal-".concat(this.position));
+      }
+    }
+    /**
+     * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.
+     * Beforehand any transition/position class gets removed.
+     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
+     * @private
+     */
 
+  }, {
+    key: "_addContentClasses",
+    value: function _addContentClasses(hasReveal) {
+      this._removeContentClasses(hasReveal);
 
+      if (typeof hasReveal !== 'boolean') {
+        this.$content.addClass("has-transition-".concat(this.options.transition, " has-position-").concat(this.position));
+      } else if (hasReveal === true) {
+        this.$content.addClass("has-reveal-".concat(this.position));
+      }
+    }
+    /**
+     * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.
+     * @param {Boolean} isRevealed - true if element should be revealed.
+     * @function
+     */
 
+  }, {
+    key: "reveal",
+    value: function reveal(isRevealed) {
+      if (isRevealed) {
+        this.close();
+        this.isRevealed = true;
+        this.$element.attr('aria-hidden', 'false');
+        this.$element.off('open.zf.trigger toggle.zf.trigger');
+        this.$element.removeClass('is-closed');
+      } else {
+        this.isRevealed = false;
+        this.$element.attr('aria-hidden', 'true');
+        this.$element.off('open.zf.trigger toggle.zf.trigger').on({
+          'open.zf.trigger': this.open.bind(this),
+          'toggle.zf.trigger': this.toggle.bind(this)
+        });
+        this.$element.addClass('is-closed');
+      }
 
+      this._addContentClasses(isRevealed);
+    }
+    /**
+     * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.
+     * @private
+     */
 
+  }, {
+    key: "_stopScrolling",
+    value: function _stopScrolling(event) {
+      return false;
+    } // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios
+    // Only really works for y, not sure how to extend to x or if we need to.
 
-var FOUNDATION_VERSION = '6.4.3';
+  }, {
+    key: "_recordScrollable",
+    value: function _recordScrollable(event) {
+      var elem = this; // called from event handler context with this as elem
+      // If the element is scrollable (content overflows), then...
 
-// Global Foundation object
-// This is attached to the window, or used as a module for AMD/Browserify
-var Foundation = {
-  version: FOUNDATION_VERSION,
+      if (elem.scrollHeight !== elem.clientHeight) {
+        // If we're at the top, scroll down one pixel to allow scrolling up
+        if (elem.scrollTop === 0) {
+          elem.scrollTop = 1;
+        } // If we're at the bottom, scroll up one pixel to allow scrolling down
 
-  /**
-   * Stores initialized plugins.
-   */
-  _plugins: {},
 
-  /**
-   * Stores generated unique ids for plugin instances
-   */
-  _uuids: [],
+        if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {
+          elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;
+        }
+      }
 
-  /**
-   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.
-   * @param {Object} plugin - The constructor of the plugin.
-   */
-  plugin: function (plugin, name) {
-    // Object key to use when adding to global Foundation object
-    // Examples: Foundation.Reveal, Foundation.OffCanvas
-    var className = name || functionName(plugin);
-    // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin
-    // Examples: data-reveal, data-off-canvas
-    var attrName = hyphenate(className);
+      elem.allowUp = elem.scrollTop > 0;
+      elem.allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight;
+      elem.lastY = event.originalEvent.pageY;
+    }
+  }, {
+    key: "_stopScrollPropagation",
+    value: function _stopScrollPropagation(event) {
+      var elem = this; // called from event handler context with this as elem
 
-    // Add to the Foundation object and the plugins list (for reflowing)
-    this._plugins[attrName] = this[className] = plugin;
-  },
-  /**
-   * @function
-   * Populates the _uuids array with pointers to each individual plugin instance.
-   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.
-   * Also fires the initialization event for each plugin, consolidating repetitive code.
-   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
-   * @param {String} name - the name of the plugin, passed as a camelCased string.
-   * @fires Plugin#init
-   */
-  registerPlugin: function (plugin, name) {
-    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();
-    plugin.uuid = __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["b" /* GetYoDigits */])(6, pluginName);
+      var up = event.pageY < elem.lastY;
+      var down = !up;
+      elem.lastY = event.pageY;
 
-    if (!plugin.$element.attr('data-' + pluginName)) {
-      plugin.$element.attr('data-' + pluginName, plugin.uuid);
-    }
-    if (!plugin.$element.data('zfPlugin')) {
-      plugin.$element.data('zfPlugin', plugin);
+      if (up && elem.allowUp || down && elem.allowDown) {
+        event.stopPropagation();
+      } else {
+        event.preventDefault();
+      }
     }
     /**
-     * Fires when the plugin has initialized.
-     * @event Plugin#init
-     */
-    plugin.$element.trigger('init.zf.' + pluginName);
-
-    this._uuids.push(plugin.uuid);
-
-    return;
-  },
-  /**
-   * @function
-   * Removes the plugins uuid from the _uuids array.
-   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.
-   * Also fires the destroyed event for the plugin, consolidating repetitive code.
-   * @param {Object} plugin - an instance of a plugin, usually `this` in context.
-   * @fires Plugin#destroyed
-   */
-  unregisterPlugin: function (plugin) {
-    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));
-
-    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);
-    plugin.$element.removeAttr('data-' + pluginName).removeData('zfPlugin')
-    /**
-     * Fires when the plugin has been destroyed.
-     * @event Plugin#destroyed
+     * Opens the off-canvas menu.
+     * @function
+     * @param {Object} event - Event object passed from listener.
+     * @param {jQuery} trigger - element that triggered the off-canvas to open.
+     * @fires Offcanvas#opened
+     * @todo also trigger 'open' event?
      */
-    .trigger('destroyed.zf.' + pluginName);
-    for (var prop in plugin) {
-      plugin[prop] = null; //clean up script to prep for garbage collection.
-    }
-    return;
-  },
 
-  /**
-   * @function
-   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.
-   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`
-   * @default If no argument is passed, reflow all currently active plugins.
-   */
-  reInit: function (plugins) {
-    var isJQ = plugins instanceof __WEBPACK_IMPORTED_MODULE_0_jquery___default.a;
-    try {
-      if (isJQ) {
-        plugins.each(function () {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('zfPlugin')._init();
-        });
-      } else {
-        var type = typeof plugins,
-            _this = this,
-            fns = {
-          'object': function (plgs) {
-            plgs.forEach(function (p) {
-              p = hyphenate(p);
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + p + ']').foundation('_init');
-            });
-          },
-          'string': function () {
-            plugins = hyphenate(plugins);
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugins + ']').foundation('_init');
-          },
-          'undefined': function () {
-            this['object'](Object.keys(_this._plugins));
-          }
-        };
-        fns[type](plugins);
+  }, {
+    key: "open",
+    value: function open(event, trigger) {
+      if (this.$element.hasClass('is-open') || this.isRevealed) {
+        return;
       }
-    } catch (err) {
-      console.error(err);
-    } finally {
-      return plugins;
-    }
-  },
 
-  /**
-   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.
-   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.
-   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.
-   */
-  reflow: function (elem, plugins) {
+      var _this = this;
 
-    // If plugins is undefined, just grab everything
-    if (typeof plugins === 'undefined') {
-      plugins = Object.keys(this._plugins);
-    }
-    // If plugins is a string, convert it to an array with one item
-    else if (typeof plugins === 'string') {
-        plugins = [plugins];
+      if (trigger) {
+        this.$lastTrigger = trigger;
       }
 
-    var _this = this;
-
-    // Iterate through each plugin
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(plugins, function (i, name) {
-      // Get the current plugin
-      var plugin = _this._plugins[name];
+      if (this.options.forceTo === 'top') {
+        window.scrollTo(0, 0);
+      } else if (this.options.forceTo === 'bottom') {
+        window.scrollTo(0, document.body.scrollHeight);
+      }
 
-      // Localize the search to all elements inside elem, as well as elem itself, unless elem === document
-      var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(elem).find('[data-' + name + ']').addBack('[data-' + name + ']');
+      if (this.options.transitionTime && this.options.transition !== 'overlap') {
+        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);
+      } else {
+        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');
+      }
 
-      // For each plugin found, initialize it
-      $elem.each(function () {
-        var $el = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            opts = {};
-        // Don't double-dip on plugins
-        if ($el.data('zfPlugin')) {
-          console.warn("Tried to initialize " + name + " on an element that already has a Foundation plugin.");
-          return;
-        }
+      this.$element.addClass('is-open').removeClass('is-closed');
+      this.$triggers.attr('aria-expanded', 'true');
+      this.$element.attr('aria-hidden', 'false');
+      this.$content.addClass('is-open-' + this.position); // If `contentScroll` is set to false, add class and disable scrolling on touch devices.
 
-        if ($el.attr('data-options')) {
-          var thing = $el.attr('data-options').split(';').forEach(function (e, i) {
-            var opt = e.split(':').map(function (el) {
-              return el.trim();
-            });
-            if (opt[0]) opts[opt[0]] = parseValue(opt[1]);
-          });
-        }
-        try {
-          $el.data('zfPlugin', new plugin(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), opts));
-        } catch (er) {
-          console.error(er);
-        } finally {
-          return;
-        }
-      });
-    });
-  },
-  getFnName: functionName,
+      if (this.options.contentScroll === false) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);
+        this.$element.on('touchstart', this._recordScrollable);
+        this.$element.on('touchmove', this._stopScrollPropagation);
+      }
 
-  addToJquery: function ($) {
-    // TODO: consider not making this a jQuery function
-    // TODO: need way to reflow vs. re-initialize
-    /**
-     * The Foundation jQuery method.
-     * @param {String|Array} method - An action to perform on the current jQuery object.
-     */
-    var foundation = function (method) {
-      var type = typeof method,
-          $noJS = $('.no-js');
+      if (this.options.contentOverlay === true) {
+        this.$overlay.addClass('is-visible');
+      }
 
-      if ($noJS.length) {
-        $noJS.removeClass('no-js');
+      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+        this.$overlay.addClass('is-closable');
       }
 
-      if (type === 'undefined') {
-        //needs to initialize the Foundation object, or an individual plugin.
-        __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
-        Foundation.reflow(this);
-      } else if (type === 'string') {
-        //an individual method to invoke on a plugin or group of plugins
-        var args = Array.prototype.slice.call(arguments, 1); //collect all the arguments, if necessary
-        var plugClass = this.data('zfPlugin'); //determine the class of plugin
+      if (this.options.autoFocus === true) {
+        this.$element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["transitionend"])(this.$element), function () {
+          if (!_this.$element.hasClass('is-open')) {
+            return; // exit if prematurely closed
+          }
 
-        if (plugClass !== undefined && plugClass[method] !== undefined) {
-          //make sure both the class and method exist
-          if (this.length === 1) {
-            //if there's only one, call it directly.
-            plugClass[method].apply(plugClass, args);
+          var canvasFocus = _this.$element.find('[data-autofocus]');
+
+          if (canvasFocus.length) {
+            canvasFocus.eq(0).focus();
           } else {
-            this.each(function (i, el) {
-              //otherwise loop through the jQuery collection and invoke the method on each
-              plugClass[method].apply($(el).data('zfPlugin'), args);
-            });
+            _this.$element.find('a, button').eq(0).focus();
           }
-        } else {
-          //error for no class or no method
-          throw new ReferenceError("We're sorry, '" + method + "' is not an available method for " + (plugClass ? functionName(plugClass) : 'this element') + '.');
-        }
-      } else {
-        //error for invalid argument type
-        throw new TypeError('We\'re sorry, ' + type + ' is not a valid parameter. You must use a string representing the method you wish to invoke.');
+        });
       }
-      return this;
-    };
-    $.fn.foundation = foundation;
-    return $;
-  }
-};
-
-Foundation.util = {
-  /**
-   * Function for applying a debounce effect to a function call.
-   * @function
-   * @param {Function} func - Function to be called at end of timeout.
-   * @param {Number} delay - Time in ms to delay the call of `func`.
-   * @returns function
-   */
-  throttle: function (func, delay) {
-    var timer = null;
-
-    return function () {
-      var context = this,
-          args = arguments;
 
-      if (timer === null) {
-        timer = setTimeout(function () {
-          func.apply(context, args);
-          timer = null;
-        }, delay);
+      if (this.options.trapFocus === true) {
+        this.$content.attr('tabindex', '-1');
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].trapFocus(this.$element);
       }
-    };
-  }
-};
 
-window.Foundation = Foundation;
+      this._addContentClasses();
+      /**
+       * Fires when the off-canvas menu opens.
+       * @event Offcanvas#opened
+       */
 
-// Polyfill for requestAnimationFrame
-(function () {
-  if (!Date.now || !window.Date.now) window.Date.now = Date.now = function () {
-    return new Date().getTime();
-  };
 
-  var vendors = ['webkit', 'moz'];
-  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {
-    var vp = vendors[i];
-    window.requestAnimationFrame = window[vp + 'RequestAnimationFrame'];
-    window.cancelAnimationFrame = window[vp + 'CancelAnimationFrame'] || window[vp + 'CancelRequestAnimationFrame'];
-  }
-  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) || !window.requestAnimationFrame || !window.cancelAnimationFrame) {
-    var lastTime = 0;
-    window.requestAnimationFrame = function (callback) {
-      var now = Date.now();
-      var nextTime = Math.max(lastTime + 16, now);
-      return setTimeout(function () {
-        callback(lastTime = nextTime);
-      }, nextTime - now);
-    };
-    window.cancelAnimationFrame = clearTimeout;
-  }
-  /**
-   * Polyfill for performance.now, required by rAF
-   */
-  if (!window.performance || !window.performance.now) {
-    window.performance = {
-      start: Date.now(),
-      now: function () {
-        return Date.now() - this.start;
-      }
-    };
-  }
-})();
-if (!Function.prototype.bind) {
-  Function.prototype.bind = function (oThis) {
-    if (typeof this !== 'function') {
-      // closest thing possible to the ECMAScript 5
-      // internal IsCallable function
-      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');
+      this.$element.trigger('opened.zf.offcanvas');
     }
+    /**
+     * Closes the off-canvas menu.
+     * @function
+     * @param {Function} cb - optional cb to fire after closure.
+     * @fires Offcanvas#closed
+     */
 
-    var aArgs = Array.prototype.slice.call(arguments, 1),
-        fToBind = this,
-        fNOP = function () {},
-        fBound = function () {
-      return fToBind.apply(this instanceof fNOP ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments)));
-    };
+  }, {
+    key: "close",
+    value: function close(cb) {
+      if (!this.$element.hasClass('is-open') || this.isRevealed) {
+        return;
+      }
 
-    if (this.prototype) {
-      // native functions don't have a prototype
-      fNOP.prototype = this.prototype;
-    }
-    fBound.prototype = new fNOP();
+      var _this = this;
 
-    return fBound;
-  };
-}
-// Polyfill to get the name of a function in IE9
-function functionName(fn) {
-  if (Function.prototype.name === undefined) {
-    var funcNameRegex = /function\s([^(]{1,})\(/;
-    var results = funcNameRegex.exec(fn.toString());
-    return results && results.length > 1 ? results[1].trim() : "";
-  } else if (fn.prototype === undefined) {
-    return fn.constructor.name;
-  } else {
-    return fn.prototype.constructor.name;
-  }
-}
-function parseValue(str) {
-  if ('true' === str) return true;else if ('false' === str) return false;else if (!isNaN(str * 1)) return parseFloat(str);
-  return str;
-}
-// Convert PascalCase to kebab-case
-// Thank you: http://stackoverflow.com/a/8955580
-function hyphenate(str) {
-  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
-}
+      this.$element.removeClass('is-open');
+      this.$element.attr('aria-hidden', 'true')
+      /**
+       * Fires when the off-canvas menu opens.
+       * @event Offcanvas#closed
+       */
+      .trigger('closed.zf.offcanvas');
+      this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom'); // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.
+
+      if (this.options.contentScroll === false) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);
+        this.$element.off('touchstart', this._recordScrollable);
+        this.$element.off('touchmove', this._stopScrollPropagation);
+      }
+
+      if (this.options.contentOverlay === true) {
+        this.$overlay.removeClass('is-visible');
+      }
+
+      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
+        this.$overlay.removeClass('is-closable');
+      }
+
+      this.$triggers.attr('aria-expanded', 'false');
+
+      if (this.options.trapFocus === true) {
+        this.$content.removeAttr('tabindex');
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].releaseFocus(this.$element);
+      } // Listen to transitionEnd and add class when done.
+
+
+      this.$element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["transitionend"])(this.$element), function (e) {
+        _this.$element.addClass('is-closed');
+
+        _this._removeContentClasses();
+      });
+    }
+    /**
+     * Toggles the off-canvas menu open or closed.
+     * @function
+     * @param {Object} event - Event object passed from listener.
+     * @param {jQuery} trigger - element that triggered the off-canvas to open.
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle(event, trigger) {
+      if (this.$element.hasClass('is-open')) {
+        this.close(event, trigger);
+      } else {
+        this.open(event, trigger);
+      }
+    }
+    /**
+     * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_handleKeyboard",
+    value: function _handleKeyboard(e) {
+      var _this3 = this;
+
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'OffCanvas', {
+        close: function close() {
+          _this3.close();
+
+          _this3.$lastTrigger.focus();
+
+          return true;
+        },
+        handled: function handled() {
+          e.stopPropagation();
+          e.preventDefault();
+        }
+      });
+    }
+    /**
+     * Destroys the offcanvas plugin.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.close();
+      this.$element.off('.zf.trigger .zf.offcanvas');
+      this.$overlay.off('.zf.offcanvas');
+      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
+    }
+  }]);
+
+  return OffCanvas;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__["Plugin"]);
+
+OffCanvas.defaults = {
+  /**
+   * Allow the user to click outside of the menu to close it.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
+
+  /**
+   * Adds an overlay on top of `[data-off-canvas-content]`.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  contentOverlay: true,
+
+  /**
+   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  contentId: null,
+
+  /**
+   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.
+   * @option
+   * @type {boolean}
+   * @default null
+   */
+  nested: null,
+
+  /**
+   * Enable/disable scrolling of the main content when an off canvas panel is open.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  contentScroll: true,
+
+  /**
+   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.
+   * @option
+   * @type {number}
+   * @default null
+   */
+  transitionTime: null,
+
+  /**
+   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.
+   * @option
+   * @type {string}
+   * @default push
+   */
+  transition: 'push',
+
+  /**
+   * Force the page to scroll to top or bottom on open.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  forceTo: null,
+
+  /**
+   * Allow the offcanvas to remain open for certain breakpoints.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  isRevealed: false,
+
+  /**
+   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  revealOn: null,
+
+  /**
+   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  autoFocus: true,
+
+  /**
+   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.
+   * @option
+   * @type {string}
+   * @default reveal-for-
+   * @todo improve the regex testing for this.
+   */
+  revealClass: 'reveal-for-',
 
+  /**
+   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  trapFocus: false
+};
 
 
 /***/ }),
-/* 22 */
+
+/***/ "./js/foundation.orbit.js":
+/*!********************************!*\
+  !*** ./js/foundation.orbit.js ***!
+  \********************************/
+/*! exports provided: Orbit */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Dropdown; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_positionable__ = __webpack_require__(15);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_triggers__ = __webpack_require__(5);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Orbit", function() { return Orbit; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./js/foundation.util.motion.js");
+/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.timer */ "./js/foundation.util.timer.js");
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.imageLoader */ "./js/foundation.util.imageLoader.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./foundation.util.touch */ "./js/foundation.util.touch.js");
 
-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; }; }();
 
-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); } };
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-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; }
 
 
 
@@ -5690,2679 +6251,2436 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
 
 
 /**
- * Dropdown module.
- * @module foundation.dropdown
+ * Orbit module.
+ * @module foundation.orbit
  * @requires foundation.util.keyboard
- * @requires foundation.util.box
- * @requires foundation.util.triggers
+ * @requires foundation.util.motion
+ * @requires foundation.util.timer
+ * @requires foundation.util.imageLoader
+ * @requires foundation.util.touch
  */
 
-var Dropdown = function (_Positionable) {
-  _inherits(Dropdown, _Positionable);
+var Orbit =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Orbit, _Plugin);
 
-  function Dropdown() {
-    _classCallCheck(this, Dropdown);
+  function Orbit() {
+    _classCallCheck(this, Orbit);
 
-    return _possibleConstructorReturn(this, (Dropdown.__proto__ || Object.getPrototypeOf(Dropdown)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Orbit).apply(this, arguments));
   }
 
-  _createClass(Dropdown, [{
-    key: '_setup',
+  _createClass(Orbit, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of a dropdown.
-     * @class
-     * @name Dropdown
-     * @param {jQuery} element - jQuery object to make into a dropdown.
-     *        Object should be of the dropdown panel, rather than its anchor.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
+    * Creates a new instance of an orbit carousel.
+    * @class
+    * @name Orbit
+    * @param {jQuery} element - jQuery object to make into an Orbit Carousel.
+    * @param {Object} options - Overrides to the default plugin settings.
+    */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Dropdown.defaults, this.$element.data(), options);
-      this.className = 'Dropdown'; // ie9 back compat
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Orbit.defaults, this.$element.data(), options);
+      this.className = 'Orbit'; // ie9 back compat
 
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_4__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+      _foundation_util_touch__WEBPACK_IMPORTED_MODULE_7__["Touch"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Touch init is idempotent, we just need to make sure it's initialied.
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('Dropdown', {
-        'ENTER': 'open',
-        'SPACE': 'open',
-        'ESCAPE': 'close'
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('Orbit', {
+        'ltr': {
+          'ARROW_RIGHT': 'next',
+          'ARROW_LEFT': 'previous'
+        },
+        'rtl': {
+          'ARROW_LEFT': 'next',
+          'ARROW_RIGHT': 'previous'
+        }
       });
     }
-
     /**
-     * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.
-     * @function
-     * @private
-     */
+    * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.
+    * @function
+    * @private
+    */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      var $id = this.$element.attr('id');
+      // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide
+      this._reset();
 
-      this.$anchors = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-toggle="' + $id + '"]').length ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-toggle="' + $id + '"]') : __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-open="' + $id + '"]');
-      this.$anchors.attr({
-        'aria-controls': $id,
-        'data-is-focus': false,
-        'data-yeti-box': $id,
-        'aria-haspopup': true,
-        'aria-expanded': false
+      this.$wrapper = this.$element.find(".".concat(this.options.containerClass));
+      this.$slides = this.$element.find(".".concat(this.options.slideClass));
+      var $images = this.$element.find('img'),
+          initActive = this.$slides.filter('.is-active'),
+          id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__["GetYoDigits"])(6, 'orbit');
+      this.$element.attr({
+        'data-resize': id,
+        'id': id
       });
 
-      this._setCurrentAnchor(this.$anchors.first());
+      if (!initActive.length) {
+        this.$slides.eq(0).addClass('is-active');
+      }
 
-      if (this.options.parentClass) {
-        this.$parent = this.$element.parents('.' + this.options.parentClass);
-      } else {
-        this.$parent = null;
+      if (!this.options.useMUI) {
+        this.$slides.addClass('no-motionui');
       }
 
-      this.$element.attr({
-        'aria-hidden': 'true',
-        'data-yeti-box': $id,
-        'data-resize': $id,
-        'aria-labelledby': this.$currentAnchor.id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["b" /* GetYoDigits */])(6, 'dd-anchor')
-      });
-      _get(Dropdown.prototype.__proto__ || Object.getPrototypeOf(Dropdown.prototype), '_init', this).call(this);
-      this._events();
-    }
-  }, {
-    key: '_getDefaultPosition',
-    value: function _getDefaultPosition() {
-      // handle legacy classnames
-      var position = this.$element[0].className.match(/(top|left|right|bottom)/g);
-      if (position) {
-        return position[0];
+      if ($images.length) {
+        Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__["onImagesLoaded"])($images, this._prepareForOrbit.bind(this));
       } else {
-        return 'bottom';
+        this._prepareForOrbit(); //hehe
+
       }
-    }
-  }, {
-    key: '_getDefaultAlignment',
-    value: function _getDefaultAlignment() {
-      // handle legacy float approach
-      var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.className);
-      if (horizontalPosition) {
-        return horizontalPosition[1];
+
+      if (this.options.bullets) {
+        this._loadBullets();
       }
 
-      return _get(Dropdown.prototype.__proto__ || Object.getPrototypeOf(Dropdown.prototype), '_getDefaultAlignment', this).call(this);
-    }
+      this._events();
+
+      if (this.options.autoPlay && this.$slides.length > 1) {
+        this.geoSync();
+      }
 
+      if (this.options.accessible) {
+        // allow wrapper to be focusable to enable arrow navigation
+        this.$wrapper.attr('tabindex', 0);
+      }
+    }
     /**
-     * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.
-     * Recursively calls itself if a collision is detected, with a new position class.
-     * @function
-     * @private
-     */
+    * Creates a jQuery collection of bullets, if they are being used.
+    * @function
+    * @private
+    */
 
   }, {
-    key: '_setPosition',
-    value: function _setPosition() {
-      _get(Dropdown.prototype.__proto__ || Object.getPrototypeOf(Dropdown.prototype), '_setPosition', this).call(this, this.$currentAnchor, this.$element, this.$parent);
+    key: "_loadBullets",
+    value: function _loadBullets() {
+      this.$bullets = this.$element.find(".".concat(this.options.boxOfBullets)).find('button');
     }
-
     /**
-     * Make it a current anchor.
-     * Current anchor as the reference for the position of Dropdown panes.
-     * @param {HTML} el - DOM element of the anchor.
-     * @function
-     * @private
-     */
+    * Sets a `timer` object on the orbit, and starts the counter for the next slide.
+    * @function
+    */
 
   }, {
-    key: '_setCurrentAnchor',
-    value: function _setCurrentAnchor(el) {
-      this.$currentAnchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el);
-    }
+    key: "geoSync",
+    value: function geoSync() {
+      var _this = this;
 
+      this.timer = new _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__["Timer"](this.$element, {
+        duration: this.options.timerDelay,
+        infinite: false
+      }, function () {
+        _this.changeSlide(true);
+      });
+      this.timer.start();
+    }
     /**
-     * Adds event listeners to the element utilizing the triggers utility library.
-     * @function
-     * @private
-     */
+    * Sets wrapper and slide heights for the orbit.
+    * @function
+    * @private
+    */
 
   }, {
-    key: '_events',
-    value: function _events() {
+    key: "_prepareForOrbit",
+    value: function _prepareForOrbit() {
       var _this = this;
-      this.$element.on({
-        'open.zf.trigger': this.open.bind(this),
-        'close.zf.trigger': this.close.bind(this),
-        'toggle.zf.trigger': this.toggle.bind(this),
-        'resizeme.zf.trigger': this._setPosition.bind(this)
-      });
 
-      this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function () {
-        _this._setCurrentAnchor(this);
-      });
+      this._setWrapperHeight();
+    }
+    /**
+    * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.
+    * @function
+    * @private
+    * @param {Function} cb - a callback function to fire when complete.
+    */
 
-      if (this.options.hover) {
-        this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
-          _this._setCurrentAnchor(this);
+  }, {
+    key: "_setWrapperHeight",
+    value: function _setWrapperHeight(cb) {
+      //rewrite this to `for` loop
+      var max = 0,
+          temp,
+          counter = 0,
+          _this = this;
 
-          var bodyData = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').data();
-          if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') {
-            clearTimeout(_this.timeout);
-            _this.timeout = setTimeout(function () {
-              _this.open();
-              _this.$anchors.data('hover', true);
-            }, _this.options.hoverDelay);
-          }
-        }).on('mouseleave.zf.dropdown', function () {
-          clearTimeout(_this.timeout);
-          _this.timeout = setTimeout(function () {
-            _this.close();
-            _this.$anchors.data('hover', false);
-          }, _this.options.hoverDelay);
-        });
-        if (this.options.hoverPane) {
-          this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
-            clearTimeout(_this.timeout);
-          }).on('mouseleave.zf.dropdown', function () {
-            clearTimeout(_this.timeout);
-            _this.timeout = setTimeout(function () {
-              _this.close();
-              _this.$anchors.data('hover', false);
-            }, _this.options.hoverDelay);
+      this.$slides.each(function () {
+        temp = this.getBoundingClientRect().height;
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('data-slide', counter); // hide all slides but the active one
+
+        if (!/mui/g.test(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css({
+            'display': 'none'
           });
         }
-      }
-      this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) {
-
-        var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            visibleFocusableElements = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].findFocusable(_this.$element);
 
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'Dropdown', {
-          open: function () {
-            if ($target.is(_this.$anchors)) {
-              _this.open();
-              _this.$element.attr('tabindex', -1).focus();
-              e.preventDefault();
-            }
-          },
-          close: function () {
-            _this.close();
-            _this.$anchors.focus();
-          }
-        });
+        max = temp > max ? temp : max;
+        counter++;
       });
-    }
 
+      if (counter === this.$slides.length) {
+        this.$wrapper.css({
+          'height': max
+        }); //only change the wrapper height property once.
+
+        if (cb) {
+          cb(max);
+        } //fire callback with max height dimension.
+
+      }
+    }
     /**
-     * Adds an event handler to the body to close any dropdowns on a click.
-     * @function
-     * @private
-     */
+    * Sets the max-height of each slide.
+    * @function
+    * @private
+    */
 
   }, {
-    key: '_addBodyHandler',
-    value: function _addBodyHandler() {
-      var $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document.body).not(this.$element),
-          _this = this;
-      $body.off('click.zf.dropdown').on('click.zf.dropdown', function (e) {
-        if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {
-          return;
-        }
-        if (_this.$element.find(e.target).length) {
-          return;
-        }
-        _this.close();
-        $body.off('click.zf.dropdown');
+    key: "_setSlideHeight",
+    value: function _setSlideHeight(height) {
+      this.$slides.each(function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css('max-height', height);
       });
     }
-
     /**
-     * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.
-     * @function
-     * @fires Dropdown#closeme
-     * @fires Dropdown#show
-     */
+    * Adds event listeners to basically everything within the element.
+    * @function
+    * @private
+    */
 
   }, {
-    key: 'open',
-    value: function open() {
-      // var _this = this;
-      /**
-       * Fires to close other open dropdowns, typically when dropdown is opening
-       * @event Dropdown#closeme
-       */
-      this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));
-      this.$anchors.addClass('hover').attr({ 'aria-expanded': true });
-      // this.$element/*.show()*/;
+    key: "_events",
+    value: function _events() {
+      var _this = this; //***************************************
+      //**Now using custom event - thanks to:**
+      //**      Yohai Ararat of Toronto      **
+      //***************************************
+      //
 
-      this.$element.addClass('is-opening');
-      this._setPosition();
-      this.$element.removeClass('is-opening').addClass('is-open').attr({ 'aria-hidden': false });
 
-      if (this.options.autoFocus) {
-        var $focusable = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].findFocusable(this.$element);
-        if ($focusable.length) {
-          $focusable.eq(0).focus();
-        }
-      }
+      this.$element.off('.resizeme.zf.trigger').on({
+        'resizeme.zf.trigger': this._prepareForOrbit.bind(this)
+      });
 
-      if (this.options.closeOnClick) {
-        this._addBodyHandler();
-      }
+      if (this.$slides.length > 1) {
+        if (this.options.swipe) {
+          this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) {
+            e.preventDefault();
 
-      if (this.options.trapFocus) {
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].trapFocus(this.$element);
-      }
+            _this.changeSlide(true);
+          }).on('swiperight.zf.orbit', function (e) {
+            e.preventDefault();
 
-      /**
-       * Fires once the dropdown is visible.
-       * @event Dropdown#show
-       */
-      this.$element.trigger('show.zf.dropdown', [this.$element]);
-    }
+            _this.changeSlide(false);
+          });
+        } //***************************************
 
+
+        if (this.options.autoPlay) {
+          this.$slides.on('click.zf.orbit', function () {
+            _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);
+
+            _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();
+          });
+
+          if (this.options.pauseOnHover) {
+            this.$element.on('mouseenter.zf.orbit', function () {
+              _this.timer.pause();
+            }).on('mouseleave.zf.orbit', function () {
+              if (!_this.$element.data('clickedOn')) {
+                _this.timer.start();
+              }
+            });
+          }
+        }
+
+        if (this.options.navButtons) {
+          var $controls = this.$element.find(".".concat(this.options.nextClass, ", .").concat(this.options.prevClass));
+          $controls.attr('tabindex', 0) //also need to handle enter/return and spacebar key presses
+          .on('click.zf.orbit touchend.zf.orbit', function (e) {
+            e.preventDefault();
+
+            _this.changeSlide(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).hasClass(_this.options.nextClass));
+          });
+        }
+
+        if (this.options.bullets) {
+          this.$bullets.on('click.zf.orbit touchend.zf.orbit', function () {
+            if (/is-active/g.test(this.className)) {
+              return false;
+            } //if this is active, kick out of function.
+
+
+            var idx = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('slide'),
+                ltr = idx > _this.$slides.filter('.is-active').data('slide'),
+                $slide = _this.$slides.eq(idx);
+
+            _this.changeSlide(ltr, $slide, idx);
+          });
+        }
+
+        if (this.options.accessible) {
+          this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) {
+            // handle keyboard event with keyboard util
+            _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'Orbit', {
+              next: function next() {
+                _this.changeSlide(true);
+              },
+              previous: function previous() {
+                _this.changeSlide(false);
+              },
+              handled: function handled() {
+                // if bullet is focused, make sure focus moves
+                if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is(_this.$bullets)) {
+                  _this.$bullets.filter('.is-active').focus();
+                }
+              }
+            });
+          });
+        }
+      }
+    }
     /**
-     * Closes the open dropdown pane.
-     * @function
-     * @fires Dropdown#hide
+     * Resets Orbit so it can be reinitialized
      */
 
   }, {
-    key: 'close',
-    value: function close() {
-      if (!this.$element.hasClass('is-open')) {
-        return false;
+    key: "_reset",
+    value: function _reset() {
+      // Don't do anything if there are no slides (first run)
+      if (typeof this.$slides == 'undefined') {
+        return;
       }
-      this.$element.removeClass('is-open').attr({ 'aria-hidden': true });
 
-      this.$anchors.removeClass('hover').attr('aria-expanded', false);
+      if (this.$slides.length > 1) {
+        // Remove old events
+        this.$element.off('.zf.orbit').find('*').off('.zf.orbit'); // Restart timer if autoPlay is enabled
 
-      /**
-       * Fires once the dropdown is no longer visible.
-       * @event Dropdown#hide
-       */
-      this.$element.trigger('hide.zf.dropdown', [this.$element]);
+        if (this.options.autoPlay) {
+          this.timer.restart();
+        } // Reset all sliddes
 
-      if (this.options.trapFocus) {
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].releaseFocus(this.$element);
+
+        this.$slides.each(function (el) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide();
+        }); // Show the first slide
+
+        this.$slides.first().addClass('is-active').show(); // Triggers when the slide has finished animating
+
+        this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); // Select first bullet if bullets are present
+
+        if (this.options.bullets) {
+          this._updateBullets(0);
+        }
       }
     }
-
     /**
-     * Toggles the dropdown pane's visibility.
-     * @function
-     */
+    * Changes the current slide to a new one.
+    * @function
+    * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.
+    * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.
+    * @param {Number} idx - the index of the new slide in its collection, if one chosen.
+    * @fires Orbit#slidechange
+    */
 
   }, {
-    key: 'toggle',
-    value: function toggle() {
-      if (this.$element.hasClass('is-open')) {
-        if (this.$anchors.data('hover')) return;
-        this.close();
+    key: "changeSlide",
+    value: function changeSlide(isLTR, chosenSlide, idx) {
+      if (!this.$slides) {
+        return;
+      } // Don't freak out if we're in the middle of cleanup
+
+
+      var $curSlide = this.$slides.filter('.is-active').eq(0);
+
+      if (/mui/g.test($curSlide[0].className)) {
+        return false;
+      } //if the slide is currently animating, kick out of the function
+
+
+      var $firstSlide = this.$slides.first(),
+          $lastSlide = this.$slides.last(),
+          dirIn = isLTR ? 'Right' : 'Left',
+          dirOut = isLTR ? 'Left' : 'Right',
+          _this = this,
+          $newSlide;
+
+      if (!chosenSlide) {
+        //most of the time, this will be auto played or clicked from the navButtons.
+        $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!
+        this.options.infiniteWrap ? $curSlide.next(".".concat(this.options.slideClass)).length ? $curSlide.next(".".concat(this.options.slideClass)) : $firstSlide : $curSlide.next(".".concat(this.options.slideClass)) : //pick next slide if moving left to right
+        this.options.infiniteWrap ? $curSlide.prev(".".concat(this.options.slideClass)).length ? $curSlide.prev(".".concat(this.options.slideClass)) : $lastSlide : $curSlide.prev(".".concat(this.options.slideClass)); //pick prev slide if moving right to left
       } else {
-        this.open();
+        $newSlide = chosenSlide;
+      }
+
+      if ($newSlide.length) {
+        /**
+        * Triggers before the next slide starts animating in and only if a next slide has been found.
+        * @event Orbit#beforeslidechange
+        */
+        this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);
+
+        if (this.options.bullets) {
+          idx = idx || this.$slides.index($newSlide); //grab index to update bullets
+
+          this._updateBullets(idx);
+        }
+
+        if (this.options.useMUI && !this.$element.is(':hidden')) {
+          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateIn($newSlide.addClass('is-active'), this.options["animInFrom".concat(dirIn)], function () {
+            $newSlide.css({
+              'display': 'block'
+            }).attr('aria-live', 'polite');
+          });
+          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut($curSlide.removeClass('is-active'), this.options["animOutTo".concat(dirOut)], function () {
+            $curSlide.removeAttr('aria-live');
+
+            if (_this.options.autoPlay && !_this.timer.isPaused) {
+              _this.timer.restart();
+            } //do stuff?
+
+          });
+        } else {
+          $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();
+          $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();
+
+          if (this.options.autoPlay && !this.timer.isPaused) {
+            this.timer.restart();
+          }
+        }
+        /**
+        * Triggers when the slide has finished animating in.
+        * @event Orbit#slidechange
+        */
+
+
+        this.$element.trigger('slidechange.zf.orbit', [$newSlide]);
       }
     }
+    /**
+    * Updates the active state of the bullets, if displayed.
+    * @function
+    * @private
+    * @param {Number} idx - the index of the current slide.
+    */
 
+  }, {
+    key: "_updateBullets",
+    value: function _updateBullets(idx) {
+      var $oldBullet = this.$element.find(".".concat(this.options.boxOfBullets)).find('.is-active').removeClass('is-active').blur(),
+          span = $oldBullet.find('span:last').detach(),
+          $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);
+    }
     /**
-     * Destroys the dropdown.
-     * @function
-     */
+    * Destroys the carousel and hides the element.
+    * @function
+    */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
-      this.$element.off('.zf.trigger').hide();
-      this.$anchors.off('.zf.dropdown');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document.body).off('click.zf.dropdown');
+      this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();
     }
   }]);
 
-  return Dropdown;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_positionable__["a" /* Positionable */]);
+  return Orbit;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_6__["Plugin"]);
 
-Dropdown.defaults = {
-  /**
-   * Class that designates bounding container of Dropdown (default: window)
-   * @option
-   * @type {?string}
-   * @default null
-   */
-  parentClass: null,
-  /**
-   * Amount of time to delay opening a submenu on hover event.
-   * @option
-   * @type {number}
-   * @default 250
-   */
-  hoverDelay: 250,
+Orbit.defaults = {
   /**
-   * Allow submenus to open on hover events
-   * @option
+  * Tells the JS to look for and loadBullets.
+  * @option
    * @type {boolean}
-   * @default false
-   */
-  hover: false,
+  * @default true
+  */
+  bullets: true,
+
   /**
-   * Don't close dropdown when hovering over dropdown pane
-   * @option
+  * Tells the JS to apply event listeners to nav buttons
+  * @option
    * @type {boolean}
-   * @default false
-   */
-  hoverPane: false,
-  /**
-   * Number of pixels between the dropdown pane and the triggering element on open.
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  vOffset: 0,
-  /**
-   * Number of pixels between the dropdown pane and the triggering element on open.
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  hOffset: 0,
+  * @default true
+  */
+  navButtons: true,
+
   /**
-   * DEPRECATED: Class applied to adjust open position.
-   * @option
+  * motion-ui animation class to apply
+  * @option
    * @type {string}
-   * @default ''
-   */
-  positionClass: '',
+  * @default 'slide-in-right'
+  */
+  animInFromRight: 'slide-in-right',
 
   /**
-   * Position of dropdown. Can be left, right, bottom, top, or auto.
-   * @option
+  * motion-ui animation class to apply
+  * @option
    * @type {string}
-   * @default 'auto'
-   */
-  position: 'auto',
+  * @default 'slide-out-right'
+  */
+  animOutToRight: 'slide-out-right',
+
   /**
-   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.
-   * @option
+  * motion-ui animation class to apply
+  * @option
    * @type {string}
-   * @default 'auto'
-   */
-  alignment: 'auto',
+  * @default 'slide-in-left'
+  *
+  */
+  animInFromLeft: 'slide-in-left',
+
   /**
-   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.
-   * @option
+  * motion-ui animation class to apply
+  * @option
+   * @type {string}
+  * @default 'slide-out-left'
+  */
+  animOutToLeft: 'slide-out-left',
+
+  /**
+  * Allows Orbit to automatically animate on page load.
+  * @option
    * @type {boolean}
-   * @default false
-   */
-  allowOverlap: false,
+  * @default true
+  */
+  autoPlay: true,
+
   /**
-   * Allow overlap of only the bottom of the container. This is the most common
-   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
-   * screen but not otherwise influence or break out of the container.
-   * @option
+  * Amount of time, in ms, between slide transitions
+  * @option
+   * @type {number}
+  * @default 5000
+  */
+  timerDelay: 5000,
+
+  /**
+  * Allows Orbit to infinitely loop through the slides
+  * @option
    * @type {boolean}
-   * @default true
-   */
-  allowBottomOverlap: true,
+  * @default true
+  */
+  infiniteWrap: true,
+
   /**
-   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.
-   * @option
+  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library
+  * @option
    * @type {boolean}
-   * @default false
-   */
-  trapFocus: false,
+  * @default true
+  */
+  swipe: true,
+
   /**
-   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.
-   * @option
+  * Allows the timing function to pause animation on hover.
+  * @option
    * @type {boolean}
-   * @default false
-   */
-  autoFocus: false,
+  * @default true
+  */
+  pauseOnHover: true,
+
   /**
-   * Allows a click on the body to close the dropdown.
-   * @option
+  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys
+  * @option
    * @type {boolean}
-   * @default false
-   */
-  closeOnClick: false
-};
+  * @default true
+  */
+  accessible: true,
+
+  /**
+  * Class applied to the container of Orbit
+  * @option
+   * @type {string}
+  * @default 'orbit-container'
+  */
+  containerClass: 'orbit-container',
+
+  /**
+  * Class applied to individual slides.
+  * @option
+   * @type {string}
+  * @default 'orbit-slide'
+  */
+  slideClass: 'orbit-slide',
+
+  /**
+  * Class applied to the bullet container. You're welcome.
+  * @option
+   * @type {string}
+  * @default 'orbit-bullets'
+  */
+  boxOfBullets: 'orbit-bullets',
+
+  /**
+  * Class applied to the `next` navigation button.
+  * @option
+   * @type {string}
+  * @default 'orbit-next'
+  */
+  nextClass: 'orbit-next',
+
+  /**
+  * Class applied to the `previous` navigation button.
+  * @option
+   * @type {string}
+  * @default 'orbit-previous'
+  */
+  prevClass: 'orbit-previous',
 
+  /**
+  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.
+  * @option
+   * @type {boolean}
+  * @default true
+  */
+  useMUI: true
+};
 
 
 /***/ }),
-/* 23 */
+
+/***/ "./js/foundation.positionable.js":
+/*!***************************************!*\
+  !*** ./js/foundation.positionable.js ***!
+  \***************************************/
+/*! exports provided: Positionable */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Equalizer; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__ = __webpack_require__(8);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Positionable", function() { return Positionable; });
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.util.box */ "./js/foundation.util.box.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
 
-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 _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
-/**
- * Equalizer module.
- * @module foundation.equalizer
- * @requires foundation.util.mediaQuery
- * @requires foundation.util.imageLoader if equalizer contains images
- */
 
-var Equalizer = function (_Plugin) {
-  _inherits(Equalizer, _Plugin);
 
-  function Equalizer() {
-    _classCallCheck(this, Equalizer);
+var POSITIONS = ['left', 'right', 'top', 'bottom'];
+var VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];
+var HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];
+var ALIGNMENTS = {
+  'left': VERTICAL_ALIGNMENTS,
+  'right': VERTICAL_ALIGNMENTS,
+  'top': HORIZONTAL_ALIGNMENTS,
+  'bottom': HORIZONTAL_ALIGNMENTS
+};
+
+function nextItem(item, array) {
+  var currentIdx = array.indexOf(item);
 
-    return _possibleConstructorReturn(this, (Equalizer.__proto__ || Object.getPrototypeOf(Equalizer)).apply(this, arguments));
+  if (currentIdx === array.length - 1) {
+    return array[0];
+  } else {
+    return array[currentIdx + 1];
   }
+}
 
-  _createClass(Equalizer, [{
-    key: '_setup',
+var Positionable =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Positionable, _Plugin);
 
-    /**
-     * Creates a new instance of Equalizer.
-     * @class
-     * @name Equalizer
-     * @fires Equalizer#init
-     * @param {Object} element - jQuery object to add the trigger to.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Equalizer.defaults, this.$element.data(), options);
-      this.className = 'Equalizer'; // ie9 back compat
+  function Positionable() {
+    _classCallCheck(this, Positionable);
 
-      this._init();
-    }
+    return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments));
+  }
 
-    /**
-     * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.
-     * @private
-     */
+  _createClass(Positionable, [{
+    key: "_init",
 
-  }, {
-    key: '_init',
+    /**
+     * Abstract class encapsulating the tether-like explicit positioning logic
+     * including repositioning based on overlap.
+     * Expects classes to define defaults for vOffset, hOffset, position,
+     * alignment, allowOverlap, and allowBottomOverlap. They can do this by
+     * extending the defaults, or (for now recommended due to the way docs are
+     * generated) by explicitly declaring them.
+     *
+     **/
     value: function _init() {
-      var eqId = this.$element.attr('data-equalizer') || '';
-      var $watched = this.$element.find('[data-equalizer-watch="' + eqId + '"]');
-
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
-
-      this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');
-      this.$element.attr('data-resize', eqId || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["b" /* GetYoDigits */])(6, 'eq'));
-      this.$element.attr('data-mutate', eqId || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["b" /* GetYoDigits */])(6, 'eq'));
-
-      this.hasNested = this.$element.find('[data-equalizer]').length > 0;
-      this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;
-      this.isOn = false;
-      this._bindHandler = {
-        onResizeMeBound: this._onResizeMe.bind(this),
-        onPostEqualizedBound: this._onPostEqualized.bind(this)
-      };
+      this.triedPositions = {};
+      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;
+      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;
+      this.originalPosition = this.position;
+      this.originalAlignment = this.alignment;
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      return 'bottom';
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      switch (this.position) {
+        case 'bottom':
+        case 'top':
+          return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["rtl"])() ? 'right' : 'left';
 
-      var imgs = this.$element.find('img');
-      var tooSmall;
-      if (this.options.equalizeOn) {
-        tooSmall = this._checkMQ();
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));
-      } else {
-        this._events();
-      }
-      if (tooSmall !== undefined && tooSmall === false || tooSmall === undefined) {
-        if (imgs.length) {
-          __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__["a" /* onImagesLoaded */])(imgs, this._reflow.bind(this));
-        } else {
-          this._reflow();
-        }
+        case 'left':
+        case 'right':
+          return 'bottom';
       }
     }
-
     /**
-     * Removes event listeners if the breakpoint is too small.
+     * Adjusts the positionable possible positions by iterating through alignments
+     * and positions.
+     * @function
      * @private
      */
 
   }, {
-    key: '_pauseEvents',
-    value: function _pauseEvents() {
-      this.isOn = false;
-      this.$element.off({
-        '.zf.equalizer': this._bindHandler.onPostEqualizedBound,
-        'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,
-        'mutateme.zf.trigger': this._bindHandler.onResizeMeBound
-      });
+    key: "_reposition",
+    value: function _reposition() {
+      if (this._alignmentsExhausted(this.position)) {
+        this.position = nextItem(this.position, POSITIONS);
+        this.alignment = ALIGNMENTS[this.position][0];
+      } else {
+        this._realign();
+      }
     }
-
     /**
-     * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound
+     * Adjusts the dropdown pane possible positions by iterating through alignments
+     * on the current position.
+     * @function
      * @private
      */
 
   }, {
-    key: '_onResizeMe',
-    value: function _onResizeMe(e) {
-      this._reflow();
-    }
-
-    /**
-     * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound
-     * @private
-     */
+    key: "_realign",
+    value: function _realign() {
+      this._addTriedPosition(this.position, this.alignment);
 
-  }, {
-    key: '_onPostEqualized',
-    value: function _onPostEqualized(e) {
-      if (e.target !== this.$element[0]) {
-        this._reflow();
-      }
+      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);
     }
-
-    /**
-     * Initializes events for Equalizer.
-     * @private
-     */
-
   }, {
-    key: '_events',
-    value: function _events() {
-      var _this = this;
-      this._pauseEvents();
-      if (this.hasNested) {
-        this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);
-      } else {
-        this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);
-        this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);
-      }
-      this.isOn = true;
+    key: "_addTriedPosition",
+    value: function _addTriedPosition(position, alignment) {
+      this.triedPositions[position] = this.triedPositions[position] || [];
+      this.triedPositions[position].push(alignment);
     }
-
-    /**
-     * Checks the current breakpoint to the minimum required size.
-     * @private
-     */
-
   }, {
-    key: '_checkMQ',
-    value: function _checkMQ() {
-      var tooSmall = !__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */].is(this.options.equalizeOn);
-      if (tooSmall) {
-        if (this.isOn) {
-          this._pauseEvents();
-          this.$watched.css('height', 'auto');
-        }
-      } else {
-        if (!this.isOn) {
-          this._events();
-        }
-      }
-      return tooSmall;
-    }
+    key: "_positionsExhausted",
+    value: function _positionsExhausted() {
+      var isExhausted = true;
 
-    /**
-     * A noop version for the plugin
-     * @private
-     */
+      for (var i = 0; i < POSITIONS.length; i++) {
+        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);
+      }
 
-  }, {
-    key: '_killswitch',
-    value: function _killswitch() {
-      return;
+      return isExhausted;
     }
-
-    /**
-     * Calls necessary functions to update Equalizer upon DOM change
-     * @private
-     */
+  }, {
+    key: "_alignmentsExhausted",
+    value: function _alignmentsExhausted(position) {
+      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;
+    } // When we're trying to center, we don't want to apply offset that's going to
+    // take us just off center, so wrap around to return 0 for the appropriate
+    // offset in those alignments.  TODO: Figure out if we want to make this
+    // configurable behavior... it feels more intuitive, especially for tooltips, but
+    // it's possible someone might actually want to start from center and then nudge
+    // slightly off.
 
   }, {
-    key: '_reflow',
-    value: function _reflow() {
-      if (!this.options.equalizeOnStack) {
-        if (this._isStacked()) {
-          this.$watched.css('height', 'auto');
-          return false;
-        }
-      }
-      if (this.options.equalizeByRow) {
-        this.getHeightsByRow(this.applyHeightByRow.bind(this));
-      } else {
-        this.getHeights(this.applyHeight.bind(this));
-      }
+    key: "_getVOffset",
+    value: function _getVOffset() {
+      return this.options.vOffset;
     }
-
-    /**
-     * Manually determines if the first 2 elements are *NOT* stacked.
-     * @private
-     */
-
   }, {
-    key: '_isStacked',
-    value: function _isStacked() {
-      if (!this.$watched[0] || !this.$watched[1]) {
-        return true;
-      }
-      return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;
+    key: "_getHOffset",
+    value: function _getHOffset() {
+      return this.options.hOffset;
     }
-
-    /**
-     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
-     * @param {Function} cb - A non-optional callback to return the heights array to.
-     * @returns {Array} heights - An array of heights of children within Equalizer container
-     */
-
   }, {
-    key: 'getHeights',
-    value: function getHeights(cb) {
-      var heights = [];
-      for (var i = 0, len = this.$watched.length; i < len; i++) {
-        this.$watched[i].style.height = 'auto';
-        heights.push(this.$watched[i].offsetHeight);
+    key: "_setPosition",
+    value: function _setPosition($anchor, $element, $parent) {
+      if ($anchor.attr('aria-expanded') === 'false') {
+        return false;
       }
-      cb(heights);
-    }
 
-    /**
-     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
-     * @param {Function} cb - A non-optional callback to return the heights array to.
-     * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
-     */
+      var $eleDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetDimensions($element),
+          $anchorDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetDimensions($anchor);
 
-  }, {
-    key: 'getHeightsByRow',
-    value: function getHeightsByRow(cb) {
-      var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0,
-          groups = [],
-          group = 0;
-      //group by Row
-      groups[group] = [];
-      for (var i = 0, len = this.$watched.length; i < len; i++) {
-        this.$watched[i].style.height = 'auto';
-        //maybe could use this.$watched[i].offsetTop
-        var elOffsetTop = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.$watched[i]).offset().top;
-        if (elOffsetTop != lastElTopOffset) {
-          group++;
-          groups[group] = [];
-          lastElTopOffset = elOffsetTop;
-        }
-        groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]);
+      if (!this.options.allowOverlap) {
+        // restore original position & alignment before checking overlap
+        this.position = this.originalPosition;
+        this.alignment = this.originalAlignment;
       }
 
-      for (var j = 0, ln = groups.length; j < ln; j++) {
-        var heights = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(groups[j]).map(function () {
-          return this[1];
-        }).get();
-        var max = Math.max.apply(null, heights);
-        groups[j].push(max);
-      }
-      cb(groups);
-    }
+      $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
 
-    /**
-     * Changes the CSS height property of each child in an Equalizer parent to match the tallest
-     * @param {array} heights - An array of heights of children within Equalizer container
-     * @fires Equalizer#preequalized
-     * @fires Equalizer#postequalized
-     */
+      if (!this.options.allowOverlap) {
+        var overlaps = {};
+        var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better
 
-  }, {
-    key: 'applyHeight',
-    value: function applyHeight(heights) {
-      var max = Math.max.apply(null, heights);
-      /**
-       * Fires before the heights are applied
-       * @event Equalizer#preequalized
-       */
-      this.$element.trigger('preequalized.zf.equalizer');
+        var minCoordinates = {
+          position: this.position,
+          alignment: this.alignment
+        };
 
-      this.$watched.css('height', max);
+        while (!this._positionsExhausted()) {
+          var overlap = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
 
-      /**
-       * Fires when the heights have been applied
-       * @event Equalizer#postequalized
-       */
-      this.$element.trigger('postequalized.zf.equalizer');
-    }
+          if (overlap === 0) {
+            return;
+          }
 
-    /**
-     * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row
-     * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
-     * @fires Equalizer#preequalized
-     * @fires Equalizer#preequalizedrow
-     * @fires Equalizer#postequalizedrow
-     * @fires Equalizer#postequalized
-     */
+          if (overlap < minOverlap) {
+            minOverlap = overlap;
+            minCoordinates = {
+              position: this.position,
+              alignment: this.alignment
+            };
+          }
 
-  }, {
-    key: 'applyHeightByRow',
-    value: function applyHeightByRow(groups) {
-      /**
-       * Fires before the heights are applied
-       */
-      this.$element.trigger('preequalized.zf.equalizer');
-      for (var i = 0, len = groups.length; i < len; i++) {
-        var groupsILength = groups[i].length,
-            max = groups[i][groupsILength - 1];
-        if (groupsILength <= 2) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(groups[i][0][0]).css({ 'height': 'auto' });
-          continue;
-        }
-        /**
-          * Fires before the heights per row are applied
-          * @event Equalizer#preequalizedrow
-          */
-        this.$element.trigger('preequalizedrow.zf.equalizer');
-        for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(groups[i][j][0]).css({ 'height': max });
-        }
-        /**
-          * Fires when the heights per row have been applied
-          * @event Equalizer#postequalizedrow
-          */
-        this.$element.trigger('postequalizedrow.zf.equalizer');
-      }
-      /**
-       * Fires when the heights have been applied
-       */
-      this.$element.trigger('postequalized.zf.equalizer');
-    }
+          this._reposition();
 
-    /**
-     * Destroys an instance of Equalizer.
-     * @function
-     */
+          $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+        } // If we get through the entire loop, there was no non-overlapping
+        // position available. Pick the version with least overlap.
 
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this._pauseEvents();
-      this.$watched.css('height', 'auto');
+
+        this.position = minCoordinates.position;
+        this.alignment = minCoordinates.alignment;
+        $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+      }
     }
   }]);
 
-  return Equalizer;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["a" /* Plugin */]);
-
-/**
- * Default settings for plugin
- */
-
+  return Positionable;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 
-Equalizer.defaults = {
+Positionable.defaults = {
   /**
-   * Enable height equalization when stacked on smaller screens.
+   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.
    * @option
-   * @type {boolean}
-   * @default false
+   * @type {string}
+   * @default 'auto'
    */
-  equalizeOnStack: false,
+  position: 'auto',
+
   /**
-   * Enable height equalization row by row.
+   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.
    * @option
-   * @type {boolean}
-   * @default false
+   * @type {string}
+   * @default 'auto'
    */
-  equalizeByRow: false,
+  alignment: 'auto',
+
   /**
-   * String representing the minimum breakpoint size the plugin should equalize heights on.
+   * Allow overlap of container/window. If false, dropdown positionable first
+   * try to position as defined by data-position and data-alignment, but
+   * reposition if it would cause an overflow.
    * @option
-   * @type {string}
-   * @default ''
+   * @type {boolean}
+   * @default false
    */
-  equalizeOn: ''
-};
+  allowOverlap: false,
+
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  allowBottomOverlap: true,
+
+  /**
+   * Number of pixels the positionable should be separated vertically from anchor
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
 
+  /**
+   * Number of pixels the positionable should be separated horizontally from anchor
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0
+};
 
 
 /***/ }),
-/* 24 */
+
+/***/ "./js/foundation.responsiveAccordionTabs.js":
+/*!**************************************************!*\
+  !*** ./js/foundation.responsiveAccordionTabs.js ***!
+  \**************************************************/
+/*! exports provided: ResponsiveAccordionTabs */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Interchange; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(1);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveAccordionTabs", function() { return ResponsiveAccordionTabs; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.accordion */ "./js/foundation.accordion.js");
+/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.tabs */ "./js/foundation.tabs.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
-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 _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
 
 
 
+ // The plugin matches the plugin classes with these plugin instances.
+
+var MenuPlugins = {
+  tabs: {
+    cssClass: 'tabs',
+    plugin: _foundation_tabs__WEBPACK_IMPORTED_MODULE_5__["Tabs"]
+  },
+  accordion: {
+    cssClass: 'accordion',
+    plugin: _foundation_accordion__WEBPACK_IMPORTED_MODULE_4__["Accordion"]
+  }
+};
 /**
- * Interchange module.
- * @module foundation.interchange
- * @requires foundation.util.mediaQuery
+ * ResponsiveAccordionTabs module.
+ * @module foundation.responsiveAccordionTabs
+ * @requires foundation.util.motion
+ * @requires foundation.accordion
+ * @requires foundation.tabs
  */
 
-var Interchange = function (_Plugin) {
-  _inherits(Interchange, _Plugin);
+var ResponsiveAccordionTabs =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveAccordionTabs, _Plugin);
 
-  function Interchange() {
-    _classCallCheck(this, Interchange);
+  function ResponsiveAccordionTabs() {
+    _classCallCheck(this, ResponsiveAccordionTabs);
 
-    return _possibleConstructorReturn(this, (Interchange.__proto__ || Object.getPrototypeOf(Interchange)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveAccordionTabs).apply(this, arguments));
   }
 
-  _createClass(Interchange, [{
-    key: '_setup',
+  _createClass(ResponsiveAccordionTabs, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of Interchange.
+     * Creates a new instance of a responsive accordion tabs.
      * @class
-     * @name Interchange
-     * @fires Interchange#init
-     * @param {Object} element - jQuery object to add the trigger to.
+     * @name ResponsiveAccordionTabs
+     * @fires ResponsiveAccordionTabs#init
+     * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Interchange.defaults, options);
-      this.rules = [];
-      this.currentPath = '';
-      this.className = 'Interchange'; // ie9 back compat
+      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.$element.data(), options);
+      this.rules = this.$element.data('responsive-accordion-tabs');
+      this.currentMq = null;
+      this.currentPlugin = null;
+      this.className = 'ResponsiveAccordionTabs'; // ie9 back compat
+
+      if (!this.$element.attr('id')) {
+        this.$element.attr('id', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'responsiveaccordiontabs'));
+      }
+
+      ;
 
       this._init();
+
       this._events();
     }
-
     /**
-     * Initializes the Interchange plugin and calls functions to get interchange functioning on load.
+     * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.
      * @function
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
-
-      var id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["b" /* GetYoDigits */])(6, 'interchange');
-      this.$element.attr({
-        'data-resize': id,
-        'id': id
-      });
-
-      this._addBreakpoints();
-      this._generateRules();
-      this._reflow();
-    }
-
-    /**
-     * Initializes events for Interchange.
-     * @function
-     * @private
-     */
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
 
-  }, {
-    key: '_events',
-    value: function _events() {
-      var _this3 = this;
 
-      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () {
-        return _this3._reflow();
-      });
-    }
+      if (typeof this.rules === 'string') {
+        var rulesTree = {}; // Parse rules from "classes" pulled from data attribute
 
-    /**
-     * Calls necessary functions to update Interchange upon DOM change
-     * @function
-     * @private
-     */
+        var rules = this.rules.split(' '); // Iterate through every rule found
 
-  }, {
-    key: '_reflow',
-    value: function _reflow() {
-      var match;
+        for (var i = 0; i < rules.length; i++) {
+          var rule = rules[i].split('-');
+          var ruleSize = rule.length > 1 ? rule[0] : 'small';
+          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
 
-      // Iterate through each rule, but only save the last match
-      for (var i in this.rules) {
-        if (this.rules.hasOwnProperty(i)) {
-          var rule = this.rules[i];
-          if (window.matchMedia(rule.query).matches) {
-            match = rule;
+          if (MenuPlugins[rulePlugin] !== null) {
+            rulesTree[ruleSize] = MenuPlugins[rulePlugin];
           }
         }
+
+        this.rules = rulesTree;
       }
 
-      if (match) {
-        this.replace(match.path);
+      this._getAllOptions();
+
+      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) {
+        this._checkMediaQueries();
       }
     }
+  }, {
+    key: "_getAllOptions",
+    value: function _getAllOptions() {
+      //get all defaults and options
+      var _this = this;
+
+      _this.allOptions = {};
+
+      for (var key in MenuPlugins) {
+        if (MenuPlugins.hasOwnProperty(key)) {
+          var obj = MenuPlugins[key];
+
+          try {
+            var dummyPlugin = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<ul></ul>');
+            var tmpPlugin = new obj.plugin(dummyPlugin, _this.options);
+
+            for (var keyKey in tmpPlugin.options) {
+              if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {
+                var objObj = tmpPlugin.options[keyKey];
+                _this.allOptions[keyKey] = objObj;
+              }
+            }
 
+            tmpPlugin.destroy();
+          } catch (e) {}
+        }
+      }
+    }
     /**
-     * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.
+     * Initializes events for the Menu.
      * @function
      * @private
      */
 
   }, {
-    key: '_addBreakpoints',
-    value: function _addBreakpoints() {
-      for (var i in __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */].queries) {
-        if (__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */].queries.hasOwnProperty(i)) {
-          var query = __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */].queries[i];
-          Interchange.SPECIAL_QUERIES[query.name] = query.value;
-        }
-      }
+    key: "_events",
+    value: function _events() {
+      this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
     }
-
     /**
-     * Checks the Interchange element for the provided media query + content pairings
+     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
      * @function
      * @private
-     * @param {Object} element - jQuery object that is an Interchange instance
-     * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys
      */
 
   }, {
-    key: '_generateRules',
-    value: function _generateRules(element) {
-      var rulesList = [];
-      var rules;
-
-      if (this.options.rules) {
-        rules = this.options.rules;
-      } else {
-        rules = this.$element.data('interchange');
-      }
-
-      rules = typeof rules === 'string' ? rules.match(/\[.*?\]/g) : rules;
-
-      for (var i in rules) {
-        if (rules.hasOwnProperty(i)) {
-          var rule = rules[i].slice(1, -1).split(', ');
-          var path = rule.slice(0, -1).join('');
-          var query = rule[rule.length - 1];
+    key: "_checkMediaQueries",
+    value: function _checkMediaQueries() {
+      var matchedMq,
+          _this = this; // Iterate through each rule and find the last matching rule
 
-          if (Interchange.SPECIAL_QUERIES[query]) {
-            query = Interchange.SPECIAL_QUERIES[query];
-          }
 
-          rulesList.push({
-            path: path,
-            query: query
-          });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].atLeast(key)) {
+          matchedMq = key;
         }
-      }
+      }); // No match? No dice
 
-      this.rules = rulesList;
-    }
+      if (!matchedMq) return; // Plugin already initialized? We good
 
-    /**
-     * Update the `src` property of an image, or change the HTML of a container, to the specified path.
-     * @function
-     * @param {String} path - Path to the image or HTML partial.
-     * @fires Interchange#replaced
-     */
+      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes
 
-  }, {
-    key: 'replace',
-    value: function replace(path) {
-      if (this.currentPath === path) return;
+      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) {
+        _this.$element.removeClass(value.cssClass);
+      }); // Add the CSS class for the new plugin
 
-      var _this = this,
-          trigger = 'replaced.zf.interchange';
+      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin
 
-      // Replacing images
-      if (this.$element[0].nodeName === 'IMG') {
-        this.$element.attr('src', path).on('load', function () {
-          _this.currentPath = path;
-        }).trigger(trigger);
+      if (this.currentPlugin) {
+        //don't know why but on nested elements data zfPlugin get's lost
+        if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData);
+        this.currentPlugin.destroy();
       }
-      // Replacing background images
-      else if (path.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {
-          path = path.replace(/\(/g, '%28').replace(/\)/g, '%29');
-          this.$element.css({ 'background-image': 'url(' + path + ')' }).trigger(trigger);
-        }
-        // Replacing HTML
-        else {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.get(path, function (response) {
-              _this.$element.html(response).trigger(trigger);
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()(response).foundation();
-              _this.currentPath = path;
-            });
-          }
 
-      /**
-       * Fires when content in an Interchange element is done being loaded.
-       * @event Interchange#replaced
-       */
-      // this.$element.trigger('replaced.zf.interchange');
+      this._handleMarkup(this.rules[matchedMq].cssClass);
+
+      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+      this.storezfData = this.currentPlugin.$element.data('zfPlugin');
     }
+  }, {
+    key: "_handleMarkup",
+    value: function _handleMarkup(toSet) {
+      var _this = this,
+          fromString = 'accordion';
 
-    /**
-     * Destroys an instance of interchange.
-     * @function
-     */
+      var $panels = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + this.$element.attr('id') + ']');
+      if ($panels.length) fromString = 'tabs';
 
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$element.off('resizeme.zf.trigger');
-    }
-  }]);
+      if (fromString === toSet) {
+        return;
+      }
 
-  return Interchange;
-}(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__["a" /* Plugin */]);
+      ;
+      var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title';
+      var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel';
+      this.$element.removeAttr('role');
+      var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');
+      var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');
 
-/**
- * Default settings for plugin
- */
+      if (fromString === 'tabs') {
+        $panels = $panels.children('.' + tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');
+        $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');
+      } else {
+        $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');
+      }
 
+      ;
+      $panels.css({
+        display: '',
+        visibility: ''
+      });
+      $liHeads.css({
+        display: '',
+        visibility: ''
+      });
 
-Interchange.defaults = {
-  /**
-   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.
-   * @option
-   * @type {?array}
-   * @default null
-   */
-  rules: null
-};
+      if (toSet === 'accordion') {
+        $panels.each(function (key, value) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({
+            height: ''
+          });
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id="tabs-placeholder-' + _this.$element.attr('id') + '"></div>').detach();
+          $liHeads.addClass('accordion-item').attr('data-accordion-item', '');
+          $liHeadsA.addClass('accordion-title');
+        });
+      } else if (toSet === 'tabs') {
+        var $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']');
+        var $placeholder = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#tabs-placeholder-' + _this.$element.attr('id'));
 
-Interchange.SPECIAL_QUERIES = {
-  'landscape': 'screen and (orientation: landscape)',
-  'portrait': 'screen and (orientation: portrait)',
-  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'
-};
+        if ($placeholder.length) {
+          $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div class="tabs-content"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));
+          $placeholder.remove();
+        } else {
+          $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div class="tabs-content"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));
+        }
+
+        ;
+        $panels.each(function (key, value) {
+          var tempValue = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($tabsContent).addClass(tabsPanel);
+          var hash = $liHeadsA.get(key).hash.slice(1);
+          var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'accordion');
+
+          if (hash !== id) {
+            if (hash !== '') {
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash);
+            } else {
+              hash = id;
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash);
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href', jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);
+            }
+
+            ;
+          }
+
+          ;
+          var isActive = jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeads.get(key)).hasClass('is-active');
+
+          if (isActive) {
+            tempValue.addClass('is-active');
+          }
+
+          ;
+        });
+        $liHeads.addClass(tabsTitle);
+      }
+
+      ;
+    }
+    /**
+     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      if (this.currentPlugin) this.currentPlugin.destroy();
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
+    }
+  }]);
+
+  return ResponsiveAccordionTabs;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 
+ResponsiveAccordionTabs.defaults = {};
 
 
 /***/ }),
-/* 25 */
+
+/***/ "./js/foundation.responsiveMenu.js":
+/*!*****************************************!*\
+  !*** ./js/foundation.responsiveMenu.js ***!
+  \*****************************************/
+/*! exports provided: ResponsiveMenu */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Magellan; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_smoothScroll__ = __webpack_require__(16);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveMenu", function() { return ResponsiveMenu; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.dropdownMenu */ "./js/foundation.dropdownMenu.js");
+/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.drilldown */ "./js/foundation.drilldown.js");
+/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.accordionMenu */ "./js/foundation.accordionMenu.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(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 _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
+
+
+
+
+
+var MenuPlugins = {
+  dropdown: {
+    cssClass: 'dropdown',
+    plugin: _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_4__["DropdownMenu"]
+  },
+  drilldown: {
+    cssClass: 'drilldown',
+    plugin: _foundation_drilldown__WEBPACK_IMPORTED_MODULE_5__["Drilldown"]
+  },
+  accordion: {
+    cssClass: 'accordion-menu',
+    plugin: _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_6__["AccordionMenu"]
+  }
+}; // import "foundation.util.triggers.js";
+
 /**
- * Magellan module.
- * @module foundation.magellan
- * @requires foundation.smoothScroll
+ * ResponsiveMenu module.
+ * @module foundation.responsiveMenu
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
  */
 
-var Magellan = function (_Plugin) {
-  _inherits(Magellan, _Plugin);
+var ResponsiveMenu =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveMenu, _Plugin);
 
-  function Magellan() {
-    _classCallCheck(this, Magellan);
+  function ResponsiveMenu() {
+    _classCallCheck(this, ResponsiveMenu);
 
-    return _possibleConstructorReturn(this, (Magellan.__proto__ || Object.getPrototypeOf(Magellan)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveMenu).apply(this, arguments));
   }
 
-  _createClass(Magellan, [{
-    key: '_setup',
+  _createClass(ResponsiveMenu, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of Magellan.
+     * Creates a new instance of a responsive menu.
      * @class
-     * @name Magellan
-     * @fires Magellan#init
-     * @param {Object} element - jQuery object to add the trigger to.
+     * @name ResponsiveMenu
+     * @fires ResponsiveMenu#init
+     * @param {jQuery} element - jQuery object to make into a dropdown menu.
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Magellan.defaults, this.$element.data(), options);
-      this.className = 'Magellan'; // ie9 back compat
+      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);
+      this.rules = this.$element.data('responsive-menu');
+      this.currentMq = null;
+      this.currentPlugin = null;
+      this.className = 'ResponsiveMenu'; // ie9 back compat
 
       this._init();
-      this.calcPoints();
-    }
-
-    /**
-     * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.
-     * @private
-     */
-
-  }, {
-    key: '_init',
-    value: function _init() {
-      var id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["b" /* GetYoDigits */])(6, 'magellan');
-      var _this = this;
-      this.$targets = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-magellan-target]');
-      this.$links = this.$element.find('a');
-      this.$element.attr({
-        'data-resize': id,
-        'data-scroll': id,
-        'id': id
-      });
-      this.$active = __WEBPACK_IMPORTED_MODULE_0_jquery___default()();
-      this.scrollPos = parseInt(window.pageYOffset, 10);
 
       this._events();
     }
-
     /**
-     * Calculates an array of pixel values that are the demarcation lines between locations on the page.
-     * Can be invoked if new elements are added or the size of a location changes.
+     * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.
      * @function
+     * @private
      */
 
   }, {
-    key: 'calcPoints',
-    value: function calcPoints() {
-      var _this = this,
-          body = document.body,
-          html = document.documentElement;
+    key: "_init",
+    value: function _init() {
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
 
-      this.points = [];
-      this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));
-      this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));
 
-      this.$targets.each(function () {
-        var $tar = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            pt = Math.round($tar.offset().top - _this.options.threshold);
-        $tar.targetPoint = pt;
-        _this.points.push(pt);
-      });
-    }
+      if (typeof this.rules === 'string') {
+        var rulesTree = {}; // Parse rules from "classes" pulled from data attribute
 
-    /**
-     * Initializes events for Magellan.
-     * @private
-     */
+        var rules = this.rules.split(' '); // Iterate through every rule found
 
-  }, {
-    key: '_events',
-    value: function _events() {
-      var _this = this,
-          $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body'),
-          opts = {
-        duration: _this.options.animationDuration,
-        easing: _this.options.animationEasing
-      };
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).one('load', function () {
-        if (_this.options.deepLinking) {
-          if (location.hash) {
-            _this.scrollToLoc(location.hash);
+        for (var i = 0; i < rules.length; i++) {
+          var rule = rules[i].split('-');
+          var ruleSize = rule.length > 1 ? rule[0] : 'small';
+          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+
+          if (MenuPlugins[rulePlugin] !== null) {
+            rulesTree[ruleSize] = MenuPlugins[rulePlugin];
           }
         }
-        _this.calcPoints();
-        _this._updateActive();
-      });
 
-      this.$element.on({
-        'resizeme.zf.trigger': this.reflow.bind(this),
-        'scrollme.zf.trigger': this._updateActive.bind(this)
-      }).on('click.zf.magellan', 'a[href^="#"]', function (e) {
-        e.preventDefault();
-        var arrival = this.getAttribute('href');
-        _this.scrollToLoc(arrival);
-      });
+        this.rules = rulesTree;
+      }
 
-      this._deepLinkScroll = function (e) {
-        if (_this.options.deepLinking) {
-          _this.scrollToLoc(window.location.hash);
-        }
-      };
+      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) {
+        this._checkMediaQueries();
+      } // Add data-mutate since children may need it.
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('popstate', this._deepLinkScroll);
-    }
 
+      this.$element.attr('data-mutate', this.$element.attr('data-mutate') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'responsive-menu'));
+    }
     /**
-     * Function to scroll to a given location on the page.
-     * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'
+     * Initializes events for the Menu.
      * @function
+     * @private
      */
 
   }, {
-    key: 'scrollToLoc',
-    value: function scrollToLoc(loc) {
-      this._inTransition = true;
+    key: "_events",
+    value: function _events() {
       var _this = this;
 
-      var options = {
-        animationEasing: this.options.animationEasing,
-        animationDuration: this.options.animationDuration,
-        threshold: this.options.threshold,
-        offset: this.options.offset
-      };
-
-      __WEBPACK_IMPORTED_MODULE_3__foundation_smoothScroll__["a" /* SmoothScroll */].scrollToLoc(loc, options, function () {
-        _this._inTransition = false;
-        _this._updateActive();
-      });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () {
+        _this._checkMediaQueries();
+      }); // $(window).on('resize.zf.ResponsiveMenu', function() {
+      //   _this._checkMediaQueries();
+      // });
     }
-
     /**
-     * Calls necessary functions to update Magellan upon DOM change
+     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
      * @function
+     * @private
      */
 
   }, {
-    key: 'reflow',
-    value: function reflow() {
-      this.calcPoints();
-      this._updateActive();
-    }
+    key: "_checkMediaQueries",
+    value: function _checkMediaQueries() {
+      var matchedMq,
+          _this = this; // Iterate through each rule and find the last matching rule
+
+
+      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].atLeast(key)) {
+          matchedMq = key;
+        }
+      }); // No match? No dice
+
+      if (!matchedMq) return; // Plugin already initialized? We good
+
+      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes
 
+      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) {
+        _this.$element.removeClass(value.cssClass);
+      }); // Add the CSS class for the new plugin
+
+      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin
+
+      if (this.currentPlugin) this.currentPlugin.destroy();
+      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+    }
     /**
-     * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.
-     * @private
+     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
      * @function
-     * @fires Magellan#update
      */
 
   }, {
-    key: '_updateActive',
-    value: function _updateActive() /*evt, elem, scrollPos*/{
-      if (this._inTransition) {
-        return;
-      }
-      var winPos = /*scrollPos ||*/parseInt(window.pageYOffset, 10),
-          curIdx;
-
-      if (winPos + this.winHeight === this.docHeight) {
-        curIdx = this.points.length - 1;
-      } else if (winPos < this.points[0]) {
-        curIdx = undefined;
-      } else {
-        var isDown = this.scrollPos < winPos,
-            _this = this,
-            curVisible = this.points.filter(function (p, i) {
-          return isDown ? p - _this.options.offset <= winPos : p - _this.options.offset - _this.options.threshold <= winPos;
-        });
-        curIdx = curVisible.length ? curVisible.length - 1 : 0;
-      }
-
-      this.$active.removeClass(this.options.activeClass);
-      this.$active = this.$links.filter('[href="#' + this.$targets.eq(curIdx).data('magellan-target') + '"]').addClass(this.options.activeClass);
-
-      if (this.options.deepLinking) {
-        var hash = "";
-        if (curIdx != undefined) {
-          hash = this.$active[0].getAttribute('href');
-        }
-        if (hash !== window.location.hash) {
-          if (window.history.pushState) {
-            window.history.pushState(null, null, hash);
-          } else {
-            window.location.hash = hash;
-          }
-        }
-      }
-
-      this.scrollPos = winPos;
-      /**
-       * Fires when magellan is finished updating to the new active element.
-       * @event Magellan#update
-       */
-      this.$element.trigger('update.zf.magellan', [this.$active]);
-    }
-
-    /**
-     * Destroys an instance of Magellan and resets the url of the window.
-     * @function
-     */
-
-  }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
-      this.$element.off('.zf.trigger .zf.magellan').find('.' + this.options.activeClass).removeClass(this.options.activeClass);
-
-      if (this.options.deepLinking) {
-        var hash = this.$active[0].getAttribute('href');
-        window.location.hash.replace(hash, '');
-      }
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('popstate', this._deepLinkScroll);
+      this.currentPlugin.destroy();
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('.zf.ResponsiveMenu');
     }
   }]);
 
-  return Magellan;
-}(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__["a" /* Plugin */]);
-
-/**
- * Default settings for plugin
- */
-
-
-Magellan.defaults = {
-  /**
-   * Amount of time, in ms, the animated scrolling should take between locations.
-   * @option
-   * @type {number}
-   * @default 500
-   */
-  animationDuration: 500,
-  /**
-   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
-   * @option
-   * @type {string}
-   * @default 'linear'
-   * @see {@link https://api.jquery.com/animate|Jquery animate}
-   */
-  animationEasing: 'linear',
-  /**
-   * Number of pixels to use as a marker for location changes.
-   * @option
-   * @type {number}
-   * @default 50
-   */
-  threshold: 50,
-  /**
-   * Class applied to the active locations link on the magellan container.
-   * @option
-   * @type {string}
-   * @default 'is-active'
-   */
-  activeClass: 'is-active',
-  /**
-   * Allows the script to manipulate the url of the current page, and if supported, alter the history.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  deepLinking: false,
-  /**
-   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  offset: 0
-};
+  return ResponsiveMenu;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 
+ResponsiveMenu.defaults = {};
 
 
 /***/ }),
-/* 26 */
+
+/***/ "./js/foundation.responsiveToggle.js":
+/*!*******************************************!*\
+  !*** ./js/foundation.responsiveToggle.js ***!
+  \*******************************************/
+/*! exports provided: ResponsiveToggle */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return OffCanvas; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_triggers__ = __webpack_require__(5);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveToggle", function() { return ResponsiveToggle; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./js/foundation.util.motion.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-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 _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
 
 
 /**
- * OffCanvas module.
- * @module foundation.offcanvas
- * @requires foundation.util.keyboard
+ * ResponsiveToggle module.
+ * @module foundation.responsiveToggle
  * @requires foundation.util.mediaQuery
- * @requires foundation.util.triggers
+ * @requires foundation.util.motion
  */
 
-var OffCanvas = function (_Plugin) {
-  _inherits(OffCanvas, _Plugin);
+var ResponsiveToggle =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(ResponsiveToggle, _Plugin);
 
-  function OffCanvas() {
-    _classCallCheck(this, OffCanvas);
+  function ResponsiveToggle() {
+    _classCallCheck(this, ResponsiveToggle);
 
-    return _possibleConstructorReturn(this, (OffCanvas.__proto__ || Object.getPrototypeOf(OffCanvas)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveToggle).apply(this, arguments));
   }
 
-  _createClass(OffCanvas, [{
-    key: '_setup',
+  _createClass(ResponsiveToggle, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of an off-canvas wrapper.
+     * Creates a new instance of Tab Bar.
      * @class
-     * @name OffCanvas
-     * @fires OffCanvas#init
-     * @param {Object} element - jQuery object to initialize.
+     * @name ResponsiveToggle
+     * @fires ResponsiveToggle#init
+     * @param {jQuery} element - jQuery object to attach tab bar functionality to.
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
-      var _this3 = this;
-
-      this.className = 'OffCanvas'; // ie9 back compat
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, OffCanvas.defaults, this.$element.data(), options);
-      this.contentClasses = { base: [], reveal: [] };
-      this.$lastTrigger = __WEBPACK_IMPORTED_MODULE_0_jquery___default()();
-      this.$triggers = __WEBPACK_IMPORTED_MODULE_0_jquery___default()();
-      this.position = 'left';
-      this.$content = __WEBPACK_IMPORTED_MODULE_0_jquery___default()();
-      this.nested = !!this.options.nested;
-
-      // Defines the CSS transition/position classes of the off-canvas content container.
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(['push', 'overlap']).each(function (index, val) {
-        _this3.contentClasses.base.push('has-transition-' + val);
-      });
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(['left', 'right', 'top', 'bottom']).each(function (index, val) {
-        _this3.contentClasses.base.push('has-position-' + val);
-        _this3.contentClasses.reveal.push('has-reveal-' + val);
-      });
-
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_5__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
+      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
+      this.className = 'ResponsiveToggle'; // ie9 back compat
 
       this._init();
-      this._events();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('OffCanvas', {
-        'ESCAPE': 'close'
-      });
+      this._events();
     }
-
     /**
-     * Initializes the off-canvas wrapper by adding the exit overlay (if needed).
+     * Initializes the tab bar by finding the target element, toggling element, and running update().
      * @function
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      var id = this.$element.attr('id');
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init();
 
-      this.$element.attr('aria-hidden', 'true');
-
-      // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)
-      if (this.options.contentId) {
-        this.$content = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + this.options.contentId);
-      } else if (this.$element.siblings('[data-off-canvas-content]').length) {
-        this.$content = this.$element.siblings('[data-off-canvas-content]').first();
-      } else {
-        this.$content = this.$element.closest('[data-off-canvas-content]').first();
-      }
-
-      if (!this.options.contentId) {
-        // Assume that the off-canvas element is nested if it isn't a sibling of the content
-        this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;
-      } else if (this.options.contentId && this.options.nested === null) {
-        // Warning if using content ID without setting the nested option
-        // Once the element is nested it is required to work properly in this case
-        console.warn('Remember to use the nested option if using the content ID option!');
-      }
-
-      if (this.nested === true) {
-        // Force transition overlap if nested
-        this.options.transition = 'overlap';
-        // Remove appropriate classes if already assigned in markup
-        this.$element.removeClass('is-transition-push');
-      }
-
-      this.$element.addClass('is-transition-' + this.options.transition + ' is-closed');
-
-      // Find triggers that affect this element and add aria-expanded to them
-      this.$triggers = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id);
-
-      // Get position by checking for related CSS class
-      this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position;
+      var targetID = this.$element.data('responsive-toggle');
 
-      // Add an overlay over the content if necessary
-      if (this.options.contentOverlay === true) {
-        var overlay = document.createElement('div');
-        var overlayPosition = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';
-        overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);
-        this.$overlay = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(overlay);
-        if (overlayPosition === 'is-overlay-fixed') {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.$overlay).insertAfter(this.$element);
-        } else {
-          this.$content.append(this.$overlay);
-        }
+      if (!targetID) {
+        console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');
       }
 
-      this.options.isRevealed = this.options.isRevealed || new RegExp(this.options.revealClass, 'g').test(this.$element[0].className);
-
-      if (this.options.isRevealed === true) {
-        this.options.revealOn = this.options.revealOn || this.$element[0].className.match(/(reveal-for-medium|reveal-for-large)/g)[0].split('-')[2];
-        this._setMQChecker();
-      }
+      this.$targetMenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetID));
+      this.$toggler = this.$element.find('[data-toggle]').filter(function () {
+        var target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+        return target === targetID || target === "";
+      });
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.options, this.$targetMenu.data()); // If they were set, parse the animation classes
 
-      if (this.options.transitionTime) {
-        this.$element.css('transition-duration', this.options.transitionTime);
+      if (this.options.animate) {
+        var input = this.options.animate.split(' ');
+        this.animationIn = input[0];
+        this.animationOut = input[1] || null;
       }
 
-      // Initally remove all transition/position CSS classes from off-canvas content container.
-      this._removeContentClasses();
+      this._update();
     }
-
     /**
-     * Adds event handlers to the off-canvas wrapper and the exit overlay.
+     * Adds necessary event handlers for the tab bar to work.
      * @function
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
-      this.$element.off('.zf.trigger .zf.offcanvas').on({
-        'open.zf.trigger': this.open.bind(this),
-        'close.zf.trigger': this.close.bind(this),
-        'toggle.zf.trigger': this.toggle.bind(this),
-        'keydown.zf.offcanvas': this._handleKeyboard.bind(this)
-      });
+      var _this = this;
 
-      if (this.options.closeOnClick === true) {
-        var $target = this.options.contentOverlay ? this.$overlay : this.$content;
-        $target.on({ 'click.zf.offcanvas': this.close.bind(this) });
-      }
+      this._updateMqHandler = this._update.bind(this);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._updateMqHandler);
+      this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));
     }
-
     /**
-     * Applies event listener for elements that will reveal at certain breakpoints.
+     * Checks the current media query to determine if the tab bar should be visible or hidden.
+     * @function
      * @private
      */
 
   }, {
-    key: '_setMQChecker',
-    value: function _setMQChecker() {
-      var _this = this;
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', function () {
-        if (__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */].atLeast(_this.options.revealOn)) {
-          _this.reveal(true);
-        } else {
-          _this.reveal(false);
-        }
-      }).one('load.zf.offcanvas', function () {
-        if (__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */].atLeast(_this.options.revealOn)) {
-          _this.reveal(true);
+    key: "_update",
+    value: function _update() {
+      // Mobile
+      if (!_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].atLeast(this.options.hideFor)) {
+        this.$element.show();
+        this.$targetMenu.hide();
+      } // Desktop
+      else {
+          this.$element.hide();
+          this.$targetMenu.show();
         }
-      });
     }
-
     /**
-     * Removes the CSS transition/position classes of the off-canvas content container.
-     * Removing the classes is important when another off-canvas gets opened that uses the same content container.
-     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
-     * @private
+     * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.
+     * @function
+     * @fires ResponsiveToggle#toggled
      */
 
   }, {
-    key: '_removeContentClasses',
-    value: function _removeContentClasses(hasReveal) {
-      if (typeof hasReveal !== 'boolean') {
-        this.$content.removeClass(this.contentClasses.base.join(' '));
-      } else if (hasReveal === false) {
-        this.$content.removeClass('has-reveal-' + this.position);
-      }
-    }
+    key: "toggleMenu",
+    value: function toggleMenu() {
+      var _this2 = this;
 
-    /**
-     * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.
-     * Beforehand any transition/position class gets removed.
-     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.
-     * @private
-     */
+      if (!_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].atLeast(this.options.hideFor)) {
+        /**
+         * Fires when the element attached to the tab bar toggles.
+         * @event ResponsiveToggle#toggled
+         */
+        if (this.options.animate) {
+          if (this.$targetMenu.is(':hidden')) {
+            _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateIn(this.$targetMenu, this.animationIn, function () {
+              _this2.$element.trigger('toggled.zf.responsiveToggle');
 
-  }, {
-    key: '_addContentClasses',
-    value: function _addContentClasses(hasReveal) {
-      this._removeContentClasses(hasReveal);
-      if (typeof hasReveal !== 'boolean') {
-        this.$content.addClass('has-transition-' + this.options.transition + ' has-position-' + this.position);
-      } else if (hasReveal === true) {
-        this.$content.addClass('has-reveal-' + this.position);
+              _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
+            });
+          } else {
+            _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(this.$targetMenu, this.animationOut, function () {
+              _this2.$element.trigger('toggled.zf.responsiveToggle');
+            });
+          }
+        } else {
+          this.$targetMenu.toggle(0);
+          this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');
+          this.$element.trigger('toggled.zf.responsiveToggle');
+        }
       }
     }
-
-    /**
-     * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.
-     * @param {Boolean} isRevealed - true if element should be revealed.
-     * @function
-     */
-
   }, {
-    key: 'reveal',
-    value: function reveal(isRevealed) {
-      if (isRevealed) {
-        this.close();
-        this.isRevealed = true;
-        this.$element.attr('aria-hidden', 'false');
-        this.$element.off('open.zf.trigger toggle.zf.trigger');
-        this.$element.removeClass('is-closed');
-      } else {
-        this.isRevealed = false;
-        this.$element.attr('aria-hidden', 'true');
-        this.$element.off('open.zf.trigger toggle.zf.trigger').on({
-          'open.zf.trigger': this.open.bind(this),
-          'toggle.zf.trigger': this.toggle.bind(this)
-        });
-        this.$element.addClass('is-closed');
-      }
-      this._addContentClasses(isRevealed);
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.responsiveToggle');
+      this.$toggler.off('.zf.responsiveToggle');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._updateMqHandler);
     }
+  }]);
 
-    /**
-     * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.
-     * @private
-     */
+  return ResponsiveToggle;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 
-  }, {
-    key: '_stopScrolling',
-    value: function _stopScrolling(event) {
-      return false;
-    }
+ResponsiveToggle.defaults = {
+  /**
+   * The breakpoint after which the menu is always shown, and the tab bar is hidden.
+   * @option
+   * @type {string}
+   * @default 'medium'
+   */
+  hideFor: 'medium',
 
-    // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios
-    // Only really works for y, not sure how to extend to x or if we need to.
+  /**
+   * To decide if the toggle should be animated or not.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animate: false
+};
 
-  }, {
-    key: '_recordScrollable',
-    value: function _recordScrollable(event) {
-      var elem = this; // called from event handler context with this as elem
 
-      // If the element is scrollable (content overflows), then...
-      if (elem.scrollHeight !== elem.clientHeight) {
-        // If we're at the top, scroll down one pixel to allow scrolling up
-        if (elem.scrollTop === 0) {
-          elem.scrollTop = 1;
-        }
-        // If we're at the bottom, scroll up one pixel to allow scrolling down
-        if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {
-          elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;
-        }
-      }
-      elem.allowUp = elem.scrollTop > 0;
-      elem.allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight;
-      elem.lastY = event.originalEvent.pageY;
-    }
-  }, {
-    key: '_stopScrollPropagation',
-    value: function _stopScrollPropagation(event) {
-      var elem = this; // called from event handler context with this as elem
-      var up = event.pageY < elem.lastY;
-      var down = !up;
-      elem.lastY = event.pageY;
+/***/ }),
 
-      if (up && elem.allowUp || down && elem.allowDown) {
-        event.stopPropagation();
-      } else {
-        event.preventDefault();
-      }
-    }
+/***/ "./js/foundation.reveal.js":
+/*!*********************************!*\
+  !*** ./js/foundation.reveal.js ***!
+  \*********************************/
+/*! exports provided: Reveal */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-    /**
-     * Opens the off-canvas menu.
-     * @function
-     * @param {Object} event - Event object passed from listener.
-     * @param {jQuery} trigger - element that triggered the off-canvas to open.
-     * @fires OffCanvas#opened
-     */
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Reveal", function() { return Reveal; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.motion */ "./js/foundation.util.motion.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./foundation.util.touch */ "./js/foundation.util.touch.js");
 
-  }, {
-    key: 'open',
-    value: function open(event, trigger) {
-      if (this.$element.hasClass('is-open') || this.isRevealed) {
-        return;
-      }
-      var _this = this;
 
-      if (trigger) {
-        this.$lastTrigger = trigger;
-      }
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-      if (this.options.forceTo === 'top') {
-        window.scrollTo(0, 0);
-      } else if (this.options.forceTo === 'bottom') {
-        window.scrollTo(0, document.body.scrollHeight);
-      }
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-      if (this.options.transitionTime && this.options.transition !== 'overlap') {
-        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);
-      } else {
-        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');
-      }
+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); } }
 
-      /**
-       * Fires when the off-canvas menu opens.
-       * @event OffCanvas#opened
-       */
-      this.$element.addClass('is-open').removeClass('is-closed');
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-      this.$triggers.attr('aria-expanded', 'true');
-      this.$element.attr('aria-hidden', 'false').trigger('opened.zf.offcanvas');
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
-      this.$content.addClass('is-open-' + this.position);
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-      // If `contentScroll` is set to false, add class and disable scrolling on touch devices.
-      if (this.options.contentScroll === false) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);
-        this.$element.on('touchstart', this._recordScrollable);
-        this.$element.on('touchmove', this._stopScrollPropagation);
-      }
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-      if (this.options.contentOverlay === true) {
-        this.$overlay.addClass('is-visible');
-      }
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
-      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
-        this.$overlay.addClass('is-closable');
-      }
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-      if (this.options.autoFocus === true) {
-        this.$element.one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["c" /* transitionend */])(this.$element), function () {
-          if (!_this.$element.hasClass('is-open')) {
-            return; // exit if prematurely closed
-          }
-          var canvasFocus = _this.$element.find('[data-autofocus]');
-          if (canvasFocus.length) {
-            canvasFocus.eq(0).focus();
-          } else {
-            _this.$element.find('a, button').eq(0).focus();
-          }
-        });
-      }
 
-      if (this.options.trapFocus === true) {
-        this.$content.attr('tabindex', '-1');
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].trapFocus(this.$element);
-      }
 
-      this._addContentClasses();
-    }
 
-    /**
-     * Closes the off-canvas menu.
-     * @function
-     * @param {Function} cb - optional cb to fire after closure.
-     * @fires OffCanvas#closed
-     */
 
-  }, {
-    key: 'close',
-    value: function close(cb) {
-      if (!this.$element.hasClass('is-open') || this.isRevealed) {
-        return;
-      }
 
-      var _this = this;
 
-      this.$element.removeClass('is-open');
 
-      this.$element.attr('aria-hidden', 'true')
-      /**
-       * Fires when the off-canvas menu opens.
-       * @event OffCanvas#closed
-       */
-      .trigger('closed.zf.offcanvas');
 
-      this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');
+/**
+ * Reveal module.
+ * @module foundation.reveal
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.motion if using animations
+ */
 
-      // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.
-      if (this.options.contentScroll === false) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);
-        this.$element.off('touchstart', this._recordScrollable);
-        this.$element.off('touchmove', this._stopScrollPropagation);
-      }
+var Reveal =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Reveal, _Plugin);
 
-      if (this.options.contentOverlay === true) {
-        this.$overlay.removeClass('is-visible');
-      }
+  function Reveal() {
+    _classCallCheck(this, Reveal);
 
-      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {
-        this.$overlay.removeClass('is-closable');
-      }
+    return _possibleConstructorReturn(this, _getPrototypeOf(Reveal).apply(this, arguments));
+  }
 
-      this.$triggers.attr('aria-expanded', 'false');
+  _createClass(Reveal, [{
+    key: "_setup",
 
-      if (this.options.trapFocus === true) {
-        this.$content.removeAttr('tabindex');
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].releaseFocus(this.$element);
-      }
+    /**
+     * Creates a new instance of Reveal.
+     * @class
+     * @name Reveal
+     * @param {jQuery} element - jQuery object to use for the modal.
+     * @param {Object} options - optional parameters.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Reveal.defaults, this.$element.data(), options);
+      this.className = 'Reveal'; // ie9 back compat
 
-      // Listen to transitionEnd and add class when done.
-      this.$element.one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["c" /* transitionend */])(this.$element), function (e) {
-        _this.$element.addClass('is-closed');
-        _this._removeContentClasses();
+      this._init(); // Triggers init is idempotent, just need to make sure it is initialized
+
+
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('Reveal', {
+        'ESCAPE': 'close'
       });
     }
-
     /**
-     * Toggles the off-canvas menu open or closed.
-     * @function
-     * @param {Object} event - Event object passed from listener.
-     * @param {jQuery} trigger - element that triggered the off-canvas to open.
+     * Initializes the modal by adding the overlay and close buttons, (if selected).
+     * @private
      */
 
   }, {
-    key: 'toggle',
-    value: function toggle(event, trigger) {
-      if (this.$element.hasClass('is-open')) {
-        this.close(event, trigger);
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"]._init();
+
+      this.id = this.$element.attr('id');
+      this.isActive = false;
+      this.cached = {
+        mq: _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"].current
+      };
+      this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(this.id, "\"]")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(this.id, "\"]")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat(this.id, "\"]"));
+      this.$anchor.attr({
+        'aria-controls': this.id,
+        'aria-haspopup': true,
+        'tabindex': 0
+      });
+
+      if (this.options.fullScreen || this.$element.hasClass('full')) {
+        this.options.fullScreen = true;
+        this.options.overlay = false;
+      }
+
+      if (this.options.overlay && !this.$overlay) {
+        this.$overlay = this._makeOverlay(this.id);
+      }
+
+      this.$element.attr({
+        'role': 'dialog',
+        'aria-hidden': true,
+        'data-yeti-box': this.id,
+        'data-resize': this.id
+      });
+
+      if (this.$overlay) {
+        this.$element.detach().appendTo(this.$overlay);
       } else {
-        this.open(event, trigger);
+        this.$element.detach().appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo));
+        this.$element.addClass('without-overlay');
       }
-    }
 
+      this._events();
+
+      if (this.options.deepLink && window.location.hash === "#".concat(this.id)) {
+        this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+          return _this2.open();
+        });
+      }
+    }
     /**
-     * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.
-     * @function
+     * Creates an overlay div to display behind the modal.
      * @private
      */
 
   }, {
-    key: '_handleKeyboard',
-    value: function _handleKeyboard(e) {
-      var _this4 = this;
+    key: "_makeOverlay",
+    value: function _makeOverlay() {
+      var additionalOverlayClasses = '';
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'OffCanvas', {
-        close: function () {
-          _this4.close();
-          _this4.$lastTrigger.focus();
-          return true;
-        },
-        handled: function () {
-          e.stopPropagation();
-          e.preventDefault();
-        }
-      });
-    }
+      if (this.options.additionalOverlayClasses) {
+        additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;
+      }
 
+      return jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div></div>').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo);
+    }
     /**
-     * Destroys the offcanvas plugin.
-     * @function
+     * Updates position of modal
+     * TODO:  Figure out if we actually need to cache these values or if it doesn't matter
+     * @private
      */
 
   }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.close();
-      this.$element.off('.zf.trigger .zf.offcanvas');
-      this.$overlay.off('.zf.offcanvas');
-    }
-  }]);
-
-  return OffCanvas;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["a" /* Plugin */]);
-
-OffCanvas.defaults = {
-  /**
-   * Allow the user to click outside of the menu to close it.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  closeOnClick: true,
+    key: "_updatePosition",
+    value: function _updatePosition() {
+      var width = this.$element.outerWidth();
+      var outerWidth = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).width();
+      var height = this.$element.outerHeight();
+      var outerHeight = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height();
+      var left,
+          top = null;
 
-  /**
-   * Adds an overlay on top of `[data-off-canvas-content]`.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  contentOverlay: true,
+      if (this.options.hOffset === 'auto') {
+        left = parseInt((outerWidth - width) / 2, 10);
+      } else {
+        left = parseInt(this.options.hOffset, 10);
+      }
 
-  /**
-   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.
-   * @option
-   * @type {?string}
-   * @default null
-   */
-  contentId: null,
+      if (this.options.vOffset === 'auto') {
+        if (height > outerHeight) {
+          top = parseInt(Math.min(100, outerHeight / 10), 10);
+        } else {
+          top = parseInt((outerHeight - height) / 4, 10);
+        }
+      } else if (this.options.vOffset !== null) {
+        top = parseInt(this.options.vOffset, 10);
+      }
 
-  /**
-   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.
-   * @option
-   * @type {boolean}
-   * @default null
-   */
-  nested: null,
+      if (top !== null) {
+        this.$element.css({
+          top: top + 'px'
+        });
+      } // only worry about left if we don't have an overlay or we have a horizontal offset,
+      // otherwise we're perfectly in the middle
 
-  /**
-   * Enable/disable scrolling of the main content when an off canvas panel is open.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  contentScroll: true,
 
-  /**
-   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.
-   * @option
-   * @type {number}
-   * @default null
-   */
-  transitionTime: null,
+      if (!this.$overlay || this.options.hOffset !== 'auto') {
+        this.$element.css({
+          left: left + 'px'
+        });
+        this.$element.css({
+          margin: '0px'
+        });
+      }
+    }
+    /**
+     * Adds event handlers for the modal.
+     * @private
+     */
 
-  /**
-   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.
-   * @option
-   * @type {string}
-   * @default push
-   */
-  transition: 'push',
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this3 = this;
 
-  /**
-   * Force the page to scroll to top or bottom on open.
-   * @option
-   * @type {?string}
-   * @default null
-   */
-  forceTo: null,
+      var _this = this;
 
-  /**
-   * Allow the offcanvas to remain open for certain breakpoints.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  isRevealed: false,
+      this.$element.on({
+        'open.zf.trigger': this.open.bind(this),
+        'close.zf.trigger': function closeZfTrigger(event, $element) {
+          if (event.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default()(event.target).parents('[data-closable]')[0] === $element) {
+            // only close reveal when it's explicitly called
+            return _this3.close.apply(_this3);
+          }
+        },
+        'toggle.zf.trigger': this.toggle.bind(this),
+        'resizeme.zf.trigger': function resizemeZfTrigger() {
+          _this._updatePosition();
+        }
+      });
 
-  /**
-   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.
-   * @option
-   * @type {?string}
-   * @default null
-   */
-  revealOn: null,
+      if (this.options.closeOnClick && this.options.overlay) {
+        this.$overlay.off('.zf.reveal').on('click.zf.reveal', function (e) {
+          if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) {
+            return;
+          }
 
-  /**
-   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  autoFocus: true,
+          _this.close();
+        });
+      }
 
-  /**
-   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.
-   * @option
-   * @type {string}
-   * @default reveal-for-
-   * @todo improve the regex testing for this.
-   */
-  revealClass: 'reveal-for-',
+      if (this.options.deepLink) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on("hashchange.zf.reveal:".concat(this.id), this._handleState.bind(this));
+      }
+    }
+    /**
+     * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.
+     * @private
+     */
 
-  /**
-   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  trapFocus: false
-};
+  }, {
+    key: "_handleState",
+    value: function _handleState(e) {
+      if (window.location.hash === '#' + this.id && !this.isActive) {
+        this.open();
+      } else {
+        this.close();
+      }
+    }
+    /**
+    * Disables the scroll when Reveal is shown to prevent the background from shifting
+    * @param {number} scrollTop - Scroll to visually apply, window current scroll by default
+    */
 
+  }, {
+    key: "_disableScroll",
+    value: function _disableScroll(scrollTop) {
+      scrollTop = scrollTop || jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop();
 
+      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top", -scrollTop);
+      }
+    }
+    /**
+    * Reenables the scroll when Reveal closes
+    * @param {number} scrollTop - Scroll to restore, html "top" property by default (as set by `_disableScroll`)
+    */
 
-/***/ }),
-/* 27 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+  }, {
+    key: "_enableScroll",
+    value: function _enableScroll(scrollTop) {
+      scrollTop = scrollTop || parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top"));
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Orbit; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_timer__ = __webpack_require__(18);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_imageLoader__ = __webpack_require__(8);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__foundation_util_touch__ = __webpack_require__(10);
+      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top", "");
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop(-scrollTop);
+      }
+    }
+    /**
+     * Opens the modal controlled by `this.$anchor`, and closes all others by default.
+     * @function
+     * @fires Reveal#closeme
+     * @fires Reveal#open
+     */
 
+  }, {
+    key: "open",
+    value: function open() {
+      var _this4 = this;
 
-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; }; }();
+      // either update or replace browser history
+      var hash = "#".concat(this.id);
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+      if (this.options.deepLink && window.location.hash !== hash) {
+        if (window.history.pushState) {
+          if (this.options.updateHistory) {
+            window.history.pushState({}, '', hash);
+          } else {
+            window.history.replaceState({}, '', hash);
+          }
+        } else {
+          window.location.hash = hash;
+        }
+      } // Remember anchor that opened it to set focus back later, have general anchors as fallback
 
-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; }
+      this.$activeAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement).is(this.$anchor) ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement) : this.$anchor;
+      this.isActive = true; // Make elements invisible, but remove display: none so we can get size and positioning
 
+      this.$element.css({
+        'visibility': 'hidden'
+      }).show().scrollTop(0);
 
+      if (this.options.overlay) {
+        this.$overlay.css({
+          'visibility': 'hidden'
+        }).show();
+      }
 
+      this._updatePosition();
 
+      this.$element.hide().css({
+        'visibility': ''
+      });
 
+      if (this.$overlay) {
+        this.$overlay.css({
+          'visibility': ''
+        }).hide();
 
+        if (this.$element.hasClass('fast')) {
+          this.$overlay.addClass('fast');
+        } else if (this.$element.hasClass('slow')) {
+          this.$overlay.addClass('slow');
+        }
+      }
 
+      if (!this.options.multipleOpened) {
+        /**
+         * Fires immediately before the modal opens.
+         * Closes any other modals that are currently open
+         * @event Reveal#closeme
+         */
+        this.$element.trigger('closeme.zf.reveal', this.id);
+      }
 
+      this._disableScroll();
 
+      var _this = this; // Motion UI method of reveal
 
-/**
- * Orbit module.
- * @module foundation.orbit
- * @requires foundation.util.keyboard
- * @requires foundation.util.motion
- * @requires foundation.util.timer
- * @requires foundation.util.imageLoader
- * @requires foundation.util.touch
- */
 
-var Orbit = function (_Plugin) {
-  _inherits(Orbit, _Plugin);
+      if (this.options.animationIn) {
+        var afterAnimation = function afterAnimation() {
+          _this.$element.attr({
+            'aria-hidden': false,
+            'tabindex': -1
+          }).focus();
 
-  function Orbit() {
-    _classCallCheck(this, Orbit);
+          _this._addGlobalClasses();
 
-    return _possibleConstructorReturn(this, (Orbit.__proto__ || Object.getPrototypeOf(Orbit)).apply(this, arguments));
-  }
+          _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].trapFocus(_this.$element);
+        };
 
-  _createClass(Orbit, [{
-    key: '_setup',
+        if (this.options.overlay) {
+          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__["Motion"].animateIn(this.$overlay, 'fade-in');
+        }
 
-    /**
-    * Creates a new instance of an orbit carousel.
-    * @class
-    * @name Orbit
-    * @param {jQuery} element - jQuery object to make into an Orbit Carousel.
-    * @param {Object} options - Overrides to the default plugin settings.
-    */
-    value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Orbit.defaults, this.$element.data(), options);
-      this.className = 'Orbit'; // ie9 back compat
+        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__["Motion"].animateIn(this.$element, this.options.animationIn, function () {
+          if (_this4.$element) {
+            // protect against object having been removed
+            _this4.focusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].findFocusable(_this4.$element);
+            afterAnimation();
+          }
+        });
+      } // jQuery method of reveal
+      else {
+          if (this.options.overlay) {
+            this.$overlay.show(0);
+          }
 
-      __WEBPACK_IMPORTED_MODULE_7__foundation_util_touch__["a" /* Touch */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a); // Touch init is idempotent, we just need to make sure it's initialied.
+          this.$element.show(this.options.showDelay);
+        } // handle accessibility
 
-      this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('Orbit', {
-        'ltr': {
-          'ARROW_RIGHT': 'next',
-          'ARROW_LEFT': 'previous'
-        },
-        'rtl': {
-          'ARROW_LEFT': 'next',
-          'ARROW_RIGHT': 'previous'
-        }
+      this.$element.attr({
+        'aria-hidden': false,
+        'tabindex': -1
+      }).focus();
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].trapFocus(this.$element);
+
+      this._addGlobalClasses();
+
+      this._addGlobalListeners();
+      /**
+       * Fires when the modal has successfully opened.
+       * @event Reveal#open
+       */
+
+
+      this.$element.trigger('open.zf.reveal');
+    }
+    /**
+     * Adds classes and listeners on document required by open modals.
+     *
+     * The following classes are added and updated:
+     * - `.is-reveal-open` - Prevents the scroll on document
+     * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the
+     *                       scroll was not disabled. This prevent a "shift" of the page content due
+     *                       the scrollbar disappearing when the modal opens.
+     *
+     * @private
+     */
+
+  }, {
+    key: "_addGlobalClasses",
+    value: function _addGlobalClasses() {
+      var updateScrollbarClass = function updateScrollbarClass() {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').toggleClass('zf-has-scroll', !!(jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()));
+      };
+
+      this.$element.on('resizeme.zf.trigger.revealScrollbarListener', function () {
+        return updateScrollbarClass();
       });
+      updateScrollbarClass();
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').addClass('is-reveal-open');
     }
+    /**
+     * Removes classes and listeners on document that were required by open modals.
+     * @private
+     */
 
+  }, {
+    key: "_removeGlobalClasses",
+    value: function _removeGlobalClasses() {
+      this.$element.off('resizeme.zf.trigger.revealScrollbarListener');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('is-reveal-open');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('zf-has-scroll');
+    }
     /**
-    * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.
-    * @function
-    * @private
-    */
+     * Adds extra event handlers for the body and window if necessary.
+     * @private
+     */
 
   }, {
-    key: '_init',
-    value: function _init() {
-      // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide
-      this._reset();
+    key: "_addGlobalListeners",
+    value: function _addGlobalListeners() {
+      var _this = this;
 
-      this.$wrapper = this.$element.find('.' + this.options.containerClass);
-      this.$slides = this.$element.find('.' + this.options.slideClass);
+      if (!this.$element) {
+        return;
+      } // If we're in the middle of cleanup, don't freak out
 
-      var $images = this.$element.find('img'),
-          initActive = this.$slides.filter('.is-active'),
-          id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_5__foundation_util_core__["b" /* GetYoDigits */])(6, 'orbit');
 
-      this.$element.attr({
-        'data-resize': id,
-        'id': id
-      });
+      this.focusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].findFocusable(this.$element);
 
-      if (!initActive.length) {
-        this.$slides.eq(0).addClass('is-active');
-      }
+      if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').on('click.zf.reveal', function (e) {
+          if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) {
+            return;
+          }
 
-      if (!this.options.useMUI) {
-        this.$slides.addClass('no-motionui');
+          _this.close();
+        });
       }
 
-      if ($images.length) {
-        __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_4__foundation_util_imageLoader__["a" /* onImagesLoaded */])($images, this._prepareForOrbit.bind(this));
-      } else {
-        this._prepareForOrbit(); //hehe
+      if (this.options.closeOnEsc) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('keydown.zf.reveal', function (e) {
+          _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'Reveal', {
+            close: function close() {
+              if (_this.options.closeOnEsc) {
+                _this.close();
+              }
+            }
+          });
+        });
       }
+    }
+    /**
+     * Closes the modal.
+     * @function
+     * @fires Reveal#closed
+     */
 
-      if (this.options.bullets) {
-        this._loadBullets();
+  }, {
+    key: "close",
+    value: function close() {
+      if (!this.isActive || !this.$element.is(':visible')) {
+        return false;
       }
 
-      this._events();
+      var _this = this; // Motion UI method of hiding
 
-      if (this.options.autoPlay && this.$slides.length > 1) {
-        this.geoSync();
+
+      if (this.options.animationOut) {
+        if (this.options.overlay) {
+          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__["Motion"].animateOut(this.$overlay, 'fade-out');
+        }
+
+        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__["Motion"].animateOut(this.$element, this.options.animationOut, finishUp);
+      } // jQuery method of hiding
+      else {
+          this.$element.hide(this.options.hideDelay);
+
+          if (this.options.overlay) {
+            this.$overlay.hide(0, finishUp);
+          } else {
+            finishUp();
+          }
+        } // Conditionals to remove extra event listeners added on open
+
+
+      if (this.options.closeOnEsc) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('keydown.zf.reveal');
       }
 
-      if (this.options.accessible) {
-        // allow wrapper to be focusable to enable arrow navigation
-        this.$wrapper.attr('tabindex', 0);
+      if (!this.options.overlay && this.options.closeOnClick) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').off('click.zf.reveal');
       }
-    }
 
-    /**
-    * Creates a jQuery collection of bullets, if they are being used.
-    * @function
-    * @private
-    */
+      this.$element.off('keydown.zf.reveal');
 
-  }, {
-    key: '_loadBullets',
-    value: function _loadBullets() {
-      this.$bullets = this.$element.find('.' + this.options.boxOfBullets).find('button');
-    }
+      function finishUp() {
+        // Get the current top before the modal is closed and restore the scroll after.
+        // TODO: use component properties instead of HTML properties
+        // See https://github.com/zurb/foundation-sites/pull/10786
+        var scrollTop = parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top"));
 
-    /**
-    * Sets a `timer` object on the orbit, and starts the counter for the next slide.
-    * @function
-    */
+        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) {
+          _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
 
-  }, {
-    key: 'geoSync',
-    value: function geoSync() {
-      var _this = this;
-      this.timer = new __WEBPACK_IMPORTED_MODULE_3__foundation_util_timer__["a" /* Timer */](this.$element, {
-        duration: this.options.timerDelay,
-        infinite: false
-      }, function () {
-        _this.changeSlide(true);
-      });
-      this.timer.start();
-    }
+        }
 
-    /**
-    * Sets wrapper and slide heights for the orbit.
-    * @function
-    * @private
-    */
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].releaseFocus(_this.$element);
 
-  }, {
-    key: '_prepareForOrbit',
-    value: function _prepareForOrbit() {
-      var _this = this;
-      this._setWrapperHeight();
-    }
+        _this.$element.attr('aria-hidden', true);
 
-    /**
-    * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.
-    * @function
-    * @private
-    * @param {Function} cb - a callback function to fire when complete.
-    */
+        _this._enableScroll(scrollTop);
+        /**
+        * Fires when the modal is done closing.
+        * @event Reveal#closed
+        */
 
-  }, {
-    key: '_setWrapperHeight',
-    value: function _setWrapperHeight(cb) {
-      //rewrite this to `for` loop
-      var max = 0,
-          temp,
-          counter = 0,
-          _this = this;
 
-      this.$slides.each(function () {
-        temp = this.getBoundingClientRect().height;
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).attr('data-slide', counter);
+        _this.$element.trigger('closed.zf.reveal');
+      }
+      /**
+      * Resets the modal content
+      * This prevents a running video to keep going in the background
+      */
 
-        if (!/mui/g.test(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {
-          //if not the active slide, set css position and display property
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).css({ 'position': 'relative', 'display': 'none' });
-        }
-        max = temp > max ? temp : max;
-        counter++;
-      });
 
-      if (counter === this.$slides.length) {
-        this.$wrapper.css({ 'height': max }); //only change the wrapper height property once.
-        if (cb) {
-          cb(max);
-        } //fire callback with max height dimension.
+      if (this.options.resetOnClose) {
+        this.$element.html(this.$element.html());
+      }
+
+      this.isActive = false; // If deepLink and we did not switched to an other modal...
+
+      if (_this.options.deepLink && window.location.hash === "#".concat(this.id)) {
+        // Remove the history hash
+        if (window.history.replaceState) {
+          var urlWithoutHash = window.location.pathname + window.location.search;
+
+          if (this.options.updateHistory) {
+            window.history.pushState({}, '', urlWithoutHash); // remove the hash
+          } else {
+            window.history.replaceState('', document.title, urlWithoutHash);
+          }
+        } else {
+          window.location.hash = '';
+        }
       }
-    }
 
+      this.$activeAnchor.focus();
+    }
     /**
-    * Sets the max-height of each slide.
-    * @function
-    * @private
-    */
+     * Toggles the open/closed state of a modal.
+     * @function
+     */
 
   }, {
-    key: '_setSlideHeight',
-    value: function _setSlideHeight(height) {
-      this.$slides.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).css('max-height', height);
-      });
+    key: "toggle",
+    value: function toggle() {
+      if (this.isActive) {
+        this.close();
+      } else {
+        this.open();
+      }
     }
+  }, {
+    key: "_destroy",
 
     /**
-    * Adds event listeners to basically everything within the element.
-    * @function
-    * @private
-    */
-
-  }, {
-    key: '_events',
-    value: function _events() {
-      var _this = this;
+     * Destroys an instance of a modal.
+     * @function
+     */
+    value: function _destroy() {
+      if (this.options.overlay) {
+        this.$element.appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()
 
-      //***************************************
-      //**Now using custom event - thanks to:**
-      //**      Yohai Ararat of Toronto      **
-      //***************************************
-      //
-      this.$element.off('.resizeme.zf.trigger').on({
-        'resizeme.zf.trigger': this._prepareForOrbit.bind(this)
-      });
-      if (this.$slides.length > 1) {
+        this.$overlay.hide().off().remove();
+      }
 
-        if (this.options.swipe) {
-          this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) {
-            e.preventDefault();
-            _this.changeSlide(true);
-          }).on('swiperight.zf.orbit', function (e) {
-            e.preventDefault();
-            _this.changeSlide(false);
-          });
-        }
-        //***************************************
+      this.$element.hide().off();
+      this.$anchor.off('.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(".zf.reveal:".concat(this.id));
+      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
 
-        if (this.options.autoPlay) {
-          this.$slides.on('click.zf.orbit', function () {
-            _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);
-            _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();
-          });
+      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) {
+        this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
 
-          if (this.options.pauseOnHover) {
-            this.$element.on('mouseenter.zf.orbit', function () {
-              _this.timer.pause();
-            }).on('mouseleave.zf.orbit', function () {
-              if (!_this.$element.data('clickedOn')) {
-                _this.timer.start();
-              }
-            });
-          }
-        }
+      }
+    }
+  }]);
 
-        if (this.options.navButtons) {
-          var $controls = this.$element.find('.' + this.options.nextClass + ', .' + this.options.prevClass);
-          $controls.attr('tabindex', 0)
-          //also need to handle enter/return and spacebar key presses
-          .on('click.zf.orbit touchend.zf.orbit', function (e) {
-            e.preventDefault();
-            _this.changeSlide(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).hasClass(_this.options.nextClass));
-          });
-        }
+  return Reveal;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__["Plugin"]);
 
-        if (this.options.bullets) {
-          this.$bullets.on('click.zf.orbit touchend.zf.orbit', function () {
-            if (/is-active/g.test(this.className)) {
-              return false;
-            } //if this is active, kick out of function.
-            var idx = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('slide'),
-                ltr = idx > _this.$slides.filter('.is-active').data('slide'),
-                $slide = _this.$slides.eq(idx);
+Reveal.defaults = {
+  /**
+   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  animationIn: '',
 
-            _this.changeSlide(ltr, $slide, idx);
-          });
-        }
+  /**
+   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  animationOut: '',
 
-        if (this.options.accessible) {
-          this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) {
-            // handle keyboard event with keyboard util
-            __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'Orbit', {
-              next: function () {
-                _this.changeSlide(true);
-              },
-              previous: function () {
-                _this.changeSlide(false);
-              },
-              handled: function () {
-                // if bullet is focused, make sure focus moves
-                if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).is(_this.$bullets)) {
-                  _this.$bullets.filter('.is-active').focus();
-                }
-              }
-            });
-          });
-        }
-      }
-    }
+  /**
+   * Time, in ms, to delay the opening of a modal after a click if no animation used.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  showDelay: 0,
 
-    /**
-     * Resets Orbit so it can be reinitialized
-     */
+  /**
+   * Time, in ms, to delay the closing of a modal after a click if no animation used.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hideDelay: 0,
 
-  }, {
-    key: '_reset',
-    value: function _reset() {
-      // Don't do anything if there are no slides (first run)
-      if (typeof this.$slides == 'undefined') {
-        return;
-      }
+  /**
+   * Allows a click on the body/overlay to close the modal.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnClick: true,
 
-      if (this.$slides.length > 1) {
-        // Remove old events
-        this.$element.off('.zf.orbit').find('*').off('.zf.orbit');
+  /**
+   * Allows the modal to close if the user presses the `ESCAPE` key.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  closeOnEsc: true,
 
-        // Restart timer if autoPlay is enabled
-        if (this.options.autoPlay) {
-          this.timer.restart();
-        }
+  /**
+   * If true, allows multiple modals to be displayed at once.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  multipleOpened: false,
 
-        // Reset all sliddes
-        this.$slides.each(function (el) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide();
-        });
+  /**
+   * Distance, in pixels, the modal should push down from the top of the screen.
+   * @option
+   * @type {number|string}
+   * @default auto
+   */
+  vOffset: 'auto',
 
-        // Show the first slide
-        this.$slides.first().addClass('is-active').show();
+  /**
+   * Distance, in pixels, the modal should push in from the side of the screen.
+   * @option
+   * @type {number|string}
+   * @default auto
+   */
+  hOffset: 'auto',
 
-        // Triggers when the slide has finished animating
-        this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);
+  /**
+   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  fullScreen: false,
 
-        // Select first bullet if bullets are present
-        if (this.options.bullets) {
-          this._updateBullets(0);
-        }
-      }
-    }
+  /**
+   * Allows the modal to generate an overlay div, which will cover the view when modal opens.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  overlay: true,
 
-    /**
-    * Changes the current slide to a new one.
-    * @function
-    * @param {Boolean} isLTR - flag if the slide should move left to right.
-    * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.
-    * @param {Number} idx - the index of the new slide in its collection, if one chosen.
-    * @fires Orbit#slidechange
-    */
+  /**
+   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  resetOnClose: false,
 
-  }, {
-    key: 'changeSlide',
-    value: function changeSlide(isLTR, chosenSlide, idx) {
-      if (!this.$slides) {
-        return;
-      } // Don't freak out if we're in the middle of cleanup
-      var $curSlide = this.$slides.filter('.is-active').eq(0);
+  /**
+   * Link the location hash to the modal.
+   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
 
-      if (/mui/g.test($curSlide[0].className)) {
-        return false;
-      } //if the slide is currently animating, kick out of the function
+  /**
+   * If `deepLink` is enabled, update the browser history with the open modal
+   * @option
+   * @default false
+   */
+  updateHistory: false,
 
-      var $firstSlide = this.$slides.first(),
-          $lastSlide = this.$slides.last(),
-          dirIn = isLTR ? 'Right' : 'Left',
-          dirOut = isLTR ? 'Left' : 'Right',
-          _this = this,
-          $newSlide;
+  /**
+  * Allows the modal to append to custom div.
+  * @option
+  * @type {string}
+  * @default "body"
+  */
+  appendTo: "body",
 
-      if (!chosenSlide) {
-        //most of the time, this will be auto played or clicked from the navButtons.
-        $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!
-        this.options.infiniteWrap ? $curSlide.next('.' + this.options.slideClass).length ? $curSlide.next('.' + this.options.slideClass) : $firstSlide : $curSlide.next('.' + this.options.slideClass) : //pick next slide if moving left to right
-        this.options.infiniteWrap ? $curSlide.prev('.' + this.options.slideClass).length ? $curSlide.prev('.' + this.options.slideClass) : $lastSlide : $curSlide.prev('.' + this.options.slideClass); //pick prev slide if moving right to left
-      } else {
-        $newSlide = chosenSlide;
-      }
+  /**
+   * Allows adding additional class names to the reveal overlay.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  additionalOverlayClasses: ''
+};
 
-      if ($newSlide.length) {
-        /**
-        * Triggers before the next slide starts animating in and only if a next slide has been found.
-        * @event Orbit#beforeslidechange
-        */
-        this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);
 
-        if (this.options.bullets) {
-          idx = idx || this.$slides.index($newSlide); //grab index to update bullets
-          this._updateBullets(idx);
-        }
+/***/ }),
 
-        if (this.options.useMUI && !this.$element.is(':hidden')) {
-          __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["a" /* Motion */].animateIn($newSlide.addClass('is-active').css({ 'position': 'absolute', 'top': 0 }), this.options['animInFrom' + dirIn], function () {
-            $newSlide.css({ 'position': 'relative', 'display': 'block' }).attr('aria-live', 'polite');
-          });
+/***/ "./js/foundation.slider.js":
+/*!*********************************!*\
+  !*** ./js/foundation.slider.js ***!
+  \*********************************/
+/*! exports provided: Slider */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-          __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["a" /* Motion */].animateOut($curSlide.removeClass('is-active'), this.options['animOutTo' + dirOut], function () {
-            $curSlide.removeAttr('aria-live');
-            if (_this.options.autoPlay && !_this.timer.isPaused) {
-              _this.timer.restart();
-            }
-            //do stuff?
-          });
-        } else {
-          $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();
-          $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();
-          if (this.options.autoPlay && !this.timer.isPaused) {
-            this.timer.restart();
-          }
-        }
-        /**
-        * Triggers when the slide has finished animating in.
-        * @event Orbit#slidechange
-        */
-        this.$element.trigger('slidechange.zf.orbit', [$newSlide]);
-      }
-    }
-
-    /**
-    * Updates the active state of the bullets, if displayed.
-    * @function
-    * @private
-    * @param {Number} idx - the index of the current slide.
-    */
-
-  }, {
-    key: '_updateBullets',
-    value: function _updateBullets(idx) {
-      var $oldBullet = this.$element.find('.' + this.options.boxOfBullets).find('.is-active').removeClass('is-active').blur(),
-          span = $oldBullet.find('span:last').detach(),
-          $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);
-    }
-
-    /**
-    * Destroys the carousel and hides the element.
-    * @function
-    */
-
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();
-    }
-  }]);
-
-  return Orbit;
-}(__WEBPACK_IMPORTED_MODULE_6__foundation_plugin__["a" /* Plugin */]);
-
-Orbit.defaults = {
-  /**
-  * Tells the JS to look for and loadBullets.
-  * @option
-   * @type {boolean}
-  * @default true
-  */
-  bullets: true,
-  /**
-  * Tells the JS to apply event listeners to nav buttons
-  * @option
-   * @type {boolean}
-  * @default true
-  */
-  navButtons: true,
-  /**
-  * motion-ui animation class to apply
-  * @option
-   * @type {string}
-  * @default 'slide-in-right'
-  */
-  animInFromRight: 'slide-in-right',
-  /**
-  * motion-ui animation class to apply
-  * @option
-   * @type {string}
-  * @default 'slide-out-right'
-  */
-  animOutToRight: 'slide-out-right',
-  /**
-  * motion-ui animation class to apply
-  * @option
-   * @type {string}
-  * @default 'slide-in-left'
-  *
-  */
-  animInFromLeft: 'slide-in-left',
-  /**
-  * motion-ui animation class to apply
-  * @option
-   * @type {string}
-  * @default 'slide-out-left'
-  */
-  animOutToLeft: 'slide-out-left',
-  /**
-  * Allows Orbit to automatically animate on page load.
-  * @option
-   * @type {boolean}
-  * @default true
-  */
-  autoPlay: true,
-  /**
-  * Amount of time, in ms, between slide transitions
-  * @option
-   * @type {number}
-  * @default 5000
-  */
-  timerDelay: 5000,
-  /**
-  * Allows Orbit to infinitely loop through the slides
-  * @option
-   * @type {boolean}
-  * @default true
-  */
-  infiniteWrap: true,
-  /**
-  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library
-  * @option
-   * @type {boolean}
-  * @default true
-  */
-  swipe: true,
-  /**
-  * Allows the timing function to pause animation on hover.
-  * @option
-   * @type {boolean}
-  * @default true
-  */
-  pauseOnHover: true,
-  /**
-  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys
-  * @option
-   * @type {boolean}
-  * @default true
-  */
-  accessible: true,
-  /**
-  * Class applied to the container of Orbit
-  * @option
-   * @type {string}
-  * @default 'orbit-container'
-  */
-  containerClass: 'orbit-container',
-  /**
-  * Class applied to individual slides.
-  * @option
-   * @type {string}
-  * @default 'orbit-slide'
-  */
-  slideClass: 'orbit-slide',
-  /**
-  * Class applied to the bullet container. You're welcome.
-  * @option
-   * @type {string}
-  * @default 'orbit-bullets'
-  */
-  boxOfBullets: 'orbit-bullets',
-  /**
-  * Class applied to the `next` navigation button.
-  * @option
-   * @type {string}
-  * @default 'orbit-next'
-  */
-  nextClass: 'orbit-next',
-  /**
-  * Class applied to the `previous` navigation button.
-  * @option
-   * @type {string}
-  * @default 'orbit-previous'
-  */
-  prevClass: 'orbit-previous',
-  /**
-  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatability.
-  * @option
-   * @type {boolean}
-  * @default true
-  */
-  useMUI: true
-};
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Slider", function() { return Slider; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./js/foundation.util.motion.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.touch */ "./js/foundation.util.touch.js");
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
 
 
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-/***/ }),
-/* 28 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
-
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return ResponsiveAccordionTabs; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_accordion__ = __webpack_require__(11);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_tabs__ = __webpack_require__(17);
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
 
-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 _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
-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 _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return 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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -8370,3419 +8688,4536 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
 
 
 
-// The plugin matches the plugin classes with these plugin instances.
-var MenuPlugins = {
-  tabs: {
-    cssClass: 'tabs',
-    plugin: __WEBPACK_IMPORTED_MODULE_5__foundation_tabs__["a" /* Tabs */]
-  },
-  accordion: {
-    cssClass: 'accordion',
-    plugin: __WEBPACK_IMPORTED_MODULE_4__foundation_accordion__["a" /* Accordion */]
-  }
-};
 
 /**
- * ResponsiveAccordionTabs module.
- * @module foundation.responsiveAccordionTabs
+ * Slider module.
+ * @module foundation.slider
  * @requires foundation.util.motion
- * @requires foundation.accordion
- * @requires foundation.tabs
+ * @requires foundation.util.triggers
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.touch
  */
 
-var ResponsiveAccordionTabs = function (_Plugin) {
-  _inherits(ResponsiveAccordionTabs, _Plugin);
+var Slider =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Slider, _Plugin);
 
-  function ResponsiveAccordionTabs() {
-    _classCallCheck(this, ResponsiveAccordionTabs);
+  function Slider() {
+    _classCallCheck(this, Slider);
 
-    return _possibleConstructorReturn(this, (ResponsiveAccordionTabs.__proto__ || Object.getPrototypeOf(ResponsiveAccordionTabs)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Slider).apply(this, arguments));
   }
 
-  _createClass(ResponsiveAccordionTabs, [{
-    key: '_setup',
+  _createClass(Slider, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of a responsive accordion tabs.
+     * Creates a new instance of a slider control.
      * @class
-     * @name ResponsiveAccordionTabs
-     * @fires ResponsiveAccordionTabs#init
-     * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.
+     * @name Slider
+     * @param {jQuery} element - jQuery object to make into a slider control.
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
-      this.$element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(element);
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, this.$element.data(), options);
-      this.rules = this.$element.data('responsive-accordion-tabs');
-      this.currentMq = null;
-      this.currentPlugin = null;
-      this.className = 'ResponsiveAccordionTabs'; // ie9 back compat
-      if (!this.$element.attr('id')) {
-        this.$element.attr('id', __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["b" /* GetYoDigits */])(6, 'responsiveaccordiontabs'));
-      };
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Slider.defaults, this.$element.data(), options);
+      this.className = 'Slider'; // ie9 back compat
+      // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.
+
+      _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__["Touch"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
       this._init();
-      this._events();
-    }
 
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('Slider', {
+        'ltr': {
+          'ARROW_RIGHT': 'increase',
+          'ARROW_UP': 'increase',
+          'ARROW_DOWN': 'decrease',
+          'ARROW_LEFT': 'decrease',
+          'SHIFT_ARROW_RIGHT': 'increase_fast',
+          'SHIFT_ARROW_UP': 'increase_fast',
+          'SHIFT_ARROW_DOWN': 'decrease_fast',
+          'SHIFT_ARROW_LEFT': 'decrease_fast',
+          'HOME': 'min',
+          'END': 'max'
+        },
+        'rtl': {
+          'ARROW_LEFT': 'increase',
+          'ARROW_RIGHT': 'decrease',
+          'SHIFT_ARROW_LEFT': 'increase_fast',
+          'SHIFT_ARROW_RIGHT': 'decrease_fast'
+        }
+      });
+    }
     /**
-     * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.
+     * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).
      * @function
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
-
-      // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
-      if (typeof this.rules === 'string') {
-        var rulesTree = {};
-
-        // Parse rules from "classes" pulled from data attribute
-        var rules = this.rules.split(' ');
+      this.inputs = this.$element.find('input');
+      this.handles = this.$element.find('[data-slider-handle]');
+      this.$handle = this.handles.eq(0);
+      this.$input = this.inputs.length ? this.inputs.eq(0) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(this.$handle.attr('aria-controls')));
+      this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);
 
-        // Iterate through every rule found
-        for (var i = 0; i < rules.length; i++) {
-          var rule = rules[i].split('-');
-          var ruleSize = rule.length > 1 ? rule[0] : 'small';
-          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+      var isDbl = false,
+          _this = this;
 
-          if (MenuPlugins[rulePlugin] !== null) {
-            rulesTree[ruleSize] = MenuPlugins[rulePlugin];
-          }
-        }
+      if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {
+        this.options.disabled = true;
+        this.$element.addClass(this.options.disabledClass);
+      }
 
-        this.rules = rulesTree;
+      if (!this.inputs.length) {
+        this.inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default()().add(this.$input);
+        this.options.binding = true;
       }
 
-      this._getAllOptions();
+      this._setInitAttr(0);
 
-      if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.isEmptyObject(this.rules)) {
-        this._checkMediaQueries();
-      }
-    }
-  }, {
-    key: '_getAllOptions',
-    value: function _getAllOptions() {
-      //get all defaults and options
-      var _this = this;
-      _this.allOptions = {};
-      for (var key in MenuPlugins) {
-        if (MenuPlugins.hasOwnProperty(key)) {
-          var obj = MenuPlugins[key];
-          try {
-            var dummyPlugin = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<ul></ul>');
-            var tmpPlugin = new obj.plugin(dummyPlugin, _this.options);
-            for (var keyKey in tmpPlugin.options) {
-              if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {
-                var objObj = tmpPlugin.options[keyKey];
-                _this.allOptions[keyKey] = objObj;
-              }
-            }
-            tmpPlugin.destroy();
-          } catch (e) {}
+      if (this.handles[1]) {
+        this.options.doubleSided = true;
+        this.$handle2 = this.handles.eq(1);
+        this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(this.$handle2.attr('aria-controls')));
+
+        if (!this.inputs[1]) {
+          this.inputs = this.inputs.add(this.$input2);
         }
-      }
-    }
 
-    /**
-     * Initializes events for the Menu.
-     * @function
-     * @private
-     */
+        isDbl = true; // this.$handle.triggerHandler('click.zf.slider');
 
-  }, {
-    key: '_events',
-    value: function _events() {
-      var _this = this;
+        this._setInitAttr(1);
+      } // Set handle positions
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', function () {
-        _this._checkMediaQueries();
-      });
-    }
 
-    /**
-     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
-     * @function
-     * @private
-     */
+      this.setHandles();
 
+      this._events();
+    }
   }, {
-    key: '_checkMediaQueries',
-    value: function _checkMediaQueries() {
-      var matchedMq,
-          _this = this;
-      // Iterate through each rule and find the last matching rule
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(this.rules, function (key) {
-        if (__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */].atLeast(key)) {
-          matchedMq = key;
-        }
-      });
-
-      // No match? No dice
-      if (!matchedMq) return;
+    key: "setHandles",
+    value: function setHandles() {
+      var _this2 = this;
 
-      // Plugin already initialized? We good
-      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;
+      if (this.handles[1]) {
+        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, function () {
+          _this2._setHandlePos(_this2.$handle2, _this2.inputs.eq(1).val(), true);
+        });
+      } else {
+        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);
+      }
+    }
+  }, {
+    key: "_reflow",
+    value: function _reflow() {
+      this.setHandles();
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)
+    */
 
-      // Remove existing plugin-specific CSS classes
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(MenuPlugins, function (key, value) {
-        _this.$element.removeClass(value.cssClass);
-      });
+  }, {
+    key: "_pctOfBar",
+    value: function _pctOfBar(value) {
+      var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start);
 
-      // Add the CSS class for the new plugin
-      this.$element.addClass(this.rules[matchedMq].cssClass);
+      switch (this.options.positionValueFunction) {
+        case "pow":
+          pctOfBar = this._logTransform(pctOfBar);
+          break;
 
-      // Create an instance of the new plugin
-      if (this.currentPlugin) {
-        //don't know why but on nested elements data zfPlugin get's lost
-        if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData);
-        this.currentPlugin.destroy();
+        case "log":
+          pctOfBar = this._powTransform(pctOfBar);
+          break;
       }
-      this._handleMarkup(this.rules[matchedMq].cssClass);
-      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
-      this.storezfData = this.currentPlugin.$element.data('zfPlugin');
+
+      return pctOfBar.toFixed(2);
     }
-  }, {
-    key: '_handleMarkup',
-    value: function _handleMarkup(toSet) {
-      var _this = this,
-          fromString = 'accordion';
-      var $panels = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-tabs-content=' + this.$element.attr('id') + ']');
-      if ($panels.length) fromString = 'tabs';
-      if (fromString === toSet) {
-        return;
-      };
+    /**
+    * @function
+    * @private
+    * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value
+    */
 
-      var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title';
-      var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel';
+  }, {
+    key: "_value",
+    value: function _value(pctOfBar) {
+      switch (this.options.positionValueFunction) {
+        case "pow":
+          pctOfBar = this._powTransform(pctOfBar);
+          break;
 
-      this.$element.removeAttr('role');
-      var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');
-      var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');
+        case "log":
+          pctOfBar = this._logTransform(pctOfBar);
+          break;
+      }
 
-      if (fromString === 'tabs') {
-        $panels = $panels.children('.' + tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');
-        $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');
-      } else {
-        $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');
-      };
+      var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);
+      return value;
+    }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function
+    */
 
-      $panels.css({ display: '', visibility: '' });
-      $liHeads.css({ display: '', visibility: '' });
-      if (toSet === 'accordion') {
-        $panels.each(function (key, value) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({ height: '' });
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id="tabs-placeholder-' + _this.$element.attr('id') + '"></div>').detach();
-          $liHeads.addClass('accordion-item').attr('data-accordion-item', '');
-          $liHeadsA.addClass('accordion-title');
-        });
-      } else if (toSet === 'tabs') {
-        var $tabsContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-tabs-content=' + _this.$element.attr('id') + ']');
-        var $placeholder = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#tabs-placeholder-' + _this.$element.attr('id'));
-        if ($placeholder.length) {
-          $tabsContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<div class="tabs-content"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));
-          $placeholder.remove();
-        } else {
-          $tabsContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<div class="tabs-content"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));
-        };
-        $panels.each(function (key, value) {
-          var tempValue = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).appendTo($tabsContent).addClass(tabsPanel);
-          var hash = $liHeadsA.get(key).hash.slice(1);
-          var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).attr('id') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["b" /* GetYoDigits */])(6, 'accordion');
-          if (hash !== id) {
-            if (hash !== '') {
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).attr('id', hash);
-            } else {
-              hash = id;
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).attr('id', hash);
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()($liHeadsA.get(key)).attr('href', __WEBPACK_IMPORTED_MODULE_0_jquery___default()($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);
-            };
-          };
-          var isActive = __WEBPACK_IMPORTED_MODULE_0_jquery___default()($liHeads.get(key)).hasClass('is-active');
-          if (isActive) {
-            tempValue.addClass('is-active');
-          };
-        });
-        $liHeads.addClass(tabsTitle);
-      };
+  }, {
+    key: "_logTransform",
+    value: function _logTransform(value) {
+      return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1);
     }
+    /**
+    * @function
+    * @private
+    * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function
+    */
 
+  }, {
+    key: "_powTransform",
+    value: function _powTransform(value) {
+      return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1);
+    }
     /**
-     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+     * Sets the position of the selected handle and fill bar.
      * @function
+     * @private
+     * @param {jQuery} $hndl - the selected handle to move.
+     * @param {Number} location - floating point between the start and end values of the slider bar.
+     * @param {Function} cb - callback function to fire on completion.
+     * @fires Slider#moved
+     * @fires Slider#changed
      */
 
   }, {
-    key: '_destroy',
-    value: function _destroy() {
-      if (this.currentPlugin) this.currentPlugin.destroy();
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('.zf.ResponsiveAccordionTabs');
-    }
-  }]);
-
-  return ResponsiveAccordionTabs;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["a" /* Plugin */]);
+    key: "_setHandlePos",
+    value: function _setHandlePos($hndl, location, noInvert, cb) {
+      // don't move if the slider has been disabled since its initialization
+      if (this.$element.hasClass(this.options.disabledClass)) {
+        return;
+      } //might need to alter that slightly for bars that will have odd number selections.
 
-ResponsiveAccordionTabs.defaults = {};
 
+      location = parseFloat(location); //on input change events, convert string to number...grumble.
+      // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max
 
+      if (location < this.options.start) {
+        location = this.options.start;
+      } else if (location > this.options.end) {
+        location = this.options.end;
+      }
 
-/***/ }),
-/* 29 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+      var isDbl = this.options.doubleSided; //this is for single-handled vertical sliders, it adjusts the value to account for the slider being "upside-down"
+      //for click and drag events, it's weird due to the scale(-1, 1) css property
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return ResponsiveMenu; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_dropdownMenu__ = __webpack_require__(14);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_drilldown__ = __webpack_require__(13);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_accordionMenu__ = __webpack_require__(12);
+      if (this.options.vertical && !noInvert) {
+        location = this.options.end - location;
+      }
 
+      if (isDbl) {
+        //this block is to prevent 2 handles from crossing eachother. Could/should be improved.
+        if (this.handles.index($hndl) === 0) {
+          var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));
+          location = location >= h2Val ? h2Val - this.options.step : location;
+        } else {
+          var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));
+          location = location <= h1Val ? h1Val + this.options.step : location;
+        }
+      }
 
-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; }; }();
+      var _this = this,
+          vert = this.options.vertical,
+          hOrW = vert ? 'height' : 'width',
+          lOrT = vert ? 'top' : 'left',
+          handleDim = $hndl[0].getBoundingClientRect()[hOrW],
+          elemDim = this.$element[0].getBoundingClientRect()[hOrW],
+          //percentage of bar min/max value based on click or drag point
+      pctOfBar = this._pctOfBar(location),
+          //number of actual pixels to shift the handle, based on the percentage obtained above
+      pxToMove = (elemDim - handleDim) * pctOfBar,
+          //percentage of bar to shift the handle
+      movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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; }
+      location = parseFloat(location.toFixed(this.options.decimal)); // declare empty object for css adjustments, only used with 2 handled-sliders
 
-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; }
+      var css = {};
 
+      this._setValues($hndl, location); // TODO update to calculate based on values set to respective inputs??
 
 
+      if (isDbl) {
+        var isLeftHndl = this.handles.index($hndl) === 0,
+            //empty variable, will be used for min-height/width for fill bar
+        dim,
+            //percentage w/h of the handle compared to the slider bar
+        handlePct = ~~(percent(handleDim, elemDim) * 100); //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar
 
+        if (isLeftHndl) {
+          //left or top percentage value to apply to the fill bar.
+          css[lOrT] = "".concat(movement, "%"); //calculate the new min-height/width for the fill bar.
 
+          dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider
+          //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.
 
+          if (cb && typeof cb === 'function') {
+            cb();
+          } //this is only needed for the initialization of 2 handled sliders
 
+        } else {
+          //just caching the value of the left/bottom handle's left/top property
+          var handlePos = parseFloat(this.$handle[0].style[lOrT]); //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0
+          //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself
 
+          dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct;
+        } // assign the min-height/width to our css object
 
 
+        css["min-".concat(hOrW)] = "".concat(dim, "%");
+      }
 
-var MenuPlugins = {
-  dropdown: {
-    cssClass: 'dropdown',
-    plugin: __WEBPACK_IMPORTED_MODULE_4__foundation_dropdownMenu__["a" /* DropdownMenu */]
-  },
-  drilldown: {
-    cssClass: 'drilldown',
-    plugin: __WEBPACK_IMPORTED_MODULE_5__foundation_drilldown__["a" /* Drilldown */]
-  },
-  accordion: {
-    cssClass: 'accordion-menu',
-    plugin: __WEBPACK_IMPORTED_MODULE_6__foundation_accordionMenu__["a" /* AccordionMenu */]
-  }
-};
+      this.$element.one('finished.zf.animate', function () {
+        /**
+         * Fires when the handle is done moving.
+         * @event Slider#moved
+         */
+        _this.$element.trigger('moved.zf.slider', [$hndl]);
+      }); //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.
 
-// import "foundation.util.triggers.js";
+      var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime;
+      Object(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Move"])(moveTime, $hndl, function () {
+        // adjusting the left/top property of the handle, based on the percentage calculated above
+        // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,
+        // fall back to next best guess.
+        if (isNaN(movement)) {
+          $hndl.css(lOrT, "".concat(pctOfBar * 100, "%"));
+        } else {
+          $hndl.css(lOrT, "".concat(movement, "%"));
+        }
 
+        if (!_this.options.doubleSided) {
+          //if single-handled, a simple method to expand the fill bar
+          _this.$fill.css(hOrW, "".concat(pctOfBar * 100, "%"));
+        } else {
+          //otherwise, use the css object we created above
+          _this.$fill.css(css);
+        }
+      });
+      /**
+       * Fires when the value has not been change for a given time.
+       * @event Slider#changed
+       */
 
-/**
- * ResponsiveMenu module.
- * @module foundation.responsiveMenu
- * @requires foundation.util.triggers
- * @requires foundation.util.mediaQuery
- */
-
-var ResponsiveMenu = function (_Plugin) {
-  _inherits(ResponsiveMenu, _Plugin);
-
-  function ResponsiveMenu() {
-    _classCallCheck(this, ResponsiveMenu);
-
-    return _possibleConstructorReturn(this, (ResponsiveMenu.__proto__ || Object.getPrototypeOf(ResponsiveMenu)).apply(this, arguments));
-  }
-
-  _createClass(ResponsiveMenu, [{
-    key: '_setup',
-
+      clearTimeout(_this.timeout);
+      _this.timeout = setTimeout(function () {
+        _this.$element.trigger('changed.zf.slider', [$hndl]);
+      }, _this.options.changedDelay);
+    }
     /**
-     * Creates a new instance of a responsive menu.
-     * @class
-     * @name ResponsiveMenu
-     * @fires ResponsiveMenu#init
-     * @param {jQuery} element - jQuery object to make into a dropdown menu.
-     * @param {Object} options - Overrides to the default plugin settings.
+     * Sets the initial attribute for the slider element.
+     * @function
+     * @private
+     * @param {Number} idx - index of the current handle/input to use.
      */
-    value: function _setup(element, options) {
-      this.$element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(element);
-      this.rules = this.$element.data('responsive-menu');
-      this.currentMq = null;
-      this.currentPlugin = null;
-      this.className = 'ResponsiveMenu'; // ie9 back compat
 
-      this._init();
-      this._events();
+  }, {
+    key: "_setInitAttr",
+    value: function _setInitAttr(idx) {
+      var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd;
+      var id = this.inputs.eq(idx).attr('id') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'slider');
+      this.inputs.eq(idx).attr({
+        'id': id,
+        'max': this.options.end,
+        'min': this.options.start,
+        'step': this.options.step
+      });
+      this.inputs.eq(idx).val(initVal);
+      this.handles.eq(idx).attr({
+        'role': 'slider',
+        'aria-controls': id,
+        'aria-valuemax': this.options.end,
+        'aria-valuemin': this.options.start,
+        'aria-valuenow': initVal,
+        'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',
+        'tabindex': 0
+      });
     }
+    /**
+     * Sets the input and `aria-valuenow` values for the slider element.
+     * @function
+     * @private
+     * @param {jQuery} $handle - the currently selected handle.
+     * @param {Number} val - floating point of the new value.
+     */
 
+  }, {
+    key: "_setValues",
+    value: function _setValues($handle, val) {
+      var idx = this.options.doubleSided ? this.handles.index($handle) : 0;
+      this.inputs.eq(idx).val(val);
+      $handle.attr('aria-valuenow', val);
+    }
     /**
-     * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.
+     * Handles events on the slider element.
+     * Calculates the new location of the current handle.
+     * If there are two handles and the bar was clicked, it determines which handle to move.
      * @function
      * @private
+     * @param {Object} e - the `event` object passed from the listener.
+     * @param {jQuery} $handle - the current handle to calculate for, if selected.
+     * @param {Number} val - floating point number for the new value of the slider.
+     * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.
      */
 
   }, {
-    key: '_init',
-    value: function _init() {
+    key: "_handleEvent",
+    value: function _handleEvent(e, $handle, val) {
+      var value, hasVal;
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
-      // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
-      if (typeof this.rules === 'string') {
-        var rulesTree = {};
+      if (!val) {
+        //click or drag events
+        e.preventDefault();
 
-        // Parse rules from "classes" pulled from data attribute
-        var rules = this.rules.split(' ');
+        var _this = this,
+            vertical = this.options.vertical,
+            param = vertical ? 'height' : 'width',
+            direction = vertical ? 'top' : 'left',
+            eventOffset = vertical ? e.pageY : e.pageX,
+            halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,
+            barDim = this.$element[0].getBoundingClientRect()[param],
+            windowScroll = vertical ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop() : jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollLeft();
 
-        // Iterate through every rule found
-        for (var i = 0; i < rules.length; i++) {
-          var rule = rules[i].split('-');
-          var ruleSize = rule.length > 1 ? rule[0] : 'small';
-          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
+        var elemOffset = this.$element.offset()[direction]; // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...
+        // best way to guess this is simulated is if clientY == pageY
 
-          if (MenuPlugins[rulePlugin] !== null) {
-            rulesTree[ruleSize] = MenuPlugins[rulePlugin];
-          }
+        if (e.clientY === e.pageY) {
+          eventOffset = eventOffset + windowScroll;
         }
 
-        this.rules = rulesTree;
-      }
+        var eventFromBar = eventOffset - elemOffset;
+        var barXY;
 
-      if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.isEmptyObject(this.rules)) {
-        this._checkMediaQueries();
-      }
-      // Add data-mutate since children may need it.
-      this.$element.attr('data-mutate', this.$element.attr('data-mutate') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["b" /* GetYoDigits */])(6, 'responsive-menu'));
-    }
+        if (eventFromBar < 0) {
+          barXY = 0;
+        } else if (eventFromBar > barDim) {
+          barXY = barDim;
+        } else {
+          barXY = eventFromBar;
+        }
 
-    /**
-     * Initializes events for the Menu.
-     * @function
-     * @private
-     */
+        var offsetPct = percent(barXY, barDim);
+        value = this._value(offsetPct); // turn everything around for RTL, yay math!
 
-  }, {
-    key: '_events',
-    value: function _events() {
-      var _this = this;
+        if (Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["rtl"])() && !this.options.vertical) {
+          value = this.options.end - value;
+        }
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', function () {
-        _this._checkMediaQueries();
-      });
-      // $(window).on('resize.zf.ResponsiveMenu', function() {
-      //   _this._checkMediaQueries();
-      // });
-    }
+        value = _this._adjustValue(null, value); //boolean flag for the setHandlePos fn, specifically for vertical sliders
+
+        hasVal = false;
+
+        if (!$handle) {
+          //figure out which handle it is, pass it to the next function.
+          var firstHndlPos = absPosition(this.$handle, direction, barXY, param),
+              secndHndlPos = absPosition(this.$handle2, direction, barXY, param);
+          $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;
+        }
+      } else {
+        //change event on input
+        value = this._adjustValue(null, val);
+        hasVal = true;
+      }
 
+      this._setHandlePos($handle, value, hasVal);
+    }
     /**
-     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
+     * Adjustes value for handle in regard to step value. returns adjusted value
      * @function
      * @private
+     * @param {jQuery} $handle - the selected handle.
+     * @param {Number} value - value to adjust. used if $handle is falsy
      */
 
   }, {
-    key: '_checkMediaQueries',
-    value: function _checkMediaQueries() {
-      var matchedMq,
-          _this = this;
-      // Iterate through each rule and find the last matching rule
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(this.rules, function (key) {
-        if (__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */].atLeast(key)) {
-          matchedMq = key;
-        }
-      });
+    key: "_adjustValue",
+    value: function _adjustValue($handle, value) {
+      var val,
+          step = this.options.step,
+          div = parseFloat(step / 2),
+          left,
+          prev_val,
+          next_val;
 
-      // No match? No dice
-      if (!matchedMq) return;
+      if (!!$handle) {
+        val = parseFloat($handle.attr('aria-valuenow'));
+      } else {
+        val = value;
+      }
 
-      // Plugin already initialized? We good
-      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;
+      if (val >= 0) {
+        left = val % step;
+      } else {
+        left = step + val % step;
+      }
 
-      // Remove existing plugin-specific CSS classes
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(MenuPlugins, function (key, value) {
-        _this.$element.removeClass(value.cssClass);
-      });
+      prev_val = val - left;
+      next_val = prev_val + step;
 
-      // Add the CSS class for the new plugin
-      this.$element.addClass(this.rules[matchedMq].cssClass);
+      if (left === 0) {
+        return val;
+      }
 
-      // Create an instance of the new plugin
-      if (this.currentPlugin) this.currentPlugin.destroy();
-      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
+      val = val >= prev_val + div ? next_val : prev_val;
+      return val;
     }
-
     /**
-     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
+     * Adds event listeners to the slider elements.
      * @function
+     * @private
      */
 
   }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.currentPlugin.destroy();
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('.zf.ResponsiveMenu');
-    }
-  }]);
+    key: "_events",
+    value: function _events() {
+      this._eventsForHandle(this.$handle);
 
-  return ResponsiveMenu;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["a" /* Plugin */]);
+      if (this.handles[1]) {
+        this._eventsForHandle(this.$handle2);
+      }
+    }
+    /**
+     * Adds event listeners a particular handle
+     * @function
+     * @private
+     * @param {jQuery} $handle - the current handle to apply listeners to.
+     */
 
-ResponsiveMenu.defaults = {};
+  }, {
+    key: "_eventsForHandle",
+    value: function _eventsForHandle($handle) {
+      var _this = this,
+          curHandle,
+          timer;
 
+      var handleChangeEvent = function handleChangeEvent(e) {
+        var idx = _this.inputs.index(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
 
+        _this._handleEvent(e, _this.handles.eq(idx), jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val());
+      }; // IE only triggers the change event when the input loses focus which strictly follows the HTML specification
+      // listen for the enter key and trigger a change
+      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events
 
-/***/ }),
-/* 30 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return ResponsiveToggle; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
+      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {
+        if (e.keyCode == 13) handleChangeEvent.call(this, e);
+      });
+      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);
 
+      if (this.options.clickSelect) {
+        this.$element.off('click.zf.slider').on('click.zf.slider', function (e) {
+          if (_this.$element.data('dragging')) {
+            return false;
+          }
 
-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; }; }();
+          if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is('[data-slider-handle]')) {
+            if (_this.options.doubleSided) {
+              _this._handleEvent(e);
+            } else {
+              _this._handleEvent(e, _this.$handle);
+            }
+          }
+        });
+      }
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+      if (this.options.draggable) {
+        this.handles.addTouch();
+        var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');
+        $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) {
+          $handle.addClass('is-dragging');
 
-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; }
+          _this.$fill.addClass('is-dragging'); //
 
-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; }
 
+          _this.$element.data('dragging', true);
 
+          curHandle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget);
+          $body.on('mousemove.zf.slider', function (e) {
+            e.preventDefault();
 
+            _this._handleEvent(e, curHandle);
+          }).on('mouseup.zf.slider', function (e) {
+            _this._handleEvent(e, curHandle);
 
+            $handle.removeClass('is-dragging');
 
+            _this.$fill.removeClass('is-dragging');
 
+            _this.$element.data('dragging', false);
 
-/**
- * ResponsiveToggle module.
- * @module foundation.responsiveToggle
- * @requires foundation.util.mediaQuery
- * @requires foundation.util.motion
- */
-
-var ResponsiveToggle = function (_Plugin) {
-  _inherits(ResponsiveToggle, _Plugin);
-
-  function ResponsiveToggle() {
-    _classCallCheck(this, ResponsiveToggle);
-
-    return _possibleConstructorReturn(this, (ResponsiveToggle.__proto__ || Object.getPrototypeOf(ResponsiveToggle)).apply(this, arguments));
-  }
-
-  _createClass(ResponsiveToggle, [{
-    key: '_setup',
-
-    /**
-     * Creates a new instance of Tab Bar.
-     * @class
-     * @name ResponsiveToggle
-     * @fires ResponsiveToggle#init
-     * @param {jQuery} element - jQuery object to attach tab bar functionality to.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    value: function _setup(element, options) {
-      this.$element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(element);
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
-      this.className = 'ResponsiveToggle'; // ie9 back compat
-
-      this._init();
-      this._events();
-    }
-
-    /**
-     * Initializes the tab bar by finding the target element, toggling element, and running update().
-     * @function
-     * @private
-     */
-
-  }, {
-    key: '_init',
-    value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
-      var targetID = this.$element.data('responsive-toggle');
-      if (!targetID) {
-        console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');
+            $body.off('mousemove.zf.slider mouseup.zf.slider');
+          });
+        }) // prevent events triggered by touch
+        .on('selectstart.zf.slider touchmove.zf.slider', function (e) {
+          e.preventDefault();
+        });
       }
 
-      this.$targetMenu = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + targetID);
-      this.$toggler = this.$element.find('[data-toggle]').filter(function () {
-        var target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
-        return target === targetID || target === "";
-      });
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, this.options, this.$targetMenu.data());
+      $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) {
+        var _$handle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,
+            oldValue = parseFloat(_this.inputs.eq(idx).val()),
+            newValue; // handle keyboard event with keyboard util
 
-      // If they were set, parse the animation classes
-      if (this.options.animate) {
-        var input = this.options.animate.split(' ');
 
-        this.animationIn = input[0];
-        this.animationOut = input[1] || null;
-      }
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'Slider', {
+          decrease: function decrease() {
+            newValue = oldValue - _this.options.step;
+          },
+          increase: function increase() {
+            newValue = oldValue + _this.options.step;
+          },
+          decrease_fast: function decrease_fast() {
+            newValue = oldValue - _this.options.step * 10;
+          },
+          increase_fast: function increase_fast() {
+            newValue = oldValue + _this.options.step * 10;
+          },
+          min: function min() {
+            newValue = _this.options.start;
+          },
+          max: function max() {
+            newValue = _this.options.end;
+          },
+          handled: function handled() {
+            // only set handle pos when event was handled specially
+            e.preventDefault();
 
-      this._update();
+            _this._setHandlePos(_$handle, newValue, true);
+          }
+        });
+        /*if (newValue) { // if pressed key has special function, update value
+          e.preventDefault();
+          _this._setHandlePos(_$handle, newValue);
+        }*/
+      });
     }
-
     /**
-     * Adds necessary event handlers for the tab bar to work.
-     * @function
-     * @private
+     * Destroys the slider plugin.
      */
 
   }, {
-    key: '_events',
-    value: function _events() {
-      var _this = this;
-
-      this._updateMqHandler = this._update.bind(this);
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', this._updateMqHandler);
-
-      this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));
+    key: "_destroy",
+    value: function _destroy() {
+      this.handles.off('.zf.slider');
+      this.inputs.off('.zf.slider');
+      this.$element.off('.zf.slider');
+      clearTimeout(this.timeout);
     }
+  }]);
 
-    /**
-     * Checks the current media query to determine if the tab bar should be visible or hidden.
-     * @function
-     * @private
-     */
-
-  }, {
-    key: '_update',
-    value: function _update() {
-      // Mobile
-      if (!__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */].atLeast(this.options.hideFor)) {
-        this.$element.show();
-        this.$targetMenu.hide();
-      }
+  return Slider;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__["Plugin"]);
 
-      // Desktop
-      else {
-          this.$element.hide();
-          this.$targetMenu.show();
-        }
-    }
+Slider.defaults = {
+  /**
+   * Minimum value for the slider scale.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  start: 0,
 
-    /**
-     * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.
-     * @function
-     * @fires ResponsiveToggle#toggled
-     */
+  /**
+   * Maximum value for the slider scale.
+   * @option
+   * @type {number}
+   * @default 100
+   */
+  end: 100,
 
-  }, {
-    key: 'toggleMenu',
-    value: function toggleMenu() {
-      var _this3 = this;
+  /**
+   * Minimum value change per change event.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  step: 1,
 
-      if (!__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */].atLeast(this.options.hideFor)) {
-        /**
-         * Fires when the element attached to the tab bar toggles.
-         * @event ResponsiveToggle#toggled
-         */
-        if (this.options.animate) {
-          if (this.$targetMenu.is(':hidden')) {
-            __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["a" /* Motion */].animateIn(this.$targetMenu, this.animationIn, function () {
-              _this3.$element.trigger('toggled.zf.responsiveToggle');
-              _this3.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
-            });
-          } else {
-            __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["a" /* Motion */].animateOut(this.$targetMenu, this.animationOut, function () {
-              _this3.$element.trigger('toggled.zf.responsiveToggle');
-            });
-          }
-        } else {
-          this.$targetMenu.toggle(0);
-          this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');
-          this.$element.trigger('toggled.zf.responsiveToggle');
-        }
-      }
-    }
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$element.off('.zf.responsiveToggle');
-      this.$toggler.off('.zf.responsiveToggle');
+  /**
+   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  initialStart: 0,
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('changed.zf.mediaquery', this._updateMqHandler);
-    }
-  }]);
+  /**
+   * Value at which the right handle/second input should be set to on initialization.
+   * @option
+   * @type {number}
+   * @default 100
+   */
+  initialEnd: 100,
 
-  return ResponsiveToggle;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["a" /* Plugin */]);
+  /**
+   * Allows the input to be located outside the container and visible. Set to by the JS
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  binding: false,
 
-ResponsiveToggle.defaults = {
   /**
-   * The breakpoint after which the menu is always shown, and the tab bar is hidden.
+   * Allows the user to click/tap on the slider bar to select a value.
    * @option
-   * @type {string}
-   * @default 'medium'
+   * @type {boolean}
+   * @default true
    */
-  hideFor: 'medium',
+  clickSelect: true,
 
   /**
-   * To decide if the toggle should be animated or not.
+   * Set to true and use the `vertical` class to change alignment to vertical.
    * @option
    * @type {boolean}
    * @default false
    */
-  animate: false
-};
+  vertical: false,
 
+  /**
+   * Allows the user to drag the slider handle(s) to select a value.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  draggable: true,
 
+  /**
+   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disabled: false,
 
-/***/ }),
-/* 31 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+  /**
+   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  doubleSided: false,
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Reveal; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_triggers__ = __webpack_require__(5);
+  /**
+   * Potential future feature.
+   */
+  // steps: 100,
 
+  /**
+   * Number of decimal places the plugin should go to for floating point precision.
+   * @option
+   * @type {number}
+   * @default 2
+   */
+  decimal: 2,
 
-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; }; }();
+  /**
+   * Time delay for dragged elements.
+   */
+  // dragDelay: 0,
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+  /**
+   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.
+   * @option
+   * @type {number}
+   * @default 200
+   */
+  moveTime: 200,
+  //update this if changing the transition time in the sass
 
-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; }
+  /**
+   * Class applied to disabled sliders.
+   * @option
+   * @type {string}
+   * @default 'disabled'
+   */
+  disabledClass: 'disabled',
 
-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; }
+  /**
+   * Will invert the default layout for a vertical<span data-tooltip title="who would do this???"> </span>slider.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  invertVertical: false,
+
+  /**
+   * Milliseconds before the `changed.zf-slider` event is triggered after value change.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  changedDelay: 500,
+
+  /**
+  * Basevalue for non-linear sliders
+  * @option
+  * @type {number}
+  * @default 5
+  */
+  nonLinearBase: 5,
+
+  /**
+  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.
+  * @option
+  * @type {string}
+  * @default 'linear'
+  */
+  positionValueFunction: 'linear'
+};
 
+function percent(frac, num) {
+  return frac / num;
+}
+
+function absPosition($handle, dir, clickPos, param) {
+  return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos);
+}
+
+function baseLog(base, value) {
+  return Math.log(value) / Math.log(base);
+}
+
+
+
+/***/ }),
+
+/***/ "./js/foundation.smoothScroll.js":
+/*!***************************************!*\
+  !*** ./js/foundation.smoothScroll.js ***!
+  \***************************************/
+/*! exports provided: SmoothScroll */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SmoothScroll", function() { return SmoothScroll; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
 
 /**
- * Reveal module.
- * @module foundation.reveal
- * @requires foundation.util.keyboard
- * @requires foundation.util.triggers
- * @requires foundation.util.mediaQuery
- * @requires foundation.util.motion if using animations
+ * SmoothScroll module.
+ * @module foundation.smooth-scroll
  */
 
-var Reveal = function (_Plugin) {
-  _inherits(Reveal, _Plugin);
+var SmoothScroll =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(SmoothScroll, _Plugin);
 
-  function Reveal() {
-    _classCallCheck(this, Reveal);
+  function SmoothScroll() {
+    _classCallCheck(this, SmoothScroll);
 
-    return _possibleConstructorReturn(this, (Reveal.__proto__ || Object.getPrototypeOf(Reveal)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(SmoothScroll).apply(this, arguments));
   }
 
-  _createClass(Reveal, [{
-    key: '_setup',
+  _createClass(SmoothScroll, [{
+    key: "_setup",
 
     /**
-     * Creates a new instance of Reveal.
+     * Creates a new instance of SmoothScroll.
      * @class
-     * @name Reveal
-     * @param {jQuery} element - jQuery object to use for the modal.
-     * @param {Object} options - optional parameters.
+     * @name SmoothScroll
+     * @fires SmoothScroll#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Reveal.defaults, this.$element.data(), options);
-      this.className = 'Reveal'; // ie9 back compat
-      this._init();
-
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_5__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, SmoothScroll.defaults, this.$element.data(), options);
+      this.className = 'SmoothScroll'; // ie9 back compat
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('Reveal', {
-        'ESCAPE': 'close'
-      });
+      this._init();
     }
-
     /**
-     * Initializes the modal by adding the overlay and close buttons, (if selected).
+     * Initialize the SmoothScroll plugin
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
-      this.id = this.$element.attr('id');
-      this.isActive = false;
-      this.cached = { mq: __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */].current };
-      this.isMobile = mobileSniff();
-
-      this.$anchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-open="' + this.id + '"]').length ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-open="' + this.id + '"]') : __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-toggle="' + this.id + '"]');
-      this.$anchor.attr({
-        'aria-controls': this.id,
-        'aria-haspopup': true,
-        'tabindex': 0
-      });
-
-      if (this.options.fullScreen || this.$element.hasClass('full')) {
-        this.options.fullScreen = true;
-        this.options.overlay = false;
-      }
-      if (this.options.overlay && !this.$overlay) {
-        this.$overlay = this._makeOverlay(this.id);
-      }
-
+      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'smooth-scroll');
       this.$element.attr({
-        'role': 'dialog',
-        'aria-hidden': true,
-        'data-yeti-box': this.id,
-        'data-resize': this.id
+        id: id
       });
 
-      if (this.$overlay) {
-        this.$element.detach().appendTo(this.$overlay);
-      } else {
-        this.$element.detach().appendTo(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.options.appendTo));
-        this.$element.addClass('without-overlay');
-      }
       this._events();
-      if (this.options.deepLink && window.location.hash === '#' + this.id) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).one('load.zf.reveal', this.open.bind(this));
-      }
-    }
-
-    /**
-     * Creates an overlay div to display behind the modal.
-     * @private
-     */
-
-  }, {
-    key: '_makeOverlay',
-    value: function _makeOverlay() {
-      var additionalOverlayClasses = '';
-
-      if (this.options.additionalOverlayClasses) {
-        additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;
-      }
-
-      return __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<div></div>').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo);
     }
-
     /**
-     * Updates position of modal
-     * TODO:  Figure out if we actually need to cache these values or if it doesn't matter
+     * Initializes events for SmoothScroll.
      * @private
      */
 
   }, {
-    key: '_updatePosition',
-    value: function _updatePosition() {
-      var width = this.$element.outerWidth();
-      var outerWidth = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).width();
-      var height = this.$element.outerHeight();
-      var outerHeight = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).height();
-      var left, top;
-      if (this.options.hOffset === 'auto') {
-        left = parseInt((outerWidth - width) / 2, 10);
-      } else {
-        left = parseInt(this.options.hOffset, 10);
-      }
-      if (this.options.vOffset === 'auto') {
-        if (height > outerHeight) {
-          top = parseInt(Math.min(100, outerHeight / 10), 10);
-        } else {
-          top = parseInt((outerHeight - height) / 4, 10);
-        }
-      } else {
-        top = parseInt(this.options.vOffset, 10);
-      }
-      this.$element.css({ top: top + 'px' });
-      // only worry about left if we don't have an overlay or we havea  horizontal offset,
-      // otherwise we're perfectly in the middle
-      if (!this.$overlay || this.options.hOffset !== 'auto') {
-        this.$element.css({ left: left + 'px' });
-        this.$element.css({ margin: '0px' });
-      }
+    key: "_events",
+    value: function _events() {
+      this._linkClickListener = this._handleLinkClick.bind(this);
+      this.$element.on('click.zf.smoothScroll', this._linkClickListener);
+      this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
     }
-
     /**
-     * Adds event handlers for the modal.
+     * Handle the given event to smoothly scroll to the anchor pointed by the event target.
+     * @param {*} e - event
+     * @function
      * @private
      */
 
   }, {
-    key: '_events',
-    value: function _events() {
-      var _this3 = this;
-
+    key: "_handleLinkClick",
+    value: function _handleLinkClick(e) {
       var _this = this;
 
-      this.$element.on({
-        'open.zf.trigger': this.open.bind(this),
-        'close.zf.trigger': function (event, $element) {
-          if (event.target === _this.$element[0] || __WEBPACK_IMPORTED_MODULE_0_jquery___default()(event.target).parents('[data-closable]')[0] === $element) {
-            // only close reveal when it's explicitly called
-            return _this3.close.apply(_this3);
-          }
-        },
-        'toggle.zf.trigger': this.toggle.bind(this),
-        'resizeme.zf.trigger': function () {
-          _this._updatePosition();
-        }
+      // Follow the link if it does not point to an anchor.
+      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget).is('a[href^="#"]')) return;
+      var arrival = e.currentTarget.getAttribute('href');
+      this._inTransition = true;
+      SmoothScroll.scrollToLoc(arrival, this.options, function () {
+        _this._inTransition = false;
       });
-
-      if (this.options.closeOnClick && this.options.overlay) {
-        this.$overlay.off('.zf.reveal').on('click.zf.reveal', function (e) {
-          if (e.target === _this.$element[0] || __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(_this.$element[0], e.target) || !__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(document, e.target)) {
-            return;
-          }
-          _this.close();
-        });
-      }
-      if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('popstate.zf.reveal:' + this.id, this._handleState.bind(this));
-      }
+      e.preventDefault();
     }
+  }, {
+    key: "_destroy",
 
     /**
-     * Handles modal methods on back/forward button clicks or any other event that triggers popstate.
-     * @private
+     * Destroys the SmoothScroll instance.
+     * @function
      */
-
-  }, {
-    key: '_handleState',
-    value: function _handleState(e) {
-      if (window.location.hash === '#' + this.id && !this.isActive) {
-        this.open();
-      } else {
-        this.close();
-      }
+    value: function _destroy() {
+      this.$element.off('click.zf.smoothScroll', this._linkClickListener);
+      this.$element.off('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
     }
+  }], [{
+    key: "scrollToLoc",
 
     /**
-     * Opens the modal controlled by `this.$anchor`, and closes all others by default.
+     * Function to scroll to a given location on the page.
+     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'
+     * @param {Object} options - The options to use.
+     * @param {Function} callback - The callback function.
+     * @static
      * @function
-     * @fires Reveal#closeme
-     * @fires Reveal#open
      */
+    value: function scrollToLoc(loc) {
+      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults;
+      var callback = arguments.length > 2 ? arguments[2] : undefined;
+      var $loc = jquery__WEBPACK_IMPORTED_MODULE_0___default()(loc); // Do nothing if target does not exist to prevent errors
+
+      if (!$loc.length) return false;
+      var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({
+        scrollTop: scrollPos
+      }, options.animationDuration, options.animationEasing, function () {
+        if (typeof callback === 'function') {
+          callback();
+        }
+      });
+    }
+  }]);
 
-  }, {
-    key: 'open',
-    value: function open() {
-      var _this4 = this;
+  return SmoothScroll;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["Plugin"]);
+/**
+ * Default settings for plugin.
+ */
 
-      // either update or replace browser history
-      if (this.options.deepLink) {
-        var hash = '#' + this.id;
 
-        if (window.history.pushState) {
-          if (this.options.updateHistory) {
-            window.history.pushState({}, '', hash);
-          } else {
-            window.history.replaceState({}, '', hash);
-          }
-        } else {
-          window.location.hash = hash;
-        }
-      }
+SmoothScroll.defaults = {
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
 
-      this.isActive = true;
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
 
-      // Make elements invisible, but remove display: none so we can get size and positioning
-      this.$element.css({ 'visibility': 'hidden' }).show().scrollTop(0);
-      if (this.options.overlay) {
-        this.$overlay.css({ 'visibility': 'hidden' }).show();
-      }
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
 
-      this._updatePosition();
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
+};
 
-      this.$element.hide().css({ 'visibility': '' });
 
-      if (this.$overlay) {
-        this.$overlay.css({ 'visibility': '' }).hide();
-        if (this.$element.hasClass('fast')) {
-          this.$overlay.addClass('fast');
-        } else if (this.$element.hasClass('slow')) {
-          this.$overlay.addClass('slow');
-        }
-      }
+/***/ }),
 
-      if (!this.options.multipleOpened) {
-        /**
-         * Fires immediately before the modal opens.
-         * Closes any other modals that are currently open
-         * @event Reveal#closeme
-         */
-        this.$element.trigger('closeme.zf.reveal', this.id);
-      }
+/***/ "./js/foundation.sticky.js":
+/*!*********************************!*\
+  !*** ./js/foundation.sticky.js ***!
+  \*********************************/
+/*! exports provided: Sticky */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-      var _this = this;
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Sticky", function() { return Sticky; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
 
-      function addRevealOpenClasses() {
-        if (_this.isMobile) {
-          if (!_this.originalScrollPos) {
-            _this.originalScrollPos = window.pageYOffset;
-          }
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').addClass('is-reveal-open');
-        } else {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').addClass('is-reveal-open');
-        }
-      }
-      // Motion UI method of reveal
-      if (this.options.animationIn) {
-        var afterAnimation = function () {
-          _this.$element.attr({
-            'aria-hidden': false,
-            'tabindex': -1
-          }).focus();
-          addRevealOpenClasses();
-          __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].trapFocus(_this.$element);
-        };
 
-        if (this.options.overlay) {
-          __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__["a" /* Motion */].animateIn(this.$overlay, 'fade-in');
-        }
-        __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__["a" /* Motion */].animateIn(this.$element, this.options.animationIn, function () {
-          if (_this4.$element) {
-            // protect against object having been removed
-            _this4.focusableElements = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].findFocusable(_this4.$element);
-            afterAnimation();
-          }
-        });
-      }
-      // jQuery method of reveal
-      else {
-          if (this.options.overlay) {
-            this.$overlay.show(0);
-          }
-          this.$element.show(this.options.showDelay);
-        }
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-      // handle accessibility
-      this.$element.attr({
-        'aria-hidden': false,
-        'tabindex': -1
-      }).focus();
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].trapFocus(this.$element);
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-      addRevealOpenClasses();
+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); } }
 
-      this._extraHandlers();
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-      /**
-       * Fires when the modal has successfully opened.
-       * @event Reveal#open
-       */
-      this.$element.trigger('open.zf.reveal');
-    }
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
+
+
+
+
+
+
+/**
+ * Sticky module.
+ * @module foundation.sticky
+ * @requires foundation.util.triggers
+ * @requires foundation.util.mediaQuery
+ */
+
+var Sticky =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Sticky, _Plugin);
+
+  function Sticky() {
+    _classCallCheck(this, Sticky);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments));
+  }
+
+  _createClass(Sticky, [{
+    key: "_setup",
 
     /**
-     * Adds extra event handlers for the body and window if necessary.
-     * @private
+     * Creates a new instance of a sticky thing.
+     * @class
+     * @name Sticky
+     * @param {jQuery} element - jQuery object to make sticky.
+     * @param {Object} options - options object passed when creating the element programmatically.
      */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Sticky.defaults, this.$element.data(), options);
+      this.className = 'Sticky'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
 
-  }, {
-    key: '_extraHandlers',
-    value: function _extraHandlers() {
-      var _this = this;
-      if (!this.$element) {
-        return;
-      } // If we're in the middle of cleanup, don't freak out
-      this.focusableElements = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].findFocusable(this.$element);
-
-      if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').on('click.zf.reveal', function (e) {
-          if (e.target === _this.$element[0] || __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(_this.$element[0], e.target) || !__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(document, e.target)) {
-            return;
-          }
-          _this.close();
-        });
-      }
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
-      if (this.options.closeOnEsc) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('keydown.zf.reveal', function (e) {
-          __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'Reveal', {
-            close: function () {
-              if (_this.options.closeOnEsc) {
-                _this.close();
-              }
-            }
-          });
-        });
-      }
+      this._init();
     }
-
     /**
-     * Closes the modal.
+     * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes
      * @function
-     * @fires Reveal#closed
+     * @private
      */
 
   }, {
-    key: 'close',
-    value: function close() {
-      if (!this.isActive || !this.$element.is(':visible')) {
-        return false;
-      }
-      var _this = this;
+    key: "_init",
+    value: function _init() {
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"]._init();
 
-      // Motion UI method of hiding
-      if (this.options.animationOut) {
-        if (this.options.overlay) {
-          __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__["a" /* Motion */].animateOut(this.$overlay, 'fade-out');
-        }
+      var $parent = this.$element.parent('[data-sticky-container]'),
+          id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'sticky'),
+          _this = this;
 
-        __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__["a" /* Motion */].animateOut(this.$element, this.options.animationOut, finishUp);
+      if ($parent.length) {
+        this.$container = $parent;
+      } else {
+        this.wasWrapped = true;
+        this.$element.wrap(this.options.container);
+        this.$container = this.$element.parent();
       }
-      // jQuery method of hiding
-      else {
-          this.$element.hide(this.options.hideDelay);
 
-          if (this.options.overlay) {
-            this.$overlay.hide(0, finishUp);
-          } else {
-            finishUp();
-          }
-        }
+      this.$container.addClass(this.options.containerClass);
+      this.$element.addClass(this.options.stickyClass).attr({
+        'data-resize': id,
+        'data-mutate': id
+      });
 
-      // Conditionals to remove extra event listeners added on open
-      if (this.options.closeOnEsc) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('keydown.zf.reveal');
+      if (this.options.anchor !== '') {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor).attr({
+          'data-mutate': id
+        });
       }
 
-      if (!this.options.overlay && this.options.closeOnClick) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').off('click.zf.reveal');
-      }
+      this.scrollCount = this.options.checkEvery;
+      this.isStuck = false;
+      this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+        //We calculate the container height to have correct values for anchor points offset calculation.
+        _this.containerHeight = _this.$element.css("display") == "none" ? 0 : _this.$element[0].getBoundingClientRect().height;
 
-      this.$element.off('keydown.zf.reveal');
+        _this.$container.css('height', _this.containerHeight);
 
-      function finishUp() {
-        if (_this.isMobile) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()('.reveal:visible').length === 0) {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').removeClass('is-reveal-open');
-          }
-          if (_this.originalScrollPos) {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').scrollTop(_this.originalScrollPos);
-            _this.originalScrollPos = null;
-          }
+        _this.elemHeight = _this.containerHeight;
+
+        if (_this.options.anchor !== '') {
+          _this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor);
         } else {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()('.reveal:visible').length === 0) {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').removeClass('is-reveal-open');
-          }
+          _this._parsePoints();
         }
 
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].releaseFocus(_this.$element);
+        _this._setSizes(function () {
+          var scroll = window.pageYOffset;
+
+          _this._calc(false, scroll); //Unstick the element will ensure that proper classes are set.
 
-        _this.$element.attr('aria-hidden', true);
 
-        /**
-        * Fires when the modal is done closing.
-        * @event Reveal#closed
-        */
-        _this.$element.trigger('closed.zf.reveal');
-      }
+          if (!_this.isStuck) {
+            _this._removeSticky(scroll >= _this.topPoint ? false : true);
+          }
+        });
 
-      /**
-      * Resets the modal content
-      * This prevents a running video to keep going in the background
-      */
-      if (this.options.resetOnClose) {
-        this.$element.html(this.$element.html());
-      }
+        _this._events(id.split('-').reverse().join('-'));
+      });
+    }
+    /**
+     * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.
+     * @function
+     * @private
+     */
 
-      this.isActive = false;
-      if (_this.options.deepLink) {
-        if (window.history.replaceState) {
-          window.history.replaceState('', document.title, window.location.href.replace('#' + this.id, ''));
+  }, {
+    key: "_parsePoints",
+    value: function _parsePoints() {
+      var top = this.options.topAnchor == "" ? 1 : this.options.topAnchor,
+          btm = this.options.btmAnchor == "" ? document.documentElement.scrollHeight : this.options.btmAnchor,
+          pts = [top, btm],
+          breaks = {};
+
+      for (var i = 0, len = pts.length; i < len && pts[i]; i++) {
+        var pt;
+
+        if (typeof pts[i] === 'number') {
+          pt = pts[i];
         } else {
-          window.location.hash = '';
+          var place = pts[i].split(':'),
+              anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(place[0]));
+          pt = anchor.offset().top;
+
+          if (place[1] && place[1].toLowerCase() === 'bottom') {
+            pt += anchor[0].getBoundingClientRect().height;
+          }
         }
+
+        breaks[i] = pt;
       }
 
-      this.$anchor.focus();
+      this.points = breaks;
+      return;
     }
-
     /**
-     * Toggles the open/closed state of a modal.
-     * @function
+     * Adds event handlers for the scrolling element.
+     * @private
+     * @param {String} id - pseudo-random id for unique scroll event listener.
      */
 
   }, {
-    key: 'toggle',
-    value: function toggle() {
-      if (this.isActive) {
-        this.close();
-      } else {
-        this.open();
+    key: "_events",
+    value: function _events(id) {
+      var _this = this,
+          scrollListener = this.scrollListener = "scroll.zf.".concat(id);
+
+      if (this.isOn) {
+        return;
       }
-    }
-  }, {
-    key: '_destroy',
 
+      if (this.canStick) {
+        this.isOn = true;
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener).on(scrollListener, function (e) {
+          if (_this.scrollCount === 0) {
+            _this.scrollCount = _this.options.checkEvery;
 
-    /**
-     * Destroys an instance of a modal.
-     * @function
-     */
-    value: function _destroy() {
-      if (this.options.overlay) {
-        this.$element.appendTo(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()
-        this.$overlay.hide().off().remove();
-      }
-      this.$element.hide().off();
-      this.$anchor.off('.zf');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('.zf.reveal:' + this.id);
-    }
-  }]);
+            _this._setSizes(function () {
+              _this._calc(false, window.pageYOffset);
+            });
+          } else {
+            _this.scrollCount--;
 
-  return Reveal;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["a" /* Plugin */]);
+            _this._calc(false, window.pageYOffset);
+          }
+        });
+      }
+
+      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) {
+        _this._eventsHandler(id);
+      });
+      this.$element.on('mutateme.zf.trigger', function (e, el) {
+        _this._eventsHandler(id);
+      });
+
+      if (this.$anchor) {
+        this.$anchor.on('mutateme.zf.trigger', function (e, el) {
+          _this._eventsHandler(id);
+        });
+      }
+    }
+    /**
+     * Handler for events.
+     * @private
+     * @param {String} id - pseudo-random id for unique scroll event listener.
+     */
+
+  }, {
+    key: "_eventsHandler",
+    value: function _eventsHandler(id) {
+      var _this = this,
+          scrollListener = this.scrollListener = "scroll.zf.".concat(id);
+
+      _this._setSizes(function () {
+        _this._calc(false);
+
+        if (_this.canStick) {
+          if (!_this.isOn) {
+            _this._events(id);
+          }
+        } else if (_this.isOn) {
+          _this._pauseListeners(scrollListener);
+        }
+      });
+    }
+    /**
+     * Removes event handlers for scroll and change events on anchor.
+     * @fires Sticky#pause
+     * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`
+     */
+
+  }, {
+    key: "_pauseListeners",
+    value: function _pauseListeners(scrollListener) {
+      this.isOn = false;
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener);
+      /**
+       * Fires when the plugin is paused due to resize event shrinking the view.
+       * @event Sticky#pause
+       * @private
+       */
+
+      this.$element.trigger('pause.zf.sticky');
+    }
+    /**
+     * Called on every `scroll` event and on `_init`
+     * fires functions based on booleans and cached values
+     * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.
+     * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.
+     */
+
+  }, {
+    key: "_calc",
+    value: function _calc(checkSizes, scroll) {
+      if (checkSizes) {
+        this._setSizes();
+      }
+
+      if (!this.canStick) {
+        if (this.isStuck) {
+          this._removeSticky(true);
+        }
+
+        return false;
+      }
+
+      if (!scroll) {
+        scroll = window.pageYOffset;
+      }
+
+      if (scroll >= this.topPoint) {
+        if (scroll <= this.bottomPoint) {
+          if (!this.isStuck) {
+            this._setSticky();
+          }
+        } else {
+          if (this.isStuck) {
+            this._removeSticky(false);
+          }
+        }
+      } else {
+        if (this.isStuck) {
+          this._removeSticky(true);
+        }
+      }
+    }
+    /**
+     * Causes the $element to become stuck.
+     * Adds `position: fixed;`, and helper classes.
+     * @fires Sticky#stuckto
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_setSticky",
+    value: function _setSticky() {
+      var _this = this,
+          stickTo = this.options.stickTo,
+          mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',
+          notStuckTo = stickTo === 'top' ? 'bottom' : 'top',
+          css = {};
+
+      css[mrgn] = "".concat(this.options[mrgn], "em");
+      css[stickTo] = 0;
+      css[notStuckTo] = 'auto';
+      this.isStuck = true;
+      this.$element.removeClass("is-anchored is-at-".concat(notStuckTo)).addClass("is-stuck is-at-".concat(stickTo)).css(css)
+      /**
+       * Fires when the $element has become `position: fixed;`
+       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`
+       * @event Sticky#stuckto
+       */
+      .trigger("sticky.zf.stuckto:".concat(stickTo));
+      this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd", function () {
+        _this._setSizes();
+      });
+    }
+    /**
+     * Causes the $element to become unstuck.
+     * Removes `position: fixed;`, and helper classes.
+     * Adds other helper classes.
+     * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.
+     * @fires Sticky#unstuckfrom
+     * @private
+     */
+
+  }, {
+    key: "_removeSticky",
+    value: function _removeSticky(isTop) {
+      var stickTo = this.options.stickTo,
+          stickToTop = stickTo === 'top',
+          css = {},
+          anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,
+          mrgn = stickToTop ? 'marginTop' : 'marginBottom',
+          notStuckTo = stickToTop ? 'bottom' : 'top',
+          topOrBottom = isTop ? 'top' : 'bottom';
+      css[mrgn] = 0;
+      css['bottom'] = 'auto';
+
+      if (isTop) {
+        css['top'] = 0;
+      } else {
+        css['top'] = anchorPt;
+      }
+
+      this.isStuck = false;
+      this.$element.removeClass("is-stuck is-at-".concat(stickTo)).addClass("is-anchored is-at-".concat(topOrBottom)).css(css)
+      /**
+       * Fires when the $element has become anchored.
+       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`
+       * @event Sticky#unstuckfrom
+       */
+      .trigger("sticky.zf.unstuckfrom:".concat(topOrBottom));
+    }
+    /**
+     * Sets the $element and $container sizes for plugin.
+     * Calls `_setBreakPoints`.
+     * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.
+     * @private
+     */
+
+  }, {
+    key: "_setSizes",
+    value: function _setSizes(cb) {
+      this.canStick = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"].is(this.options.stickyOn);
+
+      if (!this.canStick) {
+        if (cb && typeof cb === 'function') {
+          cb();
+        }
+      }
+
+      var _this = this,
+          newElemWidth = this.$container[0].getBoundingClientRect().width,
+          comp = window.getComputedStyle(this.$container[0]),
+          pdngl = parseInt(comp['padding-left'], 10),
+          pdngr = parseInt(comp['padding-right'], 10);
+
+      if (this.$anchor && this.$anchor.length) {
+        this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;
+      } else {
+        this._parsePoints();
+      }
+
+      this.$element.css({
+        'max-width': "".concat(newElemWidth - pdngl - pdngr, "px")
+      });
+      var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;
+
+      if (this.$element.css("display") == "none") {
+        newContainerHeight = 0;
+      }
+
+      this.containerHeight = newContainerHeight;
+      this.$container.css({
+        height: newContainerHeight
+      });
+      this.elemHeight = newContainerHeight;
+
+      if (!this.isStuck) {
+        if (this.$element.hasClass('is-at-bottom')) {
+          var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;
+          this.$element.css('top', anchorPt);
+        }
+      }
+
+      this._setBreakPoints(newContainerHeight, function () {
+        if (cb && typeof cb === 'function') {
+          cb();
+        }
+      });
+    }
+    /**
+     * Sets the upper and lower breakpoints for the element to become sticky/unsticky.
+     * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.
+     * @param {Function} cb - optional callback function to be called on completion.
+     * @private
+     */
+
+  }, {
+    key: "_setBreakPoints",
+    value: function _setBreakPoints(elemHeight, cb) {
+      if (!this.canStick) {
+        if (cb && typeof cb === 'function') {
+          cb();
+        } else {
+          return false;
+        }
+      }
+
+      var mTop = emCalc(this.options.marginTop),
+          mBtm = emCalc(this.options.marginBottom),
+          topPoint = this.points ? this.points[0] : this.$anchor.offset().top,
+          bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,
+          // topPoint = this.$anchor.offset().top || this.points[0],
+      // bottomPoint = topPoint + this.anchorHeight || this.points[1],
+      winHeight = window.innerHeight;
+
+      if (this.options.stickTo === 'top') {
+        topPoint -= mTop;
+        bottomPoint -= elemHeight + mTop;
+      } else if (this.options.stickTo === 'bottom') {
+        topPoint -= winHeight - (elemHeight + mBtm);
+        bottomPoint -= winHeight - mBtm;
+      } else {//this would be the stickTo: both option... tricky
+      }
+
+      this.topPoint = topPoint;
+      this.bottomPoint = bottomPoint;
+
+      if (cb && typeof cb === 'function') {
+        cb();
+      }
+    }
+    /**
+     * Destroys the current sticky element.
+     * Resets the element to the top position first.
+     * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this._removeSticky(true);
+
+      this.$element.removeClass("".concat(this.options.stickyClass, " is-anchored is-at-top")).css({
+        height: '',
+        top: '',
+        bottom: '',
+        'max-width': ''
+      }).off('resizeme.zf.trigger').off('mutateme.zf.trigger');
+
+      if (this.$anchor && this.$anchor.length) {
+        this.$anchor.off('change.zf.sticky');
+      }
+
+      if (this.scrollListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.scrollListener);
+      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
+
+      if (this.wasWrapped) {
+        this.$element.unwrap();
+      } else {
+        this.$container.removeClass(this.options.containerClass).css({
+          height: ''
+        });
+      }
+    }
+  }]);
+
+  return Sticky;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
+
+Sticky.defaults = {
+  /**
+   * Customizable container template. Add your own classes for styling and sizing.
+   * @option
+   * @type {string}
+   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'
+   */
+  container: '<div data-sticky-container></div>',
+
+  /**
+   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.
+   * @option
+   * @type {string}
+   * @default 'top'
+   */
+  stickTo: 'top',
+
+  /**
+   * If anchored to a single element, the id of that element.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  anchor: '',
+
+  /**
+   * If using more than one element as anchor points, the id of the top anchor.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  topAnchor: '',
+
+  /**
+   * If using more than one element as anchor points, the id of the bottom anchor.
+   * @option
+   * @type {string}
+   * @default ''
+   */
+  btmAnchor: '',
+
+  /**
+   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  marginTop: 1,
+
+  /**
+   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.
+   * @option
+   * @type {number}
+   * @default 1
+   */
+  marginBottom: 1,
+
+  /**
+   * Breakpoint string that is the minimum screen size an element should become sticky.
+   * @option
+   * @type {string}
+   * @default 'medium'
+   */
+  stickyOn: 'medium',
+
+  /**
+   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.
+   * @option
+   * @type {string}
+   * @default 'sticky'
+   */
+  stickyClass: 'sticky',
+
+  /**
+   * Class applied to sticky container. Foundation defaults to `sticky-container`.
+   * @option
+   * @type {string}
+   * @default 'sticky-container'
+   */
+  containerClass: 'sticky-container',
+
+  /**
+   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.
+   * @option
+   * @type {number}
+   * @default -1
+   */
+  checkEvery: -1
+};
+/**
+ * Helper function to calculate em values
+ * @param Number {em} - number of em's to calculate into pixels
+ */
+
+function emCalc(em) {
+  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;
+}
+
+
+
+/***/ }),
+
+/***/ "./js/foundation.tabs.js":
+/*!*******************************!*\
+  !*** ./js/foundation.tabs.js ***!
+  \*******************************/
+/*! exports provided: Tabs */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Tabs", function() { return Tabs; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.imageLoader */ "./js/foundation.util.imageLoader.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
+
+
+
+
+
+
+/**
+ * Tabs module.
+ * @module foundation.tabs
+ * @requires foundation.util.keyboard
+ * @requires foundation.util.imageLoader if tabs contain images
+ */
+
+var Tabs =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Tabs, _Plugin);
+
+  function Tabs() {
+    _classCallCheck(this, Tabs);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments));
+  }
+
+  _createClass(Tabs, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of tabs.
+     * @class
+     * @name Tabs
+     * @fires Tabs#init
+     * @param {jQuery} element - jQuery object to make into tabs.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tabs.defaults, this.$element.data(), options);
+      this.className = 'Tabs'; // ie9 back compat
+
+      this._init();
+
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('Tabs', {
+        'ENTER': 'open',
+        'SPACE': 'open',
+        'ARROW_RIGHT': 'next',
+        'ARROW_UP': 'previous',
+        'ARROW_DOWN': 'next',
+        'ARROW_LEFT': 'previous' // 'TAB': 'next',
+        // 'SHIFT_TAB': 'previous'
+
+      });
+    }
+    /**
+     * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var _this2 = this;
+
+      var _this = this;
+
+      this._isInitializing = true;
+      this.$element.attr({
+        'role': 'tablist'
+      });
+      this.$tabTitles = this.$element.find(".".concat(this.options.linkClass));
+      this.$tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-tabs-content=\"".concat(this.$element[0].id, "\"]"));
+      this.$tabTitles.each(function () {
+        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            $link = $elem.find('a'),
+            isActive = $elem.hasClass("".concat(_this.options.linkActiveClass)),
+            hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),
+            linkId = $link[0].id ? $link[0].id : "".concat(hash, "-label"),
+            $tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(hash));
+        $elem.attr({
+          'role': 'presentation'
+        });
+        $link.attr({
+          'role': 'tab',
+          'aria-controls': hash,
+          'aria-selected': isActive,
+          'id': linkId,
+          'tabindex': isActive ? '0' : '-1'
+        });
+        $tabContent.attr({
+          'role': 'tabpanel',
+          'aria-labelledby': linkId
+        }); // Save up the initial hash to return to it later when going back in history
+
+        if (isActive) {
+          _this._initialAnchor = "#".concat(hash);
+        }
+
+        if (!isActive) {
+          $tabContent.attr('aria-hidden', 'true');
+        }
+
+        if (isActive && _this.options.autoFocus) {
+          _this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({
+              scrollTop: $elem.offset().top
+            }, _this.options.deepLinkSmudgeDelay, function () {
+              $link.focus();
+            });
+          });
+        }
+      });
+
+      if (this.options.matchHeight) {
+        var $images = this.$tabContent.find('img');
+
+        if ($images.length) {
+          Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__["onImagesLoaded"])($images, this._setHeight.bind(this));
+        } else {
+          this._setHeight();
+        }
+      } // Current context-bound function to open tabs on page load or history hashchange
+
+
+      this._checkDeepLink = function () {
+        var anchor = window.location.hash;
+
+        if (!anchor.length) {
+          // If we are still initializing and there is no anchor, then there is nothing to do
+          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor
+
+          if (_this2._initialAnchor) anchor = _this2._initialAnchor;
+        }
+
+        var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor);
+
+        var $link = anchor && _this2.$element.find('[href$="' + anchor + '"]'); // Whether the anchor element that has been found is part of this element
+
+
+        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, select it
+
+        if ($anchor && $anchor.length && $link && $link.length) {
+          _this2.selectTab($anchor, true);
+        } // Otherwise, collapse everything
+        else {
+            _this2._collapse();
+          }
+
+        if (isOwnAnchor) {
+          // Roll up a little to show the titles
+          if (_this2.options.deepLinkSmudge) {
+            var offset = _this2.$element.offset();
+
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({
+              scrollTop: offset.top
+            }, _this2.options.deepLinkSmudgeDelay);
+          }
+          /**
+           * Fires when the plugin has deeplinked at pageload
+           * @event Tabs#deeplink
+           */
+
+
+          _this2.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);
+        }
+      }; //use browser to open a tab, if it exists in this tabset
+
+
+      if (this.options.deepLink) {
+        this._checkDeepLink();
+      }
+
+      this._events();
+
+      this._isInitializing = false;
+    }
+    /**
+     * Adds event handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._addKeyHandler();
+
+      this._addClickHandler();
+
+      this._setHeightMqHandler = null;
+
+      if (this.options.matchHeight) {
+        this._setHeightMqHandler = this._setHeight.bind(this);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._setHeightMqHandler);
+      }
+
+      if (this.options.deepLink) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink);
+      }
+    }
+    /**
+     * Adds click handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_addClickHandler",
+    value: function _addClickHandler() {
+      var _this = this;
+
+      this.$element.off('click.zf.tabs').on('click.zf.tabs', ".".concat(this.options.linkClass), function (e) {
+        e.preventDefault();
+        e.stopPropagation();
+
+        _this._handleTabChange(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
+      });
+    }
+    /**
+     * Adds keyboard event handlers for items within the tabs.
+     * @private
+     */
+
+  }, {
+    key: "_addKeyHandler",
+    value: function _addKeyHandler() {
+      var _this = this;
+
+      this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) {
+        if (e.which === 9) return;
+        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            $elements = $element.parent('ul').children('li'),
+            $prevElement,
+            $nextElement;
+        $elements.each(function (i) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {
+            if (_this.options.wrapOnKeys) {
+              $prevElement = i === 0 ? $elements.last() : $elements.eq(i - 1);
+              $nextElement = i === $elements.length - 1 ? $elements.first() : $elements.eq(i + 1);
+            } else {
+              $prevElement = $elements.eq(Math.max(0, i - 1));
+              $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
+            }
+
+            return;
+          }
+        }); // handle keyboard event with keyboard util
+
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'Tabs', {
+          open: function open() {
+            $element.find('[role="tab"]').focus();
+
+            _this._handleTabChange($element);
+          },
+          previous: function previous() {
+            $prevElement.find('[role="tab"]').focus();
+
+            _this._handleTabChange($prevElement);
+          },
+          next: function next() {
+            $nextElement.find('[role="tab"]').focus();
+
+            _this._handleTabChange($nextElement);
+          },
+          handled: function handled() {
+            e.stopPropagation();
+            e.preventDefault();
+          }
+        });
+      });
+    }
+    /**
+     * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.
+     * @param {jQuery} $target - Tab to open.
+     * @param {boolean} historyHandled - browser has already handled a history update
+     * @fires Tabs#change
+     * @function
+     */
+
+  }, {
+    key: "_handleTabChange",
+    value: function _handleTabChange($target, historyHandled) {
+      // With `activeCollapse`, if the target is the active Tab, collapse it.
+      if ($target.hasClass("".concat(this.options.linkActiveClass))) {
+        if (this.options.activeCollapse) {
+          this._collapse();
+        }
+
+        return;
+      }
+
+      var $oldTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass)),
+          $tabLink = $target.find('[role="tab"]'),
+          target = $tabLink.attr('data-tabs-target'),
+          anchor = target && target.length ? "#".concat(target) : $tabLink[0].hash,
+          $targetContent = this.$tabContent.find(anchor); //close old tab
+
+      this._collapseTab($oldTab); //open new tab
+
+
+      this._openTab($target); //either replace or update browser history
+
+
+      if (this.options.deepLink && !historyHandled) {
+        if (this.options.updateHistory) {
+          history.pushState({}, '', anchor);
+        } else {
+          history.replaceState({}, '', anchor);
+        }
+      }
+      /**
+       * Fires when the plugin has successfully changed tabs.
+       * @event Tabs#change
+       */
+
+
+      this.$element.trigger('change.zf.tabs', [$target, $targetContent]); //fire to children a mutation event
+
+      $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger");
+    }
+    /**
+     * Opens the tab `$targetContent` defined by `$target`.
+     * @param {jQuery} $target - Tab to open.
+     * @function
+     */
+
+  }, {
+    key: "_openTab",
+    value: function _openTab($target) {
+      var $tabLink = $target.find('[role="tab"]'),
+          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),
+          $targetContent = this.$tabContent.find("#".concat(hash));
+      $target.addClass("".concat(this.options.linkActiveClass));
+      $tabLink.attr({
+        'aria-selected': 'true',
+        'tabindex': '0'
+      });
+      $targetContent.addClass("".concat(this.options.panelActiveClass)).removeAttr('aria-hidden');
+    }
+    /**
+     * Collapses `$targetContent` defined by `$target`.
+     * @param {jQuery} $target - Tab to collapse.
+     * @function
+     */
+
+  }, {
+    key: "_collapseTab",
+    value: function _collapseTab($target) {
+      var $target_anchor = $target.removeClass("".concat(this.options.linkActiveClass)).find('[role="tab"]').attr({
+        'aria-selected': 'false',
+        'tabindex': -1
+      });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat($target_anchor.attr('aria-controls'))).removeClass("".concat(this.options.panelActiveClass)).attr({
+        'aria-hidden': 'true'
+      });
+    }
+    /**
+     * Collapses the active Tab.
+     * @fires Tabs#collapse
+     * @function
+     */
+
+  }, {
+    key: "_collapse",
+    value: function _collapse() {
+      var $activeTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass));
+
+      if ($activeTab.length) {
+        this._collapseTab($activeTab);
+        /**
+        * Fires when the plugin has successfully collapsed tabs.
+        * @event Tabs#collapse
+        */
+
+
+        this.$element.trigger('collapse.zf.tabs', [$activeTab]);
+      }
+    }
+    /**
+     * Public method for selecting a content pane to display.
+     * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.
+     * @param {boolean} historyHandled - browser has already handled a history update
+     * @function
+     */
+
+  }, {
+    key: "selectTab",
+    value: function selectTab(elem, historyHandled) {
+      var idStr;
+
+      if (_typeof(elem) === 'object') {
+        idStr = elem[0].id;
+      } else {
+        idStr = elem;
+      }
+
+      if (idStr.indexOf('#') < 0) {
+        idStr = "#".concat(idStr);
+      }
+
+      var $target = this.$tabTitles.has("[href$=\"".concat(idStr, "\"]"));
+
+      this._handleTabChange($target, historyHandled);
+    }
+  }, {
+    key: "_setHeight",
+
+    /**
+     * Sets the height of each panel to the height of the tallest panel.
+     * If enabled in options, gets called on media query change.
+     * If loading content via external source, can be called directly or with _reflow.
+     * If enabled with `data-match-height="true"`, tabs sets to equal height
+     * @function
+     * @private
+     */
+    value: function _setHeight() {
+      var max = 0,
+          _this = this; // Lock down the `this` value for the root tabs object
+
+
+      this.$tabContent.find(".".concat(this.options.panelClass)).css('height', '').each(function () {
+        var panel = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            isActive = panel.hasClass("".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child
+
+        if (!isActive) {
+          panel.css({
+            'visibility': 'hidden',
+            'display': 'block'
+          });
+        }
+
+        var temp = this.getBoundingClientRect().height;
+
+        if (!isActive) {
+          panel.css({
+            'visibility': '',
+            'display': ''
+          });
+        }
+
+        max = temp > max ? temp : max;
+      }).css('height', "".concat(max, "px"));
+    }
+    /**
+     * Destroys an instance of tabs.
+     * @fires Tabs#destroyed
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.find(".".concat(this.options.linkClass)).off('.zf.tabs').hide().end().find(".".concat(this.options.panelClass)).hide();
+
+      if (this.options.matchHeight) {
+        if (this._setHeightMqHandler != null) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._setHeightMqHandler);
+        }
+      }
+
+      if (this.options.deepLink) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink);
+      }
+
+      if (this.onLoadListener) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
+      }
+    }
+  }]);
+
+  return Tabs;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__["Plugin"]);
+
+Tabs.defaults = {
+  /**
+   * Link the location hash to the active pane.
+   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLink: false,
+
+  /**
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  deepLinkSmudge: false,
+
+  /**
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
+   * @option
+   * @type {number}
+   * @default 300
+   */
+  deepLinkSmudgeDelay: 300,
+
+  /**
+   * If `deepLink` is enabled, update the browser history with the open tab
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  updateHistory: false,
+
+  /**
+   * Allows the window to scroll to content of active pane on load.
+   * Not recommended if more than one tab panel per page.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoFocus: false,
+
+  /**
+   * Allows keyboard input to 'wrap' around the tab links.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  wrapOnKeys: true,
+
+  /**
+   * Allows the tab content panes to match heights if set to true.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  matchHeight: false,
+
+  /**
+   * Allows active tabs to collapse when clicked.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  activeCollapse: false,
+
+  /**
+   * Class applied to `li`'s in tab link list.
+   * @option
+   * @type {string}
+   * @default 'tabs-title'
+   */
+  linkClass: 'tabs-title',
+
+  /**
+   * Class applied to the active `li` in tab link list.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  linkActiveClass: 'is-active',
+
+  /**
+   * Class applied to the content containers.
+   * @option
+   * @type {string}
+   * @default 'tabs-panel'
+   */
+  panelClass: 'tabs-panel',
+
+  /**
+   * Class applied to the active content container.
+   * @option
+   * @type {string}
+   * @default 'is-active'
+   */
+  panelActiveClass: 'is-active'
+};
+
+
+/***/ }),
+
+/***/ "./js/foundation.toggler.js":
+/*!**********************************!*\
+  !*** ./js/foundation.toggler.js ***!
+  \**********************************/
+/*! exports provided: Toggler */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Toggler", function() { return Toggler; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.motion */ "./js/foundation.util.motion.js");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
+
+
+
+
+
+
+/**
+ * Toggler module.
+ * @module foundation.toggler
+ * @requires foundation.util.motion
+ * @requires foundation.util.triggers
+ */
+
+var Toggler =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Toggler, _Plugin);
+
+  function Toggler() {
+    _classCallCheck(this, Toggler);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Toggler).apply(this, arguments));
+  }
+
+  _createClass(Toggler, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of Toggler.
+     * @class
+     * @name Toggler
+     * @fires Toggler#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Toggler.defaults, element.data(), options);
+      this.className = '';
+      this.className = 'Toggler'; // ie9 back compat
+      // Triggers init is idempotent, just need to make sure it is initialized
+
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+
+      this._init();
+
+      this._events();
+    }
+    /**
+     * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      var input; // Parse animation classes if they were set
+
+      if (this.options.animate) {
+        input = this.options.animate.split(' ');
+        this.animationIn = input[0];
+        this.animationOut = input[1] || null;
+      } // Otherwise, parse toggle class
+      else {
+          input = this.$element.data('toggler'); // Allow for a . at the beginning of the string
+
+          this.className = input[0] === '.' ? input.slice(1) : input;
+        } // Add ARIA attributes to triggers:
+
+
+      var id = this.$element[0].id,
+          $triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open~=\"".concat(id, "\"], [data-close~=\"").concat(id, "\"], [data-toggle~=\"").concat(id, "\"]")); // - aria-expanded: according to the element visibility.
+
+      $triggers.attr('aria-expanded', !this.$element.is(':hidden')); // - aria-controls: adding the element id to it if not already in it.
+
+      $triggers.each(function (index, trigger) {
+        var $trigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()(trigger);
+        var controls = $trigger.attr('aria-controls') || '';
+        var containsId = new RegExp("\\b".concat(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["RegExpEscape"])(id), "\\b")).test(controls);
+        if (!containsId) $trigger.attr('aria-controls', controls ? "".concat(controls, " ").concat(id) : id);
+      });
+    }
+    /**
+     * Initializes events for the toggle trigger.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));
+    }
+    /**
+     * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was "on" or "off".
+     * @function
+     * @fires Toggler#on
+     * @fires Toggler#off
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      this[this.options.animate ? '_toggleAnimate' : '_toggleClass']();
+    }
+  }, {
+    key: "_toggleClass",
+    value: function _toggleClass() {
+      this.$element.toggleClass(this.className);
+      var isOn = this.$element.hasClass(this.className);
+
+      if (isOn) {
+        /**
+         * Fires if the target element has the class after a toggle.
+         * @event Toggler#on
+         */
+        this.$element.trigger('on.zf.toggler');
+      } else {
+        /**
+         * Fires if the target element does not have the class after a toggle.
+         * @event Toggler#off
+         */
+        this.$element.trigger('off.zf.toggler');
+      }
+
+      this._updateARIA(isOn);
+
+      this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');
+    }
+  }, {
+    key: "_toggleAnimate",
+    value: function _toggleAnimate() {
+      var _this = this;
+
+      if (this.$element.is(':hidden')) {
+        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__["Motion"].animateIn(this.$element, this.animationIn, function () {
+          _this._updateARIA(true);
+
+          this.trigger('on.zf.toggler');
+          this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+        });
+      } else {
+        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__["Motion"].animateOut(this.$element, this.animationOut, function () {
+          _this._updateARIA(false);
+
+          this.trigger('off.zf.toggler');
+          this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+        });
+      }
+    }
+  }, {
+    key: "_updateARIA",
+    value: function _updateARIA(isOn) {
+      var id = this.$element[0].id;
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(id, "\"], [data-close=\"").concat(id, "\"], [data-toggle=\"").concat(id, "\"]")).attr({
+        'aria-expanded': isOn ? true : false
+      });
+    }
+    /**
+     * Destroys the instance of Toggler on the element.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.toggler');
+    }
+  }]);
+
+  return Toggler;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["Plugin"]);
+
+Toggler.defaults = {
+  /**
+   * Tells the plugin if the element should animated when toggled.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  animate: false
+};
+
+
+/***/ }),
+
+/***/ "./js/foundation.tooltip.js":
+/*!**********************************!*\
+  !*** ./js/foundation.tooltip.js ***!
+  \**********************************/
+/*! exports provided: Tooltip */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Tooltip", function() { return Tooltip; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+/* harmony import */ var _foundation_positionable__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.positionable */ "./js/foundation.positionable.js");
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); }
+
+function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
+
+
+
+
+
+
+/**
+ * Tooltip module.
+ * @module foundation.tooltip
+ * @requires foundation.util.box
+ * @requires foundation.util.mediaQuery
+ * @requires foundation.util.triggers
+ */
+
+var Tooltip =
+/*#__PURE__*/
+function (_Positionable) {
+  _inherits(Tooltip, _Positionable);
+
+  function Tooltip() {
+    _classCallCheck(this, Tooltip);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments));
+  }
+
+  _createClass(Tooltip, [{
+    key: "_setup",
+
+    /**
+     * Creates a new instance of a Tooltip.
+     * @class
+     * @name Tooltip
+     * @fires Tooltip#init
+     * @param {jQuery} element - jQuery object to attach a tooltip to.
+     * @param {Object} options - object to extend the default configuration.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tooltip.defaults, this.$element.data(), options);
+      this.className = 'Tooltip'; // ie9 back compat
+
+      this.isActive = false;
+      this.isClick = false; // Triggers init is idempotent, just need to make sure it is initialized
+
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+
+      this._init();
+    }
+    /**
+     * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.
+     * @private
+     */
+
+  }, {
+    key: "_init",
+    value: function _init() {
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"]._init();
+
+      var elemId = this.$element.attr('aria-describedby') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'tooltip');
+      this.options.tipText = this.options.tipText || this.$element.attr('title');
+      this.template = this.options.template ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.template) : this._buildTemplate(elemId);
+
+      if (this.options.allowHtml) {
+        this.template.appendTo(document.body).html(this.options.tipText).hide();
+      } else {
+        this.template.appendTo(document.body).text(this.options.tipText).hide();
+      }
+
+      this.$element.attr({
+        'title': '',
+        'aria-describedby': elemId,
+        'data-yeti-box': elemId,
+        'data-toggle': elemId,
+        'data-resize': elemId
+      }).addClass(this.options.triggerClass);
+
+      _get(_getPrototypeOf(Tooltip.prototype), "_init", this).call(this);
+
+      this._events();
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      // handle legacy classnames
+      var position = this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);
+      return position ? position[0] : 'top';
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      return 'center';
+    }
+  }, {
+    key: "_getHOffset",
+    value: function _getHOffset() {
+      if (this.position === 'left' || this.position === 'right') {
+        return this.options.hOffset + this.options.tooltipWidth;
+      } else {
+        return this.options.hOffset;
+      }
+    }
+  }, {
+    key: "_getVOffset",
+    value: function _getVOffset() {
+      if (this.position === 'top' || this.position === 'bottom') {
+        return this.options.vOffset + this.options.tooltipHeight;
+      } else {
+        return this.options.vOffset;
+      }
+    }
+    /**
+     * builds the tooltip element, adds attributes, and returns the template.
+     * @private
+     */
+
+  }, {
+    key: "_buildTemplate",
+    value: function _buildTemplate(id) {
+      var templateClasses = "".concat(this.options.tooltipClass, " ").concat(this.options.templateClasses).trim();
+      var $template = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div></div>').addClass(templateClasses).attr({
+        'role': 'tooltip',
+        'aria-hidden': true,
+        'data-is-active': false,
+        'data-is-focus': false,
+        'id': id
+      });
+      return $template;
+    }
+    /**
+     * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.
+     * if the tooltip is larger than the screen width, default to full width - any user selected margin
+     * @private
+     */
+
+  }, {
+    key: "_setPosition",
+    value: function _setPosition() {
+      _get(_getPrototypeOf(Tooltip.prototype), "_setPosition", this).call(this, this.$element, this.template);
+    }
+    /**
+     * reveals the tooltip, and fires an event to close any other open tooltips on the page
+     * @fires Tooltip#closeme
+     * @fires Tooltip#show
+     * @function
+     */
+
+  }, {
+    key: "show",
+    value: function show() {
+      if (this.options.showOn !== 'all' && !_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"].is(this.options.showOn)) {
+        // console.error('The screen is too small to display this tooltip');
+        return false;
+      }
+
+      var _this = this;
+
+      this.template.css('visibility', 'hidden').show();
+
+      this._setPosition();
+
+      this.template.removeClass('top bottom left right').addClass(this.position);
+      this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);
+      /**
+       * Fires to close all other open tooltips on the page
+       * @event Closeme#tooltip
+       */
+
+      this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));
+      this.template.attr({
+        'data-is-active': true,
+        'aria-hidden': false
+      });
+      _this.isActive = true; // console.log(this.template);
+
+      this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {//maybe do stuff?
+      });
+      /**
+       * Fires when the tooltip is shown
+       * @event Tooltip#show
+       */
+
+      this.$element.trigger('show.zf.tooltip');
+    }
+    /**
+     * Hides the current tooltip, and resets the positioning class if it was changed due to collision
+     * @fires Tooltip#hide
+     * @function
+     */
+
+  }, {
+    key: "hide",
+    value: function hide() {
+      // console.log('hiding', this.$element.data('yeti-box'));
+      var _this = this;
+
+      this.template.stop().attr({
+        'aria-hidden': true,
+        'data-is-active': false
+      }).fadeOut(this.options.fadeOutDuration, function () {
+        _this.isActive = false;
+        _this.isClick = false;
+      });
+      /**
+       * fires when the tooltip is hidden
+       * @event Tooltip#hide
+       */
+
+      this.$element.trigger('hide.zf.tooltip');
+    }
+    /**
+     * adds event listeners for the tooltip and its anchor
+     * TODO combine some of the listeners like focus and mouseenter, etc.
+     * @private
+     */
+
+  }, {
+    key: "_events",
+    value: function _events() {
+      var _this = this;
+
+      var $template = this.template;
+      var isFocus = false;
+
+      if (!this.options.disableHover) {
+        this.$element.on('mouseenter.zf.tooltip', function (e) {
+          if (!_this.isActive) {
+            _this.timeout = setTimeout(function () {
+              _this.show();
+            }, _this.options.hoverDelay);
+          }
+        }).on('mouseleave.zf.tooltip', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["ignoreMousedisappear"])(function (e) {
+          clearTimeout(_this.timeout);
+
+          if (!isFocus || _this.isClick && !_this.options.clickOpen) {
+            _this.hide();
+          }
+        }));
+      }
+
+      if (this.options.clickOpen) {
+        this.$element.on('mousedown.zf.tooltip', function (e) {
+          e.stopImmediatePropagation();
+
+          if (_this.isClick) {//_this.hide();
+            // _this.isClick = false;
+          } else {
+            _this.isClick = true;
+
+            if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {
+              _this.show();
+            }
+          }
+        });
+      } else {
+        this.$element.on('mousedown.zf.tooltip', function (e) {
+          e.stopImmediatePropagation();
+          _this.isClick = true;
+        });
+      }
+
+      if (!this.options.disableForTouch) {
+        this.$element.on('tap.zf.tooltip touchend.zf.tooltip', function (e) {
+          _this.isActive ? _this.hide() : _this.show();
+        });
+      }
+
+      this.$element.on({
+        // 'toggle.zf.trigger': this.toggle.bind(this),
+        // 'close.zf.trigger': this.hide.bind(this)
+        'close.zf.trigger': this.hide.bind(this)
+      });
+      this.$element.on('focus.zf.tooltip', function (e) {
+        isFocus = true;
+
+        if (_this.isClick) {
+          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't
+          // a real focus, otherwise on hover and come back we get bad behavior
+          if (!_this.options.clickOpen) {
+            isFocus = false;
+          }
+
+          return false;
+        } else {
+          _this.show();
+        }
+      }).on('focusout.zf.tooltip', function (e) {
+        isFocus = false;
+        _this.isClick = false;
+
+        _this.hide();
+      }).on('resizeme.zf.trigger', function () {
+        if (_this.isActive) {
+          _this._setPosition();
+        }
+      });
+    }
+    /**
+     * adds a toggle method, in addition to the static show() & hide() functions
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      if (this.isActive) {
+        this.hide();
+      } else {
+        this.show();
+      }
+    }
+    /**
+     * Destroys an instance of tooltip, removes template element from the view.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass(this.options.triggerClass).removeClass('top right left bottom').removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');
+      this.template.remove();
+    }
+  }]);
+
+  return Tooltip;
+}(_foundation_positionable__WEBPACK_IMPORTED_MODULE_4__["Positionable"]);
+
+Tooltip.defaults = {
+  disableForTouch: false,
 
-Reveal.defaults = {
   /**
-   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * Time, in ms, before a tooltip should open on hover.
+   * @option
+   * @type {number}
+   * @default 200
+   */
+  hoverDelay: 200,
+
+  /**
+   * Time, in ms, a tooltip should take to fade into view.
+   * @option
+   * @type {number}
+   * @default 150
+   */
+  fadeInDuration: 150,
+
+  /**
+   * Time, in ms, a tooltip should take to fade out of view.
+   * @option
+   * @type {number}
+   * @default 150
+   */
+  fadeOutDuration: 150,
+
+  /**
+   * Disables hover events from opening the tooltip if set to true
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  disableHover: false,
+
+  /**
+   * Optional addtional classes to apply to the tooltip template on init.
    * @option
    * @type {string}
    * @default ''
    */
-  animationIn: '',
+  templateClasses: '',
+
   /**
-   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
+   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.
    * @option
    * @type {string}
-   * @default ''
+   * @default 'tooltip'
    */
-  animationOut: '',
+  tooltipClass: 'tooltip',
+
   /**
-   * Time, in ms, to delay the opening of a modal after a click if no animation used.
+   * Class applied to the tooltip anchor element.
    * @option
-   * @type {number}
-   * @default 0
+   * @type {string}
+   * @default 'has-tip'
    */
-  showDelay: 0,
+  triggerClass: 'has-tip',
+
   /**
-   * Time, in ms, to delay the closing of a modal after a click if no animation used.
+   * Minimum breakpoint size at which to open the tooltip.
    * @option
-   * @type {number}
-   * @default 0
+   * @type {string}
+   * @default 'small'
    */
-  hideDelay: 0,
+  showOn: 'small',
+
   /**
-   * Allows a click on the body/overlay to close the modal.
+   * Custom template to be used to generate markup for tooltip.
    * @option
-   * @type {boolean}
-   * @default true
+   * @type {string}
+   * @default ''
    */
-  closeOnClick: true,
+  template: '',
+
   /**
-   * Allows the modal to close if the user presses the `ESCAPE` key.
+   * Text displayed in the tooltip template on open.
    * @option
-   * @type {boolean}
-   * @default true
+   * @type {string}
+   * @default ''
    */
-  closeOnEsc: true,
+  tipText: '',
+  touchCloseText: 'Tap to close.',
+
   /**
-   * If true, allows multiple modals to be displayed at once.
+   * Allows the tooltip to remain open if triggered with a click or touch event.
    * @option
    * @type {boolean}
-   * @default false
+   * @default true
    */
-  multipleOpened: false,
+  clickOpen: true,
+
   /**
-   * Distance, in pixels, the modal should push down from the top of the screen.
+   * Position of tooltip. Can be left, right, bottom, top, or auto.
    * @option
-   * @type {number|string}
-   * @default auto
+   * @type {string}
+   * @default 'auto'
    */
-  vOffset: 'auto',
+  position: 'auto',
+
   /**
-   * Distance, in pixels, the modal should push in from the side of the screen.
+   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.
    * @option
-   * @type {number|string}
-   * @default auto
+   * @type {string}
+   * @default 'auto'
    */
-  hOffset: 'auto',
+  alignment: 'auto',
+
   /**
-   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.
-   * @option
+   * Allow overlap of container/window. If false, tooltip will first try to
+   * position as defined by data-position and data-alignment, but reposition if
+   * it would cause an overflow.  @option
    * @type {boolean}
    * @default false
    */
-  fullScreen: false,
+  allowOverlap: false,
+
   /**
-   * Percentage of screen height the modal should push up from the bottom of the view.
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * Less common for tooltips.
    * @option
-   * @type {number}
-   * @default 10
+   * @type {boolean}
+   * @default false
    */
-  btmOffsetPct: 10,
+  allowBottomOverlap: false,
+
   /**
-   * Allows the modal to generate an overlay div, which will cover the view when modal opens.
+   * Distance, in pixels, the template should push away from the anchor on the Y axis.
    * @option
-   * @type {boolean}
-   * @default true
+   * @type {number}
+   * @default 0
    */
-  overlay: true,
+  vOffset: 0,
+
   /**
-   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.
+   * Distance, in pixels, the template should push away from the anchor on the X axis
    * @option
-   * @type {boolean}
-   * @default false
+   * @type {number}
+   * @default 0
    */
-  resetOnClose: false,
+  hOffset: 0,
+
   /**
-   * Allows the modal to alter the url on open/close, and allows the use of the `back` button to close modals. ALSO, allows a modal to auto-maniacally open on page load IF the hash === the modal's user-set id.
+   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip
    * @option
-   * @type {boolean}
-   * @default false
+   * @type {number}
+   * @default 14
    */
-  deepLink: false,
+  tooltipHeight: 14,
+
   /**
-   * Update the browser history with the open modal
+   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip
    * @option
-   * @default false
+   * @type {number}
+   * @default 12
    */
-  updateHistory: false,
+  tooltipWidth: 12,
+
   /**
-  * Allows the modal to append to custom div.
+  * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,
+  * allowing HTML may open yourself up to XSS attacks.
   * @option
-  * @type {string}
-  * @default "body"
+  * @type {boolean}
+  * @default false
   */
-  appendTo: "body",
-  /**
-   * Allows adding additional class names to the reveal overlay.
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  additionalOverlayClasses: ''
+  allowHtml: false
 };
-
-function iPhoneSniff() {
-  return (/iP(ad|hone|od).*OS/.test(window.navigator.userAgent)
-  );
-}
-
-function androidSniff() {
-  return (/Android/.test(window.navigator.userAgent)
-  );
-}
-
-function mobileSniff() {
-  return iPhoneSniff() || androidSniff();
-}
+/**
+ * TODO utilize resize event trigger
+ */
 
 
 
 /***/ }),
-/* 32 */
+
+/***/ "./js/foundation.util.box.js":
+/*!***********************************!*\
+  !*** ./js/foundation.util.box.js ***!
+  \***********************************/
+/*! exports provided: Box */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Slider; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_touch__ = __webpack_require__(10);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_util_triggers__ = __webpack_require__(5);
-
-
-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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
-
-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; }
-
-
-
-
-
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Box", function() { return Box; });
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
 
 
 
+var Box = {
+  ImNotTouchingYou: ImNotTouchingYou,
+  OverlapArea: OverlapArea,
+  GetDimensions: GetDimensions,
+  GetOffsets: GetOffsets,
+  GetExplicitOffsets: GetExplicitOffsets
+  /**
+   * Compares the dimensions of an element to a container and determines collision events with container.
+   * @function
+   * @param {jQuery} element - jQuery object to test for collisions.
+   * @param {jQuery} parent - jQuery object to use as bounding container.
+   * @param {Boolean} lrOnly - set to true to check left and right values only.
+   * @param {Boolean} tbOnly - set to true to check top and bottom values only.
+   * @default if no parent object passed, detects collisions with `window`.
+   * @returns {Boolean} - true if collision free, false if a collision in any direction.
+   */
 
+};
 
-/**
- * Slider module.
- * @module foundation.slider
- * @requires foundation.util.motion
- * @requires foundation.util.triggers
- * @requires foundation.util.keyboard
- * @requires foundation.util.touch
- */
+function ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;
+}
 
-var Slider = function (_Plugin) {
-  _inherits(Slider, _Plugin);
+;
 
-  function Slider() {
-    _classCallCheck(this, Slider);
+function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  var eleDims = GetDimensions(element),
+      topOver,
+      bottomOver,
+      leftOver,
+      rightOver;
 
-    return _possibleConstructorReturn(this, (Slider.__proto__ || Object.getPrototypeOf(Slider)).apply(this, arguments));
+  if (parent) {
+    var parDims = GetDimensions(parent);
+    bottomOver = parDims.height + parDims.offset.top - (eleDims.offset.top + eleDims.height);
+    topOver = eleDims.offset.top - parDims.offset.top;
+    leftOver = eleDims.offset.left - parDims.offset.left;
+    rightOver = parDims.width + parDims.offset.left - (eleDims.offset.left + eleDims.width);
+  } else {
+    bottomOver = eleDims.windowDims.height + eleDims.windowDims.offset.top - (eleDims.offset.top + eleDims.height);
+    topOver = eleDims.offset.top - eleDims.windowDims.offset.top;
+    leftOver = eleDims.offset.left - eleDims.windowDims.offset.left;
+    rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);
   }
 
-  _createClass(Slider, [{
-    key: '_setup',
-
-    /**
-     * Creates a new instance of a slider control.
-     * @class
-     * @name Slider
-     * @param {jQuery} element - jQuery object to make into a slider control.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Slider.defaults, this.$element.data(), options);
-      this.className = 'Slider'; // ie9 back compat
-
-      // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.
-      __WEBPACK_IMPORTED_MODULE_5__foundation_util_touch__["a" /* Touch */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
-      __WEBPACK_IMPORTED_MODULE_6__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
-
-      this._init();
-
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].register('Slider', {
-        'ltr': {
-          'ARROW_RIGHT': 'increase',
-          'ARROW_UP': 'increase',
-          'ARROW_DOWN': 'decrease',
-          'ARROW_LEFT': 'decrease',
-          'SHIFT_ARROW_RIGHT': 'increase_fast',
-          'SHIFT_ARROW_UP': 'increase_fast',
-          'SHIFT_ARROW_DOWN': 'decrease_fast',
-          'SHIFT_ARROW_LEFT': 'decrease_fast',
-          'HOME': 'min',
-          'END': 'max'
-        },
-        'rtl': {
-          'ARROW_LEFT': 'increase',
-          'ARROW_RIGHT': 'decrease',
-          'SHIFT_ARROW_LEFT': 'increase_fast',
-          'SHIFT_ARROW_RIGHT': 'decrease_fast'
-        }
-      });
-    }
-
-    /**
-     * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).
-     * @function
-     * @private
-     */
-
-  }, {
-    key: '_init',
-    value: function _init() {
-      this.inputs = this.$element.find('input');
-      this.handles = this.$element.find('[data-slider-handle]');
-
-      this.$handle = this.handles.eq(0);
-      this.$input = this.inputs.length ? this.inputs.eq(0) : __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + this.$handle.attr('aria-controls'));
-      this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);
-
-      var isDbl = false,
-          _this = this;
-      if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {
-        this.options.disabled = true;
-        this.$element.addClass(this.options.disabledClass);
-      }
-      if (!this.inputs.length) {
-        this.inputs = __WEBPACK_IMPORTED_MODULE_0_jquery___default()().add(this.$input);
-        this.options.binding = true;
-      }
-
-      this._setInitAttr(0);
-
-      if (this.handles[1]) {
-        this.options.doubleSided = true;
-        this.$handle2 = this.handles.eq(1);
-        this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + this.$handle2.attr('aria-controls'));
-
-        if (!this.inputs[1]) {
-          this.inputs = this.inputs.add(this.$input2);
-        }
-        isDbl = true;
-
-        // this.$handle.triggerHandler('click.zf.slider');
-        this._setInitAttr(1);
-      }
-
-      // Set handle positions
-      this.setHandles();
-
-      this._events();
-    }
-  }, {
-    key: 'setHandles',
-    value: function setHandles() {
-      var _this3 = this;
-
-      if (this.handles[1]) {
-        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, function () {
-          _this3._setHandlePos(_this3.$handle2, _this3.inputs.eq(1).val(), true);
-        });
-      } else {
-        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);
-      }
-    }
-  }, {
-    key: '_reflow',
-    value: function _reflow() {
-      this.setHandles();
-    }
-    /**
-    * @function
-    * @private
-    * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)
-    */
-
-  }, {
-    key: '_pctOfBar',
-    value: function _pctOfBar(value) {
-      var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start);
-
-      switch (this.options.positionValueFunction) {
-        case "pow":
-          pctOfBar = this._logTransform(pctOfBar);
-          break;
-        case "log":
-          pctOfBar = this._powTransform(pctOfBar);
-          break;
-      }
-
-      return pctOfBar.toFixed(2);
-    }
-
-    /**
-    * @function
-    * @private
-    * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value
-    */
+  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);
+  topOver = Math.min(topOver, 0);
+  leftOver = Math.min(leftOver, 0);
+  rightOver = Math.min(rightOver, 0);
 
-  }, {
-    key: '_value',
-    value: function _value(pctOfBar) {
-      switch (this.options.positionValueFunction) {
-        case "pow":
-          pctOfBar = this._powTransform(pctOfBar);
-          break;
-        case "log":
-          pctOfBar = this._logTransform(pctOfBar);
-          break;
-      }
-      var value = (this.options.end - this.options.start) * pctOfBar + this.options.start;
+  if (lrOnly) {
+    return leftOver + rightOver;
+  }
 
-      return value;
-    }
+  if (tbOnly) {
+    return topOver + bottomOver;
+  } // use sum of squares b/c we care about overlap area.
 
-    /**
-    * @function
-    * @private
-    * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function
-    */
 
-  }, {
-    key: '_logTransform',
-    value: function _logTransform(value) {
-      return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1);
-    }
+  return Math.sqrt(topOver * topOver + bottomOver * bottomOver + leftOver * leftOver + rightOver * rightOver);
+}
+/**
+ * Uses native methods to return an object of dimension values.
+ * @function
+ * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.
+ * @returns {Object} - nested object of integer pixel values
+ * TODO - if element is window, return only those values.
+ */
 
-    /**
-    * @function
-    * @private
-    * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function
-    */
 
-  }, {
-    key: '_powTransform',
-    value: function _powTransform(value) {
-      return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1);
-    }
+function GetDimensions(elem) {
+  elem = elem.length ? elem[0] : elem;
 
-    /**
-     * Sets the position of the selected handle and fill bar.
-     * @function
-     * @private
-     * @param {jQuery} $hndl - the selected handle to move.
-     * @param {Number} location - floating point between the start and end values of the slider bar.
-     * @param {Function} cb - callback function to fire on completion.
-     * @fires Slider#moved
-     * @fires Slider#changed
-     */
+  if (elem === window || elem === document) {
+    throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");
+  }
 
-  }, {
-    key: '_setHandlePos',
-    value: function _setHandlePos($hndl, location, noInvert, cb) {
-      // don't move if the slider has been disabled since its initialization
-      if (this.$element.hasClass(this.options.disabledClass)) {
-        return;
+  var rect = elem.getBoundingClientRect(),
+      parRect = elem.parentNode.getBoundingClientRect(),
+      winRect = document.body.getBoundingClientRect(),
+      winY = window.pageYOffset,
+      winX = window.pageXOffset;
+  return {
+    width: rect.width,
+    height: rect.height,
+    offset: {
+      top: rect.top + winY,
+      left: rect.left + winX
+    },
+    parentDims: {
+      width: parRect.width,
+      height: parRect.height,
+      offset: {
+        top: parRect.top + winY,
+        left: parRect.left + winX
       }
-      //might need to alter that slightly for bars that will have odd number selections.
-      location = parseFloat(location); //on input change events, convert string to number...grumble.
-
-      // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max
-      if (location < this.options.start) {
-        location = this.options.start;
-      } else if (location > this.options.end) {
-        location = this.options.end;
+    },
+    windowDims: {
+      width: winRect.width,
+      height: winRect.height,
+      offset: {
+        top: winY,
+        left: winX
       }
+    }
+  };
+}
+/**
+ * Returns an object of top and left integer pixel values for dynamically rendered elements,
+ * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where
+ * you don't know alignment, but generally from
+ * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.
+ * @function
+ * @param {jQuery} element - jQuery object for the element being positioned.
+ * @param {jQuery} anchor - jQuery object for the element's anchor point.
+ * @param {String} position - a string relating to the desired position of the element, relative to it's anchor
+ * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.
+ * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.
+ * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.
+ * TODO alter/rewrite to work with `em` values as well/instead of pixels
+ */
 
-      var isDbl = this.options.doubleSided;
-
-      //this is for single-handled vertical sliders, it adjusts the value to account for the slider being "upside-down"
-      //for click and drag events, it's weird due to the scale(-1, 1) css property
-      if (this.options.vertical && !noInvert) {
-        location = this.options.end - location;
-      }
 
-      if (isDbl) {
-        //this block is to prevent 2 handles from crossing eachother. Could/should be improved.
-        if (this.handles.index($hndl) === 0) {
-          var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));
-          location = location >= h2Val ? h2Val - this.options.step : location;
-        } else {
-          var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));
-          location = location <= h1Val ? h1Val + this.options.step : location;
-        }
-      }
+function GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {
+  console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5");
 
-      var _this = this,
-          vert = this.options.vertical,
-          hOrW = vert ? 'height' : 'width',
-          lOrT = vert ? 'top' : 'left',
-          handleDim = $hndl[0].getBoundingClientRect()[hOrW],
-          elemDim = this.$element[0].getBoundingClientRect()[hOrW],
+  switch (position) {
+    case 'top':
+      return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__["rtl"])() ? GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);
 
-      //percentage of bar min/max value based on click or drag point
-      pctOfBar = this._pctOfBar(location),
+    case 'bottom':
+      return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__["rtl"])() ? GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
 
-      //number of actual pixels to shift the handle, based on the percentage obtained above
-      pxToMove = (elemDim - handleDim) * pctOfBar,
+    case 'center top':
+      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);
 
-      //percentage of bar to shift the handle
-      movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);
-      //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value
-      location = parseFloat(location.toFixed(this.options.decimal));
-      // declare empty object for css adjustments, only used with 2 handled-sliders
-      var css = {};
+    case 'center bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);
 
-      this._setValues($hndl, location);
+    case 'center left':
+      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);
 
-      // TODO update to calculate based on values set to respective inputs??
-      if (isDbl) {
-        var isLeftHndl = this.handles.index($hndl) === 0,
+    case 'center right':
+      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);
 
-        //empty variable, will be used for min-height/width for fill bar
-        dim,
+    case 'left bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);
 
-        //percentage w/h of the handle compared to the slider bar
-        handlePct = ~~(percent(handleDim, elemDim) * 100);
-        //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar
-        if (isLeftHndl) {
-          //left or top percentage value to apply to the fill bar.
-          css[lOrT] = movement + '%';
-          //calculate the new min-height/width for the fill bar.
-          dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;
-          //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider
-          //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.
-          if (cb && typeof cb === 'function') {
-            cb();
-          } //this is only needed for the initialization of 2 handled sliders
-        } else {
-          //just caching the value of the left/bottom handle's left/top property
-          var handlePos = parseFloat(this.$handle[0].style[lOrT]);
-          //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0
-          //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself
-          dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct;
-        }
-        // assign the min-height/width to our css object
-        css['min-' + hOrW] = dim + '%';
-      }
+    case 'right bottom':
+      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+    // Backwards compatibility... this along with the reveal and reveal full
+    // classes are the only ones that didn't reference anchor
 
-      this.$element.one('finished.zf.animate', function () {
-        /**
-         * Fires when the handle is done moving.
-         * @event Slider#moved
-         */
-        _this.$element.trigger('moved.zf.slider', [$hndl]);
-      });
+    case 'center':
+      return {
+        left: $eleDims.windowDims.offset.left + $eleDims.windowDims.width / 2 - $eleDims.width / 2 + hOffset,
+        top: $eleDims.windowDims.offset.top + $eleDims.windowDims.height / 2 - ($eleDims.height / 2 + vOffset)
+      };
 
-      //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.
-      var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime;
+    case 'reveal':
+      return {
+        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,
+        top: $eleDims.windowDims.offset.top + vOffset
+      };
 
-      __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["b" /* Move */])(moveTime, $hndl, function () {
-        // adjusting the left/top property of the handle, based on the percentage calculated above
-        // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,
-        // fall back to next best guess.
-        if (isNaN(movement)) {
-          $hndl.css(lOrT, pctOfBar * 100 + '%');
-        } else {
-          $hndl.css(lOrT, movement + '%');
-        }
+    case 'reveal full':
+      return {
+        left: $eleDims.windowDims.offset.left,
+        top: $eleDims.windowDims.offset.top
+      };
+      break;
 
-        if (!_this.options.doubleSided) {
-          //if single-handled, a simple method to expand the fill bar
-          _this.$fill.css(hOrW, pctOfBar * 100 + '%');
-        } else {
-          //otherwise, use the css object we created above
-          _this.$fill.css(css);
-        }
-      });
+    default:
+      return {
+        left: Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__["rtl"])() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset : $anchorDims.offset.left + hOffset,
+        top: $anchorDims.offset.top + $anchorDims.height + vOffset
+      };
+  }
+}
 
-      /**
-       * Fires when the value has not been change for a given time.
-       * @event Slider#changed
-       */
-      clearTimeout(_this.timeout);
-      _this.timeout = setTimeout(function () {
-        _this.$element.trigger('changed.zf.slider', [$hndl]);
-      }, _this.options.changedDelay);
-    }
+function GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {
+  var $eleDims = GetDimensions(element),
+      $anchorDims = anchor ? GetDimensions(anchor) : null;
+  var topVal, leftVal; // set position related attribute
 
-    /**
-     * Sets the initial attribute for the slider element.
-     * @function
-     * @private
-     * @param {Number} idx - index of the current handle/input to use.
-     */
+  switch (position) {
+    case 'top':
+      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);
+      break;
 
-  }, {
-    key: '_setInitAttr',
-    value: function _setInitAttr(idx) {
-      var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd;
-      var id = this.inputs.eq(idx).attr('id') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["b" /* GetYoDigits */])(6, 'slider');
-      this.inputs.eq(idx).attr({
-        'id': id,
-        'max': this.options.end,
-        'min': this.options.start,
-        'step': this.options.step
-      });
-      this.inputs.eq(idx).val(initVal);
-      this.handles.eq(idx).attr({
-        'role': 'slider',
-        'aria-controls': id,
-        'aria-valuemax': this.options.end,
-        'aria-valuemin': this.options.start,
-        'aria-valuenow': initVal,
-        'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',
-        'tabindex': 0
-      });
-    }
+    case 'bottom':
+      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;
+      break;
 
-    /**
-     * Sets the input and `aria-valuenow` values for the slider element.
-     * @function
-     * @private
-     * @param {jQuery} $handle - the currently selected handle.
-     * @param {Number} val - floating point of the new value.
-     */
+    case 'left':
+      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);
+      break;
 
-  }, {
-    key: '_setValues',
-    value: function _setValues($handle, val) {
-      var idx = this.options.doubleSided ? this.handles.index($handle) : 0;
-      this.inputs.eq(idx).val(val);
-      $handle.attr('aria-valuenow', val);
-    }
+    case 'right':
+      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;
+      break;
+  } // set alignment related attribute
 
-    /**
-     * Handles events on the slider element.
-     * Calculates the new location of the current handle.
-     * If there are two handles and the bar was clicked, it determines which handle to move.
-     * @function
-     * @private
-     * @param {Object} e - the `event` object passed from the listener.
-     * @param {jQuery} $handle - the current handle to calculate for, if selected.
-     * @param {Number} val - floating point number for the new value of the slider.
-     * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.
-     */
 
-  }, {
-    key: '_handleEvent',
-    value: function _handleEvent(e, $handle, val) {
-      var value, hasVal;
-      if (!val) {
-        //click or drag events
-        e.preventDefault();
-        var _this = this,
-            vertical = this.options.vertical,
-            param = vertical ? 'height' : 'width',
-            direction = vertical ? 'top' : 'left',
-            eventOffset = vertical ? e.pageY : e.pageX,
-            halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,
-            barDim = this.$element[0].getBoundingClientRect()[param],
-            windowScroll = vertical ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).scrollTop() : __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).scrollLeft();
+  switch (position) {
+    case 'top':
+    case 'bottom':
+      switch (alignment) {
+        case 'left':
+          leftVal = $anchorDims.offset.left + hOffset;
+          break;
 
-        var elemOffset = this.$element.offset()[direction];
+        case 'right':
+          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;
+          break;
 
-        // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...
-        // best way to guess this is simulated is if clientY == pageY
-        if (e.clientY === e.pageY) {
-          eventOffset = eventOffset + windowScroll;
-        }
-        var eventFromBar = eventOffset - elemOffset;
-        var barXY;
-        if (eventFromBar < 0) {
-          barXY = 0;
-        } else if (eventFromBar > barDim) {
-          barXY = barDim;
-        } else {
-          barXY = eventFromBar;
-        }
-        var offsetPct = percent(barXY, barDim);
+        case 'center':
+          leftVal = isOverflow ? hOffset : $anchorDims.offset.left + $anchorDims.width / 2 - $eleDims.width / 2 + hOffset;
+          break;
+      }
 
-        value = this._value(offsetPct);
+      break;
 
-        // turn everything around for RTL, yay math!
-        if (__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["a" /* rtl */])() && !this.options.vertical) {
-          value = this.options.end - value;
-        }
+    case 'right':
+    case 'left':
+      switch (alignment) {
+        case 'bottom':
+          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;
+          break;
 
-        value = _this._adjustValue(null, value);
-        //boolean flag for the setHandlePos fn, specifically for vertical sliders
-        hasVal = false;
+        case 'top':
+          topVal = $anchorDims.offset.top + vOffset;
+          break;
 
-        if (!$handle) {
-          //figure out which handle it is, pass it to the next function.
-          var firstHndlPos = absPosition(this.$handle, direction, barXY, param),
-              secndHndlPos = absPosition(this.$handle2, direction, barXY, param);
-          $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;
-        }
-      } else {
-        //change event on input
-        value = this._adjustValue(null, val);
-        hasVal = true;
+        case 'center':
+          topVal = $anchorDims.offset.top + vOffset + $anchorDims.height / 2 - $eleDims.height / 2;
+          break;
       }
 
-      this._setHandlePos($handle, value, hasVal);
-    }
+      break;
+  }
 
-    /**
-     * Adjustes value for handle in regard to step value. returns adjusted value
-     * @function
-     * @private
-     * @param {jQuery} $handle - the selected handle.
-     * @param {Number} value - value to adjust. used if $handle is falsy
-     */
+  return {
+    top: topVal,
+    left: leftVal
+  };
+}
 
-  }, {
-    key: '_adjustValue',
-    value: function _adjustValue($handle, value) {
-      var val,
-          step = this.options.step,
-          div = parseFloat(step / 2),
-          left,
-          prev_val,
-          next_val;
-      if (!!$handle) {
-        val = parseFloat($handle.attr('aria-valuenow'));
-      } else {
-        val = value;
-      }
-      left = val % step;
-      prev_val = val - left;
-      next_val = prev_val + step;
-      if (left === 0) {
-        return val;
-      }
-      val = val >= prev_val + div ? next_val : prev_val;
-      return val;
-    }
 
-    /**
-     * Adds event listeners to the slider elements.
-     * @function
-     * @private
-     */
 
-  }, {
-    key: '_events',
-    value: function _events() {
-      this._eventsForHandle(this.$handle);
-      if (this.handles[1]) {
-        this._eventsForHandle(this.$handle2);
-      }
-    }
+/***/ }),
 
-    /**
-     * Adds event listeners a particular handle
-     * @function
-     * @private
-     * @param {jQuery} $handle - the current handle to apply listeners to.
-     */
+/***/ "./js/foundation.util.imageLoader.js":
+/*!*******************************************!*\
+  !*** ./js/foundation.util.imageLoader.js ***!
+  \*******************************************/
+/*! exports provided: onImagesLoaded */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-  }, {
-    key: '_eventsForHandle',
-    value: function _eventsForHandle($handle) {
-      var _this = this,
-          curHandle,
-          timer;
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onImagesLoaded", function() { return onImagesLoaded; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+
+
+
+/**
+ * Runs a callback function when images are fully loaded.
+ * @param {Object} images - Image(s) to check if loaded.
+ * @param {Func} callback - Function to execute when image is fully loaded.
+ */
+
+function onImagesLoaded(images, callback) {
+  var self = this,
+      unloaded = images.length;
+
+  if (unloaded === 0) {
+    callback();
+  }
+
+  images.each(function () {
+    // Check if image is loaded
+    if (this.complete && typeof this.naturalWidth !== 'undefined') {
+      singleImageLoaded();
+    } else {
+      // If the above check failed, simulate loading on detached element.
+      var image = new Image(); // Still count image as loaded if it finalizes with an error.
 
-      this.inputs.off('change.zf.slider').on('change.zf.slider', function (e) {
-        var idx = _this.inputs.index(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
-        _this._handleEvent(e, _this.handles.eq(idx), __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).val());
+      var events = "load.zf.images error.zf.images";
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(image).one(events, function me(event) {
+        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off(events, me);
+        singleImageLoaded();
       });
+      image.src = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('src');
+    }
+  });
 
-      if (this.options.clickSelect) {
-        this.$element.off('click.zf.slider').on('click.zf.slider', function (e) {
-          if (_this.$element.data('dragging')) {
-            return false;
-          }
+  function singleImageLoaded() {
+    unloaded--;
 
-          if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).is('[data-slider-handle]')) {
-            if (_this.options.doubleSided) {
-              _this._handleEvent(e);
-            } else {
-              _this._handleEvent(e, _this.$handle);
-            }
-          }
-        });
-      }
+    if (unloaded === 0) {
+      callback();
+    }
+  }
+}
 
-      if (this.options.draggable) {
-        this.handles.addTouch();
 
-        var $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body');
-        $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) {
-          $handle.addClass('is-dragging');
-          _this.$fill.addClass('is-dragging'); //
-          _this.$element.data('dragging', true);
 
-          curHandle = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.currentTarget);
+/***/ }),
 
-          $body.on('mousemove.zf.slider', function (e) {
-            e.preventDefault();
-            _this._handleEvent(e, curHandle);
-          }).on('mouseup.zf.slider', function (e) {
-            _this._handleEvent(e, curHandle);
+/***/ "./js/foundation.util.keyboard.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.keyboard.js ***!
+  \****************************************/
+/*! exports provided: Keyboard */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-            $handle.removeClass('is-dragging');
-            _this.$fill.removeClass('is-dragging');
-            _this.$element.data('dragging', false);
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Keyboard", function() { return Keyboard; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/*******************************************
+ *                                         *
+ * This util was created by Marius Olbertz *
+ * Please thank Marius on GitHub /owlbertz *
+ * or the web http://www.mariusolbertz.de/ *
+ *                                         *
+ ******************************************/
 
-            $body.off('mousemove.zf.slider mouseup.zf.slider');
-          });
-        })
-        // prevent events triggered by touch
-        .on('selectstart.zf.slider touchmove.zf.slider', function (e) {
-          e.preventDefault();
-        });
-      }
 
-      $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) {
-        var _$handle = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,
-            oldValue = parseFloat(_this.inputs.eq(idx).val()),
-            newValue;
 
-        // handle keyboard event with keyboard util
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */].handleKey(e, 'Slider', {
-          decrease: function () {
-            newValue = oldValue - _this.options.step;
-          },
-          increase: function () {
-            newValue = oldValue + _this.options.step;
-          },
-          decrease_fast: function () {
-            newValue = oldValue - _this.options.step * 10;
-          },
-          increase_fast: function () {
-            newValue = oldValue + _this.options.step * 10;
-          },
-          min: function () {
-            newValue = _this.options.start;
-          },
-          max: function () {
-            newValue = _this.options.end;
-          },
-          handled: function () {
-            // only set handle pos when event was handled specially
-            e.preventDefault();
-            _this._setHandlePos(_$handle, newValue, true);
-          }
-        });
-        /*if (newValue) { // if pressed key has special function, update value
-          e.preventDefault();
-          _this._setHandlePos(_$handle, newValue);
-        }*/
-      });
-    }
 
-    /**
-     * Destroys the slider plugin.
-     */
+var keyCodes = {
+  9: 'TAB',
+  13: 'ENTER',
+  27: 'ESCAPE',
+  32: 'SPACE',
+  35: 'END',
+  36: 'HOME',
+  37: 'ARROW_LEFT',
+  38: 'ARROW_UP',
+  39: 'ARROW_RIGHT',
+  40: 'ARROW_DOWN'
+};
+var commands = {}; // Functions pulled out to be referenceable from internals
+
+function findFocusable($element) {
+  if (!$element) {
+    return false;
+  }
 
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.handles.off('.zf.slider');
-      this.inputs.off('.zf.slider');
-      this.$element.off('.zf.slider');
+  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function () {
+    if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':visible') || jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('tabindex') < 0) {
+      return false;
+    } //only have visible elements and those that have a tabindex greater or equal 0
 
-      clearTimeout(this.timeout);
-    }
-  }]);
 
-  return Slider;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["a" /* Plugin */]);
+    return true;
+  });
+}
+
+function parseKey(event) {
+  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase(); // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events
+
+  key = key.replace(/\W+/, '');
+  if (event.shiftKey) key = "SHIFT_".concat(key);
+  if (event.ctrlKey) key = "CTRL_".concat(key);
+  if (event.altKey) key = "ALT_".concat(key); // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)
+
+  key = key.replace(/_$/, '');
+  return key;
+}
+
+var Keyboard = {
+  keys: getKeyCodes(keyCodes),
 
-Slider.defaults = {
-  /**
-   * Minimum value for the slider scale.
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  start: 0,
-  /**
-   * Maximum value for the slider scale.
-   * @option
-   * @type {number}
-   * @default 100
-   */
-  end: 100,
-  /**
-   * Minimum value change per change event.
-   * @option
-   * @type {number}
-   * @default 1
-   */
-  step: 1,
-  /**
-   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  initialStart: 0,
-  /**
-   * Value at which the right handle/second input should be set to on initialization.
-   * @option
-   * @type {number}
-   * @default 100
-   */
-  initialEnd: 100,
-  /**
-   * Allows the input to be located outside the container and visible. Set to by the JS
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  binding: false,
-  /**
-   * Allows the user to click/tap on the slider bar to select a value.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  clickSelect: true,
-  /**
-   * Set to true and use the `vertical` class to change alignment to vertical.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  vertical: false,
-  /**
-   * Allows the user to drag the slider handle(s) to select a value.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  draggable: true,
-  /**
-   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  disabled: false,
-  /**
-   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  doubleSided: false,
-  /**
-   * Potential future feature.
-   */
-  // steps: 100,
   /**
-   * Number of decimal places the plugin should go to for floating point precision.
-   * @option
-   * @type {number}
-   * @default 2
+   * Parses the (keyboard) event and returns a String that represents its key
+   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
+   * @param {Event} event - the event generated by the event handler
+   * @return String key - String that represents the key pressed
    */
-  decimal: 2,
+  parseKey: parseKey,
+
   /**
-   * Time delay for dragged elements.
+   * Handles the given (keyboard) event
+   * @param {Event} event - the event generated by the event handler
+   * @param {String} component - Foundation component's name, e.g. Slider or Reveal
+   * @param {Objects} functions - collection of functions that are to be executed
    */
-  // dragDelay: 0,
+  handleKey: function handleKey(event, component, functions) {
+    var commandList = commands[component],
+        keyCode = this.parseKey(event),
+        cmds,
+        command,
+        fn;
+    if (!commandList) return console.warn('Component not defined!');
+
+    if (typeof commandList.ltr === 'undefined') {
+      // this component does not differentiate between ltr and rtl
+      cmds = commandList; // use plain list
+    } else {
+      // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa
+      if (Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["rtl"])()) cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.ltr, commandList.rtl);else cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.rtl, commandList.ltr);
+    }
+
+    command = cmds[keyCode];
+    fn = functions[command];
+
+    if (fn && typeof fn === 'function') {
+      // execute function  if exists
+      var returnValue = fn.apply();
+
+      if (functions.handled || typeof functions.handled === 'function') {
+        // execute function when event was handled
+        functions.handled(returnValue);
+      }
+    } else {
+      if (functions.unhandled || typeof functions.unhandled === 'function') {
+        // execute function when event was not handled
+        functions.unhandled();
+      }
+    }
+  },
+
   /**
-   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.
-   * @option
-   * @type {number}
-   * @default 200
+   * Finds all focusable elements within the given `$element`
+   * @param {jQuery} $element - jQuery object to search within
+   * @return {jQuery} $focusable - all focusable elements within `$element`
    */
-  moveTime: 200, //update this if changing the transition time in the sass
+  findFocusable: findFocusable,
+
   /**
-   * Class applied to disabled sliders.
-   * @option
-   * @type {string}
-   * @default 'disabled'
+   * Returns the component name name
+   * @param {Object} component - Foundation component, e.g. Slider or Reveal
+   * @return String componentName
    */
-  disabledClass: 'disabled',
+  register: function register(componentName, cmds) {
+    commands[componentName] = cmds;
+  },
+  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?
+  //
+
   /**
-   * Will invert the default layout for a vertical<span data-tooltip title="who would do this???"> </span>slider.
-   * @option
-   * @type {boolean}
-   * @default false
+   * Traps the focus in the given element.
+   * @param  {jQuery} $element  jQuery object to trap the foucs into.
    */
-  invertVertical: false,
+  trapFocus: function trapFocus($element) {
+    var $focusable = findFocusable($element),
+        $firstFocusable = $focusable.eq(0),
+        $lastFocusable = $focusable.eq(-1);
+    $element.on('keydown.zf.trapfocus', function (event) {
+      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {
+        event.preventDefault();
+        $firstFocusable.focus();
+      } else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {
+        event.preventDefault();
+        $lastFocusable.focus();
+      }
+    });
+  },
+
   /**
-   * Milliseconds before the `changed.zf-slider` event is triggered after value change.
-   * @option
-   * @type {number}
-   * @default 500
+   * Releases the trapped focus from the given element.
+   * @param  {jQuery} $element  jQuery object to release the focus for.
    */
-  changedDelay: 500,
-  /**
-  * Basevalue for non-linear sliders
-  * @option
-  * @type {number}
-  * @default 5
-  */
-  nonLinearBase: 5,
-  /**
-  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.
-  * @option
-  * @type {string}
-  * @default 'linear'
-  */
-  positionValueFunction: 'linear'
+  releaseFocus: function releaseFocus($element) {
+    $element.off('keydown.zf.trapfocus');
+  }
 };
+/*
+ * Constants for easier comparing.
+ * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
+ */
 
-function percent(frac, num) {
-  return frac / num;
-}
-function absPosition($handle, dir, clickPos, param) {
-  return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos);
-}
-function baseLog(base, value) {
-  return Math.log(value) / Math.log(base);
+function getKeyCodes(kcs) {
+  var k = {};
+
+  for (var kc in kcs) {
+    k[kcs[kc]] = kcs[kc];
+  }
+
+  return k;
 }
 
 
 
 /***/ }),
-/* 33 */
+
+/***/ "./js/foundation.util.mediaQuery.js":
+/*!******************************************!*\
+  !*** ./js/foundation.util.mediaQuery.js ***!
+  \******************************************/
+/*! exports provided: MediaQuery */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Sticky; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_triggers__ = __webpack_require__(5);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MediaQuery", function() { return MediaQuery; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 
 
-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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-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; }
+ // Default set of media queries
 
-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; }
+var defaultQueries = {
+  'default': 'only screen',
+  landscape: 'only screen and (orientation: landscape)',
+  portrait: 'only screen and (orientation: portrait)',
+  retina: 'only screen and (-webkit-min-device-pixel-ratio: 2),' + 'only screen and (min--moz-device-pixel-ratio: 2),' + 'only screen and (-o-min-device-pixel-ratio: 2/1),' + 'only screen and (min-device-pixel-ratio: 2),' + 'only screen and (min-resolution: 192dpi),' + 'only screen and (min-resolution: 2dppx)'
+}; // matchMedia() polyfill - Test a CSS media type/query in JS.
+// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license
 
+/* eslint-disable */
 
+window.matchMedia || (window.matchMedia = function () {
+  "use strict"; // For browsers that support matchMedium api such as IE 9 and webkit
 
+  var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium
 
+  if (!styleMedia) {
+    var style = document.createElement('style'),
+        script = document.getElementsByTagName('script')[0],
+        info = null;
+    style.type = 'text/css';
+    style.id = 'matchmediajs-test';
 
+    if (!script) {
+      document.head.appendChild(style);
+    } else {
+      script.parentNode.insertBefore(style, script);
+    } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
 
 
-/**
- * Sticky module.
- * @module foundation.sticky
- * @requires foundation.util.triggers
- * @requires foundation.util.mediaQuery
- */
+    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;
+    styleMedia = {
+      matchMedium: function matchMedium(media) {
+        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
 
-var Sticky = function (_Plugin) {
-  _inherits(Sticky, _Plugin);
+        if (style.styleSheet) {
+          style.styleSheet.cssText = text;
+        } else {
+          style.textContent = text;
+        } // Test if media query is true or false
 
-  function Sticky() {
-    _classCallCheck(this, Sticky);
 
-    return _possibleConstructorReturn(this, (Sticky.__proto__ || Object.getPrototypeOf(Sticky)).apply(this, arguments));
+        return info.width === '1px';
+      }
+    };
   }
 
-  _createClass(Sticky, [{
-    key: '_setup',
+  return function (media) {
+    return {
+      matches: styleMedia.matchMedium(media || 'all'),
+      media: media || 'all'
+    };
+  };
+}());
+/* eslint-enable */
 
-    /**
-     * Creates a new instance of a sticky thing.
-     * @class
-     * @name Sticky
-     * @param {jQuery} element - jQuery object to make sticky.
-     * @param {Object} options - options object passed when creating the element programmatically.
-     */
-    value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Sticky.defaults, this.$element.data(), options);
-      this.className = 'Sticky'; // ie9 back compat
+var MediaQuery = {
+  queries: [],
+  current: '',
 
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_4__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+  /**
+   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.
+   * @function
+   * @private
+   */
+  _init: function _init() {
+    var self = this;
+    var $meta = jquery__WEBPACK_IMPORTED_MODULE_0___default()('meta.foundation-mq');
 
-      this._init();
+    if (!$meta.length) {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('<meta class="foundation-mq">').appendTo(document.head);
     }
 
-    /**
-     * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes
-     * @function
-     * @private
-     */
+    var extractedStyles = jquery__WEBPACK_IMPORTED_MODULE_0___default()('.foundation-mq').css('font-family');
+    var namedQueries;
+    namedQueries = parseStyleToObject(extractedStyles);
 
-  }, {
-    key: '_init',
-    value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
+    for (var key in namedQueries) {
+      if (namedQueries.hasOwnProperty(key)) {
+        self.queries.push({
+          name: key,
+          value: "only screen and (min-width: ".concat(namedQueries[key], ")")
+        });
+      }
+    }
 
-      var $parent = this.$element.parent('[data-sticky-container]'),
-          id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["b" /* GetYoDigits */])(6, 'sticky'),
-          _this = this;
+    this.current = this._getCurrentSize();
 
-      if ($parent.length) {
-        this.$container = $parent;
-      } else {
-        this.wasWrapped = true;
-        this.$element.wrap(this.options.container);
-        this.$container = this.$element.parent();
-      }
-      this.$container.addClass(this.options.containerClass);
+    this._watcher();
+  },
 
-      this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });
-      if (this.options.anchor !== '') {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + _this.options.anchor).attr({ 'data-mutate': id });
+  /**
+   * Checks if the screen is at least as wide as a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to check.
+   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.
+   */
+  atLeast: function atLeast(size) {
+    var query = this.get(size);
+
+    if (query) {
+      return window.matchMedia(query).matches;
+    }
+
+    return false;
+  },
+
+  /**
+   * Checks if the screen matches to a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.
+   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.
+   */
+  is: function is(size) {
+    size = size.trim().split(' ');
+
+    if (size.length > 1 && size[1] === 'only') {
+      if (size[0] === this._getCurrentSize()) return true;
+    } else {
+      return this.atLeast(size[0]);
+    }
+
+    return false;
+  },
+
+  /**
+   * Gets the media query of a breakpoint.
+   * @function
+   * @param {String} size - Name of the breakpoint to get.
+   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.
+   */
+  get: function get(size) {
+    for (var i in this.queries) {
+      if (this.queries.hasOwnProperty(i)) {
+        var query = this.queries[i];
+        if (size === query.name) return query.value;
       }
+    }
 
-      this.scrollCount = this.options.checkEvery;
-      this.isStuck = false;
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).one('load.zf.sticky', function () {
-        //We calculate the container height to have correct values for anchor points offset calculation.
-        _this.containerHeight = _this.$element.css("display") == "none" ? 0 : _this.$element[0].getBoundingClientRect().height;
-        _this.$container.css('height', _this.containerHeight);
-        _this.elemHeight = _this.containerHeight;
-        if (_this.options.anchor !== '') {
-          _this.$anchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + _this.options.anchor);
-        } else {
-          _this._parsePoints();
-        }
+    return null;
+  },
 
-        _this._setSizes(function () {
-          var scroll = window.pageYOffset;
-          _this._calc(false, scroll);
-          //Unstick the element will ensure that proper classes are set.
-          if (!_this.isStuck) {
-            _this._removeSticky(scroll >= _this.topPoint ? false : true);
-          }
-        });
-        _this._events(id.split('-').reverse().join('-'));
-      });
+  /**
+   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).
+   * @function
+   * @private
+   * @returns {String} Name of the current breakpoint.
+   */
+  _getCurrentSize: function _getCurrentSize() {
+    var matched;
+
+    for (var i = 0; i < this.queries.length; i++) {
+      var query = this.queries[i];
+
+      if (window.matchMedia(query.value).matches) {
+        matched = query;
+      }
     }
 
-    /**
-     * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.
-     * @function
-     * @private
-     */
+    if (_typeof(matched) === 'object') {
+      return matched.name;
+    } else {
+      return matched;
+    }
+  },
 
-  }, {
-    key: '_parsePoints',
-    value: function _parsePoints() {
-      var top = this.options.topAnchor == "" ? 1 : this.options.topAnchor,
-          btm = this.options.btmAnchor == "" ? document.documentElement.scrollHeight : this.options.btmAnchor,
-          pts = [top, btm],
-          breaks = {};
-      for (var i = 0, len = pts.length; i < len && pts[i]; i++) {
-        var pt;
-        if (typeof pts[i] === 'number') {
-          pt = pts[i];
-        } else {
-          var place = pts[i].split(':'),
-              anchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + place[0]);
+  /**
+   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.
+   * @function
+   * @private
+   */
+  _watcher: function _watcher() {
+    var _this = this;
 
-          pt = anchor.offset().top;
-          if (place[1] && place[1].toLowerCase() === 'bottom') {
-            pt += anchor[0].getBoundingClientRect().height;
-          }
-        }
-        breaks[i] = pt;
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {
+      var newSize = _this._getCurrentSize(),
+          currentSize = _this.current;
+
+      if (newSize !== currentSize) {
+        // Change the current media query
+        _this.current = newSize; // Broadcast the media query change on the window
+
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
       }
+    });
+  }
+}; // Thank you: https://github.com/sindresorhus/query-string
+
+function parseStyleToObject(str) {
+  var styleObject = {};
+
+  if (typeof str !== 'string') {
+    return styleObject;
+  }
+
+  str = str.trim().slice(1, -1); // browsers re-quote string style values
+
+  if (!str) {
+    return styleObject;
+  }
+
+  styleObject = str.split('&').reduce(function (ret, param) {
+    var parts = param.replace(/\+/g, ' ').split('=');
+    var key = parts[0];
+    var val = parts[1];
+    key = decodeURIComponent(key); // missing `=` should be `null`:
+    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters
+
+    val = typeof val === 'undefined' ? null : decodeURIComponent(val);
+
+    if (!ret.hasOwnProperty(key)) {
+      ret[key] = val;
+    } else if (Array.isArray(ret[key])) {
+      ret[key].push(val);
+    } else {
+      ret[key] = [ret[key], val];
+    }
+
+    return ret;
+  }, {});
+  return styleObject;
+}
+
+
+
+/***/ }),
+
+/***/ "./js/foundation.util.motion.js":
+/*!**************************************!*\
+  !*** ./js/foundation.util.motion.js ***!
+  \**************************************/
+/*! exports provided: Move, Motion */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Move", function() { return Move; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Motion", function() { return Motion; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+
 
-      this.points = breaks;
-      return;
-    }
 
-    /**
-     * Adds event handlers for the scrolling element.
-     * @private
-     * @param {String} id - pseudo-random id for unique scroll event listener.
-     */
 
-  }, {
-    key: '_events',
-    value: function _events(id) {
-      var _this = this,
-          scrollListener = this.scrollListener = 'scroll.zf.' + id;
-      if (this.isOn) {
-        return;
-      }
-      if (this.canStick) {
-        this.isOn = true;
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(scrollListener).on(scrollListener, function (e) {
-          if (_this.scrollCount === 0) {
-            _this.scrollCount = _this.options.checkEvery;
-            _this._setSizes(function () {
-              _this._calc(false, window.pageYOffset);
-            });
-          } else {
-            _this.scrollCount--;
-            _this._calc(false, window.pageYOffset);
-          }
-        });
-      }
+/**
+ * Motion module.
+ * @module foundation.motion
+ */
 
-      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) {
-        _this._eventsHandler(id);
-      });
+var initClasses = ['mui-enter', 'mui-leave'];
+var activeClasses = ['mui-enter-active', 'mui-leave-active'];
+var Motion = {
+  animateIn: function animateIn(element, animation, cb) {
+    animate(true, element, animation, cb);
+  },
+  animateOut: function animateOut(element, animation, cb) {
+    animate(false, element, animation, cb);
+  }
+};
 
-      this.$element.on('mutateme.zf.trigger', function (e, el) {
-        _this._eventsHandler(id);
-      });
+function Move(duration, elem, fn) {
+  var anim,
+      prog,
+      start = null; // console.log('called');
 
-      if (this.$anchor) {
-        this.$anchor.on('mutateme.zf.trigger', function (e, el) {
-          _this._eventsHandler(id);
-        });
-      }
-    }
+  if (duration === 0) {
+    fn.apply(elem);
+    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
+    return;
+  }
 
-    /**
-     * Handler for events.
-     * @private
-     * @param {String} id - pseudo-random id for unique scroll event listener.
-     */
+  function move(ts) {
+    if (!start) start = ts; // console.log(start, ts);
 
-  }, {
-    key: '_eventsHandler',
-    value: function _eventsHandler(id) {
-      var _this = this,
-          scrollListener = this.scrollListener = 'scroll.zf.' + id;
+    prog = ts - start;
+    fn.apply(elem);
 
-      _this._setSizes(function () {
-        _this._calc(false);
-        if (_this.canStick) {
-          if (!_this.isOn) {
-            _this._events(id);
-          }
-        } else if (_this.isOn) {
-          _this._pauseListeners(scrollListener);
-        }
-      });
+    if (prog < duration) {
+      anim = window.requestAnimationFrame(move, elem);
+    } else {
+      window.cancelAnimationFrame(anim);
+      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
     }
+  }
 
-    /**
-     * Removes event handlers for scroll and change events on anchor.
-     * @fires Sticky#pause
-     * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`
-     */
+  anim = window.requestAnimationFrame(move);
+}
+/**
+ * Animates an element in or out using a CSS transition class.
+ * @function
+ * @private
+ * @param {Boolean} isIn - Defines if the animation is in or out.
+ * @param {Object} element - jQuery or HTML object to animate.
+ * @param {String} animation - CSS class to use.
+ * @param {Function} cb - Callback to run when animation is finished.
+ */
 
-  }, {
-    key: '_pauseListeners',
-    value: function _pauseListeners(scrollListener) {
-      this.isOn = false;
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(scrollListener);
 
-      /**
-       * Fires when the plugin is paused due to resize event shrinking the view.
-       * @event Sticky#pause
-       * @private
-       */
-      this.$element.trigger('pause.zf.sticky');
-    }
+function animate(isIn, element, animation, cb) {
+  element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element).eq(0);
+  if (!element.length) return;
+  var initClass = isIn ? initClasses[0] : initClasses[1];
+  var activeClass = isIn ? activeClasses[0] : activeClasses[1]; // Set up the animation
 
-    /**
-     * Called on every `scroll` event and on `_init`
-     * fires functions based on booleans and cached values
-     * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.
-     * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.
-     */
+  reset();
+  element.addClass(animation).css('transition', 'none');
+  requestAnimationFrame(function () {
+    element.addClass(initClass);
+    if (isIn) element.show();
+  }); // Start the animation
 
-  }, {
-    key: '_calc',
-    value: function _calc(checkSizes, scroll) {
-      if (checkSizes) {
-        this._setSizes();
-      }
+  requestAnimationFrame(function () {
+    element[0].offsetWidth;
+    element.css('transition', '').addClass(activeClass);
+  }); // Clean up the animation when it finishes
 
-      if (!this.canStick) {
-        if (this.isStuck) {
-          this._removeSticky(true);
-        }
-        return false;
-      }
+  element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["transitionend"])(element), finish); // Hides the element (for out animations), resets the element, and runs a callback
 
-      if (!scroll) {
-        scroll = window.pageYOffset;
-      }
+  function finish() {
+    if (!isIn) element.hide();
+    reset();
+    if (cb) cb.apply(element);
+  } // Resets transitions and removes motion-specific classes
 
-      if (scroll >= this.topPoint) {
-        if (scroll <= this.bottomPoint) {
-          if (!this.isStuck) {
-            this._setSticky();
-          }
-        } else {
-          if (this.isStuck) {
-            this._removeSticky(false);
-          }
-        }
-      } else {
-        if (this.isStuck) {
-          this._removeSticky(true);
-        }
-      }
-    }
 
-    /**
-     * Causes the $element to become stuck.
-     * Adds `position: fixed;`, and helper classes.
-     * @fires Sticky#stuckto
-     * @function
-     * @private
-     */
+  function reset() {
+    element[0].style.transitionDuration = 0;
+    element.removeClass("".concat(initClass, " ").concat(activeClass, " ").concat(animation));
+  }
+}
 
-  }, {
-    key: '_setSticky',
-    value: function _setSticky() {
-      var _this = this,
-          stickTo = this.options.stickTo,
-          mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',
-          notStuckTo = stickTo === 'top' ? 'bottom' : 'top',
-          css = {};
 
-      css[mrgn] = this.options[mrgn] + 'em';
-      css[stickTo] = 0;
-      css[notStuckTo] = 'auto';
-      this.isStuck = true;
-      this.$element.removeClass('is-anchored is-at-' + notStuckTo).addClass('is-stuck is-at-' + stickTo).css(css)
-      /**
-       * Fires when the $element has become `position: fixed;`
-       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`
-       * @event Sticky#stuckto
-       */
-      .trigger('sticky.zf.stuckto:' + stickTo);
-      this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd", function () {
-        _this._setSizes();
-      });
-    }
 
-    /**
-     * Causes the $element to become unstuck.
-     * Removes `position: fixed;`, and helper classes.
-     * Adds other helper classes.
-     * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.
-     * @fires Sticky#unstuckfrom
-     * @private
-     */
+/***/ }),
 
-  }, {
-    key: '_removeSticky',
-    value: function _removeSticky(isTop) {
-      var stickTo = this.options.stickTo,
-          stickToTop = stickTo === 'top',
-          css = {},
-          anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,
-          mrgn = stickToTop ? 'marginTop' : 'marginBottom',
-          notStuckTo = stickToTop ? 'bottom' : 'top',
-          topOrBottom = isTop ? 'top' : 'bottom';
+/***/ "./js/foundation.util.nest.js":
+/*!************************************!*\
+  !*** ./js/foundation.util.nest.js ***!
+  \************************************/
+/*! exports provided: Nest */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-      css[mrgn] = 0;
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Nest", function() { return Nest; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 
-      css['bottom'] = 'auto';
-      if (isTop) {
-        css['top'] = 0;
-      } else {
-        css['top'] = anchorPt;
-      }
 
-      this.isStuck = false;
-      this.$element.removeClass('is-stuck is-at-' + stickTo).addClass('is-anchored is-at-' + topOrBottom).css(css)
-      /**
-       * Fires when the $element has become anchored.
-       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`
-       * @event Sticky#unstuckfrom
-       */
-      .trigger('sticky.zf.unstuckfrom:' + topOrBottom);
-    }
 
-    /**
-     * Sets the $element and $container sizes for plugin.
-     * Calls `_setBreakPoints`.
-     * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.
-     * @private
-     */
+var Nest = {
+  Feather: function Feather(menu) {
+    var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zf';
+    menu.attr('role', 'menubar');
+    var items = menu.find('li').attr({
+      'role': 'menuitem'
+    }),
+        subMenuClass = "is-".concat(type, "-submenu"),
+        subItemClass = "".concat(subMenuClass, "-item"),
+        hasSubClass = "is-".concat(type, "-submenu-parent"),
+        applyAria = type !== 'accordion'; // Accordions handle their own ARIA attriutes.
+
+    items.each(function () {
+      var $item = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+          $sub = $item.children('ul');
+
+      if ($sub.length) {
+        $item.addClass(hasSubClass);
+
+        if (applyAria) {
+          $item.attr({
+            'aria-haspopup': true,
+            'aria-label': $item.children('a:first').text()
+          }); // Note:  Drilldowns behave differently in how they hide, and so need
+          // additional attributes.  We should look if this possibly over-generalized
+          // utility (Nest) is appropriate when we rework menus in 6.4
+
+          if (type === 'drilldown') {
+            $item.attr({
+              'aria-expanded': false
+            });
+          }
+        }
+
+        $sub.addClass("submenu ".concat(subMenuClass)).attr({
+          'data-submenu': '',
+          'role': 'menubar'
+        });
 
-  }, {
-    key: '_setSizes',
-    value: function _setSizes(cb) {
-      this.canStick = __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */].is(this.options.stickyOn);
-      if (!this.canStick) {
-        if (cb && typeof cb === 'function') {
-          cb();
+        if (type === 'drilldown') {
+          $sub.attr({
+            'aria-hidden': true
+          });
         }
       }
-      var _this = this,
-          newElemWidth = this.$container[0].getBoundingClientRect().width,
-          comp = window.getComputedStyle(this.$container[0]),
-          pdngl = parseInt(comp['padding-left'], 10),
-          pdngr = parseInt(comp['padding-right'], 10);
 
-      if (this.$anchor && this.$anchor.length) {
-        this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;
-      } else {
-        this._parsePoints();
+      if ($item.parent('[data-submenu]').length) {
+        $item.addClass("is-submenu-item ".concat(subItemClass));
       }
+    });
+    return;
+  },
+  Burn: function Burn(menu, type) {
+    var //items = menu.find('li'),
+    subMenuClass = "is-".concat(type, "-submenu"),
+        subItemClass = "".concat(subMenuClass, "-item"),
+        hasSubClass = "is-".concat(type, "-submenu-parent");
+    menu.find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li').removeClass("".concat(subMenuClass, " ").concat(subItemClass, " ").concat(hasSubClass, " is-submenu-item submenu is-active")).removeAttr('data-submenu').css('display', '');
+  }
+};
 
-      this.$element.css({
-        'max-width': newElemWidth - pdngl - pdngr + 'px'
-      });
 
-      var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;
-      if (this.$element.css("display") == "none") {
-        newContainerHeight = 0;
-      }
-      this.containerHeight = newContainerHeight;
-      this.$container.css({
-        height: newContainerHeight
-      });
-      this.elemHeight = newContainerHeight;
+/***/ }),
 
-      if (!this.isStuck) {
-        if (this.$element.hasClass('is-at-bottom')) {
-          var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;
-          this.$element.css('top', anchorPt);
-        }
-      }
+/***/ "./js/foundation.util.timer.js":
+/*!*************************************!*\
+  !*** ./js/foundation.util.timer.js ***!
+  \*************************************/
+/*! exports provided: Timer */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-      this._setBreakPoints(newContainerHeight, function () {
-        if (cb && typeof cb === 'function') {
-          cb();
-        }
-      });
-    }
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return Timer; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 
-    /**
-     * Sets the upper and lower breakpoints for the element to become sticky/unsticky.
-     * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.
-     * @param {Function} cb - optional callback function to be called on completion.
-     * @private
-     */
 
-  }, {
-    key: '_setBreakPoints',
-    value: function _setBreakPoints(elemHeight, cb) {
-      if (!this.canStick) {
-        if (cb && typeof cb === 'function') {
-          cb();
-        } else {
-          return false;
-        }
-      }
-      var mTop = emCalc(this.options.marginTop),
-          mBtm = emCalc(this.options.marginBottom),
-          topPoint = this.points ? this.points[0] : this.$anchor.offset().top,
-          bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,
 
-      // topPoint = this.$anchor.offset().top || this.points[0],
-      // bottomPoint = topPoint + this.anchorHeight || this.points[1],
-      winHeight = window.innerHeight;
 
-      if (this.options.stickTo === 'top') {
-        topPoint -= mTop;
-        bottomPoint -= elemHeight + mTop;
-      } else if (this.options.stickTo === 'bottom') {
-        topPoint -= winHeight - (elemHeight + mBtm);
-        bottomPoint -= winHeight - mBtm;
-      } else {
-        //this would be the stickTo: both option... tricky
-      }
+function Timer(elem, options, cb) {
+  var _this = this,
+      duration = options.duration,
+      //options is an object for easily adding features later.
+  nameSpace = Object.keys(elem.data())[0] || 'timer',
+      remain = -1,
+      start,
+      timer;
 
-      this.topPoint = topPoint;
-      this.bottomPoint = bottomPoint;
+  this.isPaused = false;
 
-      if (cb && typeof cb === 'function') {
-        cb();
-      }
-    }
+  this.restart = function () {
+    remain = -1;
+    clearTimeout(timer);
+    this.start();
+  };
 
-    /**
-     * Destroys the current sticky element.
-     * Resets the element to the top position first.
-     * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.
-     * @function
-     */
+  this.start = function () {
+    this.isPaused = false; // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
 
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this._removeSticky(true);
+    clearTimeout(timer);
+    remain = remain <= 0 ? duration : remain;
+    elem.data('paused', false);
+    start = Date.now();
+    timer = setTimeout(function () {
+      if (options.infinite) {
+        _this.restart(); //rerun the timer.
 
-      this.$element.removeClass(this.options.stickyClass + ' is-anchored is-at-top').css({
-        height: '',
-        top: '',
-        bottom: '',
-        'max-width': ''
-      }).off('resizeme.zf.trigger').off('mutateme.zf.trigger');
-      if (this.$anchor && this.$anchor.length) {
-        this.$anchor.off('change.zf.sticky');
       }
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(this.scrollListener);
 
-      if (this.wasWrapped) {
-        this.$element.unwrap();
-      } else {
-        this.$container.removeClass(this.options.containerClass).css({
-          height: ''
-        });
+      if (cb && typeof cb === 'function') {
+        cb();
       }
-    }
-  }]);
-
-  return Sticky;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["a" /* Plugin */]);
+    }, remain);
+    elem.trigger("timerstart.zf.".concat(nameSpace));
+  };
 
-Sticky.defaults = {
-  /**
-   * Customizable container template. Add your own classes for styling and sizing.
-   * @option
-   * @type {string}
-   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'
-   */
-  container: '<div data-sticky-container></div>',
-  /**
-   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.
-   * @option
-   * @type {string}
-   * @default 'top'
-   */
-  stickTo: 'top',
-  /**
-   * If anchored to a single element, the id of that element.
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  anchor: '',
-  /**
-   * If using more than one element as anchor points, the id of the top anchor.
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  topAnchor: '',
-  /**
-   * If using more than one element as anchor points, the id of the bottom anchor.
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  btmAnchor: '',
-  /**
-   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.
-   * @option
-   * @type {number}
-   * @default 1
-   */
-  marginTop: 1,
-  /**
-   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.
-   * @option
-   * @type {number}
-   * @default 1
-   */
-  marginBottom: 1,
-  /**
-   * Breakpoint string that is the minimum screen size an element should become sticky.
-   * @option
-   * @type {string}
-   * @default 'medium'
-   */
-  stickyOn: 'medium',
-  /**
-   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.
-   * @option
-   * @type {string}
-   * @default 'sticky'
-   */
-  stickyClass: 'sticky',
-  /**
-   * Class applied to sticky container. Foundation defaults to `sticky-container`.
-   * @option
-   * @type {string}
-   * @default 'sticky-container'
-   */
-  containerClass: 'sticky-container',
-  /**
-   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.
-   * @option
-   * @type {number}
-   * @default -1
-   */
-  checkEvery: -1
-};
+  this.pause = function () {
+    this.isPaused = true; //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
 
-/**
- * Helper function to calculate em values
- * @param Number {em} - number of em's to calculate into pixels
- */
-function emCalc(em) {
-  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;
+    clearTimeout(timer);
+    elem.data('paused', true);
+    var end = Date.now();
+    remain = remain - (end - start);
+    elem.trigger("timerpaused.zf.".concat(nameSpace));
+  };
 }
 
 
 
 /***/ }),
-/* 34 */
+
+/***/ "./js/foundation.util.touch.js":
+/*!*************************************!*\
+  !*** ./js/foundation.util.touch.js ***!
+  \*************************************/
+/*! exports provided: Touch */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Toggler; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_triggers__ = __webpack_require__(5);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Touch", function() { return Touch; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+function _createClass(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; }
+//**************************************************
+//**Work inspired by multiple jquery swipe plugins**
+//**Done by Yohai Ararat ***************************
+//**************************************************
 
-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; }
+var Touch = {};
+var startPosX,
+    startPosY,
+    startTime,
+    elapsedTime,
+    startEvent,
+    isMoving = false,
+    didMoved = false;
 
+function onTouchEnd(e) {
+  this.removeEventListener('touchmove', onTouchMove);
+  this.removeEventListener('touchend', onTouchEnd); // If the touch did not move, consider it as a "tap"
 
+  if (!didMoved) {
+    var tapEvent = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('tap', startEvent || e);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(tapEvent);
+  }
 
+  startEvent = null;
+  isMoving = false;
+  didMoved = false;
+}
 
+function onTouchMove(e) {
+  if (jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.preventDefault) {
+    e.preventDefault();
+  }
 
+  if (isMoving) {
+    var x = e.touches[0].pageX;
+    var y = e.touches[0].pageY;
+    var dx = startPosX - x;
+    var dy = startPosY - y;
+    var dir;
+    didMoved = true;
+    elapsedTime = new Date().getTime() - startTime;
 
-/**
- * Toggler module.
- * @module foundation.toggler
- * @requires foundation.util.motion
- * @requires foundation.util.triggers
- */
+    if (Math.abs(dx) >= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.moveThreshold && elapsedTime <= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.timeThreshold) {
+      dir = dx > 0 ? 'left' : 'right';
+    } // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
+    //   dir = dy > 0 ? 'down' : 'up';
+    // }
 
-var Toggler = function (_Plugin) {
-  _inherits(Toggler, _Plugin);
 
-  function Toggler() {
-    _classCallCheck(this, Toggler);
+    if (dir) {
+      e.preventDefault();
+      onTouchEnd.apply(this, arguments);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('swipe', e), dir).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event("swipe".concat(dir), e));
+    }
+  }
+}
 
-    return _possibleConstructorReturn(this, (Toggler.__proto__ || Object.getPrototypeOf(Toggler)).apply(this, arguments));
+function onTouchStart(e) {
+  if (e.touches.length == 1) {
+    startPosX = e.touches[0].pageX;
+    startPosY = e.touches[0].pageY;
+    startEvent = e;
+    isMoving = true;
+    didMoved = false;
+    startTime = new Date().getTime();
+    this.addEventListener('touchmove', onTouchMove, false);
+    this.addEventListener('touchend', onTouchEnd, false);
   }
+}
 
-  _createClass(Toggler, [{
-    key: '_setup',
+function init() {
+  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);
+}
 
-    /**
-     * Creates a new instance of Toggler.
-     * @class
-     * @name Toggler
-     * @fires Toggler#init
-     * @param {Object} element - jQuery object to add the trigger to.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Toggler.defaults, element.data(), options);
-      this.className = '';
-      this.className = 'Toggler'; // ie9 back compat
+function teardown() {
+  this.removeEventListener('touchstart', onTouchStart);
+}
 
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_3__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+var SpotSwipe =
+/*#__PURE__*/
+function () {
+  function SpotSwipe($) {
+    _classCallCheck(this, SpotSwipe);
 
-      this._init();
-      this._events();
-    }
+    this.version = '1.0.0';
+    this.enabled = 'ontouchstart' in document.documentElement;
+    this.preventDefault = false;
+    this.moveThreshold = 75;
+    this.timeThreshold = 200;
+    this.$ = $;
 
-    /**
-     * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.
-     * @function
-     * @private
-     */
+    this._init();
+  }
 
-  }, {
-    key: '_init',
+  _createClass(SpotSwipe, [{
+    key: "_init",
     value: function _init() {
-      var input;
-      // Parse animation classes if they were set
-      if (this.options.animate) {
-        input = this.options.animate.split(' ');
-
-        this.animationIn = input[0];
-        this.animationOut = input[1] || null;
-      }
-      // Otherwise, parse toggle class
-      else {
-          input = this.$element.data('toggler');
-          // Allow for a . at the beginning of the string
-          this.className = input[0] === '.' ? input.slice(1) : input;
-        }
-
-      // Add ARIA attributes to triggers
-      var id = this.$element[0].id;
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-controls', id);
-      // If the target is hidden, add aria-hidden
-      this.$element.attr('aria-expanded', this.$element.is(':hidden') ? false : true);
+      var $ = this.$;
+      $.event.special.swipe = {
+        setup: init
+      };
+      $.event.special.tap = {
+        setup: init
+      };
+      $.each(['left', 'up', 'down', 'right'], function () {
+        $.event.special["swipe".concat(this)] = {
+          setup: function setup() {
+            $(this).on('swipe', $.noop);
+          }
+        };
+      });
     }
+  }]);
 
-    /**
-     * Initializes events for the toggle trigger.
-     * @function
-     * @private
-     */
+  return SpotSwipe;
+}();
+/****************************************************
+ * As far as I can tell, both setupSpotSwipe and    *
+ * setupTouchHandler should be idempotent,          *
+ * because they directly replace functions &        *
+ * values, and do not add event handlers directly.  *
+ ****************************************************/
 
-  }, {
-    key: '_events',
-    value: function _events() {
-      this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));
-    }
 
-    /**
-     * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was "on" or "off".
-     * @function
-     * @fires Toggler#on
-     * @fires Toggler#off
    */
+Touch.setupSpotSwipe = function ($) {
+  $.spotSwipe = new SpotSwipe($);
+};
+/****************************************************
+ * Method for adding pseudo drag events to elements *
***************************************************/
 
-  }, {
-    key: 'toggle',
-    value: function toggle() {
-      this[this.options.animate ? '_toggleAnimate' : '_toggleClass']();
-    }
-  }, {
-    key: '_toggleClass',
-    value: function _toggleClass() {
-      this.$element.toggleClass(this.className);
 
-      var isOn = this.$element.hasClass(this.className);
-      if (isOn) {
-        /**
-         * Fires if the target element has the class after a toggle.
-         * @event Toggler#on
-         */
-        this.$element.trigger('on.zf.toggler');
-      } else {
-        /**
-         * Fires if the target element does not have the class after a toggle.
-         * @event Toggler#off
-         */
-        this.$element.trigger('off.zf.toggler');
-      }
+Touch.setupTouchHandler = function ($) {
+  $.fn.addTouch = function () {
+    this.each(function (i, el) {
+      $(el).bind('touchstart touchmove touchend touchcancel', function (event) {
+        //we pass the original event object because the jQuery event
+        //object is normalized to w3c specs and does not provide the TouchList
+        handleTouch(event);
+      });
+    });
 
-      this._updateARIA(isOn);
-      this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');
-    }
-  }, {
-    key: '_toggleAnimate',
-    value: function _toggleAnimate() {
-      var _this = this;
+    var handleTouch = function handleTouch(event) {
+      var touches = event.changedTouches,
+          first = touches[0],
+          eventTypes = {
+        touchstart: 'mousedown',
+        touchmove: 'mousemove',
+        touchend: 'mouseup'
+      },
+          type = eventTypes[event.type],
+          simulatedEvent;
 
-      if (this.$element.is(':hidden')) {
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["a" /* Motion */].animateIn(this.$element, this.animationIn, function () {
-          _this._updateARIA(true);
-          this.trigger('on.zf.toggler');
-          this.find('[data-mutate]').trigger('mutateme.zf.trigger');
+      if ('MouseEvent' in window && typeof window.MouseEvent === 'function') {
+        simulatedEvent = new window.MouseEvent(type, {
+          'bubbles': true,
+          'cancelable': true,
+          'screenX': first.screenX,
+          'screenY': first.screenY,
+          'clientX': first.clientX,
+          'clientY': first.clientY
         });
       } else {
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["a" /* Motion */].animateOut(this.$element, this.animationOut, function () {
-          _this._updateARIA(false);
-          this.trigger('off.zf.toggler');
-          this.find('[data-mutate]').trigger('mutateme.zf.trigger');
-        });
+        simulatedEvent = document.createEvent('MouseEvent');
+        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0
+        /*left*/
+        , null);
       }
-    }
-  }, {
-    key: '_updateARIA',
-    value: function _updateARIA(isOn) {
-      this.$element.attr('aria-expanded', isOn ? true : false);
-    }
-
-    /**
-     * Destroys the instance of Toggler on the element.
-     * @function
-     */
-
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$element.off('.zf.toggler');
-    }
-  }]);
 
-  return Toggler;
-}(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__["a" /* Plugin */]);
+      first.target.dispatchEvent(simulatedEvent);
+    };
+  };
+};
 
-Toggler.defaults = {
-  /**
-   * Tells the plugin if the element should animated when toggled.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  animate: false
+Touch.init = function ($) {
+  if (typeof $.spotSwipe === 'undefined') {
+    Touch.setupSpotSwipe($);
+    Touch.setupTouchHandler($);
+  }
 };
 
 
 
 /***/ }),
-/* 35 */
+
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Tooltip; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_triggers__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_positionable__ = __webpack_require__(15);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./js/foundation.util.motion.js");
 
-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); } };
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
-
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-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; }
 
 
 
 
+var MutationObserver = function () {
+  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
 
+  for (var i = 0; i < prefixes.length; i++) {
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
+    }
+  }
 
+  return false;
+}();
 
+var triggers = function triggers(el, type) {
+  el.data(type).split(' ').forEach(function (id) {
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
+  });
+};
 
-/**
- * Tooltip module.
- * @module foundation.tooltip
- * @requires foundation.util.box
- * @requires foundation.util.mediaQuery
- * @requires foundation.util.triggers
- */
+var Triggers = {
+  Listeners: {
+    Basic: {},
+    Global: {}
+  },
+  Initializers: {}
+};
+Triggers.Listeners.Basic = {
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
+  },
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
 
-var Tooltip = function (_Positionable) {
-  _inherits(Tooltip, _Positionable);
+    if (id) {
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
+    } else {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
+    }
+  },
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
 
-  function Tooltip() {
-    _classCallCheck(this, Tooltip);
+    if (id) {
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
+    } else {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
+    }
+  },
+  closeableListener: function closeableListener(e) {
+    e.stopPropagation();
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
-    return _possibleConstructorReturn(this, (Tooltip.__proto__ || Object.getPrototypeOf(Tooltip)).apply(this, arguments));
+    if (animation !== '') {
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
+      });
+    } else {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
+    }
+  },
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-  _createClass(Tooltip, [{
-    key: '_setup',
+Triggers.Initializers.addOpenListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
+  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
+// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
 
-    /**
-     * Creates a new instance of a Tooltip.
-     * @class
-     * @name Tooltip
-     * @fires Tooltip#init
-     * @param {jQuery} element - jQuery object to attach a tooltip to.
-     * @param {Object} options - object to extend the default configuration.
-     */
-    value: function _setup(element, options) {
-      this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Tooltip.defaults, this.$element.data(), options);
-      this.className = 'Tooltip'; // ie9 back compat
 
-      this.isActive = false;
-      this.isClick = false;
+Triggers.Initializers.addCloseListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
+  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_3__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
 
-      this._init();
-    }
+Triggers.Initializers.addToggleListener = function ($elem) {
+  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
+  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
 
-    /**
-     * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.
-     * @private
-     */
 
-  }, {
-    key: '_init',
-    value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
-      var elemId = this.$element.attr('aria-describedby') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["b" /* GetYoDigits */])(6, 'tooltip');
+Triggers.Initializers.addCloseableListener = function ($elem) {
+  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
+  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
 
-      this.options.tipText = this.options.tipText || this.$element.attr('title');
-      this.template = this.options.template ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.options.template) : this._buildTemplate(elemId);
 
-      if (this.options.allowHtml) {
-        this.template.appendTo(document.body).html(this.options.tipText).hide();
-      } else {
-        this.template.appendTo(document.body).text(this.options.tipText).hide();
-      }
+Triggers.Initializers.addToggleFocusListener = function ($elem) {
+  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
+  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
+}; // More Global/complex listeners and triggers
 
-      this.$element.attr({
-        'title': '',
-        'aria-describedby': elemId,
-        'data-yeti-box': elemId,
-        'data-toggle': elemId,
-        'data-resize': elemId
-      }).addClass(this.options.triggerClass);
 
-      _get(Tooltip.prototype.__proto__ || Object.getPrototypeOf(Tooltip.prototype), '_init', this).call(this);
-      this._events();
-    }
-  }, {
-    key: '_getDefaultPosition',
-    value: function _getDefaultPosition() {
-      // handle legacy classnames
-      var position = this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);
-      return position ? position[0] : 'top';
-    }
-  }, {
-    key: '_getDefaultAlignment',
-    value: function _getDefaultAlignment() {
-      return 'center';
-    }
-  }, {
-    key: '_getHOffset',
-    value: function _getHOffset() {
-      if (this.position === 'left' || this.position === 'right') {
-        return this.options.hOffset + this.options.tooltipWidth;
-      } else {
-        return this.options.hOffset;
-      }
-    }
-  }, {
-    key: '_getVOffset',
-    value: function _getVOffset() {
-      if (this.position === 'top' || this.position === 'bottom') {
-        return this.options.vOffset + this.options.tooltipHeight;
-      } else {
-        return this.options.vOffset;
-      }
-    }
+Triggers.Listeners.Global = {
+  resizeListener: function resizeListener($nodes) {
+    if (!MutationObserver) {
+      //fallback for IE 9
+      $nodes.each(function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
+      });
+    } //trigger all listening elements and signal a resize event
 
-    /**
-     * builds the tooltip element, adds attributes, and returns the template.
-     * @private
-     */
 
-  }, {
-    key: '_buildTemplate',
-    value: function _buildTemplate(id) {
-      var templateClasses = (this.options.tooltipClass + ' ' + this.options.positionClass + ' ' + this.options.templateClasses).trim();
-      var $template = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<div></div>').addClass(templateClasses).attr({
-        'role': 'tooltip',
-        'aria-hidden': true,
-        'data-is-active': false,
-        'data-is-focus': false,
-        'id': id
+    $nodes.attr('data-events', "resize");
+  },
+  scrollListener: function scrollListener($nodes) {
+    if (!MutationObserver) {
+      //fallback for IE 9
+      $nodes.each(function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-      return $template;
-    }
-
-    /**
-     * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.
-     * if the tooltip is larger than the screen width, default to full width - any user selected margin
-     * @private
-     */
+    } //trigger all listening elements and signal a scroll event
 
-  }, {
-    key: '_setPosition',
-    value: function _setPosition() {
-      _get(Tooltip.prototype.__proto__ || Object.getPrototypeOf(Tooltip.prototype), '_setPosition', this).call(this, this.$element, this.template);
-    }
 
-    /**
-     * reveals the tooltip, and fires an event to close any other open tooltips on the page
-     * @fires Tooltip#closeme
-     * @fires Tooltip#show
-     * @function
-     */
+    $nodes.attr('data-events', "scroll");
+  },
+  closeMeListener: function closeMeListener(e, pluginId) {
+    var plugin = e.namespace.split('.')[0];
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
+    plugins.each(function () {
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
 
-  }, {
-    key: 'show',
-    value: function show() {
-      if (this.options.showOn !== 'all' && !__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */].is(this.options.showOn)) {
-        // console.error('The screen is too small to display this tooltip');
-        return false;
-      }
+      _this.triggerHandler('close.zf.trigger', [_this]);
+    });
+  } // Global, parses whole document.
 
-      var _this = this;
-      this.template.css('visibility', 'hidden').show();
-      this._setPosition();
-      this.template.removeClass('top bottom left right').addClass(this.position);
-      this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);
+};
 
-      /**
-       * Fires to close all other open tooltips on the page
-       * @event Closeme#tooltip
-       */
-      this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
+      plugNames = ['dropdown', 'tooltip', 'reveal'];
 
-      this.template.attr({
-        'data-is-active': true,
-        'aria-hidden': false
-      });
-      _this.isActive = true;
-      // console.log(this.template);
-      this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {
-        //maybe do stuff?
-      });
-      /**
-       * Fires when the tooltip is shown
-       * @event Tooltip#show
-       */
-      this.$element.trigger('show.zf.tooltip');
+  if (pluginName) {
+    if (typeof pluginName === 'string') {
+      plugNames.push(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
+    } else {
+      console.error('Plugin names must be strings');
     }
+  }
 
-    /**
-     * Hides the current tooltip, and resets the positioning class if it was changed due to collision
-     * @fires Tooltip#hide
-     * @function
-     */
+  if (yetiBoxes.length) {
+    var listeners = plugNames.map(function (name) {
+      return "closeme.zf.".concat(name);
+    }).join(' ');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+  }
+};
 
-  }, {
-    key: 'hide',
-    value: function hide() {
-      // console.log('hiding', this.$element.data('yeti-box'));
-      var _this = this;
-      this.template.stop().attr({
-        'aria-hidden': true,
-        'data-is-active': false
-      }).fadeOut(this.options.fadeOutDuration, function () {
-        _this.isActive = false;
-        _this.isClick = false;
-      });
-      /**
-       * fires when the tooltip is hidden
-       * @event Tooltip#hide
-       */
-      this.$element.trigger('hide.zf.tooltip');
+function debounceGlobalListener(debounce, trigger, listener) {
+  var timer,
+      args = Array.prototype.slice.call(arguments, 3);
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
+    if (timer) {
+      clearTimeout(timer);
     }
 
-    /**
-     * adds event listeners for the tooltip and its anchor
-     * TODO combine some of the listeners like focus and mouseenter, etc.
-     * @private
-     */
+    timer = setTimeout(function () {
+      listener.apply(null, args);
+    }, debounce || 10); //default time to emit scroll event
+  });
+}
 
-  }, {
-    key: '_events',
-    value: function _events() {
-      var _this = this;
-      var $template = this.template;
-      var isFocus = false;
+Triggers.Initializers.addResizeListener = function (debounce) {
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
 
-      if (!this.options.disableHover) {
+  if ($nodes.length) {
+    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
+  }
+};
 
-        this.$element.on('mouseenter.zf.tooltip', function (e) {
-          if (!_this.isActive) {
-            _this.timeout = setTimeout(function () {
-              _this.show();
-            }, _this.options.hoverDelay);
-          }
-        }).on('mouseleave.zf.tooltip', function (e) {
-          clearTimeout(_this.timeout);
-          if (!isFocus || _this.isClick && !_this.options.clickOpen) {
-            _this.hide();
-          }
-        });
-      }
+Triggers.Initializers.addScrollListener = function (debounce) {
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
 
-      if (this.options.clickOpen) {
-        this.$element.on('mousedown.zf.tooltip', function (e) {
-          e.stopImmediatePropagation();
-          if (_this.isClick) {
-            //_this.hide();
-            // _this.isClick = false;
-          } else {
-            _this.isClick = true;
-            if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {
-              _this.show();
-            }
-          }
-        });
-      } else {
-        this.$element.on('mousedown.zf.tooltip', function (e) {
-          e.stopImmediatePropagation();
-          _this.isClick = true;
-        });
-      }
+  if ($nodes.length) {
+    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
+  }
+};
 
-      if (!this.options.disableForTouch) {
-        this.$element.on('tap.zf.tooltip touchend.zf.tooltip', function (e) {
-          _this.isActive ? _this.hide() : _this.show();
-        });
-      }
+Triggers.Initializers.addMutationEventsListener = function ($elem) {
+  if (!MutationObserver) {
+    return false;
+  }
 
-      this.$element.on({
-        // 'toggle.zf.trigger': this.toggle.bind(this),
-        // 'close.zf.trigger': this.hide.bind(this)
-        'close.zf.trigger': this.hide.bind(this)
-      });
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
 
-      this.$element.on('focus.zf.tooltip', function (e) {
-        isFocus = true;
-        if (_this.isClick) {
-          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't
-          // a real focus, otherwise on hover and come back we get bad behavior
-          if (!_this.options.clickOpen) {
-            isFocus = false;
-          }
-          return false;
-        } else {
-          _this.show();
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
+
+    switch (mutationRecordsList[0].type) {
+      case "attributes":
+        if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
+          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
-      }).on('focusout.zf.tooltip', function (e) {
-        isFocus = false;
-        _this.isClick = false;
-        _this.hide();
-      }).on('resizeme.zf.trigger', function () {
-        if (_this.isActive) {
-          _this._setPosition();
+
+        if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
+          $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
-      });
-    }
 
-    /**
-     * adds a toggle method, in addition to the static show() & hide() functions
-     * @function
-     */
+        if (mutationRecordsList[0].attributeName === "style") {
+          $target.closest("[data-mutate]").attr("data-events", "mutate");
+          $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+        }
 
-  }, {
-    key: 'toggle',
-    value: function toggle() {
-      if (this.isActive) {
-        this.hide();
-      } else {
-        this.show();
-      }
-    }
+        break;
 
-    /**
-     * Destroys an instance of tooltip, removes template element from the view.
-     * @function
-     */
+      case "childList":
+        $target.closest("[data-mutate]").attr("data-events", "mutate");
+        $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
+        break;
 
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass('has-tip top right left').removeAttr('aria-describedby aria-haspopup data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');
+      default:
+        return false;
+      //nothing
+    }
+  };
 
-      this.template.remove();
+  if ($nodes.length) {
+    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
+    for (var i = 0; i <= $nodes.length - 1; i++) {
+      var elementObserver = new MutationObserver(listeningElementsMutation);
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
-  }]);
+  }
+};
 
-  return Tooltip;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_positionable__["a" /* Positionable */]);
+Triggers.Initializers.addSimpleListeners = function () {
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
+  Triggers.Initializers.addOpenListener($document);
+  Triggers.Initializers.addCloseListener($document);
+  Triggers.Initializers.addToggleListener($document);
+  Triggers.Initializers.addCloseableListener($document);
+  Triggers.Initializers.addToggleFocusListener($document);
+};
 
-Tooltip.defaults = {
-  disableForTouch: false,
-  /**
-   * Time, in ms, before a tooltip should open on hover.
-   * @option
-   * @type {number}
-   * @default 200
-   */
-  hoverDelay: 200,
-  /**
-   * Time, in ms, a tooltip should take to fade into view.
-   * @option
-   * @type {number}
-   * @default 150
-   */
-  fadeInDuration: 150,
-  /**
-   * Time, in ms, a tooltip should take to fade out of view.
-   * @option
-   * @type {number}
-   * @default 150
-   */
-  fadeOutDuration: 150,
-  /**
-   * Disables hover events from opening the tooltip if set to true
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  disableHover: false,
-  /**
-   * Optional addtional classes to apply to the tooltip template on init.
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  templateClasses: '',
-  /**
-   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.
-   * @option
-   * @type {string}
-   * @default 'tooltip'
-   */
-  tooltipClass: 'tooltip',
-  /**
-   * Class applied to the tooltip anchor element.
-   * @option
-   * @type {string}
-   * @default 'has-tip'
-   */
-  triggerClass: 'has-tip',
-  /**
-   * Minimum breakpoint size at which to open the tooltip.
-   * @option
-   * @type {string}
-   * @default 'small'
-   */
-  showOn: 'small',
-  /**
-   * Custom template to be used to generate markup for tooltip.
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  template: '',
-  /**
-   * Text displayed in the tooltip template on open.
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  tipText: '',
-  touchCloseText: 'Tap to close.',
-  /**
-   * Allows the tooltip to remain open if triggered with a click or touch event.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  clickOpen: true,
-  /**
-   * DEPRECATED Additional positioning classes, set by the JS
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  positionClass: '',
-  /**
-   * Position of tooltip. Can be left, right, bottom, top, or auto.
-   * @option
-   * @type {string}
-   * @default 'auto'
-   */
-  position: 'auto',
-  /**
-   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.
-   * @option
-   * @type {string}
-   * @default 'auto'
-   */
-  alignment: 'auto',
-  /**
-   * Allow overlap of container/window. If false, tooltip will first try to
-   * position as defined by data-position and data-alignment, but reposition if
-   * it would cause an overflow.  @option
-   * @type {boolean}
-   * @default false
-   */
-  allowOverlap: false,
-  /**
-   * Allow overlap of only the bottom of the container. This is the most common
-   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
-   * screen but not otherwise influence or break out of the container.
-   * Less common for tooltips.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  allowBottomOverlap: false,
-  /**
-   * Distance, in pixels, the template should push away from the anchor on the Y axis.
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  vOffset: 0,
-  /**
-   * Distance, in pixels, the template should push away from the anchor on the X axis
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  hOffset: 0,
-  /**
-   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip
-   * @option
-   * @type {number}
-   * @default 14
-   */
-  tooltipHeight: 14,
-  /**
-   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip
-   * @option
-   * @type {number}
-   * @default 12
-   */
-  tooltipWidth: 12,
-  /**
-  * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,
-  * allowing HTML may open yourself up to XSS attacks.
-  * @option
-  * @type {boolean}
-  * @default false
-  */
-  allowHtml: false
+Triggers.Initializers.addGlobalListeners = function () {
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
+  Triggers.Initializers.addMutationEventsListener($document);
+  Triggers.Initializers.addResizeListener();
+  Triggers.Initializers.addScrollListener();
+  Triggers.Initializers.addClosemeListener();
 };
 
-/**
- * TODO utilize resize event trigger
- */
+Triggers.init = function ($, Foundation) {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
+      Triggers.Initializers.addSimpleListeners();
+      Triggers.Initializers.addGlobalListeners();
+      $.triggersInitialized = true;
+    }
+  });
+
+  if (Foundation) {
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
+    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
+  }
+};
 
 
 
 /***/ }),
-/* 36 */
+
+/***/ 0:
+/*!****************************************!*\
+  !*** multi ./js/entries/foundation.js ***!
+  \****************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(19);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/foundation.js */"./js/entries/foundation.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
-/******/ ]);
\ No newline at end of file
+
+/******/ });
+});
+//# sourceMappingURL=foundation.js.map
\ No newline at end of file
diff --git a/dist/js/foundation.js.map b/dist/js/foundation.js.map
new file mode 100644 (file)
index 0000000..c740245
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack:///webpack/universalModuleDefinition","webpack:///webpack/bootstrap","webpack:///./js/entries/foundation.js","webpack:///./js/foundation.abide.js","webpack:///./js/foundation.accordion.js","webpack:///./js/foundation.accordionMenu.js","webpack:///./js/foundation.core.js","webpack:///./js/foundation.core.plugin.js","webpack:///./js/foundation.core.utils.js","webpack:///./js/foundation.drilldown.js","webpack:///./js/foundation.dropdown.js","webpack:///./js/foundation.dropdownMenu.js","webpack:///./js/foundation.equalizer.js","webpack:///./js/foundation.interchange.js","webpack:///./js/foundation.magellan.js","webpack:///./js/foundation.offcanvas.js","webpack:///./js/foundation.orbit.js","webpack:///./js/foundation.positionable.js","webpack:///./js/foundation.responsiveAccordionTabs.js","webpack:///./js/foundation.responsiveMenu.js","webpack:///./js/foundation.responsiveToggle.js","webpack:///./js/foundation.reveal.js","webpack:///./js/foundation.slider.js","webpack:///./js/foundation.smoothScroll.js","webpack:///./js/foundation.sticky.js","webpack:///./js/foundation.tabs.js","webpack:///./js/foundation.toggler.js","webpack:///./js/foundation.tooltip.js","webpack:///./js/foundation.util.box.js","webpack:///./js/foundation.util.imageLoader.js","webpack:///./js/foundation.util.keyboard.js","webpack:///./js/foundation.util.mediaQuery.js","webpack:///./js/foundation.util.motion.js","webpack:///./js/foundation.util.nest.js","webpack:///./js/foundation.util.timer.js","webpack:///./js/foundation.util.touch.js","webpack:///./js/foundation.util.triggers.js","webpack:///external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","addToJquery","$","rtl","CoreUtils","GetYoDigits","transitionend","RegExpEscape","onLoad","Box","onImagesLoaded","Keyboard","MediaQuery","Motion","Move","Nest","Timer","Touch","init","Triggers","_init","plugin","Abide","Accordion","AccordionMenu","Drilldown","Dropdown","DropdownMenu","Equalizer","Interchange","Magellan","OffCanvas","Orbit","ResponsiveMenu","ResponsiveToggle","Reveal","Slider","SmoothScroll","Sticky","Tabs","Toggler","Tooltip","ResponsiveAccordionTabs","element","options","$element","extend","defaults","data","className","$inputs","merge","find","not","$globalErrors","a11yAttributes","each","i","input","addA11yAttributes","error","addGlobalErrorA11yAttributes","_events","off","on","resetForm","validateForm","validateOn","e","validateInput","target","liveValidate","validateOnBlur","$el","attr","isGood","type","checked","opt","length","val","id","$error","siblings","formErrorSelector","parent","add","$label","closest","$els","labels","map","el","findLabel","$formError","findFormError","addClass","labelErrorClass","formErrorClass","inputErrorClass","$errors","$labels","filter","first","errorId","elemId","label","end","a11yErrorLevel","groupName","findRadioLabels","$formErrors","removeClass","removeRadioErrorClasses","clearRequire","requiredCheck","validated","customValidator","validator","equalTo","is","validateRadio","validateText","matchValidation","validators","goodToGo","indexOf","message","dependentElements","_this","trigger","acc","push","noError","elem","$elem","css","pattern","inputText","valid","patterns","hasOwnProperty","test","RegExp","prop","$group","required","clear","split","v","$form","opts","removeErrorClasses","Plugin","alpha","alpha_numeric","integer","number","card","cvv","email","url","domain","datetime","date","time","dateISO","month_day_year","day_month_year","color","website","text","register","_isInitializing","$tabs","children","idx","$content","linkId","$initActive","_initialAnchor","prev","_openSingleTab","_checkDeepLink","anchor","window","location","hash","$anchor","$link","isOwnAnchor","hasClass","_closeAllTabs","deepLinkSmudge","offset","animate","scrollTop","top","deepLinkSmudgeDelay","deepLink","$tabContent","preventDefault","toggle","handleKey","next","$a","focus","multiExpand","previous","handled","stopPropagation","$target","console","info","up","down","updateHistory","history","pushState","replaceState","_openTab","$targetItem","$othersItems","allowAllClosed","_closeTab","$activeContents","targetContentId","slideDown","slideSpeed","slideUp","$activeTabs","stop","Feather","multiOpen","$menuLinks","$sub","subId","isActive","parentLink","clone","prependTo","wrap","submenuToggle","after","submenuToggleText","initPanes","$submenu","$elements","$prevElement","$nextElement","eq","Math","max","min","parents","open","close","closeAll","hideAll","stopImmediatePropagation","$targetBranch","parentsUntil","$othersActiveSubmenus","$submenus","$allmenus","detach","remove","Burn","FOUNDATION_VERSION","version","_plugins","_uuids","name","functionName","attrName","hyphenate","registerPlugin","pluginName","constructor","toLowerCase","uuid","unregisterPlugin","splice","removeAttr","removeData","reInit","plugins","isJQ","fns","plgs","forEach","p","foundation","Object","keys","err","reflow","addBack","warn","thing","trim","parseValue","er","getFnName","method","$noJS","args","Array","prototype","slice","call","arguments","plugClass","apply","ReferenceError","TypeError","fn","util","throttle","func","delay","timer","context","setTimeout","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","navigator","userAgent","lastTime","callback","nextTime","clearTimeout","performance","start","Function","bind","oThis","aArgs","fToBind","fNOP","fBound","concat","funcNameRegex","results","exec","toString","str","isNaN","parseFloat","replace","_setup","getPluginName","_destroy","obj","namespace","round","pow","random","transitions","document","createElement","t","style","triggerHandler","handler","didLoad","readyState","eventType","cb","one","ignoreMousedisappear","ignoreLeaveWindow","ignoreReappear","leaveEventHandler","eLeave","rest","relatedTarget","leaveEventDebouncer","hasFocus","reenterEventHandler","eReenter","currentTarget","has","autoApplyClass","$submenuAnchors","$menuItems","$currentMenu","_prepareMenu","_registerEvents","_keyboardEvents","$menu","$back","backButtonPosition","append","backButton","prepend","_back","autoHeight","$wrapper","wrapper","animateHeight","_getMaxDims","_show","closeOnClick","$body","contains","_hideAll","_bindHandler","_scrollTop","_resize","$scrollTopElement","scrollTopElement","scrollPos","parseInt","scrollTopOffset","animationDuration","animationEasing","_hide","height","parentSubMenu","autoFocus","$expandedSubmenus","index","_setHideSubMenuClasses","isLastChild","_setShowSubMenuClasses","blur","maxHeight","result","numOfElems","GetDimensions","getBoundingClientRect","width","unwrap","$id","$anchors","_setCurrentAnchor","parentClass","$parent","$currentAnchor","position","match","horizontalPosition","alignment","_setPosition","hover","bodyData","whatinput","timeout","hoverDelay","hoverPane","visibleFocusableElements","findFocusable","body","$focusable","_addBodyHandler","trapFocus","releaseFocus","hide","Positionable","vOffset","hOffset","allowOverlap","allowBottomOverlap","subs","verticalClass","rightClass","Rtl","changed","hasTouch","ontouchstart","parClass","handleClickFn","hasSub","hasClicked","clickOpen","forceFollow","closeOnClickInside","disableHover","autoclose","closingTime","isTab","nextSibling","prevSibling","openSub","closeSub","functions","_isVertical","_isRtl","$sibs","ImNotTouchingYou","oldClass","$parentLi","$toClose","somethingToClose","eqId","$watched","hasNested","isNested","isOn","onResizeMeBound","_onResizeMe","onPostEqualizedBound","_onPostEqualized","imgs","tooSmall","equalizeOn","_checkMQ","_reflow","_pauseEvents","equalizeOnStack","_isStacked","equalizeByRow","getHeightsByRow","applyHeightByRow","getHeights","applyHeight","heights","len","offsetHeight","lastElTopOffset","groups","group","elOffsetTop","j","ln","get","groupsILength","lenJ","rules","currentPath","_addBreakpoints","_generateRules","rule","matchMedia","query","matches","path","queries","SPECIAL_QUERIES","value","rulesList","join","nodeName","response","html","calcPoints","$targets","$links","$active","pageYOffset","documentElement","points","winHeight","innerHeight","clientHeight","docHeight","scrollHeight","$tar","pt","threshold","targetPoint","duration","easing","deepLinking","scrollToLoc","_updateActive","onLoadListener","arrival","getAttribute","_deepLinkScroll","loc","_inTransition","newScrollPos","isScrollingUp","activeIdx","visibleLinks","$oldActive","activeHash","isNewActive","isNewHash","activeClass","pathname","search","contentClasses","base","reveal","$lastTrigger","$triggers","nested","contentId","transition","contentOverlay","overlay","overlayPosition","setAttribute","$overlay","insertAfter","revealOnRegExp","revealClass","revealOnClass","isRevealed","revealOn","_setMQChecker","transitionTime","_removeContentClasses","_handleKeyboard","atLeast","hasReveal","_addContentClasses","event","allowUp","allowDown","lastY","originalEvent","pageY","forceTo","scrollTo","contentScroll","_stopScrolling","_recordScrollable","_stopScrollPropagation","canvasFocus","_reset","containerClass","$slides","slideClass","$images","initActive","useMUI","_prepareForOrbit","bullets","_loadBullets","autoPlay","geoSync","accessible","$bullets","boxOfBullets","timerDelay","infinite","changeSlide","_setWrapperHeight","temp","counter","swipe","pauseOnHover","pause","navButtons","$controls","nextClass","prevClass","ltr","$slide","restart","show","_updateBullets","isLTR","chosenSlide","$curSlide","$firstSlide","$lastSlide","last","dirIn","dirOut","$newSlide","infiniteWrap","animateIn","animateOut","isPaused","$oldBullet","span","$newBullet","animInFromRight","animOutToRight","animInFromLeft","animOutToLeft","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","nextItem","item","array","currentIdx","triedPositions","_getDefaultPosition","_getDefaultAlignment","originalPosition","originalAlignment","_alignmentsExhausted","_realign","_addTriedPosition","isExhausted","$eleDims","$anchorDims","GetExplicitOffsets","_getVOffset","_getHOffset","overlaps","minOverlap","minCoordinates","_positionsExhausted","overlap","OverlapArea","_reposition","MenuPlugins","tabs","cssClass","accordion","currentMq","currentPlugin","rulesTree","ruleSize","rulePlugin","_getAllOptions","isEmptyObject","_checkMediaQueries","allOptions","key","dummyPlugin","tmpPlugin","keyKey","objObj","destroy","_changedZfMediaQueryHandler","matchedMq","storezfData","_handleMarkup","toSet","fromString","$panels","tabsTitle","linkClass","tabsPanel","panelClass","$liHeads","$liHeadsA","display","visibility","appendTo","$tabsContent","$placeholder","tempValue","dropdown","drilldown","targetID","$targetMenu","$toggler","animationIn","animationOut","_update","_updateMqHandler","toggleMenu","hideFor","cached","mq","current","fullScreen","_makeOverlay","additionalOverlayClasses","outerWidth","outerHeight","left","margin","_updatePosition","_handleState","$activeAnchor","activeElement","multipleOpened","_disableScroll","afterAnimation","_addGlobalClasses","focusableElements","showDelay","_addGlobalListeners","updateScrollbarClass","toggleClass","closeOnEsc","finishUp","hideDelay","_removeGlobalClasses","_enableScroll","resetOnClose","urlWithoutHash","title","inputs","handles","$handle","$input","$fill","vertical","isDbl","disabled","disabledClass","binding","_setInitAttr","doubleSided","$handle2","$input2","setHandles","_setHandlePos","pctOfBar","percent","positionValueFunction","_logTransform","_powTransform","toFixed","baseLog","nonLinearBase","$hndl","noInvert","h2Val","step","h1Val","vert","hOrW","lOrT","handleDim","elemDim","_pctOfBar","pxToMove","movement","decimal","_setValues","isLeftHndl","dim","handlePct","handlePos","initialStart","moveTime","changedDelay","initVal","initialEnd","hasVal","param","direction","eventOffset","pageX","halfOfHandle","barDim","windowScroll","scrollLeft","elemOffset","clientY","eventFromBar","barXY","offsetPct","_value","_adjustValue","firstHndlPos","absPosition","secndHndlPos","div","prev_val","next_val","_eventsForHandle","curHandle","handleChangeEvent","_handleEvent","keyCode","clickSelect","draggable","addTouch","_$handle","oldValue","newValue","decrease","increase","decrease_fast","increase_fast","invertVertical","frac","num","dir","clickPos","abs","log","_linkClickListener","_handleLinkClick","$loc","$container","wasWrapped","container","stickyClass","scrollCount","checkEvery","isStuck","containerHeight","elemHeight","_parsePoints","_setSizes","scroll","_calc","_removeSticky","topPoint","reverse","topAnchor","btm","btmAnchor","pts","breaks","place","scrollListener","canStick","_eventsHandler","_pauseListeners","checkSizes","bottomPoint","_setSticky","stickTo","mrgn","notStuckTo","isTop","stickToTop","anchorPt","anchorHeight","topOrBottom","stickyOn","newElemWidth","comp","getComputedStyle","pdngl","pdngr","newContainerHeight","_setBreakPoints","mTop","emCalc","marginTop","mBtm","marginBottom","bottom","em","fontSize","$tabTitles","linkActiveClass","matchHeight","_setHeight","selectTab","_collapse","_addKeyHandler","_addClickHandler","_setHeightMqHandler","_handleTabChange","which","wrapOnKeys","historyHandled","activeCollapse","$oldTab","$tabLink","$targetContent","_collapseTab","panelActiveClass","$target_anchor","$activeTab","idStr","panel","$trigger","controls","containsId","_updateARIA","isClick","tipText","template","_buildTemplate","allowHtml","triggerClass","tooltipWidth","tooltipHeight","templateClasses","tooltipClass","$template","showOn","fadeIn","fadeInDuration","fadeOut","fadeOutDuration","isFocus","disableForTouch","touchCloseText","GetOffsets","lrOnly","tbOnly","ignoreBottom","eleDims","topOver","bottomOver","leftOver","rightOver","parDims","windowDims","sqrt","Error","rect","parRect","parentNode","winRect","winY","winX","pageXOffset","parentDims","isOverflow","topVal","leftVal","images","self","unloaded","complete","naturalWidth","singleImageLoaded","image","Image","events","me","src","keyCodes","commands","parseKey","String","fromCharCode","toUpperCase","shiftKey","ctrlKey","altKey","getKeyCodes","component","commandList","cmds","command","returnValue","unhandled","componentName","$firstFocusable","$lastFocusable","kcs","k","kc","defaultQueries","landscape","portrait","retina","styleMedia","media","script","getElementsByTagName","head","appendChild","insertBefore","currentStyle","matchMedium","styleSheet","cssText","textContent","$meta","extractedStyles","namedQueries","parseStyleToObject","_getCurrentSize","_watcher","size","matched","newSize","currentSize","styleObject","reduce","ret","parts","decodeURIComponent","isArray","initClasses","activeClasses","animation","anim","prog","move","ts","isIn","initClass","reset","offsetWidth","finish","transitionDuration","menu","items","subMenuClass","subItemClass","hasSubClass","applyAria","$item","nameSpace","remain","startPosX","startPosY","startTime","elapsedTime","startEvent","isMoving","didMoved","onTouchEnd","removeEventListener","onTouchMove","tapEvent","Event","spotSwipe","x","touches","y","dx","dy","moveThreshold","timeThreshold","onTouchStart","addEventListener","teardown","SpotSwipe","enabled","special","setup","tap","noop","setupSpotSwipe","setupTouchHandler","handleTouch","changedTouches","eventTypes","touchstart","touchmove","touchend","simulatedEvent","MouseEvent","screenX","screenY","clientX","createEvent","initMouseEvent","dispatchEvent","MutationObserver","prefixes","triggers","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","toggleFocusListener","addOpenListener","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","closeMeListener","pluginId","addClosemeListener","yetiBoxes","plugNames","listeners","debounceGlobalListener","debounce","listener","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","attributeName","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","triggersInitialized","IHearYou"],"mappings":"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","file":"foundation.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"jquery\"], factory);\n\telse {\n\t\tvar a = typeof exports === 'object' ? factory(require(\"jquery\")) : factory(root[\"jQuery\"]);\n\t\tfor(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];\n\t}\n})(window, function(__WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","import $ from 'jquery';\n\nimport { Foundation } from '../foundation.core';\nimport * as CoreUtils from '../foundation.core.utils';\nimport { Box } from '../foundation.util.box'\nimport { onImagesLoaded } from '../foundation.util.imageLoader';\nimport { Keyboard } from '../foundation.util.keyboard';\nimport { MediaQuery } from '../foundation.util.mediaQuery';\nimport { Motion, Move } from '../foundation.util.motion';\nimport { Nest } from '../foundation.util.nest';\nimport { Timer } from '../foundation.util.timer';\nimport { Touch } from '../foundation.util.touch';\nimport { Triggers } from '../foundation.util.triggers';\nimport { Abide } from '../foundation.abide';\nimport { Accordion } from '../foundation.accordion';\nimport { AccordionMenu } from '../foundation.accordionMenu';\nimport { Drilldown } from '../foundation.drilldown';\nimport { Dropdown } from '../foundation.dropdown';\nimport { DropdownMenu } from '../foundation.dropdownMenu';\nimport { Equalizer } from '../foundation.equalizer';\nimport { Interchange } from '../foundation.interchange';\nimport { Magellan } from '../foundation.magellan';\nimport { OffCanvas } from '../foundation.offcanvas';\nimport { Orbit } from '../foundation.orbit';\nimport { ResponsiveMenu } from '../foundation.responsiveMenu';\nimport { ResponsiveToggle } from '../foundation.responsiveToggle';\nimport { Reveal } from '../foundation.reveal';\nimport { Slider } from '../foundation.slider';\nimport { SmoothScroll } from '../foundation.smoothScroll';\nimport { Sticky } from '../foundation.sticky';\nimport { Tabs } from '../foundation.tabs';\nimport { Toggler } from '../foundation.toggler';\nimport { Tooltip } from '../foundation.tooltip';\nimport { ResponsiveAccordionTabs } from '../foundation.responsiveAccordionTabs';\n\nFoundation.addToJquery($);\n\n// Add Foundation Utils to Foundation global namespace for backwards\n// compatibility.\nFoundation.rtl = CoreUtils.rtl;\nFoundation.GetYoDigits = CoreUtils.GetYoDigits;\nFoundation.transitionend = CoreUtils.transitionend;\nFoundation.RegExpEscape = CoreUtils.RegExpEscape;\nFoundation.onLoad = CoreUtils.onLoad;\n\nFoundation.Box = Box;\nFoundation.onImagesLoaded = onImagesLoaded;\nFoundation.Keyboard = Keyboard;\nFoundation.MediaQuery = MediaQuery;\nFoundation.Motion = Motion;\nFoundation.Move = Move;\nFoundation.Nest = Nest;\nFoundation.Timer = Timer;\n\n// Touch and Triggers previously were almost purely sede effect driven,\n// so no need to add it to Foundation, just init them.\nTouch.init($);\nTriggers.init($, Foundation);\nMediaQuery._init();\n\nFoundation.plugin(Abide, 'Abide');\nFoundation.plugin(Accordion, 'Accordion');\nFoundation.plugin(AccordionMenu, 'AccordionMenu');\nFoundation.plugin(Drilldown, 'Drilldown');\nFoundation.plugin(Dropdown, 'Dropdown');\nFoundation.plugin(DropdownMenu, 'DropdownMenu');\nFoundation.plugin(Equalizer, 'Equalizer');\nFoundation.plugin(Interchange, 'Interchange');\nFoundation.plugin(Magellan, 'Magellan');\nFoundation.plugin(OffCanvas, 'OffCanvas');\nFoundation.plugin(Orbit, 'Orbit');\nFoundation.plugin(ResponsiveMenu, 'ResponsiveMenu');\nFoundation.plugin(ResponsiveToggle, 'ResponsiveToggle');\nFoundation.plugin(Reveal, 'Reveal');\nFoundation.plugin(Slider, 'Slider');\nFoundation.plugin(SmoothScroll, 'SmoothScroll');\nFoundation.plugin(Sticky, 'Sticky');\nFoundation.plugin(Tabs, 'Tabs');\nFoundation.plugin(Toggler, 'Toggler');\nFoundation.plugin(Tooltip, 'Tooltip');\nFoundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');\n\nexport {\n  Foundation,\n  CoreUtils,\n  Box,\n  onImagesLoaded,\n  Keyboard,\n  MediaQuery,\n  Motion,\n  Nest,\n  Timer,\n  Touch,\n  Triggers,\n  Abide,\n  Accordion,\n  AccordionMenu,\n  Drilldown,\n  Dropdown,\n  DropdownMenu,\n  Equalizer,\n  Interchange,\n  Magellan,\n  OffCanvas,\n  Orbit,\n  ResponsiveMenu,\n  ResponsiveToggle,\n  Reveal,\n  Slider,\n  SmoothScroll,\n  Sticky,\n  Tabs,\n  Toggler,\n  Tooltip,\n  ResponsiveAccordionTabs\n}\n\nexport default Foundation;\n\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nclass Abide extends Plugin {\n  /**\n   * Creates a new instance of Abide.\n   * @class\n   * @name Abide\n   * @fires Abide#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options = {}) {\n    this.$element = element;\n    this.options  = $.extend(true, {}, Abide.defaults, this.$element.data(), options);\n\n    this.className = 'Abide'; // ie9 back compat\n    this._init();\n  }\n\n  /**\n   * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n   * @private\n   */\n  _init() {\n    this.$inputs = $.merge(                               // Consider as input to validate:\n      this.$element.find('input').not('[type=submit]'),   // * all input fields expect submit\n      this.$element.find('textarea, select')              // * all textareas and select fields\n    );\n    const $globalErrors = this.$element.find('[data-abide-error]');\n\n    // Add a11y attributes to all fields\n    if (this.options.a11yAttributes) {\n      this.$inputs.each((i, input) => this.addA11yAttributes($(input)));\n      $globalErrors.each((i, error) => this.addGlobalErrorA11yAttributes($(error)));\n    }\n\n    this._events();\n  }\n\n  /**\n   * Initializes events for Abide.\n   * @private\n   */\n  _events() {\n    this.$element.off('.abide')\n      .on('reset.zf.abide', () => {\n        this.resetForm();\n      })\n      .on('submit.zf.abide', () => {\n        return this.validateForm();\n      });\n\n    if (this.options.validateOn === 'fieldChange') {\n      this.$inputs\n        .off('change.zf.abide')\n        .on('change.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.liveValidate) {\n      this.$inputs\n        .off('input.zf.abide')\n        .on('input.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.validateOnBlur) {\n      this.$inputs\n        .off('blur.zf.abide')\n        .on('blur.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n  }\n\n  /**\n   * Calls necessary functions to update Abide upon DOM change\n   * @private\n   */\n  _reflow() {\n    this._init();\n  }\n\n  /**\n   * Checks whether or not a form element has the required attribute and if it's checked or not\n   * @param {Object} element - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  requiredCheck($el) {\n    if (!$el.attr('required')) return true;\n\n    var isGood = true;\n\n    switch ($el[0].type) {\n      case 'checkbox':\n        isGood = $el[0].checked;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        var opt = $el.find('option:selected');\n        if (!opt.length || !opt.val()) isGood = false;\n        break;\n\n      default:\n        if(!$el.val() || !$el.val().length) isGood = false;\n    }\n\n    return isGood;\n  }\n\n  /**\n   * Get:\n   * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n   *   1. The element's direct sibling('s).\n   *   2. The element's parent's children.\n   * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n   *\n   * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n   *\n   * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n   * @returns {Object} jQuery object with the selector.\n   */\n  findFormError($el) {\n    var id = $el[0].id;\n    var $error = $el.siblings(this.options.formErrorSelector);\n\n    if (!$error.length) {\n      $error = $el.parent().find(this.options.formErrorSelector);\n    }\n\n    if (id) {\n      $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"]`));\n    }\n\n    return $error;\n  }\n\n  /**\n   * Get the first element in this order:\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findLabel($el) {\n    var id = $el[0].id;\n    var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n    if (!$label.length) {\n      return $el.closest('label');\n    }\n\n    return $label;\n  }\n\n  /**\n   * Get the set of labels associated with a set of radio els in this order\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findRadioLabels($els) {\n    var labels = $els.map((i, el) => {\n      var id = el.id;\n      var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n      if (!$label.length) {\n        $label = $(el).closest('label');\n      }\n      return $label[0];\n    });\n\n    return $(labels);\n  }\n\n  /**\n   * Adds the CSS error class as specified by the Abide settings to the label, input, and the form\n   * @param {Object} $el - jQuery object to add the class to\n   */\n  addErrorClasses($el) {\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.addClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.addClass(this.options.formErrorClass);\n    }\n\n    $el.addClass(this.options.inputErrorClass).attr({\n      'data-invalid': '',\n      'aria-invalid': true\n    });\n  }\n\n  /**\n   * Adds [for] and [role=alert] attributes to all form error targetting $el,\n   * and [aria-describedby] attribute to $el toward the first form error.\n   * @param {Object} $el - jQuery object\n   */\n  addA11yAttributes($el) {\n    let $errors = this.findFormError($el);\n    let $labels = $errors.filter('label');\n    let $error = $errors.first();\n    if (!$errors.length) return;\n\n    // Set [aria-describedby] on the input toward the first form error if it is not set\n    if (typeof $el.attr('aria-describedby') === 'undefined') {\n      // Get the first error ID or create one\n      let errorId = $error.attr('id');\n      if (typeof errorId === 'undefined') {\n        errorId = GetYoDigits(6, 'abide-error');\n        $error.attr('id', errorId);\n      };\n\n      $el.attr('aria-describedby', errorId);\n    }\n\n    if ($labels.filter('[for]').length < $labels.length) {\n      // Get the input ID or create one\n      let elemId = $el.attr('id');\n      if (typeof elemId === 'undefined') {\n        elemId = GetYoDigits(6, 'abide-input');\n        $el.attr('id', elemId);\n      };\n\n      // For each label targeting $el, set [for] if it is not set.\n      $labels.each((i, label) => {\n        const $label = $(label);\n        if (typeof $label.attr('for') === 'undefined')\n          $label.attr('for', elemId);\n      });\n    }\n\n    // For each error targeting $el, set [role=alert] if it is not set.\n    $errors.each((i, label) => {\n      const $label = $(label);\n      if (typeof $label.attr('role') === 'undefined')\n        $label.attr('role', 'alert');\n    }).end();\n  }\n\n  /**\n   * Adds [aria-live] attribute to the given global form error $el.\n   * @param {Object} $el - jQuery object to add the attribute to\n   */\n  addGlobalErrorA11yAttributes($el) {\n    if (typeof $el.attr('aria-live') === 'undefined')\n      $el.attr('aria-live', this.options.a11yErrorLevel);\n  }\n\n  /**\n   * Remove CSS error classes etc from an entire radio button group\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   *\n   */\n  removeRadioErrorClasses(groupName) {\n    var $els = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var $labels = this.findRadioLabels($els);\n    var $formErrors = this.findFormError($els);\n\n    if ($labels.length) {\n      $labels.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formErrors.length) {\n      $formErrors.removeClass(this.options.formErrorClass);\n    }\n\n    $els.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n\n  }\n\n  /**\n   * Removes CSS error class as specified by the Abide settings from the label, input, and the form\n   * @param {Object} $el - jQuery object to remove the class from\n   */\n  removeErrorClasses($el) {\n    // radios need to clear all of the els\n    if($el[0].type == 'radio') {\n      return this.removeRadioErrorClasses($el.attr('name'));\n    }\n\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.removeClass(this.options.formErrorClass);\n    }\n\n    $el.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n  }\n\n  /**\n   * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.\n   * Ignores inputs with data-abide-ignore, type=\"hidden\" or disabled attributes set\n   * @fires Abide#invalid\n   * @fires Abide#valid\n   * @param {Object} element - jQuery object to validate, should be an HTML input\n   * @returns {Boolean} goodToGo - If the input is valid or not.\n   */\n  validateInput($el) {\n    var clearRequire = this.requiredCheck($el),\n        validated = false,\n        customValidator = true,\n        validator = $el.attr('data-validator'),\n        equalTo = true;\n\n    // don't validate ignored inputs or hidden inputs or disabled inputs\n    if ($el.is('[data-abide-ignore]') || $el.is('[type=\"hidden\"]') || $el.is('[disabled]')) {\n      return true;\n    }\n\n    switch ($el[0].type) {\n      case 'radio':\n        validated = this.validateRadio($el.attr('name'));\n        break;\n\n      case 'checkbox':\n        validated = clearRequire;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        validated = clearRequire;\n        break;\n\n      default:\n        validated = this.validateText($el);\n    }\n\n    if (validator) {\n      customValidator = this.matchValidation($el, validator, $el.attr('required'));\n    }\n\n    if ($el.attr('data-equalto')) {\n      equalTo = this.options.validators.equalTo($el);\n    }\n\n\n    var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;\n    var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';\n\n    if (goodToGo) {\n      // Re-validate inputs that depend on this one with equalto\n      const dependentElements = this.$element.find(`[data-equalto=\"${$el.attr('id')}\"]`);\n      if (dependentElements.length) {\n        let _this = this;\n        dependentElements.each(function() {\n          if ($(this).val()) {\n            _this.validateInput($(this));\n          }\n        });\n      }\n    }\n\n    this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);\n\n    /**\n     * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`\n     * Trigger includes the DOM element of the input.\n     * @event Abide#valid\n     * @event Abide#invalid\n     */\n    $el.trigger(message, [$el]);\n\n    return goodToGo;\n  }\n\n  /**\n   * Goes through a form and if there are any invalid inputs, it will display the form error element\n   * @returns {Boolean} noError - true if no errors were detected...\n   * @fires Abide#formvalid\n   * @fires Abide#forminvalid\n   */\n  validateForm() {\n    var acc = [];\n    var _this = this;\n\n    this.$inputs.each(function() {\n      acc.push(_this.validateInput($(this)));\n    });\n\n    var noError = acc.indexOf(false) === -1;\n\n    this.$element.find('[data-abide-error]').each((i, elem) => {\n      const $elem = $(elem);\n      // Ensure a11y attributes are set\n      if (this.options.a11yAttributes) this.addGlobalErrorA11yAttributes($elem);\n      // Show or hide the error\n      $elem.css('display', (noError ? 'none' : 'block'));\n    });\n\n    /**\n     * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.\n     * Trigger includes the element of the form.\n     * @event Abide#formvalid\n     * @event Abide#forminvalid\n     */\n    this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);\n\n    return noError;\n  }\n\n  /**\n   * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.\n   * @param {Object} $el - jQuery object to validate, should be a text input HTML element\n   * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns\n   * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified\n   */\n  validateText($el, pattern) {\n    // A pattern can be passed to this function, or it will be infered from the input's \"pattern\" attribute, or it's \"type\" attribute\n    pattern = (pattern || $el.attr('pattern') || $el.attr('type'));\n    var inputText = $el.val();\n    var valid = false;\n\n    if (inputText.length) {\n      // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp\n      if (this.options.patterns.hasOwnProperty(pattern)) {\n        valid = this.options.patterns[pattern].test(inputText);\n      }\n      // If the pattern name isn't also the type attribute of the field, then test it as a regexp\n      else if (pattern !== $el.attr('type')) {\n        valid = new RegExp(pattern).test(inputText);\n      }\n      else {\n        valid = true;\n      }\n    }\n    // An empty field is valid if it's not required\n    else if (!$el.prop('required')) {\n      valid = true;\n    }\n\n    return valid;\n   }\n\n  /**\n   * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)\n   */\n  validateRadio(groupName) {\n    // If at least one radio in the group has the `required` attribute, the group is considered required\n    // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice\n    var $group = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var valid = false, required = false;\n\n    // For the group to be required, at least one radio needs to be required\n    $group.each((i, e) => {\n      if ($(e).attr('required')) {\n        required = true;\n      }\n    });\n    if(!required) valid=true;\n\n    if (!valid) {\n      // For the group to be valid, at least one radio needs to be checked\n      $group.each((i, e) => {\n        if ($(e).prop('checked')) {\n          valid = true;\n        }\n      });\n    };\n\n    return valid;\n  }\n\n  /**\n   * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator=\"foo bar baz\"` in a space separated listed.\n   * @param {Object} $el - jQuery input element.\n   * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.\n   * @param {Boolean} required - self explanatory?\n   * @returns {Boolean} - true if validations passed.\n   */\n  matchValidation($el, validators, required) {\n    required = required ? true : false;\n\n    var clear = validators.split(' ').map((v) => {\n      return this.options.validators[v]($el, required, $el.parent());\n    });\n    return clear.indexOf(false) === -1;\n  }\n\n  /**\n   * Resets form inputs and styles\n   * @fires Abide#formreset\n   */\n  resetForm() {\n    var $form = this.$element,\n        opts = this.options;\n\n    $(`.${opts.labelErrorClass}`, $form).not('small').removeClass(opts.labelErrorClass);\n    $(`.${opts.inputErrorClass}`, $form).not('small').removeClass(opts.inputErrorClass);\n    $(`${opts.formErrorSelector}.${opts.formErrorClass}`).removeClass(opts.formErrorClass);\n    $form.find('[data-abide-error]').css('display', 'none');\n    $(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:radio', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    /**\n     * Fires when the form has been reset.\n     * @event Abide#formreset\n     */\n    $form.trigger('formreset.zf.abide', [$form]);\n  }\n\n  /**\n   * Destroys an instance of Abide.\n   * Removes error styles and classes from elements, without resetting their values.\n   */\n  _destroy() {\n    var _this = this;\n    this.$element\n      .off('.abide')\n      .find('[data-abide-error]')\n        .css('display', 'none');\n\n    this.$inputs\n      .off('.abide')\n      .each(function() {\n        _this.removeErrorClasses($(this));\n      });\n  }\n}\n\n/**\n * Default settings for plugin\n */\nAbide.defaults = {\n  /**\n   * The default event to validate inputs. Checkboxes and radios validate immediately.\n   * Remove or change this value for manual validation.\n   * @option\n   * @type {?string}\n   * @default 'fieldChange'\n   */\n  validateOn: 'fieldChange',\n\n  /**\n   * Class to be applied to input labels on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-label'\n   */\n  labelErrorClass: 'is-invalid-label',\n\n  /**\n   * Class to be applied to inputs on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-input'\n   */\n  inputErrorClass: 'is-invalid-input',\n\n  /**\n   * Class selector to use to target Form Errors for show/hide.\n   * @option\n   * @type {string}\n   * @default '.form-error'\n   */\n  formErrorSelector: '.form-error',\n\n  /**\n   * Class added to Form Errors on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-visible'\n   */\n  formErrorClass: 'is-visible',\n\n  /**\n   * If true, automatically insert when possible:\n   * - `[aria-describedby]` on fields\n   * - `[role=alert]` on form errors and `[for]` on form error labels\n   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  a11yAttributes: true,\n\n  /**\n   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.\n   * Options are: 'assertive', 'polite' and 'off'/null\n   * @option\n   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions\n   * @type {string}\n   * @default 'assertive'\n   */\n  a11yErrorLevel: 'assertive',\n\n  /**\n   * Set to true to validate text inputs on any value change.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  liveValidate: false,\n\n  /**\n   * Set to true to validate inputs on blur.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  validateOnBlur: false,\n\n  patterns: {\n    alpha : /^[a-zA-Z]+$/,\n    alpha_numeric : /^[a-zA-Z0-9]+$/,\n    integer : /^[-+]?\\d+$/,\n    number : /^[-+]?\\d*(?:[\\.\\,]\\d+)?$/,\n\n    // amex, visa, diners\n    card : /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\\d{3})\\d{11})$/,\n    cvv : /^([0-9]){3,4}$/,\n\n    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address\n    email : /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,\n\n    // From CommonRegexJS (@talyssonoc)\n    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76\n    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.\n    url: /^((?:(https?|ftps?|file|ssh|sftp):\\/\\/|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}\\/)(?:[^\\s()<>]+|\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\))+(?:\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:\\'\".,<>?\\xab\\xbb\\u201c\\u201d\\u2018\\u2019]))$/,\n\n    // abc.de\n    domain : /^([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,8}$/,\n\n    datetime : /^([0-2][0-9]{3})\\-([0-1][0-9])\\-([0-3][0-9])T([0-5][0-9])\\:([0-5][0-9])\\:([0-5][0-9])(Z|([\\-\\+]([0-1][0-9])\\:00))$/,\n    // YYYY-MM-DD\n    date : /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,\n    // HH:MM:SS\n    time : /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,\n    dateISO : /^\\d{4}[\\/\\-]\\d{1,2}[\\/\\-]\\d{1,2}$/,\n    // MM/DD/YYYY\n    month_day_year : /^(0[1-9]|1[012])[- \\/.](0[1-9]|[12][0-9]|3[01])[- \\/.]\\d{4}$/,\n    // DD/MM/YYYY\n    day_month_year : /^(0[1-9]|[12][0-9]|3[01])[- \\/.](0[1-9]|1[012])[- \\/.]\\d{4}$/,\n\n    // #FFF or #FFFFFF\n    color : /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,\n\n    // Domain || URL\n    website: {\n      test: (text) => {\n        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);\n      }\n    }\n  },\n\n  /**\n   * Optional validation functions to be used. `equalTo` being the only default included function.\n   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:\n   * el : The jQuery element to validate.\n   * required : Boolean value of the required attribute be present or not.\n   * parent : The direct parent of the input.\n   * @option\n   */\n  validators: {\n    equalTo: function (el, required, parent) {\n      return $(`#${el.attr('data-equalto')}`).val() === el.val();\n    }\n  }\n}\n\nexport {Abide};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Accordion module.\n * @module foundation.accordion\n * @requires foundation.util.keyboard\n */\n\nclass Accordion extends Plugin {\n  /**\n   * Creates a new instance of an accordion.\n   * @class\n   * @name Accordion\n   * @fires Accordion#init\n   * @param {jQuery} element - jQuery object to make into an accordion.\n   * @param {Object} options - a plain object with settings to override the default options.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);\n\n    this.className = 'Accordion'; // ie9 back compat\n    this._init();\n\n    Keyboard.register('Accordion', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_DOWN': 'next',\n      'ARROW_UP': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the accordion by animating the preset active pane(s).\n   * @private\n   */\n  _init() {\n    this._isInitializing = true;\n\n    this.$element.attr('role', 'tablist');\n    this.$tabs = this.$element.children('[data-accordion-item]');\n\n    this.$tabs.each(function(idx, el) {\n      var $el = $(el),\n          $content = $el.children('[data-tab-content]'),\n          id = $content[0].id || GetYoDigits(6, 'accordion'),\n          linkId = (el.id) ? `${el.id}-label` : `${id}-label`;\n\n      $el.find('a:first').attr({\n        'aria-controls': id,\n        'role': 'tab',\n        'id': linkId,\n        'aria-expanded': false,\n        'aria-selected': false\n      });\n\n      $content.attr({'role': 'tabpanel', 'aria-labelledby': linkId, 'aria-hidden': true, 'id': id});\n    });\n\n    var $initActive = this.$element.find('.is-active').children('[data-tab-content]');\n    if ($initActive.length) {\n      // Save up the initial hash to return to it later when going back in history\n      this._initialAnchor = $initActive.prev('a').attr('href');\n      this._openSingleTab($initActive);\n    }\n\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find(`[href$=\"${anchor}\"]`);\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, open it (if not already active)\n      if ($anchor && $link && $link.length) {\n        if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {\n          this._openSingleTab($anchor);\n        };\n      }\n      // Otherwise, close everything\n      else {\n        this._closeAllTabs();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          onLoad($(window), () => {\n            var offset = this.$element.offset();\n            $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n          });\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Accordion#deeplink\n         */\n        this.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the accordion.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$tabs.each(function() {\n      var $elem = $(this);\n      var $tabContent = $elem.children('[data-tab-content]');\n      if ($tabContent.length) {\n        $elem.children('a').off('click.zf.accordion keydown.zf.accordion')\n               .on('click.zf.accordion', function(e) {\n          e.preventDefault();\n          _this.toggle($tabContent);\n        }).on('keydown.zf.accordion', function(e){\n          Keyboard.handleKey(e, 'Accordion', {\n            toggle: function() {\n              _this.toggle($tabContent);\n            },\n            next: function() {\n              var $a = $elem.next().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            previous: function() {\n              var $a = $elem.prev().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            handled: function() {\n              e.preventDefault();\n              e.stopPropagation();\n            }\n          });\n        });\n      }\n    });\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Toggles the selected content pane's open/close state.\n   * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).\n   * @function\n   */\n  toggle($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]')) {\n      console.info('Cannot toggle an accordion that is disabled.');\n      return;\n    }\n    if($target.parent().hasClass('is-active')) {\n      this.up($target);\n    } else {\n      this.down($target);\n    }\n    //either replace or update browser history\n    if (this.options.deepLink) {\n      var anchor = $target.prev('a').attr('href');\n\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n  }\n\n  /**\n   * Opens the accordion tab defined by `$target`.\n   * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   */\n  down($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]'))  {\n      console.info('Cannot call down on an accordion that is disabled.');\n      return;\n    }\n\n    if (this.options.multiExpand)\n      this._openTab($target);\n    else\n      this._openSingleTab($target);\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * It may be ignored if the Accordion options don't allow it.\n   *\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   */\n  up($target) {\n    if (this.$element.is('[disabled]')) {\n      console.info('Cannot call up on an accordion that is disabled.');\n      return;\n    }\n\n    // Don't close the item if it is already closed\n    const $targetItem = $target.parent();\n    if (!$targetItem.hasClass('is-active')) return;\n\n    // Don't close the item if there is no other active item (unless with `allowAllClosed`)\n    const $othersItems = $targetItem.siblings();\n    if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;\n\n    this._closeTab($target);\n  }\n\n  /**\n   * Make the tab defined by `$target` the only opened tab, closing all others tabs.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @function\n   * @private\n   */\n  _openSingleTab($target) {\n    // Close all the others active tabs.\n    const $activeContents = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeContents.length) {\n      this._closeTab($activeContents.not($target));\n    }\n\n    // Then open the target.\n    this._openTab($target);\n  }\n\n  /**\n   * Opens the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   * @private\n   */\n  _openTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', false);\n    $targetItem.addClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n      'aria-expanded': true,\n      'aria-selected': true\n    });\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done opening.\n       * @event Accordion#down\n       */\n      this.$element.trigger('down.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', true)\n    $targetItem.removeClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n     'aria-expanded': false,\n     'aria-selected': false\n    });\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done collapsing up.\n       * @event Accordion#up\n       */\n      this.$element.trigger('up.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes all active tabs\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeAllTabs() {\n    var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeTabs.length) {\n      this._closeTab($activeTabs);\n    }\n  }\n\n  /**\n   * Destroys an instance of an accordion.\n   * @fires Accordion#destroyed\n   * @function\n   */\n  _destroy() {\n    this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');\n    this.$element.find('a').off('.zf.accordion');\n    if(this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n  }\n}\n\nAccordion.defaults = {\n  /**\n   * Amount of time to animate the opening of an accordion pane.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Allow the accordion to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multiExpand: false,\n  /**\n   * Allow the accordion to close all panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowAllClosed: false,\n  /**\n   * Link the location hash to the open pane.\n   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open accordion\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false\n};\n\nexport {Accordion};\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n */\n\nclass AccordionMenu extends Plugin {\n  /**\n   * Creates a new instance of an accordion menu.\n   * @class\n   * @name AccordionMenu\n   * @fires AccordionMenu#init\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n    this.className = 'AccordionMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('AccordionMenu', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_RIGHT': 'open',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'close',\n      'ESCAPE': 'closeAll'\n    });\n  }\n\n\n\n  /**\n   * Initializes the accordion menu by hiding all nested menus.\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'accordion');\n\n    var _this = this;\n\n    this.$element.find('[data-submenu]').not('.is-active').slideUp(0);//.find('a').css('padding-left', '1rem');\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': this.options.multiOpen\n    });\n\n    this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');\n    this.$menuLinks.each(function(){\n      var linkId = this.id || GetYoDigits(6, 'acc-menu-link'),\n          $elem = $(this),\n          $sub = $elem.children('[data-submenu]'),\n          subId = $sub[0].id || GetYoDigits(6, 'acc-menu'),\n          isActive = $sub.hasClass('is-active');\n\n      if(_this.options.parentLink) {\n        let $anchor = $elem.children('a');\n        $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-accordion-submenu-item\"></li>');\n      }\n\n      if(_this.options.submenuToggle) {\n        $elem.addClass('has-submenu-toggle');\n        $elem.children('a').after('<button id=\"' + linkId + '\" class=\"submenu-toggle\" aria-controls=\"' + subId + '\" aria-expanded=\"' + isActive + '\" title=\"' + _this.options.submenuToggleText + '\"><span class=\"submenu-toggle-text\">' + _this.options.submenuToggleText + '</span></button>');\n      } else {\n        $elem.attr({\n          'aria-controls': subId,\n          'aria-expanded': isActive,\n          'id': linkId\n        });\n      }\n      $sub.attr({\n        'aria-labelledby': linkId,\n        'aria-hidden': !isActive,\n        'role': 'group',\n        'id': subId\n      });\n    });\n    this.$element.find('li').attr({\n      'role': 'treeitem'\n    });\n    var initPanes = this.$element.find('.is-active');\n    if(initPanes.length){\n      var _this = this;\n      initPanes.each(function(){\n        _this.down($(this));\n      });\n    }\n    this._events();\n  }\n\n  /**\n   * Adds event handlers for items within the menu.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.find('li').each(function() {\n      var $submenu = $(this).children('[data-submenu]');\n\n      if ($submenu.length) {\n        if(_this.options.submenuToggle) {\n          $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n            _this.toggle($submenu);\n          });\n        } else {\n            $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n              e.preventDefault();\n              _this.toggle($submenu);\n            });\n        }\n      }\n    }).on('keydown.zf.accordionmenu', function(e){\n      var $element = $(this),\n          $elements = $element.parent('ul').children('li'),\n          $prevElement,\n          $nextElement,\n          $target = $element.children('[data-submenu]');\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1)).find('a').first();\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1)).find('a').first();\n\n          if ($(this).children('[data-submenu]:visible').length) { // has open sub menu\n            $nextElement = $element.find('li:first-child').find('a').first();\n          }\n          if ($(this).is(':first-child')) { // is first element of sub menu\n            $prevElement = $element.parents('li').first().find('a').first();\n          } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) { // if previous element has open sub menu\n            $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();\n          }\n          if ($(this).is(':last-child')) { // is last element of sub menu\n            $nextElement = $element.parents('li').first().next('li').find('a').first();\n          }\n\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'AccordionMenu', {\n        open: function() {\n          if ($target.is(':hidden')) {\n            _this.down($target);\n            $target.find('li').first().find('a').first().focus();\n          }\n        },\n        close: function() {\n          if ($target.length && !$target.is(':hidden')) { // close active sub of this item\n            _this.up($target);\n          } else if ($element.parent('[data-submenu]').length) { // close currently open sub\n            _this.up($element.parent('[data-submenu]'));\n            $element.parents('li').first().find('a').first().focus();\n          }\n        },\n        up: function() {\n          $prevElement.focus();\n          return true;\n        },\n        down: function() {\n          $nextElement.focus();\n          return true;\n        },\n        toggle: function() {\n          if (_this.options.submenuToggle) {\n            return false;\n          }\n          if ($element.children('[data-submenu]').length) {\n            _this.toggle($element.children('[data-submenu]'));\n            return true;\n          }\n        },\n        closeAll: function() {\n          _this.hideAll();\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    });//.attr('tabindex', 0);\n  }\n\n  /**\n   * Closes all panes of the menu.\n   * @function\n   */\n  hideAll() {\n    this.up(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Opens all panes of the menu.\n   * @function\n   */\n  showAll() {\n    this.down(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Toggles the open/close state of a submenu.\n   * @function\n   * @param {jQuery} $target - the submenu to toggle\n   */\n  toggle($target){\n    if(!$target.is(':animated')) {\n      if (!$target.is(':hidden')) {\n        this.up($target);\n      }\n      else {\n        this.down($target);\n      }\n    }\n  }\n\n  /**\n   * Opens the sub-menu defined by `$target`.\n   * @param {jQuery} $target - Sub-menu to open.\n   * @fires AccordionMenu#down\n   */\n  down($target) {\n    // If having multiple submenus active is disabled, close all the submenus\n    // that are not parents or children of the targeted submenu.\n    if (!this.options.multiOpen) {\n      // The \"branch\" of the targetted submenu, from the component root to\n      // the active submenus nested in it.\n      const $targetBranch = $target.parentsUntil(this.$element)\n        .add($target)\n        .add($target.find('.is-active'));\n      // All the active submenus that are not in the branch.\n      const $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);\n\n      this.up($othersActiveSubmenus);\n    }\n\n    $target\n      .addClass('is-active')\n      .attr({ 'aria-hidden': false });\n\n    if(this.options.submenuToggle) {\n      $target.prev('.submenu-toggle').attr({'aria-expanded': true});\n    }\n    else {\n      $target.parent('.is-accordion-submenu-parent').attr({'aria-expanded': true});\n    }\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done opening.\n       * @event AccordionMenu#down\n       */\n      this.$element.trigger('down.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.\n   * @param {jQuery} $target - Sub-menu to close.\n   * @fires AccordionMenu#up\n   */\n  up($target) {\n    const $submenus = $target.find('[data-submenu]');\n    const $allmenus = $target.add($submenus);\n\n    $submenus.slideUp(0);\n    $allmenus\n      .removeClass('is-active')\n      .attr('aria-hidden', true);\n\n    if(this.options.submenuToggle) {\n      $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);\n    }\n    else {\n      $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\n    }\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done collapsing up.\n       * @event AccordionMenu#up\n       */\n      this.$element.trigger('up.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Destroys an instance of accordion menu.\n   * @fires AccordionMenu#destroyed\n   */\n  _destroy() {\n    this.$element.find('[data-submenu]').slideDown(0).css('display', '');\n    this.$element.find('a').off('click.zf.accordionMenu');\n    this.$element.find('[data-is-parent-link]').detach();\n\n    if(this.options.submenuToggle) {\n      this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');\n      this.$element.find('.submenu-toggle').remove();\n    }\n\n    Nest.Burn(this.$element, 'accordion');\n  }\n}\n\nAccordionMenu.defaults = {\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Amount of time to animate the opening of a submenu in ms.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Adds a separate submenu toggle button. This allows the parent item to have a link.\n   * @option\n   * @example true\n   */\n  submenuToggle: false,\n  /**\n   * The text used for the submenu toggle if enabled. This is used for screen readers only.\n   * @option\n   * @example true\n   */\n  submenuToggleText: 'Toggle menu',\n  /**\n   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\nexport {AccordionMenu};\n","\"use strict\";\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\n\nvar FOUNDATION_VERSION = '6.5.3';\n\n// Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\nvar Foundation = {\n  version: FOUNDATION_VERSION,\n\n  /**\n   * Stores initialized plugins.\n   */\n  _plugins: {},\n\n  /**\n   * Stores generated unique ids for plugin instances\n   */\n  _uuids: [],\n\n  /**\n   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n   * @param {Object} plugin - The constructor of the plugin.\n   */\n  plugin: function(plugin, name) {\n    // Object key to use when adding to global Foundation object\n    // Examples: Foundation.Reveal, Foundation.OffCanvas\n    var className = (name || functionName(plugin));\n    // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n    // Examples: data-reveal, data-off-canvas\n    var attrName  = hyphenate(className);\n\n    // Add to the Foundation object and the plugins list (for reflowing)\n    this._plugins[attrName] = this[className] = plugin;\n  },\n  /**\n   * @function\n   * Populates the _uuids array with pointers to each individual plugin instance.\n   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n   * Also fires the initialization event for each plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @param {String} name - the name of the plugin, passed as a camelCased string.\n   * @fires Plugin#init\n   */\n  registerPlugin: function(plugin, name){\n    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n    plugin.uuid = GetYoDigits(6, pluginName);\n\n    if(!plugin.$element.attr(`data-${pluginName}`)){ plugin.$element.attr(`data-${pluginName}`, plugin.uuid); }\n    if(!plugin.$element.data('zfPlugin')){ plugin.$element.data('zfPlugin', plugin); }\n          /**\n           * Fires when the plugin has initialized.\n           * @event Plugin#init\n           */\n    plugin.$element.trigger(`init.zf.${pluginName}`);\n\n    this._uuids.push(plugin.uuid);\n\n    return;\n  },\n  /**\n   * @function\n   * Removes the plugins uuid from the _uuids array.\n   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n   * Also fires the destroyed event for the plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @fires Plugin#destroyed\n   */\n  unregisterPlugin: function(plugin){\n    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n    plugin.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n          /**\n           * Fires when the plugin has been destroyed.\n           * @event Plugin#destroyed\n           */\n          .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in plugin){\n      plugin[prop] = null;//clean up script to prep for garbage collection.\n    }\n    return;\n  },\n\n  /**\n   * @function\n   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n   * @default If no argument is passed, reflow all currently active plugins.\n   */\n   reInit: function(plugins){\n     var isJQ = plugins instanceof $;\n     try{\n       if(isJQ){\n         plugins.each(function(){\n           $(this).data('zfPlugin')._init();\n         });\n       }else{\n         var type = typeof plugins,\n         _this = this,\n         fns = {\n           'object': function(plgs){\n             plgs.forEach(function(p){\n               p = hyphenate(p);\n               $('[data-'+ p +']').foundation('_init');\n             });\n           },\n           'string': function(){\n             plugins = hyphenate(plugins);\n             $('[data-'+ plugins +']').foundation('_init');\n           },\n           'undefined': function(){\n             this['object'](Object.keys(_this._plugins));\n           }\n         };\n         fns[type](plugins);\n       }\n     }catch(err){\n       console.error(err);\n     }finally{\n       return plugins;\n     }\n   },\n\n  /**\n   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n   */\n  reflow: function(elem, plugins) {\n\n    // If plugins is undefined, just grab everything\n    if (typeof plugins === 'undefined') {\n      plugins = Object.keys(this._plugins);\n    }\n    // If plugins is a string, convert it to an array with one item\n    else if (typeof plugins === 'string') {\n      plugins = [plugins];\n    }\n\n    var _this = this;\n\n    // Iterate through each plugin\n    $.each(plugins, function(i, name) {\n      // Get the current plugin\n      var plugin = _this._plugins[name];\n\n      // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n      var $elem = $(elem).find('[data-'+name+']').addBack('[data-'+name+']');\n\n      // For each plugin found, initialize it\n      $elem.each(function() {\n        var $el = $(this),\n            opts = {};\n        // Don't double-dip on plugins\n        if ($el.data('zfPlugin')) {\n          console.warn(\"Tried to initialize \"+name+\" on an element that already has a Foundation plugin.\");\n          return;\n        }\n\n        if($el.attr('data-options')){\n          var thing = $el.attr('data-options').split(';').forEach(function(e, i){\n            var opt = e.split(':').map(function(el){ return el.trim(); });\n            if(opt[0]) opts[opt[0]] = parseValue(opt[1]);\n          });\n        }\n        try{\n          $el.data('zfPlugin', new plugin($(this), opts));\n        }catch(er){\n          console.error(er);\n        }finally{\n          return;\n        }\n      });\n    });\n  },\n  getFnName: functionName,\n\n  addToJquery: function($) {\n    // TODO: consider not making this a jQuery function\n    // TODO: need way to reflow vs. re-initialize\n    /**\n     * The Foundation jQuery method.\n     * @param {String|Array} method - An action to perform on the current jQuery object.\n     */\n    var foundation = function(method) {\n      var type = typeof method,\n          $noJS = $('.no-js');\n\n      if($noJS.length){\n        $noJS.removeClass('no-js');\n      }\n\n      if(type === 'undefined'){//needs to initialize the Foundation object, or an individual plugin.\n        MediaQuery._init();\n        Foundation.reflow(this);\n      }else if(type === 'string'){//an individual method to invoke on a plugin or group of plugins\n        var args = Array.prototype.slice.call(arguments, 1);//collect all the arguments, if necessary\n        var plugClass = this.data('zfPlugin');//determine the class of plugin\n\n        if(typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined'){//make sure both the class and method exist\n          if(this.length === 1){//if there's only one, call it directly.\n              plugClass[method].apply(plugClass, args);\n          }else{\n            this.each(function(i, el){//otherwise loop through the jQuery collection and invoke the method on each\n              plugClass[method].apply($(el).data('zfPlugin'), args);\n            });\n          }\n        }else{//error for no class or no method\n          throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n        }\n      }else{//error for invalid argument type\n        throw new TypeError(`We're sorry, ${type} is not a valid parameter. You must use a string representing the method you wish to invoke.`);\n      }\n      return this;\n    };\n    $.fn.foundation = foundation;\n    return $;\n  }\n};\n\nFoundation.util = {\n  /**\n   * Function for applying a debounce effect to a function call.\n   * @function\n   * @param {Function} func - Function to be called at end of timeout.\n   * @param {Number} delay - Time in ms to delay the call of `func`.\n   * @returns function\n   */\n  throttle: function (func, delay) {\n    var timer = null;\n\n    return function () {\n      var context = this, args = arguments;\n\n      if (timer === null) {\n        timer = setTimeout(function () {\n          func.apply(context, args);\n          timer = null;\n        }, delay);\n      }\n    };\n  }\n};\n\nwindow.Foundation = Foundation;\n\n// Polyfill for requestAnimationFrame\n(function() {\n  if (!Date.now || !window.Date.now)\n    window.Date.now = Date.now = function() { return new Date().getTime(); };\n\n  var vendors = ['webkit', 'moz'];\n  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n      var vp = vendors[i];\n      window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];\n      window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']\n                                 || window[vp+'CancelRequestAnimationFrame']);\n  }\n  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)\n    || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n    var lastTime = 0;\n    window.requestAnimationFrame = function(callback) {\n        var now = Date.now();\n        var nextTime = Math.max(lastTime + 16, now);\n        return setTimeout(function() { callback(lastTime = nextTime); },\n                          nextTime - now);\n    };\n    window.cancelAnimationFrame = clearTimeout;\n  }\n  /**\n   * Polyfill for performance.now, required by rAF\n   */\n  if(!window.performance || !window.performance.now){\n    window.performance = {\n      start: Date.now(),\n      now: function(){ return Date.now() - this.start; }\n    };\n  }\n})();\nif (!Function.prototype.bind) {\n  Function.prototype.bind = function(oThis) {\n    if (typeof this !== 'function') {\n      // closest thing possible to the ECMAScript 5\n      // internal IsCallable function\n      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n    }\n\n    var aArgs   = Array.prototype.slice.call(arguments, 1),\n        fToBind = this,\n        fNOP    = function() {},\n        fBound  = function() {\n          return fToBind.apply(this instanceof fNOP\n                 ? this\n                 : oThis,\n                 aArgs.concat(Array.prototype.slice.call(arguments)));\n        };\n\n    if (this.prototype) {\n      // native functions don't have a prototype\n      fNOP.prototype = this.prototype;\n    }\n    fBound.prototype = new fNOP();\n\n    return fBound;\n  };\n}\n// Polyfill to get the name of a function in IE9\nfunction functionName(fn) {\n  if (typeof Function.prototype.name === 'undefined') {\n    var funcNameRegex = /function\\s([^(]{1,})\\(/;\n    var results = (funcNameRegex).exec((fn).toString());\n    return (results && results.length > 1) ? results[1].trim() : \"\";\n  }\n  else if (typeof fn.prototype === 'undefined') {\n    return fn.constructor.name;\n  }\n  else {\n    return fn.prototype.constructor.name;\n  }\n}\nfunction parseValue(str){\n  if ('true' === str) return true;\n  else if ('false' === str) return false;\n  else if (!isNaN(str * 1)) return parseFloat(str);\n  return str;\n}\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nexport {Foundation};\n","'use strict';\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\n\n// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\nclass Plugin {\n\n  constructor(element, options) {\n    this._setup(element, options);\n    var pluginName = getPluginName(this);\n    this.uuid = GetYoDigits(6, pluginName);\n\n    if(!this.$element.attr(`data-${pluginName}`)){ this.$element.attr(`data-${pluginName}`, this.uuid); }\n    if(!this.$element.data('zfPlugin')){ this.$element.data('zfPlugin', this); }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n    this.$element.trigger(`init.zf.${pluginName}`);\n  }\n\n  destroy() {\n    this._destroy();\n    var pluginName = getPluginName(this);\n    this.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n        /**\n         * Fires when the plugin has been destroyed.\n         * @event Plugin#destroyed\n         */\n        .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in this){\n      this[prop] = null;//clean up script to prep for garbage collection.\n    }\n  }\n}\n\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n  if(typeof(obj.constructor.name) !== 'undefined') {\n    return hyphenate(obj.constructor.name);\n  } else {\n    return hyphenate(obj.className);\n  }\n}\n\nexport {Plugin};\n","\"use strict\";\n\nimport $ from 'jquery';\n\n// Core Foundation Utilities, utilized in a number of places.\n\n  /**\n   * Returns a boolean for RTL support\n   */\nfunction rtl() {\n  return $('html').attr('dir') === 'rtl';\n}\n\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\nfunction GetYoDigits(length, namespace){\n  length = length || 6;\n  return Math.round((Math.pow(36, length + 1) - Math.random() * Math.pow(36, length))).toString(36).slice(1) + (namespace ? `-${namespace}` : '');\n}\n\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\nfunction RegExpEscape(str){\n  return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem){\n  var transitions = {\n    'transition': 'transitionend',\n    'WebkitTransition': 'webkitTransitionEnd',\n    'MozTransition': 'transitionend',\n    'OTransition': 'otransitionend'\n  };\n  var elem = document.createElement('div'),\n      end;\n\n  for (var t in transitions){\n    if (typeof elem.style[t] !== 'undefined'){\n      end = transitions[t];\n    }\n  }\n  if(end){\n    return end;\n  }else{\n    end = setTimeout(function(){\n      $elem.triggerHandler('transitionend', [$elem]);\n    }, 1);\n    return 'transitionend';\n  }\n}\n\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\nfunction onLoad($elem, handler) {\n  const didLoad = document.readyState === 'complete';\n  const eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n  const cb = () => $elem.triggerHandler(eventType);\n\n  if ($elem) {\n    if (handler) $elem.one(eventType, handler);\n\n    if (didLoad)\n      setTimeout(cb);\n    else\n      $(window).one('load', cb);\n  }\n\n  return eventType;\n}\n\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n *   (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n *   outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\nfunction ignoreMousedisappear(handler, { ignoreLeaveWindow = false, ignoreReappear = false } = {}) {\n  return function leaveEventHandler(eLeave, ...rest) {\n    const callback = handler.bind(this, eLeave, ...rest);\n\n    // The mouse left: call the given callback if the mouse entered elsewhere\n    if (eLeave.relatedTarget !== null) {\n      return callback();\n    }\n\n    // Otherwise, check if the mouse actually left the window.\n    // In firefox if the user switched between windows, the window sill have the focus by the time\n    // the event is triggered. We have to debounce the event to test this case.\n    setTimeout(function leaveEventDebouncer() {\n      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n        return callback();\n      }\n\n      // Otherwise, wait for the mouse to reeapear outside of the element,\n      if (!ignoreReappear) {\n        $(document).one('mouseenter', function reenterEventHandler(eReenter) {\n          if (!$(eLeave.currentTarget).has(eReenter.target).length) {\n            // Fill where the mouse finally entered.\n            eLeave.relatedTarget = eReenter.target;\n            callback();\n          }\n        });\n      }\n\n    }, 0);\n  };\n}\n\nexport { rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear };\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits, transitionend } from './foundation.core.utils';\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Drilldown module.\n * @module foundation.drilldown\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n * @requires foundation.util.box\n */\n\nclass Drilldown extends Plugin {\n  /**\n   * Creates a new instance of a drilldown menu.\n   * @class\n   * @name Drilldown\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);\n    this.className = 'Drilldown'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('Drilldown', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close',\n      'TAB': 'down',\n      'SHIFT_TAB': 'up'\n    });\n  }\n\n  /**\n   * Initializes the drilldown by creating jQuery collections of elements\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'drilldown');\n\n    if(this.options.autoApplyClass) {\n      this.$element.addClass('drilldown');\n    }\n\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': false\n    });\n    this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');\n    this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');\n    this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a');\n\n    // Set the main menu as current by default (unless a submenu is selected)\n    // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu\n    this.$currentMenu = this.$element;\n\n    this.$element.attr('data-mutate', (this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown')));\n\n    this._prepareMenu();\n    this._registerEvents();\n\n    this._keyboardEvents();\n  }\n\n  /**\n   * prepares drilldown menu by setting attributes to links and elements\n   * sets a min height to prevent content jumping\n   * wraps the element if not already wrapped\n   * @private\n   * @function\n   */\n  _prepareMenu() {\n    var _this = this;\n    // if(!this.options.holdOpen){\n    //   this._menuLinkEvents();\n    // }\n    this.$submenuAnchors.each(function(){\n      var $link = $(this);\n      var $sub = $link.parent();\n      if(_this.options.parentLink){\n        $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-drilldown-submenu-item\" role=\"menuitem\"></li>');\n      }\n      $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);\n      $link.children('[data-submenu]')\n          .attr({\n            'aria-hidden': true,\n            'tabindex': 0,\n            'role': 'group'\n          });\n      _this._events($link);\n    });\n    this.$submenus.each(function(){\n      var $menu = $(this),\n          $back = $menu.find('.js-drilldown-back');\n      if(!$back.length){\n        switch (_this.options.backButtonPosition) {\n          case \"bottom\":\n            $menu.append(_this.options.backButton);\n            break;\n          case \"top\":\n            $menu.prepend(_this.options.backButton);\n            break;\n          default:\n            console.error(\"Unsupported backButtonPosition value '\" + _this.options.backButtonPosition + \"'\");\n        }\n      }\n      _this._back($menu);\n    });\n\n    this.$submenus.addClass('invisible');\n    if(!this.options.autoHeight) {\n      this.$submenus.addClass('drilldown-submenu-cover-previous');\n    }\n\n    // create a wrapper on element if it doesn't exist.\n    if(!this.$element.parent().hasClass('is-drilldown')){\n      this.$wrapper = $(this.options.wrapper).addClass('is-drilldown');\n      if(this.options.animateHeight) this.$wrapper.addClass('animate-height');\n      this.$element.wrap(this.$wrapper);\n    }\n    // set wrapper\n    this.$wrapper = this.$element.parent();\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  _resize() {\n    this.$wrapper.css({'max-width': 'none', 'min-height': 'none'});\n    // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  /**\n   * Adds event handlers to elements in the menu.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the current menu item to add handlers to.\n   */\n  _events($elem) {\n    var _this = this;\n\n    $elem.off('click.zf.drilldown')\n    .on('click.zf.drilldown', function(e){\n      if($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')){\n        e.stopImmediatePropagation();\n        e.preventDefault();\n      }\n\n      // if(e.target !== e.currentTarget.firstElementChild){\n      //   return false;\n      // }\n      _this._show($elem.parent('li'));\n\n      if(_this.options.closeOnClick){\n        var $body = $('body');\n        $body.off('.zf.drilldown').on('click.zf.drilldown', function(e){\n          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target)) { return; }\n          e.preventDefault();\n          _this._hideAll();\n          $body.off('.zf.drilldown');\n        });\n      }\n    });\n  }\n\n  /**\n   * Adds event handlers to the menu element.\n   * @function\n   * @private\n   */\n  _registerEvents() {\n    if(this.options.scrollTop){\n      this._bindHandler = this._scrollTop.bind(this);\n      this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown',this._bindHandler);\n    }\n    this.$element.on('mutateme.zf.trigger', this._resize.bind(this));\n  }\n\n  /**\n   * Scroll to Top of Element or data-scroll-top-element\n   * @function\n   * @fires Drilldown#scrollme\n   */\n  _scrollTop() {\n    var _this = this;\n    var $scrollTopElement = _this.options.scrollTopElement!=''?$(_this.options.scrollTopElement):_this.$element,\n        scrollPos = parseInt($scrollTopElement.offset().top+_this.options.scrollTopOffset, 10);\n    $('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing,function(){\n      /**\n        * Fires after the menu has scrolled\n        * @event Drilldown#scrollme\n        */\n      if(this===$('html')[0])_this.$element.trigger('scrollme.zf.drilldown');\n    });\n  }\n\n  /**\n   * Adds keydown event listener to `li`'s in the menu.\n   * @private\n   */\n  _keyboardEvents() {\n    var _this = this;\n\n    this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function(e){\n      var $element = $(this),\n          $elements = $element.parent('li').parent('ul').children('li').children('a'),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1));\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'Drilldown', {\n        next: function() {\n          if ($element.is(_this.$submenuAnchors)) {\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        previous: function() {\n          _this._hide($element.parent('li').parent('ul'));\n          $element.parent('li').parent('ul').one(transitionend($element), function(){\n            setTimeout(function() {\n              $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n            }, 1);\n          });\n          return true;\n        },\n        up: function() {\n          $prevElement.focus();\n          // Don't tap focus on first element in root ul\n          return !$element.is(_this.$element.find('> li:first-child > a'));\n        },\n        down: function() {\n          $nextElement.focus();\n          // Don't tap focus on last element in root ul\n          return !$element.is(_this.$element.find('> li:last-child > a'));\n        },\n        close: function() {\n          // Don't close on element in root ul\n          if (!$element.is(_this.$element.find('> li > a'))) {\n            _this._hide($element.parent().parent());\n            $element.parent().parent().siblings('a').focus();\n          }\n        },\n        open: function() {\n          if (_this.options.parentLink && $element.attr('href')) { // Link with href\n            return false;\n          } else if (!$element.is(_this.$menuItems)) { // not menu item means back button\n            _this._hide($element.parent('li').parent('ul'));\n            $element.parent('li').parent('ul').one(transitionend($element), function(){\n              setTimeout(function() {\n                $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n              }, 1);\n            });\n            return true;\n          } else if ($element.is(_this.$submenuAnchors)) { // Sub menu item\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    }); // end keyboardAccess\n  }\n\n  /**\n   * Closes all open elements, and returns to root menu.\n   * @function\n   * @fires Drilldown#closed\n   */\n  _hideAll() {\n    var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    $elem.one(transitionend($elem), function(e){\n      $elem.removeClass('is-active is-closing');\n    });\n        /**\n         * Fires when the menu is fully closed.\n         * @event Drilldown#closed\n         */\n    this.$element.trigger('closed.zf.drilldown');\n  }\n\n  /**\n   * Adds event listener for each `back` button, and closes open menus.\n   * @function\n   * @fires Drilldown#back\n   * @param {jQuery} $elem - the current sub-menu to add `back` event.\n   */\n  _back($elem) {\n    var _this = this;\n    $elem.off('click.zf.drilldown');\n    $elem.children('.js-drilldown-back')\n      .on('click.zf.drilldown', function(e){\n        e.stopImmediatePropagation();\n        // console.log('mouseup on back');\n        _this._hide($elem);\n\n        // If there is a parent submenu, call show\n        let parentSubMenu = $elem.parent('li').parent('ul').parent('li');\n        if (parentSubMenu.length) {\n          _this._show(parentSubMenu);\n        }\n      });\n  }\n\n  /**\n   * Adds event listener to menu items w/o submenus to close open menus on click.\n   * @function\n   * @private\n   */\n  _menuLinkEvents() {\n    var _this = this;\n    this.$menuItems.not('.is-drilldown-submenu-parent')\n        .off('click.zf.drilldown')\n        .on('click.zf.drilldown', function(e){\n          // e.stopImmediatePropagation();\n          setTimeout(function(){\n            _this._hideAll();\n          }, 0);\n      });\n  }\n\n  /**\n   * Sets the CSS classes for submenu to show it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setShowSubMenuClasses($elem, trigger) {\n    $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    $elem.parent('li').attr('aria-expanded', true);\n    if (trigger === true) {\n      this.$element.trigger('open.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Sets the CSS classes for submenu to hide it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setHideSubMenuClasses($elem, trigger) {\n    $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);\n    $elem.parent('li').attr('aria-expanded', false);\n    if (trigger === true) {\n      $elem.trigger('hide.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.\n   * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the target (sub)menu (`ul` tag)\n   * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused\n   */\n  _showMenu($elem, autoFocus) {\n\n    var _this = this;\n\n    // Reset drilldown\n    var $expandedSubmenus = this.$element.find('li[aria-expanded=\"true\"] > ul[data-submenu]');\n    $expandedSubmenus.each(function(index) {\n      _this._setHideSubMenuClasses($(this));\n    });\n\n    // Save the menu as the currently displayed one.\n    this.$currentMenu = $elem;\n\n    // If target menu is root, focus first link & exit\n    if ($elem.is('[data-drilldown]')) {\n      if (autoFocus === true) $elem.find('li[role=\"treeitem\"] > a').first().focus();\n      if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));\n      return;\n    }\n\n    // Find all submenus on way to root incl. the element itself\n    var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]');\n\n    // Open target menu and all submenus on its way to root\n    $submenus.each(function(index) {\n\n      // Update height of first child (target menu) if autoHeight option true\n      if (index === 0 && _this.options.autoHeight) {\n        _this.$wrapper.css('height', $(this).data('calcHeight'));\n      }\n\n      var isLastChild = index == $submenus.length - 1;\n\n      // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link\n      // Last child makes sure the event gets always triggered even if going through several menus\n      if (isLastChild === true) {\n        $(this).one(transitionend($(this)), () => {\n          if (autoFocus === true) {\n            $elem.find('li[role=\"treeitem\"] > a').first().focus();\n          }\n        });\n      }\n\n      _this._setShowSubMenuClasses($(this), isLastChild);\n    });\n  }\n\n  /**\n   * Opens a submenu.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.\n   */\n  _show($elem) {\n    const $submenu = $elem.children('[data-submenu]');\n\n    $elem.attr('aria-expanded', true);\n\n    this.$currentMenu = $submenu;\n    $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    if (this.options.autoHeight) {\n      this.$wrapper.css({ height: $submenu.data('calcHeight') });\n    }\n\n    /**\n     * Fires when the submenu has opened.\n     * @event Drilldown#open\n     */\n    this.$element.trigger('open.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Hides a submenu\n   * @function\n   * @fires Drilldown#hide\n   * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.\n   */\n  _hide($elem) {\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    var _this = this;\n    $elem.parent('li').attr('aria-expanded', false);\n    $elem.attr('aria-hidden', true);\n    $elem.addClass('is-closing')\n         .one(transitionend($elem), function(){\n           $elem.removeClass('is-active is-closing');\n           $elem.blur().addClass('invisible');\n         });\n    /**\n     * Fires when the submenu has closed.\n     * @event Drilldown#hide\n     */\n    $elem.trigger('hide.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Iterates through the nested menus to calculate the min-height, and max-width for the menu.\n   * Prevents content jumping.\n   * @function\n   * @private\n   */\n  _getMaxDims() {\n    var maxHeight = 0, result = {}, _this = this;\n\n    // Recalculate menu heights and total max height\n    this.$submenus.add(this.$element).each(function(){\n      var numOfElems = $(this).children('li').length;\n      var height = Box.GetDimensions(this).height;\n\n      maxHeight = height > maxHeight ? height : maxHeight;\n\n      if(_this.options.autoHeight) {\n        $(this).data('calcHeight',height);\n      }\n    });\n\n    if (this.options.autoHeight)\n      result['height'] = this.$currentMenu.data('calcHeight');\n    else\n      result['min-height'] = `${maxHeight}px`;\n\n    result['max-width'] = `${this.$element[0].getBoundingClientRect().width}px`;\n\n    return result;\n  }\n\n  /**\n   * Destroys the Drilldown Menu\n   * @function\n   */\n  _destroy() {\n    if(this.options.scrollTop) this.$element.off('.zf.drilldown',this._bindHandler);\n    this._hideAll();\n\t  this.$element.off('mutateme.zf.trigger');\n    Nest.Burn(this.$element, 'drilldown');\n    this.$element.unwrap()\n                 .find('.js-drilldown-back, .is-submenu-parent-item').remove()\n                 .end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu')\n                 .end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');\n    this.$submenuAnchors.each(function() {\n      $(this).off('.zf.drilldown');\n    });\n\n    this.$element.find('[data-is-parent-link]').detach();\n    this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');\n\n    this.$element.find('a').each(function(){\n      var $link = $(this);\n      $link.removeAttr('tabindex');\n      if($link.data('savedHref')){\n        $link.attr('href', $link.data('savedHref')).removeData('savedHref');\n      }else{ return; }\n    });\n  };\n}\n\nDrilldown.defaults = {\n  /**\n   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are\n   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.\n   * @option\n   * @type {boolian}\n   * @default true\n   */\n  autoApplyClass: true,\n  /**\n   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>'\n   */\n  backButton: '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>',\n  /**\n   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default top\n   */\n  backButtonPosition: 'top',\n  /**\n   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<div></div>'\n   */\n  wrapper: '<div></div>',\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Allow the menu to return to root list on body click.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false,\n  /**\n   * Allow the menu to auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoHeight: false,\n  /**\n   * Animate the auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animateHeight: false,\n  /**\n   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  scrollTop: false,\n  /**\n   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  scrollTopElement: '',\n  /**\n   * ScrollTop offset\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  scrollTopOffset: 0,\n  /**\n   * Scroll animation duration\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Scroll animation easing. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @see {@link https://api.jquery.com/animate|JQuery animate}\n   * @default 'swing'\n   */\n  animationEasing: 'swing'\n  // holdOpen: false\n};\n\nexport {Drilldown};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { Positionable } from './foundation.positionable';\n\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Dropdown module.\n * @module foundation.dropdown\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.triggers\n */\nclass Dropdown extends Positionable {\n  /**\n   * Creates a new instance of a dropdown.\n   * @class\n   * @name Dropdown\n   * @param {jQuery} element - jQuery object to make into a dropdown.\n   *        Object should be of the dropdown panel, rather than its anchor.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);\n    this.className = 'Dropdown'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Dropdown', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.\n   * @function\n   * @private\n   */\n  _init() {\n    var $id = this.$element.attr('id');\n\n    this.$anchors = $(`[data-toggle=\"${$id}\"]`).length ? $(`[data-toggle=\"${$id}\"]`) : $(`[data-open=\"${$id}\"]`);\n    this.$anchors.attr({\n      'aria-controls': $id,\n      'data-is-focus': false,\n      'data-yeti-box': $id,\n      'aria-haspopup': true,\n      'aria-expanded': false\n    });\n\n    this._setCurrentAnchor(this.$anchors.first());\n\n    if(this.options.parentClass){\n      this.$parent = this.$element.parents('.' + this.options.parentClass);\n    }else{\n      this.$parent = null;\n    }\n\n    // Set [aria-labelledby] on the Dropdown if it is not set\n    if (typeof this.$element.attr('aria-labelledby') === 'undefined') {\n      // Get the anchor ID or create one\n      if (typeof this.$currentAnchor.attr('id') === 'undefined') {\n        this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));\n      };\n\n      this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));\n    }\n\n    this.$element.attr({\n      'aria-hidden': 'true',\n      'data-yeti-box': $id,\n      'data-resize': $id,\n    });\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/(top|left|right|bottom)/g);\n    if(position) {\n      return position[0];\n    } else {\n      return 'bottom'\n    }\n  }\n\n  _getDefaultAlignment() {\n    // handle legacy float approach\n    var horizontalPosition = /float-(\\S+)/.exec(this.$currentAnchor.attr('class'));\n    if(horizontalPosition) {\n      return horizontalPosition[1];\n    }\n\n    return super._getDefaultAlignment();\n  }\n\n\n\n  /**\n   * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.\n   * Recursively calls itself if a collision is detected, with a new position class.\n   * @function\n   * @private\n   */\n  _setPosition() {\n    this.$element.removeClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n    super._setPosition(this.$currentAnchor, this.$element, this.$parent);\n    this.$element.addClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n  }\n\n  /**\n   * Make it a current anchor.\n   * Current anchor as the reference for the position of Dropdown panes.\n   * @param {HTML} el - DOM element of the anchor.\n   * @function\n   * @private\n   */\n  _setCurrentAnchor(el) {\n    this.$currentAnchor = $(el);\n  }\n\n  /**\n   * Adds event listeners to the element utilizing the triggers utility library.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': this._setPosition.bind(this)\n    });\n\n    this.$anchors.off('click.zf.trigger')\n      .on('click.zf.trigger', function() { _this._setCurrentAnchor(this); });\n\n    if(this.options.hover){\n      this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n      .on('mouseenter.zf.dropdown', function(){\n        _this._setCurrentAnchor(this);\n\n        var bodyData = $('body').data();\n        if(typeof(bodyData.whatinput) === 'undefined' || bodyData.whatinput === 'mouse') {\n          clearTimeout(_this.timeout);\n          _this.timeout = setTimeout(function(){\n            _this.open();\n            _this.$anchors.data('hover', true);\n          }, _this.options.hoverDelay);\n        }\n      }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n        clearTimeout(_this.timeout);\n        _this.timeout = setTimeout(function(){\n          _this.close();\n          _this.$anchors.data('hover', false);\n        }, _this.options.hoverDelay);\n      }));\n      if(this.options.hoverPane){\n        this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n            .on('mouseenter.zf.dropdown', function(){\n              clearTimeout(_this.timeout);\n            }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n              clearTimeout(_this.timeout);\n              _this.timeout = setTimeout(function(){\n                _this.close();\n                _this.$anchors.data('hover', false);\n              }, _this.options.hoverDelay);\n            }));\n      }\n    }\n    this.$anchors.add(this.$element).on('keydown.zf.dropdown', function(e) {\n\n      var $target = $(this),\n        visibleFocusableElements = Keyboard.findFocusable(_this.$element);\n\n      Keyboard.handleKey(e, 'Dropdown', {\n        open: function() {\n          if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {\n            _this.open();\n            _this.$element.attr('tabindex', -1).focus();\n            e.preventDefault();\n          }\n        },\n        close: function() {\n          _this.close();\n          _this.$anchors.focus();\n        }\n      });\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n     var $body = $(document.body).not(this.$element),\n         _this = this;\n     $body.off('click.zf.dropdown')\n          .on('click.zf.dropdown', function(e){\n            if(_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {\n              return;\n            }\n            if(_this.$element.is(e.target) || _this.$element.find(e.target).length) {\n              return;\n            }\n            _this.close();\n            $body.off('click.zf.dropdown');\n          });\n  }\n\n  /**\n   * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.\n   * @function\n   * @fires Dropdown#closeme\n   * @fires Dropdown#show\n   */\n  open() {\n    // var _this = this;\n    /**\n     * Fires to close other open dropdowns, typically when dropdown is opening\n     * @event Dropdown#closeme\n     */\n    this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));\n    this.$anchors.addClass('hover')\n        .attr({'aria-expanded': true});\n    // this.$element/*.show()*/;\n\n    this.$element.addClass('is-opening');\n    this._setPosition();\n    this.$element.removeClass('is-opening').addClass('is-open')\n        .attr({'aria-hidden': false});\n\n    if(this.options.autoFocus){\n      var $focusable = Keyboard.findFocusable(this.$element);\n      if($focusable.length){\n        $focusable.eq(0).focus();\n      }\n    }\n\n    if(this.options.closeOnClick){ this._addBodyHandler(); }\n\n    if (this.options.trapFocus) {\n      Keyboard.trapFocus(this.$element);\n    }\n\n    /**\n     * Fires once the dropdown is visible.\n     * @event Dropdown#show\n     */\n    this.$element.trigger('show.zf.dropdown', [this.$element]);\n  }\n\n  /**\n   * Closes the open dropdown pane.\n   * @function\n   * @fires Dropdown#hide\n   */\n  close() {\n    if(!this.$element.hasClass('is-open')){\n      return false;\n    }\n    this.$element.removeClass('is-open')\n        .attr({'aria-hidden': true});\n\n    this.$anchors.removeClass('hover')\n        .attr('aria-expanded', false);\n\n    /**\n     * Fires once the dropdown is no longer visible.\n     * @event Dropdown#hide\n     */\n    this.$element.trigger('hide.zf.dropdown', [this.$element]);\n\n    if (this.options.trapFocus) {\n      Keyboard.releaseFocus(this.$element);\n    }\n  }\n\n  /**\n   * Toggles the dropdown pane's visibility.\n   * @function\n   */\n  toggle() {\n    if(this.$element.hasClass('is-open')){\n      if(this.$anchors.data('hover')) return;\n      this.close();\n    }else{\n      this.open();\n    }\n  }\n\n  /**\n   * Destroys the dropdown.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger').hide();\n    this.$anchors.off('.zf.dropdown');\n    $(document.body).off('click.zf.dropdown');\n\n  }\n}\n\nDropdown.defaults = {\n  /**\n   * Class that designates bounding container of Dropdown (default: window)\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  parentClass: null,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  hoverDelay: 250,\n  /**\n   * Allow submenus to open on hover events\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hover: false,\n  /**\n   * Don't close dropdown when hovering over dropdown pane\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hoverPane: false,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Position of dropdown. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false,\n  /**\n   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n  /**\n   * Allows a click on the body to close the dropdown.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false\n};\n\nexport {Dropdown};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl, ignoreMousedisappear } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { Box } from './foundation.util.box';\n\n/**\n * DropdownMenu module.\n * @module foundation.dropdown-menu\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.nest\n */\n\nclass DropdownMenu extends Plugin {\n  /**\n   * Creates a new instance of DropdownMenu.\n   * @class\n   * @name DropdownMenu\n   * @fires DropdownMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n    this.className = 'DropdownMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('DropdownMenu', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin, and calls _prepareMenu\n   * @private\n   * @function\n   */\n  _init() {\n    Nest.Feather(this.$element, 'dropdown');\n\n    var subs = this.$element.find('li.is-dropdown-submenu-parent');\n    this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');\n\n    this.$menuItems = this.$element.find('[role=\"menuitem\"]');\n    this.$tabs = this.$element.children('[role=\"menuitem\"]');\n    this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);\n\n    if (this.options.alignment === 'auto') {\n        if (this.$element.hasClass(this.options.rightClass) || Rtl() || this.$element.parents('.top-bar-right').is('*')) {\n            this.options.alignment = 'right';\n            subs.addClass('opens-left');\n        } else {\n            this.options.alignment = 'left';\n            subs.addClass('opens-right');\n        }\n    } else {\n      if (this.options.alignment === 'right') {\n          subs.addClass('opens-left');\n      } else {\n          subs.addClass('opens-right');\n      }\n    }\n    this.changed = false;\n    this._events();\n  };\n\n  _isVertical() {\n    return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';\n  }\n\n  _isRtl() {\n    return this.$element.hasClass('align-right') || (Rtl() && !this.$element.hasClass('align-left'));\n  }\n\n  /**\n   * Adds event listeners to elements within the menu\n   * @private\n   * @function\n   */\n  _events() {\n    var _this = this,\n        hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined'),\n        parClass = 'is-dropdown-submenu-parent';\n\n    // used for onClick and in the keyboard handlers\n    var handleClickFn = function(e) {\n      var $elem = $(e.target).parentsUntil('ul', `.${parClass}`),\n          hasSub = $elem.hasClass(parClass),\n          hasClicked = $elem.attr('data-is-click') === 'true',\n          $sub = $elem.children('.is-dropdown-submenu');\n\n      if (hasSub) {\n        if (hasClicked) {\n          if (!_this.options.closeOnClick || (!_this.options.clickOpen && !hasTouch) || (_this.options.forceFollow && hasTouch)) { return; }\n          else {\n            e.stopImmediatePropagation();\n            e.preventDefault();\n            _this._hide($elem);\n          }\n        } else {\n          e.preventDefault();\n          e.stopImmediatePropagation();\n          _this._show($sub);\n          $elem.add($elem.parentsUntil(_this.$element, `.${parClass}`)).attr('data-is-click', true);\n        }\n      }\n    };\n\n    if (this.options.clickOpen || hasTouch) {\n      this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);\n    }\n\n    // Handle Leaf element Clicks\n    if(_this.options.closeOnClickInside){\n      this.$menuItems.on('click.zf.dropdownmenu', function(e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if(!hasSub){\n          _this._hide();\n        }\n      });\n    }\n\n    if (!this.options.disableHover) {\n      this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {\n        var $elem = $(this),\n          hasSub = $elem.hasClass(parClass);\n\n        if (hasSub) {\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._show($elem.children('.is-dropdown-submenu'));\n          }, _this.options.hoverDelay));\n        }\n      }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if (hasSub && _this.options.autoclose) {\n          if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { return false; }\n\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._hide($elem);\n          }, _this.options.closingTime));\n        }\n      }));\n    }\n    this.$menuItems.on('keydown.zf.dropdownmenu', function(e) {\n      var $element = $(e.target).parentsUntil('ul', '[role=\"menuitem\"]'),\n          isTab = _this.$tabs.index($element) > -1,\n          $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(i-1);\n          $nextElement = $elements.eq(i+1);\n          return;\n        }\n      });\n\n      var nextSibling = function() {\n        $nextElement.children('a:first').focus();\n        e.preventDefault();\n      }, prevSibling = function() {\n        $prevElement.children('a:first').focus();\n        e.preventDefault();\n      }, openSub = function() {\n        var $sub = $element.children('ul.is-dropdown-submenu');\n        if ($sub.length) {\n          _this._show($sub);\n          $element.find('li > a:first').focus();\n          e.preventDefault();\n        } else { return; }\n      }, closeSub = function() {\n        //if ($element.is(':first-child')) {\n        var close = $element.parent('ul').parent('li');\n        close.children('a:first').focus();\n        _this._hide(close);\n        e.preventDefault();\n        //}\n      };\n      var functions = {\n        open: openSub,\n        close: function() {\n          _this._hide(_this.$element);\n          _this.$menuItems.eq(0).children('a').focus(); // focus to first element\n          e.preventDefault();\n        },\n        handled: function() {\n          e.stopImmediatePropagation();\n        }\n      };\n\n      if (isTab) {\n        if (_this._isVertical()) { // vertical menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: closeSub,\n              previous: openSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: openSub,\n              previous: closeSub\n            });\n          }\n        } else { // horizontal menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              next: prevSibling,\n              previous: nextSibling,\n              down: openSub,\n              up: closeSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              next: nextSibling,\n              previous: prevSibling,\n              down: openSub,\n              up: closeSub\n            });\n          }\n        }\n      } else { // not tabs -> one sub\n        if (_this._isRtl()) { // right aligned\n          $.extend(functions, {\n            next: closeSub,\n            previous: openSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        } else { // left aligned\n          $.extend(functions, {\n            next: openSub,\n            previous: closeSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        }\n      }\n      Keyboard.handleKey(e, 'DropdownMenu', functions);\n\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n    var $body = $(document.body),\n        _this = this;\n    $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu')\n         .on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function(e) {\n           var $link = _this.$element.find(e.target);\n           if ($link.length) { return; }\n\n           _this._hide();\n           $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');\n         });\n  }\n\n  /**\n   * Opens a dropdown pane, and checks for collisions first.\n   * @param {jQuery} $sub - ul element that is a submenu to show\n   * @function\n   * @private\n   * @fires Dropdownmenu#show\n   */\n  _show($sub) {\n    var idx = this.$tabs.index(this.$tabs.filter(function(i, el) {\n      return $(el).find($sub).length > 0;\n    }));\n    var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');\n    this._hide($sibs, idx);\n    $sub.css('visibility', 'hidden').addClass('js-dropdown-active')\n        .parent('li.is-dropdown-submenu-parent').addClass('is-active');\n    var clear = Box.ImNotTouchingYou($sub, null, true);\n    if (!clear) {\n      var oldClass = this.options.alignment === 'left' ? '-right' : '-left',\n          $parentLi = $sub.parent('.is-dropdown-submenu-parent');\n      $parentLi.removeClass(`opens${oldClass}`).addClass(`opens-${this.options.alignment}`);\n      clear = Box.ImNotTouchingYou($sub, null, true);\n      if (!clear) {\n        $parentLi.removeClass(`opens-${this.options.alignment}`).addClass('opens-inner');\n      }\n      this.changed = true;\n    }\n    $sub.css('visibility', '');\n    if (this.options.closeOnClick) { this._addBodyHandler(); }\n    /**\n     * Fires when the new dropdown pane is visible.\n     * @event Dropdownmenu#show\n     */\n    this.$element.trigger('show.zf.dropdownmenu', [$sub]);\n  }\n\n  /**\n   * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.\n   * @function\n   * @param {jQuery} $elem - element with a submenu to hide\n   * @param {Number} idx - index of the $tabs collection to hide\n   * @private\n   */\n  _hide($elem, idx) {\n    var $toClose;\n    if ($elem && $elem.length) {\n      $toClose = $elem;\n    } else if (typeof idx !== 'undefined') {\n      $toClose = this.$tabs.not(function(i, el) {\n        return i === idx;\n      });\n    }\n    else {\n      $toClose = this.$element;\n    }\n    var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;\n\n    if (somethingToClose) {\n      $toClose.find('li.is-active').add($toClose).attr({\n        'data-is-click': false\n      }).removeClass('is-active');\n\n      $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');\n\n      if (this.changed || $toClose.find('opens-inner').length) {\n        var oldClass = this.options.alignment === 'left' ? 'right' : 'left';\n        $toClose.find('li.is-dropdown-submenu-parent').add($toClose)\n                .removeClass(`opens-inner opens-${this.options.alignment}`)\n                .addClass(`opens-${oldClass}`);\n        this.changed = false;\n      }\n      /**\n       * Fires when the open menus are closed.\n       * @event Dropdownmenu#hide\n       */\n      this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);\n    }\n  }\n\n  /**\n   * Destroys the plugin.\n   * @function\n   */\n  _destroy() {\n    this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click')\n        .removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');\n    $(document.body).off('.zf.dropdownmenu');\n    Nest.Burn(this.$element, 'dropdown');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nDropdownMenu.defaults = {\n  /**\n   * Disallows hover events from opening submenus\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoclose: true,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  hoverDelay: 50,\n  /**\n   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  clickOpen: false,\n  /**\n   * Amount of time to delay closing a submenu on a mouseleave event.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n\n  closingTime: 500,\n  /**\n   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow clicks on the body to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allow clicks on leaf anchor links to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClickInside: true,\n  /**\n   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'vertical'\n   */\n  verticalClass: 'vertical',\n  /**\n   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'align-right'\n   */\n  rightClass: 'align-right',\n  /**\n   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  forceFollow: true\n};\n\nexport {DropdownMenu};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.imageLoader if equalizer contains images\n */\n\nclass Equalizer extends Plugin {\n  /**\n   * Creates a new instance of Equalizer.\n   * @class\n   * @name Equalizer\n   * @fires Equalizer#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options){\n    this.$element = element;\n    this.options  = $.extend({}, Equalizer.defaults, this.$element.data(), options);\n    this.className = 'Equalizer'; // ie9 back compat\n\n    this._init();\n  }\n\n  /**\n   * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var eqId = this.$element.attr('data-equalizer') || '';\n    var $watched = this.$element.find(`[data-equalizer-watch=\"${eqId}\"]`);\n\n    MediaQuery._init();\n\n    this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n    this.$element.attr('data-resize', (eqId || GetYoDigits(6, 'eq')));\n    this.$element.attr('data-mutate', (eqId || GetYoDigits(6, 'eq')));\n\n    this.hasNested = this.$element.find('[data-equalizer]').length > 0;\n    this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;\n    this.isOn = false;\n    this._bindHandler = {\n      onResizeMeBound: this._onResizeMe.bind(this),\n      onPostEqualizedBound: this._onPostEqualized.bind(this)\n    };\n\n    var imgs = this.$element.find('img');\n    var tooSmall;\n    if(this.options.equalizeOn){\n      tooSmall = this._checkMQ();\n      $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));\n    }else{\n      this._events();\n    }\n    if((typeof tooSmall !== 'undefined' && tooSmall === false) || typeof tooSmall === 'undefined'){\n      if(imgs.length){\n        onImagesLoaded(imgs, this._reflow.bind(this));\n      }else{\n        this._reflow();\n      }\n    }\n  }\n\n  /**\n   * Removes event listeners if the breakpoint is too small.\n   * @private\n   */\n  _pauseEvents() {\n    this.isOn = false;\n    this.$element.off({\n      '.zf.equalizer': this._bindHandler.onPostEqualizedBound,\n      'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,\n\t  'mutateme.zf.trigger': this._bindHandler.onResizeMeBound\n    });\n  }\n\n  /**\n   * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound\n   * @private\n   */\n  _onResizeMe(e) {\n    this._reflow();\n  }\n\n  /**\n   * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound\n   * @private\n   */\n  _onPostEqualized(e) {\n    if(e.target !== this.$element[0]){ this._reflow(); }\n  }\n\n  /**\n   * Initializes events for Equalizer.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this._pauseEvents();\n    if(this.hasNested){\n      this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);\n    }else{\n      this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);\n\t  this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);\n    }\n    this.isOn = true;\n  }\n\n  /**\n   * Checks the current breakpoint to the minimum required size.\n   * @private\n   */\n  _checkMQ() {\n    var tooSmall = !MediaQuery.is(this.options.equalizeOn);\n    if(tooSmall){\n      if(this.isOn){\n        this._pauseEvents();\n        this.$watched.css('height', 'auto');\n      }\n    }else{\n      if(!this.isOn){\n        this._events();\n      }\n    }\n    return tooSmall;\n  }\n\n  /**\n   * A noop version for the plugin\n   * @private\n   */\n  _killswitch() {\n    return;\n  }\n\n  /**\n   * Calls necessary functions to update Equalizer upon DOM change\n   * @private\n   */\n  _reflow() {\n    if(!this.options.equalizeOnStack){\n      if(this._isStacked()){\n        this.$watched.css('height', 'auto');\n        return false;\n      }\n    }\n    if (this.options.equalizeByRow) {\n      this.getHeightsByRow(this.applyHeightByRow.bind(this));\n    }else{\n      this.getHeights(this.applyHeight.bind(this));\n    }\n  }\n\n  /**\n   * Manually determines if the first 2 elements are *NOT* stacked.\n   * @private\n   */\n  _isStacked() {\n    if (!this.$watched[0] || !this.$watched[1]) {\n      return true;\n    }\n    return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} heights - An array of heights of children within Equalizer container\n   */\n  getHeights(cb) {\n    var heights = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      heights.push(this.$watched[i].offsetHeight);\n    }\n    cb(heights);\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   */\n  getHeightsByRow(cb) {\n    var lastElTopOffset = (this.$watched.length ? this.$watched.first().offset().top : 0),\n        groups = [],\n        group = 0;\n    //group by Row\n    groups[group] = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      //maybe could use this.$watched[i].offsetTop\n      var elOffsetTop = $(this.$watched[i]).offset().top;\n      if (elOffsetTop!=lastElTopOffset) {\n        group++;\n        groups[group] = [];\n        lastElTopOffset=elOffsetTop;\n      }\n      groups[group].push([this.$watched[i],this.$watched[i].offsetHeight]);\n    }\n\n    for (var j = 0, ln = groups.length; j < ln; j++) {\n      var heights = $(groups[j]).map(function(){ return this[1]; }).get();\n      var max         = Math.max.apply(null, heights);\n      groups[j].push(max);\n    }\n    cb(groups);\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest\n   * @param {array} heights - An array of heights of children within Equalizer container\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#postequalized\n   */\n  applyHeight(heights) {\n    var max = Math.max.apply(null, heights);\n    /**\n     * Fires before the heights are applied\n     * @event Equalizer#preequalized\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n\n    this.$watched.css('height', max);\n\n    /**\n     * Fires when the heights have been applied\n     * @event Equalizer#postequalized\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row\n   * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#preequalizedrow\n   * @fires Equalizer#postequalizedrow\n   * @fires Equalizer#postequalized\n   */\n  applyHeightByRow(groups) {\n    /**\n     * Fires before the heights are applied\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n    for (var i = 0, len = groups.length; i < len ; i++) {\n      var groupsILength = groups[i].length,\n          max = groups[i][groupsILength - 1];\n      if (groupsILength<=2) {\n        $(groups[i][0][0]).css({'height':'auto'});\n        continue;\n      }\n      /**\n        * Fires before the heights per row are applied\n        * @event Equalizer#preequalizedrow\n        */\n      this.$element.trigger('preequalizedrow.zf.equalizer');\n      for (var j = 0, lenJ = (groupsILength-1); j < lenJ ; j++) {\n        $(groups[i][j][0]).css({'height':max});\n      }\n      /**\n        * Fires when the heights per row have been applied\n        * @event Equalizer#postequalizedrow\n        */\n      this.$element.trigger('postequalizedrow.zf.equalizer');\n    }\n    /**\n     * Fires when the heights have been applied\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Destroys an instance of Equalizer.\n   * @function\n   */\n  _destroy() {\n    this._pauseEvents();\n    this.$watched.css('height', 'auto');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nEqualizer.defaults = {\n  /**\n   * Enable height equalization when stacked on smaller screens.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeOnStack: false,\n  /**\n   * Enable height equalization row by row.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeByRow: false,\n  /**\n   * String representing the minimum breakpoint size the plugin should equalize heights on.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  equalizeOn: ''\n};\n\nexport {Equalizer};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n */\n\nclass Interchange extends Plugin {\n  /**\n   * Creates a new instance of Interchange.\n   * @class\n   * @name Interchange\n   * @fires Interchange#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Interchange.defaults, options);\n    this.rules = [];\n    this.currentPath = '';\n    this.className = 'Interchange'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Interchange plugin and calls functions to get interchange functioning on load.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var id = this.$element[0].id || GetYoDigits(6, 'interchange');\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    this._addBreakpoints();\n    this._generateRules();\n    this._reflow();\n  }\n\n  /**\n   * Initializes events for Interchange.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', () => this._reflow());\n  }\n\n  /**\n   * Calls necessary functions to update Interchange upon DOM change\n   * @function\n   * @private\n   */\n  _reflow() {\n    var match;\n\n    // Iterate through each rule, but only save the last match\n    for (var i in this.rules) {\n      if(this.rules.hasOwnProperty(i)) {\n        var rule = this.rules[i];\n        if (window.matchMedia(rule.query).matches) {\n          match = rule;\n        }\n      }\n    }\n\n    if (match) {\n      this.replace(match.path);\n    }\n  }\n\n  /**\n   * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.\n   * @function\n   * @private\n   */\n  _addBreakpoints() {\n    for (var i in MediaQuery.queries) {\n      if (MediaQuery.queries.hasOwnProperty(i)) {\n        var query = MediaQuery.queries[i];\n        Interchange.SPECIAL_QUERIES[query.name] = query.value;\n      }\n    }\n  }\n\n  /**\n   * Checks the Interchange element for the provided media query + content pairings\n   * @function\n   * @private\n   * @param {Object} element - jQuery object that is an Interchange instance\n   * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys\n   */\n  _generateRules(element) {\n    var rulesList = [];\n    var rules;\n\n    if (this.options.rules) {\n      rules = this.options.rules;\n    }\n    else {\n      rules = this.$element.data('interchange');\n    }\n\n    rules =  typeof rules === 'string' ? rules.match(/\\[.*?, .*?\\]/g) : rules;\n\n    for (var i in rules) {\n      if(rules.hasOwnProperty(i)) {\n        var rule = rules[i].slice(1, -1).split(', ');\n        var path = rule.slice(0, -1).join('');\n        var query = rule[rule.length - 1];\n\n        if (Interchange.SPECIAL_QUERIES[query]) {\n          query = Interchange.SPECIAL_QUERIES[query];\n        }\n\n        rulesList.push({\n          path: path,\n          query: query\n        });\n      }\n    }\n\n    this.rules = rulesList;\n  }\n\n  /**\n   * Update the `src` property of an image, or change the HTML of a container, to the specified path.\n   * @function\n   * @param {String} path - Path to the image or HTML partial.\n   * @fires Interchange#replaced\n   */\n  replace(path) {\n    if (this.currentPath === path) return;\n\n    var _this = this,\n        trigger = 'replaced.zf.interchange';\n\n    // Replacing images\n    if (this.$element[0].nodeName === 'IMG') {\n      this.$element.attr('src', path).on('load', function() {\n        _this.currentPath = path;\n      })\n      .trigger(trigger);\n    }\n    // Replacing background images\n    else if (path.match(/\\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {\n      path = path.replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n      this.$element.css({ 'background-image': 'url('+path+')' })\n          .trigger(trigger);\n    }\n    // Replacing HTML\n    else {\n      $.get(path, function(response) {\n        _this.$element.html(response)\n             .trigger(trigger);\n        $(response).foundation();\n        _this.currentPath = path;\n      });\n    }\n\n    /**\n     * Fires when content in an Interchange element is done being loaded.\n     * @event Interchange#replaced\n     */\n    // this.$element.trigger('replaced.zf.interchange');\n  }\n\n  /**\n   * Destroys an instance of interchange.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('resizeme.zf.trigger')\n  }\n}\n\n/**\n * Default settings for plugin\n */\nInterchange.defaults = {\n  /**\n   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.\n   * @option\n   * @type {?array}\n   * @default null\n   */\n  rules: null\n};\n\nInterchange.SPECIAL_QUERIES = {\n  'landscape': 'screen and (orientation: landscape)',\n  'portrait': 'screen and (orientation: portrait)',\n  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'\n};\n\nexport {Interchange};\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { SmoothScroll } from './foundation.smoothScroll';\n\n/**\n * Magellan module.\n * @module foundation.magellan\n * @requires foundation.smoothScroll\n */\n\nclass Magellan extends Plugin {\n  /**\n   * Creates a new instance of Magellan.\n   * @class\n   * @name Magellan\n   * @fires Magellan#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options  = $.extend({}, Magellan.defaults, this.$element.data(), options);\n    this.className = 'Magellan'; // ie9 back compat\n\n    this._init();\n    this.calcPoints();\n  }\n\n  /**\n   * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var id = this.$element[0].id || GetYoDigits(6, 'magellan');\n    var _this = this;\n    this.$targets = $('[data-magellan-target]');\n    this.$links = this.$element.find('a');\n    this.$element.attr({\n      'data-resize': id,\n      'data-scroll': id,\n      'id': id\n    });\n    this.$active = $();\n    this.scrollPos = parseInt(window.pageYOffset, 10);\n\n    this._events();\n  }\n\n  /**\n   * Calculates an array of pixel values that are the demarcation lines between locations on the page.\n   * Can be invoked if new elements are added or the size of a location changes.\n   * @function\n   */\n  calcPoints() {\n    var _this = this,\n        body = document.body,\n        html = document.documentElement;\n\n    this.points = [];\n    this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));\n    this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));\n\n    this.$targets.each(function(){\n      var $tar = $(this),\n          pt = Math.round($tar.offset().top - _this.options.threshold);\n      $tar.targetPoint = pt;\n      _this.points.push(pt);\n    });\n  }\n\n  /**\n   * Initializes events for Magellan.\n   * @private\n   */\n  _events() {\n    var _this = this,\n        $body = $('html, body'),\n        opts = {\n          duration: _this.options.animationDuration,\n          easing:   _this.options.animationEasing\n        };\n\n    $(window).one('load', function(){\n      if(_this.options.deepLinking){\n        if(location.hash){\n          _this.scrollToLoc(location.hash);\n        }\n      }\n      _this.calcPoints();\n      _this._updateActive();\n    });\n\n    _this.onLoadListener = onLoad($(window), function () {\n      _this.$element\n        .on({\n          'resizeme.zf.trigger': _this.reflow.bind(_this),\n          'scrollme.zf.trigger': _this._updateActive.bind(_this)\n        })\n        .on('click.zf.magellan', 'a[href^=\"#\"]', function (e) {\n          e.preventDefault();\n          var arrival   = this.getAttribute('href');\n          _this.scrollToLoc(arrival);\n        });\n    });\n\n    this._deepLinkScroll = function(e) {\n      if(_this.options.deepLinking) {\n        _this.scrollToLoc(window.location.hash);\n      }\n    };\n\n    $(window).on('hashchange', this._deepLinkScroll);\n  }\n\n  /**\n   * Function to scroll to a given location on the page.\n   * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'\n   * @function\n   */\n  scrollToLoc(loc) {\n    this._inTransition = true;\n    var _this = this;\n\n    var options = {\n      animationEasing: this.options.animationEasing,\n      animationDuration: this.options.animationDuration,\n      threshold: this.options.threshold,\n      offset: this.options.offset\n    };\n\n    SmoothScroll.scrollToLoc(loc, options, function() {\n      _this._inTransition = false;\n    })\n  }\n\n  /**\n   * Calls necessary functions to update Magellan upon DOM change\n   * @function\n   */\n  reflow() {\n    this.calcPoints();\n    this._updateActive();\n  }\n\n  /**\n   * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.\n   * @private\n   * @function\n   * @fires Magellan#update\n   */\n  _updateActive(/*evt, elem, scrollPos*/) {\n    if(this._inTransition) return;\n\n    const newScrollPos = parseInt(window.pageYOffset, 10);\n    const isScrollingUp = this.scrollPos > newScrollPos;\n    this.scrollPos = newScrollPos;\n\n    let activeIdx;\n    // Before the first point: no link\n    if(newScrollPos < this.points[0]){ /* do nothing */ }\n    // At the bottom of the page: last link\n    else if(newScrollPos + this.winHeight === this.docHeight){ activeIdx = this.points.length - 1; }\n    // Otherwhise, use the last visible link\n    else{\n      const visibleLinks = this.points.filter((p, i) => {\n        return (p - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) <= newScrollPos;\n      });\n      activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;\n    }\n\n    // Get the new active link\n    const $oldActive = this.$active;\n    let activeHash = '';\n    if(typeof activeIdx !== 'undefined'){\n      this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(activeIdx).data('magellan-target') + '\"]');\n      if (this.$active.length) activeHash = this.$active[0].getAttribute('href');\n    }else{\n      this.$active = $();\n    }\n    const isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);\n    const isNewHash = activeHash !== window.location.hash;\n\n    // Update the active link element\n    if(isNewActive) {\n      $oldActive.removeClass(this.options.activeClass);\n      this.$active.addClass(this.options.activeClass);\n    }\n\n    // Update the hash (it may have changed with the same active link)\n    if(this.options.deepLinking && isNewHash){\n      if(window.history.pushState){\n        // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384\n        const url = activeHash ? activeHash : window.location.pathname + window.location.search;\n        window.history.pushState(null, null, url);\n      }else{\n        window.location.hash = activeHash;\n      }\n    }\n\n    if (isNewActive) {\n      /**\n       * Fires when magellan is finished updating to the new active element.\n       * @event Magellan#update\n       */\n    \tthis.$element.trigger('update.zf.magellan', [this.$active]);\n\t  }\n  }\n\n  /**\n   * Destroys an instance of Magellan and resets the url of the window.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger .zf.magellan')\n        .find(`.${this.options.activeClass}`).removeClass(this.options.activeClass);\n\n    if(this.options.deepLinking){\n      var hash = this.$active[0].getAttribute('href');\n      window.location.hash.replace(hash, '');\n    }\n\n    $(window).off('hashchange', this._deepLinkScroll)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\n/**\n * Default settings for plugin\n */\nMagellan.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Class applied to the active locations link on the magellan container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  activeClass: 'is-active',\n  /**\n   * Allows the script to manipulate the url of the current page, and if supported, alter the history.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinking: false,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {Magellan};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, transitionend, RegExpEscape } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * OffCanvas module.\n * @module foundation.offcanvas\n * @requires foundation.util.keyboard\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass OffCanvas extends Plugin {\n  /**\n   * Creates a new instance of an off-canvas wrapper.\n   * @class\n   * @name OffCanvas\n   * @fires OffCanvas#init\n   * @param {Object} element - jQuery object to initialize.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.className = 'OffCanvas'; // ie9 back compat\n    this.$element = element;\n    this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);\n    this.contentClasses = { base: [], reveal: [] };\n    this.$lastTrigger = $();\n    this.$triggers = $();\n    this.position = 'left';\n    this.$content = $();\n    this.nested = !!(this.options.nested);\n\n    // Defines the CSS transition/position classes of the off-canvas content container.\n    $(['push', 'overlap']).each((index, val) => {\n      this.contentClasses.base.push('has-transition-'+val);\n    });\n    $(['left', 'right', 'top', 'bottom']).each((index, val) => {\n      this.contentClasses.base.push('has-position-'+val);\n      this.contentClasses.reveal.push('has-reveal-'+val);\n    });\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n    MediaQuery._init();\n\n    this._init();\n    this._events();\n\n    Keyboard.register('OffCanvas', {\n      'ESCAPE': 'close'\n    });\n\n  }\n\n  /**\n   * Initializes the off-canvas wrapper by adding the exit overlay (if needed).\n   * @function\n   * @private\n   */\n  _init() {\n    var id = this.$element.attr('id');\n\n    this.$element.attr('aria-hidden', 'true');\n\n    // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)\n    if (this.options.contentId) {\n      this.$content = $('#'+this.options.contentId);\n    } else if (this.$element.siblings('[data-off-canvas-content]').length) {\n      this.$content = this.$element.siblings('[data-off-canvas-content]').first();\n    } else {\n      this.$content = this.$element.closest('[data-off-canvas-content]').first();\n    }\n\n    if (!this.options.contentId) {\n      // Assume that the off-canvas element is nested if it isn't a sibling of the content\n      this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;\n\n    } else if (this.options.contentId && this.options.nested === null) {\n      // Warning if using content ID without setting the nested option\n      // Once the element is nested it is required to work properly in this case\n      console.warn('Remember to use the nested option if using the content ID option!');\n    }\n\n    if (this.nested === true) {\n      // Force transition overlap if nested\n      this.options.transition = 'overlap';\n      // Remove appropriate classes if already assigned in markup\n      this.$element.removeClass('is-transition-push');\n    }\n\n    this.$element.addClass(`is-transition-${this.options.transition} is-closed`);\n\n    // Find triggers that affect this element and add aria-expanded to them\n    this.$triggers = $(document)\n      .find('[data-open=\"'+id+'\"], [data-close=\"'+id+'\"], [data-toggle=\"'+id+'\"]')\n      .attr('aria-expanded', 'false')\n      .attr('aria-controls', id);\n\n    // Get position by checking for related CSS class\n    this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\\-(left|top|right|bottom)/)[1] : this.position;\n\n    // Add an overlay over the content if necessary\n    if (this.options.contentOverlay === true) {\n      var overlay = document.createElement('div');\n      var overlayPosition = $(this.$element).css(\"position\") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';\n      overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);\n      this.$overlay = $(overlay);\n      if(overlayPosition === 'is-overlay-fixed') {\n        $(this.$overlay).insertAfter(this.$element);\n      } else {\n        this.$content.append(this.$overlay);\n      }\n    }\n\n    // Get the revealOn option from the class.\n    var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\\\s]+)', 'g');\n    var revealOnClass = revealOnRegExp.exec(this.$element[0].className);\n    if (revealOnClass) {\n      this.options.isRevealed = true;\n      this.options.revealOn = this.options.revealOn || revealOnClass[1];\n    }\n\n    // Ensure the `reveal-on-*` class is set.\n    if (this.options.isRevealed === true && this.options.revealOn) {\n      this.$element.first().addClass(`${this.options.revealClass}${this.options.revealOn}`);\n      this._setMQChecker();\n    }\n\n    if (this.options.transitionTime) {\n      this.$element.css('transition-duration', this.options.transitionTime);\n    }\n\n    // Initally remove all transition/position CSS classes from off-canvas content container.\n    this._removeContentClasses();\n  }\n\n  /**\n   * Adds event handlers to the off-canvas wrapper and the exit overlay.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('.zf.trigger .zf.offcanvas').on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'keydown.zf.offcanvas': this._handleKeyboard.bind(this)\n    });\n\n    if (this.options.closeOnClick === true) {\n      var $target = this.options.contentOverlay ? this.$overlay : this.$content;\n      $target.on({'click.zf.offcanvas': this.close.bind(this)});\n    }\n  }\n\n  /**\n   * Applies event listener for elements that will reveal at certain breakpoints.\n   * @private\n   */\n  _setMQChecker() {\n    var _this = this;\n\n    this.onLoadListener = onLoad($(window), function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      }\n    });\n\n    $(window).on('changed.zf.mediaquery', function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      } else {\n        _this.reveal(false);\n      }\n    });\n  }\n\n  /**\n   * Removes the CSS transition/position classes of the off-canvas content container.\n   * Removing the classes is important when another off-canvas gets opened that uses the same content container.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _removeContentClasses(hasReveal) {\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.removeClass(this.contentClasses.base.join(' '));\n    } else if (hasReveal === false) {\n      this.$content.removeClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.\n   * Beforehand any transition/position class gets removed.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _addContentClasses(hasReveal) {\n    this._removeContentClasses(hasReveal);\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.addClass(`has-transition-${this.options.transition} has-position-${this.position}`);\n    } else if (hasReveal === true) {\n      this.$content.addClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.\n   * @param {Boolean} isRevealed - true if element should be revealed.\n   * @function\n   */\n  reveal(isRevealed) {\n    if (isRevealed) {\n      this.close();\n      this.isRevealed = true;\n      this.$element.attr('aria-hidden', 'false');\n      this.$element.off('open.zf.trigger toggle.zf.trigger');\n      this.$element.removeClass('is-closed');\n    } else {\n      this.isRevealed = false;\n      this.$element.attr('aria-hidden', 'true');\n      this.$element.off('open.zf.trigger toggle.zf.trigger').on({\n        'open.zf.trigger': this.open.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this)\n      });\n      this.$element.addClass('is-closed');\n    }\n    this._addContentClasses(isRevealed);\n  }\n\n  /**\n   * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.\n   * @private\n   */\n  _stopScrolling(event) {\n    return false;\n  }\n\n  // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios\n  // Only really works for y, not sure how to extend to x or if we need to.\n  _recordScrollable(event) {\n    let elem = this; // called from event handler context with this as elem\n\n     // If the element is scrollable (content overflows), then...\n    if (elem.scrollHeight !== elem.clientHeight) {\n      // If we're at the top, scroll down one pixel to allow scrolling up\n      if (elem.scrollTop === 0) {\n        elem.scrollTop = 1;\n      }\n      // If we're at the bottom, scroll up one pixel to allow scrolling down\n      if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {\n        elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;\n      }\n    }\n    elem.allowUp = elem.scrollTop > 0;\n    elem.allowDown = elem.scrollTop < (elem.scrollHeight - elem.clientHeight);\n    elem.lastY = event.originalEvent.pageY;\n  }\n\n  _stopScrollPropagation(event) {\n    let elem = this; // called from event handler context with this as elem\n    let up = event.pageY < elem.lastY;\n    let down = !up;\n    elem.lastY = event.pageY;\n\n    if((up && elem.allowUp) || (down && elem.allowDown)) {\n      event.stopPropagation();\n    } else {\n      event.preventDefault();\n    }\n  }\n\n  /**\n   * Opens the off-canvas menu.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   * @fires Offcanvas#opened\n   * @todo also trigger 'open' event?\n   */\n  open(event, trigger) {\n    if (this.$element.hasClass('is-open') || this.isRevealed) { return; }\n    var _this = this;\n\n    if (trigger) {\n      this.$lastTrigger = trigger;\n    }\n\n    if (this.options.forceTo === 'top') {\n      window.scrollTo(0, 0);\n    } else if (this.options.forceTo === 'bottom') {\n      window.scrollTo(0,document.body.scrollHeight);\n    }\n\n    if (this.options.transitionTime && this.options.transition !== 'overlap') {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);\n    } else {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');\n    }\n\n    this.$element.addClass('is-open').removeClass('is-closed');\n\n    this.$triggers.attr('aria-expanded', 'true');\n    this.$element.attr('aria-hidden', 'false');\n\n    this.$content.addClass('is-open-' + this.position);\n\n    // If `contentScroll` is set to false, add class and disable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);\n      this.$element.on('touchstart', this._recordScrollable);\n      this.$element.on('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-closable');\n    }\n\n    if (this.options.autoFocus === true) {\n      this.$element.one(transitionend(this.$element), function() {\n        if (!_this.$element.hasClass('is-open')) {\n          return; // exit if prematurely closed\n        }\n        var canvasFocus = _this.$element.find('[data-autofocus]');\n        if (canvasFocus.length) {\n            canvasFocus.eq(0).focus();\n        } else {\n            _this.$element.find('a, button').eq(0).focus();\n        }\n      });\n    }\n\n    if (this.options.trapFocus === true) {\n      this.$content.attr('tabindex', '-1');\n      Keyboard.trapFocus(this.$element);\n    }\n\n    this._addContentClasses();\n\n    /**\n     * Fires when the off-canvas menu opens.\n     * @event Offcanvas#opened\n     */\n    this.$element.trigger('opened.zf.offcanvas');\n  }\n\n  /**\n   * Closes the off-canvas menu.\n   * @function\n   * @param {Function} cb - optional cb to fire after closure.\n   * @fires Offcanvas#closed\n   */\n  close(cb) {\n    if (!this.$element.hasClass('is-open') || this.isRevealed) { return; }\n\n    var _this = this;\n\n    this.$element.removeClass('is-open');\n\n    this.$element.attr('aria-hidden', 'true')\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#closed\n       */\n        .trigger('closed.zf.offcanvas');\n\n    this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');\n\n    // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);\n      this.$element.off('touchstart', this._recordScrollable);\n      this.$element.off('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-closable');\n    }\n\n    this.$triggers.attr('aria-expanded', 'false');\n\n    if (this.options.trapFocus === true) {\n      this.$content.removeAttr('tabindex');\n      Keyboard.releaseFocus(this.$element);\n    }\n\n    // Listen to transitionEnd and add class when done.\n    this.$element.one(transitionend(this.$element), function(e) {\n      _this.$element.addClass('is-closed');\n      _this._removeContentClasses();\n    });\n  }\n\n  /**\n   * Toggles the off-canvas menu open or closed.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   */\n  toggle(event, trigger) {\n    if (this.$element.hasClass('is-open')) {\n      this.close(event, trigger);\n    }\n    else {\n      this.open(event, trigger);\n    }\n  }\n\n  /**\n   * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.\n   * @function\n   * @private\n   */\n  _handleKeyboard(e) {\n    Keyboard.handleKey(e, 'OffCanvas', {\n      close: () => {\n        this.close();\n        this.$lastTrigger.focus();\n        return true;\n      },\n      handled: () => {\n        e.stopPropagation();\n        e.preventDefault();\n      }\n    });\n  }\n\n  /**\n   * Destroys the offcanvas plugin.\n   * @function\n   */\n  _destroy() {\n    this.close();\n    this.$element.off('.zf.trigger .zf.offcanvas');\n    this.$overlay.off('.zf.offcanvas');\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\nOffCanvas.defaults = {\n  /**\n   * Allow the user to click outside of the menu to close it.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Adds an overlay on top of `[data-off-canvas-content]`.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentOverlay: true,\n\n  /**\n   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  contentId: null,\n\n  /**\n   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.\n   * @option\n   * @type {boolean}\n   * @default null\n   */\n  nested: null,\n\n  /**\n   * Enable/disable scrolling of the main content when an off canvas panel is open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentScroll: true,\n\n  /**\n   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.\n   * @option\n   * @type {number}\n   * @default null\n   */\n  transitionTime: null,\n\n  /**\n   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.\n   * @option\n   * @type {string}\n   * @default push\n   */\n  transition: 'push',\n\n  /**\n   * Force the page to scroll to top or bottom on open.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  forceTo: null,\n\n  /**\n   * Allow the offcanvas to remain open for certain breakpoints.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  isRevealed: false,\n\n  /**\n   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  revealOn: null,\n\n  /**\n   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoFocus: true,\n\n  /**\n   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.\n   * @option\n   * @type {string}\n   * @default reveal-for-\n   * @todo improve the regex testing for this.\n   */\n  revealClass: 'reveal-for-',\n\n  /**\n   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false\n}\n\nexport {OffCanvas};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Motion } from './foundation.util.motion';\nimport { Timer } from './foundation.util.timer';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { Touch } from './foundation.util.touch'\n\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timer\n * @requires foundation.util.imageLoader\n * @requires foundation.util.touch\n */\n\nclass Orbit extends Plugin {\n  /**\n  * Creates a new instance of an orbit carousel.\n  * @class\n  * @name Orbit\n  * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n  * @param {Object} options - Overrides to the default plugin settings.\n  */\n  _setup(element, options){\n    this.$element = element;\n    this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);\n    this.className = 'Orbit'; // ie9 back compat\n\n    Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.\n\n    this._init();\n\n    Keyboard.register('Orbit', {\n      'ltr': {\n        'ARROW_RIGHT': 'next',\n        'ARROW_LEFT': 'previous'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'next',\n        'ARROW_RIGHT': 'previous'\n      }\n    });\n  }\n\n  /**\n  * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.\n  * @function\n  * @private\n  */\n  _init() {\n    // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide\n    this._reset();\n\n    this.$wrapper = this.$element.find(`.${this.options.containerClass}`);\n    this.$slides = this.$element.find(`.${this.options.slideClass}`);\n\n    var $images = this.$element.find('img'),\n        initActive = this.$slides.filter('.is-active'),\n        id = this.$element[0].id || GetYoDigits(6, 'orbit');\n\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    if (!initActive.length) {\n      this.$slides.eq(0).addClass('is-active');\n    }\n\n    if (!this.options.useMUI) {\n      this.$slides.addClass('no-motionui');\n    }\n\n    if ($images.length) {\n      onImagesLoaded($images, this._prepareForOrbit.bind(this));\n    } else {\n      this._prepareForOrbit();//hehe\n    }\n\n    if (this.options.bullets) {\n      this._loadBullets();\n    }\n\n    this._events();\n\n    if (this.options.autoPlay && this.$slides.length > 1) {\n      this.geoSync();\n    }\n\n    if (this.options.accessible) { // allow wrapper to be focusable to enable arrow navigation\n      this.$wrapper.attr('tabindex', 0);\n    }\n  }\n\n  /**\n  * Creates a jQuery collection of bullets, if they are being used.\n  * @function\n  * @private\n  */\n  _loadBullets() {\n    this.$bullets = this.$element.find(`.${this.options.boxOfBullets}`).find('button');\n  }\n\n  /**\n  * Sets a `timer` object on the orbit, and starts the counter for the next slide.\n  * @function\n  */\n  geoSync() {\n    var _this = this;\n    this.timer = new Timer(\n      this.$element,\n      {\n        duration: this.options.timerDelay,\n        infinite: false\n      },\n      function() {\n        _this.changeSlide(true);\n      });\n    this.timer.start();\n  }\n\n  /**\n  * Sets wrapper and slide heights for the orbit.\n  * @function\n  * @private\n  */\n  _prepareForOrbit() {\n    var _this = this;\n    this._setWrapperHeight();\n  }\n\n  /**\n  * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.\n  * @function\n  * @private\n  * @param {Function} cb - a callback function to fire when complete.\n  */\n  _setWrapperHeight(cb) {//rewrite this to `for` loop\n    var max = 0, temp, counter = 0, _this = this;\n\n    this.$slides.each(function() {\n      temp = this.getBoundingClientRect().height;\n      $(this).attr('data-slide', counter);\n\n      // hide all slides but the active one\n      if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {\n        $(this).css({'display': 'none'});\n      }\n      max = temp > max ? temp : max;\n      counter++;\n    });\n\n    if (counter === this.$slides.length) {\n      this.$wrapper.css({'height': max}); //only change the wrapper height property once.\n      if(cb) {cb(max);} //fire callback with max height dimension.\n    }\n  }\n\n  /**\n  * Sets the max-height of each slide.\n  * @function\n  * @private\n  */\n  _setSlideHeight(height) {\n    this.$slides.each(function() {\n      $(this).css('max-height', height);\n    });\n  }\n\n  /**\n  * Adds event listeners to basically everything within the element.\n  * @function\n  * @private\n  */\n  _events() {\n    var _this = this;\n\n    //***************************************\n    //**Now using custom event - thanks to:**\n    //**      Yohai Ararat of Toronto      **\n    //***************************************\n    //\n    this.$element.off('.resizeme.zf.trigger').on({\n      'resizeme.zf.trigger': this._prepareForOrbit.bind(this)\n    })\n    if (this.$slides.length > 1) {\n\n      if (this.options.swipe) {\n        this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit')\n        .on('swipeleft.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(true);\n        }).on('swiperight.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(false);\n        });\n      }\n      //***************************************\n\n      if (this.options.autoPlay) {\n        this.$slides.on('click.zf.orbit', function() {\n          _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);\n          _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();\n        });\n\n        if (this.options.pauseOnHover) {\n          this.$element.on('mouseenter.zf.orbit', function() {\n            _this.timer.pause();\n          }).on('mouseleave.zf.orbit', function() {\n            if (!_this.$element.data('clickedOn')) {\n              _this.timer.start();\n            }\n          });\n        }\n      }\n\n      if (this.options.navButtons) {\n        var $controls = this.$element.find(`.${this.options.nextClass}, .${this.options.prevClass}`);\n        $controls.attr('tabindex', 0)\n        //also need to handle enter/return and spacebar key presses\n        .on('click.zf.orbit touchend.zf.orbit', function(e){\n\t  e.preventDefault();\n          _this.changeSlide($(this).hasClass(_this.options.nextClass));\n        });\n      }\n\n      if (this.options.bullets) {\n        this.$bullets.on('click.zf.orbit touchend.zf.orbit', function() {\n          if (/is-active/g.test(this.className)) { return false; }//if this is active, kick out of function.\n          var idx = $(this).data('slide'),\n          ltr = idx > _this.$slides.filter('.is-active').data('slide'),\n          $slide = _this.$slides.eq(idx);\n\n          _this.changeSlide(ltr, $slide, idx);\n        });\n      }\n\n      if (this.options.accessible) {\n        this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function(e) {\n          // handle keyboard event with keyboard util\n          Keyboard.handleKey(e, 'Orbit', {\n            next: function() {\n              _this.changeSlide(true);\n            },\n            previous: function() {\n              _this.changeSlide(false);\n            },\n            handled: function() { // if bullet is focused, make sure focus moves\n              if ($(e.target).is(_this.$bullets)) {\n                _this.$bullets.filter('.is-active').focus();\n              }\n            }\n          });\n        });\n      }\n    }\n  }\n\n  /**\n   * Resets Orbit so it can be reinitialized\n   */\n  _reset() {\n    // Don't do anything if there are no slides (first run)\n    if (typeof this.$slides == 'undefined') {\n      return;\n    }\n\n    if (this.$slides.length > 1) {\n      // Remove old events\n      this.$element.off('.zf.orbit').find('*').off('.zf.orbit')\n\n      // Restart timer if autoPlay is enabled\n      if (this.options.autoPlay) {\n        this.timer.restart();\n      }\n\n      // Reset all sliddes\n      this.$slides.each(function(el) {\n        $(el).removeClass('is-active is-active is-in')\n          .removeAttr('aria-live')\n          .hide();\n      });\n\n      // Show the first slide\n      this.$slides.first().addClass('is-active').show();\n\n      // Triggers when the slide has finished animating\n      this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);\n\n      // Select first bullet if bullets are present\n      if (this.options.bullets) {\n        this._updateBullets(0);\n      }\n    }\n  }\n\n  /**\n  * Changes the current slide to a new one.\n  * @function\n  * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.\n  * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.\n  * @param {Number} idx - the index of the new slide in its collection, if one chosen.\n  * @fires Orbit#slidechange\n  */\n  changeSlide(isLTR, chosenSlide, idx) {\n    if (!this.$slides) {return; } // Don't freak out if we're in the middle of cleanup\n    var $curSlide = this.$slides.filter('.is-active').eq(0);\n\n    if (/mui/g.test($curSlide[0].className)) { return false; } //if the slide is currently animating, kick out of the function\n\n    var $firstSlide = this.$slides.first(),\n    $lastSlide = this.$slides.last(),\n    dirIn = isLTR ? 'Right' : 'Left',\n    dirOut = isLTR ? 'Left' : 'Right',\n    _this = this,\n    $newSlide;\n\n    if (!chosenSlide) { //most of the time, this will be auto played or clicked from the navButtons.\n      $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!\n      (this.options.infiniteWrap ? $curSlide.next(`.${this.options.slideClass}`).length ? $curSlide.next(`.${this.options.slideClass}`) : $firstSlide : $curSlide.next(`.${this.options.slideClass}`))//pick next slide if moving left to right\n      :\n      (this.options.infiniteWrap ? $curSlide.prev(`.${this.options.slideClass}`).length ? $curSlide.prev(`.${this.options.slideClass}`) : $lastSlide : $curSlide.prev(`.${this.options.slideClass}`));//pick prev slide if moving right to left\n    } else {\n      $newSlide = chosenSlide;\n    }\n\n    if ($newSlide.length) {\n      /**\n      * Triggers before the next slide starts animating in and only if a next slide has been found.\n      * @event Orbit#beforeslidechange\n      */\n      this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);\n\n      if (this.options.bullets) {\n        idx = idx || this.$slides.index($newSlide); //grab index to update bullets\n        this._updateBullets(idx);\n      }\n\n      if (this.options.useMUI && !this.$element.is(':hidden')) {\n        Motion.animateIn(\n          $newSlide.addClass('is-active'),\n          this.options[`animInFrom${dirIn}`],\n          function(){\n            $newSlide.css({'display': 'block'}).attr('aria-live', 'polite');\n        });\n\n        Motion.animateOut(\n          $curSlide.removeClass('is-active'),\n          this.options[`animOutTo${dirOut}`],\n          function(){\n            $curSlide.removeAttr('aria-live');\n            if(_this.options.autoPlay && !_this.timer.isPaused){\n              _this.timer.restart();\n            }\n            //do stuff?\n          });\n      } else {\n        $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();\n        $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();\n        if (this.options.autoPlay && !this.timer.isPaused) {\n          this.timer.restart();\n        }\n      }\n    /**\n    * Triggers when the slide has finished animating in.\n    * @event Orbit#slidechange\n    */\n      this.$element.trigger('slidechange.zf.orbit', [$newSlide]);\n    }\n  }\n\n  /**\n  * Updates the active state of the bullets, if displayed.\n  * @function\n  * @private\n  * @param {Number} idx - the index of the current slide.\n  */\n  _updateBullets(idx) {\n    var $oldBullet = this.$element.find(`.${this.options.boxOfBullets}`)\n    .find('.is-active').removeClass('is-active').blur(),\n    span = $oldBullet.find('span:last').detach(),\n    $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);\n  }\n\n  /**\n  * Destroys the carousel and hides the element.\n  * @function\n  */\n  _destroy() {\n    this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();\n  }\n}\n\nOrbit.defaults = {\n  /**\n  * Tells the JS to look for and loadBullets.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  bullets: true,\n  /**\n  * Tells the JS to apply event listeners to nav buttons\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  navButtons: true,\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-right'\n  */\n  animInFromRight: 'slide-in-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-right'\n  */\n  animOutToRight: 'slide-out-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-left'\n  *\n  */\n  animInFromLeft: 'slide-in-left',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-left'\n  */\n  animOutToLeft: 'slide-out-left',\n  /**\n  * Allows Orbit to automatically animate on page load.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  autoPlay: true,\n  /**\n  * Amount of time, in ms, between slide transitions\n  * @option\n   * @type {number}\n  * @default 5000\n  */\n  timerDelay: 5000,\n  /**\n  * Allows Orbit to infinitely loop through the slides\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  infiniteWrap: true,\n  /**\n  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  swipe: true,\n  /**\n  * Allows the timing function to pause animation on hover.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  pauseOnHover: true,\n  /**\n  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  accessible: true,\n  /**\n  * Class applied to the container of Orbit\n  * @option\n   * @type {string}\n  * @default 'orbit-container'\n  */\n  containerClass: 'orbit-container',\n  /**\n  * Class applied to individual slides.\n  * @option\n   * @type {string}\n  * @default 'orbit-slide'\n  */\n  slideClass: 'orbit-slide',\n  /**\n  * Class applied to the bullet container. You're welcome.\n  * @option\n   * @type {string}\n  * @default 'orbit-bullets'\n  */\n  boxOfBullets: 'orbit-bullets',\n  /**\n  * Class applied to the `next` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-next'\n  */\n  nextClass: 'orbit-next',\n  /**\n  * Class applied to the `previous` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-previous'\n  */\n  prevClass: 'orbit-previous',\n  /**\n  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  useMUI: true\n};\n\nexport {Orbit};\n","'use strict';\n\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst POSITIONS = ['left', 'right', 'top', 'bottom'];\nconst VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nconst HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\n\nconst ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n}\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n  if(currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\n\nclass Positionable extends Plugin {\n  /**\n   * Abstract class encapsulating the tether-like explicit positioning logic\n   * including repositioning based on overlap.\n   * Expects classes to define defaults for vOffset, hOffset, position,\n   * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n   * extending the defaults, or (for now recommended due to the way docs are\n   * generated) by explicitly declaring them.\n   *\n   **/\n\n  _init() {\n    this.triedPositions = {};\n    this.position  = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n    this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n    this.originalPosition = this.position;\n    this.originalAlignment = this.alignment;\n  }\n\n  _getDefaultPosition () {\n    return 'bottom';\n  }\n\n  _getDefaultAlignment() {\n    switch(this.position) {\n      case 'bottom':\n      case 'top':\n        return Rtl() ? 'right' : 'left';\n      case 'left':\n      case 'right':\n        return 'bottom';\n    }\n  }\n\n  /**\n   * Adjusts the positionable possible positions by iterating through alignments\n   * and positions.\n   * @function\n   * @private\n   */\n  _reposition() {\n    if(this._alignmentsExhausted(this.position)) {\n      this.position = nextItem(this.position, POSITIONS);\n      this.alignment = ALIGNMENTS[this.position][0];\n    } else {\n      this._realign();\n    }\n  }\n\n  /**\n   * Adjusts the dropdown pane possible positions by iterating through alignments\n   * on the current position.\n   * @function\n   * @private\n   */\n  _realign() {\n    this._addTriedPosition(this.position, this.alignment)\n    this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position])\n  }\n\n  _addTriedPosition(position, alignment) {\n    this.triedPositions[position] = this.triedPositions[position] || []\n    this.triedPositions[position].push(alignment);\n  }\n\n  _positionsExhausted() {\n    var isExhausted = true;\n    for(var i = 0; i < POSITIONS.length; i++) {\n      isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n    }\n    return isExhausted;\n  }\n\n  _alignmentsExhausted(position) {\n    return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n  }\n\n\n  // When we're trying to center, we don't want to apply offset that's going to\n  // take us just off center, so wrap around to return 0 for the appropriate\n  // offset in those alignments.  TODO: Figure out if we want to make this\n  // configurable behavior... it feels more intuitive, especially for tooltips, but\n  // it's possible someone might actually want to start from center and then nudge\n  // slightly off.\n  _getVOffset() {\n    return this.options.vOffset;\n  }\n\n  _getHOffset() {\n    return this.options.hOffset;\n  }\n\n\n  _setPosition($anchor, $element, $parent) {\n    if($anchor.attr('aria-expanded') === 'false'){ return false; }\n    var $eleDims = Box.GetDimensions($element),\n        $anchorDims = Box.GetDimensions($anchor);\n\n\n    if (!this.options.allowOverlap) {\n      // restore original position & alignment before checking overlap\n      this.position = this.originalPosition;\n      this.alignment = this.originalAlignment;\n    }\n\n    $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n    if(!this.options.allowOverlap) {\n      var overlaps = {};\n      var minOverlap = 100000000;\n      // default coordinates to how we start, in case we can't figure out better\n      var minCoordinates = {position: this.position, alignment: this.alignment};\n      while(!this._positionsExhausted()) {\n        let overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n        if(overlap === 0) {\n          return;\n        }\n\n        if(overlap < minOverlap) {\n          minOverlap = overlap;\n          minCoordinates = {position: this.position, alignment: this.alignment};\n        }\n\n        this._reposition();\n\n        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n      // If we get through the entire loop, there was no non-overlapping\n      // position available. Pick the version with least overlap.\n      this.position = minCoordinates.position;\n      this.alignment = minCoordinates.alignment;\n      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n    }\n  }\n\n}\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n}\n\nexport {Positionable};\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin }from './foundation.core.plugin';\n\nimport { Accordion } from './foundation.accordion';\nimport { Tabs } from './foundation.tabs';\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n  tabs: {\n    cssClass: 'tabs',\n    plugin: Tabs\n  },\n  accordion: {\n    cssClass: 'accordion',\n    plugin: Accordion\n  }\n};\n\n\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nclass ResponsiveAccordionTabs extends Plugin{\n  /**\n   * Creates a new instance of a responsive accordion tabs.\n   * @class\n   * @name ResponsiveAccordionTabs\n   * @fires ResponsiveAccordionTabs#init\n   * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options  = $.extend({}, this.$element.data(), options);\n    this.rules = this.$element.data('responsive-accordion-tabs');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveAccordionTabs'; // ie9 back compat\n    if (!this.$element.attr('id')) {\n      this.$element.attr('id',GetYoDigits(6, 'responsiveaccordiontabs'));\n    };\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    this._getAllOptions();\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n  }\n\n  _getAllOptions() {\n    //get all defaults and options\n    var _this = this;\n    _this.allOptions = {};\n    for (var key in MenuPlugins) {\n      if (MenuPlugins.hasOwnProperty(key)) {\n        var obj = MenuPlugins[key];\n        try {\n          var dummyPlugin = $('<ul></ul>');\n          var tmpPlugin = new obj.plugin(dummyPlugin,_this.options);\n          for (var keyKey in tmpPlugin.options) {\n            if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {\n              var objObj = tmpPlugin.options[keyKey];\n              _this.allOptions[keyKey] = objObj;\n            }\n          }\n          tmpPlugin.destroy();\n        }\n        catch(e) {\n        }\n      }\n    }\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);\n    $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) {\n      //don't know why but on nested elements data zfPlugin get's lost\n      if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin',this.storezfData);\n      this.currentPlugin.destroy();\n    }\n    this._handleMarkup(this.rules[matchedMq].cssClass);\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n    this.storezfData = this.currentPlugin.$element.data('zfPlugin');\n\n  }\n\n  _handleMarkup(toSet){\n    var _this = this, fromString = 'accordion';\n    var $panels = $('[data-tabs-content='+this.$element.attr('id')+']');\n    if ($panels.length) fromString = 'tabs';\n    if (fromString === toSet) {\n      return;\n    };\n\n    var tabsTitle = _this.allOptions.linkClass?_this.allOptions.linkClass:'tabs-title';\n    var tabsPanel = _this.allOptions.panelClass?_this.allOptions.panelClass:'tabs-panel';\n\n    this.$element.removeAttr('role');\n    var $liHeads = this.$element.children('.'+tabsTitle+',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');\n    var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');\n\n    if (fromString === 'tabs') {\n      $panels = $panels.children('.'+tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');\n      $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');\n    }else{\n      $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');\n    };\n\n    $panels.css({display:'',visibility:''});\n    $liHeads.css({display:'',visibility:''});\n    if (toSet === 'accordion') {\n      $panels.each(function(key,value){\n        $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content','').removeClass('is-active').css({height:''});\n        $('[data-tabs-content='+_this.$element.attr('id')+']').after('<div id=\"tabs-placeholder-'+_this.$element.attr('id')+'\"></div>').detach();\n        $liHeads.addClass('accordion-item').attr('data-accordion-item','');\n        $liHeadsA.addClass('accordion-title');\n      });\n    }else if (toSet === 'tabs'){\n      var $tabsContent = $('[data-tabs-content='+_this.$element.attr('id')+']');\n      var $placeholder = $('#tabs-placeholder-'+_this.$element.attr('id'));\n      if ($placeholder.length) {\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter($placeholder).attr('data-tabs-content',_this.$element.attr('id'));\n        $placeholder.remove();\n      }else{\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter(_this.$element).attr('data-tabs-content',_this.$element.attr('id'));\n      };\n      $panels.each(function(key,value){\n        var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);\n        var hash = $liHeadsA.get(key).hash.slice(1);\n        var id = $(value).attr('id') || GetYoDigits(6, 'accordion');\n        if (hash !== id) {\n          if (hash !== '') {\n            $(value).attr('id',hash);\n          }else{\n            hash = id;\n            $(value).attr('id',hash);\n            $($liHeadsA.get(key)).attr('href',$($liHeadsA.get(key)).attr('href').replace('#','')+'#'+hash);\n          };\n        };\n        var isActive = $($liHeads.get(key)).hasClass('is-active');\n        if (isActive) {\n          tempValue.addClass('is-active');\n        };\n      });\n      $liHeads.addClass(tabsTitle);\n    };\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n}\n\nResponsiveAccordionTabs.defaults = {};\n\nexport {ResponsiveAccordionTabs};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { DropdownMenu } from './foundation.dropdownMenu';\nimport { Drilldown } from './foundation.drilldown';\nimport { AccordionMenu } from './foundation.accordionMenu';\n\nlet MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: DropdownMenu\n  },\n drilldown: {\n    cssClass: 'drilldown',\n    plugin: Drilldown\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: AccordionMenu\n  }\n};\n\n  // import \"foundation.util.triggers.js\";\n\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveMenu extends Plugin {\n  /**\n   * Creates a new instance of a responsive menu.\n   * @class\n   * @name ResponsiveMenu\n   * @fires ResponsiveMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.rules = this.$element.data('responsive-menu');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveMenu'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n\n    MediaQuery._init();\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n    // Add data-mutate since children may need it.\n    this.$element.attr('data-mutate', (this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')));\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    $(window).on('changed.zf.mediaquery', function() {\n      _this._checkMediaQueries();\n    });\n    // $(window).on('resize.zf.ResponsiveMenu', function() {\n    //   _this._checkMediaQueries();\n    // });\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    this.currentPlugin.destroy();\n    $(window).off('.zf.ResponsiveMenu');\n  }\n}\n\nResponsiveMenu.defaults = {};\n\nexport {ResponsiveMenu};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion\n */\n\nclass ResponsiveToggle extends Plugin {\n  /**\n   * Creates a new instance of Tab Bar.\n   * @class\n   * @name ResponsiveToggle\n   * @fires ResponsiveToggle#init\n   * @param {jQuery} element - jQuery object to attach tab bar functionality to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n    this.className = 'ResponsiveToggle'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the tab bar by finding the target element, toggling element, and running update().\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var targetID = this.$element.data('responsive-toggle');\n    if (!targetID) {\n      console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');\n    }\n\n    this.$targetMenu = $(`#${targetID}`);\n    this.$toggler = this.$element.find('[data-toggle]').filter(function() {\n      var target = $(this).data('toggle');\n      return (target === targetID || target === \"\");\n    });\n    this.options = $.extend({}, this.options, this.$targetMenu.data());\n\n    // If they were set, parse the animation classes\n    if(this.options.animate) {\n      let input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n\n    this._update();\n  }\n\n  /**\n   * Adds necessary event handlers for the tab bar to work.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this._updateMqHandler = this._update.bind(this);\n\n    $(window).on('changed.zf.mediaquery', this._updateMqHandler);\n\n    this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));\n  }\n\n  /**\n   * Checks the current media query to determine if the tab bar should be visible or hidden.\n   * @function\n   * @private\n   */\n  _update() {\n    // Mobile\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      this.$element.show();\n      this.$targetMenu.hide();\n    }\n\n    // Desktop\n    else {\n      this.$element.hide();\n      this.$targetMenu.show();\n    }\n  }\n\n  /**\n   * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.\n   * @function\n   * @fires ResponsiveToggle#toggled\n   */\n  toggleMenu() {\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      /**\n       * Fires when the element attached to the tab bar toggles.\n       * @event ResponsiveToggle#toggled\n       */\n      if(this.options.animate) {\n        if (this.$targetMenu.is(':hidden')) {\n          Motion.animateIn(this.$targetMenu, this.animationIn, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n            this.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');\n          });\n        }\n        else {\n          Motion.animateOut(this.$targetMenu, this.animationOut, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n          });\n        }\n      }\n      else {\n        this.$targetMenu.toggle(0);\n        this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        this.$element.trigger('toggled.zf.responsiveToggle');\n      }\n    }\n  };\n\n  _destroy() {\n    this.$element.off('.zf.responsiveToggle');\n    this.$toggler.off('.zf.responsiveToggle');\n\n    $(window).off('changed.zf.mediaquery', this._updateMqHandler);\n  }\n}\n\nResponsiveToggle.defaults = {\n  /**\n   * The breakpoint after which the menu is always shown, and the tab bar is hidden.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  hideFor: 'medium',\n\n  /**\n   * To decide if the toggle should be animated or not.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport { ResponsiveToggle };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nclass Reveal extends Plugin {\n  /**\n   * Creates a new instance of Reveal.\n   * @class\n   * @name Reveal\n   * @param {jQuery} element - jQuery object to use for the modal.\n   * @param {Object} options - optional parameters.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);\n    this.className = 'Reveal'; // ie9 back compat\n    this._init();\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    Keyboard.register('Reveal', {\n      'ESCAPE': 'close',\n    });\n  }\n\n  /**\n   * Initializes the modal by adding the overlay and close buttons, (if selected).\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    this.id = this.$element.attr('id');\n    this.isActive = false;\n    this.cached = {mq: MediaQuery.current};\n\n    this.$anchor = $(`[data-open=\"${this.id}\"]`).length ? $(`[data-open=\"${this.id}\"]`) : $(`[data-toggle=\"${this.id}\"]`);\n    this.$anchor.attr({\n      'aria-controls': this.id,\n      'aria-haspopup': true,\n      'tabindex': 0\n    });\n\n    if (this.options.fullScreen || this.$element.hasClass('full')) {\n      this.options.fullScreen = true;\n      this.options.overlay = false;\n    }\n    if (this.options.overlay && !this.$overlay) {\n      this.$overlay = this._makeOverlay(this.id);\n    }\n\n    this.$element.attr({\n        'role': 'dialog',\n        'aria-hidden': true,\n        'data-yeti-box': this.id,\n        'data-resize': this.id\n    });\n\n    if(this.$overlay) {\n      this.$element.detach().appendTo(this.$overlay);\n    } else {\n      this.$element.detach().appendTo($(this.options.appendTo));\n      this.$element.addClass('without-overlay');\n    }\n    this._events();\n    if (this.options.deepLink && window.location.hash === ( `#${this.id}`)) {\n      this.onLoadListener = onLoad($(window), () => this.open());\n    }\n  }\n\n  /**\n   * Creates an overlay div to display behind the modal.\n   * @private\n   */\n  _makeOverlay() {\n    var additionalOverlayClasses = '';\n\n    if (this.options.additionalOverlayClasses) {\n      additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;\n    }\n\n    return $('<div></div>')\n      .addClass('reveal-overlay' + additionalOverlayClasses)\n      .appendTo(this.options.appendTo);\n  }\n\n  /**\n   * Updates position of modal\n   * TODO:  Figure out if we actually need to cache these values or if it doesn't matter\n   * @private\n   */\n  _updatePosition() {\n    var width = this.$element.outerWidth();\n    var outerWidth = $(window).width();\n    var height = this.$element.outerHeight();\n    var outerHeight = $(window).height();\n    var left, top = null;\n    if (this.options.hOffset === 'auto') {\n      left = parseInt((outerWidth - width) / 2, 10);\n    } else {\n      left = parseInt(this.options.hOffset, 10);\n    }\n    if (this.options.vOffset === 'auto') {\n      if (height > outerHeight) {\n        top = parseInt(Math.min(100, outerHeight / 10), 10);\n      } else {\n        top = parseInt((outerHeight - height) / 4, 10);\n      }\n    } else if (this.options.vOffset !== null) {\n      top = parseInt(this.options.vOffset, 10);\n    }\n\n    if (top !== null) {\n      this.$element.css({top: top + 'px'});\n    }\n\n    // only worry about left if we don't have an overlay or we have a horizontal offset,\n    // otherwise we're perfectly in the middle\n    if (!this.$overlay || (this.options.hOffset !== 'auto')) {\n      this.$element.css({left: left + 'px'});\n      this.$element.css({margin: '0px'});\n    }\n\n  }\n\n  /**\n   * Adds event handlers for the modal.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': (event, $element) => {\n        if ((event.target === _this.$element[0]) ||\n            ($(event.target).parents('[data-closable]')[0] === $element)) { // only close reveal when it's explicitly called\n          return this.close.apply(this);\n        }\n      },\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': function() {\n        _this._updatePosition();\n      }\n    });\n\n    if (this.options.closeOnClick && this.options.overlay) {\n      this.$overlay.off('.zf.reveal').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) {\n              return;\n        }\n        _this.close();\n      });\n    }\n    if (this.options.deepLink) {\n      $(window).on(`hashchange.zf.reveal:${this.id}`, this._handleState.bind(this));\n    }\n  }\n\n  /**\n   * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.\n   * @private\n   */\n  _handleState(e) {\n    if(window.location.hash === ( '#' + this.id) && !this.isActive){ this.open(); }\n    else{ this.close(); }\n  }\n\n  /**\n  * Disables the scroll when Reveal is shown to prevent the background from shifting\n  * @param {number} scrollTop - Scroll to visually apply, window current scroll by default\n  */\n  _disableScroll(scrollTop) {\n    scrollTop = scrollTop || $(window).scrollTop();\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", -scrollTop);\n    }\n  }\n\n  /**\n  * Reenables the scroll when Reveal closes\n  * @param {number} scrollTop - Scroll to restore, html \"top\" property by default (as set by `_disableScroll`)\n  */\n  _enableScroll(scrollTop) {\n    scrollTop = scrollTop || parseInt($(\"html\").css(\"top\"));\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", \"\");\n      $(window).scrollTop(-scrollTop);\n    }\n  }\n\n\n  /**\n   * Opens the modal controlled by `this.$anchor`, and closes all others by default.\n   * @function\n   * @fires Reveal#closeme\n   * @fires Reveal#open\n   */\n  open() {\n    // either update or replace browser history\n    const hash = `#${this.id}`;\n    if (this.options.deepLink && window.location.hash !== hash) {\n\n      if (window.history.pushState) {\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', hash);\n        } else {\n          window.history.replaceState({}, '', hash);\n        }\n      } else {\n        window.location.hash = hash;\n      }\n    }\n\n    // Remember anchor that opened it to set focus back later, have general anchors as fallback\n    this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;\n\n    this.isActive = true;\n\n    // Make elements invisible, but remove display: none so we can get size and positioning\n    this.$element\n        .css({ 'visibility': 'hidden' })\n        .show()\n        .scrollTop(0);\n    if (this.options.overlay) {\n      this.$overlay.css({'visibility': 'hidden'}).show();\n    }\n\n    this._updatePosition();\n\n    this.$element\n      .hide()\n      .css({ 'visibility': '' });\n\n    if(this.$overlay) {\n      this.$overlay.css({'visibility': ''}).hide();\n      if(this.$element.hasClass('fast')) {\n        this.$overlay.addClass('fast');\n      } else if (this.$element.hasClass('slow')) {\n        this.$overlay.addClass('slow');\n      }\n    }\n\n\n    if (!this.options.multipleOpened) {\n      /**\n       * Fires immediately before the modal opens.\n       * Closes any other modals that are currently open\n       * @event Reveal#closeme\n       */\n      this.$element.trigger('closeme.zf.reveal', this.id);\n    }\n\n    this._disableScroll();\n\n    var _this = this;\n\n    // Motion UI method of reveal\n    if (this.options.animationIn) {\n      function afterAnimation(){\n        _this.$element\n          .attr({\n            'aria-hidden': false,\n            'tabindex': -1\n          })\n          .focus();\n        _this._addGlobalClasses();\n        Keyboard.trapFocus(_this.$element);\n      }\n      if (this.options.overlay) {\n        Motion.animateIn(this.$overlay, 'fade-in');\n      }\n      Motion.animateIn(this.$element, this.options.animationIn, () => {\n        if(this.$element) { // protect against object having been removed\n          this.focusableElements = Keyboard.findFocusable(this.$element);\n          afterAnimation();\n        }\n      });\n    }\n    // jQuery method of reveal\n    else {\n      if (this.options.overlay) {\n        this.$overlay.show(0);\n      }\n      this.$element.show(this.options.showDelay);\n    }\n\n    // handle accessibility\n    this.$element\n      .attr({\n        'aria-hidden': false,\n        'tabindex': -1\n      })\n      .focus();\n    Keyboard.trapFocus(this.$element);\n\n    this._addGlobalClasses();\n\n    this._addGlobalListeners();\n\n    /**\n     * Fires when the modal has successfully opened.\n     * @event Reveal#open\n     */\n    this.$element.trigger('open.zf.reveal');\n  }\n\n  /**\n   * Adds classes and listeners on document required by open modals.\n   *\n   * The following classes are added and updated:\n   * - `.is-reveal-open` - Prevents the scroll on document\n   * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the\n   *                       scroll was not disabled. This prevent a \"shift\" of the page content due\n   *                       the scrollbar disappearing when the modal opens.\n   *\n   * @private\n   */\n  _addGlobalClasses() {\n    const updateScrollbarClass = () => {\n      $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));\n    };\n\n    this.$element.on('resizeme.zf.trigger.revealScrollbarListener', () => updateScrollbarClass());\n    updateScrollbarClass();\n    $('html').addClass('is-reveal-open');\n  }\n\n  /**\n   * Removes classes and listeners on document that were required by open modals.\n   * @private\n   */\n  _removeGlobalClasses() {\n    this.$element.off('resizeme.zf.trigger.revealScrollbarListener');\n    $('html').removeClass('is-reveal-open');\n    $('html').removeClass('zf-has-scroll');\n  }\n\n  /**\n   * Adds extra event handlers for the body and window if necessary.\n   * @private\n   */\n  _addGlobalListeners() {\n    var _this = this;\n    if(!this.$element) { return; } // If we're in the middle of cleanup, don't freak out\n    this.focusableElements = Keyboard.findFocusable(this.$element);\n\n    if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {\n      $('body').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) { return; }\n        _this.close();\n      });\n    }\n\n    if (this.options.closeOnEsc) {\n      $(window).on('keydown.zf.reveal', function(e) {\n        Keyboard.handleKey(e, 'Reveal', {\n          close: function() {\n            if (_this.options.closeOnEsc) {\n              _this.close();\n            }\n          }\n        });\n      });\n    }\n  }\n\n  /**\n   * Closes the modal.\n   * @function\n   * @fires Reveal#closed\n   */\n  close() {\n    if (!this.isActive || !this.$element.is(':visible')) {\n      return false;\n    }\n    var _this = this;\n\n    // Motion UI method of hiding\n    if (this.options.animationOut) {\n      if (this.options.overlay) {\n        Motion.animateOut(this.$overlay, 'fade-out');\n      }\n\n      Motion.animateOut(this.$element, this.options.animationOut, finishUp);\n    }\n    // jQuery method of hiding\n    else {\n      this.$element.hide(this.options.hideDelay);\n\n      if (this.options.overlay) {\n        this.$overlay.hide(0, finishUp);\n      }\n      else {\n        finishUp();\n      }\n    }\n\n    // Conditionals to remove extra event listeners added on open\n    if (this.options.closeOnEsc) {\n      $(window).off('keydown.zf.reveal');\n    }\n\n    if (!this.options.overlay && this.options.closeOnClick) {\n      $('body').off('click.zf.reveal');\n    }\n\n    this.$element.off('keydown.zf.reveal');\n\n    function finishUp() {\n\n      // Get the current top before the modal is closed and restore the scroll after.\n      // TODO: use component properties instead of HTML properties\n      // See https://github.com/zurb/foundation-sites/pull/10786\n      var scrollTop = parseInt($(\"html\").css(\"top\"));\n\n      if ($('.reveal:visible').length  === 0) {\n        _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n      }\n\n      Keyboard.releaseFocus(_this.$element);\n\n      _this.$element.attr('aria-hidden', true);\n\n      _this._enableScroll(scrollTop);\n\n      /**\n      * Fires when the modal is done closing.\n      * @event Reveal#closed\n      */\n      _this.$element.trigger('closed.zf.reveal');\n    }\n\n    /**\n    * Resets the modal content\n    * This prevents a running video to keep going in the background\n    */\n    if (this.options.resetOnClose) {\n      this.$element.html(this.$element.html());\n    }\n\n    this.isActive = false;\n    // If deepLink and we did not switched to an other modal...\n    if (_this.options.deepLink && window.location.hash === `#${this.id}`) {\n      // Remove the history hash\n      if (window.history.replaceState) {\n        const urlWithoutHash = window.location.pathname + window.location.search;\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', urlWithoutHash); // remove the hash\n        } else {\n          window.history.replaceState('', document.title, urlWithoutHash);\n        }\n      } else {\n        window.location.hash = '';\n      }\n    }\n\n    this.$activeAnchor.focus();\n  }\n\n  /**\n   * Toggles the open/closed state of a modal.\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.close();\n    } else {\n      this.open();\n    }\n  };\n\n  /**\n   * Destroys an instance of a modal.\n   * @function\n   */\n  _destroy() {\n    if (this.options.overlay) {\n      this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()\n      this.$overlay.hide().off().remove();\n    }\n    this.$element.hide().off();\n    this.$anchor.off('.zf');\n    $(window).off(`.zf.reveal:${this.id}`)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n\n    if ($('.reveal:visible').length  === 0) {\n      this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n    }\n  };\n}\n\nReveal.defaults = {\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationIn: '',\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationOut: '',\n  /**\n   * Time, in ms, to delay the opening of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  showDelay: 0,\n  /**\n   * Time, in ms, to delay the closing of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hideDelay: 0,\n  /**\n   * Allows a click on the body/overlay to close the modal.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allows the modal to close if the user presses the `ESCAPE` key.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnEsc: true,\n  /**\n   * If true, allows multiple modals to be displayed at once.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multipleOpened: false,\n  /**\n   * Distance, in pixels, the modal should push down from the top of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  vOffset: 'auto',\n  /**\n   * Distance, in pixels, the modal should push in from the side of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  hOffset: 'auto',\n  /**\n   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  fullScreen: false,\n  /**\n   * Allows the modal to generate an overlay div, which will cover the view when modal opens.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  overlay: true,\n  /**\n   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  resetOnClose: false,\n  /**\n   * Link the location hash to the modal.\n   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open modal\n   * @option\n   * @default false\n   */\n  updateHistory: false,\n    /**\n   * Allows the modal to append to custom div.\n   * @option\n   * @type {string}\n   * @default \"body\"\n   */\n  appendTo: \"body\",\n  /**\n   * Allows adding additional class names to the reveal overlay.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  additionalOverlayClasses: ''\n};\n\nexport {Reveal};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Move } from './foundation.util.motion';\nimport { GetYoDigits, rtl as Rtl } from './foundation.core.utils';\n\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Touch } from './foundation.util.touch';\n\nimport { Triggers } from './foundation.util.triggers';\n/**\n * Slider module.\n * @module foundation.slider\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n */\n\nclass Slider extends Plugin {\n  /**\n   * Creates a new instance of a slider control.\n   * @class\n   * @name Slider\n   * @param {jQuery} element - jQuery object to make into a slider control.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Slider.defaults, this.$element.data(), options);\n    this.className = 'Slider'; // ie9 back compat\n\n  // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.\n    Touch.init($);\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Slider', {\n      'ltr': {\n        'ARROW_RIGHT': 'increase',\n        'ARROW_UP': 'increase',\n        'ARROW_DOWN': 'decrease',\n        'ARROW_LEFT': 'decrease',\n        'SHIFT_ARROW_RIGHT': 'increase_fast',\n        'SHIFT_ARROW_UP': 'increase_fast',\n        'SHIFT_ARROW_DOWN': 'decrease_fast',\n        'SHIFT_ARROW_LEFT': 'decrease_fast',\n        'HOME': 'min',\n        'END': 'max'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'increase',\n        'ARROW_RIGHT': 'decrease',\n        'SHIFT_ARROW_LEFT': 'increase_fast',\n        'SHIFT_ARROW_RIGHT': 'decrease_fast'\n      }\n    });\n  }\n\n  /**\n   * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).\n   * @function\n   * @private\n   */\n  _init() {\n    this.inputs = this.$element.find('input');\n    this.handles = this.$element.find('[data-slider-handle]');\n\n    this.$handle = this.handles.eq(0);\n    this.$input = this.inputs.length ? this.inputs.eq(0) : $(`#${this.$handle.attr('aria-controls')}`);\n    this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);\n\n    var isDbl = false,\n        _this = this;\n    if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {\n      this.options.disabled = true;\n      this.$element.addClass(this.options.disabledClass);\n    }\n    if (!this.inputs.length) {\n      this.inputs = $().add(this.$input);\n      this.options.binding = true;\n    }\n\n    this._setInitAttr(0);\n\n    if (this.handles[1]) {\n      this.options.doubleSided = true;\n      this.$handle2 = this.handles.eq(1);\n      this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $(`#${this.$handle2.attr('aria-controls')}`);\n\n      if (!this.inputs[1]) {\n        this.inputs = this.inputs.add(this.$input2);\n      }\n      isDbl = true;\n\n      // this.$handle.triggerHandler('click.zf.slider');\n      this._setInitAttr(1);\n    }\n\n    // Set handle positions\n    this.setHandles();\n\n    this._events();\n  }\n\n  setHandles() {\n    if(this.handles[1]) {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, () => {\n        this._setHandlePos(this.$handle2, this.inputs.eq(1).val(), true);\n      });\n    } else {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);\n    }\n  }\n\n  _reflow() {\n    this.setHandles();\n  }\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)\n  */\n  _pctOfBar(value) {\n    var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start)\n\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    }\n\n    return pctOfBar.toFixed(2)\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value\n  */\n  _value(pctOfBar) {\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    }\n    var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);\n\n    return value\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function\n  */\n  _logTransform(value) {\n    return baseLog(this.options.nonLinearBase, ((value*(this.options.nonLinearBase-1))+1))\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function\n  */\n  _powTransform(value) {\n    return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1)\n  }\n\n  /**\n   * Sets the position of the selected handle and fill bar.\n   * @function\n   * @private\n   * @param {jQuery} $hndl - the selected handle to move.\n   * @param {Number} location - floating point between the start and end values of the slider bar.\n   * @param {Function} cb - callback function to fire on completion.\n   * @fires Slider#moved\n   * @fires Slider#changed\n   */\n  _setHandlePos($hndl, location, noInvert, cb) {\n    // don't move if the slider has been disabled since its initialization\n    if (this.$element.hasClass(this.options.disabledClass)) {\n      return;\n    }\n    //might need to alter that slightly for bars that will have odd number selections.\n    location = parseFloat(location);//on input change events, convert string to number...grumble.\n\n    // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max\n    if (location < this.options.start) { location = this.options.start; }\n    else if (location > this.options.end) { location = this.options.end; }\n\n    var isDbl = this.options.doubleSided;\n\n    //this is for single-handled vertical sliders, it adjusts the value to account for the slider being \"upside-down\"\n    //for click and drag events, it's weird due to the scale(-1, 1) css property\n    if (this.options.vertical && !noInvert) {\n      location = this.options.end - location;\n    }\n\n    if (isDbl) { //this block is to prevent 2 handles from crossing eachother. Could/should be improved.\n      if (this.handles.index($hndl) === 0) {\n        var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));\n        location = location >= h2Val ? h2Val - this.options.step : location;\n      } else {\n        var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));\n        location = location <= h1Val ? h1Val + this.options.step : location;\n      }\n    }\n\n    var _this = this,\n        vert = this.options.vertical,\n        hOrW = vert ? 'height' : 'width',\n        lOrT = vert ? 'top' : 'left',\n        handleDim = $hndl[0].getBoundingClientRect()[hOrW],\n        elemDim = this.$element[0].getBoundingClientRect()[hOrW],\n        //percentage of bar min/max value based on click or drag point\n        pctOfBar = this._pctOfBar(location),\n        //number of actual pixels to shift the handle, based on the percentage obtained above\n        pxToMove = (elemDim - handleDim) * pctOfBar,\n        //percentage of bar to shift the handle\n        movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);\n        //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value\n        location = parseFloat(location.toFixed(this.options.decimal));\n        // declare empty object for css adjustments, only used with 2 handled-sliders\n    var css = {};\n\n    this._setValues($hndl, location);\n\n    // TODO update to calculate based on values set to respective inputs??\n    if (isDbl) {\n      var isLeftHndl = this.handles.index($hndl) === 0,\n          //empty variable, will be used for min-height/width for fill bar\n          dim,\n          //percentage w/h of the handle compared to the slider bar\n          handlePct =  ~~(percent(handleDim, elemDim) * 100);\n      //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar\n      if (isLeftHndl) {\n        //left or top percentage value to apply to the fill bar.\n        css[lOrT] = `${movement}%`;\n        //calculate the new min-height/width for the fill bar.\n        dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;\n        //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider\n        //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.\n        if (cb && typeof cb === 'function') { cb(); }//this is only needed for the initialization of 2 handled sliders\n      } else {\n        //just caching the value of the left/bottom handle's left/top property\n        var handlePos = parseFloat(this.$handle[0].style[lOrT]);\n        //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0\n        //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself\n        dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start)/((this.options.end-this.options.start)/100) : handlePos) + handlePct;\n      }\n      // assign the min-height/width to our css object\n      css[`min-${hOrW}`] = `${dim}%`;\n    }\n\n    this.$element.one('finished.zf.animate', function() {\n                    /**\n                     * Fires when the handle is done moving.\n                     * @event Slider#moved\n                     */\n                    _this.$element.trigger('moved.zf.slider', [$hndl]);\n                });\n\n    //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.\n    var moveTime = this.$element.data('dragging') ? 1000/60 : this.options.moveTime;\n\n    Move(moveTime, $hndl, function() {\n      // adjusting the left/top property of the handle, based on the percentage calculated above\n      // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,\n      // fall back to next best guess.\n      if (isNaN(movement)) {\n        $hndl.css(lOrT, `${pctOfBar * 100}%`);\n      }\n      else {\n        $hndl.css(lOrT, `${movement}%`);\n      }\n\n      if (!_this.options.doubleSided) {\n        //if single-handled, a simple method to expand the fill bar\n        _this.$fill.css(hOrW, `${pctOfBar * 100}%`);\n      } else {\n        //otherwise, use the css object we created above\n        _this.$fill.css(css);\n      }\n    });\n\n\n    /**\n     * Fires when the value has not been change for a given time.\n     * @event Slider#changed\n     */\n    clearTimeout(_this.timeout);\n    _this.timeout = setTimeout(function(){\n      _this.$element.trigger('changed.zf.slider', [$hndl]);\n    }, _this.options.changedDelay);\n  }\n\n  /**\n   * Sets the initial attribute for the slider element.\n   * @function\n   * @private\n   * @param {Number} idx - index of the current handle/input to use.\n   */\n  _setInitAttr(idx) {\n    var initVal = (idx === 0 ? this.options.initialStart : this.options.initialEnd)\n    var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');\n    this.inputs.eq(idx).attr({\n      'id': id,\n      'max': this.options.end,\n      'min': this.options.start,\n      'step': this.options.step\n    });\n    this.inputs.eq(idx).val(initVal);\n    this.handles.eq(idx).attr({\n      'role': 'slider',\n      'aria-controls': id,\n      'aria-valuemax': this.options.end,\n      'aria-valuemin': this.options.start,\n      'aria-valuenow': initVal,\n      'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',\n      'tabindex': 0\n    });\n  }\n\n  /**\n   * Sets the input and `aria-valuenow` values for the slider element.\n   * @function\n   * @private\n   * @param {jQuery} $handle - the currently selected handle.\n   * @param {Number} val - floating point of the new value.\n   */\n  _setValues($handle, val) {\n    var idx = this.options.doubleSided ? this.handles.index($handle) : 0;\n    this.inputs.eq(idx).val(val);\n    $handle.attr('aria-valuenow', val);\n  }\n\n  /**\n   * Handles events on the slider element.\n   * Calculates the new location of the current handle.\n   * If there are two handles and the bar was clicked, it determines which handle to move.\n   * @function\n   * @private\n   * @param {Object} e - the `event` object passed from the listener.\n   * @param {jQuery} $handle - the current handle to calculate for, if selected.\n   * @param {Number} val - floating point number for the new value of the slider.\n   * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.\n   */\n  _handleEvent(e, $handle, val) {\n    var value, hasVal;\n    if (!val) {//click or drag events\n      e.preventDefault();\n      var _this = this,\n          vertical = this.options.vertical,\n          param = vertical ? 'height' : 'width',\n          direction = vertical ? 'top' : 'left',\n          eventOffset = vertical ? e.pageY : e.pageX,\n          halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,\n          barDim = this.$element[0].getBoundingClientRect()[param],\n          windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();\n\n\n      var elemOffset = this.$element.offset()[direction];\n\n      // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...\n      // best way to guess this is simulated is if clientY == pageY\n      if (e.clientY === e.pageY) { eventOffset = eventOffset + windowScroll; }\n      var eventFromBar = eventOffset - elemOffset;\n      var barXY;\n      if (eventFromBar < 0) {\n        barXY = 0;\n      } else if (eventFromBar > barDim) {\n        barXY = barDim;\n      } else {\n        barXY = eventFromBar;\n      }\n      var offsetPct = percent(barXY, barDim);\n\n      value = this._value(offsetPct);\n\n      // turn everything around for RTL, yay math!\n      if (Rtl() && !this.options.vertical) {value = this.options.end - value;}\n\n      value = _this._adjustValue(null, value);\n      //boolean flag for the setHandlePos fn, specifically for vertical sliders\n      hasVal = false;\n\n      if (!$handle) {//figure out which handle it is, pass it to the next function.\n        var firstHndlPos = absPosition(this.$handle, direction, barXY, param),\n            secndHndlPos = absPosition(this.$handle2, direction, barXY, param);\n            $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;\n      }\n\n    } else {//change event on input\n      value = this._adjustValue(null, val);\n      hasVal = true;\n    }\n\n    this._setHandlePos($handle, value, hasVal);\n  }\n\n  /**\n   * Adjustes value for handle in regard to step value. returns adjusted value\n   * @function\n   * @private\n   * @param {jQuery} $handle - the selected handle.\n   * @param {Number} value - value to adjust. used if $handle is falsy\n   */\n  _adjustValue($handle, value) {\n    var val,\n      step = this.options.step,\n      div = parseFloat(step/2),\n      left, prev_val, next_val;\n    if (!!$handle) {\n      val = parseFloat($handle.attr('aria-valuenow'));\n    }\n    else {\n      val = value;\n    }\n    if (val >= 0) {\n      left = val % step;\n    } else {\n      left = step + (val % step);\n    }\n    prev_val = val - left;\n    next_val = prev_val + step;\n    if (left === 0) {\n      return val;\n    }\n    val = val >= prev_val + div ? next_val : prev_val;\n    return val;\n  }\n\n  /**\n   * Adds event listeners to the slider elements.\n   * @function\n   * @private\n   */\n  _events() {\n    this._eventsForHandle(this.$handle);\n    if(this.handles[1]) {\n      this._eventsForHandle(this.$handle2);\n    }\n  }\n\n\n  /**\n   * Adds event listeners a particular handle\n   * @function\n   * @private\n   * @param {jQuery} $handle - the current handle to apply listeners to.\n   */\n  _eventsForHandle($handle) {\n    var _this = this,\n        curHandle,\n        timer;\n\n      const handleChangeEvent = function(e) {\n        const idx = _this.inputs.index($(this));\n        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());\n      };\n\n      // IE only triggers the change event when the input loses focus which strictly follows the HTML specification\n      // listen for the enter key and trigger a change\n      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events\n      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {\n        if(e.keyCode == 13) handleChangeEvent.call(this, e);\n      });\n\n      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);\n\n      if (this.options.clickSelect) {\n        this.$element.off('click.zf.slider').on('click.zf.slider', function(e) {\n          if (_this.$element.data('dragging')) { return false; }\n\n          if (!$(e.target).is('[data-slider-handle]')) {\n            if (_this.options.doubleSided) {\n              _this._handleEvent(e);\n            } else {\n              _this._handleEvent(e, _this.$handle);\n            }\n          }\n        });\n      }\n\n    if (this.options.draggable) {\n      this.handles.addTouch();\n\n      var $body = $('body');\n      $handle\n        .off('mousedown.zf.slider')\n        .on('mousedown.zf.slider', function(e) {\n          $handle.addClass('is-dragging');\n          _this.$fill.addClass('is-dragging');//\n          _this.$element.data('dragging', true);\n\n          curHandle = $(e.currentTarget);\n\n          $body.on('mousemove.zf.slider', function(e) {\n            e.preventDefault();\n            _this._handleEvent(e, curHandle);\n\n          }).on('mouseup.zf.slider', function(e) {\n            _this._handleEvent(e, curHandle);\n\n            $handle.removeClass('is-dragging');\n            _this.$fill.removeClass('is-dragging');\n            _this.$element.data('dragging', false);\n\n            $body.off('mousemove.zf.slider mouseup.zf.slider');\n          });\n      })\n      // prevent events triggered by touch\n      .on('selectstart.zf.slider touchmove.zf.slider', function(e) {\n        e.preventDefault();\n      });\n    }\n\n    $handle.off('keydown.zf.slider').on('keydown.zf.slider', function(e) {\n      var _$handle = $(this),\n          idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,\n          oldValue = parseFloat(_this.inputs.eq(idx).val()),\n          newValue;\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Slider', {\n        decrease: function() {\n          newValue = oldValue - _this.options.step;\n        },\n        increase: function() {\n          newValue = oldValue + _this.options.step;\n        },\n        decrease_fast: function() {\n          newValue = oldValue - _this.options.step * 10;\n        },\n        increase_fast: function() {\n          newValue = oldValue + _this.options.step * 10;\n        },\n        min: function() {\n          newValue = _this.options.start;\n        },\n        max: function() {\n          newValue = _this.options.end;\n        },\n        handled: function() { // only set handle pos when event was handled specially\n          e.preventDefault();\n          _this._setHandlePos(_$handle, newValue, true);\n        }\n      });\n      /*if (newValue) { // if pressed key has special function, update value\n        e.preventDefault();\n        _this._setHandlePos(_$handle, newValue);\n      }*/\n    });\n  }\n\n  /**\n   * Destroys the slider plugin.\n   */\n  _destroy() {\n    this.handles.off('.zf.slider');\n    this.inputs.off('.zf.slider');\n    this.$element.off('.zf.slider');\n\n    clearTimeout(this.timeout);\n  }\n}\n\nSlider.defaults = {\n  /**\n   * Minimum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  start: 0,\n  /**\n   * Maximum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  end: 100,\n  /**\n   * Minimum value change per change event.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  step: 1,\n  /**\n   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  initialStart: 0,\n  /**\n   * Value at which the right handle/second input should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  initialEnd: 100,\n  /**\n   * Allows the input to be located outside the container and visible. Set to by the JS\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  binding: false,\n  /**\n   * Allows the user to click/tap on the slider bar to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickSelect: true,\n  /**\n   * Set to true and use the `vertical` class to change alignment to vertical.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  vertical: false,\n  /**\n   * Allows the user to drag the slider handle(s) to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  draggable: true,\n  /**\n   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disabled: false,\n  /**\n   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  doubleSided: false,\n  /**\n   * Potential future feature.\n   */\n  // steps: 100,\n  /**\n   * Number of decimal places the plugin should go to for floating point precision.\n   * @option\n   * @type {number}\n   * @default 2\n   */\n  decimal: 2,\n  /**\n   * Time delay for dragged elements.\n   */\n  // dragDelay: 0,\n  /**\n   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  moveTime: 200,//update this if changing the transition time in the sass\n  /**\n   * Class applied to disabled sliders.\n   * @option\n   * @type {string}\n   * @default 'disabled'\n   */\n  disabledClass: 'disabled',\n  /**\n   * Will invert the default layout for a vertical<span data-tooltip title=\"who would do this???\"> </span>slider.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  invertVertical: false,\n  /**\n   * Milliseconds before the `changed.zf-slider` event is triggered after value change.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  changedDelay: 500,\n  /**\n  * Basevalue for non-linear sliders\n  * @option\n  * @type {number}\n  * @default 5\n  */\n  nonLinearBase: 5,\n  /**\n  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.\n  * @option\n  * @type {string}\n  * @default 'linear'\n  */\n  positionValueFunction: 'linear',\n};\n\nfunction percent(frac, num) {\n  return (frac / num);\n}\nfunction absPosition($handle, dir, clickPos, param) {\n  return Math.abs(($handle.position()[dir] + ($handle[param]() / 2)) - clickPos);\n}\nfunction baseLog(base, value) {\n  return Math.log(value)/Math.log(base)\n}\n\nexport {Slider};\n","import $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * SmoothScroll module.\n * @module foundation.smooth-scroll\n */\nclass SmoothScroll extends Plugin {\n  /**\n   * Creates a new instance of SmoothScroll.\n   * @class\n   * @name SmoothScroll\n   * @fires SmoothScroll#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n    _setup(element, options) {\n        this.$element = element;\n        this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);\n        this.className = 'SmoothScroll'; // ie9 back compat\n\n        this._init();\n    }\n\n    /**\n     * Initialize the SmoothScroll plugin\n     * @private\n     */\n    _init() {\n        const id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');\n        this.$element.attr({ id });\n\n        this._events();\n    }\n\n    /**\n     * Initializes events for SmoothScroll.\n     * @private\n     */\n    _events() {\n        this._linkClickListener = this._handleLinkClick.bind(this);\n        this.$element.on('click.zf.smoothScroll', this._linkClickListener);\n        this.$element.on('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n\n    /**\n     * Handle the given event to smoothly scroll to the anchor pointed by the event target.\n     * @param {*} e - event\n     * @function\n     * @private\n     */\n    _handleLinkClick(e) {\n        // Follow the link if it does not point to an anchor.\n        if (!$(e.currentTarget).is('a[href^=\"#\"]')) return;\n\n        const arrival = e.currentTarget.getAttribute('href');\n\n        this._inTransition = true;\n\n        SmoothScroll.scrollToLoc(arrival, this.options, () => {\n            this._inTransition = false;\n        });\n\n        e.preventDefault();\n    };\n\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'\n     * @param {Object} options - The options to use.\n     * @param {Function} callback - The callback function.\n     * @static\n     * @function\n     */\n    static scrollToLoc(loc, options = SmoothScroll.defaults, callback) {\n        const $loc = $(loc);\n\n        // Do nothing if target does not exist to prevent errors\n        if (!$loc.length) return false;\n\n        var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);\n\n        $('html, body').stop(true).animate(\n            { scrollTop: scrollPos },\n            options.animationDuration,\n            options.animationEasing,\n            () => {\n                if (typeof callback === 'function'){\n                    callback();\n                }\n            }\n        );\n    }\n\n    /**\n     * Destroys the SmoothScroll instance.\n     * @function\n     */\n    _destroy() {\n        this.$element.off('click.zf.smoothScroll', this._linkClickListener)\n        this.$element.off('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n}\n\n/**\n * Default settings for plugin.\n */\nSmoothScroll.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {SmoothScroll}\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass Sticky extends Plugin {\n  /**\n   * Creates a new instance of a sticky thing.\n   * @class\n   * @name Sticky\n   * @param {jQuery} element - jQuery object to make sticky.\n   * @param {Object} options - options object passed when creating the element programmatically.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);\n    this.className = 'Sticky'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var $parent = this.$element.parent('[data-sticky-container]'),\n        id = this.$element[0].id || GetYoDigits(6, 'sticky'),\n        _this = this;\n\n    if($parent.length){\n      this.$container = $parent;\n    } else {\n      this.wasWrapped = true;\n      this.$element.wrap(this.options.container);\n      this.$container = this.$element.parent();\n    }\n    this.$container.addClass(this.options.containerClass);\n\n    this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });\n    if (this.options.anchor !== '') {\n        $('#' + _this.options.anchor).attr({ 'data-mutate': id });\n    }\n\n    this.scrollCount = this.options.checkEvery;\n    this.isStuck = false;\n    this.onLoadListener = onLoad($(window), function () {\n      //We calculate the container height to have correct values for anchor points offset calculation.\n      _this.containerHeight = _this.$element.css(\"display\") == \"none\" ? 0 : _this.$element[0].getBoundingClientRect().height;\n      _this.$container.css('height', _this.containerHeight);\n      _this.elemHeight = _this.containerHeight;\n      if (_this.options.anchor !== '') {\n        _this.$anchor = $('#' + _this.options.anchor);\n      } else {\n        _this._parsePoints();\n      }\n\n      _this._setSizes(function () {\n        var scroll = window.pageYOffset;\n        _this._calc(false, scroll);\n        //Unstick the element will ensure that proper classes are set.\n        if (!_this.isStuck) {\n          _this._removeSticky((scroll >= _this.topPoint) ? false : true);\n        }\n      });\n      _this._events(id.split('-').reverse().join('-'));\n    });\n  }\n\n  /**\n   * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.\n   * @function\n   * @private\n   */\n  _parsePoints() {\n    var top = this.options.topAnchor == \"\" ? 1 : this.options.topAnchor,\n        btm = this.options.btmAnchor== \"\" ? document.documentElement.scrollHeight : this.options.btmAnchor,\n        pts = [top, btm],\n        breaks = {};\n    for (var i = 0, len = pts.length; i < len && pts[i]; i++) {\n      var pt;\n      if (typeof pts[i] === 'number') {\n        pt = pts[i];\n      } else {\n        var place = pts[i].split(':'),\n            anchor = $(`#${place[0]}`);\n\n        pt = anchor.offset().top;\n        if (place[1] && place[1].toLowerCase() === 'bottom') {\n          pt += anchor[0].getBoundingClientRect().height;\n        }\n      }\n      breaks[i] = pt;\n    }\n\n\n    this.points = breaks;\n    return;\n  }\n\n  /**\n   * Adds event handlers for the scrolling element.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _events(id) {\n    var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n    if (this.isOn) { return; }\n    if (this.canStick) {\n      this.isOn = true;\n      $(window).off(scrollListener)\n               .on(scrollListener, function(e) {\n                 if (_this.scrollCount === 0) {\n                   _this.scrollCount = _this.options.checkEvery;\n                   _this._setSizes(function() {\n                     _this._calc(false, window.pageYOffset);\n                   });\n                 } else {\n                   _this.scrollCount--;\n                   _this._calc(false, window.pageYOffset);\n                 }\n              });\n    }\n\n    this.$element.off('resizeme.zf.trigger')\n                 .on('resizeme.zf.trigger', function(e, el) {\n                    _this._eventsHandler(id);\n    });\n\n    this.$element.on('mutateme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n    });\n\n    if(this.$anchor) {\n      this.$anchor.on('mutateme.zf.trigger', function (e, el) {\n          _this._eventsHandler(id);\n      });\n    }\n  }\n\n  /**\n   * Handler for events.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _eventsHandler(id) {\n       var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n\n       _this._setSizes(function() {\n       _this._calc(false);\n       if (_this.canStick) {\n         if (!_this.isOn) {\n           _this._events(id);\n         }\n       } else if (_this.isOn) {\n         _this._pauseListeners(scrollListener);\n       }\n     });\n  }\n\n  /**\n   * Removes event handlers for scroll and change events on anchor.\n   * @fires Sticky#pause\n   * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`\n   */\n  _pauseListeners(scrollListener) {\n    this.isOn = false;\n    $(window).off(scrollListener);\n\n    /**\n     * Fires when the plugin is paused due to resize event shrinking the view.\n     * @event Sticky#pause\n     * @private\n     */\n     this.$element.trigger('pause.zf.sticky');\n  }\n\n  /**\n   * Called on every `scroll` event and on `_init`\n   * fires functions based on booleans and cached values\n   * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.\n   * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.\n   */\n  _calc(checkSizes, scroll) {\n    if (checkSizes) { this._setSizes(); }\n\n    if (!this.canStick) {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n      return false;\n    }\n\n    if (!scroll) { scroll = window.pageYOffset; }\n\n    if (scroll >= this.topPoint) {\n      if (scroll <= this.bottomPoint) {\n        if (!this.isStuck) {\n          this._setSticky();\n        }\n      } else {\n        if (this.isStuck) {\n          this._removeSticky(false);\n        }\n      }\n    } else {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n    }\n  }\n\n  /**\n   * Causes the $element to become stuck.\n   * Adds `position: fixed;`, and helper classes.\n   * @fires Sticky#stuckto\n   * @function\n   * @private\n   */\n  _setSticky() {\n    var _this = this,\n        stickTo = this.options.stickTo,\n        mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickTo === 'top' ? 'bottom' : 'top',\n        css = {};\n\n    css[mrgn] = `${this.options[mrgn]}em`;\n    css[stickTo] = 0;\n    css[notStuckTo] = 'auto';\n    this.isStuck = true;\n    this.$element.removeClass(`is-anchored is-at-${notStuckTo}`)\n                 .addClass(`is-stuck is-at-${stickTo}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become `position: fixed;`\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`\n                  * @event Sticky#stuckto\n                  */\n                 .trigger(`sticky.zf.stuckto:${stickTo}`);\n    this.$element.on(\"transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd\", function() {\n      _this._setSizes();\n    });\n  }\n\n  /**\n   * Causes the $element to become unstuck.\n   * Removes `position: fixed;`, and helper classes.\n   * Adds other helper classes.\n   * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.\n   * @fires Sticky#unstuckfrom\n   * @private\n   */\n  _removeSticky(isTop) {\n    var stickTo = this.options.stickTo,\n        stickToTop = stickTo === 'top',\n        css = {},\n        anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,\n        mrgn = stickToTop ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickToTop ? 'bottom' : 'top',\n        topOrBottom = isTop ? 'top' : 'bottom';\n\n    css[mrgn] = 0;\n\n    css['bottom'] = 'auto';\n    if(isTop) {\n      css['top'] = 0;\n    } else {\n      css['top'] = anchorPt;\n    }\n\n    this.isStuck = false;\n    this.$element.removeClass(`is-stuck is-at-${stickTo}`)\n                 .addClass(`is-anchored is-at-${topOrBottom}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become anchored.\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`\n                  * @event Sticky#unstuckfrom\n                  */\n                 .trigger(`sticky.zf.unstuckfrom:${topOrBottom}`);\n  }\n\n  /**\n   * Sets the $element and $container sizes for plugin.\n   * Calls `_setBreakPoints`.\n   * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.\n   * @private\n   */\n  _setSizes(cb) {\n    this.canStick = MediaQuery.is(this.options.stickyOn);\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n    }\n    var _this = this,\n        newElemWidth = this.$container[0].getBoundingClientRect().width,\n        comp = window.getComputedStyle(this.$container[0]),\n        pdngl = parseInt(comp['padding-left'], 10),\n        pdngr = parseInt(comp['padding-right'], 10);\n\n    if (this.$anchor && this.$anchor.length) {\n      this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;\n    } else {\n      this._parsePoints();\n    }\n\n    this.$element.css({\n      'max-width': `${newElemWidth - pdngl - pdngr}px`\n    });\n\n    var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;\n    if (this.$element.css(\"display\") == \"none\") {\n      newContainerHeight = 0;\n    }\n    this.containerHeight = newContainerHeight;\n    this.$container.css({\n      height: newContainerHeight\n    });\n    this.elemHeight = newContainerHeight;\n\n    if (!this.isStuck) {\n      if (this.$element.hasClass('is-at-bottom')) {\n        var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;\n        this.$element.css('top', anchorPt);\n      }\n    }\n\n    this._setBreakPoints(newContainerHeight, function() {\n      if (cb && typeof cb === 'function') { cb(); }\n    });\n  }\n\n  /**\n   * Sets the upper and lower breakpoints for the element to become sticky/unsticky.\n   * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.\n   * @param {Function} cb - optional callback function to be called on completion.\n   * @private\n   */\n  _setBreakPoints(elemHeight, cb) {\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n      else { return false; }\n    }\n    var mTop = emCalc(this.options.marginTop),\n        mBtm = emCalc(this.options.marginBottom),\n        topPoint = this.points ? this.points[0] : this.$anchor.offset().top,\n        bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,\n        // topPoint = this.$anchor.offset().top || this.points[0],\n        // bottomPoint = topPoint + this.anchorHeight || this.points[1],\n        winHeight = window.innerHeight;\n\n    if (this.options.stickTo === 'top') {\n      topPoint -= mTop;\n      bottomPoint -= (elemHeight + mTop);\n    } else if (this.options.stickTo === 'bottom') {\n      topPoint -= (winHeight - (elemHeight + mBtm));\n      bottomPoint -= (winHeight - mBtm);\n    } else {\n      //this would be the stickTo: both option... tricky\n    }\n\n    this.topPoint = topPoint;\n    this.bottomPoint = bottomPoint;\n\n    if (cb && typeof cb === 'function') { cb(); }\n  }\n\n  /**\n   * Destroys the current sticky element.\n   * Resets the element to the top position first.\n   * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.\n   * @function\n   */\n  _destroy() {\n    this._removeSticky(true);\n\n    this.$element.removeClass(`${this.options.stickyClass} is-anchored is-at-top`)\n                 .css({\n                   height: '',\n                   top: '',\n                   bottom: '',\n                   'max-width': ''\n                 })\n                 .off('resizeme.zf.trigger')\n                 .off('mutateme.zf.trigger');\n    if (this.$anchor && this.$anchor.length) {\n      this.$anchor.off('change.zf.sticky');\n    }\n    if (this.scrollListener) $(window).off(this.scrollListener)\n    if (this.onLoadListener) $(window).off(this.onLoadListener)\n\n    if (this.wasWrapped) {\n      this.$element.unwrap();\n    } else {\n      this.$container.removeClass(this.options.containerClass)\n                     .css({\n                       height: ''\n                     });\n    }\n  }\n}\n\nSticky.defaults = {\n  /**\n   * Customizable container template. Add your own classes for styling and sizing.\n   * @option\n   * @type {string}\n   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'\n   */\n  container: '<div data-sticky-container></div>',\n  /**\n   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default 'top'\n   */\n  stickTo: 'top',\n  /**\n   * If anchored to a single element, the id of that element.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  anchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the top anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  topAnchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the bottom anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  btmAnchor: '',\n  /**\n   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginTop: 1,\n  /**\n   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginBottom: 1,\n  /**\n   * Breakpoint string that is the minimum screen size an element should become sticky.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  stickyOn: 'medium',\n  /**\n   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.\n   * @option\n   * @type {string}\n   * @default 'sticky'\n   */\n  stickyClass: 'sticky',\n  /**\n   * Class applied to sticky container. Foundation defaults to `sticky-container`.\n   * @option\n   * @type {string}\n   * @default 'sticky-container'\n   */\n  containerClass: 'sticky-container',\n  /**\n   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.\n   * @option\n   * @type {number}\n   * @default -1\n   */\n  checkEvery: -1\n};\n\n/**\n * Helper function to calculate em values\n * @param Number {em} - number of em's to calculate into pixels\n */\nfunction emCalc(em) {\n  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;\n}\n\nexport {Sticky};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { Plugin } from './foundation.core.plugin';\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.imageLoader if tabs contain images\n */\n\nclass Tabs extends Plugin {\n  /**\n   * Creates a new instance of tabs.\n   * @class\n   * @name Tabs\n   * @fires Tabs#init\n   * @param {jQuery} element - jQuery object to make into tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);\n    this.className = 'Tabs'; // ie9 back compat\n\n    this._init();\n    Keyboard.register('Tabs', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'previous',\n      'ARROW_DOWN': 'next',\n      'ARROW_LEFT': 'previous'\n      // 'TAB': 'next',\n      // 'SHIFT_TAB': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.\n   * @private\n   */\n  _init() {\n    var _this = this;\n    this._isInitializing = true;\n\n    this.$element.attr({'role': 'tablist'});\n    this.$tabTitles = this.$element.find(`.${this.options.linkClass}`);\n    this.$tabContent = $(`[data-tabs-content=\"${this.$element[0].id}\"]`);\n\n    this.$tabTitles.each(function(){\n      var $elem = $(this),\n          $link = $elem.find('a'),\n          isActive = $elem.hasClass(`${_this.options.linkActiveClass}`),\n          hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),\n          linkId = $link[0].id ? $link[0].id : `${hash}-label`,\n          $tabContent = $(`#${hash}`);\n\n      $elem.attr({'role': 'presentation'});\n\n      $link.attr({\n        'role': 'tab',\n        'aria-controls': hash,\n        'aria-selected': isActive,\n        'id': linkId,\n        'tabindex': isActive ? '0' : '-1'\n      });\n\n      $tabContent.attr({\n        'role': 'tabpanel',\n        'aria-labelledby': linkId\n      });\n\n      // Save up the initial hash to return to it later when going back in history\n      if (isActive) {\n        _this._initialAnchor = `#${hash}`;\n      }\n\n      if(!isActive) {\n        $tabContent.attr('aria-hidden', 'true');\n      }\n\n      if(isActive && _this.options.autoFocus){\n        _this.onLoadListener = onLoad($(window), function() {\n          $('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, () => {\n            $link.focus();\n          });\n        });\n      }\n    });\n\n    if(this.options.matchHeight) {\n      var $images = this.$tabContent.find('img');\n\n      if ($images.length) {\n        onImagesLoaded($images, this._setHeight.bind(this));\n      } else {\n        this._setHeight();\n      }\n    }\n\n     // Current context-bound function to open tabs on page load or history hashchange\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find('[href$=\"'+anchor+'\"]');\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, select it\n      if ($anchor && $anchor.length && $link && $link.length) {\n        this.selectTab($anchor, true);\n      }\n      // Otherwise, collapse everything\n      else {\n        this._collapse();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          var offset = this.$element.offset();\n          $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Tabs#deeplink\n         */\n        this.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the tabs.\n   * @private\n   */\n  _events() {\n    this._addKeyHandler();\n    this._addClickHandler();\n    this._setHeightMqHandler = null;\n\n    if (this.options.matchHeight) {\n      this._setHeightMqHandler = this._setHeight.bind(this);\n\n      $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);\n    }\n\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Adds click handlers for items within the tabs.\n   * @private\n   */\n  _addClickHandler() {\n    var _this = this;\n\n    this.$element\n      .off('click.zf.tabs')\n      .on('click.zf.tabs', `.${this.options.linkClass}`, function(e){\n        e.preventDefault();\n        e.stopPropagation();\n        _this._handleTabChange($(this));\n      });\n  }\n\n  /**\n   * Adds keyboard event handlers for items within the tabs.\n   * @private\n   */\n  _addKeyHandler() {\n    var _this = this;\n\n    this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function(e){\n      if (e.which === 9) return;\n\n\n      var $element = $(this),\n        $elements = $element.parent('ul').children('li'),\n        $prevElement,\n        $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          if (_this.options.wrapOnKeys) {\n            $prevElement = i === 0 ? $elements.last() : $elements.eq(i-1);\n            $nextElement = i === $elements.length -1 ? $elements.first() : $elements.eq(i+1);\n          } else {\n            $prevElement = $elements.eq(Math.max(0, i-1));\n            $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          }\n          return;\n        }\n      });\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Tabs', {\n        open: function() {\n          $element.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($element);\n        },\n        previous: function() {\n          $prevElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($prevElement);\n        },\n        next: function() {\n          $nextElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($nextElement);\n        },\n        handled: function() {\n          e.stopPropagation();\n          e.preventDefault();\n        }\n      });\n    });\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.\n   * @param {jQuery} $target - Tab to open.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @fires Tabs#change\n   * @function\n   */\n  _handleTabChange($target, historyHandled) {\n\n    // With `activeCollapse`, if the target is the active Tab, collapse it.\n    if ($target.hasClass(`${this.options.linkActiveClass}`)) {\n        if(this.options.activeCollapse) {\n            this._collapse();\n        }\n        return;\n    }\n\n    var $oldTab = this.$element.\n          find(`.${this.options.linkClass}.${this.options.linkActiveClass}`),\n          $tabLink = $target.find('[role=\"tab\"]'),\n          target = $tabLink.attr('data-tabs-target'),\n          anchor = target && target.length ? `#${target}` : $tabLink[0].hash,\n          $targetContent = this.$tabContent.find(anchor);\n\n    //close old tab\n    this._collapseTab($oldTab);\n\n    //open new tab\n    this._openTab($target);\n\n    //either replace or update browser history\n    if (this.options.deepLink && !historyHandled) {\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n\n    /**\n     * Fires when the plugin has successfully changed tabs.\n     * @event Tabs#change\n     */\n    this.$element.trigger('change.zf.tabs', [$target, $targetContent]);\n\n    //fire to children a mutation event\n    $targetContent.find(\"[data-mutate]\").trigger(\"mutateme.zf.trigger\");\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to open.\n   * @function\n   */\n  _openTab($target) {\n      var $tabLink = $target.find('[role=\"tab\"]'),\n          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),\n          $targetContent = this.$tabContent.find(`#${hash}`);\n\n      $target.addClass(`${this.options.linkActiveClass}`);\n\n      $tabLink.attr({\n        'aria-selected': 'true',\n        'tabindex': '0'\n      });\n\n      $targetContent\n        .addClass(`${this.options.panelActiveClass}`).removeAttr('aria-hidden');\n  }\n\n  /**\n   * Collapses `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to collapse.\n   * @function\n   */\n  _collapseTab($target) {\n    var $target_anchor = $target\n      .removeClass(`${this.options.linkActiveClass}`)\n      .find('[role=\"tab\"]')\n      .attr({\n        'aria-selected': 'false',\n        'tabindex': -1\n      });\n\n    $(`#${$target_anchor.attr('aria-controls')}`)\n      .removeClass(`${this.options.panelActiveClass}`)\n      .attr({ 'aria-hidden': 'true' })\n  }\n\n  /**\n   * Collapses the active Tab.\n   * @fires Tabs#collapse\n   * @function\n   */\n  _collapse() {\n    var $activeTab = this.$element.find(`.${this.options.linkClass}.${this.options.linkActiveClass}`);\n\n    if ($activeTab.length) {\n      this._collapseTab($activeTab);\n\n      /**\n      * Fires when the plugin has successfully collapsed tabs.\n      * @event Tabs#collapse\n      */\n      this.$element.trigger('collapse.zf.tabs', [$activeTab]);\n    }\n  }\n\n  /**\n   * Public method for selecting a content pane to display.\n   * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @function\n   */\n  selectTab(elem, historyHandled) {\n    var idStr;\n\n    if (typeof elem === 'object') {\n      idStr = elem[0].id;\n    } else {\n      idStr = elem;\n    }\n\n    if (idStr.indexOf('#') < 0) {\n      idStr = `#${idStr}`;\n    }\n\n    var $target = this.$tabTitles.has(`[href$=\"${idStr}\"]`);\n\n    this._handleTabChange($target, historyHandled);\n  };\n\n  /**\n   * Sets the height of each panel to the height of the tallest panel.\n   * If enabled in options, gets called on media query change.\n   * If loading content via external source, can be called directly or with _reflow.\n   * If enabled with `data-match-height=\"true\"`, tabs sets to equal height\n   * @function\n   * @private\n   */\n  _setHeight() {\n    var max = 0,\n        _this = this; // Lock down the `this` value for the root tabs object\n\n    this.$tabContent\n      .find(`.${this.options.panelClass}`)\n      .css('height', '')\n      .each(function() {\n\n        var panel = $(this),\n            isActive = panel.hasClass(`${_this.options.panelActiveClass}`); // get the options from the parent instead of trying to get them from the child\n\n        if (!isActive) {\n          panel.css({'visibility': 'hidden', 'display': 'block'});\n        }\n\n        var temp = this.getBoundingClientRect().height;\n\n        if (!isActive) {\n          panel.css({\n            'visibility': '',\n            'display': ''\n          });\n        }\n\n        max = temp > max ? temp : max;\n      })\n      .css('height', `${max}px`);\n  }\n\n  /**\n   * Destroys an instance of tabs.\n   * @fires Tabs#destroyed\n   */\n  _destroy() {\n    this.$element\n      .find(`.${this.options.linkClass}`)\n      .off('.zf.tabs').hide().end()\n      .find(`.${this.options.panelClass}`)\n      .hide();\n\n    if (this.options.matchHeight) {\n      if (this._setHeightMqHandler != null) {\n         $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);\n      }\n    }\n\n    if (this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n    if (this.onLoadListener) {\n      $(window).off(this.onLoadListener);\n    }\n  }\n}\n\nTabs.defaults = {\n  /**\n   * Link the location hash to the active pane.\n   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open tab\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n   * Allows the window to scroll to content of active pane on load.\n   * Not recommended if more than one tab panel per page.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows keyboard input to 'wrap' around the tab links.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  wrapOnKeys: true,\n\n  /**\n   * Allows the tab content panes to match heights if set to true.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  matchHeight: false,\n\n  /**\n   * Allows active tabs to collapse when clicked.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  activeCollapse: false,\n\n  /**\n   * Class applied to `li`'s in tab link list.\n   * @option\n   * @type {string}\n   * @default 'tabs-title'\n   */\n  linkClass: 'tabs-title',\n\n  /**\n   * Class applied to the active `li` in tab link list.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  linkActiveClass: 'is-active',\n\n  /**\n   * Class applied to the content containers.\n   * @option\n   * @type {string}\n   * @default 'tabs-panel'\n   */\n  panelClass: 'tabs-panel',\n\n  /**\n   * Class applied to the active content container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  panelActiveClass: 'is-active'\n};\n\nexport {Tabs};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { RegExpEscape } from './foundation.core.utils';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nclass Toggler extends Plugin {\n  /**\n   * Creates a new instance of Toggler.\n   * @class\n   * @name Toggler\n   * @fires Toggler#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Toggler.defaults, element.data(), options);\n    this.className = '';\n    this.className = 'Toggler'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.\n   * @function\n   * @private\n   */\n  _init() {\n    var input;\n    // Parse animation classes if they were set\n    if (this.options.animate) {\n      input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n    // Otherwise, parse toggle class\n    else {\n      input = this.$element.data('toggler');\n      // Allow for a . at the beginning of the string\n      this.className = input[0] === '.' ? input.slice(1) : input;\n    }\n\n    // Add ARIA attributes to triggers:\n    var id = this.$element[0].id,\n      $triggers = $(`[data-open~=\"${id}\"], [data-close~=\"${id}\"], [data-toggle~=\"${id}\"]`);\n\n    // - aria-expanded: according to the element visibility.\n    $triggers.attr('aria-expanded', !this.$element.is(':hidden'));\n    // - aria-controls: adding the element id to it if not already in it.\n    $triggers.each((index, trigger) => {\n      const $trigger = $(trigger);\n      const controls = $trigger.attr('aria-controls') || '';\n\n      const containsId = new RegExp(`\\\\b${RegExpEscape(id)}\\\\b`).test(controls);\n      if (!containsId) $trigger.attr('aria-controls', controls ? `${controls} ${id}` : id);\n    });\n  }\n\n  /**\n   * Initializes events for the toggle trigger.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));\n  }\n\n  /**\n   * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was \"on\" or \"off\".\n   * @function\n   * @fires Toggler#on\n   * @fires Toggler#off\n   */\n  toggle() {\n    this[ this.options.animate ? '_toggleAnimate' : '_toggleClass']();\n  }\n\n  _toggleClass() {\n    this.$element.toggleClass(this.className);\n\n    var isOn = this.$element.hasClass(this.className);\n    if (isOn) {\n      /**\n       * Fires if the target element has the class after a toggle.\n       * @event Toggler#on\n       */\n      this.$element.trigger('on.zf.toggler');\n    }\n    else {\n      /**\n       * Fires if the target element does not have the class after a toggle.\n       * @event Toggler#off\n       */\n      this.$element.trigger('off.zf.toggler');\n    }\n\n    this._updateARIA(isOn);\n    this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');\n  }\n\n  _toggleAnimate() {\n    var _this = this;\n\n    if (this.$element.is(':hidden')) {\n      Motion.animateIn(this.$element, this.animationIn, function() {\n        _this._updateARIA(true);\n        this.trigger('on.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n    else {\n      Motion.animateOut(this.$element, this.animationOut, function() {\n        _this._updateARIA(false);\n        this.trigger('off.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n  }\n\n  _updateARIA(isOn) {\n    var id = this.$element[0].id;\n    $(`[data-open=\"${id}\"], [data-close=\"${id}\"], [data-toggle=\"${id}\"]`)\n      .attr({\n        'aria-expanded': isOn ? true : false\n      });\n  }\n\n  /**\n   * Destroys the instance of Toggler on the element.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.toggler');\n  }\n}\n\nToggler.defaults = {\n  /**\n   * Tells the plugin if the element should animated when toggled.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport {Toggler};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Triggers } from './foundation.util.triggers';\nimport { Positionable } from './foundation.positionable';\n\n/**\n * Tooltip module.\n * @module foundation.tooltip\n * @requires foundation.util.box\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass Tooltip extends Positionable {\n  /**\n   * Creates a new instance of a Tooltip.\n   * @class\n   * @name Tooltip\n   * @fires Tooltip#init\n   * @param {jQuery} element - jQuery object to attach a tooltip to.\n   * @param {Object} options - object to extend the default configuration.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);\n    this.className = 'Tooltip'; // ie9 back compat\n\n    this.isActive = false;\n    this.isClick = false;\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');\n\n    this.options.tipText = this.options.tipText || this.$element.attr('title');\n    this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);\n\n    if (this.options.allowHtml) {\n      this.template.appendTo(document.body)\n        .html(this.options.tipText)\n        .hide();\n    } else {\n      this.template.appendTo(document.body)\n        .text(this.options.tipText)\n        .hide();\n    }\n\n    this.$element.attr({\n      'title': '',\n      'aria-describedby': elemId,\n      'data-yeti-box': elemId,\n      'data-toggle': elemId,\n      'data-resize': elemId\n    }).addClass(this.options.triggerClass);\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/\\b(top|left|right|bottom)\\b/g);\n    return position ? position[0] : 'top';\n  }\n\n  _getDefaultAlignment() {\n    return 'center';\n  }\n\n  _getHOffset() {\n    if(this.position === 'left' || this.position === 'right') {\n      return this.options.hOffset + this.options.tooltipWidth;\n    } else {\n      return this.options.hOffset\n    }\n  }\n\n  _getVOffset() {\n    if(this.position === 'top' || this.position === 'bottom') {\n      return this.options.vOffset + this.options.tooltipHeight;\n    } else {\n      return this.options.vOffset\n    }\n  }\n\n  /**\n   * builds the tooltip element, adds attributes, and returns the template.\n   * @private\n   */\n  _buildTemplate(id) {\n    var templateClasses = (`${this.options.tooltipClass} ${this.options.templateClasses}`).trim();\n    var $template =  $('<div></div>').addClass(templateClasses).attr({\n      'role': 'tooltip',\n      'aria-hidden': true,\n      'data-is-active': false,\n      'data-is-focus': false,\n      'id': id\n    });\n    return $template;\n  }\n\n  /**\n   * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.\n   * if the tooltip is larger than the screen width, default to full width - any user selected margin\n   * @private\n   */\n  _setPosition() {\n    super._setPosition(this.$element, this.template);\n  }\n\n  /**\n   * reveals the tooltip, and fires an event to close any other open tooltips on the page\n   * @fires Tooltip#closeme\n   * @fires Tooltip#show\n   * @function\n   */\n  show() {\n    if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {\n      // console.error('The screen is too small to display this tooltip');\n      return false;\n    }\n\n    var _this = this;\n    this.template.css('visibility', 'hidden').show();\n    this._setPosition();\n    this.template.removeClass('top bottom left right').addClass(this.position)\n    this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);\n\n    /**\n     * Fires to close all other open tooltips on the page\n     * @event Closeme#tooltip\n     */\n    this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));\n\n\n    this.template.attr({\n      'data-is-active': true,\n      'aria-hidden': false\n    });\n    _this.isActive = true;\n    // console.log(this.template);\n    this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function() {\n      //maybe do stuff?\n    });\n    /**\n     * Fires when the tooltip is shown\n     * @event Tooltip#show\n     */\n    this.$element.trigger('show.zf.tooltip');\n  }\n\n  /**\n   * Hides the current tooltip, and resets the positioning class if it was changed due to collision\n   * @fires Tooltip#hide\n   * @function\n   */\n  hide() {\n    // console.log('hiding', this.$element.data('yeti-box'));\n    var _this = this;\n    this.template.stop().attr({\n      'aria-hidden': true,\n      'data-is-active': false\n    }).fadeOut(this.options.fadeOutDuration, function() {\n      _this.isActive = false;\n      _this.isClick = false;\n    });\n    /**\n     * fires when the tooltip is hidden\n     * @event Tooltip#hide\n     */\n    this.$element.trigger('hide.zf.tooltip');\n  }\n\n  /**\n   * adds event listeners for the tooltip and its anchor\n   * TODO combine some of the listeners like focus and mouseenter, etc.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    var $template = this.template;\n    var isFocus = false;\n\n    if (!this.options.disableHover) {\n\n      this.$element\n      .on('mouseenter.zf.tooltip', function(e) {\n        if (!_this.isActive) {\n          _this.timeout = setTimeout(function() {\n            _this.show();\n          }, _this.options.hoverDelay);\n        }\n      })\n      .on('mouseleave.zf.tooltip', ignoreMousedisappear(function(e) {\n        clearTimeout(_this.timeout);\n        if (!isFocus || (_this.isClick && !_this.options.clickOpen)) {\n          _this.hide();\n        }\n      }));\n    }\n\n    if (this.options.clickOpen) {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        if (_this.isClick) {\n          //_this.hide();\n          // _this.isClick = false;\n        } else {\n          _this.isClick = true;\n          if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {\n            _this.show();\n          }\n        }\n      });\n    } else {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        _this.isClick = true;\n      });\n    }\n\n    if (!this.options.disableForTouch) {\n      this.$element\n      .on('tap.zf.tooltip touchend.zf.tooltip', function(e) {\n        _this.isActive ? _this.hide() : _this.show();\n      });\n    }\n\n    this.$element.on({\n      // 'toggle.zf.trigger': this.toggle.bind(this),\n      // 'close.zf.trigger': this.hide.bind(this)\n      'close.zf.trigger': this.hide.bind(this)\n    });\n\n    this.$element\n      .on('focus.zf.tooltip', function(e) {\n        isFocus = true;\n        if (_this.isClick) {\n          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't\n          // a real focus, otherwise on hover and come back we get bad behavior\n          if(!_this.options.clickOpen) { isFocus = false; }\n          return false;\n        } else {\n          _this.show();\n        }\n      })\n\n      .on('focusout.zf.tooltip', function(e) {\n        isFocus = false;\n        _this.isClick = false;\n        _this.hide();\n      })\n\n      .on('resizeme.zf.trigger', function() {\n        if (_this.isActive) {\n          _this._setPosition();\n        }\n      });\n  }\n\n  /**\n   * adds a toggle method, in addition to the static show() & hide() functions\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  /**\n   * Destroys an instance of tooltip, removes template element from the view.\n   * @function\n   */\n  _destroy() {\n    this.$element.attr('title', this.template.text())\n                 .off('.zf.trigger .zf.tooltip')\n                 .removeClass(this.options.triggerClass)\n                 .removeClass('top right left bottom')\n                 .removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n\n    this.template.remove();\n  }\n}\n\nTooltip.defaults = {\n  disableForTouch: false,\n  /**\n   * Time, in ms, before a tooltip should open on hover.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  hoverDelay: 200,\n  /**\n   * Time, in ms, a tooltip should take to fade into view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeInDuration: 150,\n  /**\n   * Time, in ms, a tooltip should take to fade out of view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeOutDuration: 150,\n  /**\n   * Disables hover events from opening the tooltip if set to true\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Optional addtional classes to apply to the tooltip template on init.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  templateClasses: '',\n  /**\n   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.\n   * @option\n   * @type {string}\n   * @default 'tooltip'\n   */\n  tooltipClass: 'tooltip',\n  /**\n   * Class applied to the tooltip anchor element.\n   * @option\n   * @type {string}\n   * @default 'has-tip'\n   */\n  triggerClass: 'has-tip',\n  /**\n   * Minimum breakpoint size at which to open the tooltip.\n   * @option\n   * @type {string}\n   * @default 'small'\n   */\n  showOn: 'small',\n  /**\n   * Custom template to be used to generate markup for tooltip.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  template: '',\n  /**\n   * Text displayed in the tooltip template on open.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  tipText: '',\n  touchCloseText: 'Tap to close.',\n  /**\n   * Allows the tooltip to remain open if triggered with a click or touch event.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickOpen: true,\n  /**\n   * Position of tooltip. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, tooltip will first try to\n   * position as defined by data-position and data-alignment, but reposition if\n   * it would cause an overflow.  @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * Less common for tooltips.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowBottomOverlap: false,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the Y axis.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the X axis\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip\n   * @option\n   * @type {number}\n   * @default 14\n   */\n  tooltipHeight: 14,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip\n   * @option\n   * @type {number}\n   * @default 12\n   */\n  tooltipWidth: 12,\n    /**\n   * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,\n   * allowing HTML may open yourself up to XSS attacks.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowHtml: false\n};\n\n/**\n * TODO utilize resize event trigger\n */\n\nexport {Tooltip};\n","'use strict';\n\n\nimport { rtl as Rtl } from \"./foundation.core.utils\";\n\nvar Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  OverlapArea: OverlapArea,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets,\n  GetExplicitOffsets: GetExplicitOffsets\n}\n\n/**\n * Compares the dimensions of an element to a container and determines collision events with container.\n * @function\n * @param {jQuery} element - jQuery object to test for collisions.\n * @param {jQuery} parent - jQuery object to use as bounding container.\n * @param {Boolean} lrOnly - set to true to check left and right values only.\n * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n * @default if no parent object passed, detects collisions with `window`.\n * @returns {Boolean} - true if collision free, false if a collision in any direction.\n */\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n};\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  var eleDims = GetDimensions(element),\n  topOver, bottomOver, leftOver, rightOver;\n  if (parent) {\n    var parDims = GetDimensions(parent);\n\n    bottomOver = (parDims.height + parDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - parDims.offset.top;\n    leftOver   = eleDims.offset.left - parDims.offset.left;\n    rightOver  = (parDims.width + parDims.offset.left) - (eleDims.offset.left + eleDims.width);\n  }\n  else {\n    bottomOver = (eleDims.windowDims.height + eleDims.windowDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - eleDims.windowDims.offset.top;\n    leftOver   = eleDims.offset.left - eleDims.windowDims.offset.left;\n    rightOver  = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n  }\n\n  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n  topOver    = Math.min(topOver, 0);\n  leftOver   = Math.min(leftOver, 0);\n  rightOver  = Math.min(rightOver, 0);\n\n  if (lrOnly) {\n    return leftOver + rightOver;\n  }\n  if (tbOnly) {\n    return topOver + bottomOver;\n  }\n\n  // use sum of squares b/c we care about overlap area.\n  return Math.sqrt((topOver * topOver) + (bottomOver * bottomOver) + (leftOver * leftOver) + (rightOver * rightOver));\n}\n\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\nfunction GetDimensions(elem){\n  elem = elem.length ? elem[0] : elem;\n\n  if (elem === window || elem === document) {\n    throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n  }\n\n  var rect = elem.getBoundingClientRect(),\n      parRect = elem.parentNode.getBoundingClientRect(),\n      winRect = document.body.getBoundingClientRect(),\n      winY = window.pageYOffset,\n      winX = window.pageXOffset;\n\n  return {\n    width: rect.width,\n    height: rect.height,\n    offset: {\n      top: rect.top + winY,\n      left: rect.left + winX\n    },\n    parentDims: {\n      width: parRect.width,\n      height: parRect.height,\n      offset: {\n        top: parRect.top + winY,\n        left: parRect.left + winX\n      }\n    },\n    windowDims: {\n      width: winRect.width,\n      height: winRect.height,\n      offset: {\n        top: winY,\n        left: winX\n      }\n    }\n  }\n}\n\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\nfunction GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {\n  console.log(\"NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5\");\n  switch (position) {\n    case 'top':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);\n    case 'bottom':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    case 'center top':\n      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);\n    case 'center bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);\n    case 'center left':\n      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);\n    case 'center right':\n      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);\n    case 'left bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);\n    case 'right bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    // Backwards compatibility... this along with the reveal and reveal full\n    // classes are the only ones that didn't reference anchor\n    case 'center':\n      return {\n        left: ($eleDims.windowDims.offset.left + ($eleDims.windowDims.width / 2)) - ($eleDims.width / 2) + hOffset,\n        top: ($eleDims.windowDims.offset.top + ($eleDims.windowDims.height / 2)) - ($eleDims.height / 2 + vOffset)\n      }\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + vOffset\n      }\n    case 'reveal full':\n      return {\n        left: $eleDims.windowDims.offset.left,\n        top: $eleDims.windowDims.offset.top\n      }\n      break;\n    default:\n      return {\n        left: (Rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset: $anchorDims.offset.left + hOffset),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n\n  }\n\n}\n\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n      var topVal, leftVal;\n\n  // set position related attribute\n\n  switch (position) {\n    case 'top':\n      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n      break;\n    case 'bottom':\n      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n      break;\n    case 'left':\n      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n      break;\n    case 'right':\n      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n      break;\n  }\n\n\n  // set alignment related attribute\n  switch (position) {\n    case 'top':\n    case 'bottom':\n      switch (alignment) {\n        case 'left':\n          leftVal = $anchorDims.offset.left + hOffset;\n          break;\n        case 'right':\n          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n          break;\n        case 'center':\n          leftVal = isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)) + hOffset;\n          break;\n      }\n      break;\n    case 'right':\n    case 'left':\n      switch (alignment) {\n        case 'bottom':\n          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n          break;\n        case 'top':\n          topVal = $anchorDims.offset.top + vOffset\n          break;\n        case 'center':\n          topVal = ($anchorDims.offset.top + vOffset + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n          break;\n      }\n      break;\n  }\n  return {top: topVal, left: leftVal};\n}\n\nexport {Box};\n","'use strict';\n\nimport $ from 'jquery';\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\nfunction onImagesLoaded(images, callback){\n  var self = this,\n      unloaded = images.length;\n\n  if (unloaded === 0) {\n    callback();\n  }\n\n  images.each(function(){\n    // Check if image is loaded\n    if (this.complete && typeof this.naturalWidth !== 'undefined') {\n      singleImageLoaded();\n    }\n    else {\n      // If the above check failed, simulate loading on detached element.\n      var image = new Image();\n      // Still count image as loaded if it finalizes with an error.\n      var events = \"load.zf.images error.zf.images\";\n      $(image).one(events, function me(event){\n        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n        $(this).off(events, me);\n        singleImageLoaded();\n      });\n      image.src = $(this).attr('src');\n    }\n  });\n\n  function singleImageLoaded() {\n    unloaded--;\n    if (unloaded === 0) {\n      callback();\n    }\n  }\n}\n\nexport { onImagesLoaded };\n","/*******************************************\n *                                         *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n *                                         *\n ******************************************/\n\n'use strict';\n\nimport $ from 'jquery';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  35: 'END',\n  36: 'HOME',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n}\n\nvar commands = {}\n\n// Functions pulled out to be referenceable from internals\nfunction findFocusable($element) {\n  if(!$element) {return false; }\n  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function() {\n    if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) { return false; } //only have visible elements and those that have a tabindex greater or equal 0\n    return true;\n  });\n}\n\nfunction parseKey(event) {\n  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();\n\n  // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n  key = key.replace(/\\W+/, '');\n\n  if (event.shiftKey) key = `SHIFT_${key}`;\n  if (event.ctrlKey) key = `CTRL_${key}`;\n  if (event.altKey) key = `ALT_${key}`;\n\n  // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n  key = key.replace(/_$/, '');\n\n  return key;\n}\n\nvar Keyboard = {\n  keys: getKeyCodes(keyCodes),\n\n  /**\n   * Parses the (keyboard) event and returns a String that represents its key\n   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n   * @param {Event} event - the event generated by the event handler\n   * @return String key - String that represents the key pressed\n   */\n  parseKey: parseKey,\n\n  /**\n   * Handles the given (keyboard) event\n   * @param {Event} event - the event generated by the event handler\n   * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n   * @param {Objects} functions - collection of functions that are to be executed\n   */\n  handleKey(event, component, functions) {\n    var commandList = commands[component],\n      keyCode = this.parseKey(event),\n      cmds,\n      command,\n      fn;\n\n    if (!commandList) return console.warn('Component not defined!');\n\n    if (typeof commandList.ltr === 'undefined') { // this component does not differentiate between ltr and rtl\n        cmds = commandList; // use plain list\n    } else { // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n        if (Rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);\n\n        else cmds = $.extend({}, commandList.rtl, commandList.ltr);\n    }\n    command = cmds[keyCode];\n\n    fn = functions[command];\n    if (fn && typeof fn === 'function') { // execute function  if exists\n      var returnValue = fn.apply();\n      if (functions.handled || typeof functions.handled === 'function') { // execute function when event was handled\n          functions.handled(returnValue);\n      }\n    } else {\n      if (functions.unhandled || typeof functions.unhandled === 'function') { // execute function when event was not handled\n          functions.unhandled();\n      }\n    }\n  },\n\n  /**\n   * Finds all focusable elements within the given `$element`\n   * @param {jQuery} $element - jQuery object to search within\n   * @return {jQuery} $focusable - all focusable elements within `$element`\n   */\n\n  findFocusable: findFocusable,\n\n  /**\n   * Returns the component name name\n   * @param {Object} component - Foundation component, e.g. Slider or Reveal\n   * @return String componentName\n   */\n\n  register(componentName, cmds) {\n    commands[componentName] = cmds;\n  },\n\n\n  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n  //\n  /**\n   * Traps the focus in the given element.\n   * @param  {jQuery} $element  jQuery object to trap the foucs into.\n   */\n  trapFocus($element) {\n    var $focusable = findFocusable($element),\n        $firstFocusable = $focusable.eq(0),\n        $lastFocusable = $focusable.eq(-1);\n\n    $element.on('keydown.zf.trapfocus', function(event) {\n      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      }\n      else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n        event.preventDefault();\n        $lastFocusable.focus();\n      }\n    });\n  },\n  /**\n   * Releases the trapped focus from the given element.\n   * @param  {jQuery} $element  jQuery object to release the focus for.\n   */\n  releaseFocus($element) {\n    $element.off('keydown.zf.trapfocus');\n  }\n}\n\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\nfunction getKeyCodes(kcs) {\n  var k = {};\n  for (var kc in kcs) k[kcs[kc]] = kcs[kc];\n  return k;\n}\n\nexport {Keyboard};\n","'use strict';\n\nimport $ from 'jquery';\n\n// Default set of media queries\nconst defaultQueries = {\n  'default' : 'only screen',\n  landscape : 'only screen and (orientation: landscape)',\n  portrait : 'only screen and (orientation: portrait)',\n  retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' +\n    'only screen and (min--moz-device-pixel-ratio: 2),' +\n    'only screen and (-o-min-device-pixel-ratio: 2/1),' +\n    'only screen and (min-device-pixel-ratio: 2),' +\n    'only screen and (min-resolution: 192dpi),' +\n    'only screen and (min-resolution: 2dppx)'\n  };\n\n\n// matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n/* eslint-disable */\nwindow.matchMedia || (window.matchMedia = (function () {\n  \"use strict\";\n\n  // For browsers that support matchMedium api such as IE 9 and webkit\n  var styleMedia = (window.styleMedia || window.media);\n\n  // For those that don't support matchMedium\n  if (!styleMedia) {\n    var style   = document.createElement('style'),\n    script      = document.getElementsByTagName('script')[0],\n    info        = null;\n\n    style.type  = 'text/css';\n    style.id    = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    }\n\n    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n    info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;\n\n    styleMedia = {\n      matchMedium: function (media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';\n\n        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        }\n\n        // Test if media query is true or false\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function(media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n})());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init() {\n    var self = this;\n    var $meta = $('meta.foundation-mq');\n    if(!$meta.length){\n      $('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = $('.foundation-mq').css('font-family');\n    var namedQueries;\n\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if(namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: `only screen and (min-width: ${namedQueries[key]})`\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is(size) {\n    size = size.trim().split(' ');\n    if(size.length > 1 && size[1] === 'only') {\n      if(size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get(size) {\n    for (var i in this.queries) {\n      if(this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (typeof matched === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher() {\n    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', () => {\n      var newSize = this._getCurrentSize(), currentSize = this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        this.current = newSize;\n\n        // Broadcast the media query change on the window\n        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n};\n\n\n\n// Thank you: https://github.com/sindresorhus/query-string\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function(ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key);\n\n    // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n    return ret;\n  }, {});\n\n  return styleObject;\n}\n\nexport {MediaQuery};\n","'use strict';\n\nimport $ from 'jquery';\nimport { transitionend } from './foundation.core.utils';\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nconst initClasses   = ['mui-enter', 'mui-leave'];\nconst activeClasses = ['mui-enter-active', 'mui-leave-active'];\n\nconst Motion = {\n  animateIn: function(element, animation, cb) {\n    animate(true, element, animation, cb);\n  },\n\n  animateOut: function(element, animation, cb) {\n    animate(false, element, animation, cb);\n  }\n}\n\nfunction Move(duration, elem, fn){\n  var anim, prog, start = null;\n  // console.log('called');\n\n  if (duration === 0) {\n    fn.apply(elem);\n    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    return;\n  }\n\n  function move(ts){\n    if(!start) start = ts;\n    // console.log(start, ts);\n    prog = ts - start;\n    fn.apply(elem);\n\n    if(prog < duration){ anim = window.requestAnimationFrame(move, elem); }\n    else{\n      window.cancelAnimationFrame(anim);\n      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    }\n  }\n  anim = window.requestAnimationFrame(move);\n}\n\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\nfunction animate(isIn, element, animation, cb) {\n  element = $(element).eq(0);\n\n  if (!element.length) return;\n\n  var initClass = isIn ? initClasses[0] : initClasses[1];\n  var activeClass = isIn ? activeClasses[0] : activeClasses[1];\n\n  // Set up the animation\n  reset();\n\n  element\n    .addClass(animation)\n    .css('transition', 'none');\n\n  requestAnimationFrame(() => {\n    element.addClass(initClass);\n    if (isIn) element.show();\n  });\n\n  // Start the animation\n  requestAnimationFrame(() => {\n    element[0].offsetWidth;\n    element\n      .css('transition', '')\n      .addClass(activeClass);\n  });\n\n  // Clean up the animation when it finishes\n  element.one(transitionend(element), finish);\n\n  // Hides the element (for out animations), resets the element, and runs a callback\n  function finish() {\n    if (!isIn) element.hide();\n    reset();\n    if (cb) cb.apply(element);\n  }\n\n  // Resets transitions and removes motion-specific classes\n  function reset() {\n    element[0].style.transitionDuration = 0;\n    element.removeClass(`${initClass} ${activeClass} ${animation}`);\n  }\n}\n\nexport { Move, Motion };\n\n","'use strict';\n\nimport $ from 'jquery';\n\nconst Nest = {\n  Feather(menu, type = 'zf') {\n    menu.attr('role', 'menubar');\n\n    var items = menu.find('li').attr({'role': 'menuitem'}),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`,\n        applyAria = (type !== 'accordion'); // Accordions handle their own ARIA attriutes.\n\n    items.each(function() {\n      var $item = $(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item.addClass(hasSubClass);\n        if(applyAria) {\n          $item.attr({\n            'aria-haspopup': true,\n            'aria-label': $item.children('a:first').text()\n          });\n          // Note:  Drilldowns behave differently in how they hide, and so need\n          // additional attributes.  We should look if this possibly over-generalized\n          // utility (Nest) is appropriate when we rework menus in 6.4\n          if(type === 'drilldown') {\n            $item.attr({'aria-expanded': false});\n          }\n        }\n        $sub\n          .addClass(`submenu ${subMenuClass}`)\n          .attr({\n            'data-submenu': '',\n            'role': 'menubar'\n          });\n        if(type === 'drilldown') {\n          $sub.attr({'aria-hidden': true});\n        }\n      }\n\n      if ($item.parent('[data-submenu]').length) {\n        $item.addClass(`is-submenu-item ${subItemClass}`);\n      }\n    });\n\n    return;\n  },\n\n  Burn(menu, type) {\n    var //items = menu.find('li'),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`;\n\n    menu\n      .find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li')\n      .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n      .removeAttr('data-submenu').css('display', '');\n\n  }\n}\n\nexport {Nest};\n","'use strict';\n\nimport $ from 'jquery';\n\nfunction Timer(elem, options, cb) {\n  var _this = this,\n      duration = options.duration,//options is an object for easily adding features later.\n      nameSpace = Object.keys(elem.data())[0] || 'timer',\n      remain = -1,\n      start,\n      timer;\n\n  this.isPaused = false;\n\n  this.restart = function() {\n    remain = -1;\n    clearTimeout(timer);\n    this.start();\n  }\n\n  this.start = function() {\n    this.isPaused = false;\n    // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    remain = remain <= 0 ? duration : remain;\n    elem.data('paused', false);\n    start = Date.now();\n    timer = setTimeout(function(){\n      if(options.infinite){\n        _this.restart();//rerun the timer.\n      }\n      if (cb && typeof cb === 'function') { cb(); }\n    }, remain);\n    elem.trigger(`timerstart.zf.${nameSpace}`);\n  }\n\n  this.pause = function() {\n    this.isPaused = true;\n    //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    elem.data('paused', true);\n    var end = Date.now();\n    remain = remain - (end - start);\n    elem.trigger(`timerpaused.zf.${nameSpace}`);\n  }\n}\n\nexport {Timer};\n","//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nimport $ from 'jquery';\n\nvar Touch = {};\n\nvar startPosX,\n    startPosY,\n    startTime,\n    elapsedTime,\n    startEvent,\n    isMoving = false,\n    didMoved = false;\n\nfunction onTouchEnd(e) {\n  this.removeEventListener('touchmove', onTouchMove);\n  this.removeEventListener('touchend', onTouchEnd);\n\n  // If the touch did not move, consider it as a \"tap\"\n  if (!didMoved) {\n    var tapEvent = $.Event('tap', startEvent || e);\n    $(this).trigger(tapEvent);\n  }\n\n  startEvent = null;\n  isMoving = false;\n  didMoved = false;\n}\n\nfunction onTouchMove(e) {\n  if ($.spotSwipe.preventDefault) { e.preventDefault(); }\n\n  if(isMoving) {\n    var x = e.touches[0].pageX;\n    var y = e.touches[0].pageY;\n    var dx = startPosX - x;\n    var dy = startPosY - y;\n    var dir;\n    didMoved = true;\n    elapsedTime = new Date().getTime() - startTime;\n    if(Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n      dir = dx > 0 ? 'left' : 'right';\n    }\n    // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n    //   dir = dy > 0 ? 'down' : 'up';\n    // }\n    if(dir) {\n      e.preventDefault();\n      onTouchEnd.apply(this, arguments);\n      $(this)\n        .trigger($.Event('swipe', e), dir)\n        .trigger($.Event(`swipe${dir}`, e));\n    }\n  }\n\n}\n\nfunction onTouchStart(e) {\n\n  if (e.touches.length == 1) {\n    startPosX = e.touches[0].pageX;\n    startPosY = e.touches[0].pageY;\n    startEvent = e;\n    isMoving = true;\n    didMoved = false;\n    startTime = new Date().getTime();\n    this.addEventListener('touchmove', onTouchMove, false);\n    this.addEventListener('touchend', onTouchEnd, false);\n  }\n}\n\nfunction init() {\n  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);\n}\n\nfunction teardown() {\n  this.removeEventListener('touchstart', onTouchStart);\n}\n\nclass SpotSwipe {\n  constructor($) {\n    this.version = '1.0.0';\n    this.enabled = 'ontouchstart' in document.documentElement;\n    this.preventDefault = false;\n    this.moveThreshold = 75;\n    this.timeThreshold = 200;\n    this.$ = $;\n    this._init();\n  }\n\n  _init() {\n    var $ = this.$;\n    $.event.special.swipe = { setup: init };\n    $.event.special.tap = { setup: init };\n\n    $.each(['left', 'up', 'down', 'right'], function () {\n      $.event.special[`swipe${this}`] = { setup: function(){\n        $(this).on('swipe', $.noop);\n      } };\n    });\n  }\n}\n\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and    *\n * setupTouchHandler should be idempotent,          *\n * because they directly replace functions &        *\n * values, and do not add event handlers directly.  *\n ****************************************************/\n\nTouch.setupSpotSwipe = function($) {\n  $.spotSwipe = new SpotSwipe($);\n};\n\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\nTouch.setupTouchHandler = function($) {\n  $.fn.addTouch = function(){\n    this.each(function(i,el){\n      $(el).bind('touchstart touchmove touchend touchcancel', function(event)  {\n        //we pass the original event object because the jQuery event\n        //object is normalized to w3c specs and does not provide the TouchList\n        handleTouch(event);\n      });\n    });\n\n    var handleTouch = function(event){\n      var touches = event.changedTouches,\n          first = touches[0],\n          eventTypes = {\n            touchstart: 'mousedown',\n            touchmove: 'mousemove',\n            touchend: 'mouseup'\n          },\n          type = eventTypes[event.type],\n          simulatedEvent\n        ;\n\n      if('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n        simulatedEvent = new window.MouseEvent(type, {\n          'bubbles': true,\n          'cancelable': true,\n          'screenX': first.screenX,\n          'screenY': first.screenY,\n          'clientX': first.clientX,\n          'clientY': first.clientY\n        });\n      } else {\n        simulatedEvent = document.createEvent('MouseEvent');\n        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0/*left*/, null);\n      }\n      first.target.dispatchEvent(simulatedEvent);\n    };\n  };\n};\n\nTouch.init = function ($) {\n\n  if(typeof($.spotSwipe) === 'undefined') {\n    Touch.setupSpotSwipe($);\n    Touch.setupTouchHandler($);\n  }\n};\n\nexport {Touch};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index ee1877e03f15fde1bb8600ad0497c033ae7905e1..6d5f014bc8768f5e3a6f34d4bd27fa2d47889267 100644 (file)
@@ -1,5 +1,2 @@
-!function(t){function e(n){if(i[n])return i[n].exports;var s=i[n]={i:n,l:!1,exports:{}};return t[n].call(s.exports,s,s.exports,e),s.l=!0,s.exports}var i={};e.m=t,e.c=i,e.i=function(t){return t},e.d=function(t,i,n){e.o(t,i)||Object.defineProperty(t,i,{configurable:!1,enumerable:!0,get:n})},e.n=function(t){var i=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(i,"a",i),i},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=36)}([function(t,e){t.exports=jQuery},function(t,e,i){"use strict";function n(){return"rtl"===r()("html").attr("dir")}function s(t,e){return t=t||6,Math.round(Math.pow(36,t+1)-Math.random()*Math.pow(36,t)).toString(36).slice(1)+(e?"-"+e:"")}function o(t){var e,i={transition:"transitionend",WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"otransitionend"},n=document.createElement("div");for(var s in i)void 0!==n.style[s]&&(e=i[s]);return e||(e=setTimeout(function(){t.triggerHandler("transitionend",[t])},1),"transitionend")}i.d(e,"a",function(){return n}),i.d(e,"b",function(){return s}),i.d(e,"c",function(){return o});var a=i(0),r=i.n(a)},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function o(t){return s(void 0!==t.constructor.name?t.constructor.name:t.className)}i.d(e,"a",function(){return u});var a=i(0),r=(i.n(a),i(1)),l=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),u=function(){function t(e,s){n(this,t),this._setup(e,s);var a=o(this);this.uuid=i.i(r.b)(6,a),this.$element.attr("data-"+a)||this.$element.attr("data-"+a,this.uuid),this.$element.data("zfPlugin")||this.$element.data("zfPlugin",this),this.$element.trigger("init.zf."+a)}return l(t,[{key:"destroy",value:function(){this._destroy();var t=o(this);this.$element.removeAttr("data-"+t).removeData("zfPlugin").trigger("destroyed.zf."+t);for(var e in this)this[e]=null}}]),t}()},function(t,e,i){"use strict";function n(t){return!!t&&t.find("a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]").filter(function(){return!(!a()(this).is(":visible")||a()(this).attr("tabindex")<0)})}function s(t){var e=l[t.which||t.keyCode]||String.fromCharCode(t.which).toUpperCase();return e=e.replace(/\W+/,""),t.shiftKey&&(e="SHIFT_"+e),t.ctrlKey&&(e="CTRL_"+e),t.altKey&&(e="ALT_"+e),e=e.replace(/_$/,"")}i.d(e,"a",function(){return c});var o=i(0),a=i.n(o),r=i(1),l={9:"TAB",13:"ENTER",27:"ESCAPE",32:"SPACE",35:"END",36:"HOME",37:"ARROW_LEFT",38:"ARROW_UP",39:"ARROW_RIGHT",40:"ARROW_DOWN"},u={},c={keys:function(t){var e={};for(var i in t)e[t[i]]=t[i];return e}(l),parseKey:s,handleKey:function(t,e,n){var s,o,l,c=u[e],h=this.parseKey(t);if(!c)return console.warn("Component not defined!");if(s=void 0===c.ltr?c:i.i(r.a)()?a.a.extend({},c.ltr,c.rtl):a.a.extend({},c.rtl,c.ltr),o=s[h],(l=n[o])&&"function"==typeof l){var d=l.apply();(n.handled||"function"==typeof n.handled)&&n.handled(d)}else(n.unhandled||"function"==typeof n.unhandled)&&n.unhandled()},findFocusable:n,register:function(t,e){u[t]=e},trapFocus:function(t){var e=n(t),i=e.eq(0),o=e.eq(-1);t.on("keydown.zf.trapfocus",function(t){t.target===o[0]&&"TAB"===s(t)?(t.preventDefault(),i.focus()):t.target===i[0]&&"SHIFT_TAB"===s(t)&&(t.preventDefault(),o.focus())})},releaseFocus:function(t){t.off("keydown.zf.trapfocus")}}},function(t,e,i){"use strict";function n(t){var e={};return"string"!=typeof t?e:(t=t.trim().slice(1,-1))?e=t.split("&").reduce(function(t,e){var i=e.replace(/\+/g," ").split("="),n=i[0],s=i[1];return n=decodeURIComponent(n),s=void 0===s?null:decodeURIComponent(s),t.hasOwnProperty(n)?Array.isArray(t[n])?t[n].push(s):t[n]=[t[n],s]:t[n]=s,t},{}):e}i.d(e,"a",function(){return r});var s=i(0),o=i.n(s),a=window.matchMedia||function(){var t=window.styleMedia||window.media;if(!t){var e=document.createElement("style"),i=document.getElementsByTagName("script")[0],n=null;e.type="text/css",e.id="matchmediajs-test",i&&i.parentNode&&i.parentNode.insertBefore(e,i),n="getComputedStyle"in window&&window.getComputedStyle(e,null)||e.currentStyle,t={matchMedium:function(t){var i="@media "+t+"{ #matchmediajs-test { width: 1px; } }";return e.styleSheet?e.styleSheet.cssText=i:e.textContent=i,"1px"===n.width}}}return function(e){return{matches:t.matchMedium(e||"all"),media:e||"all"}}}(),r={queries:[],current:"",_init:function(){var t=this;o()("meta.foundation-mq").length||o()('<meta class="foundation-mq">').appendTo(document.head);var e,i=o()(".foundation-mq").css("font-family");e=n(i);for(var s in e)e.hasOwnProperty(s)&&t.queries.push({name:s,value:"only screen and (min-width: "+e[s]+")"});this.current=this._getCurrentSize(),this._watcher()},atLeast:function(t){var e=this.get(t);return!!e&&a(e).matches},is:function(t){return t=t.trim().split(" "),t.length>1&&"only"===t[1]?t[0]===this._getCurrentSize():this.atLeast(t[0])},get:function(t){for(var e in this.queries)if(this.queries.hasOwnProperty(e)){var i=this.queries[e];if(t===i.name)return i.value}return null},_getCurrentSize:function(){for(var t,e=0;e<this.queries.length;e++){var i=this.queries[e];a(i.value).matches&&(t=i)}return"object"==typeof t?t.name:t},_watcher:function(){var t=this;o()(window).off("resize.zf.mediaquery").on("resize.zf.mediaquery",function(){var e=t._getCurrentSize(),i=t.current;e!==i&&(t.current=e,o()(window).trigger("changed.zf.mediaquery",[e,i]))})}}},function(t,e,i){"use strict";function n(t,e,i){var n=void 0,s=Array.prototype.slice.call(arguments,3);o()(window).off(e).on(e,function(e){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,s)},t||10)})}i.d(e,"a",function(){return u});var s=i(0),o=i.n(s),a=i(6),r=function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if(t[e]+"MutationObserver"in window)return window[t[e]+"MutationObserver"];return!1}(),l=function(t,e){t.data(e).split(" ").forEach(function(i){o()("#"+i)["close"===e?"trigger":"triggerHandler"](e+".zf.trigger",[t])})},u={Listeners:{Basic:{},Global:{}},Initializers:{}};u.Listeners.Basic={openListener:function(){l(o()(this),"open")},closeListener:function(){o()(this).data("close")?l(o()(this),"close"):o()(this).trigger("close.zf.trigger")},toggleListener:function(){o()(this).data("toggle")?l(o()(this),"toggle"):o()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=o()(this).data("closable");""!==e?a.a.animateOut(o()(this),e,function(){o()(this).trigger("closed.zf")}):o()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=o()(this).data("toggle-focus");o()("#"+t).triggerHandler("toggle.zf.trigger",[o()(this)])}},u.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",u.Listeners.Basic.openListener)},u.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",u.Listeners.Basic.closeListener)},u.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",u.Listeners.Basic.toggleListener)},u.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",u.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",u.Listeners.Basic.closeableListener)},u.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",u.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",u.Listeners.Basic.toggleFocusListener)},u.Listeners.Global={resizeListener:function(t){r||t.each(function(){o()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){r||t.each(function(){o()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];o()("[data-"+i+"]").not('[data-yeti-box="'+e+'"]').each(function(){var t=o()(this);t.triggerHandler("close.zf.trigger",[t])})}},u.Initializers.addClosemeListener=function(t){var e=o()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"==typeof t&&"string"==typeof t[0]?i.concat(t):console.error("Plugin names must be strings")),e.length){var n=i.map(function(t){return"closeme.zf."+t}).join(" ");o()(window).off(n).on(n,u.Listeners.Global.closeMeListener)}},u.Initializers.addResizeListener=function(t){var e=o()("[data-resize]");e.length&&n(t,"resize.zf.trigger",u.Listeners.Global.resizeListener,e)},u.Initializers.addScrollListener=function(t){var e=o()("[data-scroll]");e.length&&n(t,"scroll.zf.trigger",u.Listeners.Global.scrollListener,e)},u.Initializers.addMutationEventsListener=function(t){if(!r)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=o()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var n=0;n<=e.length-1;n++){var s=new r(i);s.observe(e[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},u.Initializers.addSimpleListeners=function(){var t=o()(document);u.Initializers.addOpenListener(t),u.Initializers.addCloseListener(t),u.Initializers.addToggleListener(t),u.Initializers.addCloseableListener(t),u.Initializers.addToggleFocusListener(t)},u.Initializers.addGlobalListeners=function(){var t=o()(document);u.Initializers.addMutationEventsListener(t),u.Initializers.addResizeListener(),u.Initializers.addScrollListener(),u.Initializers.addClosemeListener()},u.init=function(t,e){if(void 0===t.triggersInitialized){t(document);"complete"===document.readyState?(u.Initializers.addSimpleListeners(),u.Initializers.addGlobalListeners()):t(window).on("load",function(){u.Initializers.addSimpleListeners(),u.Initializers.addGlobalListeners()}),t.triggersInitialized=!0}e&&(e.Triggers=u,e.IHearYou=u.Initializers.addGlobalListeners)}},function(t,e,i){"use strict";function n(t,e,i){function n(r){a||(a=r),o=r-a,i.apply(e),o<t?s=window.requestAnimationFrame(n,e):(window.cancelAnimationFrame(s),e.trigger("finished.zf.animate",[e]).triggerHandler("finished.zf.animate",[e]))}var s,o,a=null;if(0===t)return i.apply(e),void e.trigger("finished.zf.animate",[e]).triggerHandler("finished.zf.animate",[e]);s=window.requestAnimationFrame(n)}function s(t,e,n,s){function o(){t||e.hide(),c(),s&&s.apply(e)}function c(){e[0].style.transitionDuration=0,e.removeClass(h+" "+d+" "+n)}if(e=a()(e).eq(0),e.length){var h=t?l[0]:l[1],d=t?u[0]:u[1];c(),e.addClass(n).css("transition","none"),requestAnimationFrame(function(){e.addClass(h),t&&e.show()}),requestAnimationFrame(function(){e[0].offsetWidth,e.css("transition","").addClass(d)}),e.one(i.i(r.c)(e),o)}}i.d(e,"b",function(){return n}),i.d(e,"a",function(){return c});var o=i(0),a=i.n(o),r=i(1),l=["mui-enter","mui-leave"],u=["mui-enter-active","mui-leave-active"],c={animateIn:function(t,e,i){s(!0,t,e,i)},animateOut:function(t,e,i){s(!1,t,e,i)}}},function(t,e,i){"use strict";function n(t,e,i,n,o){return 0===s(t,e,i,n,o)}function s(t,e,i,n,s){var a,r,l,u,c=o(t);if(e){var h=o(e);r=h.height+h.offset.top-(c.offset.top+c.height),a=c.offset.top-h.offset.top,l=c.offset.left-h.offset.left,u=h.width+h.offset.left-(c.offset.left+c.width)}else r=c.windowDims.height+c.windowDims.offset.top-(c.offset.top+c.height),a=c.offset.top-c.windowDims.offset.top,l=c.offset.left-c.windowDims.offset.left,u=c.windowDims.width-(c.offset.left+c.width);return r=s?0:Math.min(r,0),a=Math.min(a,0),l=Math.min(l,0),u=Math.min(u,0),i?l+u:n?a+r:Math.sqrt(a*a+r*r+l*l+u*u)}function o(t){if((t=t.length?t[0]:t)===window||t===document)throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");var e=t.getBoundingClientRect(),i=t.parentNode.getBoundingClientRect(),n=document.body.getBoundingClientRect(),s=window.pageYOffset,o=window.pageXOffset;return{width:e.width,height:e.height,offset:{top:e.top+s,left:e.left+o},parentDims:{width:i.width,height:i.height,offset:{top:i.top+s,left:i.left+o}},windowDims:{width:n.width,height:n.height,offset:{top:s,left:o}}}}function a(t,e,n,s,o,a){switch(console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5"),n){case"top":return i.i(l.a)()?r(t,e,"top","left",s,o,a):r(t,e,"top","right",s,o,a);case"bottom":return i.i(l.a)()?r(t,e,"bottom","left",s,o,a):r(t,e,"bottom","right",s,o,a);case"center top":return r(t,e,"top","center",s,o,a);case"center bottom":return r(t,e,"bottom","center",s,o,a);case"center left":return r(t,e,"left","center",s,o,a);case"center right":return r(t,e,"right","center",s,o,a);case"left bottom":return r(t,e,"bottom","left",s,o,a);case"right bottom":return r(t,e,"bottom","right",s,o,a);case"center":return{left:$eleDims.windowDims.offset.left+$eleDims.windowDims.width/2-$eleDims.width/2+o,top:$eleDims.windowDims.offset.top+$eleDims.windowDims.height/2-($eleDims.height/2+s)};case"reveal":return{left:($eleDims.windowDims.width-$eleDims.width)/2+o,top:$eleDims.windowDims.offset.top+s};case"reveal full":return{left:$eleDims.windowDims.offset.left,top:$eleDims.windowDims.offset.top};default:return{left:i.i(l.a)()?$anchorDims.offset.left-$eleDims.width+$anchorDims.width-o:$anchorDims.offset.left+o,top:$anchorDims.offset.top+$anchorDims.height+s}}}function r(t,e,i,n,s,a,r){var l,u,c=o(t),h=e?o(e):null;switch(i){case"top":l=h.offset.top-(c.height+s);break;case"bottom":l=h.offset.top+h.height+s;break;case"left":u=h.offset.left-(c.width+a);break;case"right":u=h.offset.left+h.width+a}switch(i){case"top":case"bottom":switch(n){case"left":u=h.offset.left+a;break;case"right":u=h.offset.left-c.width+h.width-a;break;case"center":u=r?a:h.offset.left+h.width/2-c.width/2+a}break;case"right":case"left":switch(n){case"bottom":l=h.offset.top-s+h.height-c.height;break;case"top":l=h.offset.top+s;break;case"center":l=h.offset.top+s+h.height/2-c.height/2}}return{top:l,left:u}}i.d(e,"a",function(){return u});var l=i(1),u={ImNotTouchingYou:n,OverlapArea:s,GetDimensions:o,GetOffsets:a,GetExplicitOffsets:r}},function(t,e,i){"use strict";function n(t,e){function i(){0===--n&&e()}var n=t.length;0===n&&e(),t.each(function(){if(this.complete&&void 0!==this.naturalWidth)i();else{var t=new Image,e="load.zf.images error.zf.images";o()(t).one(e,function t(n){o()(this).off(e,t),i()}),t.src=o()(this).attr("src")}})}i.d(e,"a",function(){return n});var s=i(0),o=i.n(s)},function(t,e,i){"use strict";i.d(e,"a",function(){return o});var n=i(0),s=i.n(n),o={Feather:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"zf";t.attr("role","menubar");var i=t.find("li").attr({role:"menuitem"}),n="is-"+e+"-submenu",o=n+"-item",a="is-"+e+"-submenu-parent",r="accordion"!==e;i.each(function(){var t=s()(this),i=t.children("ul");i.length&&(t.addClass(a),i.addClass("submenu "+n).attr({"data-submenu":""}),r&&(t.attr({"aria-haspopup":!0,"aria-label":t.children("a:first").text()}),"drilldown"===e&&t.attr({"aria-expanded":!1})),i.addClass("submenu "+n).attr({"data-submenu":"",role:"menu"}),"drilldown"===e&&i.attr({"aria-hidden":!0})),t.parent("[data-submenu]").length&&t.addClass("is-submenu-item "+o)})},Burn:function(t,e){var i="is-"+e+"-submenu",n=i+"-item",s="is-"+e+"-submenu-parent";t.find(">li, .menu, .menu > li").removeClass(i+" "+n+" "+s+" is-submenu-item submenu is-active").removeAttr("data-submenu").css("display","")}}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(){this.removeEventListener("touchmove",o),this.removeEventListener("touchend",s),g=!1}function o(t){if(f.a.spotSwipe.preventDefault&&t.preventDefault(),g){var e,i=t.touches[0].pageX,n=(t.touches[0].pageY,l-i);h=(new Date).getTime()-c,Math.abs(n)>=f.a.spotSwipe.moveThreshold&&h<=f.a.spotSwipe.timeThreshold&&(e=n>0?"left":"right"),e&&(t.preventDefault(),s.call(this),f()(this).trigger("swipe",e).trigger("swipe"+e))}}function a(t){1==t.touches.length&&(l=t.touches[0].pageX,u=t.touches[0].pageY,g=!0,c=(new Date).getTime(),this.addEventListener("touchmove",o,!1),this.addEventListener("touchend",s,!1))}function r(){this.addEventListener&&this.addEventListener("touchstart",a,!1)}i.d(e,"a",function(){return m});var l,u,c,h,d=i(0),f=i.n(d),p=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),m={},g=!1,v=function(){function t(e){n(this,t),this.version="1.0.0",this.enabled="ontouchstart"in document.documentElement,this.preventDefault=!1,this.moveThreshold=75,this.timeThreshold=200,this.$=e,this._init()}return p(t,[{key:"_init",value:function(){var t=this.$;t.event.special.swipe={setup:r},t.each(["left","up","down","right"],function(){t.event.special["swipe"+this]={setup:function(){t(this).on("swipe",t.noop)}}})}}]),t}();m.setupSpotSwipe=function(t){t.spotSwipe=new v(t)},m.setupTouchHandler=function(t){t.fn.addTouch=function(){this.each(function(i,n){t(n).bind("touchstart touchmove touchend touchcancel",function(){e(event)})});var e=function(t){var e,i=t.changedTouches,n=i[0],s={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup"},o=s[t.type];"MouseEvent"in window&&"function"==typeof window.MouseEvent?e=new window.MouseEvent(o,{bubbles:!0,cancelable:!0,screenX:n.screenX,screenY:n.screenY,clientX:n.clientX,clientY:n.clientY}):(e=document.createEvent("MouseEvent"),e.initMouseEvent(o,!0,!0,window,1,n.screenX,n.screenY,n.clientX,n.clientY,!1,!1,!1,!1,0,null)),n.target.dispatchEvent(e)}}},m.init=function(t){void 0===t.spotSwipe&&(m.setupSpotSwipe(t),m.setupTouchHandler(t))}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return d});var a=i(0),r=i.n(a),l=i(3),u=i(1),c=i(2),h=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),d=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),h(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Accordion",this._init(),l.a.register("Accordion",{ENTER:"toggle",SPACE:"toggle",ARROW_DOWN:"next",ARROW_UP:"previous"})}},{key:"_init",value:function(){var t=this;this.$element.attr("role","tablist"),this.$tabs=this.$element.children("[data-accordion-item]"),this.$tabs.each(function(t,e){var n=r()(e),s=n.children("[data-tab-content]"),o=s[0].id||i.i(u.b)(6,"accordion"),a=e.id||o+"-label";n.find("a:first").attr({"aria-controls":o,role:"tab",id:a,"aria-expanded":!1,"aria-selected":!1}),s.attr({role:"tabpanel","aria-labelledby":a,"aria-hidden":!0,id:o})});var e=this.$element.find(".is-active").children("[data-tab-content]");this.firstTimeInit=!0,e.length&&(this.down(e,this.firstTimeInit),this.firstTimeInit=!1),this._checkDeepLink=function(){var e=window.location.hash;if(e.length){var i=t.$element.find('[href$="'+e+'"]'),n=r()(e);if(i.length&&n){if(i.parent("[data-accordion-item]").hasClass("is-active")||(t.down(n,t.firstTimeInit),t.firstTimeInit=!1),t.options.deepLinkSmudge){var s=t;r()(window).load(function(){var t=s.$element.offset();r()("html, body").animate({scrollTop:t.top},s.options.deepLinkSmudgeDelay)})}t.$element.trigger("deeplink.zf.accordion",[i,n])}}},this.options.deepLink&&this._checkDeepLink(),this._events()}},{key:"_events",value:function(){var t=this;this.$tabs.each(function(){var e=r()(this),i=e.children("[data-tab-content]");i.length&&e.children("a").off("click.zf.accordion keydown.zf.accordion").on("click.zf.accordion",function(e){e.preventDefault(),t.toggle(i)}).on("keydown.zf.accordion",function(n){l.a.handleKey(n,"Accordion",{toggle:function(){t.toggle(i)},next:function(){var i=e.next().find("a").focus();t.options.multiExpand||i.trigger("click.zf.accordion")},previous:function(){var i=e.prev().find("a").focus();t.options.multiExpand||i.trigger("click.zf.accordion")},handled:function(){n.preventDefault(),n.stopPropagation()}})})}),this.options.deepLink&&r()(window).on("popstate",this._checkDeepLink)}},{key:"toggle",value:function(t){if(t.closest("[data-accordion]").is("[disabled]"))return void console.info("Cannot toggle an accordion that is disabled.");if(t.parent().hasClass("is-active")?this.up(t):this.down(t),this.options.deepLink){var e=t.prev("a").attr("href");this.options.updateHistory?history.pushState({},"",e):history.replaceState({},"",e)}}},{key:"down",value:function(t,e){var i=this;if(t.closest("[data-accordion]").is("[disabled]")&&!e)return void console.info("Cannot call down on an accordion that is disabled.");if(t.attr("aria-hidden",!1).parent("[data-tab-content]").addBack().parent().addClass("is-active"),!this.options.multiExpand&&!e){var n=this.$element.children(".is-active").children("[data-tab-content]");n.length&&this.up(n.not(t))}t.slideDown(this.options.slideSpeed,function(){i.$element.trigger("down.zf.accordion",[t])}),r()("#"+t.attr("aria-labelledby")).attr({"aria-expanded":!0,"aria-selected":!0})}},{key:"up",value:function(t){if(t.closest("[data-accordion]").is("[disabled]"))return void console.info("Cannot call up on an accordion that is disabled.");var e=t.parent().siblings(),i=this;(this.options.allowAllClosed||e.hasClass("is-active"))&&t.parent().hasClass("is-active")&&(t.slideUp(i.options.slideSpeed,function(){i.$element.trigger("up.zf.accordion",[t])}),t.attr("aria-hidden",!0).parent().removeClass("is-active"),r()("#"+t.attr("aria-labelledby")).attr({"aria-expanded":!1,"aria-selected":!1}))}},{key:"_destroy",value:function(){this.$element.find("[data-tab-content]").stop(!0).slideUp(0).css("display",""),this.$element.find("a").off(".zf.accordion"),this.options.deepLink&&r()(window).off("popstate",this._checkDeepLink)}}]),e}(c.a);d.defaults={slideSpeed:250,multiExpand:!1,allowAllClosed:!1,deepLink:!1,deepLinkSmudge:!1,deepLinkSmudgeDelay:300,updateHistory:!1}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return f});var a=i(0),r=i.n(a),l=i(3),u=i(9),c=i(1),h=i(2),d=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),f=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),d(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="AccordionMenu",this._init(),l.a.register("AccordionMenu",{ENTER:"toggle",SPACE:"toggle",ARROW_RIGHT:"open",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"close",ESCAPE:"closeAll"})}},{key:"_init",value:function(){u.a.Feather(this.$element,"accordion");var t=this;this.$element.find("[data-submenu]").not(".is-active").slideUp(0),this.$element.attr({role:"tree","aria-multiselectable":this.options.multiOpen}),this.$menuLinks=this.$element.find(".is-accordion-submenu-parent"),this.$menuLinks.each(function(){var e=this.id||i.i(c.b)(6,"acc-menu-link"),n=r()(this),s=n.children("[data-submenu]"),o=s[0].id||i.i(c.b)(6,"acc-menu"),a=s.hasClass("is-active");t.options.submenuToggle?(n.addClass("has-submenu-toggle"),n.children("a").after('<button id="'+e+'" class="submenu-toggle" aria-controls="'+o+'" aria-expanded="'+a+'" title="'+t.options.submenuToggleText+'"><span class="submenu-toggle-text">'+t.options.submenuToggleText+"</span></button>")):n.attr({"aria-controls":o,"aria-expanded":a,id:e}),s.attr({"aria-labelledby":e,"aria-hidden":!a,role:"group",id:o})}),this.$element.find("li").attr({role:"treeitem"});var e=this.$element.find(".is-active");if(e.length){var t=this;e.each(function(){t.down(r()(this))})}this._events()}},{key:"_events",value:function(){var t=this;this.$element.find("li").each(function(){var e=r()(this).children("[data-submenu]");e.length&&(t.options.submenuToggle?r()(this).children(".submenu-toggle").off("click.zf.accordionMenu").on("click.zf.accordionMenu",function(i){t.toggle(e)}):r()(this).children("a").off("click.zf.accordionMenu").on("click.zf.accordionMenu",function(i){i.preventDefault(),t.toggle(e)}))}).on("keydown.zf.accordionmenu",function(e){var i,n,s=r()(this),o=s.parent("ul").children("li"),a=s.children("[data-submenu]");o.each(function(t){if(r()(this).is(s))return i=o.eq(Math.max(0,t-1)).find("a").first(),n=o.eq(Math.min(t+1,o.length-1)).find("a").first(),r()(this).children("[data-submenu]:visible").length&&(n=s.find("li:first-child").find("a").first()),r()(this).is(":first-child")?i=s.parents("li").first().find("a").first():i.parents("li").first().children("[data-submenu]:visible").length&&(i=i.parents("li").find("li:last-child").find("a").first()),void(r()(this).is(":last-child")&&(n=s.parents("li").first().next("li").find("a").first()))}),l.a.handleKey(e,"AccordionMenu",{open:function(){a.is(":hidden")&&(t.down(a),a.find("li").first().find("a").first().focus())},close:function(){a.length&&!a.is(":hidden")?t.up(a):s.parent("[data-submenu]").length&&(t.up(s.parent("[data-submenu]")),s.parents("li").first().find("a").first().focus())},up:function(){return i.focus(),!0},down:function(){return n.focus(),!0},toggle:function(){return!t.options.submenuToggle&&(s.children("[data-submenu]").length?(t.toggle(s.children("[data-submenu]")),!0):void 0)},closeAll:function(){t.hideAll()},handled:function(t){t&&e.preventDefault(),e.stopImmediatePropagation()}})})}},{key:"hideAll",value:function(){this.up(this.$element.find("[data-submenu]"))}},{key:"showAll",value:function(){this.down(this.$element.find("[data-submenu]"))}},{key:"toggle",value:function(t){t.is(":animated")||(t.is(":hidden")?this.down(t):this.up(t))}},{key:"down",value:function(t){var e=this;this.options.multiOpen||this.up(this.$element.find(".is-active").not(t.parentsUntil(this.$element).add(t))),t.addClass("is-active").attr({"aria-hidden":!1}),this.options.submenuToggle?t.prev(".submenu-toggle").attr({"aria-expanded":!0}):t.parent(".is-accordion-submenu-parent").attr({"aria-expanded":!0}),t.slideDown(e.options.slideSpeed,function(){e.$element.trigger("down.zf.accordionMenu",[t])})}},{key:"up",value:function(t){var e=this;t.slideUp(e.options.slideSpeed,function(){e.$element.trigger("up.zf.accordionMenu",[t])});var i=t.find("[data-submenu]").slideUp(0).addBack().attr("aria-hidden",!0);this.options.submenuToggle?i.prev(".submenu-toggle").attr("aria-expanded",!1):i.parent(".is-accordion-submenu-parent").attr("aria-expanded",!1)}},{key:"_destroy",value:function(){this.$element.find("[data-submenu]").slideDown(0).css("display",""),this.$element.find("a").off("click.zf.accordionMenu"),this.options.submenuToggle&&(this.$element.find(".has-submenu-toggle").removeClass("has-submenu-toggle"),this.$element.find(".submenu-toggle").remove()),u.a.Burn(this.$element,"accordion")}}]),e}(h.a);f.defaults={slideSpeed:250,submenuToggle:!1,submenuToggleText:"Toggle menu",multiOpen:!0}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return p});var a=i(0),r=i.n(a),l=i(3),u=i(9),c=i(1),h=i(7),d=i(2),f=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),p=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),f(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Drilldown",this._init(),l.a.register("Drilldown",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close",TAB:"down",SHIFT_TAB:"up"})}},{key:"_init",value:function(){u.a.Feather(this.$element,"drilldown"),this.options.autoApplyClass&&this.$element.addClass("drilldown"),this.$element.attr({role:"tree","aria-multiselectable":!1}),this.$submenuAnchors=this.$element.find("li.is-drilldown-submenu-parent").children("a"),this.$submenus=this.$submenuAnchors.parent("li").children("[data-submenu]").attr("role","group"),this.$menuItems=this.$element.find("li").not(".js-drilldown-back").attr("role","treeitem").find("a"),this.$element.attr("data-mutate",this.$element.attr("data-drilldown")||i.i(c.b)(6,"drilldown")),this._prepareMenu(),this._registerEvents(),this._keyboardEvents()}},{key:"_prepareMenu",value:function(){var t=this;this.$submenuAnchors.each(function(){var e=r()(this),i=e.parent();t.options.parentLink&&e.clone().prependTo(i.children("[data-submenu]")).wrap('<li class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>'),e.data("savedHref",e.attr("href")).removeAttr("href").attr("tabindex",0),e.children("[data-submenu]").attr({"aria-hidden":!0,tabindex:0,role:"group"}),t._events(e)}),this.$submenus.each(function(){var e=r()(this);if(!e.find(".js-drilldown-back").length)switch(t.options.backButtonPosition){case"bottom":e.append(t.options.backButton);break;case"top":e.prepend(t.options.backButton);break;default:
-console.error("Unsupported backButtonPosition value '"+t.options.backButtonPosition+"'")}t._back(e)}),this.$submenus.addClass("invisible"),this.options.autoHeight||this.$submenus.addClass("drilldown-submenu-cover-previous"),this.$element.parent().hasClass("is-drilldown")||(this.$wrapper=r()(this.options.wrapper).addClass("is-drilldown"),this.options.animateHeight&&this.$wrapper.addClass("animate-height"),this.$element.wrap(this.$wrapper)),this.$wrapper=this.$element.parent(),this.$wrapper.css(this._getMaxDims())}},{key:"_resize",value:function(){this.$wrapper.css({"max-width":"none","min-height":"none"}),this.$wrapper.css(this._getMaxDims())}},{key:"_events",value:function(t){var e=this;t.off("click.zf.drilldown").on("click.zf.drilldown",function(i){if(r()(i.target).parentsUntil("ul","li").hasClass("is-drilldown-submenu-parent")&&(i.stopImmediatePropagation(),i.preventDefault()),e._show(t.parent("li")),e.options.closeOnClick){var n=r()("body");n.off(".zf.drilldown").on("click.zf.drilldown",function(t){t.target===e.$element[0]||r.a.contains(e.$element[0],t.target)||(t.preventDefault(),e._hideAll(),n.off(".zf.drilldown"))})}})}},{key:"_registerEvents",value:function(){this.options.scrollTop&&(this._bindHandler=this._scrollTop.bind(this),this.$element.on("open.zf.drilldown hide.zf.drilldown closed.zf.drilldown",this._bindHandler)),this.$element.on("mutateme.zf.trigger",this._resize.bind(this))}},{key:"_scrollTop",value:function(){var t=this,e=""!=t.options.scrollTopElement?r()(t.options.scrollTopElement):t.$element,i=parseInt(e.offset().top+t.options.scrollTopOffset,10);r()("html, body").stop(!0).animate({scrollTop:i},t.options.animationDuration,t.options.animationEasing,function(){this===r()("html")[0]&&t.$element.trigger("scrollme.zf.drilldown")})}},{key:"_keyboardEvents",value:function(){var t=this;this.$menuItems.add(this.$element.find(".js-drilldown-back > a, .is-submenu-parent-item > a")).on("keydown.zf.drilldown",function(e){var n,s,o=r()(this),a=o.parent("li").parent("ul").children("li").children("a");a.each(function(t){if(r()(this).is(o))return n=a.eq(Math.max(0,t-1)),void(s=a.eq(Math.min(t+1,a.length-1)))}),l.a.handleKey(e,"Drilldown",{next:function(){if(o.is(t.$submenuAnchors))return t._show(o.parent("li")),o.parent("li").one(i.i(c.c)(o),function(){o.parent("li").find("ul li a").filter(t.$menuItems).first().focus()}),!0},previous:function(){return t._hide(o.parent("li").parent("ul")),o.parent("li").parent("ul").one(i.i(c.c)(o),function(){setTimeout(function(){o.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0},up:function(){return n.focus(),!o.is(t.$element.find("> li:first-child > a"))},down:function(){return s.focus(),!o.is(t.$element.find("> li:last-child > a"))},close:function(){o.is(t.$element.find("> li > a"))||(t._hide(o.parent().parent()),o.parent().parent().siblings("a").focus())},open:function(){return o.is(t.$menuItems)?o.is(t.$submenuAnchors)?(t._show(o.parent("li")),o.parent("li").one(i.i(c.c)(o),function(){o.parent("li").find("ul li a").filter(t.$menuItems).first().focus()}),!0):void 0:(t._hide(o.parent("li").parent("ul")),o.parent("li").parent("ul").one(i.i(c.c)(o),function(){setTimeout(function(){o.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0)},handled:function(t){t&&e.preventDefault(),e.stopImmediatePropagation()}})})}},{key:"_hideAll",value:function(){var t=this.$element.find(".is-drilldown-submenu.is-active").addClass("is-closing");this.options.autoHeight&&this.$wrapper.css({height:t.parent().closest("ul").data("calcHeight")}),t.one(i.i(c.c)(t),function(e){t.removeClass("is-active is-closing")}),this.$element.trigger("closed.zf.drilldown")}},{key:"_back",value:function(t){var e=this;t.off("click.zf.drilldown"),t.children(".js-drilldown-back").on("click.zf.drilldown",function(i){i.stopImmediatePropagation(),e._hide(t);var n=t.parent("li").parent("ul").parent("li");n.length&&e._show(n)})}},{key:"_menuLinkEvents",value:function(){var t=this;this.$menuItems.not(".is-drilldown-submenu-parent").off("click.zf.drilldown").on("click.zf.drilldown",function(e){setTimeout(function(){t._hideAll()},0)})}},{key:"_show",value:function(t){this.options.autoHeight&&this.$wrapper.css({height:t.children("[data-submenu]").data("calcHeight")}),t.attr("aria-expanded",!0),t.children("[data-submenu]").addClass("is-active").removeClass("invisible").attr("aria-hidden",!1),this.$element.trigger("open.zf.drilldown",[t])}},{key:"_hide",value:function(t){this.options.autoHeight&&this.$wrapper.css({height:t.parent().closest("ul").data("calcHeight")});t.parent("li").attr("aria-expanded",!1),t.attr("aria-hidden",!0).addClass("is-closing"),t.addClass("is-closing").one(i.i(c.c)(t),function(){t.removeClass("is-active is-closing"),t.blur().addClass("invisible")}),t.trigger("hide.zf.drilldown",[t])}},{key:"_getMaxDims",value:function(){var t=0,e={},i=this;return this.$submenus.add(this.$element).each(function(){var n=(r()(this).children("li").length,h.a.GetDimensions(this).height);t=n>t?n:t,i.options.autoHeight&&(r()(this).data("calcHeight",n),r()(this).hasClass("is-drilldown-submenu")||(e.height=n))}),this.options.autoHeight||(e["min-height"]=t+"px"),e["max-width"]=this.$element[0].getBoundingClientRect().width+"px",e}},{key:"_destroy",value:function(){this.options.scrollTop&&this.$element.off(".zf.drilldown",this._bindHandler),this._hideAll(),this.$element.off("mutateme.zf.trigger"),u.a.Burn(this.$element,"drilldown"),this.$element.unwrap().find(".js-drilldown-back, .is-submenu-parent-item").remove().end().find(".is-active, .is-closing, .is-drilldown-submenu").removeClass("is-active is-closing is-drilldown-submenu").end().find("[data-submenu]").removeAttr("aria-hidden tabindex role"),this.$submenuAnchors.each(function(){r()(this).off(".zf.drilldown")}),this.$submenus.removeClass("drilldown-submenu-cover-previous invisible"),this.$element.find("a").each(function(){var t=r()(this);t.removeAttr("tabindex"),t.data("savedHref")&&t.attr("href",t.data("savedHref")).removeData("savedHref")})}}]),e}(d.a);p.defaults={autoApplyClass:!0,backButton:'<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',backButtonPosition:"top",wrapper:"<div></div>",parentLink:!1,closeOnClick:!1,autoHeight:!1,animateHeight:!1,scrollTop:!1,scrollTopElement:"",scrollTopOffset:0,animationDuration:500,animationEasing:"swing"}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return p});var a=i(0),r=i.n(a),l=i(3),u=i(9),c=i(7),h=i(1),d=i(2),f=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),p=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),f(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="DropdownMenu",this._init(),l.a.register("DropdownMenu",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close"})}},{key:"_init",value:function(){u.a.Feather(this.$element,"dropdown");var t=this.$element.find("li.is-dropdown-submenu-parent");this.$element.children(".is-dropdown-submenu-parent").children(".is-dropdown-submenu").addClass("first-sub"),this.$menuItems=this.$element.find('[role="menuitem"]'),this.$tabs=this.$element.children('[role="menuitem"]'),this.$tabs.find("ul.is-dropdown-submenu").addClass(this.options.verticalClass),"auto"===this.options.alignment?this.$element.hasClass(this.options.rightClass)||i.i(h.a)()||this.$element.parents(".top-bar-right").is("*")?(this.options.alignment="right",t.addClass("opens-left")):(this.options.alignment="left",t.addClass("opens-right")):"right"===this.options.alignment?t.addClass("opens-left"):t.addClass("opens-right"),this.changed=!1,this._events()}},{key:"_isVertical",value:function(){return"block"===this.$tabs.css("display")||"column"===this.$element.css("flex-direction")}},{key:"_isRtl",value:function(){return this.$element.hasClass("align-right")||i.i(h.a)()&&!this.$element.hasClass("align-left")}},{key:"_events",value:function(){var t=this,e="ontouchstart"in window||void 0!==window.ontouchstart,i="is-dropdown-submenu-parent",n=function(n){var s=r()(n.target).parentsUntil("ul","."+i),o=s.hasClass(i),a="true"===s.attr("data-is-click"),l=s.children(".is-dropdown-submenu");if(o)if(a){if(!t.options.closeOnClick||!t.options.clickOpen&&!e||t.options.forceFollow&&e)return;n.stopImmediatePropagation(),n.preventDefault(),t._hide(s)}else n.preventDefault(),n.stopImmediatePropagation(),t._show(l),s.add(s.parentsUntil(t.$element,"."+i)).attr("data-is-click",!0)};(this.options.clickOpen||e)&&this.$menuItems.on("click.zf.dropdownmenu touchstart.zf.dropdownmenu",n),t.options.closeOnClickInside&&this.$menuItems.on("click.zf.dropdownmenu",function(e){r()(this).hasClass(i)||t._hide()}),this.options.disableHover||this.$menuItems.on("mouseenter.zf.dropdownmenu",function(e){var n=r()(this);n.hasClass(i)&&(clearTimeout(n.data("_delay")),n.data("_delay",setTimeout(function(){t._show(n.children(".is-dropdown-submenu"))},t.options.hoverDelay)))}).on("mouseleave.zf.dropdownmenu",function(e){var n=r()(this);if(n.hasClass(i)&&t.options.autoclose){if("true"===n.attr("data-is-click")&&t.options.clickOpen)return!1;clearTimeout(n.data("_delay")),n.data("_delay",setTimeout(function(){t._hide(n)},t.options.closingTime))}}),this.$menuItems.on("keydown.zf.dropdownmenu",function(e){var i,n,s=r()(e.target).parentsUntil("ul",'[role="menuitem"]'),o=t.$tabs.index(s)>-1,a=o?t.$tabs:s.siblings("li").add(s);a.each(function(t){if(r()(this).is(s))return i=a.eq(t-1),void(n=a.eq(t+1))});var u=function(){n.children("a:first").focus(),e.preventDefault()},c=function(){i.children("a:first").focus(),e.preventDefault()},h=function(){var i=s.children("ul.is-dropdown-submenu");i.length&&(t._show(i),s.find("li > a:first").focus(),e.preventDefault())},d=function(){var i=s.parent("ul").parent("li");i.children("a:first").focus(),t._hide(i),e.preventDefault()},f={open:h,close:function(){t._hide(t.$element),t.$menuItems.eq(0).children("a").focus(),e.preventDefault()},handled:function(){e.stopImmediatePropagation()}};o?t._isVertical()?t._isRtl()?r.a.extend(f,{down:u,up:c,next:d,previous:h}):r.a.extend(f,{down:u,up:c,next:h,previous:d}):t._isRtl()?r.a.extend(f,{next:c,previous:u,down:h,up:d}):r.a.extend(f,{next:u,previous:c,down:h,up:d}):t._isRtl()?r.a.extend(f,{next:d,previous:h,down:u,up:c}):r.a.extend(f,{next:h,previous:d,down:u,up:c}),l.a.handleKey(e,"DropdownMenu",f)})}},{key:"_addBodyHandler",value:function(){var t=r()(document.body),e=this;t.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu").on("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu",function(i){e.$element.find(i.target).length||(e._hide(),t.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu"))})}},{key:"_show",value:function(t){var e=this.$tabs.index(this.$tabs.filter(function(e,i){return r()(i).find(t).length>0})),i=t.parent("li.is-dropdown-submenu-parent").siblings("li.is-dropdown-submenu-parent");this._hide(i,e),t.css("visibility","hidden").addClass("js-dropdown-active").parent("li.is-dropdown-submenu-parent").addClass("is-active");var n=c.a.ImNotTouchingYou(t,null,!0);if(!n){var s="left"===this.options.alignment?"-right":"-left",o=t.parent(".is-dropdown-submenu-parent");o.removeClass("opens"+s).addClass("opens-"+this.options.alignment),n=c.a.ImNotTouchingYou(t,null,!0),n||o.removeClass("opens-"+this.options.alignment).addClass("opens-inner"),this.changed=!0}t.css("visibility",""),this.options.closeOnClick&&this._addBodyHandler(),this.$element.trigger("show.zf.dropdownmenu",[t])}},{key:"_hide",value:function(t,e){var i;if(i=t&&t.length?t:void 0!==e?this.$tabs.not(function(t,i){return t===e}):this.$element,i.hasClass("is-active")||i.find(".is-active").length>0){if(i.find("li.is-active").add(i).attr({"data-is-click":!1}).removeClass("is-active"),i.find("ul.js-dropdown-active").removeClass("js-dropdown-active"),this.changed||i.find("opens-inner").length){var n="left"===this.options.alignment?"right":"left";i.find("li.is-dropdown-submenu-parent").add(i).removeClass("opens-inner opens-"+this.options.alignment).addClass("opens-"+n),this.changed=!1}this.$element.trigger("hide.zf.dropdownmenu",[i])}}},{key:"_destroy",value:function(){this.$menuItems.off(".zf.dropdownmenu").removeAttr("data-is-click").removeClass("is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner"),r()(document.body).off(".zf.dropdownmenu"),u.a.Burn(this.$element,"dropdown")}}]),e}(d.a);p.defaults={disableHover:!1,autoclose:!0,hoverDelay:50,clickOpen:!1,closingTime:500,alignment:"auto",closeOnClick:!0,closeOnClickInside:!0,verticalClass:"vertical",rightClass:"align-right",forceFollow:!0}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function a(t,e){var i=e.indexOf(t);return i===e.length-1?e[0]:e[i+1]}i.d(e,"a",function(){return m});var r=i(7),l=i(2),u=i(1),c=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),h=["left","right","top","bottom"],d=["top","bottom","center"],f=["left","right","center"],p={left:d,right:d,top:f,bottom:f},m=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),c(e,[{key:"_init",value:function(){this.triedPositions={},this.position="auto"===this.options.position?this._getDefaultPosition():this.options.position,this.alignment="auto"===this.options.alignment?this._getDefaultAlignment():this.options.alignment}},{key:"_getDefaultPosition",value:function(){return"bottom"}},{key:"_getDefaultAlignment",value:function(){switch(this.position){case"bottom":case"top":return i.i(u.a)()?"right":"left";case"left":case"right":return"bottom"}}},{key:"_reposition",value:function(){this._alignmentsExhausted(this.position)?(this.position=a(this.position,h),this.alignment=p[this.position][0]):this._realign()}},{key:"_realign",value:function(){this._addTriedPosition(this.position,this.alignment),this.alignment=a(this.alignment,p[this.position])}},{key:"_addTriedPosition",value:function(t,e){this.triedPositions[t]=this.triedPositions[t]||[],this.triedPositions[t].push(e)}},{key:"_positionsExhausted",value:function(){for(var t=!0,e=0;e<h.length;e++)t=t&&this._alignmentsExhausted(h[e]);return t}},{key:"_alignmentsExhausted",value:function(t){return this.triedPositions[t]&&this.triedPositions[t].length==p[t].length}},{key:"_getVOffset",value:function(){return this.options.vOffset}},{key:"_getHOffset",value:function(){return this.options.hOffset}},{key:"_setPosition",value:function(t,e,i){if("false"===t.attr("aria-expanded"))return!1;r.a.GetDimensions(e),r.a.GetDimensions(t);if(e.offset(r.a.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset())),!this.options.allowOverlap){for(var n=1e8,s={position:this.position,alignment:this.alignment};!this._positionsExhausted();){var o=r.a.OverlapArea(e,i,!1,!1,this.options.allowBottomOverlap);if(0===o)return;o<n&&(n=o,s={position:this.position,alignment:this.alignment}),this._reposition(),e.offset(r.a.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}this.position=s.position,this.alignment=s.alignment,e.offset(r.a.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}}}]),e}(l.a);m.defaults={position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,vOffset:0,hOffset:0}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return h});var a=i(0),r=i.n(a),l=i(1),u=i(2),c=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),h=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),c(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="SmoothScroll",this._init()}},{key:"_init",value:function(){var t=this.$element[0].id||i.i(l.b)(6,"smooth-scroll");this.$element.attr({id:t}),this._events()}},{key:"_events",value:function(){var t=this,i=function(i){if(!r()(this).is('a[href^="#"]'))return!1;var n=this.getAttribute("href");t._inTransition=!0,e.scrollToLoc(n,t.options,function(){t._inTransition=!1}),i.preventDefault()};this.$element.on("click.zf.smoothScroll",i),this.$element.on("click.zf.smoothScroll",'a[href^="#"]',i)}}],[{key:"scrollToLoc",value:function(t){var i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:e.defaults,n=arguments[2];if(!r()(t).length)return!1;var s=Math.round(r()(t).offset().top-i.threshold/2-i.offset);r()("html, body").stop(!0).animate({scrollTop:s},i.animationDuration,i.animationEasing,function(){n&&"function"==typeof n&&n()})}}]),e}(u.a);h.defaults={animationDuration:500,animationEasing:"linear",threshold:50,offset:0}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return d});var a=i(0),r=i.n(a),l=i(3),u=i(8),c=i(2),h=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),d=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),h(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Tabs",this._init(),l.a.register("Tabs",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"previous",ARROW_DOWN:"next",ARROW_LEFT:"previous"})}},{key:"_init",value:function(){var t=this,e=this;if(this.$element.attr({role:"tablist"}),this.$tabTitles=this.$element.find("."+this.options.linkClass),this.$tabContent=r()('[data-tabs-content="'+this.$element[0].id+'"]'),this.$tabTitles.each(function(){var t=r()(this),i=t.find("a"),n=t.hasClass(""+e.options.linkActiveClass),s=i.attr("data-tabs-target")||i[0].hash.slice(1),o=i[0].id?i[0].id:s+"-label",a=r()("#"+s);t.attr({role:"presentation"}),i.attr({role:"tab","aria-controls":s,"aria-selected":n,id:o,tabindex:n?"0":"-1"}),a.attr({role:"tabpanel","aria-labelledby":o}),n||a.attr("aria-hidden","true"),n&&e.options.autoFocus&&r()(window).load(function(){r()("html, body").animate({scrollTop:t.offset().top},e.options.deepLinkSmudgeDelay,function(){i.focus()})})}),this.options.matchHeight){var n=this.$tabContent.find("img");n.length?i.i(u.a)(n,this._setHeight.bind(this)):this._setHeight()}this._checkDeepLink=function(){var e=window.location.hash;if(e.length){var i=t.$element.find('[href$="'+e+'"]');if(i.length){if(t.selectTab(r()(e),!0),t.options.deepLinkSmudge){var n=t.$element.offset();r()("html, body").animate({scrollTop:n.top},t.options.deepLinkSmudgeDelay)}t.$element.trigger("deeplink.zf.tabs",[i,r()(e)])}}},this.options.deepLink&&this._checkDeepLink(),this._events()}},{key:"_events",value:function(){this._addKeyHandler(),this._addClickHandler(),this._setHeightMqHandler=null,this.options.matchHeight&&(this._setHeightMqHandler=this._setHeight.bind(this),r()(window).on("changed.zf.mediaquery",this._setHeightMqHandler)),this.options.deepLink&&r()(window).on("popstate",this._checkDeepLink)}},{key:"_addClickHandler",value:function(){var t=this;this.$element.off("click.zf.tabs").on("click.zf.tabs","."+this.options.linkClass,function(e){e.preventDefault(),e.stopPropagation(),t._handleTabChange(r()(this))})}},{key:"_addKeyHandler",value:function(){var t=this;this.$tabTitles.off("keydown.zf.tabs").on("keydown.zf.tabs",function(e){if(9!==e.which){var i,n,s=r()(this),o=s.parent("ul").children("li");o.each(function(e){if(r()(this).is(s))return void(t.options.wrapOnKeys?(i=0===e?o.last():o.eq(e-1),n=e===o.length-1?o.first():o.eq(e+1)):(i=o.eq(Math.max(0,e-1)),n=o.eq(Math.min(e+1,o.length-1))))}),l.a.handleKey(e,"Tabs",{open:function(){s.find('[role="tab"]').focus(),t._handleTabChange(s)},previous:function(){i.find('[role="tab"]').focus(),t._handleTabChange(i)},next:function(){n.find('[role="tab"]').focus(),t._handleTabChange(n)},handled:function(){e.stopPropagation(),e.preventDefault()}})}})}},{key:"_handleTabChange",value:function(t,e){if(t.hasClass(""+this.options.linkActiveClass))return void(this.options.activeCollapse&&(this._collapseTab(t),this.$element.trigger("collapse.zf.tabs",[t])));var i=this.$element.find("."+this.options.linkClass+"."+this.options.linkActiveClass),n=t.find('[role="tab"]'),s=n.attr("data-tabs-target")||n[0].hash.slice(1),o=this.$tabContent.find("#"+s);if(this._collapseTab(i),this._openTab(t),this.options.deepLink&&!e){var a=t.find("a").attr("href");this.options.updateHistory?history.pushState({},"",a):history.replaceState({},"",a)}this.$element.trigger("change.zf.tabs",[t,o]),o.find("[data-mutate]").trigger("mutateme.zf.trigger")}},{key:"_openTab",value:function(t){var e=t.find('[role="tab"]'),i=e.attr("data-tabs-target")||e[0].hash.slice(1),n=this.$tabContent.find("#"+i);t.addClass(""+this.options.linkActiveClass),e.attr({"aria-selected":"true",tabindex:"0"}),n.addClass(""+this.options.panelActiveClass).removeAttr("aria-hidden")}},{key:"_collapseTab",value:function(t){var e=t.removeClass(""+this.options.linkActiveClass).find('[role="tab"]').attr({"aria-selected":"false",tabindex:-1});r()("#"+e.attr("aria-controls")).removeClass(""+this.options.panelActiveClass).attr({"aria-hidden":"true"})}},{key:"selectTab",value:function(t,e){var i;i="object"==typeof t?t[0].id:t,i.indexOf("#")<0&&(i="#"+i);var n=this.$tabTitles.find('[href$="'+i+'"]').parent("."+this.options.linkClass);this._handleTabChange(n,e)}},{key:"_setHeight",value:function(){var t=0,e=this;this.$tabContent.find("."+this.options.panelClass).css("height","").each(function(){var i=r()(this),n=i.hasClass(""+e.options.panelActiveClass);n||i.css({visibility:"hidden",display:"block"});var s=this.getBoundingClientRect().height;n||i.css({visibility:"",display:""}),t=s>t?s:t}).css("height",t+"px")}},{key:"_destroy",value:function(){this.$element.find("."+this.options.linkClass).off(".zf.tabs").hide().end().find("."+this.options.panelClass).hide(),this.options.matchHeight&&null!=this._setHeightMqHandler&&r()(window).off("changed.zf.mediaquery",this._setHeightMqHandler),this.options.deepLink&&r()(window).off("popstate",this._checkDeepLink)}}]),e}(c.a);d.defaults={deepLink:!1,deepLinkSmudge:!1,deepLinkSmudgeDelay:300,updateHistory:!1,autoFocus:!1,wrapOnKeys:!0,matchHeight:!1,activeCollapse:!1,linkClass:"tabs-title",linkActiveClass:"is-active",panelClass:"tabs-panel",panelActiveClass:"is-active"}},function(t,e,i){"use strict";function n(t,e,i){var n,s,o=this,a=e.duration,r=Object.keys(t.data())[0]||"timer",l=-1;this.isPaused=!1,this.restart=function(){l=-1,clearTimeout(s),this.start()},this.start=function(){this.isPaused=!1,clearTimeout(s),l=l<=0?a:l,t.data("paused",!1),n=Date.now(),s=setTimeout(function(){e.infinite&&o.restart(),i&&"function"==typeof i&&i()},l),t.trigger("timerstart.zf."+r)},this.pause=function(){this.isPaused=!0,clearTimeout(s),t.data("paused",!0);var e=Date.now();l-=e-n,t.trigger("timerpaused.zf."+r)}}i.d(e,"a",function(){return n});var s=i(0);i.n(s)},function(t,e,i){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var n=i(0),s=i.n(n),o=i(21),a=i(1),r=i(7),l=i(8),u=i(3),c=i(4),h=i(6),d=i(9),f=i(18),p=i(10),m=i(5),g=i(20),v=i(11),b=i(12),y=i(13),w=i(22),_=i(14),$=i(23),k=i(24),C=i(25),z=i(26),O=i(27),T=i(29),E=i(30),P=i(31),A=i(32),F=i(16),x=i(33),D=i(17),S=i(34),R=i(35),H=i(28);o.a.addToJquery(s.a),o.a.rtl=a.a,o.a.GetYoDigits=a.b,o.a.transitionend=a.c,o.a.Box=r.a,o.a.onImagesLoaded=l.a,o.a.Keyboard=u.a,o.a.MediaQuery=c.a,o.a.Motion=h.a,o.a.Move=h.b,o.a.Nest=d.a,o.a.Timer=f.a,p.a.init(s.a),m.a.init(s.a,o.a),o.a.plugin(g.a,"Abide"),o.a.plugin(v.a,"Accordion"),o.a.plugin(b.a,"AccordionMenu"),o.a.plugin(y.a,"Drilldown"),o.a.plugin(w.a,"Dropdown"),o.a.plugin(_.a,"DropdownMenu"),o.a.plugin($.a,"Equalizer"),o.a.plugin(k.a,"Interchange"),o.a.plugin(C.a,"Magellan"),o.a.plugin(z.a,"OffCanvas"),o.a.plugin(O.a,"Orbit"),o.a.plugin(T.a,"ResponsiveMenu"),o.a.plugin(E.a,"ResponsiveToggle"),o.a.plugin(P.a,"Reveal"),o.a.plugin(A.a,"Slider"),o.a.plugin(F.a,"SmoothScroll"),o.a.plugin(x.a,"Sticky"),o.a.plugin(D.a,"Tabs"),o.a.plugin(S.a,"Toggler"),o.a.plugin(R.a,"Tooltip"),o.a.plugin(H.a,"ResponsiveAccordionTabs")},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return c});var a=i(0),r=i.n(a),l=i(2),u=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),c=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),u(e,[{key:"_setup",value:function(t){var i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.$element=t,this.options=r.a.extend(!0,{},e.defaults,this.$element.data(),i),this.className="Abide",this._init()}},{key:"_init",value:function(){this.$inputs=this.$element.find("input, textarea, select"),this._events()}},{key:"_events",value:function(){var t=this;this.$element.off(".abide").on("reset.zf.abide",function(){t.resetForm()}).on("submit.zf.abide",function(){return t.validateForm()}),"fieldChange"===this.options.validateOn&&this.$inputs.off("change.zf.abide").on("change.zf.abide",function(e){t.validateInput(r()(e.target))}),this.options.liveValidate&&this.$inputs.off("input.zf.abide").on("input.zf.abide",function(e){t.validateInput(r()(e.target))}),this.options.validateOnBlur&&this.$inputs.off("blur.zf.abide").on("blur.zf.abide",function(e){t.validateInput(r()(e.target))})}},{key:"_reflow",value:function(){this._init()}},{key:"requiredCheck",value:function(t){if(!t.attr("required"))return!0;var e=!0;switch(t[0].type){case"checkbox":e=t[0].checked;break;case"select":case"select-one":case"select-multiple":var i=t.find("option:selected");i.length&&i.val()||(e=!1);break;default:t.val()&&t.val().length||(e=!1)}return e}},{key:"findFormError",value:function(t){var e=t[0].id,i=t.siblings(this.options.formErrorSelector);return i.length||(i=t.parent().find(this.options.formErrorSelector)),i=i.add(this.$element.find('[data-form-error-for="'+e+'"]'))}},{key:"findLabel",value:function(t){var e=t[0].id,i=this.$element.find('label[for="'+e+'"]');return i.length?i:t.closest("label")}},{key:"findRadioLabels",value:function(t){var e=this,i=t.map(function(t,i){var n=i.id,s=e.$element.find('label[for="'+n+'"]');return s.length||(s=r()(i).closest("label")),s[0]});return r()(i)}},{key:"addErrorClasses",value:function(t){var e=this.findLabel(t),i=this.findFormError(t);e.length&&e.addClass(this.options.labelErrorClass),i.length&&i.addClass(this.options.formErrorClass),t.addClass(this.options.inputErrorClass).attr("data-invalid","")}},{key:"removeRadioErrorClasses",value:function(t){var e=this.$element.find(':radio[name="'+t+'"]'),i=this.findRadioLabels(e),n=this.findFormError(e);i.length&&i.removeClass(this.options.labelErrorClass),n.length&&n.removeClass(this.options.formErrorClass),e.removeClass(this.options.inputErrorClass).removeAttr("data-invalid")}},{key:"removeErrorClasses",value:function(t){if("radio"==t[0].type)return this.removeRadioErrorClasses(t.attr("name"));var e=this.findLabel(t),i=this.findFormError(t);e.length&&e.removeClass(this.options.labelErrorClass),i.length&&i.removeClass(this.options.formErrorClass),t.removeClass(this.options.inputErrorClass).removeAttr("data-invalid")}},{key:"validateInput",value:function(t){var e=this.requiredCheck(t),i=!1,n=!0,s=t.attr("data-validator"),o=!0;if(t.is("[data-abide-ignore]")||t.is('[type="hidden"]')||t.is("[disabled]"))return!0;switch(t[0].type){case"radio":i=this.validateRadio(t.attr("name"));break;case"checkbox":i=e;break;case"select":case"select-one":case"select-multiple":i=e;break;default:i=this.validateText(t)}s&&(n=this.matchValidation(t,s,t.attr("required"))),t.attr("data-equalto")&&(o=this.options.validators.equalTo(t));var a=-1===[e,i,n,o].indexOf(!1),l=(a?"valid":"invalid")+".zf.abide";if(a){var u=this.$element.find('[data-equalto="'+t.attr("id")+'"]');if(u.length){var c=this;u.each(function(){r()(this).val()&&c.validateInput(r()(this))})}}return this[a?"removeErrorClasses":"addErrorClasses"](t),t.trigger(l,[t]),a}},{key:"validateForm",value:function(){var t=[],e=this;this.$inputs.each(function(){t.push(e.validateInput(r()(this)))});var i=-1===t.indexOf(!1);return this.$element.find("[data-abide-error]").css("display",i?"none":"block"),this.$element.trigger((i?"formvalid":"forminvalid")+".zf.abide",[this.$element]),i}},{key:"validateText",value:function(t,e){e=e||t.attr("pattern")||t.attr("type")
-;var i=t.val(),n=!1;return i.length?n=this.options.patterns.hasOwnProperty(e)?this.options.patterns[e].test(i):e===t.attr("type")||new RegExp(e).test(i):t.prop("required")||(n=!0),n}},{key:"validateRadio",value:function(t){var e=this.$element.find(':radio[name="'+t+'"]'),i=!1,n=!1;return e.each(function(t,e){r()(e).attr("required")&&(n=!0)}),n||(i=!0),i||e.each(function(t,e){r()(e).prop("checked")&&(i=!0)}),i}},{key:"matchValidation",value:function(t,e,i){var n=this;return i=!!i,-1===e.split(" ").map(function(e){return n.options.validators[e](t,i,t.parent())}).indexOf(!1)}},{key:"resetForm",value:function(){var t=this.$element,e=this.options;r()("."+e.labelErrorClass,t).not("small").removeClass(e.labelErrorClass),r()("."+e.inputErrorClass,t).not("small").removeClass(e.inputErrorClass),r()(e.formErrorSelector+"."+e.formErrorClass).removeClass(e.formErrorClass),t.find("[data-abide-error]").css("display","none"),r()(":input",t).not(":button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]").val("").removeAttr("data-invalid"),r()(":input:radio",t).not("[data-abide-ignore]").prop("checked",!1).removeAttr("data-invalid"),r()(":input:checkbox",t).not("[data-abide-ignore]").prop("checked",!1).removeAttr("data-invalid"),t.trigger("formreset.zf.abide",[t])}},{key:"_destroy",value:function(){var t=this;this.$element.off(".abide").find("[data-abide-error]").css("display","none"),this.$inputs.off(".abide").each(function(){t.removeErrorClasses(r()(this))})}}]),e}(l.a);c.defaults={validateOn:"fieldChange",labelErrorClass:"is-invalid-label",inputErrorClass:"is-invalid-input",formErrorSelector:".form-error",formErrorClass:"is-visible",liveValidate:!1,validateOnBlur:!1,patterns:{alpha:/^[a-zA-Z]+$/,alpha_numeric:/^[a-zA-Z0-9]+$/,integer:/^[-+]?\d+$/,number:/^[-+]?\d*(?:[\.\,]\d+)?$/,card:/^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,cvv:/^([0-9]){3,4}$/,email:/^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,url:/^(https?|ftp|file|ssh):\/\/(((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/,domain:/^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,datetime:/^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,date:/(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,time:/^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,dateISO:/^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,month_day_year:/^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,day_month_year:/^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,color:/^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,website:{test:function(t){return c.defaults.patterns.domain.test(t)||c.defaults.patterns.url.test(t)}}},validators:{equalTo:function(t,e,i){return r()("#"+t.attr("data-equalto")).val()===t.val()}}}},function(t,e,i){"use strict";function n(t){if(void 0===Function.prototype.name){var e=/function\s([^(]{1,})\(/,i=e.exec(t.toString());return i&&i.length>1?i[1].trim():""}return void 0===t.prototype?t.constructor.name:t.prototype.constructor.name}function s(t){return"true"===t||"false"!==t&&(isNaN(1*t)?t:parseFloat(t))}function o(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}i.d(e,"a",function(){return c});var a=i(0),r=i.n(a),l=i(1),u=i(4),c={version:"6.4.3",_plugins:{},_uuids:[],plugin:function(t,e){var i=e||n(t),s=o(i);this._plugins[s]=this[i]=t},registerPlugin:function(t,e){var s=e?o(e):n(t.constructor).toLowerCase();t.uuid=i.i(l.b)(6,s),t.$element.attr("data-"+s)||t.$element.attr("data-"+s,t.uuid),t.$element.data("zfPlugin")||t.$element.data("zfPlugin",t),t.$element.trigger("init.zf."+s),this._uuids.push(t.uuid)},unregisterPlugin:function(t){var e=o(n(t.$element.data("zfPlugin").constructor));this._uuids.splice(this._uuids.indexOf(t.uuid),1),t.$element.removeAttr("data-"+e).removeData("zfPlugin").trigger("destroyed.zf."+e);for(var i in t)t[i]=null},reInit:function(t){var e=t instanceof r.a;try{if(e)t.each(function(){r()(this).data("zfPlugin")._init()});else{var i=typeof t,n=this;({object:function(t){t.forEach(function(t){t=o(t),r()("[data-"+t+"]").foundation("_init")})},string:function(){t=o(t),r()("[data-"+t+"]").foundation("_init")},undefined:function(){this.object(Object.keys(n._plugins))}})[i](t)}}catch(t){console.error(t)}finally{return t}},reflow:function(t,e){void 0===e?e=Object.keys(this._plugins):"string"==typeof e&&(e=[e]);var i=this;r.a.each(e,function(e,n){var o=i._plugins[n];r()(t).find("[data-"+n+"]").addBack("[data-"+n+"]").each(function(){var t=r()(this),e={};if(t.data("zfPlugin"))return void console.warn("Tried to initialize "+n+" on an element that already has a Foundation plugin.");t.attr("data-options")&&t.attr("data-options").split(";").forEach(function(t,i){var n=t.split(":").map(function(t){return t.trim()});n[0]&&(e[n[0]]=s(n[1]))});try{t.data("zfPlugin",new o(r()(this),e))}catch(t){console.error(t)}finally{return}})})},getFnName:n,addToJquery:function(t){var e=function(e){var i=typeof e,s=t(".no-js");if(s.length&&s.removeClass("no-js"),"undefined"===i)u.a._init(),c.reflow(this);else{if("string"!==i)throw new TypeError("We're sorry, "+i+" is not a valid parameter. You must use a string representing the method you wish to invoke.");var o=Array.prototype.slice.call(arguments,1),a=this.data("zfPlugin");if(void 0===a||void 0===a[e])throw new ReferenceError("We're sorry, '"+e+"' is not an available method for "+(a?n(a):"this element")+".");1===this.length?a[e].apply(a,o):this.each(function(i,n){a[e].apply(t(n).data("zfPlugin"),o)})}return this};return t.fn.foundation=e,t}};c.util={throttle:function(t,e){var i=null;return function(){var n=this,s=arguments;null===i&&(i=setTimeout(function(){t.apply(n,s),i=null},e))}}},window.Foundation=c,function(){Date.now&&window.Date.now||(window.Date.now=Date.now=function(){return(new Date).getTime()});for(var t=["webkit","moz"],e=0;e<t.length&&!window.requestAnimationFrame;++e){var i=t[e];window.requestAnimationFrame=window[i+"RequestAnimationFrame"],window.cancelAnimationFrame=window[i+"CancelAnimationFrame"]||window[i+"CancelRequestAnimationFrame"]}if(/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)||!window.requestAnimationFrame||!window.cancelAnimationFrame){var n=0;window.requestAnimationFrame=function(t){var e=Date.now(),i=Math.max(n+16,e);return setTimeout(function(){t(n=i)},i-e)},window.cancelAnimationFrame=clearTimeout}window.performance&&window.performance.now||(window.performance={start:Date.now(),now:function(){return Date.now()-this.start}})}(),Function.prototype.bind||(Function.prototype.bind=function(t){if("function"!=typeof this)throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable");var e=Array.prototype.slice.call(arguments,1),i=this,n=function(){},s=function(){return i.apply(this instanceof n?this:t,e.concat(Array.prototype.slice.call(arguments)))};return this.prototype&&(n.prototype=this.prototype),s.prototype=new n,s})},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return p});var a=i(0),r=i.n(a),l=i(3),u=i(1),c=i(15),h=i(5),d=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),f=function t(e,i,n){null===e&&(e=Function.prototype);var s=Object.getOwnPropertyDescriptor(e,i);if(void 0===s){var o=Object.getPrototypeOf(e);return null===o?void 0:t(o,i,n)}if("value"in s)return s.value;var a=s.get;if(void 0!==a)return a.call(n)},p=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),d(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Dropdown",h.a.init(r.a),this._init(),l.a.register("Dropdown",{ENTER:"open",SPACE:"open",ESCAPE:"close"})}},{key:"_init",value:function(){var t=this.$element.attr("id");this.$anchors=r()('[data-toggle="'+t+'"]').length?r()('[data-toggle="'+t+'"]'):r()('[data-open="'+t+'"]'),this.$anchors.attr({"aria-controls":t,"data-is-focus":!1,"data-yeti-box":t,"aria-haspopup":!0,"aria-expanded":!1}),this._setCurrentAnchor(this.$anchors.first()),this.options.parentClass?this.$parent=this.$element.parents("."+this.options.parentClass):this.$parent=null,this.$element.attr({"aria-hidden":"true","data-yeti-box":t,"data-resize":t,"aria-labelledby":this.$currentAnchor.id||i.i(u.b)(6,"dd-anchor")}),f(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_init",this).call(this),this._events()}},{key:"_getDefaultPosition",value:function(){var t=this.$element[0].className.match(/(top|left|right|bottom)/g);return t?t[0]:"bottom"}},{key:"_getDefaultAlignment",value:function(){var t=/float-(\S+)/.exec(this.$currentAnchor.className);return t?t[1]:f(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_getDefaultAlignment",this).call(this)}},{key:"_setPosition",value:function(){f(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_setPosition",this).call(this,this.$currentAnchor,this.$element,this.$parent)}},{key:"_setCurrentAnchor",value:function(t){this.$currentAnchor=r()(t)}},{key:"_events",value:function(){var t=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":this.close.bind(this),"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":this._setPosition.bind(this)}),this.$anchors.off("click.zf.trigger").on("click.zf.trigger",function(){t._setCurrentAnchor(this)}),this.options.hover&&(this.$anchors.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){t._setCurrentAnchor(this);var e=r()("body").data();void 0!==e.whatinput&&"mouse"!==e.whatinput||(clearTimeout(t.timeout),t.timeout=setTimeout(function(){t.open(),t.$anchors.data("hover",!0)},t.options.hoverDelay))}).on("mouseleave.zf.dropdown",function(){clearTimeout(t.timeout),t.timeout=setTimeout(function(){t.close(),t.$anchors.data("hover",!1)},t.options.hoverDelay)}),this.options.hoverPane&&this.$element.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){clearTimeout(t.timeout)}).on("mouseleave.zf.dropdown",function(){clearTimeout(t.timeout),t.timeout=setTimeout(function(){t.close(),t.$anchors.data("hover",!1)},t.options.hoverDelay)})),this.$anchors.add(this.$element).on("keydown.zf.dropdown",function(e){var i=r()(this);l.a.findFocusable(t.$element);l.a.handleKey(e,"Dropdown",{open:function(){i.is(t.$anchors)&&(t.open(),t.$element.attr("tabindex",-1).focus(),e.preventDefault())},close:function(){t.close(),t.$anchors.focus()}})})}},{key:"_addBodyHandler",value:function(){var t=r()(document.body).not(this.$element),e=this;t.off("click.zf.dropdown").on("click.zf.dropdown",function(i){e.$anchors.is(i.target)||e.$anchors.find(i.target).length||e.$element.find(i.target).length||(e.close(),t.off("click.zf.dropdown"))})}},{key:"open",value:function(){if(this.$element.trigger("closeme.zf.dropdown",this.$element.attr("id")),this.$anchors.addClass("hover").attr({"aria-expanded":!0}),this.$element.addClass("is-opening"),this._setPosition(),this.$element.removeClass("is-opening").addClass("is-open").attr({"aria-hidden":!1}),this.options.autoFocus){var t=l.a.findFocusable(this.$element);t.length&&t.eq(0).focus()}this.options.closeOnClick&&this._addBodyHandler(),this.options.trapFocus&&l.a.trapFocus(this.$element),this.$element.trigger("show.zf.dropdown",[this.$element])}},{key:"close",value:function(){if(!this.$element.hasClass("is-open"))return!1;this.$element.removeClass("is-open").attr({"aria-hidden":!0}),this.$anchors.removeClass("hover").attr("aria-expanded",!1),this.$element.trigger("hide.zf.dropdown",[this.$element]),this.options.trapFocus&&l.a.releaseFocus(this.$element)}},{key:"toggle",value:function(){if(this.$element.hasClass("is-open")){if(this.$anchors.data("hover"))return;this.close()}else this.open()}},{key:"_destroy",value:function(){this.$element.off(".zf.trigger").hide(),this.$anchors.off(".zf.dropdown"),r()(document.body).off("click.zf.dropdown")}}]),e}(c.a);p.defaults={parentClass:null,hoverDelay:250,hover:!1,hoverPane:!1,vOffset:0,hOffset:0,positionClass:"",position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,trapFocus:!1,autoFocus:!1,closeOnClick:!1}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return f});var a=i(0),r=i.n(a),l=i(4),u=i(8),c=i(1),h=i(2),d=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),f=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),d(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Equalizer",this._init()}},{key:"_init",value:function(){var t=this.$element.attr("data-equalizer")||"",e=this.$element.find('[data-equalizer-watch="'+t+'"]');l.a._init(),this.$watched=e.length?e:this.$element.find("[data-equalizer-watch]"),this.$element.attr("data-resize",t||i.i(c.b)(6,"eq")),this.$element.attr("data-mutate",t||i.i(c.b)(6,"eq")),this.hasNested=this.$element.find("[data-equalizer]").length>0,this.isNested=this.$element.parentsUntil(document.body,"[data-equalizer]").length>0,this.isOn=!1,this._bindHandler={onResizeMeBound:this._onResizeMe.bind(this),onPostEqualizedBound:this._onPostEqualized.bind(this)};var n,s=this.$element.find("img");this.options.equalizeOn?(n=this._checkMQ(),r()(window).on("changed.zf.mediaquery",this._checkMQ.bind(this))):this._events(),(void 0!==n&&!1===n||void 0===n)&&(s.length?i.i(u.a)(s,this._reflow.bind(this)):this._reflow())}},{key:"_pauseEvents",value:function(){this.isOn=!1,this.$element.off({".zf.equalizer":this._bindHandler.onPostEqualizedBound,"resizeme.zf.trigger":this._bindHandler.onResizeMeBound,"mutateme.zf.trigger":this._bindHandler.onResizeMeBound})}},{key:"_onResizeMe",value:function(t){this._reflow()}},{key:"_onPostEqualized",value:function(t){t.target!==this.$element[0]&&this._reflow()}},{key:"_events",value:function(){this._pauseEvents(),this.hasNested?this.$element.on("postequalized.zf.equalizer",this._bindHandler.onPostEqualizedBound):(this.$element.on("resizeme.zf.trigger",this._bindHandler.onResizeMeBound),this.$element.on("mutateme.zf.trigger",this._bindHandler.onResizeMeBound)),this.isOn=!0}},{key:"_checkMQ",value:function(){var t=!l.a.is(this.options.equalizeOn);return t?this.isOn&&(this._pauseEvents(),this.$watched.css("height","auto")):this.isOn||this._events(),t}},{key:"_killswitch",value:function(){}},{key:"_reflow",value:function(){if(!this.options.equalizeOnStack&&this._isStacked())return this.$watched.css("height","auto"),!1;this.options.equalizeByRow?this.getHeightsByRow(this.applyHeightByRow.bind(this)):this.getHeights(this.applyHeight.bind(this))}},{key:"_isStacked",value:function(){return!this.$watched[0]||!this.$watched[1]||this.$watched[0].getBoundingClientRect().top!==this.$watched[1].getBoundingClientRect().top}},{key:"getHeights",value:function(t){for(var e=[],i=0,n=this.$watched.length;i<n;i++)this.$watched[i].style.height="auto",e.push(this.$watched[i].offsetHeight);t(e)}},{key:"getHeightsByRow",value:function(t){var e=this.$watched.length?this.$watched.first().offset().top:0,i=[],n=0;i[n]=[];for(var s=0,o=this.$watched.length;s<o;s++){this.$watched[s].style.height="auto";var a=r()(this.$watched[s]).offset().top;a!=e&&(n++,i[n]=[],e=a),i[n].push([this.$watched[s],this.$watched[s].offsetHeight])}for(var l=0,u=i.length;l<u;l++){var c=r()(i[l]).map(function(){return this[1]}).get(),h=Math.max.apply(null,c);i[l].push(h)}t(i)}},{key:"applyHeight",value:function(t){var e=Math.max.apply(null,t);this.$element.trigger("preequalized.zf.equalizer"),this.$watched.css("height",e),this.$element.trigger("postequalized.zf.equalizer")}},{key:"applyHeightByRow",value:function(t){this.$element.trigger("preequalized.zf.equalizer");for(var e=0,i=t.length;e<i;e++){var n=t[e].length,s=t[e][n-1];if(n<=2)r()(t[e][0][0]).css({height:"auto"});else{this.$element.trigger("preequalizedrow.zf.equalizer");for(var o=0,a=n-1;o<a;o++)r()(t[e][o][0]).css({height:s});this.$element.trigger("postequalizedrow.zf.equalizer")}}this.$element.trigger("postequalized.zf.equalizer")}},{key:"_destroy",value:function(){this._pauseEvents(),this.$watched.css("height","auto")}}]),e}(h.a);f.defaults={equalizeOnStack:!1,equalizeByRow:!1,equalizeOn:""}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return d});var a=i(0),r=i.n(a),l=i(4),u=i(2),c=i(1),h=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),d=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),h(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,i),this.rules=[],this.currentPath="",this.className="Interchange",this._init(),this._events()}},{key:"_init",value:function(){l.a._init();var t=this.$element[0].id||i.i(c.b)(6,"interchange");this.$element.attr({"data-resize":t,id:t}),this._addBreakpoints(),this._generateRules(),this._reflow()}},{key:"_events",value:function(){var t=this;this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(){return t._reflow()})}},{key:"_reflow",value:function(){var t;for(var e in this.rules)if(this.rules.hasOwnProperty(e)){var i=this.rules[e];window.matchMedia(i.query).matches&&(t=i)}t&&this.replace(t.path)}},{key:"_addBreakpoints",value:function(){for(var t in l.a.queries)if(l.a.queries.hasOwnProperty(t)){var i=l.a.queries[t];e.SPECIAL_QUERIES[i.name]=i.value}}},{key:"_generateRules",value:function(t){var i,n=[];i=this.options.rules?this.options.rules:this.$element.data("interchange"),i="string"==typeof i?i.match(/\[.*?\]/g):i;for(var s in i)if(i.hasOwnProperty(s)){var o=i[s].slice(1,-1).split(", "),a=o.slice(0,-1).join(""),r=o[o.length-1];e.SPECIAL_QUERIES[r]&&(r=e.SPECIAL_QUERIES[r]),n.push({path:a,query:r})}this.rules=n}},{key:"replace",value:function(t){if(this.currentPath!==t){var e=this,i="replaced.zf.interchange";"IMG"===this.$element[0].nodeName?this.$element.attr("src",t).on("load",function(){e.currentPath=t}).trigger(i):t.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)?(t=t.replace(/\(/g,"%28").replace(/\)/g,"%29"),this.$element.css({"background-image":"url("+t+")"}).trigger(i)):r.a.get(t,function(n){e.$element.html(n).trigger(i),r()(n).foundation(),e.currentPath=t})}}},{key:"_destroy",value:function(){this.$element.off("resizeme.zf.trigger")}}]),e}(u.a);d.defaults={rules:null},d.SPECIAL_QUERIES={landscape:"screen and (orientation: landscape)",portrait:"screen and (orientation: portrait)",retina:"only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)"}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return d});var a=i(0),r=i.n(a),l=i(1),u=i(2),c=i(16),h=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),d=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),h(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Magellan",this._init(),this.calcPoints()}},{key:"_init",value:function(){var t=this.$element[0].id||i.i(l.b)(6,"magellan");this.$targets=r()("[data-magellan-target]"),this.$links=this.$element.find("a"),this.$element.attr({"data-resize":t,"data-scroll":t,id:t}),this.$active=r()(),this.scrollPos=parseInt(window.pageYOffset,10),this._events()}},{key:"calcPoints",value:function(){var t=this,e=document.body,i=document.documentElement;this.points=[],this.winHeight=Math.round(Math.max(window.innerHeight,i.clientHeight)),this.docHeight=Math.round(Math.max(e.scrollHeight,e.offsetHeight,i.clientHeight,i.scrollHeight,i.offsetHeight)),this.$targets.each(function(){var e=r()(this),i=Math.round(e.offset().top-t.options.threshold);e.targetPoint=i,t.points.push(i)})}},{key:"_events",value:function(){var t=this;r()("html, body"),t.options.animationDuration,t.options.animationEasing;r()(window).one("load",function(){t.options.deepLinking&&location.hash&&t.scrollToLoc(location.hash),t.calcPoints(),t._updateActive()}),this.$element.on({"resizeme.zf.trigger":this.reflow.bind(this),"scrollme.zf.trigger":this._updateActive.bind(this)}).on("click.zf.magellan",'a[href^="#"]',function(e){e.preventDefault();var i=this.getAttribute("href");t.scrollToLoc(i)}),this._deepLinkScroll=function(e){t.options.deepLinking&&t.scrollToLoc(window.location.hash)},r()(window).on("popstate",this._deepLinkScroll)}},{key:"scrollToLoc",value:function(t){this._inTransition=!0;var e=this,i={animationEasing:this.options.animationEasing,animationDuration:this.options.animationDuration,threshold:this.options.threshold,offset:this.options.offset};c.a.scrollToLoc(t,i,function(){e._inTransition=!1,e._updateActive()})}},{key:"reflow",value:function(){this.calcPoints(),this._updateActive()}},{key:"_updateActive",value:function(){if(!this._inTransition){var t,e=parseInt(window.pageYOffset,10);if(e+this.winHeight===this.docHeight)t=this.points.length-1;else if(e<this.points[0])t=void 0;else{var i=this.scrollPos<e,n=this,s=this.points.filter(function(t,s){return i?t-n.options.offset<=e:t-n.options.offset-n.options.threshold<=e});t=s.length?s.length-1:0}if(this.$active.removeClass(this.options.activeClass),this.$active=this.$links.filter('[href="#'+this.$targets.eq(t).data("magellan-target")+'"]').addClass(this.options.activeClass),this.options.deepLinking){var o="";void 0!=t&&(o=this.$active[0].getAttribute("href")),o!==window.location.hash&&(window.history.pushState?window.history.pushState(null,null,o):window.location.hash=o)}this.scrollPos=e,this.$element.trigger("update.zf.magellan",[this.$active])}}},{key:"_destroy",value:function(){if(this.$element.off(".zf.trigger .zf.magellan").find("."+this.options.activeClass).removeClass(this.options.activeClass),this.options.deepLinking){var t=this.$active[0].getAttribute("href");window.location.hash.replace(t,"")}r()(window).off("popstate",this._deepLinkScroll)}}]),e}(u.a);d.defaults={animationDuration:500,animationEasing:"linear",threshold:50,activeClass:"is-active",deepLinking:!1,offset:0}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return p});var a=i(0),r=i.n(a),l=i(3),u=i(4),c=i(1),h=i(2),d=i(5),f=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),p=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),f(e,[{key:"_setup",value:function(t,i){var n=this;this.className="OffCanvas",this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.contentClasses={base:[],reveal:[]},this.$lastTrigger=r()(),this.$triggers=r()(),this.position="left",this.$content=r()(),this.nested=!!this.options.nested,r()(["push","overlap"]).each(function(t,e){n.contentClasses.base.push("has-transition-"+e)}),r()(["left","right","top","bottom"]).each(function(t,e){n.contentClasses.base.push("has-position-"+e),n.contentClasses.reveal.push("has-reveal-"+e)}),d.a.init(r.a),u.a._init(),this._init(),this._events(),l.a.register("OffCanvas",{ESCAPE:"close"})}},{key:"_init",value:function(){var t=this.$element.attr("id");if(this.$element.attr("aria-hidden","true"),this.options.contentId?this.$content=r()("#"+this.options.contentId):this.$element.siblings("[data-off-canvas-content]").length?this.$content=this.$element.siblings("[data-off-canvas-content]").first():this.$content=this.$element.closest("[data-off-canvas-content]").first(),this.options.contentId?this.options.contentId&&null===this.options.nested&&console.warn("Remember to use the nested option if using the content ID option!"):this.nested=0===this.$element.siblings("[data-off-canvas-content]").length,!0===this.nested&&(this.options.transition="overlap",this.$element.removeClass("is-transition-push")),this.$element.addClass("is-transition-"+this.options.transition+" is-closed"),this.$triggers=r()(document).find('[data-open="'+t+'"], [data-close="'+t+'"], [data-toggle="'+t+'"]').attr("aria-expanded","false").attr("aria-controls",t),this.position=this.$element.is(".position-left, .position-top, .position-right, .position-bottom")?this.$element.attr("class").match(/position\-(left|top|right|bottom)/)[1]:this.position,!0===this.options.contentOverlay){var e=document.createElement("div"),i="fixed"===r()(this.$element).css("position")?"is-overlay-fixed":"is-overlay-absolute";e.setAttribute("class","js-off-canvas-overlay "+i),this.$overlay=r()(e),"is-overlay-fixed"===i?r()(this.$overlay).insertAfter(this.$element):this.$content.append(this.$overlay)}this.options.isRevealed=this.options.isRevealed||new RegExp(this.options.revealClass,"g").test(this.$element[0].className),!0===this.options.isRevealed&&(this.options.revealOn=this.options.revealOn||this.$element[0].className.match(/(reveal-for-medium|reveal-for-large)/g)[0].split("-")[2],this._setMQChecker()),this.options.transitionTime&&this.$element.css("transition-duration",this.options.transitionTime),this._removeContentClasses()}},{key:"_events",value:function(){if(this.$element.off(".zf.trigger .zf.offcanvas").on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":this.close.bind(this),"toggle.zf.trigger":this.toggle.bind(this),"keydown.zf.offcanvas":this._handleKeyboard.bind(this)}),!0===this.options.closeOnClick){(this.options.contentOverlay?this.$overlay:this.$content).on({"click.zf.offcanvas":this.close.bind(this)})}}},{key:"_setMQChecker",value:function(){var t=this;r()(window).on("changed.zf.mediaquery",function(){u.a.atLeast(t.options.revealOn)?t.reveal(!0):t.reveal(!1)}).one("load.zf.offcanvas",function(){u.a.atLeast(t.options.revealOn)&&t.reveal(!0)})}},{key:"_removeContentClasses",value:function(t){"boolean"!=typeof t?this.$content.removeClass(this.contentClasses.base.join(" ")):!1===t&&this.$content.removeClass("has-reveal-"+this.position)}},{key:"_addContentClasses",value:function(t){this._removeContentClasses(t),"boolean"!=typeof t?this.$content.addClass("has-transition-"+this.options.transition+" has-position-"+this.position):!0===t&&this.$content.addClass("has-reveal-"+this.position)}},{key:"reveal",value:function(t){t?(this.close(),this.isRevealed=!0,this.$element.attr("aria-hidden","false"),this.$element.off("open.zf.trigger toggle.zf.trigger"),this.$element.removeClass("is-closed")):(this.isRevealed=!1,this.$element.attr("aria-hidden","true"),this.$element.off("open.zf.trigger toggle.zf.trigger").on({"open.zf.trigger":this.open.bind(this),"toggle.zf.trigger":this.toggle.bind(this)}),this.$element.addClass("is-closed")),this._addContentClasses(t)}},{key:"_stopScrolling",value:function(t){return!1}},{key:"_recordScrollable",value:function(t){var e=this
-;e.scrollHeight!==e.clientHeight&&(0===e.scrollTop&&(e.scrollTop=1),e.scrollTop===e.scrollHeight-e.clientHeight&&(e.scrollTop=e.scrollHeight-e.clientHeight-1)),e.allowUp=e.scrollTop>0,e.allowDown=e.scrollTop<e.scrollHeight-e.clientHeight,e.lastY=t.originalEvent.pageY}},{key:"_stopScrollPropagation",value:function(t){var e=this,i=t.pageY<e.lastY,n=!i;e.lastY=t.pageY,i&&e.allowUp||n&&e.allowDown?t.stopPropagation():t.preventDefault()}},{key:"open",value:function(t,e){if(!this.$element.hasClass("is-open")&&!this.isRevealed){var n=this;e&&(this.$lastTrigger=e),"top"===this.options.forceTo?window.scrollTo(0,0):"bottom"===this.options.forceTo&&window.scrollTo(0,document.body.scrollHeight),this.options.transitionTime&&"overlap"!==this.options.transition?this.$element.siblings("[data-off-canvas-content]").css("transition-duration",this.options.transitionTime):this.$element.siblings("[data-off-canvas-content]").css("transition-duration",""),this.$element.addClass("is-open").removeClass("is-closed"),this.$triggers.attr("aria-expanded","true"),this.$element.attr("aria-hidden","false").trigger("opened.zf.offcanvas"),this.$content.addClass("is-open-"+this.position),!1===this.options.contentScroll&&(r()("body").addClass("is-off-canvas-open").on("touchmove",this._stopScrolling),this.$element.on("touchstart",this._recordScrollable),this.$element.on("touchmove",this._stopScrollPropagation)),!0===this.options.contentOverlay&&this.$overlay.addClass("is-visible"),!0===this.options.closeOnClick&&!0===this.options.contentOverlay&&this.$overlay.addClass("is-closable"),!0===this.options.autoFocus&&this.$element.one(i.i(c.c)(this.$element),function(){if(n.$element.hasClass("is-open")){var t=n.$element.find("[data-autofocus]");t.length?t.eq(0).focus():n.$element.find("a, button").eq(0).focus()}}),!0===this.options.trapFocus&&(this.$content.attr("tabindex","-1"),l.a.trapFocus(this.$element)),this._addContentClasses()}}},{key:"close",value:function(t){if(this.$element.hasClass("is-open")&&!this.isRevealed){var e=this;this.$element.removeClass("is-open"),this.$element.attr("aria-hidden","true").trigger("closed.zf.offcanvas"),this.$content.removeClass("is-open-left is-open-top is-open-right is-open-bottom"),!1===this.options.contentScroll&&(r()("body").removeClass("is-off-canvas-open").off("touchmove",this._stopScrolling),this.$element.off("touchstart",this._recordScrollable),this.$element.off("touchmove",this._stopScrollPropagation)),!0===this.options.contentOverlay&&this.$overlay.removeClass("is-visible"),!0===this.options.closeOnClick&&!0===this.options.contentOverlay&&this.$overlay.removeClass("is-closable"),this.$triggers.attr("aria-expanded","false"),!0===this.options.trapFocus&&(this.$content.removeAttr("tabindex"),l.a.releaseFocus(this.$element)),this.$element.one(i.i(c.c)(this.$element),function(t){e.$element.addClass("is-closed"),e._removeContentClasses()})}}},{key:"toggle",value:function(t,e){this.$element.hasClass("is-open")?this.close(t,e):this.open(t,e)}},{key:"_handleKeyboard",value:function(t){var e=this;l.a.handleKey(t,"OffCanvas",{close:function(){return e.close(),e.$lastTrigger.focus(),!0},handled:function(){t.stopPropagation(),t.preventDefault()}})}},{key:"_destroy",value:function(){this.close(),this.$element.off(".zf.trigger .zf.offcanvas"),this.$overlay.off(".zf.offcanvas")}}]),e}(h.a);p.defaults={closeOnClick:!0,contentOverlay:!0,contentId:null,nested:null,contentScroll:!0,transitionTime:null,transition:"push",forceTo:null,isRevealed:!1,revealOn:null,autoFocus:!0,revealClass:"reveal-for-",trapFocus:!1}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return g});var a=i(0),r=i.n(a),l=i(3),u=i(6),c=i(18),h=i(8),d=i(1),f=i(2),p=i(10),m=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),g=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),m(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Orbit",p.a.init(r.a),this._init(),l.a.register("Orbit",{ltr:{ARROW_RIGHT:"next",ARROW_LEFT:"previous"},rtl:{ARROW_LEFT:"next",ARROW_RIGHT:"previous"}})}},{key:"_init",value:function(){this._reset(),this.$wrapper=this.$element.find("."+this.options.containerClass),this.$slides=this.$element.find("."+this.options.slideClass);var t=this.$element.find("img"),e=this.$slides.filter(".is-active"),n=this.$element[0].id||i.i(d.b)(6,"orbit");this.$element.attr({"data-resize":n,id:n}),e.length||this.$slides.eq(0).addClass("is-active"),this.options.useMUI||this.$slides.addClass("no-motionui"),t.length?i.i(h.a)(t,this._prepareForOrbit.bind(this)):this._prepareForOrbit(),this.options.bullets&&this._loadBullets(),this._events(),this.options.autoPlay&&this.$slides.length>1&&this.geoSync(),this.options.accessible&&this.$wrapper.attr("tabindex",0)}},{key:"_loadBullets",value:function(){this.$bullets=this.$element.find("."+this.options.boxOfBullets).find("button")}},{key:"geoSync",value:function(){var t=this;this.timer=new c.a(this.$element,{duration:this.options.timerDelay,infinite:!1},function(){t.changeSlide(!0)}),this.timer.start()}},{key:"_prepareForOrbit",value:function(){this._setWrapperHeight()}},{key:"_setWrapperHeight",value:function(t){var e,i=0,n=0,s=this;this.$slides.each(function(){e=this.getBoundingClientRect().height,r()(this).attr("data-slide",n),/mui/g.test(r()(this)[0].className)||s.$slides.filter(".is-active")[0]===s.$slides.eq(n)[0]||r()(this).css({position:"relative",display:"none"}),i=e>i?e:i,n++}),n===this.$slides.length&&(this.$wrapper.css({height:i}),t&&t(i))}},{key:"_setSlideHeight",value:function(t){this.$slides.each(function(){r()(this).css("max-height",t)})}},{key:"_events",value:function(){var t=this;if(this.$element.off(".resizeme.zf.trigger").on({"resizeme.zf.trigger":this._prepareForOrbit.bind(this)}),this.$slides.length>1){if(this.options.swipe&&this.$slides.off("swipeleft.zf.orbit swiperight.zf.orbit").on("swipeleft.zf.orbit",function(e){e.preventDefault(),t.changeSlide(!0)}).on("swiperight.zf.orbit",function(e){e.preventDefault(),t.changeSlide(!1)}),this.options.autoPlay&&(this.$slides.on("click.zf.orbit",function(){t.$element.data("clickedOn",!t.$element.data("clickedOn")),t.timer[t.$element.data("clickedOn")?"pause":"start"]()}),this.options.pauseOnHover&&this.$element.on("mouseenter.zf.orbit",function(){t.timer.pause()}).on("mouseleave.zf.orbit",function(){t.$element.data("clickedOn")||t.timer.start()})),this.options.navButtons){this.$element.find("."+this.options.nextClass+", ."+this.options.prevClass).attr("tabindex",0).on("click.zf.orbit touchend.zf.orbit",function(e){e.preventDefault(),t.changeSlide(r()(this).hasClass(t.options.nextClass))})}this.options.bullets&&this.$bullets.on("click.zf.orbit touchend.zf.orbit",function(){if(/is-active/g.test(this.className))return!1;var e=r()(this).data("slide"),i=e>t.$slides.filter(".is-active").data("slide"),n=t.$slides.eq(e);t.changeSlide(i,n,e)}),this.options.accessible&&this.$wrapper.add(this.$bullets).on("keydown.zf.orbit",function(e){l.a.handleKey(e,"Orbit",{next:function(){t.changeSlide(!0)},previous:function(){t.changeSlide(!1)},handled:function(){r()(e.target).is(t.$bullets)&&t.$bullets.filter(".is-active").focus()}})})}}},{key:"_reset",value:function(){void 0!==this.$slides&&this.$slides.length>1&&(this.$element.off(".zf.orbit").find("*").off(".zf.orbit"),this.options.autoPlay&&this.timer.restart(),this.$slides.each(function(t){r()(t).removeClass("is-active is-active is-in").removeAttr("aria-live").hide()}),this.$slides.first().addClass("is-active").show(),this.$element.trigger("slidechange.zf.orbit",[this.$slides.first()]),this.options.bullets&&this._updateBullets(0))}},{key:"changeSlide",value:function(t,e,i){if(this.$slides){var n=this.$slides.filter(".is-active").eq(0);if(/mui/g.test(n[0].className))return!1;var s,o=this.$slides.first(),a=this.$slides.last(),r=t?"Right":"Left",l=t?"Left":"Right",c=this;s=e||(t?this.options.infiniteWrap?n.next("."+this.options.slideClass).length?n.next("."+this.options.slideClass):o:n.next("."+this.options.slideClass):this.options.infiniteWrap?n.prev("."+this.options.slideClass).length?n.prev("."+this.options.slideClass):a:n.prev("."+this.options.slideClass)),s.length&&(this.$element.trigger("beforeslidechange.zf.orbit",[n,s]),this.options.bullets&&(i=i||this.$slides.index(s),this._updateBullets(i)),this.options.useMUI&&!this.$element.is(":hidden")?(u.a.animateIn(s.addClass("is-active").css({position:"absolute",top:0}),this.options["animInFrom"+r],function(){s.css({position:"relative",display:"block"}).attr("aria-live","polite")}),u.a.animateOut(n.removeClass("is-active"),this.options["animOutTo"+l],function(){n.removeAttr("aria-live"),c.options.autoPlay&&!c.timer.isPaused&&c.timer.restart()})):(n.removeClass("is-active is-in").removeAttr("aria-live").hide(),s.addClass("is-active is-in").attr("aria-live","polite").show(),this.options.autoPlay&&!this.timer.isPaused&&this.timer.restart()),this.$element.trigger("slidechange.zf.orbit",[s]))}}},{key:"_updateBullets",value:function(t){var e=this.$element.find("."+this.options.boxOfBullets).find(".is-active").removeClass("is-active").blur(),i=e.find("span:last").detach();this.$bullets.eq(t).addClass("is-active").append(i)}},{key:"_destroy",value:function(){this.$element.off(".zf.orbit").find("*").off(".zf.orbit").end().hide()}}]),e}(f.a);g.defaults={bullets:!0,navButtons:!0,animInFromRight:"slide-in-right",animOutToRight:"slide-out-right",animInFromLeft:"slide-in-left",animOutToLeft:"slide-out-left",autoPlay:!0,timerDelay:5e3,infiniteWrap:!0,swipe:!0,pauseOnHover:!0,accessible:!0,containerClass:"orbit-container",slideClass:"orbit-slide",boxOfBullets:"orbit-bullets",nextClass:"orbit-next",prevClass:"orbit-previous",useMUI:!0}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return m});var a=i(0),r=i.n(a),l=i(4),u=i(1),c=i(2),h=i(11),d=i(17),f=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),p={tabs:{cssClass:"tabs",plugin:d.a},accordion:{cssClass:"accordion",plugin:h.a}},m=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),f(e,[{key:"_setup",value:function(t,e){this.$element=r()(t),this.options=r.a.extend({},this.$element.data(),e),this.rules=this.$element.data("responsive-accordion-tabs"),this.currentMq=null,this.currentPlugin=null,this.className="ResponsiveAccordionTabs",this.$element.attr("id")||this.$element.attr("id",i.i(u.b)(6,"responsiveaccordiontabs")),this._init(),this._events()}},{key:"_init",value:function(){if(l.a._init(),"string"==typeof this.rules){for(var t={},e=this.rules.split(" "),i=0;i<e.length;i++){var n=e[i].split("-"),s=n.length>1?n[0]:"small",o=n.length>1?n[1]:n[0];null!==p[o]&&(t[s]=p[o])}this.rules=t}this._getAllOptions(),r.a.isEmptyObject(this.rules)||this._checkMediaQueries()}},{key:"_getAllOptions",value:function(){var t=this;t.allOptions={};for(var e in p)if(p.hasOwnProperty(e)){var i=p[e];try{var n=r()("<ul></ul>"),s=new i.plugin(n,t.options);for(var o in s.options)if(s.options.hasOwnProperty(o)&&"zfPlugin"!==o){var a=s.options[o];t.allOptions[o]=a}s.destroy()}catch(t){}}}},{key:"_events",value:function(){var t=this;r()(window).on("changed.zf.mediaquery",function(){t._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var t,e=this;r.a.each(this.rules,function(e){l.a.atLeast(e)&&(t=e)}),t&&(this.currentPlugin instanceof this.rules[t].plugin||(r.a.each(p,function(t,i){e.$element.removeClass(i.cssClass)}),this.$element.addClass(this.rules[t].cssClass),this.currentPlugin&&(!this.currentPlugin.$element.data("zfPlugin")&&this.storezfData&&this.currentPlugin.$element.data("zfPlugin",this.storezfData),this.currentPlugin.destroy()),this._handleMarkup(this.rules[t].cssClass),this.currentPlugin=new this.rules[t].plugin(this.$element,{}),this.storezfData=this.currentPlugin.$element.data("zfPlugin")))}},{key:"_handleMarkup",value:function(t){var e=this,n="accordion",s=r()("[data-tabs-content="+this.$element.attr("id")+"]");if(s.length&&(n="tabs"),n!==t){var o=e.allOptions.linkClass?e.allOptions.linkClass:"tabs-title",a=e.allOptions.panelClass?e.allOptions.panelClass:"tabs-panel";this.$element.removeAttr("role");var l=this.$element.children("."+o+",[data-accordion-item]").removeClass(o).removeClass("accordion-item").removeAttr("data-accordion-item"),c=l.children("a").removeClass("accordion-title");if("tabs"===n?(s=s.children("."+a).removeClass(a).removeAttr("role").removeAttr("aria-hidden").removeAttr("aria-labelledby"),s.children("a").removeAttr("role").removeAttr("aria-controls").removeAttr("aria-selected")):s=l.children("[data-tab-content]").removeClass("accordion-content"),s.css({display:"",visibility:""}),l.css({display:"",visibility:""}),"accordion"===t)s.each(function(t,i){r()(i).appendTo(l.get(t)).addClass("accordion-content").attr("data-tab-content","").removeClass("is-active").css({height:""}),r()("[data-tabs-content="+e.$element.attr("id")+"]").after('<div id="tabs-placeholder-'+e.$element.attr("id")+'"></div>').detach(),l.addClass("accordion-item").attr("data-accordion-item",""),c.addClass("accordion-title")});else if("tabs"===t){var h=r()("[data-tabs-content="+e.$element.attr("id")+"]"),d=r()("#tabs-placeholder-"+e.$element.attr("id"));d.length?(h=r()('<div class="tabs-content"></div>').insertAfter(d).attr("data-tabs-content",e.$element.attr("id")),d.remove()):h=r()('<div class="tabs-content"></div>').insertAfter(e.$element).attr("data-tabs-content",e.$element.attr("id")),s.each(function(t,e){var n=r()(e).appendTo(h).addClass(a),s=c.get(t).hash.slice(1),o=r()(e).attr("id")||i.i(u.b)(6,"accordion");s!==o&&(""!==s?r()(e).attr("id",s):(s=o,r()(e).attr("id",s),r()(c.get(t)).attr("href",r()(c.get(t)).attr("href").replace("#","")+"#"+s))),r()(l.get(t)).hasClass("is-active")&&n.addClass("is-active")}),l.addClass(o)}}}},{key:"_destroy",value:function(){this.currentPlugin&&this.currentPlugin.destroy(),r()(window).off(".zf.ResponsiveAccordionTabs")}}]),e}(c.a);m.defaults={}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return g});var a=i(0),r=i.n(a),l=i(4),u=i(1),c=i(2),h=i(14),d=i(13),f=i(12),p=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),m={dropdown:{cssClass:"dropdown",plugin:h.a},drilldown:{cssClass:"drilldown",plugin:d.a},accordion:{cssClass:"accordion-menu",plugin:f.a}},g=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),p(e,[{key:"_setup",value:function(t,e){this.$element=r()(t),this.rules=this.$element.data("responsive-menu"),this.currentMq=null,this.currentPlugin=null,this.className="ResponsiveMenu",this._init(),this._events()}},{key:"_init",value:function(){if(l.a._init(),"string"==typeof this.rules){for(var t={},e=this.rules.split(" "),n=0;n<e.length;n++){var s=e[n].split("-"),o=s.length>1?s[0]:"small",a=s.length>1?s[1]:s[0];null!==m[a]&&(t[o]=m[a])}this.rules=t}r.a.isEmptyObject(this.rules)||this._checkMediaQueries(),this.$element.attr("data-mutate",this.$element.attr("data-mutate")||i.i(u.b)(6,"responsive-menu"))}},{key:"_events",value:function(){var t=this;r()(window).on("changed.zf.mediaquery",function(){t._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var t,e=this;r.a.each(this.rules,function(e){l.a.atLeast(e)&&(t=e)}),t&&(this.currentPlugin instanceof this.rules[t].plugin||(r.a.each(m,function(t,i){e.$element.removeClass(i.cssClass)}),this.$element.addClass(this.rules[t].cssClass),this.currentPlugin&&this.currentPlugin.destroy(),this.currentPlugin=new this.rules[t].plugin(this.$element,{})))}},{key:"_destroy",value:function(){this.currentPlugin.destroy(),r()(window).off(".zf.ResponsiveMenu")}}]),e}(c.a);g.defaults={}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return d});var a=i(0),r=i.n(a),l=i(4),u=i(6),c=i(2),h=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),d=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),h(e,[{key:"_setup",value:function(t,i){this.$element=r()(t),this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="ResponsiveToggle",this._init(),this._events()}},{key:"_init",value:function(){l.a._init();var t=this.$element.data("responsive-toggle");if(t||console.error("Your tab bar needs an ID of a Menu as the value of data-tab-bar."),this.$targetMenu=r()("#"+t),this.$toggler=this.$element.find("[data-toggle]").filter(function(){var e=r()(this).data("toggle");return e===t||""===e}),this.options=r.a.extend({},this.options,this.$targetMenu.data()),this.options.animate){var e=this.options.animate.split(" ");this.animationIn=e[0],this.animationOut=e[1]||null}this._update()}},{key:"_events",value:function(){this._updateMqHandler=this._update.bind(this),r()(window).on("changed.zf.mediaquery",this._updateMqHandler),this.$toggler.on("click.zf.responsiveToggle",this.toggleMenu.bind(this))}},{key:"_update",value:function(){l.a.atLeast(this.options.hideFor)?(this.$element.hide(),this.$targetMenu.show()):(this.$element.show(),this.$targetMenu.hide())}},{key:"toggleMenu",value:function(){var t=this;l.a.atLeast(this.options.hideFor)||(this.options.animate?this.$targetMenu.is(":hidden")?u.a.animateIn(this.$targetMenu,this.animationIn,function(){t.$element.trigger("toggled.zf.responsiveToggle"),t.$targetMenu.find("[data-mutate]").triggerHandler("mutateme.zf.trigger")}):u.a.animateOut(this.$targetMenu,this.animationOut,function(){t.$element.trigger("toggled.zf.responsiveToggle")}):(this.$targetMenu.toggle(0),this.$targetMenu.find("[data-mutate]").trigger("mutateme.zf.trigger"),this.$element.trigger("toggled.zf.responsiveToggle")))}},{key:"_destroy",value:function(){this.$element.off(".zf.responsiveToggle"),this.$toggler.off(".zf.responsiveToggle"),r()(window).off("changed.zf.mediaquery",this._updateMqHandler)}}]),e}(c.a);d.defaults={hideFor:"medium",animate:!1}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function a(){return/iP(ad|hone|od).*OS/.test(window.navigator.userAgent)}function r(){return/Android/.test(window.navigator.userAgent)}function l(){return a()||r()}i.d(e,"a",function(){return v});var u=i(0),c=i.n(u),h=i(3),d=i(4),f=i(6),p=i(2),m=i(5),g=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),v=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),g(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=c.a.extend({},e.defaults,this.$element.data(),i),this.className="Reveal",this._init(),m.a.init(c.a),h.a.register("Reveal",{ESCAPE:"close"})}},{key:"_init",value:function(){d.a._init(),this.id=this.$element.attr("id"),this.isActive=!1,this.cached={mq:d.a.current},this.isMobile=l(),this.$anchor=c()('[data-open="'+this.id+'"]').length?c()('[data-open="'+this.id+'"]'):c()('[data-toggle="'+this.id+'"]'),this.$anchor.attr({"aria-controls":this.id,"aria-haspopup":!0,tabindex:0}),(this.options.fullScreen||this.$element.hasClass("full"))&&(this.options.fullScreen=!0,this.options.overlay=!1),this.options.overlay&&!this.$overlay&&(this.$overlay=this._makeOverlay(this.id)),this.$element.attr({role:"dialog","aria-hidden":!0,"data-yeti-box":this.id,"data-resize":this.id}),this.$overlay?this.$element.detach().appendTo(this.$overlay):(this.$element.detach().appendTo(c()(this.options.appendTo)),this.$element.addClass("without-overlay")),this._events(),this.options.deepLink&&window.location.hash==="#"+this.id&&c()(window).one("load.zf.reveal",this.open.bind(this))}},{key:"_makeOverlay",value:function(){var t="";return this.options.additionalOverlayClasses&&(t=" "+this.options.additionalOverlayClasses),c()("<div></div>").addClass("reveal-overlay"+t).appendTo(this.options.appendTo)}},{key:"_updatePosition",value:function(){var t,e,i=this.$element.outerWidth(),n=c()(window).width(),s=this.$element.outerHeight(),o=c()(window).height();t="auto"===this.options.hOffset?parseInt((n-i)/2,10):parseInt(this.options.hOffset,10),e="auto"===this.options.vOffset?s>o?parseInt(Math.min(100,o/10),10):parseInt((o-s)/4,10):parseInt(this.options.vOffset,10),this.$element.css({top:e+"px"}),this.$overlay&&"auto"===this.options.hOffset||(this.$element.css({left:t+"px"}),this.$element.css({margin:"0px"}))}},{key:"_events",value:function(){var t=this,e=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":function(i,n){if(i.target===e.$element[0]||c()(i.target).parents("[data-closable]")[0]===n)return t.close.apply(t)},"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":function(){e._updatePosition()}}),this.options.closeOnClick&&this.options.overlay&&this.$overlay.off(".zf.reveal").on("click.zf.reveal",function(t){t.target!==e.$element[0]&&!c.a.contains(e.$element[0],t.target)&&c.a.contains(document,t.target)&&e.close()}),this.options.deepLink&&c()(window).on("popstate.zf.reveal:"+this.id,this._handleState.bind(this))}},{key:"_handleState",value:function(t){window.location.hash!=="#"+this.id||this.isActive?this.close():this.open()}},{key:"open",value:function(){function t(){n.isMobile?(n.originalScrollPos||(n.originalScrollPos=window.pageYOffset),c()("html, body").addClass("is-reveal-open")):c()("body").addClass("is-reveal-open")}var e=this;if(this.options.deepLink){var i="#"+this.id;window.history.pushState?this.options.updateHistory?window.history.pushState({},"",i):window.history.replaceState({},"",i):window.location.hash=i}this.isActive=!0,this.$element.css({visibility:"hidden"}).show().scrollTop(0),this.options.overlay&&this.$overlay.css({visibility:"hidden"}).show(),this._updatePosition(),this.$element.hide().css({visibility:""}),this.$overlay&&(this.$overlay.css({visibility:""}).hide(),this.$element.hasClass("fast")?this.$overlay.addClass("fast"):this.$element.hasClass("slow")&&this.$overlay.addClass("slow")),this.options.multipleOpened||this.$element.trigger("closeme.zf.reveal",this.id);var n=this;if(this.options.animationIn){var s=function(){n.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),t(),h.a.trapFocus(n.$element)};this.options.overlay&&f.a.animateIn(this.$overlay,"fade-in"),f.a.animateIn(this.$element,this.options.animationIn,function(){e.$element&&(e.focusableElements=h.a.findFocusable(e.$element),s())})}else this.options.overlay&&this.$overlay.show(0),this.$element.show(this.options.showDelay);this.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),h.a.trapFocus(this.$element),t(),this._extraHandlers(),this.$element.trigger("open.zf.reveal")}},{key:"_extraHandlers",value:function(){var t=this;this.$element&&(this.focusableElements=h.a.findFocusable(this.$element),this.options.overlay||!this.options.closeOnClick||this.options.fullScreen||c()("body").on("click.zf.reveal",function(e){e.target!==t.$element[0]&&!c.a.contains(t.$element[0],e.target)&&c.a.contains(document,e.target)&&t.close()}),this.options.closeOnEsc&&c()(window).on("keydown.zf.reveal",function(e){h.a.handleKey(e,"Reveal",{close:function(){t.options.closeOnEsc&&t.close()}})}))}},{key:"close",value:function(){function t(){e.isMobile?(0===c()(".reveal:visible").length&&c()("html, body").removeClass("is-reveal-open"),e.originalScrollPos&&(c()("body").scrollTop(e.originalScrollPos),e.originalScrollPos=null)):0===c()(".reveal:visible").length&&c()("body").removeClass("is-reveal-open"),h.a.releaseFocus(e.$element),e.$element.attr("aria-hidden",!0),e.$element.trigger("closed.zf.reveal")}if(!this.isActive||!this.$element.is(":visible"))return!1;var e=this;this.options.animationOut?(this.options.overlay&&f.a.animateOut(this.$overlay,"fade-out"),f.a.animateOut(this.$element,this.options.animationOut,t)):(this.$element.hide(this.options.hideDelay),this.options.overlay?this.$overlay.hide(0,t):t()),this.options.closeOnEsc&&c()(window).off("keydown.zf.reveal"),!this.options.overlay&&this.options.closeOnClick&&c()("body").off("click.zf.reveal"),this.$element.off("keydown.zf.reveal"),this.options.resetOnClose&&this.$element.html(this.$element.html()),this.isActive=!1,e.options.deepLink&&(window.history.replaceState?window.history.replaceState("",document.title,window.location.href.replace("#"+this.id,"")):window.location.hash=""),this.$anchor.focus()}},{key:"toggle",value:function(){this.isActive?this.close():this.open()}},{key:"_destroy",value:function(){this.options.overlay&&(this.$element.appendTo(c()(this.options.appendTo)),this.$overlay.hide().off().remove()),this.$element.hide().off(),this.$anchor.off(".zf"),c()(window).off(".zf.reveal:"+this.id)}}]),e}(p.a);v.defaults={animationIn:"",animationOut:"",showDelay:0,hideDelay:0,closeOnClick:!0,closeOnEsc:!0,multipleOpened:!1,vOffset:"auto",hOffset:"auto",fullScreen:!1,btmOffsetPct:10,overlay:!0,resetOnClose:!1,deepLink:!1,updateHistory:!1,appendTo:"body",additionalOverlayClasses:""}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function a(t,e){return t/e}function r(t,e,i,n){return Math.abs(t.position()[e]+t[n]()/2-i)}function l(t,e){return Math.log(e)/Math.log(t)}i.d(e,"a",function(){return b});var u=i(0),c=i.n(u),h=i(3),d=i(6),f=i(1),p=i(2),m=i(10),g=i(5),v=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),b=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),v(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=c.a.extend({},e.defaults,this.$element.data(),i),this.className="Slider",m.a.init(c.a),g.a.init(c.a),this._init(),h.a.register("Slider",{ltr:{ARROW_RIGHT:"increase",ARROW_UP:"increase",ARROW_DOWN:"decrease",ARROW_LEFT:"decrease",SHIFT_ARROW_RIGHT:"increase_fast",SHIFT_ARROW_UP:"increase_fast",SHIFT_ARROW_DOWN:"decrease_fast",SHIFT_ARROW_LEFT:"decrease_fast",HOME:"min",END:"max"},rtl:{ARROW_LEFT:"increase",ARROW_RIGHT:"decrease",SHIFT_ARROW_LEFT:"increase_fast",SHIFT_ARROW_RIGHT:"decrease_fast"}})}},{key:"_init",value:function(){this.inputs=this.$element.find("input"),this.handles=this.$element.find("[data-slider-handle]"),this.$handle=this.handles.eq(0),this.$input=this.inputs.length?this.inputs.eq(0):c()("#"+this.$handle.attr("aria-controls")),this.$fill=this.$element.find("[data-slider-fill]").css(this.options.vertical?"height":"width",0);(this.options.disabled||this.$element.hasClass(this.options.disabledClass))&&(this.options.disabled=!0,this.$element.addClass(this.options.disabledClass)),this.inputs.length||(this.inputs=c()().add(this.$input),this.options.binding=!0),this._setInitAttr(0),this.handles[1]&&(this.options.doubleSided=!0,this.$handle2=this.handles.eq(1),this.$input2=this.inputs.length>1?this.inputs.eq(1):c()("#"+this.$handle2.attr("aria-controls")),this.inputs[1]||(this.inputs=this.inputs.add(this.$input2)),!0,this._setInitAttr(1)),this.setHandles(),this._events()}},{key:"setHandles",value:function(){var t=this;this.handles[1]?this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0,function(){t._setHandlePos(t.$handle2,t.inputs.eq(1).val(),!0)}):this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0)}},{key:"_reflow",value:function(){this.setHandles()}},{key:"_pctOfBar",value:function(t){var e=a(t-this.options.start,this.options.end-this.options.start);switch(this.options.positionValueFunction){case"pow":e=this._logTransform(e);break;case"log":e=this._powTransform(e)}return e.toFixed(2)}},{key:"_value",value:function(t){switch(this.options.positionValueFunction){case"pow":t=this._powTransform(t);break;case"log":t=this._logTransform(t)}
-return(this.options.end-this.options.start)*t+this.options.start}},{key:"_logTransform",value:function(t){return l(this.options.nonLinearBase,t*(this.options.nonLinearBase-1)+1)}},{key:"_powTransform",value:function(t){return(Math.pow(this.options.nonLinearBase,t)-1)/(this.options.nonLinearBase-1)}},{key:"_setHandlePos",value:function(t,e,n,s){if(!this.$element.hasClass(this.options.disabledClass)){e=parseFloat(e),e<this.options.start?e=this.options.start:e>this.options.end&&(e=this.options.end);var o=this.options.doubleSided;if(this.options.vertical&&!n&&(e=this.options.end-e),o)if(0===this.handles.index(t)){var r=parseFloat(this.$handle2.attr("aria-valuenow"));e=e>=r?r-this.options.step:e}else{var l=parseFloat(this.$handle.attr("aria-valuenow"));e=e<=l?l+this.options.step:e}var u=this,c=this.options.vertical,h=c?"height":"width",f=c?"top":"left",p=t[0].getBoundingClientRect()[h],m=this.$element[0].getBoundingClientRect()[h],g=this._pctOfBar(e),v=(m-p)*g,b=(100*a(v,m)).toFixed(this.options.decimal);e=parseFloat(e.toFixed(this.options.decimal));var y={};if(this._setValues(t,e),o){var w,_=0===this.handles.index(t),$=~~(100*a(p,m));if(_)y[f]=b+"%",w=parseFloat(this.$handle2[0].style[f])-b+$,s&&"function"==typeof s&&s();else{var k=parseFloat(this.$handle[0].style[f]);w=b-(isNaN(k)?(this.options.initialStart-this.options.start)/((this.options.end-this.options.start)/100):k)+$}y["min-"+h]=w+"%"}this.$element.one("finished.zf.animate",function(){u.$element.trigger("moved.zf.slider",[t])});var C=this.$element.data("dragging")?1e3/60:this.options.moveTime;i.i(d.b)(C,t,function(){isNaN(b)?t.css(f,100*g+"%"):t.css(f,b+"%"),u.options.doubleSided?u.$fill.css(y):u.$fill.css(h,100*g+"%")}),clearTimeout(u.timeout),u.timeout=setTimeout(function(){u.$element.trigger("changed.zf.slider",[t])},u.options.changedDelay)}}},{key:"_setInitAttr",value:function(t){var e=0===t?this.options.initialStart:this.options.initialEnd,n=this.inputs.eq(t).attr("id")||i.i(f.b)(6,"slider");this.inputs.eq(t).attr({id:n,max:this.options.end,min:this.options.start,step:this.options.step}),this.inputs.eq(t).val(e),this.handles.eq(t).attr({role:"slider","aria-controls":n,"aria-valuemax":this.options.end,"aria-valuemin":this.options.start,"aria-valuenow":e,"aria-orientation":this.options.vertical?"vertical":"horizontal",tabindex:0})}},{key:"_setValues",value:function(t,e){var i=this.options.doubleSided?this.handles.index(t):0;this.inputs.eq(i).val(e),t.attr("aria-valuenow",e)}},{key:"_handleEvent",value:function(t,e,n){var s,o;if(n)s=this._adjustValue(null,n),o=!0;else{t.preventDefault();var l=this,u=this.options.vertical,h=u?"height":"width",d=u?"top":"left",p=u?t.pageY:t.pageX,m=(this.$handle[0].getBoundingClientRect()[h],this.$element[0].getBoundingClientRect()[h]),g=u?c()(window).scrollTop():c()(window).scrollLeft(),v=this.$element.offset()[d];t.clientY===t.pageY&&(p+=g);var b,y=p-v;b=y<0?0:y>m?m:y;var w=a(b,m);if(s=this._value(w),i.i(f.a)()&&!this.options.vertical&&(s=this.options.end-s),s=l._adjustValue(null,s),o=!1,!e){e=r(this.$handle,d,b,h)<=r(this.$handle2,d,b,h)?this.$handle:this.$handle2}}this._setHandlePos(e,s,o)}},{key:"_adjustValue",value:function(t,e){var i,n,s,o,a=this.options.step,r=parseFloat(a/2);return i=t?parseFloat(t.attr("aria-valuenow")):e,n=i%a,s=i-n,o=s+a,0===n?i:i=i>=s+r?o:s}},{key:"_events",value:function(){this._eventsForHandle(this.$handle),this.handles[1]&&this._eventsForHandle(this.$handle2)}},{key:"_eventsForHandle",value:function(t){var e,i=this;if(this.inputs.off("change.zf.slider").on("change.zf.slider",function(t){var e=i.inputs.index(c()(this));i._handleEvent(t,i.handles.eq(e),c()(this).val())}),this.options.clickSelect&&this.$element.off("click.zf.slider").on("click.zf.slider",function(t){if(i.$element.data("dragging"))return!1;c()(t.target).is("[data-slider-handle]")||(i.options.doubleSided?i._handleEvent(t):i._handleEvent(t,i.$handle))}),this.options.draggable){this.handles.addTouch();var n=c()("body");t.off("mousedown.zf.slider").on("mousedown.zf.slider",function(s){t.addClass("is-dragging"),i.$fill.addClass("is-dragging"),i.$element.data("dragging",!0),e=c()(s.currentTarget),n.on("mousemove.zf.slider",function(t){t.preventDefault(),i._handleEvent(t,e)}).on("mouseup.zf.slider",function(s){i._handleEvent(s,e),t.removeClass("is-dragging"),i.$fill.removeClass("is-dragging"),i.$element.data("dragging",!1),n.off("mousemove.zf.slider mouseup.zf.slider")})}).on("selectstart.zf.slider touchmove.zf.slider",function(t){t.preventDefault()})}t.off("keydown.zf.slider").on("keydown.zf.slider",function(t){var e,n=c()(this),s=i.options.doubleSided?i.handles.index(n):0,o=parseFloat(i.inputs.eq(s).val());h.a.handleKey(t,"Slider",{decrease:function(){e=o-i.options.step},increase:function(){e=o+i.options.step},decrease_fast:function(){e=o-10*i.options.step},increase_fast:function(){e=o+10*i.options.step},min:function(){e=i.options.start},max:function(){e=i.options.end},handled:function(){t.preventDefault(),i._setHandlePos(n,e,!0)}})})}},{key:"_destroy",value:function(){this.handles.off(".zf.slider"),this.inputs.off(".zf.slider"),this.$element.off(".zf.slider"),clearTimeout(this.timeout)}}]),e}(p.a);b.defaults={start:0,end:100,step:1,initialStart:0,initialEnd:100,binding:!1,clickSelect:!0,vertical:!1,draggable:!0,disabled:!1,doubleSided:!1,decimal:2,moveTime:200,disabledClass:"disabled",invertVertical:!1,changedDelay:500,nonLinearBase:5,positionValueFunction:"linear"}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function a(t){return parseInt(window.getComputedStyle(document.body,null).fontSize,10)*t}i.d(e,"a",function(){return p});var r=i(0),l=i.n(r),u=i(1),c=i(4),h=i(2),d=i(5),f=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),p=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),f(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=l.a.extend({},e.defaults,this.$element.data(),i),this.className="Sticky",d.a.init(l.a),this._init()}},{key:"_init",value:function(){c.a._init();var t=this.$element.parent("[data-sticky-container]"),e=this.$element[0].id||i.i(u.b)(6,"sticky"),n=this;t.length?this.$container=t:(this.wasWrapped=!0,this.$element.wrap(this.options.container),this.$container=this.$element.parent()),this.$container.addClass(this.options.containerClass),this.$element.addClass(this.options.stickyClass).attr({"data-resize":e,"data-mutate":e}),""!==this.options.anchor&&l()("#"+n.options.anchor).attr({"data-mutate":e}),this.scrollCount=this.options.checkEvery,this.isStuck=!1,l()(window).one("load.zf.sticky",function(){n.containerHeight="none"==n.$element.css("display")?0:n.$element[0].getBoundingClientRect().height,n.$container.css("height",n.containerHeight),n.elemHeight=n.containerHeight,""!==n.options.anchor?n.$anchor=l()("#"+n.options.anchor):n._parsePoints(),n._setSizes(function(){var t=window.pageYOffset;n._calc(!1,t),n.isStuck||n._removeSticky(!(t>=n.topPoint))}),n._events(e.split("-").reverse().join("-"))})}},{key:"_parsePoints",value:function(){for(var t=""==this.options.topAnchor?1:this.options.topAnchor,e=""==this.options.btmAnchor?document.documentElement.scrollHeight:this.options.btmAnchor,i=[t,e],n={},s=0,o=i.length;s<o&&i[s];s++){var a;if("number"==typeof i[s])a=i[s];else{var r=i[s].split(":"),u=l()("#"+r[0]);a=u.offset().top,r[1]&&"bottom"===r[1].toLowerCase()&&(a+=u[0].getBoundingClientRect().height)}n[s]=a}this.points=n}},{key:"_events",value:function(t){var e=this,i=this.scrollListener="scroll.zf."+t;this.isOn||(this.canStick&&(this.isOn=!0,l()(window).off(i).on(i,function(t){0===e.scrollCount?(e.scrollCount=e.options.checkEvery,e._setSizes(function(){e._calc(!1,window.pageYOffset)})):(e.scrollCount--,e._calc(!1,window.pageYOffset))})),this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(i,n){e._eventsHandler(t)}),this.$element.on("mutateme.zf.trigger",function(i,n){e._eventsHandler(t)}),this.$anchor&&this.$anchor.on("mutateme.zf.trigger",function(i,n){e._eventsHandler(t)}))}},{key:"_eventsHandler",value:function(t){var e=this,i=this.scrollListener="scroll.zf."+t;e._setSizes(function(){e._calc(!1),e.canStick?e.isOn||e._events(t):e.isOn&&e._pauseListeners(i)})}},{key:"_pauseListeners",value:function(t){this.isOn=!1,l()(window).off(t),this.$element.trigger("pause.zf.sticky")}},{key:"_calc",value:function(t,e){if(t&&this._setSizes(),!this.canStick)return this.isStuck&&this._removeSticky(!0),!1;e||(e=window.pageYOffset),e>=this.topPoint?e<=this.bottomPoint?this.isStuck||this._setSticky():this.isStuck&&this._removeSticky(!1):this.isStuck&&this._removeSticky(!0)}},{key:"_setSticky",value:function(){var t=this,e=this.options.stickTo,i="top"===e?"marginTop":"marginBottom",n="top"===e?"bottom":"top",s={};s[i]=this.options[i]+"em",s[e]=0,s[n]="auto",this.isStuck=!0,this.$element.removeClass("is-anchored is-at-"+n).addClass("is-stuck is-at-"+e).css(s).trigger("sticky.zf.stuckto:"+e),this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd",function(){t._setSizes()})}},{key:"_removeSticky",value:function(t){var e=this.options.stickTo,i="top"===e,n={},s=(this.points?this.points[1]-this.points[0]:this.anchorHeight)-this.elemHeight,o=i?"marginTop":"marginBottom",a=t?"top":"bottom";n[o]=0,n.bottom="auto",n.top=t?0:s,this.isStuck=!1,this.$element.removeClass("is-stuck is-at-"+e).addClass("is-anchored is-at-"+a).css(n).trigger("sticky.zf.unstuckfrom:"+a)}},{key:"_setSizes",value:function(t){this.canStick=c.a.is(this.options.stickyOn),this.canStick||t&&"function"==typeof t&&t();var e=this.$container[0].getBoundingClientRect().width,i=window.getComputedStyle(this.$container[0]),n=parseInt(i["padding-left"],10),s=parseInt(i["padding-right"],10);this.$anchor&&this.$anchor.length?this.anchorHeight=this.$anchor[0].getBoundingClientRect().height:this._parsePoints(),this.$element.css({"max-width":e-n-s+"px"});var o=this.$element[0].getBoundingClientRect().height||this.containerHeight;if("none"==this.$element.css("display")&&(o=0),this.containerHeight=o,this.$container.css({height:o}),this.elemHeight=o,!this.isStuck&&this.$element.hasClass("is-at-bottom")){var a=(this.points?this.points[1]-this.$container.offset().top:this.anchorHeight)-this.elemHeight;this.$element.css("top",a)}this._setBreakPoints(o,function(){t&&"function"==typeof t&&t()})}},{key:"_setBreakPoints",value:function(t,e){if(!this.canStick){if(!e||"function"!=typeof e)return!1;e()}var i=a(this.options.marginTop),n=a(this.options.marginBottom),s=this.points?this.points[0]:this.$anchor.offset().top,o=this.points?this.points[1]:s+this.anchorHeight,r=window.innerHeight;"top"===this.options.stickTo?(s-=i,o-=t+i):"bottom"===this.options.stickTo&&(s-=r-(t+n),o-=r-n),this.topPoint=s,this.bottomPoint=o,e&&"function"==typeof e&&e()}},{key:"_destroy",value:function(){this._removeSticky(!0),this.$element.removeClass(this.options.stickyClass+" is-anchored is-at-top").css({height:"",top:"",bottom:"","max-width":""}).off("resizeme.zf.trigger").off("mutateme.zf.trigger"),this.$anchor&&this.$anchor.length&&this.$anchor.off("change.zf.sticky"),l()(window).off(this.scrollListener),this.wasWrapped?this.$element.unwrap():this.$container.removeClass(this.options.containerClass).css({height:""})}}]),e}(h.a);p.defaults={container:"<div data-sticky-container></div>",stickTo:"top",anchor:"",topAnchor:"",btmAnchor:"",marginTop:1,marginBottom:1,stickyOn:"medium",stickyClass:"sticky",containerClass:"sticky-container",checkEvery:-1}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return d});var a=i(0),r=i.n(a),l=i(6),u=i(2),c=i(5),h=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),d=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),h(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,t.data(),i),this.className="",this.className="Toggler",c.a.init(r.a),this._init(),this._events()}},{key:"_init",value:function(){var t;this.options.animate?(t=this.options.animate.split(" "),this.animationIn=t[0],this.animationOut=t[1]||null):(t=this.$element.data("toggler"),this.className="."===t[0]?t.slice(1):t);var e=this.$element[0].id;r()('[data-open="'+e+'"], [data-close="'+e+'"], [data-toggle="'+e+'"]').attr("aria-controls",e),this.$element.attr("aria-expanded",!this.$element.is(":hidden"))}},{key:"_events",value:function(){this.$element.off("toggle.zf.trigger").on("toggle.zf.trigger",this.toggle.bind(this))}},{key:"toggle",value:function(){this[this.options.animate?"_toggleAnimate":"_toggleClass"]()}},{key:"_toggleClass",value:function(){this.$element.toggleClass(this.className);var t=this.$element.hasClass(this.className);t?this.$element.trigger("on.zf.toggler"):this.$element.trigger("off.zf.toggler"),this._updateARIA(t),this.$element.find("[data-mutate]").trigger("mutateme.zf.trigger")}},{key:"_toggleAnimate",value:function(){var t=this;this.$element.is(":hidden")?l.a.animateIn(this.$element,this.animationIn,function(){t._updateARIA(!0),this.trigger("on.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")}):l.a.animateOut(this.$element,this.animationOut,function(){t._updateARIA(!1),this.trigger("off.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")})}},{key:"_updateARIA",value:function(t){this.$element.attr("aria-expanded",!!t)}},{key:"_destroy",value:function(){this.$element.off(".zf.toggler")}}]),e}(u.a);d.defaults={animate:!1}},function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return p});var a=i(0),r=i.n(a),l=i(1),u=i(4),c=i(5),h=i(15),d=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),f=function t(e,i,n){null===e&&(e=Function.prototype);var s=Object.getOwnPropertyDescriptor(e,i);if(void 0===s){var o=Object.getPrototypeOf(e);return null===o?void 0:t(o,i,n)}if("value"in s)return s.value;var a=s.get;if(void 0!==a)return a.call(n)},p=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),d(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Tooltip",this.isActive=!1,this.isClick=!1,c.a.init(r.a),this._init()}},{key:"_init",value:function(){u.a._init();var t=this.$element.attr("aria-describedby")||i.i(l.b)(6,"tooltip");this.options.tipText=this.options.tipText||this.$element.attr("title"),this.template=this.options.template?r()(this.options.template):this._buildTemplate(t),this.options.allowHtml?this.template.appendTo(document.body).html(this.options.tipText).hide():this.template.appendTo(document.body).text(this.options.tipText).hide(),this.$element.attr({title:"","aria-describedby":t,"data-yeti-box":t,"data-toggle":t,"data-resize":t}).addClass(this.options.triggerClass),f(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_init",this).call(this),this._events()}},{key:"_getDefaultPosition",value:function(){var t=this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);return t?t[0]:"top"}},{key:"_getDefaultAlignment",value:function(){return"center"}},{key:"_getHOffset",value:function(){return"left"===this.position||"right"===this.position?this.options.hOffset+this.options.tooltipWidth:this.options.hOffset}},{key:"_getVOffset",value:function(){return"top"===this.position||"bottom"===this.position?this.options.vOffset+this.options.tooltipHeight:this.options.vOffset}},{key:"_buildTemplate",value:function(t){var e=(this.options.tooltipClass+" "+this.options.positionClass+" "+this.options.templateClasses).trim();return r()("<div></div>").addClass(e).attr({role:"tooltip","aria-hidden":!0,"data-is-active":!1,"data-is-focus":!1,id:t})}},{key:"_setPosition",value:function(){f(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_setPosition",this).call(this,this.$element,this.template)}},{key:"show",value:function(){if("all"!==this.options.showOn&&!u.a.is(this.options.showOn))return!1;var t=this;this.template.css("visibility","hidden").show(),this._setPosition(),this.template.removeClass("top bottom left right").addClass(this.position),this.template.removeClass("align-top align-bottom align-left align-right align-center").addClass("align-"+this.alignment),this.$element.trigger("closeme.zf.tooltip",this.template.attr("id")),this.template.attr({"data-is-active":!0,"aria-hidden":!1}),t.isActive=!0,this.template.stop().hide().css("visibility","").fadeIn(this.options.fadeInDuration,function(){}),this.$element.trigger("show.zf.tooltip")}},{key:"hide",value:function(){var t=this;this.template.stop().attr({"aria-hidden":!0,"data-is-active":!1}).fadeOut(this.options.fadeOutDuration,function(){t.isActive=!1,t.isClick=!1}),this.$element.trigger("hide.zf.tooltip")}},{key:"_events",value:function(){var t=this,e=(this.template,!1);this.options.disableHover||this.$element.on("mouseenter.zf.tooltip",function(e){t.isActive||(t.timeout=setTimeout(function(){t.show()},t.options.hoverDelay))}).on("mouseleave.zf.tooltip",function(i){clearTimeout(t.timeout),(!e||t.isClick&&!t.options.clickOpen)&&t.hide()}),this.options.clickOpen?this.$element.on("mousedown.zf.tooltip",function(e){e.stopImmediatePropagation(),t.isClick||(t.isClick=!0,!t.options.disableHover&&t.$element.attr("tabindex")||t.isActive||t.show())}):this.$element.on("mousedown.zf.tooltip",function(e){e.stopImmediatePropagation(),t.isClick=!0}),this.options.disableForTouch||this.$element.on("tap.zf.tooltip touchend.zf.tooltip",function(e){t.isActive?t.hide():t.show()}),this.$element.on({"close.zf.trigger":this.hide.bind(this)}),this.$element.on("focus.zf.tooltip",function(i){if(e=!0,t.isClick)return t.options.clickOpen||(e=!1),!1;t.show()}).on("focusout.zf.tooltip",function(i){e=!1,t.isClick=!1,t.hide()}).on("resizeme.zf.trigger",function(){t.isActive&&t._setPosition()})}},{key:"toggle",value:function(){this.isActive?this.hide():this.show()}},{key:"_destroy",value:function(){this.$element.attr("title",this.template.text()).off(".zf.trigger .zf.tooltip").removeClass("has-tip top right left").removeAttr("aria-describedby aria-haspopup data-disable-hover data-resize data-toggle data-tooltip data-yeti-box"),this.template.remove()}}]),e}(h.a);p.defaults={disableForTouch:!1,hoverDelay:200,fadeInDuration:150,fadeOutDuration:150,disableHover:!1,templateClasses:"",tooltipClass:"tooltip",triggerClass:"has-tip",showOn:"small",template:"",tipText:"",touchCloseText:"Tap to close.",clickOpen:!0,positionClass:"",position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!1,vOffset:0,hOffset:0,tooltipHeight:14,tooltipWidth:12,allowHtml:!1}},function(t,e,i){t.exports=i(19)}]);
\ No newline at end of file
+!function(t,e){if("object"==typeof exports&&"object"==typeof module)module.exports=e(require("jquery"));else if("function"==typeof define&&define.amd)define(["jquery"],e);else{var n="object"==typeof exports?e(require("jquery")):e(t.jQuery);for(var i in n)("object"==typeof exports?exports:t)[i]=n[i]}}(window,function(n){return function(n){var i={};function o(t){if(i[t])return i[t].exports;var e=i[t]={i:t,l:!1,exports:{}};return n[t].call(e.exports,e,e.exports,o),e.l=!0,e.exports}return o.m=n,o.c=i,o.d=function(t,e,n){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(o.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)o.d(n,i,function(t){return e[t]}.bind(null,i));return n},o.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return o.d(e,"a",e),e},o.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},o.p="",o(o.s=0)}({"./js/entries/foundation.js":function(t,e,n){"use strict";n.r(e);var i=n("jquery"),o=n.n(i),s=n("./js/foundation.core.js");n.d(e,"Foundation",function(){return s.Foundation});var a=n("./js/foundation.core.utils.js");n.d(e,"CoreUtils",function(){return a});var r=n("./js/foundation.util.box.js");n.d(e,"Box",function(){return r.Box});var l=n("./js/foundation.util.imageLoader.js");n.d(e,"onImagesLoaded",function(){return l.onImagesLoaded});var u=n("./js/foundation.util.keyboard.js");n.d(e,"Keyboard",function(){return u.Keyboard});var c=n("./js/foundation.util.mediaQuery.js");n.d(e,"MediaQuery",function(){return c.MediaQuery});var d=n("./js/foundation.util.motion.js");n.d(e,"Motion",function(){return d.Motion});var h=n("./js/foundation.util.nest.js");n.d(e,"Nest",function(){return h.Nest});var f=n("./js/foundation.util.timer.js");n.d(e,"Timer",function(){return f.Timer});var p=n("./js/foundation.util.touch.js");n.d(e,"Touch",function(){return p.Touch});var m=n("./js/foundation.util.triggers.js");n.d(e,"Triggers",function(){return m.Triggers});var g=n("./js/foundation.abide.js");n.d(e,"Abide",function(){return g.Abide});var v=n("./js/foundation.accordion.js");n.d(e,"Accordion",function(){return v.Accordion});var y=n("./js/foundation.accordionMenu.js");n.d(e,"AccordionMenu",function(){return y.AccordionMenu});var b=n("./js/foundation.drilldown.js");n.d(e,"Drilldown",function(){return b.Drilldown});var w=n("./js/foundation.dropdown.js");n.d(e,"Dropdown",function(){return w.Dropdown});var _=n("./js/foundation.dropdownMenu.js");n.d(e,"DropdownMenu",function(){return _.DropdownMenu});var $=n("./js/foundation.equalizer.js");n.d(e,"Equalizer",function(){return $.Equalizer});var j=n("./js/foundation.interchange.js");n.d(e,"Interchange",function(){return j.Interchange});var k=n("./js/foundation.magellan.js");n.d(e,"Magellan",function(){return k.Magellan});var O=n("./js/foundation.offcanvas.js");n.d(e,"OffCanvas",function(){return O.OffCanvas});var C=n("./js/foundation.orbit.js");n.d(e,"Orbit",function(){return C.Orbit});var z=n("./js/foundation.responsiveMenu.js");n.d(e,"ResponsiveMenu",function(){return z.ResponsiveMenu});var T=n("./js/foundation.responsiveToggle.js");n.d(e,"ResponsiveToggle",function(){return T.ResponsiveToggle});var S=n("./js/foundation.reveal.js");n.d(e,"Reveal",function(){return S.Reveal});var P=n("./js/foundation.slider.js");n.d(e,"Slider",function(){return P.Slider});var E=n("./js/foundation.smoothScroll.js");n.d(e,"SmoothScroll",function(){return E.SmoothScroll});var A=n("./js/foundation.sticky.js");n.d(e,"Sticky",function(){return A.Sticky});var x=n("./js/foundation.tabs.js");n.d(e,"Tabs",function(){return x.Tabs});var L=n("./js/foundation.toggler.js");n.d(e,"Toggler",function(){return L.Toggler});var R=n("./js/foundation.tooltip.js");n.d(e,"Tooltip",function(){return R.Tooltip});var M=n("./js/foundation.responsiveAccordionTabs.js");n.d(e,"ResponsiveAccordionTabs",function(){return M.ResponsiveAccordionTabs}),s.Foundation.addToJquery(o.a),s.Foundation.rtl=a.rtl,s.Foundation.GetYoDigits=a.GetYoDigits,s.Foundation.transitionend=a.transitionend,s.Foundation.RegExpEscape=a.RegExpEscape,s.Foundation.onLoad=a.onLoad,s.Foundation.Box=r.Box,s.Foundation.onImagesLoaded=l.onImagesLoaded,s.Foundation.Keyboard=u.Keyboard,s.Foundation.MediaQuery=c.MediaQuery,s.Foundation.Motion=d.Motion,s.Foundation.Move=d.Move,s.Foundation.Nest=h.Nest,s.Foundation.Timer=f.Timer,p.Touch.init(o.a),m.Triggers.init(o.a,s.Foundation),c.MediaQuery._init(),s.Foundation.plugin(g.Abide,"Abide"),s.Foundation.plugin(v.Accordion,"Accordion"),s.Foundation.plugin(y.AccordionMenu,"AccordionMenu"),s.Foundation.plugin(b.Drilldown,"Drilldown"),s.Foundation.plugin(w.Dropdown,"Dropdown"),s.Foundation.plugin(_.DropdownMenu,"DropdownMenu"),s.Foundation.plugin($.Equalizer,"Equalizer"),s.Foundation.plugin(j.Interchange,"Interchange"),s.Foundation.plugin(k.Magellan,"Magellan"),s.Foundation.plugin(O.OffCanvas,"OffCanvas"),s.Foundation.plugin(C.Orbit,"Orbit"),s.Foundation.plugin(z.ResponsiveMenu,"ResponsiveMenu"),s.Foundation.plugin(T.ResponsiveToggle,"ResponsiveToggle"),s.Foundation.plugin(S.Reveal,"Reveal"),s.Foundation.plugin(P.Slider,"Slider"),s.Foundation.plugin(E.SmoothScroll,"SmoothScroll"),s.Foundation.plugin(A.Sticky,"Sticky"),s.Foundation.plugin(x.Tabs,"Tabs"),s.Foundation.plugin(L.Toggler,"Toggler"),s.Foundation.plugin(R.Tooltip,"Tooltip"),s.Foundation.plugin(M.ResponsiveAccordionTabs,"ResponsiveAccordionTabs"),e.default=s.Foundation},"./js/foundation.abide.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Abide",function(){return h});var i=n("jquery"),c=n.n(i),s=n("./js/foundation.core.plugin.js"),a=n("./js/foundation.core.utils.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function r(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function l(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function u(t){return(u=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function d(t,e){return(d=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var h=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),l(this,u(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&d(t,e)}(n,s["Plugin"]),e=n,(i=[{key:"_setup",value:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{};this.$element=t,this.options=c.a.extend(!0,{},n.defaults,this.$element.data(),e),this.className="Abide",this._init()}},{key:"_init",value:function(){var n=this;this.$inputs=c.a.merge(this.$element.find("input").not("[type=submit]"),this.$element.find("textarea, select"));var t=this.$element.find("[data-abide-error]");this.options.a11yAttributes&&(this.$inputs.each(function(t,e){return n.addA11yAttributes(c()(e))}),t.each(function(t,e){return n.addGlobalErrorA11yAttributes(c()(e))})),this._events()}},{key:"_events",value:function(){var e=this;this.$element.off(".abide").on("reset.zf.abide",function(){e.resetForm()}).on("submit.zf.abide",function(){return e.validateForm()}),"fieldChange"===this.options.validateOn&&this.$inputs.off("change.zf.abide").on("change.zf.abide",function(t){e.validateInput(c()(t.target))}),this.options.liveValidate&&this.$inputs.off("input.zf.abide").on("input.zf.abide",function(t){e.validateInput(c()(t.target))}),this.options.validateOnBlur&&this.$inputs.off("blur.zf.abide").on("blur.zf.abide",function(t){e.validateInput(c()(t.target))})}},{key:"_reflow",value:function(){this._init()}},{key:"requiredCheck",value:function(t){if(!t.attr("required"))return!0;var e=!0;switch(t[0].type){case"checkbox":e=t[0].checked;break;case"select":case"select-one":case"select-multiple":var n=t.find("option:selected");n.length&&n.val()||(e=!1);break;default:t.val()&&t.val().length||(e=!1)}return e}},{key:"findFormError",value:function(t){var e=t[0].id,n=t.siblings(this.options.formErrorSelector);return n.length||(n=t.parent().find(this.options.formErrorSelector)),e&&(n=n.add(this.$element.find('[data-form-error-for="'.concat(e,'"]')))),n}},{key:"findLabel",value:function(t){var e=t[0].id,n=this.$element.find('label[for="'.concat(e,'"]'));return n.length?n:t.closest("label")}},{key:"findRadioLabels",value:function(t){var o=this,e=t.map(function(t,e){var n=e.id,i=o.$element.find('label[for="'.concat(n,'"]'));return i.length||(i=c()(e).closest("label")),i[0]});return c()(e)}},{key:"addErrorClasses",value:function(t){var e=this.findLabel(t),n=this.findFormError(t);e.length&&e.addClass(this.options.labelErrorClass),n.length&&n.addClass(this.options.formErrorClass),t.addClass(this.options.inputErrorClass).attr({"data-invalid":"","aria-invalid":!0})}},{key:"addA11yAttributes",value:function(t){var e=this.findFormError(t),n=e.filter("label"),i=e.first();if(e.length){if(void 0===t.attr("aria-describedby")){var o=i.attr("id");void 0===o&&(o=Object(a.GetYoDigits)(6,"abide-error"),i.attr("id",o)),t.attr("aria-describedby",o)}if(n.filter("[for]").length<n.length){var s=t.attr("id");void 0===s&&(s=Object(a.GetYoDigits)(6,"abide-input"),t.attr("id",s)),n.each(function(t,e){var n=c()(e);void 0===n.attr("for")&&n.attr("for",s)})}e.each(function(t,e){var n=c()(e);void 0===n.attr("role")&&n.attr("role","alert")}).end()}}},{key:"addGlobalErrorA11yAttributes",value:function(t){void 0===t.attr("aria-live")&&t.attr("aria-live",this.options.a11yErrorLevel)}},{key:"removeRadioErrorClasses",value:function(t){var e=this.$element.find(':radio[name="'.concat(t,'"]')),n=this.findRadioLabels(e),i=this.findFormError(e);n.length&&n.removeClass(this.options.labelErrorClass),i.length&&i.removeClass(this.options.formErrorClass),e.removeClass(this.options.inputErrorClass).attr({"data-invalid":null,"aria-invalid":null})}},{key:"removeErrorClasses",value:function(t){if("radio"==t[0].type)return this.removeRadioErrorClasses(t.attr("name"));var e=this.findLabel(t),n=this.findFormError(t);e.length&&e.removeClass(this.options.labelErrorClass),n.length&&n.removeClass(this.options.formErrorClass),t.removeClass(this.options.inputErrorClass).attr({"data-invalid":null,"aria-invalid":null})}},{key:"validateInput",value:function(t){var e=this.requiredCheck(t),n=!1,i=!0,o=t.attr("data-validator"),s=!0;if(t.is("[data-abide-ignore]")||t.is('[type="hidden"]')||t.is("[disabled]"))return!0;switch(t[0].type){case"radio":n=this.validateRadio(t.attr("name"));break;case"checkbox":n=e;break;case"select":case"select-one":case"select-multiple":n=e;break;default:n=this.validateText(t)}o&&(i=this.matchValidation(t,o,t.attr("required"))),t.attr("data-equalto")&&(s=this.options.validators.equalTo(t));var a=-1===[e,n,i,s].indexOf(!1),r=(a?"valid":"invalid")+".zf.abide";if(a){var l=this.$element.find('[data-equalto="'.concat(t.attr("id"),'"]'));if(l.length){var u=this;l.each(function(){c()(this).val()&&u.validateInput(c()(this))})}}return this[a?"removeErrorClasses":"addErrorClasses"](t),t.trigger(r,[t]),a}},{key:"validateForm",value:function(){var i=this,t=[],e=this;this.$inputs.each(function(){t.push(e.validateInput(c()(this)))});var o=-1===t.indexOf(!1);return this.$element.find("[data-abide-error]").each(function(t,e){var n=c()(e);i.options.a11yAttributes&&i.addGlobalErrorA11yAttributes(n),n.css("display",o?"none":"block")}),this.$element.trigger((o?"formvalid":"forminvalid")+".zf.abide",[this.$element]),o}},{key:"validateText",value:function(t,e){e=e||t.attr("pattern")||t.attr("type");var n=t.val(),i=!1;return n.length?i=this.options.patterns.hasOwnProperty(e)?this.options.patterns[e].test(n):e===t.attr("type")||new RegExp(e).test(n):t.prop("required")||(i=!0),i}},{key:"validateRadio",value:function(t){var e=this.$element.find(':radio[name="'.concat(t,'"]')),n=!1,i=!1;return e.each(function(t,e){c()(e).attr("required")&&(i=!0)}),i||(n=!0),n||e.each(function(t,e){c()(e).prop("checked")&&(n=!0)}),n}},{key:"matchValidation",value:function(e,t,n){var i=this;return n=!!n,-1===t.split(" ").map(function(t){return i.options.validators[t](e,n,e.parent())}).indexOf(!1)}},{key:"resetForm",value:function(){var t=this.$element,e=this.options;c()(".".concat(e.labelErrorClass),t).not("small").removeClass(e.labelErrorClass),c()(".".concat(e.inputErrorClass),t).not("small").removeClass(e.inputErrorClass),c()("".concat(e.formErrorSelector,".").concat(e.formErrorClass)).removeClass(e.formErrorClass),t.find("[data-abide-error]").css("display","none"),c()(":input",t).not(":button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]").val("").attr({"data-invalid":null,"aria-invalid":null}),c()(":input:radio",t).not("[data-abide-ignore]").prop("checked",!1).attr({"data-invalid":null,"aria-invalid":null}),c()(":input:checkbox",t).not("[data-abide-ignore]").prop("checked",!1).attr({"data-invalid":null,"aria-invalid":null}),t.trigger("formreset.zf.abide",[t])}},{key:"_destroy",value:function(){var t=this;this.$element.off(".abide").find("[data-abide-error]").css("display","none"),this.$inputs.off(".abide").each(function(){t.removeErrorClasses(c()(this))})}}])&&r(e.prototype,i),o&&r(e,o),n}();h.defaults={validateOn:"fieldChange",labelErrorClass:"is-invalid-label",inputErrorClass:"is-invalid-input",formErrorSelector:".form-error",formErrorClass:"is-visible",a11yAttributes:!0,a11yErrorLevel:"assertive",liveValidate:!1,validateOnBlur:!1,patterns:{alpha:/^[a-zA-Z]+$/,alpha_numeric:/^[a-zA-Z0-9]+$/,integer:/^[-+]?\d+$/,number:/^[-+]?\d*(?:[\.\,]\d+)?$/,card:/^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,cvv:/^([0-9]){3,4}$/,email:/^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,url:/^((?:(https?|ftps?|file|ssh|sftp):\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\))+(?:\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?\xab\xbb\u201c\u201d\u2018\u2019]))$/,domain:/^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,datetime:/^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,date:/(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,time:/^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,dateISO:/^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,month_day_year:/^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,day_month_year:/^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,color:/^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,website:{test:function(t){return h.defaults.patterns.domain.test(t)||h.defaults.patterns.url.test(t)}}},validators:{equalTo:function(t,e,n){return c()("#".concat(t.attr("data-equalto"))).val()===t.val()}}}},"./js/foundation.accordion.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Accordion",function(){return f});var i=n("jquery"),a=n.n(i),r=n("./js/foundation.core.utils.js"),s=n("./js/foundation.util.keyboard.js"),l=n("./js/foundation.core.plugin.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function c(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function h(t,e){return(h=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var f=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),c(this,d(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&h(t,e)}(n,l["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=a.a.extend({},n.defaults,this.$element.data(),e),this.className="Accordion",this._init(),s.Keyboard.register("Accordion",{ENTER:"toggle",SPACE:"toggle",ARROW_DOWN:"next",ARROW_UP:"previous"})}},{key:"_init",value:function(){var o=this;this._isInitializing=!0,this.$element.attr("role","tablist"),this.$tabs=this.$element.children("[data-accordion-item]"),this.$tabs.each(function(t,e){var n=a()(e),i=n.children("[data-tab-content]"),o=i[0].id||Object(r.GetYoDigits)(6,"accordion"),s=e.id?"".concat(e.id,"-label"):"".concat(o,"-label");n.find("a:first").attr({"aria-controls":o,role:"tab",id:s,"aria-expanded":!1,"aria-selected":!1}),i.attr({role:"tabpanel","aria-labelledby":s,"aria-hidden":!0,id:o})});var t=this.$element.find(".is-active").children("[data-tab-content]");t.length&&(this._initialAnchor=t.prev("a").attr("href"),this._openSingleTab(t)),this._checkDeepLink=function(){var t=window.location.hash;if(!t.length){if(o._isInitializing)return;o._initialAnchor&&(t=o._initialAnchor)}var e=t&&a()(t),n=t&&o.$element.find('[href$="'.concat(t,'"]')),i=!(!e.length||!n.length);e&&n&&n.length?n.parent("[data-accordion-item]").hasClass("is-active")||o._openSingleTab(e):o._closeAllTabs(),i&&(o.options.deepLinkSmudge&&Object(r.onLoad)(a()(window),function(){var t=o.$element.offset();a()("html, body").animate({scrollTop:t.top},o.options.deepLinkSmudgeDelay)}),o.$element.trigger("deeplink.zf.accordion",[n,e]))},this.options.deepLink&&this._checkDeepLink(),this._events(),this._isInitializing=!1}},{key:"_events",value:function(){var i=this;this.$tabs.each(function(){var e=a()(this),n=e.children("[data-tab-content]");n.length&&e.children("a").off("click.zf.accordion keydown.zf.accordion").on("click.zf.accordion",function(t){t.preventDefault(),i.toggle(n)}).on("keydown.zf.accordion",function(t){s.Keyboard.handleKey(t,"Accordion",{toggle:function(){i.toggle(n)},next:function(){var t=e.next().find("a").focus();i.options.multiExpand||t.trigger("click.zf.accordion")},previous:function(){var t=e.prev().find("a").focus();i.options.multiExpand||t.trigger("click.zf.accordion")},handled:function(){t.preventDefault(),t.stopPropagation()}})})}),this.options.deepLink&&a()(window).on("hashchange",this._checkDeepLink)}},{key:"toggle",value:function(t){if(t.closest("[data-accordion]").is("[disabled]"))console.info("Cannot toggle an accordion that is disabled.");else if(t.parent().hasClass("is-active")?this.up(t):this.down(t),this.options.deepLink){var e=t.prev("a").attr("href");this.options.updateHistory?history.pushState({},"",e):history.replaceState({},"",e)}}},{key:"down",value:function(t){t.closest("[data-accordion]").is("[disabled]")?console.info("Cannot call down on an accordion that is disabled."):this.options.multiExpand?this._openTab(t):this._openSingleTab(t)}},{key:"up",value:function(t){if(this.$element.is("[disabled]"))console.info("Cannot call up on an accordion that is disabled.");else{var e=t.parent();if(e.hasClass("is-active")){var n=e.siblings();(this.options.allowAllClosed||n.hasClass("is-active"))&&this._closeTab(t)}}}},{key:"_openSingleTab",value:function(t){var e=this.$element.children(".is-active").children("[data-tab-content]");e.length&&this._closeTab(e.not(t)),this._openTab(t)}},{key:"_openTab",value:function(t){var e=this,n=t.parent(),i=t.attr("aria-labelledby");t.attr("aria-hidden",!1),n.addClass("is-active"),a()("#".concat(i)).attr({"aria-expanded":!0,"aria-selected":!0}),t.slideDown(this.options.slideSpeed,function(){e.$element.trigger("down.zf.accordion",[t])})}},{key:"_closeTab",value:function(t){var e=this,n=t.parent(),i=t.attr("aria-labelledby");t.attr("aria-hidden",!0),n.removeClass("is-active"),a()("#".concat(i)).attr({"aria-expanded":!1,"aria-selected":!1}),t.slideUp(this.options.slideSpeed,function(){e.$element.trigger("up.zf.accordion",[t])})}},{key:"_closeAllTabs",value:function(){var t=this.$element.children(".is-active").children("[data-tab-content]");t.length&&this._closeTab(t)}},{key:"_destroy",value:function(){this.$element.find("[data-tab-content]").stop(!0).slideUp(0).css("display",""),this.$element.find("a").off(".zf.accordion"),this.options.deepLink&&a()(window).off("hashchange",this._checkDeepLink)}}])&&u(e.prototype,i),o&&u(e,o),n}();f.defaults={slideSpeed:250,multiExpand:!1,allowAllClosed:!1,deepLink:!1,deepLinkSmudge:!1,deepLinkSmudgeDelay:300,updateHistory:!1}},"./js/foundation.accordionMenu.js":function(t,e,n){"use strict";n.r(e),n.d(e,"AccordionMenu",function(){return p});var i=n("jquery"),r=n.n(i),l=n("./js/foundation.util.keyboard.js"),a=n("./js/foundation.util.nest.js"),u=n("./js/foundation.core.utils.js"),s=n("./js/foundation.core.plugin.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function c(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function d(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function h(t){return(h=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function f(t,e){return(f=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var p=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),d(this,h(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&f(t,e)}(n,s["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=r.a.extend({},n.defaults,this.$element.data(),e),this.className="AccordionMenu",this._init(),l.Keyboard.register("AccordionMenu",{ENTER:"toggle",SPACE:"toggle",ARROW_RIGHT:"open",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"close",ESCAPE:"closeAll"})}},{key:"_init",value:function(){a.Nest.Feather(this.$element,"accordion");var s=this;this.$element.find("[data-submenu]").not(".is-active").slideUp(0),this.$element.attr({role:"tree","aria-multiselectable":this.options.multiOpen}),this.$menuLinks=this.$element.find(".is-accordion-submenu-parent"),this.$menuLinks.each(function(){var t=this.id||Object(u.GetYoDigits)(6,"acc-menu-link"),e=r()(this),n=e.children("[data-submenu]"),i=n[0].id||Object(u.GetYoDigits)(6,"acc-menu"),o=n.hasClass("is-active");s.options.parentLink&&e.children("a").clone().prependTo(n).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-accordion-submenu-item"></li>');s.options.submenuToggle?(e.addClass("has-submenu-toggle"),e.children("a").after('<button id="'+t+'" class="submenu-toggle" aria-controls="'+i+'" aria-expanded="'+o+'" title="'+s.options.submenuToggleText+'"><span class="submenu-toggle-text">'+s.options.submenuToggleText+"</span></button>")):e.attr({"aria-controls":i,"aria-expanded":o,id:t}),n.attr({"aria-labelledby":t,"aria-hidden":!o,role:"group",id:i})}),this.$element.find("li").attr({role:"treeitem"});var t=this.$element.find(".is-active");if(t.length){s=this;t.each(function(){s.down(r()(this))})}this._events()}},{key:"_events",value:function(){var a=this;this.$element.find("li").each(function(){var e=r()(this).children("[data-submenu]");e.length&&(a.options.submenuToggle?r()(this).children(".submenu-toggle").off("click.zf.accordionMenu").on("click.zf.accordionMenu",function(t){a.toggle(e)}):r()(this).children("a").off("click.zf.accordionMenu").on("click.zf.accordionMenu",function(t){t.preventDefault(),a.toggle(e)}))}).on("keydown.zf.accordionmenu",function(e){var n,i,o=r()(this),s=o.parent("ul").children("li"),t=o.children("[data-submenu]");s.each(function(t){if(r()(this).is(o))return n=s.eq(Math.max(0,t-1)).find("a").first(),i=s.eq(Math.min(t+1,s.length-1)).find("a").first(),r()(this).children("[data-submenu]:visible").length&&(i=o.find("li:first-child").find("a").first()),r()(this).is(":first-child")?n=o.parents("li").first().find("a").first():n.parents("li").first().children("[data-submenu]:visible").length&&(n=n.parents("li").find("li:last-child").find("a").first()),void(r()(this).is(":last-child")&&(i=o.parents("li").first().next("li").find("a").first()))}),l.Keyboard.handleKey(e,"AccordionMenu",{open:function(){t.is(":hidden")&&(a.down(t),t.find("li").first().find("a").first().focus())},close:function(){t.length&&!t.is(":hidden")?a.up(t):o.parent("[data-submenu]").length&&(a.up(o.parent("[data-submenu]")),o.parents("li").first().find("a").first().focus())},up:function(){return n.focus(),!0},down:function(){return i.focus(),!0},toggle:function(){return!a.options.submenuToggle&&(o.children("[data-submenu]").length?(a.toggle(o.children("[data-submenu]")),!0):void 0)},closeAll:function(){a.hideAll()},handled:function(t){t&&e.preventDefault(),e.stopImmediatePropagation()}})})}},{key:"hideAll",value:function(){this.up(this.$element.find("[data-submenu]"))}},{key:"showAll",value:function(){this.down(this.$element.find("[data-submenu]"))}},{key:"toggle",value:function(t){t.is(":animated")||(t.is(":hidden")?this.down(t):this.up(t))}},{key:"down",value:function(t){var e=this;if(!this.options.multiOpen){var n=t.parentsUntil(this.$element).add(t).add(t.find(".is-active")),i=this.$element.find(".is-active").not(n);this.up(i)}t.addClass("is-active").attr({"aria-hidden":!1}),this.options.submenuToggle?t.prev(".submenu-toggle").attr({"aria-expanded":!0}):t.parent(".is-accordion-submenu-parent").attr({"aria-expanded":!0}),t.slideDown(this.options.slideSpeed,function(){e.$element.trigger("down.zf.accordionMenu",[t])})}},{key:"up",value:function(t){var e=this,n=t.find("[data-submenu]"),i=t.add(n);n.slideUp(0),i.removeClass("is-active").attr("aria-hidden",!0),this.options.submenuToggle?i.prev(".submenu-toggle").attr("aria-expanded",!1):i.parent(".is-accordion-submenu-parent").attr("aria-expanded",!1),t.slideUp(this.options.slideSpeed,function(){e.$element.trigger("up.zf.accordionMenu",[t])})}},{key:"_destroy",value:function(){this.$element.find("[data-submenu]").slideDown(0).css("display",""),this.$element.find("a").off("click.zf.accordionMenu"),this.$element.find("[data-is-parent-link]").detach(),this.options.submenuToggle&&(this.$element.find(".has-submenu-toggle").removeClass("has-submenu-toggle"),this.$element.find(".submenu-toggle").remove()),a.Nest.Burn(this.$element,"accordion")}}])&&c(e.prototype,i),o&&c(e,o),n}();p.defaults={parentLink:!1,slideSpeed:250,submenuToggle:!1,submenuToggleText:"Toggle menu",multiOpen:!0}},"./js/foundation.core.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Foundation",function(){return l});var i=n("jquery"),s=n.n(i),o=n("./js/foundation.core.utils.js"),a=n("./js/foundation.util.mediaQuery.js");function r(t){return(r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var l={version:"6.5.3",_plugins:{},_uuids:[],plugin:function(t,e){var n=e||u(t),i=c(n);this._plugins[i]=this[n]=t},registerPlugin:function(t,e){var n=e?c(e):u(t.constructor).toLowerCase();t.uuid=Object(o.GetYoDigits)(6,n),t.$element.attr("data-".concat(n))||t.$element.attr("data-".concat(n),t.uuid),t.$element.data("zfPlugin")||t.$element.data("zfPlugin",t),t.$element.trigger("init.zf.".concat(n)),this._uuids.push(t.uuid)},unregisterPlugin:function(t){var e=c(u(t.$element.data("zfPlugin").constructor));for(var n in this._uuids.splice(this._uuids.indexOf(t.uuid),1),t.$element.removeAttr("data-".concat(e)).removeData("zfPlugin").trigger("destroyed.zf.".concat(e)),t)t[n]=null},reInit:function(t){var e=t instanceof s.a;try{if(e)t.each(function(){s()(this).data("zfPlugin")._init()});else{var n=r(t),i=this;({object:function(t){t.forEach(function(t){t=c(t),s()("[data-"+t+"]").foundation("_init")})},string:function(){t=c(t),s()("[data-"+t+"]").foundation("_init")},undefined:function(){this.object(Object.keys(i._plugins))}})[n](t)}}catch(t){console.error(t)}finally{return t}},reflow:function(i,t){void 0===t?t=Object.keys(this._plugins):"string"==typeof t&&(t=[t]);var o=this;s.a.each(t,function(t,e){var n=o._plugins[e];s()(i).find("[data-"+e+"]").addBack("[data-"+e+"]").each(function(){var t=s()(this),i={};if(t.data("zfPlugin"))console.warn("Tried to initialize "+e+" on an element that already has a Foundation plugin.");else{if(t.attr("data-options"))t.attr("data-options").split(";").forEach(function(t,e){var n=t.split(":").map(function(t){return t.trim()});n[0]&&(i[n[0]]=function(t){{if("true"===t)return!0;if("false"===t)return!1;if(!isNaN(1*t))return parseFloat(t)}return t}(n[1]))});try{t.data("zfPlugin",new n(s()(this),i))}catch(t){console.error(t)}finally{return}}})})},getFnName:u,addToJquery:function(s){return s.fn.foundation=function(n){var t=r(n),e=s(".no-js");if(e.length&&e.removeClass("no-js"),"undefined"===t)a.MediaQuery._init(),l.reflow(this);else{if("string"!==t)throw new TypeError("We're sorry, ".concat(t," is not a valid parameter. You must use a string representing the method you wish to invoke."));var i=Array.prototype.slice.call(arguments,1),o=this.data("zfPlugin");if(void 0===o||void 0===o[n])throw new ReferenceError("We're sorry, '"+n+"' is not an available method for "+(o?u(o):"this element")+".");1===this.length?o[n].apply(o,i):this.each(function(t,e){o[n].apply(s(e).data("zfPlugin"),i)})}return this},s}};function u(t){if(void 0!==Function.prototype.name)return void 0===t.prototype?t.constructor.name:t.prototype.constructor.name;var e=/function\s([^(]{1,})\(/.exec(t.toString());return e&&1<e.length?e[1].trim():""}function c(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}l.util={throttle:function(n,i){var o=null;return function(){var t=this,e=arguments;null===o&&(o=setTimeout(function(){n.apply(t,e),o=null},i))}}},window.Foundation=l,function(){Date.now&&window.Date.now||(window.Date.now=Date.now=function(){return(new Date).getTime()});for(var t=["webkit","moz"],e=0;e<t.length&&!window.requestAnimationFrame;++e){var n=t[e];window.requestAnimationFrame=window[n+"RequestAnimationFrame"],window.cancelAnimationFrame=window[n+"CancelAnimationFrame"]||window[n+"CancelRequestAnimationFrame"]}if(/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)||!window.requestAnimationFrame||!window.cancelAnimationFrame){var i=0;window.requestAnimationFrame=function(t){var e=Date.now(),n=Math.max(i+16,e);return setTimeout(function(){t(i=n)},n-e)},window.cancelAnimationFrame=clearTimeout}window.performance&&window.performance.now||(window.performance={start:Date.now(),now:function(){return Date.now()-this.start}})}(),Function.prototype.bind||(Function.prototype.bind=function(t){if("function"!=typeof this)throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable");var e=Array.prototype.slice.call(arguments,1),n=this,i=function(){},o=function(){return n.apply(this instanceof i?this:t,e.concat(Array.prototype.slice.call(arguments)))};return this.prototype&&(i.prototype=this.prototype),o.prototype=new i,o})},"./js/foundation.core.plugin.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Plugin",function(){return i});n("jquery");var o=n("./js/foundation.core.utils.js");function s(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}var i=function(){function i(t,e){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),this._setup(t,e);var n=r(this);this.uuid=Object(o.GetYoDigits)(6,n),this.$element.attr("data-".concat(n))||this.$element.attr("data-".concat(n),this.uuid),this.$element.data("zfPlugin")||this.$element.data("zfPlugin",this),this.$element.trigger("init.zf.".concat(n))}var t,e,n;return t=i,(e=[{key:"destroy",value:function(){this._destroy();var t=r(this);for(var e in this.$element.removeAttr("data-".concat(t)).removeData("zfPlugin").trigger("destroyed.zf.".concat(t)),this)this[e]=null}}])&&s(t.prototype,e),n&&s(t,n),i}();function a(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function r(t){return void 0!==t.constructor.name?a(t.constructor.name):a(t.className)}},"./js/foundation.core.utils.js":function(t,e,n){"use strict";n.r(e),n.d(e,"rtl",function(){return o}),n.d(e,"GetYoDigits",function(){return s}),n.d(e,"RegExpEscape",function(){return a}),n.d(e,"transitionend",function(){return r}),n.d(e,"onLoad",function(){return u}),n.d(e,"ignoreMousedisappear",function(){return c});var i=n("jquery"),l=n.n(i);function o(){return"rtl"===l()("html").attr("dir")}function s(t,e){return t=t||6,Math.round(Math.pow(36,t+1)-Math.random()*Math.pow(36,t)).toString(36).slice(1)+(e?"-".concat(e):"")}function a(t){return t.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&")}function r(t){var e,n={transition:"transitionend",WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"otransitionend"},i=document.createElement("div");for(var o in n)void 0!==i.style[o]&&(e=n[o]);return e||(e=setTimeout(function(){t.triggerHandler("transitionend",[t])},1),"transitionend")}function u(t,e){var n="complete"===document.readyState,i=(n?"_didLoad":"load")+".zf.util.onLoad",o=function(){return t.triggerHandler(i)};return t&&(e&&t.one(i,e),n?setTimeout(o):l()(window).one("load",o)),i}function c(s){var t=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},e=t.ignoreLeaveWindow,a=void 0!==e&&e,n=t.ignoreReappear,r=void 0!==n&&n;return function(e){for(var t=arguments.length,n=new Array(1<t?t-1:0),i=1;i<t;i++)n[i-1]=arguments[i];var o=s.bind.apply(s,[this,e].concat(n));if(null!==e.relatedTarget)return o();setTimeout(function(){if(!a&&document.hasFocus&&!document.hasFocus())return o();r||l()(document).one("mouseenter",function(t){l()(e.currentTarget).has(t.target).length||(e.relatedTarget=t.target,o())})},0)}}},"./js/foundation.drilldown.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Drilldown",function(){return m});var i=n("jquery"),a=n.n(i),r=n("./js/foundation.util.keyboard.js"),s=n("./js/foundation.util.nest.js"),l=n("./js/foundation.core.utils.js"),u=n("./js/foundation.util.box.js"),c=n("./js/foundation.core.plugin.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function d(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function h(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function p(t,e){return(p=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var m=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),h(this,f(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&p(t,e)}(n,c["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=a.a.extend({},n.defaults,this.$element.data(),e),this.className="Drilldown",this._init(),r.Keyboard.register("Drilldown",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close",TAB:"down",SHIFT_TAB:"up"})}},{key:"_init",value:function(){s.Nest.Feather(this.$element,"drilldown"),this.options.autoApplyClass&&this.$element.addClass("drilldown"),this.$element.attr({role:"tree","aria-multiselectable":!1}),this.$submenuAnchors=this.$element.find("li.is-drilldown-submenu-parent").children("a"),this.$submenus=this.$submenuAnchors.parent("li").children("[data-submenu]").attr("role","group"),this.$menuItems=this.$element.find("li").not(".js-drilldown-back").attr("role","treeitem").find("a"),this.$currentMenu=this.$element,this.$element.attr("data-mutate",this.$element.attr("data-drilldown")||Object(l.GetYoDigits)(6,"drilldown")),this._prepareMenu(),this._registerEvents(),this._keyboardEvents()}},{key:"_prepareMenu",value:function(){var n=this;this.$submenuAnchors.each(function(){var t=a()(this),e=t.parent();n.options.parentLink&&t.clone().prependTo(e.children("[data-submenu]")).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>'),t.data("savedHref",t.attr("href")).removeAttr("href").attr("tabindex",0),t.children("[data-submenu]").attr({"aria-hidden":!0,tabindex:0,role:"group"}),n._events(t)}),this.$submenus.each(function(){var t=a()(this);if(!t.find(".js-drilldown-back").length)switch(n.options.backButtonPosition){case"bottom":t.append(n.options.backButton);break;case"top":t.prepend(n.options.backButton);break;default:console.error("Unsupported backButtonPosition value '"+n.options.backButtonPosition+"'")}n._back(t)}),this.$submenus.addClass("invisible"),this.options.autoHeight||this.$submenus.addClass("drilldown-submenu-cover-previous"),this.$element.parent().hasClass("is-drilldown")||(this.$wrapper=a()(this.options.wrapper).addClass("is-drilldown"),this.options.animateHeight&&this.$wrapper.addClass("animate-height"),this.$element.wrap(this.$wrapper)),this.$wrapper=this.$element.parent(),this.$wrapper.css(this._getMaxDims())}},{key:"_resize",value:function(){this.$wrapper.css({"max-width":"none","min-height":"none"}),this.$wrapper.css(this._getMaxDims())}},{key:"_events",value:function(n){var i=this;n.off("click.zf.drilldown").on("click.zf.drilldown",function(t){if(a()(t.target).parentsUntil("ul","li").hasClass("is-drilldown-submenu-parent")&&(t.stopImmediatePropagation(),t.preventDefault()),i._show(n.parent("li")),i.options.closeOnClick){var e=a()("body");e.off(".zf.drilldown").on("click.zf.drilldown",function(t){t.target===i.$element[0]||a.a.contains(i.$element[0],t.target)||(t.preventDefault(),i._hideAll(),e.off(".zf.drilldown"))})}})}},{key:"_registerEvents",value:function(){this.options.scrollTop&&(this._bindHandler=this._scrollTop.bind(this),this.$element.on("open.zf.drilldown hide.zf.drilldown closed.zf.drilldown",this._bindHandler)),this.$element.on("mutateme.zf.trigger",this._resize.bind(this))}},{key:"_scrollTop",value:function(){var t=this,e=""!=t.options.scrollTopElement?a()(t.options.scrollTopElement):t.$element,n=parseInt(e.offset().top+t.options.scrollTopOffset,10);a()("html, body").stop(!0).animate({scrollTop:n},t.options.animationDuration,t.options.animationEasing,function(){this===a()("html")[0]&&t.$element.trigger("scrollme.zf.drilldown")})}},{key:"_keyboardEvents",value:function(){var t=this;this.$menuItems.add(this.$element.find(".js-drilldown-back > a, .is-submenu-parent-item > a")).on("keydown.zf.drilldown",function(e){var n,i,o=a()(this),s=o.parent("li").parent("ul").children("li").children("a");s.each(function(t){if(a()(this).is(o))return n=s.eq(Math.max(0,t-1)),void(i=s.eq(Math.min(t+1,s.length-1)))}),r.Keyboard.handleKey(e,"Drilldown",{next:function(){if(o.is(t.$submenuAnchors))return t._show(o.parent("li")),o.parent("li").one(Object(l.transitionend)(o),function(){o.parent("li").find("ul li a").not(".js-drilldown-back a").first().focus()}),!0},previous:function(){return t._hide(o.parent("li").parent("ul")),o.parent("li").parent("ul").one(Object(l.transitionend)(o),function(){setTimeout(function(){o.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0},up:function(){return n.focus(),!o.is(t.$element.find("> li:first-child > a"))},down:function(){return i.focus(),!o.is(t.$element.find("> li:last-child > a"))},close:function(){o.is(t.$element.find("> li > a"))||(t._hide(o.parent().parent()),o.parent().parent().siblings("a").focus())},open:function(){return(!t.options.parentLink||!o.attr("href"))&&(o.is(t.$menuItems)?o.is(t.$submenuAnchors)?(t._show(o.parent("li")),o.parent("li").one(Object(l.transitionend)(o),function(){o.parent("li").find("ul li a").not(".js-drilldown-back a").first().focus()}),!0):void 0:(t._hide(o.parent("li").parent("ul")),o.parent("li").parent("ul").one(Object(l.transitionend)(o),function(){setTimeout(function(){o.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0))},handled:function(t){t&&e.preventDefault(),e.stopImmediatePropagation()}})})}},{key:"_hideAll",value:function(){var e=this.$element.find(".is-drilldown-submenu.is-active").addClass("is-closing");this.options.autoHeight&&this.$wrapper.css({height:e.parent().closest("ul").data("calcHeight")}),e.one(Object(l.transitionend)(e),function(t){e.removeClass("is-active is-closing")}),this.$element.trigger("closed.zf.drilldown")}},{key:"_back",value:function(n){var i=this;n.off("click.zf.drilldown"),n.children(".js-drilldown-back").on("click.zf.drilldown",function(t){t.stopImmediatePropagation(),i._hide(n);var e=n.parent("li").parent("ul").parent("li");e.length&&i._show(e)})}},{key:"_menuLinkEvents",value:function(){var e=this;this.$menuItems.not(".is-drilldown-submenu-parent").off("click.zf.drilldown").on("click.zf.drilldown",function(t){setTimeout(function(){e._hideAll()},0)})}},{key:"_setShowSubMenuClasses",value:function(t,e){t.addClass("is-active").removeClass("invisible").attr("aria-hidden",!1),t.parent("li").attr("aria-expanded",!0),!0===e&&this.$element.trigger("open.zf.drilldown",[t])}},{key:"_setHideSubMenuClasses",value:function(t,e){t.removeClass("is-active").addClass("invisible").attr("aria-hidden",!0),t.parent("li").attr("aria-expanded",!1),!0===e&&t.trigger("hide.zf.drilldown",[t])}},{key:"_showMenu",value:function(n,i){var o=this;if(this.$element.find('li[aria-expanded="true"] > ul[data-submenu]').each(function(t){o._setHideSubMenuClasses(a()(this))}),(this.$currentMenu=n).is("[data-drilldown]"))return!0===i&&n.find('li[role="treeitem"] > a').first().focus(),void(this.options.autoHeight&&this.$wrapper.css("height",n.data("calcHeight")));var s=n.children().first().parentsUntil("[data-drilldown]","[data-submenu]");s.each(function(t){0===t&&o.options.autoHeight&&o.$wrapper.css("height",a()(this).data("calcHeight"));var e=t==s.length-1;!0===e&&a()(this).one(Object(l.transitionend)(a()(this)),function(){!0===i&&n.find('li[role="treeitem"] > a').first().focus()}),o._setShowSubMenuClasses(a()(this),e)})}},{key:"_show",value:function(t){var e=t.children("[data-submenu]");t.attr("aria-expanded",!0),(this.$currentMenu=e).addClass("is-active").removeClass("invisible").attr("aria-hidden",!1),this.options.autoHeight&&this.$wrapper.css({height:e.data("calcHeight")}),this.$element.trigger("open.zf.drilldown",[t])}},{key:"_hide",value:function(t){this.options.autoHeight&&this.$wrapper.css({height:t.parent().closest("ul").data("calcHeight")});t.parent("li").attr("aria-expanded",!1),t.attr("aria-hidden",!0),t.addClass("is-closing").one(Object(l.transitionend)(t),function(){t.removeClass("is-active is-closing"),t.blur().addClass("invisible")}),t.trigger("hide.zf.drilldown",[t])}},{key:"_getMaxDims",value:function(){var e=0,t={},n=this;return this.$submenus.add(this.$element).each(function(){a()(this).children("li").length;var t=u.Box.GetDimensions(this).height;e=e<t?t:e,n.options.autoHeight&&a()(this).data("calcHeight",t)}),this.options.autoHeight?t.height=this.$currentMenu.data("calcHeight"):t["min-height"]="".concat(e,"px"),t["max-width"]="".concat(this.$element[0].getBoundingClientRect().width,"px"),t}},{key:"_destroy",value:function(){this.options.scrollTop&&this.$element.off(".zf.drilldown",this._bindHandler),this._hideAll(),this.$element.off("mutateme.zf.trigger"),s.Nest.Burn(this.$element,"drilldown"),this.$element.unwrap().find(".js-drilldown-back, .is-submenu-parent-item").remove().end().find(".is-active, .is-closing, .is-drilldown-submenu").removeClass("is-active is-closing is-drilldown-submenu").end().find("[data-submenu]").removeAttr("aria-hidden tabindex role"),this.$submenuAnchors.each(function(){a()(this).off(".zf.drilldown")}),this.$element.find("[data-is-parent-link]").detach(),this.$submenus.removeClass("drilldown-submenu-cover-previous invisible"),this.$element.find("a").each(function(){var t=a()(this);t.removeAttr("tabindex"),t.data("savedHref")&&t.attr("href",t.data("savedHref")).removeData("savedHref")})}}])&&d(e.prototype,i),o&&d(e,o),n}();m.defaults={autoApplyClass:!0,backButton:'<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',backButtonPosition:"top",wrapper:"<div></div>",parentLink:!1,closeOnClick:!1,autoHeight:!1,animateHeight:!1,scrollTop:!1,scrollTopElement:"",scrollTopOffset:0,animationDuration:500,animationEasing:"swing"}},"./js/foundation.dropdown.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Dropdown",function(){return m});var i=n("jquery"),s=n.n(i),a=n("./js/foundation.util.keyboard.js"),r=n("./js/foundation.core.utils.js"),l=n("./js/foundation.positionable.js"),u=n("./js/foundation.util.triggers.js");n("./js/foundation.util.touch.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function c(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function d(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function h(t,e,n){return(h="undefined"!=typeof Reflect&&Reflect.get?Reflect.get:function(t,e,n){var i=function(t,e){for(;!Object.prototype.hasOwnProperty.call(t,e)&&null!==(t=f(t)););return t}(t,e);if(i){var o=Object.getOwnPropertyDescriptor(i,e);return o.get?o.get.call(n):o.value}})(t,e,n||t)}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function p(t,e){return(p=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var m=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),d(this,f(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&p(t,e)}(n,l["Positionable"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=s.a.extend({},n.defaults,this.$element.data(),e),this.className="Dropdown",u.Triggers.init(s.a),this._init(),a.Keyboard.register("Dropdown",{ENTER:"toggle",SPACE:"toggle",ESCAPE:"close"})}},{key:"_init",value:function(){var t=this.$element.attr("id");this.$anchors=s()('[data-toggle="'.concat(t,'"]')).length?s()('[data-toggle="'.concat(t,'"]')):s()('[data-open="'.concat(t,'"]')),this.$anchors.attr({"aria-controls":t,"data-is-focus":!1,"data-yeti-box":t,"aria-haspopup":!0,"aria-expanded":!1}),this._setCurrentAnchor(this.$anchors.first()),this.options.parentClass?this.$parent=this.$element.parents("."+this.options.parentClass):this.$parent=null,void 0===this.$element.attr("aria-labelledby")&&(void 0===this.$currentAnchor.attr("id")&&this.$currentAnchor.attr("id",Object(r.GetYoDigits)(6,"dd-anchor")),this.$element.attr("aria-labelledby",this.$currentAnchor.attr("id"))),this.$element.attr({"aria-hidden":"true","data-yeti-box":t,"data-resize":t}),h(f(n.prototype),"_init",this).call(this),this._events()}},{key:"_getDefaultPosition",value:function(){var t=this.$element[0].className.match(/(top|left|right|bottom)/g);return t?t[0]:"bottom"}},{key:"_getDefaultAlignment",value:function(){var t=/float-(\S+)/.exec(this.$currentAnchor.attr("class"));return t?t[1]:h(f(n.prototype),"_getDefaultAlignment",this).call(this)}},{key:"_setPosition",value:function(){this.$element.removeClass("has-position-".concat(this.position," has-alignment-").concat(this.alignment)),h(f(n.prototype),"_setPosition",this).call(this,this.$currentAnchor,this.$element,this.$parent),this.$element.addClass("has-position-".concat(this.position," has-alignment-").concat(this.alignment))}},{key:"_setCurrentAnchor",value:function(t){this.$currentAnchor=s()(t)}},{key:"_events",value:function(){var n=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":this.close.bind(this),"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":this._setPosition.bind(this)}),this.$anchors.off("click.zf.trigger").on("click.zf.trigger",function(){n._setCurrentAnchor(this)}),this.options.hover&&(this.$anchors.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){n._setCurrentAnchor(this);var t=s()("body").data();void 0!==t.whatinput&&"mouse"!==t.whatinput||(clearTimeout(n.timeout),n.timeout=setTimeout(function(){n.open(),n.$anchors.data("hover",!0)},n.options.hoverDelay))}).on("mouseleave.zf.dropdown",Object(r.ignoreMousedisappear)(function(){clearTimeout(n.timeout),n.timeout=setTimeout(function(){n.close(),n.$anchors.data("hover",!1)},n.options.hoverDelay)})),this.options.hoverPane&&this.$element.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){clearTimeout(n.timeout)}).on("mouseleave.zf.dropdown",Object(r.ignoreMousedisappear)(function(){clearTimeout(n.timeout),n.timeout=setTimeout(function(){n.close(),n.$anchors.data("hover",!1)},n.options.hoverDelay)}))),this.$anchors.add(this.$element).on("keydown.zf.dropdown",function(t){var e=s()(this);a.Keyboard.findFocusable(n.$element);a.Keyboard.handleKey(t,"Dropdown",{open:function(){e.is(n.$anchors)&&!e.is("input, textarea")&&(n.open(),n.$element.attr("tabindex",-1).focus(),t.preventDefault())},close:function(){n.close(),n.$anchors.focus()}})})}},{key:"_addBodyHandler",value:function(){var e=s()(document.body).not(this.$element),n=this;e.off("click.zf.dropdown").on("click.zf.dropdown",function(t){n.$anchors.is(t.target)||n.$anchors.find(t.target).length||n.$element.is(t.target)||n.$element.find(t.target).length||(n.close(),e.off("click.zf.dropdown"))})}},{key:"open",value:function(){if(this.$element.trigger("closeme.zf.dropdown",this.$element.attr("id")),this.$anchors.addClass("hover").attr({"aria-expanded":!0}),this.$element.addClass("is-opening"),this._setPosition(),this.$element.removeClass("is-opening").addClass("is-open").attr({"aria-hidden":!1}),this.options.autoFocus){var t=a.Keyboard.findFocusable(this.$element);t.length&&t.eq(0).focus()}this.options.closeOnClick&&this._addBodyHandler(),this.options.trapFocus&&a.Keyboard.trapFocus(this.$element),this.$element.trigger("show.zf.dropdown",[this.$element])}},{key:"close",value:function(){if(!this.$element.hasClass("is-open"))return!1;this.$element.removeClass("is-open").attr({"aria-hidden":!0}),this.$anchors.removeClass("hover").attr("aria-expanded",!1),this.$element.trigger("hide.zf.dropdown",[this.$element]),this.options.trapFocus&&a.Keyboard.releaseFocus(this.$element)}},{key:"toggle",value:function(){if(this.$element.hasClass("is-open")){if(this.$anchors.data("hover"))return;this.close()}else this.open()}},{key:"_destroy",value:function(){this.$element.off(".zf.trigger").hide(),this.$anchors.off(".zf.dropdown"),s()(document.body).off("click.zf.dropdown")}}])&&c(e.prototype,i),o&&c(e,o),n}();m.defaults={parentClass:null,hoverDelay:250,hover:!1,hoverPane:!1,vOffset:0,hOffset:0,position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,trapFocus:!1,autoFocus:!1,closeOnClick:!1}},"./js/foundation.dropdownMenu.js":function(t,e,n){"use strict";n.r(e),n.d(e,"DropdownMenu",function(){return m});var i=n("jquery"),h=n.n(i),s=n("./js/foundation.core.plugin.js"),r=n("./js/foundation.core.utils.js"),f=n("./js/foundation.util.keyboard.js"),a=n("./js/foundation.util.nest.js"),l=n("./js/foundation.util.box.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function c(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function p(t,e){return(p=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var m=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),c(this,d(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&p(t,e)}(n,s["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=h.a.extend({},n.defaults,this.$element.data(),e),this.className="DropdownMenu",this._init(),f.Keyboard.register("DropdownMenu",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close"})}},{key:"_init",value:function(){a.Nest.Feather(this.$element,"dropdown");var t=this.$element.find("li.is-dropdown-submenu-parent");this.$element.children(".is-dropdown-submenu-parent").children(".is-dropdown-submenu").addClass("first-sub"),this.$menuItems=this.$element.find('[role="menuitem"]'),this.$tabs=this.$element.children('[role="menuitem"]'),this.$tabs.find("ul.is-dropdown-submenu").addClass(this.options.verticalClass),"auto"===this.options.alignment?this.$element.hasClass(this.options.rightClass)||Object(r.rtl)()||this.$element.parents(".top-bar-right").is("*")?(this.options.alignment="right",t.addClass("opens-left")):(this.options.alignment="left",t.addClass("opens-right")):"right"===this.options.alignment?t.addClass("opens-left"):t.addClass("opens-right"),this.changed=!1,this._events()}},{key:"_isVertical",value:function(){return"block"===this.$tabs.css("display")||"column"===this.$element.css("flex-direction")}},{key:"_isRtl",value:function(){return this.$element.hasClass("align-right")||Object(r.rtl)()&&!this.$element.hasClass("align-left")}},{key:"_events",value:function(){var d=this,s="ontouchstart"in window||void 0!==window.ontouchstart,a="is-dropdown-submenu-parent";(this.options.clickOpen||s)&&this.$menuItems.on("click.zf.dropdownmenu touchstart.zf.dropdownmenu",function(t){var e=h()(t.target).parentsUntil("ul",".".concat(a)),n=e.hasClass(a),i="true"===e.attr("data-is-click"),o=e.children(".is-dropdown-submenu");if(n)if(i){if(!d.options.closeOnClick||!d.options.clickOpen&&!s||d.options.forceFollow&&s)return;t.stopImmediatePropagation(),t.preventDefault(),d._hide(e)}else t.preventDefault(),t.stopImmediatePropagation(),d._show(o),e.add(e.parentsUntil(d.$element,".".concat(a))).attr("data-is-click",!0)}),d.options.closeOnClickInside&&this.$menuItems.on("click.zf.dropdownmenu",function(t){h()(this).hasClass(a)||d._hide()}),this.options.disableHover||this.$menuItems.on("mouseenter.zf.dropdownmenu",function(t){var e=h()(this);e.hasClass(a)&&(clearTimeout(e.data("_delay")),e.data("_delay",setTimeout(function(){d._show(e.children(".is-dropdown-submenu"))},d.options.hoverDelay)))}).on("mouseleave.zf.dropdownMenu",Object(r.ignoreMousedisappear)(function(t){var e=h()(this);if(e.hasClass(a)&&d.options.autoclose){if("true"===e.attr("data-is-click")&&d.options.clickOpen)return!1;clearTimeout(e.data("_delay")),e.data("_delay",setTimeout(function(){d._hide(e)},d.options.closingTime))}})),this.$menuItems.on("keydown.zf.dropdownmenu",function(e){var n,i,o=h()(e.target).parentsUntil("ul",'[role="menuitem"]'),t=-1<d.$tabs.index(o),s=t?d.$tabs:o.siblings("li").add(o);s.each(function(t){if(h()(this).is(o))return n=s.eq(t-1),void(i=s.eq(t+1))});var a=function(){i.children("a:first").focus(),e.preventDefault()},r=function(){n.children("a:first").focus(),e.preventDefault()},l=function(){var t=o.children("ul.is-dropdown-submenu");t.length&&(d._show(t),o.find("li > a:first").focus(),e.preventDefault())},u=function(){var t=o.parent("ul").parent("li");t.children("a:first").focus(),d._hide(t),e.preventDefault()},c={open:l,close:function(){d._hide(d.$element),d.$menuItems.eq(0).children("a").focus(),e.preventDefault()},handled:function(){e.stopImmediatePropagation()}};t?d._isVertical()?d._isRtl()?h.a.extend(c,{down:a,up:r,next:u,previous:l}):h.a.extend(c,{down:a,up:r,next:l,previous:u}):d._isRtl()?h.a.extend(c,{next:r,previous:a,down:l,up:u}):h.a.extend(c,{next:a,previous:r,down:l,up:u}):d._isRtl()?h.a.extend(c,{next:u,previous:l,down:a,up:r}):h.a.extend(c,{next:l,previous:u,down:a,up:r}),f.Keyboard.handleKey(e,"DropdownMenu",c)})}},{key:"_addBodyHandler",value:function(){var e=h()(document.body),n=this;e.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu").on("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu",function(t){n.$element.find(t.target).length||(n._hide(),e.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu"))})}},{key:"_show",value:function(n){var t=this.$tabs.index(this.$tabs.filter(function(t,e){return 0<h()(e).find(n).length})),e=n.parent("li.is-dropdown-submenu-parent").siblings("li.is-dropdown-submenu-parent");this._hide(e,t),n.css("visibility","hidden").addClass("js-dropdown-active").parent("li.is-dropdown-submenu-parent").addClass("is-active");var i=l.Box.ImNotTouchingYou(n,null,!0);if(!i){var o="left"===this.options.alignment?"-right":"-left",s=n.parent(".is-dropdown-submenu-parent");s.removeClass("opens".concat(o)).addClass("opens-".concat(this.options.alignment)),(i=l.Box.ImNotTouchingYou(n,null,!0))||s.removeClass("opens-".concat(this.options.alignment)).addClass("opens-inner"),this.changed=!0}n.css("visibility",""),this.options.closeOnClick&&this._addBodyHandler(),this.$element.trigger("show.zf.dropdownmenu",[n])}},{key:"_hide",value:function(t,n){var e;if((e=t&&t.length?t:void 0!==n?this.$tabs.not(function(t,e){return t===n}):this.$element).hasClass("is-active")||0<e.find(".is-active").length){if(e.find("li.is-active").add(e).attr({"data-is-click":!1}).removeClass("is-active"),e.find("ul.js-dropdown-active").removeClass("js-dropdown-active"),this.changed||e.find("opens-inner").length){var i="left"===this.options.alignment?"right":"left";e.find("li.is-dropdown-submenu-parent").add(e).removeClass("opens-inner opens-".concat(this.options.alignment)).addClass("opens-".concat(i)),this.changed=!1}this.$element.trigger("hide.zf.dropdownmenu",[e])}}},{key:"_destroy",value:function(){this.$menuItems.off(".zf.dropdownmenu").removeAttr("data-is-click").removeClass("is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner"),h()(document.body).off(".zf.dropdownmenu"),a.Nest.Burn(this.$element,"dropdown")}}])&&u(e.prototype,i),o&&u(e,o),n}();m.defaults={disableHover:!1,autoclose:!0,hoverDelay:50,clickOpen:!1,closingTime:500,alignment:"auto",closeOnClick:!0,closeOnClickInside:!0,verticalClass:"vertical",rightClass:"align-right",forceFollow:!0}},"./js/foundation.equalizer.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Equalizer",function(){return p});var i=n("jquery"),d=n.n(i),s=n("./js/foundation.util.mediaQuery.js"),a=n("./js/foundation.util.imageLoader.js"),r=n("./js/foundation.core.utils.js"),l=n("./js/foundation.core.plugin.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function c(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function h(t){return(h=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function f(t,e){return(f=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var p=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),c(this,h(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&f(t,e)}(n,l["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=d.a.extend({},n.defaults,this.$element.data(),e),this.className="Equalizer",this._init()}},{key:"_init",value:function(){var t=this.$element.attr("data-equalizer")||"",e=this.$element.find('[data-equalizer-watch="'.concat(t,'"]'));s.MediaQuery._init(),this.$watched=e.length?e:this.$element.find("[data-equalizer-watch]"),this.$element.attr("data-resize",t||Object(r.GetYoDigits)(6,"eq")),this.$element.attr("data-mutate",t||Object(r.GetYoDigits)(6,"eq")),this.hasNested=0<this.$element.find("[data-equalizer]").length,this.isNested=0<this.$element.parentsUntil(document.body,"[data-equalizer]").length,this.isOn=!1,this._bindHandler={onResizeMeBound:this._onResizeMe.bind(this),onPostEqualizedBound:this._onPostEqualized.bind(this)};var n,i=this.$element.find("img");this.options.equalizeOn?(n=this._checkMQ(),d()(window).on("changed.zf.mediaquery",this._checkMQ.bind(this))):this._events(),(void 0!==n&&!1===n||void 0===n)&&(i.length?Object(a.onImagesLoaded)(i,this._reflow.bind(this)):this._reflow())}},{key:"_pauseEvents",value:function(){this.isOn=!1,this.$element.off({".zf.equalizer":this._bindHandler.onPostEqualizedBound,"resizeme.zf.trigger":this._bindHandler.onResizeMeBound,"mutateme.zf.trigger":this._bindHandler.onResizeMeBound})}},{key:"_onResizeMe",value:function(t){this._reflow()}},{key:"_onPostEqualized",value:function(t){t.target!==this.$element[0]&&this._reflow()}},{key:"_events",value:function(){this._pauseEvents(),this.hasNested?this.$element.on("postequalized.zf.equalizer",this._bindHandler.onPostEqualizedBound):(this.$element.on("resizeme.zf.trigger",this._bindHandler.onResizeMeBound),this.$element.on("mutateme.zf.trigger",this._bindHandler.onResizeMeBound)),this.isOn=!0}},{key:"_checkMQ",value:function(){var t=!s.MediaQuery.is(this.options.equalizeOn);return t?this.isOn&&(this._pauseEvents(),this.$watched.css("height","auto")):this.isOn||this._events(),t}},{key:"_killswitch",value:function(){}},{key:"_reflow",value:function(){if(!this.options.equalizeOnStack&&this._isStacked())return this.$watched.css("height","auto"),!1;this.options.equalizeByRow?this.getHeightsByRow(this.applyHeightByRow.bind(this)):this.getHeights(this.applyHeight.bind(this))}},{key:"_isStacked",value:function(){return!this.$watched[0]||!this.$watched[1]||this.$watched[0].getBoundingClientRect().top!==this.$watched[1].getBoundingClientRect().top}},{key:"getHeights",value:function(t){for(var e=[],n=0,i=this.$watched.length;n<i;n++)this.$watched[n].style.height="auto",e.push(this.$watched[n].offsetHeight);t(e)}},{key:"getHeightsByRow",value:function(t){var e=this.$watched.length?this.$watched.first().offset().top:0,n=[],i=0;n[i]=[];for(var o=0,s=this.$watched.length;o<s;o++){this.$watched[o].style.height="auto";var a=d()(this.$watched[o]).offset().top;a!=e&&(n[++i]=[],e=a),n[i].push([this.$watched[o],this.$watched[o].offsetHeight])}for(var r=0,l=n.length;r<l;r++){var u=d()(n[r]).map(function(){return this[1]}).get(),c=Math.max.apply(null,u);n[r].push(c)}t(n)}},{key:"applyHeight",value:function(t){var e=Math.max.apply(null,t);this.$element.trigger("preequalized.zf.equalizer"),this.$watched.css("height",e),this.$element.trigger("postequalized.zf.equalizer")}},{key:"applyHeightByRow",value:function(t){this.$element.trigger("preequalized.zf.equalizer");for(var e=0,n=t.length;e<n;e++){var i=t[e].length,o=t[e][i-1];if(i<=2)d()(t[e][0][0]).css({height:"auto"});else{this.$element.trigger("preequalizedrow.zf.equalizer");for(var s=0,a=i-1;s<a;s++)d()(t[e][s][0]).css({height:o});this.$element.trigger("postequalizedrow.zf.equalizer")}}this.$element.trigger("postequalized.zf.equalizer")}},{key:"_destroy",value:function(){this._pauseEvents(),this.$watched.css("height","auto")}}])&&u(e.prototype,i),o&&u(e,o),n}();p.defaults={equalizeOnStack:!1,equalizeByRow:!1,equalizeOn:""}},"./js/foundation.interchange.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Interchange",function(){return f});var i=n("jquery"),o=n.n(i),s=n("./js/foundation.util.mediaQuery.js"),a=n("./js/foundation.core.plugin.js"),l=n("./js/foundation.core.utils.js");function r(t){return(r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function c(t,e){return!e||"object"!==r(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function h(t,e){return(h=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var f=function(t){function r(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,r),c(this,d(r).apply(this,arguments))}var e,n,i;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&h(t,e)}(r,a["Plugin"]),e=r,(n=[{key:"_setup",value:function(t,e){this.$element=t,this.options=o.a.extend({},r.defaults,e),this.rules=[],this.currentPath="",this.className="Interchange",this._init(),this._events()}},{key:"_init",value:function(){s.MediaQuery._init();var t=this.$element[0].id||Object(l.GetYoDigits)(6,"interchange");this.$element.attr({"data-resize":t,id:t}),this._addBreakpoints(),this._generateRules(),this._reflow()}},{key:"_events",value:function(){var t=this;this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(){return t._reflow()})}},{key:"_reflow",value:function(){var t;for(var e in this.rules)if(this.rules.hasOwnProperty(e)){var n=this.rules[e];window.matchMedia(n.query).matches&&(t=n)}t&&this.replace(t.path)}},{key:"_addBreakpoints",value:function(){for(var t in s.MediaQuery.queries)if(s.MediaQuery.queries.hasOwnProperty(t)){var e=s.MediaQuery.queries[t];r.SPECIAL_QUERIES[e.name]=e.value}}},{key:"_generateRules",value:function(t){var e,n=[];for(var i in e="string"==typeof(e=this.options.rules?this.options.rules:this.$element.data("interchange"))?e.match(/\[.*?, .*?\]/g):e)if(e.hasOwnProperty(i)){var o=e[i].slice(1,-1).split(", "),s=o.slice(0,-1).join(""),a=o[o.length-1];r.SPECIAL_QUERIES[a]&&(a=r.SPECIAL_QUERIES[a]),n.push({path:s,query:a})}this.rules=n}},{key:"replace",value:function(e){if(this.currentPath!==e){var n=this,i="replaced.zf.interchange";"IMG"===this.$element[0].nodeName?this.$element.attr("src",e).on("load",function(){n.currentPath=e}).trigger(i):e.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)?(e=e.replace(/\(/g,"%28").replace(/\)/g,"%29"),this.$element.css({"background-image":"url("+e+")"}).trigger(i)):o.a.get(e,function(t){n.$element.html(t).trigger(i),o()(t).foundation(),n.currentPath=e})}}},{key:"_destroy",value:function(){this.$element.off("resizeme.zf.trigger")}}])&&u(e.prototype,n),i&&u(e,i),r}();f.defaults={rules:null},f.SPECIAL_QUERIES={landscape:"screen and (orientation: landscape)",portrait:"screen and (orientation: portrait)",retina:"only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)"}},"./js/foundation.magellan.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Magellan",function(){return f});var i=n("jquery"),c=n.n(i),s=n("./js/foundation.core.utils.js"),a=n("./js/foundation.core.plugin.js"),r=n("./js/foundation.smoothScroll.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function l(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function u(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function h(t,e){return(h=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var f=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),u(this,d(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&h(t,e)}(n,a["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=c.a.extend({},n.defaults,this.$element.data(),e),this.className="Magellan",this._init(),this.calcPoints()}},{key:"_init",value:function(){var t=this.$element[0].id||Object(s.GetYoDigits)(6,"magellan");this.$targets=c()("[data-magellan-target]"),this.$links=this.$element.find("a"),this.$element.attr({"data-resize":t,"data-scroll":t,id:t}),this.$active=c()(),this.scrollPos=parseInt(window.pageYOffset,10),this._events()}},{key:"calcPoints",value:function(){var n=this,t=document.body,e=document.documentElement;this.points=[],this.winHeight=Math.round(Math.max(window.innerHeight,e.clientHeight)),this.docHeight=Math.round(Math.max(t.scrollHeight,t.offsetHeight,e.clientHeight,e.scrollHeight,e.offsetHeight)),this.$targets.each(function(){var t=c()(this),e=Math.round(t.offset().top-n.options.threshold);t.targetPoint=e,n.points.push(e)})}},{key:"_events",value:function(){var n=this;c()("html, body"),n.options.animationDuration,n.options.animationEasing;c()(window).one("load",function(){n.options.deepLinking&&location.hash&&n.scrollToLoc(location.hash),n.calcPoints(),n._updateActive()}),n.onLoadListener=Object(s.onLoad)(c()(window),function(){n.$element.on({"resizeme.zf.trigger":n.reflow.bind(n),"scrollme.zf.trigger":n._updateActive.bind(n)}).on("click.zf.magellan",'a[href^="#"]',function(t){t.preventDefault();var e=this.getAttribute("href");n.scrollToLoc(e)})}),this._deepLinkScroll=function(t){n.options.deepLinking&&n.scrollToLoc(window.location.hash)},c()(window).on("hashchange",this._deepLinkScroll)}},{key:"scrollToLoc",value:function(t){this._inTransition=!0;var e=this,n={animationEasing:this.options.animationEasing,animationDuration:this.options.animationDuration,threshold:this.options.threshold,offset:this.options.offset};r.SmoothScroll.scrollToLoc(t,n,function(){e._inTransition=!1})}},{key:"reflow",value:function(){this.calcPoints(),this._updateActive()}},{key:"_updateActive",value:function(){var n=this;if(!this._inTransition){var t,i=parseInt(window.pageYOffset,10),o=this.scrollPos>i;if((this.scrollPos=i)<this.points[0]);else if(i+this.winHeight===this.docHeight)t=this.points.length-1;else{var e=this.points.filter(function(t,e){return t-n.options.offset-(o?n.options.threshold:0)<=i});t=e.length?e.length-1:0}var s=this.$active,a="";void 0!==t?(this.$active=this.$links.filter('[href="#'+this.$targets.eq(t).data("magellan-target")+'"]'),this.$active.length&&(a=this.$active[0].getAttribute("href"))):this.$active=c()();var r=!(!this.$active.length&&!s.length||this.$active.is(s)),l=a!==window.location.hash;if(r&&(s.removeClass(this.options.activeClass),this.$active.addClass(this.options.activeClass)),this.options.deepLinking&&l)if(window.history.pushState){var u=a||window.location.pathname+window.location.search;window.history.pushState(null,null,u)}else window.location.hash=a;r&&this.$element.trigger("update.zf.magellan",[this.$active])}}},{key:"_destroy",value:function(){if(this.$element.off(".zf.trigger .zf.magellan").find(".".concat(this.options.activeClass)).removeClass(this.options.activeClass),this.options.deepLinking){var t=this.$active[0].getAttribute("href");window.location.hash.replace(t,"")}c()(window).off("hashchange",this._deepLinkScroll),this.onLoadListener&&c()(window).off(this.onLoadListener)}}])&&l(e.prototype,i),o&&l(e,o),n}();f.defaults={animationDuration:500,animationEasing:"linear",threshold:50,activeClass:"is-active",deepLinking:!1,offset:0}},"./js/foundation.offcanvas.js":function(t,e,n){"use strict";n.r(e),n.d(e,"OffCanvas",function(){return m});var i=n("jquery"),s=n.n(i),a=n("./js/foundation.core.utils.js"),r=n("./js/foundation.util.keyboard.js"),l=n("./js/foundation.util.mediaQuery.js"),u=n("./js/foundation.core.plugin.js"),c=n("./js/foundation.util.triggers.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function d(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function h(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function p(t,e){return(p=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var m=function(t){function i(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),h(this,f(i).apply(this,arguments))}var e,n,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&p(t,e)}(i,u["Plugin"]),e=i,(n=[{key:"_setup",value:function(t,e){var n=this;this.className="OffCanvas",this.$element=t,this.options=s.a.extend({},i.defaults,this.$element.data(),e),this.contentClasses={base:[],reveal:[]},this.$lastTrigger=s()(),this.$triggers=s()(),this.position="left",this.$content=s()(),this.nested=!!this.options.nested,s()(["push","overlap"]).each(function(t,e){n.contentClasses.base.push("has-transition-"+e)}),s()(["left","right","top","bottom"]).each(function(t,e){n.contentClasses.base.push("has-position-"+e),n.contentClasses.reveal.push("has-reveal-"+e)}),c.Triggers.init(s.a),l.MediaQuery._init(),this._init(),this._events(),r.Keyboard.register("OffCanvas",{ESCAPE:"close"})}},{key:"_init",value:function(){var t=this.$element.attr("id");if(this.$element.attr("aria-hidden","true"),this.options.contentId?this.$content=s()("#"+this.options.contentId):this.$element.siblings("[data-off-canvas-content]").length?this.$content=this.$element.siblings("[data-off-canvas-content]").first():this.$content=this.$element.closest("[data-off-canvas-content]").first(),this.options.contentId?this.options.contentId&&null===this.options.nested&&console.warn("Remember to use the nested option if using the content ID option!"):this.nested=0===this.$element.siblings("[data-off-canvas-content]").length,!0===this.nested&&(this.options.transition="overlap",this.$element.removeClass("is-transition-push")),this.$element.addClass("is-transition-".concat(this.options.transition," is-closed")),this.$triggers=s()(document).find('[data-open="'+t+'"], [data-close="'+t+'"], [data-toggle="'+t+'"]').attr("aria-expanded","false").attr("aria-controls",t),this.position=this.$element.is(".position-left, .position-top, .position-right, .position-bottom")?this.$element.attr("class").match(/position\-(left|top|right|bottom)/)[1]:this.position,!0===this.options.contentOverlay){var e=document.createElement("div"),n="fixed"===s()(this.$element).css("position")?"is-overlay-fixed":"is-overlay-absolute";e.setAttribute("class","js-off-canvas-overlay "+n),this.$overlay=s()(e),"is-overlay-fixed"===n?s()(this.$overlay).insertAfter(this.$element):this.$content.append(this.$overlay)}var i=new RegExp(Object(a.RegExpEscape)(this.options.revealClass)+"([^\\s]+)","g").exec(this.$element[0].className);i&&(this.options.isRevealed=!0,this.options.revealOn=this.options.revealOn||i[1]),!0===this.options.isRevealed&&this.options.revealOn&&(this.$element.first().addClass("".concat(this.options.revealClass).concat(this.options.revealOn)),this._setMQChecker()),this.options.transitionTime&&this.$element.css("transition-duration",this.options.transitionTime),this._removeContentClasses()}},{key:"_events",value:function(){(this.$element.off(".zf.trigger .zf.offcanvas").on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":this.close.bind(this),"toggle.zf.trigger":this.toggle.bind(this),"keydown.zf.offcanvas":this._handleKeyboard.bind(this)}),!0===this.options.closeOnClick)&&(this.options.contentOverlay?this.$overlay:this.$content).on({"click.zf.offcanvas":this.close.bind(this)})}},{key:"_setMQChecker",value:function(){var t=this;this.onLoadListener=Object(a.onLoad)(s()(window),function(){l.MediaQuery.atLeast(t.options.revealOn)&&t.reveal(!0)}),s()(window).on("changed.zf.mediaquery",function(){l.MediaQuery.atLeast(t.options.revealOn)?t.reveal(!0):t.reveal(!1)})}},{key:"_removeContentClasses",value:function(t){"boolean"!=typeof t?this.$content.removeClass(this.contentClasses.base.join(" ")):!1===t&&this.$content.removeClass("has-reveal-".concat(this.position))}},{key:"_addContentClasses",value:function(t){this._removeContentClasses(t),"boolean"!=typeof t?this.$content.addClass("has-transition-".concat(this.options.transition," has-position-").concat(this.position)):!0===t&&this.$content.addClass("has-reveal-".concat(this.position))}},{key:"reveal",value:function(t){t?(this.close(),this.isRevealed=!0,this.$element.attr("aria-hidden","false"),this.$element.off("open.zf.trigger toggle.zf.trigger"),this.$element.removeClass("is-closed")):(this.isRevealed=!1,this.$element.attr("aria-hidden","true"),this.$element.off("open.zf.trigger toggle.zf.trigger").on({"open.zf.trigger":this.open.bind(this),"toggle.zf.trigger":this.toggle.bind(this)}),this.$element.addClass("is-closed")),this._addContentClasses(t)}},{key:"_stopScrolling",value:function(t){return!1}},{key:"_recordScrollable",value:function(t){var e=this;e.scrollHeight!==e.clientHeight&&(0===e.scrollTop&&(e.scrollTop=1),e.scrollTop===e.scrollHeight-e.clientHeight&&(e.scrollTop=e.scrollHeight-e.clientHeight-1)),e.allowUp=0<e.scrollTop,e.allowDown=e.scrollTop<e.scrollHeight-e.clientHeight,e.lastY=t.originalEvent.pageY}},{key:"_stopScrollPropagation",value:function(t){var e=t.pageY<this.lastY,n=!e;this.lastY=t.pageY,e&&this.allowUp||n&&this.allowDown?t.stopPropagation():t.preventDefault()}},{key:"open",value:function(t,e){if(!this.$element.hasClass("is-open")&&!this.isRevealed){var n=this;e&&(this.$lastTrigger=e),"top"===this.options.forceTo?window.scrollTo(0,0):"bottom"===this.options.forceTo&&window.scrollTo(0,document.body.scrollHeight),this.options.transitionTime&&"overlap"!==this.options.transition?this.$element.siblings("[data-off-canvas-content]").css("transition-duration",this.options.transitionTime):this.$element.siblings("[data-off-canvas-content]").css("transition-duration",""),this.$element.addClass("is-open").removeClass("is-closed"),this.$triggers.attr("aria-expanded","true"),this.$element.attr("aria-hidden","false"),this.$content.addClass("is-open-"+this.position),!1===this.options.contentScroll&&(s()("body").addClass("is-off-canvas-open").on("touchmove",this._stopScrolling),this.$element.on("touchstart",this._recordScrollable),this.$element.on("touchmove",this._stopScrollPropagation)),!0===this.options.contentOverlay&&this.$overlay.addClass("is-visible"),!0===this.options.closeOnClick&&!0===this.options.contentOverlay&&this.$overlay.addClass("is-closable"),!0===this.options.autoFocus&&this.$element.one(Object(a.transitionend)(this.$element),function(){if(n.$element.hasClass("is-open")){var t=n.$element.find("[data-autofocus]");t.length?t.eq(0).focus():n.$element.find("a, button").eq(0).focus()}}),!0===this.options.trapFocus&&(this.$content.attr("tabindex","-1"),r.Keyboard.trapFocus(this.$element)),this._addContentClasses(),this.$element.trigger("opened.zf.offcanvas")}}},{key:"close",value:function(t){if(this.$element.hasClass("is-open")&&!this.isRevealed){var e=this;this.$element.removeClass("is-open"),this.$element.attr("aria-hidden","true").trigger("closed.zf.offcanvas"),this.$content.removeClass("is-open-left is-open-top is-open-right is-open-bottom"),!1===this.options.contentScroll&&(s()("body").removeClass("is-off-canvas-open").off("touchmove",this._stopScrolling),this.$element.off("touchstart",this._recordScrollable),this.$element.off("touchmove",this._stopScrollPropagation)),!0===this.options.contentOverlay&&this.$overlay.removeClass("is-visible"),!0===this.options.closeOnClick&&!0===this.options.contentOverlay&&this.$overlay.removeClass("is-closable"),this.$triggers.attr("aria-expanded","false"),!0===this.options.trapFocus&&(this.$content.removeAttr("tabindex"),r.Keyboard.releaseFocus(this.$element)),this.$element.one(Object(a.transitionend)(this.$element),function(t){e.$element.addClass("is-closed"),e._removeContentClasses()})}}},{key:"toggle",value:function(t,e){this.$element.hasClass("is-open")?this.close(t,e):this.open(t,e)}},{key:"_handleKeyboard",value:function(t){var e=this;r.Keyboard.handleKey(t,"OffCanvas",{close:function(){return e.close(),e.$lastTrigger.focus(),!0},handled:function(){t.stopPropagation(),t.preventDefault()}})}},{key:"_destroy",value:function(){this.close(),this.$element.off(".zf.trigger .zf.offcanvas"),this.$overlay.off(".zf.offcanvas"),this.onLoadListener&&s()(window).off(this.onLoadListener)}}])&&d(e.prototype,n),o&&d(e,o),i}();m.defaults={closeOnClick:!0,contentOverlay:!0,contentId:null,nested:null,contentScroll:!0,transitionTime:null,transition:"push",forceTo:null,isRevealed:!1,revealOn:null,autoFocus:!0,revealClass:"reveal-for-",trapFocus:!1}},"./js/foundation.orbit.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Orbit",function(){return v});var i=n("jquery"),s=n.n(i),a=n("./js/foundation.util.keyboard.js"),c=n("./js/foundation.util.motion.js"),r=n("./js/foundation.util.timer.js"),l=n("./js/foundation.util.imageLoader.js"),u=n("./js/foundation.core.utils.js"),d=n("./js/foundation.core.plugin.js"),h=n("./js/foundation.util.touch.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function f(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function p(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function m(t){return(m=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function g(t,e){return(g=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var v=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),p(this,m(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&g(t,e)}(n,d["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=s.a.extend({},n.defaults,this.$element.data(),e),this.className="Orbit",h.Touch.init(s.a),this._init(),a.Keyboard.register("Orbit",{ltr:{ARROW_RIGHT:"next",ARROW_LEFT:"previous"},rtl:{ARROW_LEFT:"next",ARROW_RIGHT:"previous"}})}},{key:"_init",value:function(){this._reset(),this.$wrapper=this.$element.find(".".concat(this.options.containerClass)),this.$slides=this.$element.find(".".concat(this.options.slideClass));var t=this.$element.find("img"),e=this.$slides.filter(".is-active"),n=this.$element[0].id||Object(u.GetYoDigits)(6,"orbit");this.$element.attr({"data-resize":n,id:n}),e.length||this.$slides.eq(0).addClass("is-active"),this.options.useMUI||this.$slides.addClass("no-motionui"),t.length?Object(l.onImagesLoaded)(t,this._prepareForOrbit.bind(this)):this._prepareForOrbit(),this.options.bullets&&this._loadBullets(),this._events(),this.options.autoPlay&&1<this.$slides.length&&this.geoSync(),this.options.accessible&&this.$wrapper.attr("tabindex",0)}},{key:"_loadBullets",value:function(){this.$bullets=this.$element.find(".".concat(this.options.boxOfBullets)).find("button")}},{key:"geoSync",value:function(){var t=this;this.timer=new r.Timer(this.$element,{duration:this.options.timerDelay,infinite:!1},function(){t.changeSlide(!0)}),this.timer.start()}},{key:"_prepareForOrbit",value:function(){this._setWrapperHeight()}},{key:"_setWrapperHeight",value:function(t){var e,n=0,i=0,o=this;this.$slides.each(function(){e=this.getBoundingClientRect().height,s()(this).attr("data-slide",i),/mui/g.test(s()(this)[0].className)||o.$slides.filter(".is-active")[0]===o.$slides.eq(i)[0]||s()(this).css({display:"none"}),n=n<e?e:n,i++}),i===this.$slides.length&&(this.$wrapper.css({height:n}),t&&t(n))}},{key:"_setSlideHeight",value:function(t){this.$slides.each(function(){s()(this).css("max-height",t)})}},{key:"_events",value:function(){var i=this;if(this.$element.off(".resizeme.zf.trigger").on({"resizeme.zf.trigger":this._prepareForOrbit.bind(this)}),1<this.$slides.length){if(this.options.swipe&&this.$slides.off("swipeleft.zf.orbit swiperight.zf.orbit").on("swipeleft.zf.orbit",function(t){t.preventDefault(),i.changeSlide(!0)}).on("swiperight.zf.orbit",function(t){t.preventDefault(),i.changeSlide(!1)}),this.options.autoPlay&&(this.$slides.on("click.zf.orbit",function(){i.$element.data("clickedOn",!i.$element.data("clickedOn")),i.timer[i.$element.data("clickedOn")?"pause":"start"]()}),this.options.pauseOnHover&&this.$element.on("mouseenter.zf.orbit",function(){i.timer.pause()}).on("mouseleave.zf.orbit",function(){i.$element.data("clickedOn")||i.timer.start()})),this.options.navButtons)this.$element.find(".".concat(this.options.nextClass,", .").concat(this.options.prevClass)).attr("tabindex",0).on("click.zf.orbit touchend.zf.orbit",function(t){t.preventDefault(),i.changeSlide(s()(this).hasClass(i.options.nextClass))});this.options.bullets&&this.$bullets.on("click.zf.orbit touchend.zf.orbit",function(){if(/is-active/g.test(this.className))return!1;var t=s()(this).data("slide"),e=t>i.$slides.filter(".is-active").data("slide"),n=i.$slides.eq(t);i.changeSlide(e,n,t)}),this.options.accessible&&this.$wrapper.add(this.$bullets).on("keydown.zf.orbit",function(t){a.Keyboard.handleKey(t,"Orbit",{next:function(){i.changeSlide(!0)},previous:function(){i.changeSlide(!1)},handled:function(){s()(t.target).is(i.$bullets)&&i.$bullets.filter(".is-active").focus()}})})}}},{key:"_reset",value:function(){void 0!==this.$slides&&1<this.$slides.length&&(this.$element.off(".zf.orbit").find("*").off(".zf.orbit"),this.options.autoPlay&&this.timer.restart(),this.$slides.each(function(t){s()(t).removeClass("is-active is-active is-in").removeAttr("aria-live").hide()}),this.$slides.first().addClass("is-active").show(),this.$element.trigger("slidechange.zf.orbit",[this.$slides.first()]),this.options.bullets&&this._updateBullets(0))}},{key:"changeSlide",value:function(t,e,n){if(this.$slides){var i=this.$slides.filter(".is-active").eq(0);if(/mui/g.test(i[0].className))return!1;var o,s=this.$slides.first(),a=this.$slides.last(),r=t?"Right":"Left",l=t?"Left":"Right",u=this;(o=e||(t?this.options.infiniteWrap?i.next(".".concat(this.options.slideClass)).length?i.next(".".concat(this.options.slideClass)):s:i.next(".".concat(this.options.slideClass)):this.options.infiniteWrap?i.prev(".".concat(this.options.slideClass)).length?i.prev(".".concat(this.options.slideClass)):a:i.prev(".".concat(this.options.slideClass)))).length&&(this.$element.trigger("beforeslidechange.zf.orbit",[i,o]),this.options.bullets&&(n=n||this.$slides.index(o),this._updateBullets(n)),this.options.useMUI&&!this.$element.is(":hidden")?(c.Motion.animateIn(o.addClass("is-active"),this.options["animInFrom".concat(r)],function(){o.css({display:"block"}).attr("aria-live","polite")}),c.Motion.animateOut(i.removeClass("is-active"),this.options["animOutTo".concat(l)],function(){i.removeAttr("aria-live"),u.options.autoPlay&&!u.timer.isPaused&&u.timer.restart()})):(i.removeClass("is-active is-in").removeAttr("aria-live").hide(),o.addClass("is-active is-in").attr("aria-live","polite").show(),this.options.autoPlay&&!this.timer.isPaused&&this.timer.restart()),this.$element.trigger("slidechange.zf.orbit",[o]))}}},{key:"_updateBullets",value:function(t){var e=this.$element.find(".".concat(this.options.boxOfBullets)).find(".is-active").removeClass("is-active").blur().find("span:last").detach();this.$bullets.eq(t).addClass("is-active").append(e)}},{key:"_destroy",value:function(){this.$element.off(".zf.orbit").find("*").off(".zf.orbit").end().hide()}}])&&f(e.prototype,i),o&&f(e,o),n}();v.defaults={bullets:!0,navButtons:!0,animInFromRight:"slide-in-right",animOutToRight:"slide-out-right",animInFromLeft:"slide-in-left",animOutToLeft:"slide-out-left",autoPlay:!0,timerDelay:5e3,infiniteWrap:!0,swipe:!0,pauseOnHover:!0,accessible:!0,containerClass:"orbit-container",slideClass:"orbit-slide",boxOfBullets:"orbit-bullets",nextClass:"orbit-next",prevClass:"orbit-previous",useMUI:!0}},"./js/foundation.positionable.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Positionable",function(){return g});var a=n("./js/foundation.util.box.js"),s=n("./js/foundation.core.plugin.js"),r=n("./js/foundation.core.utils.js");function i(t){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function l(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function u(t,e){return!e||"object"!==i(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function c(t){return(c=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function d(t,e){return(d=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var h=["left","right","top","bottom"],o=["top","bottom","center"],f=["left","right","center"],p={left:o,right:o,top:f,bottom:f};function m(t,e){var n=e.indexOf(t);return n===e.length-1?e[0]:e[n+1]}var g=function(t){function e(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,e),u(this,c(e).apply(this,arguments))}var n,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&d(t,e)}(e,s["Plugin"]),n=e,(i=[{key:"_init",value:function(){this.triedPositions={},this.position="auto"===this.options.position?this._getDefaultPosition():this.options.position,this.alignment="auto"===this.options.alignment?this._getDefaultAlignment():this.options.alignment,this.originalPosition=this.position,this.originalAlignment=this.alignment}},{key:"_getDefaultPosition",value:function(){return"bottom"}},{key:"_getDefaultAlignment",value:function(){switch(this.position){case"bottom":case"top":return Object(r.rtl)()?"right":"left";case"left":case"right":return"bottom"}}},{key:"_reposition",value:function(){this._alignmentsExhausted(this.position)?(this.position=m(this.position,h),this.alignment=p[this.position][0]):this._realign()}},{key:"_realign",value:function(){this._addTriedPosition(this.position,this.alignment),this.alignment=m(this.alignment,p[this.position])}},{key:"_addTriedPosition",value:function(t,e){this.triedPositions[t]=this.triedPositions[t]||[],this.triedPositions[t].push(e)}},{key:"_positionsExhausted",value:function(){for(var t=!0,e=0;e<h.length;e++)t=t&&this._alignmentsExhausted(h[e]);return t}},{key:"_alignmentsExhausted",value:function(t){return this.triedPositions[t]&&this.triedPositions[t].length==p[t].length}},{key:"_getVOffset",value:function(){return this.options.vOffset}},{key:"_getHOffset",value:function(){return this.options.hOffset}},{key:"_setPosition",value:function(t,e,n){if("false"===t.attr("aria-expanded"))return!1;a.Box.GetDimensions(e),a.Box.GetDimensions(t);if(this.options.allowOverlap||(this.position=this.originalPosition,this.alignment=this.originalAlignment),e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset())),!this.options.allowOverlap){for(var i=1e8,o={position:this.position,alignment:this.alignment};!this._positionsExhausted();){var s=a.Box.OverlapArea(e,n,!1,!1,this.options.allowBottomOverlap);if(0===s)return;s<i&&(i=s,o={position:this.position,alignment:this.alignment}),this._reposition(),e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}this.position=o.position,this.alignment=o.alignment,e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}}}])&&l(n.prototype,i),o&&l(n,o),e}();g.defaults={position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,vOffset:0,hOffset:0}},"./js/foundation.responsiveAccordionTabs.js":function(t,e,n){"use strict";n.r(e),n.d(e,"ResponsiveAccordionTabs",function(){return m});var i=n("jquery"),c=n.n(i),a=n("./js/foundation.util.mediaQuery.js"),d=n("./js/foundation.core.utils.js"),s=n("./js/foundation.core.plugin.js"),o=n("./js/foundation.accordion.js");function r(t){return(r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function l(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function u(t,e){return!e||"object"!==r(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function h(t){return(h=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function f(t,e){return(f=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var p={tabs:{cssClass:"tabs",plugin:n("./js/foundation.tabs.js").Tabs},accordion:{cssClass:"accordion",plugin:o.Accordion}},m=function(t){function e(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,e),u(this,h(e).apply(this,arguments))}var n,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&f(t,e)}(e,s["Plugin"]),n=e,(i=[{key:"_setup",value:function(t,e){this.$element=c()(t),this.options=c.a.extend({},this.$element.data(),e),this.rules=this.$element.data("responsive-accordion-tabs"),this.currentMq=null,this.currentPlugin=null,this.className="ResponsiveAccordionTabs",this.$element.attr("id")||this.$element.attr("id",Object(d.GetYoDigits)(6,"responsiveaccordiontabs")),this._init(),this._events()}},{key:"_init",value:function(){if(a.MediaQuery._init(),"string"==typeof this.rules){for(var t={},e=this.rules.split(" "),n=0;n<e.length;n++){var i=e[n].split("-"),o=1<i.length?i[0]:"small",s=1<i.length?i[1]:i[0];null!==p[s]&&(t[o]=p[s])}this.rules=t}this._getAllOptions(),c.a.isEmptyObject(this.rules)||this._checkMediaQueries()}},{key:"_getAllOptions",value:function(){for(var t in this.allOptions={},p)if(p.hasOwnProperty(t)){var e=p[t];try{var n=c()("<ul></ul>"),i=new e.plugin(n,this.options);for(var o in i.options)if(i.options.hasOwnProperty(o)&&"zfPlugin"!==o){var s=i.options[o];this.allOptions[o]=s}i.destroy()}catch(t){}}}},{key:"_events",value:function(){this._changedZfMediaQueryHandler=this._checkMediaQueries.bind(this),c()(window).on("changed.zf.mediaquery",this._changedZfMediaQueryHandler)}},{key:"_checkMediaQueries",value:function(){var e,n=this;c.a.each(this.rules,function(t){a.MediaQuery.atLeast(t)&&(e=t)}),e&&(this.currentPlugin instanceof this.rules[e].plugin||(c.a.each(p,function(t,e){n.$element.removeClass(e.cssClass)}),this.$element.addClass(this.rules[e].cssClass),this.currentPlugin&&(!this.currentPlugin.$element.data("zfPlugin")&&this.storezfData&&this.currentPlugin.$element.data("zfPlugin",this.storezfData),this.currentPlugin.destroy()),this._handleMarkup(this.rules[e].cssClass),this.currentPlugin=new this.rules[e].plugin(this.$element,{}),this.storezfData=this.currentPlugin.$element.data("zfPlugin")))}},{key:"_handleMarkup",value:function(t){var n=this,e="accordion",i=c()("[data-tabs-content="+this.$element.attr("id")+"]");if(i.length&&(e="tabs"),e!==t){var o=n.allOptions.linkClass?n.allOptions.linkClass:"tabs-title",s=n.allOptions.panelClass?n.allOptions.panelClass:"tabs-panel";this.$element.removeAttr("role");var a=this.$element.children("."+o+",[data-accordion-item]").removeClass(o).removeClass("accordion-item").removeAttr("data-accordion-item"),r=a.children("a").removeClass("accordion-title");if("tabs"===e?(i=i.children("."+s).removeClass(s).removeAttr("role").removeAttr("aria-hidden").removeAttr("aria-labelledby")).children("a").removeAttr("role").removeAttr("aria-controls").removeAttr("aria-selected"):i=a.children("[data-tab-content]").removeClass("accordion-content"),i.css({display:"",visibility:""}),a.css({display:"",visibility:""}),"accordion"===t)i.each(function(t,e){c()(e).appendTo(a.get(t)).addClass("accordion-content").attr("data-tab-content","").removeClass("is-active").css({height:""}),c()("[data-tabs-content="+n.$element.attr("id")+"]").after('<div id="tabs-placeholder-'+n.$element.attr("id")+'"></div>').detach(),a.addClass("accordion-item").attr("data-accordion-item",""),r.addClass("accordion-title")});else if("tabs"===t){var l=c()("[data-tabs-content="+n.$element.attr("id")+"]"),u=c()("#tabs-placeholder-"+n.$element.attr("id"));u.length?(l=c()('<div class="tabs-content"></div>').insertAfter(u).attr("data-tabs-content",n.$element.attr("id")),u.remove()):l=c()('<div class="tabs-content"></div>').insertAfter(n.$element).attr("data-tabs-content",n.$element.attr("id")),i.each(function(t,e){var n=c()(e).appendTo(l).addClass(s),i=r.get(t).hash.slice(1),o=c()(e).attr("id")||Object(d.GetYoDigits)(6,"accordion");i!==o&&(""!==i?c()(e).attr("id",i):(i=o,c()(e).attr("id",i),c()(r.get(t)).attr("href",c()(r.get(t)).attr("href").replace("#","")+"#"+i))),c()(a.get(t)).hasClass("is-active")&&n.addClass("is-active")}),a.addClass(o)}}}},{key:"_destroy",value:function(){this.currentPlugin&&this.currentPlugin.destroy(),c()(window).off("changed.zf.mediaquery",this._changedZfMediaQueryHandler)}}])&&l(n.prototype,i),o&&l(n,o),e}();m.defaults={}},"./js/foundation.responsiveMenu.js":function(t,e,n){"use strict";n.r(e),n.d(e,"ResponsiveMenu",function(){return v});var i=n("jquery"),a=n.n(i),r=n("./js/foundation.util.mediaQuery.js"),l=n("./js/foundation.core.utils.js"),s=n("./js/foundation.core.plugin.js"),o=n("./js/foundation.dropdownMenu.js"),u=n("./js/foundation.drilldown.js"),c=n("./js/foundation.accordionMenu.js");function d(t){return(d="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function h(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function f(t,e){return!e||"object"!==d(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function p(t){return(p=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function m(t,e){return(m=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var g={dropdown:{cssClass:"dropdown",plugin:o.DropdownMenu},drilldown:{cssClass:"drilldown",plugin:u.Drilldown},accordion:{cssClass:"accordion-menu",plugin:c.AccordionMenu}},v=function(t){function e(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,e),f(this,p(e).apply(this,arguments))}var n,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&m(t,e)}(e,s["Plugin"]),n=e,(i=[{key:"_setup",value:function(t,e){this.$element=a()(t),this.rules=this.$element.data("responsive-menu"),this.currentMq=null,this.currentPlugin=null,this.className="ResponsiveMenu",this._init(),this._events()}},{key:"_init",value:function(){if(r.MediaQuery._init(),"string"==typeof this.rules){for(var t={},e=this.rules.split(" "),n=0;n<e.length;n++){var i=e[n].split("-"),o=1<i.length?i[0]:"small",s=1<i.length?i[1]:i[0];null!==g[s]&&(t[o]=g[s])}this.rules=t}a.a.isEmptyObject(this.rules)||this._checkMediaQueries(),this.$element.attr("data-mutate",this.$element.attr("data-mutate")||Object(l.GetYoDigits)(6,"responsive-menu"))}},{key:"_events",value:function(){var t=this;a()(window).on("changed.zf.mediaquery",function(){t._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var e,n=this;a.a.each(this.rules,function(t){r.MediaQuery.atLeast(t)&&(e=t)}),e&&(this.currentPlugin instanceof this.rules[e].plugin||(a.a.each(g,function(t,e){n.$element.removeClass(e.cssClass)}),this.$element.addClass(this.rules[e].cssClass),this.currentPlugin&&this.currentPlugin.destroy(),this.currentPlugin=new this.rules[e].plugin(this.$element,{})))}},{key:"_destroy",value:function(){this.currentPlugin.destroy(),a()(window).off(".zf.ResponsiveMenu")}}])&&h(n.prototype,i),o&&h(n,o),e}();v.defaults={}},"./js/foundation.responsiveToggle.js":function(t,e,n){"use strict";n.r(e),n.d(e,"ResponsiveToggle",function(){return f});var i=n("jquery"),s=n.n(i),a=n("./js/foundation.util.mediaQuery.js"),r=n("./js/foundation.util.motion.js"),l=n("./js/foundation.core.plugin.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function c(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function h(t,e){return(h=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var f=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),c(this,d(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&h(t,e)}(n,l["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=s()(t),this.options=s.a.extend({},n.defaults,this.$element.data(),e),this.className="ResponsiveToggle",this._init(),this._events()}},{key:"_init",value:function(){a.MediaQuery._init();var e=this.$element.data("responsive-toggle");if(e||console.error("Your tab bar needs an ID of a Menu as the value of data-tab-bar."),this.$targetMenu=s()("#".concat(e)),this.$toggler=this.$element.find("[data-toggle]").filter(function(){var t=s()(this).data("toggle");return t===e||""===t}),this.options=s.a.extend({},this.options,this.$targetMenu.data()),this.options.animate){var t=this.options.animate.split(" ");this.animationIn=t[0],this.animationOut=t[1]||null}this._update()}},{key:"_events",value:function(){this._updateMqHandler=this._update.bind(this),s()(window).on("changed.zf.mediaquery",this._updateMqHandler),this.$toggler.on("click.zf.responsiveToggle",this.toggleMenu.bind(this))}},{key:"_update",value:function(){a.MediaQuery.atLeast(this.options.hideFor)?(this.$element.hide(),this.$targetMenu.show()):(this.$element.show(),this.$targetMenu.hide())}},{key:"toggleMenu",value:function(){var t=this;a.MediaQuery.atLeast(this.options.hideFor)||(this.options.animate?this.$targetMenu.is(":hidden")?r.Motion.animateIn(this.$targetMenu,this.animationIn,function(){t.$element.trigger("toggled.zf.responsiveToggle"),t.$targetMenu.find("[data-mutate]").triggerHandler("mutateme.zf.trigger")}):r.Motion.animateOut(this.$targetMenu,this.animationOut,function(){t.$element.trigger("toggled.zf.responsiveToggle")}):(this.$targetMenu.toggle(0),this.$targetMenu.find("[data-mutate]").trigger("mutateme.zf.trigger"),this.$element.trigger("toggled.zf.responsiveToggle")))}},{key:"_destroy",value:function(){this.$element.off(".zf.responsiveToggle"),this.$toggler.off(".zf.responsiveToggle"),s()(window).off("changed.zf.mediaquery",this._updateMqHandler)}}])&&u(e.prototype,i),o&&u(e,o),n}();f.defaults={hideFor:"medium",animate:!1}},"./js/foundation.reveal.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Reveal",function(){return g});var i=n("jquery"),a=n.n(i),s=n("./js/foundation.core.utils.js"),r=n("./js/foundation.util.keyboard.js"),l=n("./js/foundation.util.mediaQuery.js"),u=n("./js/foundation.util.motion.js"),c=n("./js/foundation.core.plugin.js"),d=n("./js/foundation.util.triggers.js");n("./js/foundation.util.touch.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function h(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function f(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function p(t){return(p=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function m(t,e){return(m=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var g=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),f(this,p(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&m(t,e)}(n,c["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=a.a.extend({},n.defaults,this.$element.data(),e),this.className="Reveal",this._init(),d.Triggers.init(a.a),r.Keyboard.register("Reveal",{ESCAPE:"close"})}},{key:"_init",value:function(){var t=this;l.MediaQuery._init(),this.id=this.$element.attr("id"),this.isActive=!1,this.cached={mq:l.MediaQuery.current},this.$anchor=a()('[data-open="'.concat(this.id,'"]')).length?a()('[data-open="'.concat(this.id,'"]')):a()('[data-toggle="'.concat(this.id,'"]')),this.$anchor.attr({"aria-controls":this.id,"aria-haspopup":!0,tabindex:0}),(this.options.fullScreen||this.$element.hasClass("full"))&&(this.options.fullScreen=!0,this.options.overlay=!1),this.options.overlay&&!this.$overlay&&(this.$overlay=this._makeOverlay(this.id)),this.$element.attr({role:"dialog","aria-hidden":!0,"data-yeti-box":this.id,"data-resize":this.id}),this.$overlay?this.$element.detach().appendTo(this.$overlay):(this.$element.detach().appendTo(a()(this.options.appendTo)),this.$element.addClass("without-overlay")),this._events(),this.options.deepLink&&window.location.hash==="#".concat(this.id)&&(this.onLoadListener=Object(s.onLoad)(a()(window),function(){return t.open()}))}},{key:"_makeOverlay",value:function(){var t="";return this.options.additionalOverlayClasses&&(t=" "+this.options.additionalOverlayClasses),a()("<div></div>").addClass("reveal-overlay"+t).appendTo(this.options.appendTo)}},{key:"_updatePosition",value:function(){var t,e=this.$element.outerWidth(),n=a()(window).width(),i=this.$element.outerHeight(),o=a()(window).height(),s=null;t="auto"===this.options.hOffset?parseInt((n-e)/2,10):parseInt(this.options.hOffset,10),"auto"===this.options.vOffset?s=o<i?parseInt(Math.min(100,o/10),10):parseInt((o-i)/4,10):null!==this.options.vOffset&&(s=parseInt(this.options.vOffset,10)),null!==s&&this.$element.css({top:s+"px"}),this.$overlay&&"auto"===this.options.hOffset||(this.$element.css({left:t+"px"}),this.$element.css({margin:"0px"}))}},{key:"_events",value:function(){var n=this,i=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":function(t,e){if(t.target===i.$element[0]||a()(t.target).parents("[data-closable]")[0]===e)return n.close.apply(n)},"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":function(){i._updatePosition()}}),this.options.closeOnClick&&this.options.overlay&&this.$overlay.off(".zf.reveal").on("click.zf.reveal",function(t){t.target!==i.$element[0]&&!a.a.contains(i.$element[0],t.target)&&a.a.contains(document,t.target)&&i.close()}),this.options.deepLink&&a()(window).on("hashchange.zf.reveal:".concat(this.id),this._handleState.bind(this))}},{key:"_handleState",value:function(t){window.location.hash!=="#"+this.id||this.isActive?this.close():this.open()}},{key:"_disableScroll",value:function(t){t=t||a()(window).scrollTop(),a()(document).height()>a()(window).height()&&a()("html").css("top",-t)}},{key:"_enableScroll",value:function(t){t=t||parseInt(a()("html").css("top")),a()(document).height()>a()(window).height()&&(a()("html").css("top",""),a()(window).scrollTop(-t))}},{key:"open",value:function(){var t=this,e="#".concat(this.id);this.options.deepLink&&window.location.hash!==e&&(window.history.pushState?this.options.updateHistory?window.history.pushState({},"",e):window.history.replaceState({},"",e):window.location.hash=e),this.$activeAnchor=a()(document.activeElement).is(this.$anchor)?a()(document.activeElement):this.$anchor,this.isActive=!0,this.$element.css({visibility:"hidden"}).show().scrollTop(0),this.options.overlay&&this.$overlay.css({visibility:"hidden"}).show(),this._updatePosition(),this.$element.hide().css({visibility:""}),this.$overlay&&(this.$overlay.css({visibility:""}).hide(),this.$element.hasClass("fast")?this.$overlay.addClass("fast"):this.$element.hasClass("slow")&&this.$overlay.addClass("slow")),this.options.multipleOpened||this.$element.trigger("closeme.zf.reveal",this.id),this._disableScroll();var n=this;if(this.options.animationIn){this.options.overlay&&u.Motion.animateIn(this.$overlay,"fade-in"),u.Motion.animateIn(this.$element,this.options.animationIn,function(){t.$element&&(t.focusableElements=r.Keyboard.findFocusable(t.$element),n.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),n._addGlobalClasses(),r.Keyboard.trapFocus(n.$element))})}else this.options.overlay&&this.$overlay.show(0),this.$element.show(this.options.showDelay);this.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),r.Keyboard.trapFocus(this.$element),this._addGlobalClasses(),this._addGlobalListeners(),this.$element.trigger("open.zf.reveal")}},{key:"_addGlobalClasses",value:function(){var t=function(){a()("html").toggleClass("zf-has-scroll",!!(a()(document).height()>a()(window).height()))};this.$element.on("resizeme.zf.trigger.revealScrollbarListener",function(){return t()}),t(),a()("html").addClass("is-reveal-open")}},{key:"_removeGlobalClasses",value:function(){this.$element.off("resizeme.zf.trigger.revealScrollbarListener"),a()("html").removeClass("is-reveal-open"),a()("html").removeClass("zf-has-scroll")}},{key:"_addGlobalListeners",value:function(){var e=this;this.$element&&(this.focusableElements=r.Keyboard.findFocusable(this.$element),this.options.overlay||!this.options.closeOnClick||this.options.fullScreen||a()("body").on("click.zf.reveal",function(t){t.target!==e.$element[0]&&!a.a.contains(e.$element[0],t.target)&&a.a.contains(document,t.target)&&e.close()}),this.options.closeOnEsc&&a()(window).on("keydown.zf.reveal",function(t){r.Keyboard.handleKey(t,"Reveal",{close:function(){e.options.closeOnEsc&&e.close()}})}))}},{key:"close",value:function(){if(!this.isActive||!this.$element.is(":visible"))return!1;var e=this;function t(){var t=parseInt(a()("html").css("top"));0===a()(".reveal:visible").length&&e._removeGlobalClasses(),r.Keyboard.releaseFocus(e.$element),e.$element.attr("aria-hidden",!0),e._enableScroll(t),e.$element.trigger("closed.zf.reveal")}if(this.options.animationOut?(this.options.overlay&&u.Motion.animateOut(this.$overlay,"fade-out"),u.Motion.animateOut(this.$element,this.options.animationOut,t)):(this.$element.hide(this.options.hideDelay),this.options.overlay?this.$overlay.hide(0,t):t()),this.options.closeOnEsc&&a()(window).off("keydown.zf.reveal"),!this.options.overlay&&this.options.closeOnClick&&a()("body").off("click.zf.reveal"),this.$element.off("keydown.zf.reveal"),this.options.resetOnClose&&this.$element.html(this.$element.html()),this.isActive=!1,e.options.deepLink&&window.location.hash==="#".concat(this.id))if(window.history.replaceState){var n=window.location.pathname+window.location.search;this.options.updateHistory?window.history.pushState({},"",n):window.history.replaceState("",document.title,n)}else window.location.hash="";this.$activeAnchor.focus()}},{key:"toggle",value:function(){this.isActive?this.close():this.open()}},{key:"_destroy",value:function(){this.options.overlay&&(this.$element.appendTo(a()(this.options.appendTo)),this.$overlay.hide().off().remove()),this.$element.hide().off(),this.$anchor.off(".zf"),a()(window).off(".zf.reveal:".concat(this.id)),this.onLoadListener&&a()(window).off(this.onLoadListener),0===a()(".reveal:visible").length&&this._removeGlobalClasses()}}])&&h(e.prototype,i),o&&h(e,o),n}();g.defaults={animationIn:"",animationOut:"",showDelay:0,hideDelay:0,closeOnClick:!0,closeOnEsc:!0,multipleOpened:!1,vOffset:"auto",hOffset:"auto",fullScreen:!1,overlay:!0,resetOnClose:!1,deepLink:!1,updateHistory:!1,appendTo:"body",additionalOverlayClasses:""}},"./js/foundation.slider.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Slider",function(){return f});var i=n("jquery"),m=n.n(i),a=n("./js/foundation.util.keyboard.js"),_=n("./js/foundation.util.motion.js"),g=n("./js/foundation.core.utils.js"),s=n("./js/foundation.core.plugin.js"),r=n("./js/foundation.util.touch.js"),l=n("./js/foundation.util.triggers.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function c(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function h(t,e){return(h=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var f=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),c(this,d(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&h(t,e)}(n,s["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=m.a.extend({},n.defaults,this.$element.data(),e),this.className="Slider",r.Touch.init(m.a),l.Triggers.init(m.a),this._init(),a.Keyboard.register("Slider",{ltr:{ARROW_RIGHT:"increase",ARROW_UP:"increase",ARROW_DOWN:"decrease",ARROW_LEFT:"decrease",SHIFT_ARROW_RIGHT:"increase_fast",SHIFT_ARROW_UP:"increase_fast",SHIFT_ARROW_DOWN:"decrease_fast",SHIFT_ARROW_LEFT:"decrease_fast",HOME:"min",END:"max"},rtl:{ARROW_LEFT:"increase",ARROW_RIGHT:"decrease",SHIFT_ARROW_LEFT:"increase_fast",SHIFT_ARROW_RIGHT:"decrease_fast"}})}},{key:"_init",value:function(){this.inputs=this.$element.find("input"),this.handles=this.$element.find("[data-slider-handle]"),this.$handle=this.handles.eq(0),this.$input=this.inputs.length?this.inputs.eq(0):m()("#".concat(this.$handle.attr("aria-controls"))),this.$fill=this.$element.find("[data-slider-fill]").css(this.options.vertical?"height":"width",0);(this.options.disabled||this.$element.hasClass(this.options.disabledClass))&&(this.options.disabled=!0,this.$element.addClass(this.options.disabledClass)),this.inputs.length||(this.inputs=m()().add(this.$input),this.options.binding=!0),this._setInitAttr(0),this.handles[1]&&(this.options.doubleSided=!0,this.$handle2=this.handles.eq(1),this.$input2=1<this.inputs.length?this.inputs.eq(1):m()("#".concat(this.$handle2.attr("aria-controls"))),this.inputs[1]||(this.inputs=this.inputs.add(this.$input2)),!0,this._setInitAttr(1)),this.setHandles(),this._events()}},{key:"setHandles",value:function(){var t=this;this.handles[1]?this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0,function(){t._setHandlePos(t.$handle2,t.inputs.eq(1).val(),!0)}):this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0)}},{key:"_reflow",value:function(){this.setHandles()}},{key:"_pctOfBar",value:function(t){var e=$(t-this.options.start,this.options.end-this.options.start);switch(this.options.positionValueFunction){case"pow":e=this._logTransform(e);break;case"log":e=this._powTransform(e)}return e.toFixed(2)}},{key:"_value",value:function(t){switch(this.options.positionValueFunction){case"pow":t=this._powTransform(t);break;case"log":t=this._logTransform(t)}return(this.options.end-this.options.start)*t+parseFloat(this.options.start)}},{key:"_logTransform",value:function(t){return e=this.options.nonLinearBase,n=t*(this.options.nonLinearBase-1)+1,Math.log(n)/Math.log(e);var e,n}},{key:"_powTransform",value:function(t){return(Math.pow(this.options.nonLinearBase,t)-1)/(this.options.nonLinearBase-1)}},{key:"_setHandlePos",value:function(t,e,n,i){if(!this.$element.hasClass(this.options.disabledClass)){(e=parseFloat(e))<this.options.start?e=this.options.start:e>this.options.end&&(e=this.options.end);var o=this.options.doubleSided;if(this.options.vertical&&!n&&(e=this.options.end-e),o)if(0===this.handles.index(t)){var s=parseFloat(this.$handle2.attr("aria-valuenow"));e=s<=e?s-this.options.step:e}else{var a=parseFloat(this.$handle.attr("aria-valuenow"));e=e<=a?a+this.options.step:e}var r=this,l=this.options.vertical,u=l?"height":"width",c=l?"top":"left",d=t[0].getBoundingClientRect()[u],h=this.$element[0].getBoundingClientRect()[u],f=this._pctOfBar(e),p=(100*$((h-d)*f,h)).toFixed(this.options.decimal);e=parseFloat(e.toFixed(this.options.decimal));var m={};if(this._setValues(t,e),o){var g,v=0===this.handles.index(t),y=~~(100*$(d,h));if(v)m[c]="".concat(p,"%"),g=parseFloat(this.$handle2[0].style[c])-p+y,i&&"function"==typeof i&&i();else{var b=parseFloat(this.$handle[0].style[c]);g=p-(isNaN(b)?(this.options.initialStart-this.options.start)/((this.options.end-this.options.start)/100):b)+y}m["min-".concat(u)]="".concat(g,"%")}this.$element.one("finished.zf.animate",function(){r.$element.trigger("moved.zf.slider",[t])});var w=this.$element.data("dragging")?1e3/60:this.options.moveTime;Object(_.Move)(w,t,function(){isNaN(p)?t.css(c,"".concat(100*f,"%")):t.css(c,"".concat(p,"%")),r.options.doubleSided?r.$fill.css(m):r.$fill.css(u,"".concat(100*f,"%"))}),clearTimeout(r.timeout),r.timeout=setTimeout(function(){r.$element.trigger("changed.zf.slider",[t])},r.options.changedDelay)}}},{key:"_setInitAttr",value:function(t){var e=0===t?this.options.initialStart:this.options.initialEnd,n=this.inputs.eq(t).attr("id")||Object(g.GetYoDigits)(6,"slider");this.inputs.eq(t).attr({id:n,max:this.options.end,min:this.options.start,step:this.options.step}),this.inputs.eq(t).val(e),this.handles.eq(t).attr({role:"slider","aria-controls":n,"aria-valuemax":this.options.end,"aria-valuemin":this.options.start,"aria-valuenow":e,"aria-orientation":this.options.vertical?"vertical":"horizontal",tabindex:0})}},{key:"_setValues",value:function(t,e){var n=this.options.doubleSided?this.handles.index(t):0;this.inputs.eq(n).val(e),t.attr("aria-valuenow",e)}},{key:"_handleEvent",value:function(t,e,n){var i,o;if(n)i=this._adjustValue(null,n),o=!0;else{t.preventDefault();var s=this.options.vertical,a=s?"height":"width",r=s?"top":"left",l=s?t.pageY:t.pageX,u=(this.$handle[0].getBoundingClientRect()[a],this.$element[0].getBoundingClientRect()[a]),c=s?m()(window).scrollTop():m()(window).scrollLeft(),d=this.$element.offset()[r];t.clientY===t.pageY&&(l+=c);var h,f=l-d,p=$(h=f<0?0:u<f?u:f,u);if(i=this._value(p),Object(g.rtl)()&&!this.options.vertical&&(i=this.options.end-i),i=this._adjustValue(null,i),o=!1,!e)e=v(this.$handle,r,h,a)<=v(this.$handle2,r,h,a)?this.$handle:this.$handle2}this._setHandlePos(e,i,o)}},{key:"_adjustValue",value:function(t,e){var n,i,o,s=this.options.step,a=parseFloat(s/2);return 0===(i=0<=(n=t?parseFloat(t.attr("aria-valuenow")):e)?n%s:s+n%s)?n:n=(o=n-i)+a<=n?o+s:o}},{key:"_events",value:function(){this._eventsForHandle(this.$handle),this.handles[1]&&this._eventsForHandle(this.$handle2)}},{key:"_eventsForHandle",value:function(e){var n,s=this,i=function(t){var e=s.inputs.index(m()(this));s._handleEvent(t,s.handles.eq(e),m()(this).val())};if(this.inputs.off("keyup.zf.slider").on("keyup.zf.slider",function(t){13==t.keyCode&&i.call(this,t)}),this.inputs.off("change.zf.slider").on("change.zf.slider",i),this.options.clickSelect&&this.$element.off("click.zf.slider").on("click.zf.slider",function(t){if(s.$element.data("dragging"))return!1;m()(t.target).is("[data-slider-handle]")||(s.options.doubleSided?s._handleEvent(t):s._handleEvent(t,s.$handle))}),this.options.draggable){this.handles.addTouch();var o=m()("body");e.off("mousedown.zf.slider").on("mousedown.zf.slider",function(t){e.addClass("is-dragging"),s.$fill.addClass("is-dragging"),s.$element.data("dragging",!0),n=m()(t.currentTarget),o.on("mousemove.zf.slider",function(t){t.preventDefault(),s._handleEvent(t,n)}).on("mouseup.zf.slider",function(t){s._handleEvent(t,n),e.removeClass("is-dragging"),s.$fill.removeClass("is-dragging"),s.$element.data("dragging",!1),o.off("mousemove.zf.slider mouseup.zf.slider")})}).on("selectstart.zf.slider touchmove.zf.slider",function(t){t.preventDefault()})}e.off("keydown.zf.slider").on("keydown.zf.slider",function(t){var e,n=m()(this),i=s.options.doubleSided?s.handles.index(n):0,o=parseFloat(s.inputs.eq(i).val());a.Keyboard.handleKey(t,"Slider",{decrease:function(){e=o-s.options.step},increase:function(){e=o+s.options.step},decrease_fast:function(){e=o-10*s.options.step},increase_fast:function(){e=o+10*s.options.step},min:function(){e=s.options.start},max:function(){e=s.options.end},handled:function(){t.preventDefault(),s._setHandlePos(n,e,!0)}})})}},{key:"_destroy",value:function(){this.handles.off(".zf.slider"),this.inputs.off(".zf.slider"),this.$element.off(".zf.slider"),clearTimeout(this.timeout)}}])&&u(e.prototype,i),o&&u(e,o),n}();function $(t,e){return t/e}function v(t,e,n,i){return Math.abs(t.position()[e]+t[i]()/2-n)}f.defaults={start:0,end:100,step:1,initialStart:0,initialEnd:100,binding:!1,clickSelect:!0,vertical:!1,draggable:!0,disabled:!1,doubleSided:!1,decimal:2,moveTime:200,disabledClass:"disabled",invertVertical:!1,changedDelay:500,nonLinearBase:5,positionValueFunction:"linear"}},"./js/foundation.smoothScroll.js":function(t,e,n){"use strict";n.r(e),n.d(e,"SmoothScroll",function(){return h});var i=n("jquery"),a=n.n(i),o=n("./js/foundation.core.utils.js"),r=n("./js/foundation.core.plugin.js");function s(t){return(s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function l(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function u(t,e){return!e||"object"!==s(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function c(t){return(c=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function d(t,e){return(d=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var h=function(t){function s(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,s),u(this,c(s).apply(this,arguments))}var e,n,i;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&d(t,e)}(s,r["Plugin"]),e=s,i=[{key:"scrollToLoc",value:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:s.defaults,n=2<arguments.length?arguments[2]:void 0,i=a()(t);if(!i.length)return!1;var o=Math.round(i.offset().top-e.threshold/2-e.offset);a()("html, body").stop(!0).animate({scrollTop:o},e.animationDuration,e.animationEasing,function(){"function"==typeof n&&n()})}}],(n=[{key:"_setup",value:function(t,e){this.$element=t,this.options=a.a.extend({},s.defaults,this.$element.data(),e),this.className="SmoothScroll",this._init()}},{key:"_init",value:function(){var t=this.$element[0].id||Object(o.GetYoDigits)(6,"smooth-scroll");this.$element.attr({id:t}),this._events()}},{key:"_events",value:function(){this._linkClickListener=this._handleLinkClick.bind(this),this.$element.on("click.zf.smoothScroll",this._linkClickListener),this.$element.on("click.zf.smoothScroll",'a[href^="#"]',this._linkClickListener)}},{key:"_handleLinkClick",value:function(t){var e=this;if(a()(t.currentTarget).is('a[href^="#"]')){var n=t.currentTarget.getAttribute("href");this._inTransition=!0,s.scrollToLoc(n,this.options,function(){e._inTransition=!1}),t.preventDefault()}}},{key:"_destroy",value:function(){this.$element.off("click.zf.smoothScroll",this._linkClickListener),this.$element.off("click.zf.smoothScroll",'a[href^="#"]',this._linkClickListener)}}])&&l(e.prototype,n),i&&l(e,i),s}();h.defaults={animationDuration:500,animationEasing:"linear",threshold:50,offset:0}},"./js/foundation.sticky.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Sticky",function(){return p});var i=n("jquery"),r=n.n(i),s=n("./js/foundation.core.utils.js"),l=n("./js/foundation.util.mediaQuery.js"),a=n("./js/foundation.core.plugin.js"),u=n("./js/foundation.util.triggers.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function c(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function d(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function h(t){return(h=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function f(t,e){return(f=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var p=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),d(this,h(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&f(t,e)}(n,a["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=r.a.extend({},n.defaults,this.$element.data(),e),this.className="Sticky",u.Triggers.init(r.a),this._init()}},{key:"_init",value:function(){l.MediaQuery._init();var t=this.$element.parent("[data-sticky-container]"),e=this.$element[0].id||Object(s.GetYoDigits)(6,"sticky"),n=this;t.length?this.$container=t:(this.wasWrapped=!0,this.$element.wrap(this.options.container),this.$container=this.$element.parent()),this.$container.addClass(this.options.containerClass),this.$element.addClass(this.options.stickyClass).attr({"data-resize":e,"data-mutate":e}),""!==this.options.anchor&&r()("#"+n.options.anchor).attr({"data-mutate":e}),this.scrollCount=this.options.checkEvery,this.isStuck=!1,this.onLoadListener=Object(s.onLoad)(r()(window),function(){n.containerHeight="none"==n.$element.css("display")?0:n.$element[0].getBoundingClientRect().height,n.$container.css("height",n.containerHeight),n.elemHeight=n.containerHeight,""!==n.options.anchor?n.$anchor=r()("#"+n.options.anchor):n._parsePoints(),n._setSizes(function(){var t=window.pageYOffset;n._calc(!1,t),n.isStuck||n._removeSticky(!(t>=n.topPoint))}),n._events(e.split("-").reverse().join("-"))})}},{key:"_parsePoints",value:function(){for(var t=[""==this.options.topAnchor?1:this.options.topAnchor,""==this.options.btmAnchor?document.documentElement.scrollHeight:this.options.btmAnchor],e={},n=0,i=t.length;n<i&&t[n];n++){var o;if("number"==typeof t[n])o=t[n];else{var s=t[n].split(":"),a=r()("#".concat(s[0]));o=a.offset().top,s[1]&&"bottom"===s[1].toLowerCase()&&(o+=a[0].getBoundingClientRect().height)}e[n]=o}this.points=e}},{key:"_events",value:function(n){var i=this,t=this.scrollListener="scroll.zf.".concat(n);this.isOn||(this.canStick&&(this.isOn=!0,r()(window).off(t).on(t,function(t){0===i.scrollCount?(i.scrollCount=i.options.checkEvery,i._setSizes(function(){i._calc(!1,window.pageYOffset)})):(i.scrollCount--,i._calc(!1,window.pageYOffset))})),this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(t,e){i._eventsHandler(n)}),this.$element.on("mutateme.zf.trigger",function(t,e){i._eventsHandler(n)}),this.$anchor&&this.$anchor.on("mutateme.zf.trigger",function(t,e){i._eventsHandler(n)}))}},{key:"_eventsHandler",value:function(t){var e=this,n=this.scrollListener="scroll.zf.".concat(t);e._setSizes(function(){e._calc(!1),e.canStick?e.isOn||e._events(t):e.isOn&&e._pauseListeners(n)})}},{key:"_pauseListeners",value:function(t){this.isOn=!1,r()(window).off(t),this.$element.trigger("pause.zf.sticky")}},{key:"_calc",value:function(t,e){if(t&&this._setSizes(),!this.canStick)return this.isStuck&&this._removeSticky(!0),!1;e||(e=window.pageYOffset),e>=this.topPoint?e<=this.bottomPoint?this.isStuck||this._setSticky():this.isStuck&&this._removeSticky(!1):this.isStuck&&this._removeSticky(!0)}},{key:"_setSticky",value:function(){var t=this,e=this.options.stickTo,n="top"===e?"marginTop":"marginBottom",i="top"===e?"bottom":"top",o={};o[n]="".concat(this.options[n],"em"),o[e]=0,o[i]="auto",this.isStuck=!0,this.$element.removeClass("is-anchored is-at-".concat(i)).addClass("is-stuck is-at-".concat(e)).css(o).trigger("sticky.zf.stuckto:".concat(e)),this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd",function(){t._setSizes()})}},{key:"_removeSticky",value:function(t){var e=this.options.stickTo,n="top"===e,i={},o=(this.points?this.points[1]-this.points[0]:this.anchorHeight)-this.elemHeight,s=t?"top":"bottom";i[n?"marginTop":"marginBottom"]=0,i.bottom="auto",i.top=t?0:o,this.isStuck=!1,this.$element.removeClass("is-stuck is-at-".concat(e)).addClass("is-anchored is-at-".concat(s)).css(i).trigger("sticky.zf.unstuckfrom:".concat(s))}},{key:"_setSizes",value:function(t){this.canStick=l.MediaQuery.is(this.options.stickyOn),this.canStick||t&&"function"==typeof t&&t();var e=this.$container[0].getBoundingClientRect().width,n=window.getComputedStyle(this.$container[0]),i=parseInt(n["padding-left"],10),o=parseInt(n["padding-right"],10);this.$anchor&&this.$anchor.length?this.anchorHeight=this.$anchor[0].getBoundingClientRect().height:this._parsePoints(),this.$element.css({"max-width":"".concat(e-i-o,"px")});var s=this.$element[0].getBoundingClientRect().height||this.containerHeight;if("none"==this.$element.css("display")&&(s=0),this.containerHeight=s,this.$container.css({height:s}),this.elemHeight=s,!this.isStuck&&this.$element.hasClass("is-at-bottom")){var a=(this.points?this.points[1]-this.$container.offset().top:this.anchorHeight)-this.elemHeight;this.$element.css("top",a)}this._setBreakPoints(s,function(){t&&"function"==typeof t&&t()})}},{key:"_setBreakPoints",value:function(t,e){if(!this.canStick){if(!e||"function"!=typeof e)return!1;e()}var n=m(this.options.marginTop),i=m(this.options.marginBottom),o=this.points?this.points[0]:this.$anchor.offset().top,s=this.points?this.points[1]:o+this.anchorHeight,a=window.innerHeight;"top"===this.options.stickTo?(o-=n,s-=t+n):"bottom"===this.options.stickTo&&(o-=a-(t+i),s-=a-i),this.topPoint=o,this.bottomPoint=s,e&&"function"==typeof e&&e()}},{key:"_destroy",value:function(){this._removeSticky(!0),this.$element.removeClass("".concat(this.options.stickyClass," is-anchored is-at-top")).css({height:"",top:"",bottom:"","max-width":""}).off("resizeme.zf.trigger").off("mutateme.zf.trigger"),this.$anchor&&this.$anchor.length&&this.$anchor.off("change.zf.sticky"),this.scrollListener&&r()(window).off(this.scrollListener),this.onLoadListener&&r()(window).off(this.onLoadListener),this.wasWrapped?this.$element.unwrap():this.$container.removeClass(this.options.containerClass).css({height:""})}}])&&c(e.prototype,i),o&&c(e,o),n}();function m(t){return parseInt(window.getComputedStyle(document.body,null).fontSize,10)*t}p.defaults={container:"<div data-sticky-container></div>",stickTo:"top",anchor:"",topAnchor:"",btmAnchor:"",marginTop:1,marginBottom:1,stickyOn:"medium",stickyClass:"sticky",containerClass:"sticky-container",checkEvery:-1}},"./js/foundation.tabs.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Tabs",function(){return o});var i=n("jquery"),r=n.n(i),l=n("./js/foundation.core.utils.js"),a=n("./js/foundation.util.keyboard.js"),u=n("./js/foundation.util.imageLoader.js"),s=n("./js/foundation.core.plugin.js");function c(t){return(c="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function d(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function h(t,e){return!e||"object"!==c(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function p(t,e){return(p=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var o=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),h(this,f(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&p(t,e)}(n,s["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=r.a.extend({},n.defaults,this.$element.data(),e),this.className="Tabs",this._init(),a.Keyboard.register("Tabs",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"previous",ARROW_DOWN:"next",ARROW_LEFT:"previous"})}},{key:"_init",value:function(){var s=this,a=this;if(this._isInitializing=!0,this.$element.attr({role:"tablist"}),this.$tabTitles=this.$element.find(".".concat(this.options.linkClass)),this.$tabContent=r()('[data-tabs-content="'.concat(this.$element[0].id,'"]')),this.$tabTitles.each(function(){var t=r()(this),e=t.find("a"),n=t.hasClass("".concat(a.options.linkActiveClass)),i=e.attr("data-tabs-target")||e[0].hash.slice(1),o=e[0].id?e[0].id:"".concat(i,"-label"),s=r()("#".concat(i));t.attr({role:"presentation"}),e.attr({role:"tab","aria-controls":i,"aria-selected":n,id:o,tabindex:n?"0":"-1"}),s.attr({role:"tabpanel","aria-labelledby":o}),n&&(a._initialAnchor="#".concat(i)),n||s.attr("aria-hidden","true"),n&&a.options.autoFocus&&(a.onLoadListener=Object(l.onLoad)(r()(window),function(){r()("html, body").animate({scrollTop:t.offset().top},a.options.deepLinkSmudgeDelay,function(){e.focus()})}))}),this.options.matchHeight){var t=this.$tabContent.find("img");t.length?Object(u.onImagesLoaded)(t,this._setHeight.bind(this)):this._setHeight()}this._checkDeepLink=function(){var t=window.location.hash;if(!t.length){if(s._isInitializing)return;s._initialAnchor&&(t=s._initialAnchor)}var e=t&&r()(t),n=t&&s.$element.find('[href$="'+t+'"]'),i=!(!e.length||!n.length);if(e&&e.length&&n&&n.length?s.selectTab(e,!0):s._collapse(),i){if(s.options.deepLinkSmudge){var o=s.$element.offset();r()("html, body").animate({scrollTop:o.top},s.options.deepLinkSmudgeDelay)}s.$element.trigger("deeplink.zf.tabs",[n,e])}},this.options.deepLink&&this._checkDeepLink(),this._events(),this._isInitializing=!1}},{key:"_events",value:function(){this._addKeyHandler(),this._addClickHandler(),this._setHeightMqHandler=null,this.options.matchHeight&&(this._setHeightMqHandler=this._setHeight.bind(this),r()(window).on("changed.zf.mediaquery",this._setHeightMqHandler)),this.options.deepLink&&r()(window).on("hashchange",this._checkDeepLink)}},{key:"_addClickHandler",value:function(){var e=this;this.$element.off("click.zf.tabs").on("click.zf.tabs",".".concat(this.options.linkClass),function(t){t.preventDefault(),t.stopPropagation(),e._handleTabChange(r()(this))})}},{key:"_addKeyHandler",value:function(){var s=this;this.$tabTitles.off("keydown.zf.tabs").on("keydown.zf.tabs",function(t){if(9!==t.which){var e,n,i=r()(this),o=i.parent("ul").children("li");o.each(function(t){r()(this).is(i)&&(n=s.options.wrapOnKeys?(e=0===t?o.last():o.eq(t-1),t===o.length-1?o.first():o.eq(t+1)):(e=o.eq(Math.max(0,t-1)),o.eq(Math.min(t+1,o.length-1))))}),a.Keyboard.handleKey(t,"Tabs",{open:function(){i.find('[role="tab"]').focus(),s._handleTabChange(i)},previous:function(){e.find('[role="tab"]').focus(),s._handleTabChange(e)},next:function(){n.find('[role="tab"]').focus(),s._handleTabChange(n)},handled:function(){t.stopPropagation(),t.preventDefault()}})}})}},{key:"_handleTabChange",value:function(t,e){if(t.hasClass("".concat(this.options.linkActiveClass)))this.options.activeCollapse&&this._collapse();else{var n=this.$element.find(".".concat(this.options.linkClass,".").concat(this.options.linkActiveClass)),i=t.find('[role="tab"]'),o=i.attr("data-tabs-target"),s=o&&o.length?"#".concat(o):i[0].hash,a=this.$tabContent.find(s);this._collapseTab(n),this._openTab(t),this.options.deepLink&&!e&&(this.options.updateHistory?history.pushState({},"",s):history.replaceState({},"",s)),this.$element.trigger("change.zf.tabs",[t,a]),a.find("[data-mutate]").trigger("mutateme.zf.trigger")}}},{key:"_openTab",value:function(t){var e=t.find('[role="tab"]'),n=e.attr("data-tabs-target")||e[0].hash.slice(1),i=this.$tabContent.find("#".concat(n));t.addClass("".concat(this.options.linkActiveClass)),e.attr({"aria-selected":"true",tabindex:"0"}),i.addClass("".concat(this.options.panelActiveClass)).removeAttr("aria-hidden")}},{key:"_collapseTab",value:function(t){var e=t.removeClass("".concat(this.options.linkActiveClass)).find('[role="tab"]').attr({"aria-selected":"false",tabindex:-1});r()("#".concat(e.attr("aria-controls"))).removeClass("".concat(this.options.panelActiveClass)).attr({"aria-hidden":"true"})}},{key:"_collapse",value:function(){var t=this.$element.find(".".concat(this.options.linkClass,".").concat(this.options.linkActiveClass));t.length&&(this._collapseTab(t),this.$element.trigger("collapse.zf.tabs",[t]))}},{key:"selectTab",value:function(t,e){var n;(n="object"===c(t)?t[0].id:t).indexOf("#")<0&&(n="#".concat(n));var i=this.$tabTitles.has('[href$="'.concat(n,'"]'));this._handleTabChange(i,e)}},{key:"_setHeight",value:function(){var i=0,o=this;this.$tabContent.find(".".concat(this.options.panelClass)).css("height","").each(function(){var t=r()(this),e=t.hasClass("".concat(o.options.panelActiveClass));e||t.css({visibility:"hidden",display:"block"});var n=this.getBoundingClientRect().height;e||t.css({visibility:"",display:""}),i=i<n?n:i}).css("height","".concat(i,"px"))}},{key:"_destroy",value:function(){this.$element.find(".".concat(this.options.linkClass)).off(".zf.tabs").hide().end().find(".".concat(this.options.panelClass)).hide(),this.options.matchHeight&&null!=this._setHeightMqHandler&&r()(window).off("changed.zf.mediaquery",this._setHeightMqHandler),this.options.deepLink&&r()(window).off("hashchange",this._checkDeepLink),this.onLoadListener&&r()(window).off(this.onLoadListener)}}])&&d(e.prototype,i),o&&d(e,o),n}();o.defaults={deepLink:!1,deepLinkSmudge:!1,deepLinkSmudgeDelay:300,updateHistory:!1,autoFocus:!1,wrapOnKeys:!0,matchHeight:!1,activeCollapse:!1,linkClass:"tabs-title",linkActiveClass:"is-active",panelClass:"tabs-panel",panelActiveClass:"is-active"}},"./js/foundation.toggler.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Toggler",function(){return p});var i=n("jquery"),s=n.n(i),a=n("./js/foundation.util.motion.js"),r=n("./js/foundation.core.plugin.js"),l=n("./js/foundation.core.utils.js"),u=n("./js/foundation.util.triggers.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function c(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function d(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function h(t){return(h=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function f(t,e){return(f=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var p=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),d(this,h(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&f(t,e)}(n,r["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=s.a.extend({},n.defaults,t.data(),e),this.className="",this.className="Toggler",u.Triggers.init(s.a),this._init(),this._events()}},{key:"_init",value:function(){var t;this.options.animate?(t=this.options.animate.split(" "),this.animationIn=t[0],this.animationOut=t[1]||null):(t=this.$element.data("toggler"),this.className="."===t[0]?t.slice(1):t);var o=this.$element[0].id,e=s()('[data-open~="'.concat(o,'"], [data-close~="').concat(o,'"], [data-toggle~="').concat(o,'"]'));e.attr("aria-expanded",!this.$element.is(":hidden")),e.each(function(t,e){var n=s()(e),i=n.attr("aria-controls")||"";new RegExp("\\b".concat(Object(l.RegExpEscape)(o),"\\b")).test(i)||n.attr("aria-controls",i?"".concat(i," ").concat(o):o)})}},{key:"_events",value:function(){this.$element.off("toggle.zf.trigger").on("toggle.zf.trigger",this.toggle.bind(this))}},{key:"toggle",value:function(){this[this.options.animate?"_toggleAnimate":"_toggleClass"]()}},{key:"_toggleClass",value:function(){this.$element.toggleClass(this.className);var t=this.$element.hasClass(this.className);t?this.$element.trigger("on.zf.toggler"):this.$element.trigger("off.zf.toggler"),this._updateARIA(t),this.$element.find("[data-mutate]").trigger("mutateme.zf.trigger")}},{key:"_toggleAnimate",value:function(){var t=this;this.$element.is(":hidden")?a.Motion.animateIn(this.$element,this.animationIn,function(){t._updateARIA(!0),this.trigger("on.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")}):a.Motion.animateOut(this.$element,this.animationOut,function(){t._updateARIA(!1),this.trigger("off.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")})}},{key:"_updateARIA",value:function(t){var e=this.$element[0].id;s()('[data-open="'.concat(e,'"], [data-close="').concat(e,'"], [data-toggle="').concat(e,'"]')).attr({"aria-expanded":!!t})}},{key:"_destroy",value:function(){this.$element.off(".zf.toggler")}}])&&c(e.prototype,i),o&&c(e,o),n}();p.defaults={animate:!1}},"./js/foundation.tooltip.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Tooltip",function(){return m});var i=n("jquery"),s=n.n(i),a=n("./js/foundation.core.utils.js"),r=n("./js/foundation.util.mediaQuery.js"),l=n("./js/foundation.util.triggers.js"),u=n("./js/foundation.positionable.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function c(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function d(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function h(t,e,n){return(h="undefined"!=typeof Reflect&&Reflect.get?Reflect.get:function(t,e,n){var i=function(t,e){for(;!Object.prototype.hasOwnProperty.call(t,e)&&null!==(t=f(t)););return t}(t,e);if(i){var o=Object.getOwnPropertyDescriptor(i,e);return o.get?o.get.call(n):o.value}})(t,e,n||t)}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function p(t,e){return(p=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var m=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),d(this,f(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&p(t,e)}(n,u["Positionable"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=s.a.extend({},n.defaults,this.$element.data(),e),this.className="Tooltip",this.isActive=!1,this.isClick=!1,l.Triggers.init(s.a),this._init()}},{key:"_init",value:function(){r.MediaQuery._init();var t=this.$element.attr("aria-describedby")||Object(a.GetYoDigits)(6,"tooltip");this.options.tipText=this.options.tipText||this.$element.attr("title"),this.template=this.options.template?s()(this.options.template):this._buildTemplate(t),this.options.allowHtml?this.template.appendTo(document.body).html(this.options.tipText).hide():this.template.appendTo(document.body).text(this.options.tipText).hide(),this.$element.attr({title:"","aria-describedby":t,"data-yeti-box":t,"data-toggle":t,"data-resize":t}).addClass(this.options.triggerClass),h(f(n.prototype),"_init",this).call(this),this._events()}},{key:"_getDefaultPosition",value:function(){var t=this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);return t?t[0]:"top"}},{key:"_getDefaultAlignment",value:function(){return"center"}},{key:"_getHOffset",value:function(){return"left"===this.position||"right"===this.position?this.options.hOffset+this.options.tooltipWidth:this.options.hOffset}},{key:"_getVOffset",value:function(){return"top"===this.position||"bottom"===this.position?this.options.vOffset+this.options.tooltipHeight:this.options.vOffset}},{key:"_buildTemplate",value:function(t){var e="".concat(this.options.tooltipClass," ").concat(this.options.templateClasses).trim();return s()("<div></div>").addClass(e).attr({role:"tooltip","aria-hidden":!0,"data-is-active":!1,"data-is-focus":!1,id:t})}},{key:"_setPosition",value:function(){h(f(n.prototype),"_setPosition",this).call(this,this.$element,this.template)}},{key:"show",value:function(){if("all"!==this.options.showOn&&!r.MediaQuery.is(this.options.showOn))return!1;this.template.css("visibility","hidden").show(),this._setPosition(),this.template.removeClass("top bottom left right").addClass(this.position),this.template.removeClass("align-top align-bottom align-left align-right align-center").addClass("align-"+this.alignment),this.$element.trigger("closeme.zf.tooltip",this.template.attr("id")),this.template.attr({"data-is-active":!0,"aria-hidden":!1}),this.isActive=!0,this.template.stop().hide().css("visibility","").fadeIn(this.options.fadeInDuration,function(){}),this.$element.trigger("show.zf.tooltip")}},{key:"hide",value:function(){var t=this;this.template.stop().attr({"aria-hidden":!0,"data-is-active":!1}).fadeOut(this.options.fadeOutDuration,function(){t.isActive=!1,t.isClick=!1}),this.$element.trigger("hide.zf.tooltip")}},{key:"_events",value:function(){var e=this,n=(this.template,!1);this.options.disableHover||this.$element.on("mouseenter.zf.tooltip",function(t){e.isActive||(e.timeout=setTimeout(function(){e.show()},e.options.hoverDelay))}).on("mouseleave.zf.tooltip",Object(a.ignoreMousedisappear)(function(t){clearTimeout(e.timeout),(!n||e.isClick&&!e.options.clickOpen)&&e.hide()})),this.options.clickOpen?this.$element.on("mousedown.zf.tooltip",function(t){t.stopImmediatePropagation(),e.isClick||(e.isClick=!0,!e.options.disableHover&&e.$element.attr("tabindex")||e.isActive||e.show())}):this.$element.on("mousedown.zf.tooltip",function(t){t.stopImmediatePropagation(),e.isClick=!0}),this.options.disableForTouch||this.$element.on("tap.zf.tooltip touchend.zf.tooltip",function(t){e.isActive?e.hide():e.show()}),this.$element.on({"close.zf.trigger":this.hide.bind(this)}),this.$element.on("focus.zf.tooltip",function(t){if(n=!0,e.isClick)return e.options.clickOpen||(n=!1),!1;e.show()}).on("focusout.zf.tooltip",function(t){n=!1,e.isClick=!1,e.hide()}).on("resizeme.zf.trigger",function(){e.isActive&&e._setPosition()})}},{key:"toggle",value:function(){this.isActive?this.hide():this.show()}},{key:"_destroy",value:function(){this.$element.attr("title",this.template.text()).off(".zf.trigger .zf.tooltip").removeClass(this.options.triggerClass).removeClass("top right left bottom").removeAttr("aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box"),this.template.remove()}}])&&c(e.prototype,i),o&&c(e,o),n}();m.defaults={disableForTouch:!1,hoverDelay:200,fadeInDuration:150,fadeOutDuration:150,disableHover:!1,templateClasses:"",tooltipClass:"tooltip",triggerClass:"has-tip",showOn:"small",template:"",tipText:"",touchCloseText:"Tap to close.",clickOpen:!0,position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!1,vOffset:0,hOffset:0,tooltipHeight:14,tooltipWidth:12,allowHtml:!1}},"./js/foundation.util.box.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Box",function(){return i});var a=n("./js/foundation.core.utils.js"),i={ImNotTouchingYou:function(t,e,n,i,o){return 0===s(t,e,n,i,o)},OverlapArea:s,GetDimensions:d,GetOffsets:function(t,e,n,i,o,s){switch(console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5"),n){case"top":return Object(a.rtl)()?r(t,e,"top","left",i,o,s):r(t,e,"top","right",i,o,s);case"bottom":return Object(a.rtl)()?r(t,e,"bottom","left",i,o,s):r(t,e,"bottom","right",i,o,s);case"center top":return r(t,e,"top","center",i,o,s);case"center bottom":return r(t,e,"bottom","center",i,o,s);case"center left":return r(t,e,"left","center",i,o,s);case"center right":return r(t,e,"right","center",i,o,s);case"left bottom":return r(t,e,"bottom","left",i,o,s);case"right bottom":return r(t,e,"bottom","right",i,o,s);case"center":return{left:$eleDims.windowDims.offset.left+$eleDims.windowDims.width/2-$eleDims.width/2+o,top:$eleDims.windowDims.offset.top+$eleDims.windowDims.height/2-($eleDims.height/2+i)};case"reveal":return{left:($eleDims.windowDims.width-$eleDims.width)/2+o,top:$eleDims.windowDims.offset.top+i};case"reveal full":return{left:$eleDims.windowDims.offset.left,top:$eleDims.windowDims.offset.top};default:return{left:Object(a.rtl)()?$anchorDims.offset.left-$eleDims.width+$anchorDims.width-o:$anchorDims.offset.left+o,top:$anchorDims.offset.top+$anchorDims.height+i}}},GetExplicitOffsets:r};function s(t,e,n,i,o){var s,a,r,l,u=d(t);if(e){var c=d(e);a=c.height+c.offset.top-(u.offset.top+u.height),s=u.offset.top-c.offset.top,r=u.offset.left-c.offset.left,l=c.width+c.offset.left-(u.offset.left+u.width)}else a=u.windowDims.height+u.windowDims.offset.top-(u.offset.top+u.height),s=u.offset.top-u.windowDims.offset.top,r=u.offset.left-u.windowDims.offset.left,l=u.windowDims.width-(u.offset.left+u.width);return a=o?0:Math.min(a,0),s=Math.min(s,0),r=Math.min(r,0),l=Math.min(l,0),n?r+l:i?s+a:Math.sqrt(s*s+a*a+r*r+l*l)}function d(t){if((t=t.length?t[0]:t)===window||t===document)throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");var e=t.getBoundingClientRect(),n=t.parentNode.getBoundingClientRect(),i=document.body.getBoundingClientRect(),o=window.pageYOffset,s=window.pageXOffset;return{width:e.width,height:e.height,offset:{top:e.top+o,left:e.left+s},parentDims:{width:n.width,height:n.height,offset:{top:n.top+o,left:n.left+s}},windowDims:{width:i.width,height:i.height,offset:{top:o,left:s}}}}function r(t,e,n,i,o,s,a){var r,l,u=d(t),c=e?d(e):null;switch(n){case"top":r=c.offset.top-(u.height+o);break;case"bottom":r=c.offset.top+c.height+o;break;case"left":l=c.offset.left-(u.width+s);break;case"right":l=c.offset.left+c.width+s}switch(n){case"top":case"bottom":switch(i){case"left":l=c.offset.left+s;break;case"right":l=c.offset.left-u.width+c.width-s;break;case"center":l=a?s:c.offset.left+c.width/2-u.width/2+s}break;case"right":case"left":switch(i){case"bottom":r=c.offset.top-o+c.height-u.height;break;case"top":r=c.offset.top+o;break;case"center":r=c.offset.top+o+c.height/2-u.height/2}}return{top:r,left:l}}},"./js/foundation.util.imageLoader.js":function(t,e,n){"use strict";n.r(e),n.d(e,"onImagesLoaded",function(){return s});var i=n("jquery"),o=n.n(i);function s(t,e){var n=t.length;function i(){0===--n&&e()}0===n&&e(),t.each(function(){if(this.complete&&void 0!==this.naturalWidth)i();else{var t=new Image,n="load.zf.images error.zf.images";o()(t).one(n,function t(e){o()(this).off(n,t),i()}),t.src=o()(this).attr("src")}})}},"./js/foundation.util.keyboard.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Keyboard",function(){return c});var i=n("jquery"),r=n.n(i),l=n("./js/foundation.core.utils.js"),o={9:"TAB",13:"ENTER",27:"ESCAPE",32:"SPACE",35:"END",36:"HOME",37:"ARROW_LEFT",38:"ARROW_UP",39:"ARROW_RIGHT",40:"ARROW_DOWN"},u={};function s(t){return!!t&&t.find("a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]").filter(function(){return!(!r()(this).is(":visible")||r()(this).attr("tabindex")<0)})}function a(t){var e=o[t.which||t.keyCode]||String.fromCharCode(t.which).toUpperCase();return e=e.replace(/\W+/,""),t.shiftKey&&(e="SHIFT_".concat(e)),t.ctrlKey&&(e="CTRL_".concat(e)),t.altKey&&(e="ALT_".concat(e)),e=e.replace(/_$/,"")}var c={keys:function(t){var e={};for(var n in t)e[t[n]]=t[n];return e}(o),parseKey:a,handleKey:function(t,e,n){var i,o=u[e],s=this.parseKey(t);if(!o)return console.warn("Component not defined!");if((i=n[(void 0===o.ltr?o:Object(l.rtl)()?r.a.extend({},o.ltr,o.rtl):r.a.extend({},o.rtl,o.ltr))[s]])&&"function"==typeof i){var a=i.apply();(n.handled||"function"==typeof n.handled)&&n.handled(a)}else(n.unhandled||"function"==typeof n.unhandled)&&n.unhandled()},findFocusable:s,register:function(t,e){u[t]=e},trapFocus:function(t){var e=s(t),n=e.eq(0),i=e.eq(-1);t.on("keydown.zf.trapfocus",function(t){t.target===i[0]&&"TAB"===a(t)?(t.preventDefault(),n.focus()):t.target===n[0]&&"SHIFT_TAB"===a(t)&&(t.preventDefault(),i.focus())})},releaseFocus:function(t){t.off("keydown.zf.trapfocus")}}},"./js/foundation.util.mediaQuery.js":function(t,e,n){"use strict";n.r(e),n.d(e,"MediaQuery",function(){return a});var i=n("jquery"),s=n.n(i);function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}window.matchMedia||(window.matchMedia=function(){var e=window.styleMedia||window.media;if(!e){var n,i=document.createElement("style"),t=document.getElementsByTagName("script")[0];i.type="text/css",i.id="matchmediajs-test",t?t.parentNode.insertBefore(i,t):document.head.appendChild(i),n="getComputedStyle"in window&&window.getComputedStyle(i,null)||i.currentStyle,e={matchMedium:function(t){var e="@media "+t+"{ #matchmediajs-test { width: 1px; } }";return i.styleSheet?i.styleSheet.cssText=e:i.textContent=e,"1px"===n.width}}}return function(t){return{matches:e.matchMedium(t||"all"),media:t||"all"}}}());var a={queries:[],current:"",_init:function(){s()("meta.foundation-mq").length||s()('<meta class="foundation-mq">').appendTo(document.head);var t,e,n,i=s()(".foundation-mq").css("font-family");for(var o in n={},t="string"==typeof(e=i)&&(e=e.trim().slice(1,-1))?n=e.split("&").reduce(function(t,e){var n=e.replace(/\+/g," ").split("="),i=n[0],o=n[1];return i=decodeURIComponent(i),o=void 0===o?null:decodeURIComponent(o),t.hasOwnProperty(i)?Array.isArray(t[i])?t[i].push(o):t[i]=[t[i],o]:t[i]=o,t},{}):n)t.hasOwnProperty(o)&&this.queries.push({name:o,value:"only screen and (min-width: ".concat(t[o],")")});this.current=this._getCurrentSize(),this._watcher()},atLeast:function(t){var e=this.get(t);return!!e&&window.matchMedia(e).matches},is:function(t){return 1<(t=t.trim().split(" ")).length&&"only"===t[1]?t[0]===this._getCurrentSize():this.atLeast(t[0])},get:function(t){for(var e in this.queries)if(this.queries.hasOwnProperty(e)){var n=this.queries[e];if(t===n.name)return n.value}return null},_getCurrentSize:function(){for(var t,e=0;e<this.queries.length;e++){var n=this.queries[e];window.matchMedia(n.value).matches&&(t=n)}return"object"===o(t)?t.name:t},_watcher:function(){var n=this;s()(window).off("resize.zf.mediaquery").on("resize.zf.mediaquery",function(){var t=n._getCurrentSize(),e=n.current;t!==e&&(n.current=t,s()(window).trigger("changed.zf.mediaquery",[t,e]))})}}},"./js/foundation.util.motion.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Move",function(){return s}),n.d(e,"Motion",function(){return o});var i=n("jquery"),r=n.n(i),l=n("./js/foundation.core.utils.js"),u=["mui-enter","mui-leave"],c=["mui-enter-active","mui-leave-active"],o={animateIn:function(t,e,n){a(!0,t,e,n)},animateOut:function(t,e,n){a(!1,t,e,n)}};function s(n,i,o){var s,a,r=null;if(0===n)return o.apply(i),void i.trigger("finished.zf.animate",[i]).triggerHandler("finished.zf.animate",[i]);s=window.requestAnimationFrame(function t(e){r||(r=e),a=e-r,o.apply(i),a<n?s=window.requestAnimationFrame(t,i):(window.cancelAnimationFrame(s),i.trigger("finished.zf.animate",[i]).triggerHandler("finished.zf.animate",[i]))})}function a(t,e,n,i){if((e=r()(e).eq(0)).length){var o=t?u[0]:u[1],s=t?c[0]:c[1];a(),e.addClass(n).css("transition","none"),requestAnimationFrame(function(){e.addClass(o),t&&e.show()}),requestAnimationFrame(function(){e[0].offsetWidth,e.css("transition","").addClass(s)}),e.one(Object(l.transitionend)(e),function(){t||e.hide();a(),i&&i.apply(e)})}function a(){e[0].style.transitionDuration=0,e.removeClass("".concat(o," ").concat(s," ").concat(n))}}},"./js/foundation.util.nest.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Nest",function(){return o});var i=n("jquery"),r=n.n(i),o={Feather:function(t){var n=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"zf";t.attr("role","menubar");var e=t.find("li").attr({role:"menuitem"}),i="is-".concat(n,"-submenu"),o="".concat(i,"-item"),s="is-".concat(n,"-submenu-parent"),a="accordion"!==n;e.each(function(){var t=r()(this),e=t.children("ul");e.length&&(t.addClass(s),a&&(t.attr({"aria-haspopup":!0,"aria-label":t.children("a:first").text()}),"drilldown"===n&&t.attr({"aria-expanded":!1})),e.addClass("submenu ".concat(i)).attr({"data-submenu":"",role:"menubar"}),"drilldown"===n&&e.attr({"aria-hidden":!0})),t.parent("[data-submenu]").length&&t.addClass("is-submenu-item ".concat(o))})},Burn:function(t,e){var n="is-".concat(e,"-submenu"),i="".concat(n,"-item"),o="is-".concat(e,"-submenu-parent");t.find(">li, > li > ul, .menu, .menu > li, [data-submenu] > li").removeClass("".concat(n," ").concat(i," ").concat(o," is-submenu-item submenu is-active")).removeAttr("data-submenu").css("display","")}}},"./js/foundation.util.timer.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Timer",function(){return i});n("jquery");function i(e,t,n){var i,o,s=this,a=t.duration,r=Object.keys(e.data())[0]||"timer",l=-1;this.isPaused=!1,this.restart=function(){l=-1,clearTimeout(o),this.start()},this.start=function(){this.isPaused=!1,clearTimeout(o),l=l<=0?a:l,e.data("paused",!1),i=Date.now(),o=setTimeout(function(){t.infinite&&s.restart(),n&&"function"==typeof n&&n()},l),e.trigger("timerstart.zf.".concat(r))},this.pause=function(){this.isPaused=!0,clearTimeout(o),e.data("paused",!0);var t=Date.now();l-=t-i,e.trigger("timerpaused.zf.".concat(r))}}},"./js/foundation.util.touch.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Touch",function(){return c});var i=n("jquery"),o=n.n(i);function s(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}var a,r,l,u,c={},d=!1,h=!1;function f(t){if(this.removeEventListener("touchmove",p),this.removeEventListener("touchend",f),!h){var e=o.a.Event("tap",u||t);o()(this).trigger(e)}u=null,h=d=!1}function p(t){if(o.a.spotSwipe.preventDefault&&t.preventDefault(),d){var e,n=t.touches[0].pageX,i=(t.touches[0].pageY,a-n);h=!0,l=(new Date).getTime()-r,Math.abs(i)>=o.a.spotSwipe.moveThreshold&&l<=o.a.spotSwipe.timeThreshold&&(e=0<i?"left":"right"),e&&(t.preventDefault(),f.apply(this,arguments),o()(this).trigger(o.a.Event("swipe",t),e).trigger(o.a.Event("swipe".concat(e),t)))}}function m(t){1==t.touches.length&&(a=t.touches[0].pageX,t.touches[0].pageY,u=t,h=!(d=!0),r=(new Date).getTime(),this.addEventListener("touchmove",p,!1),this.addEventListener("touchend",f,!1))}function g(){this.addEventListener&&this.addEventListener("touchstart",m,!1)}var v=function(){function e(t){!function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,e),this.version="1.0.0",this.enabled="ontouchstart"in document.documentElement,this.preventDefault=!1,this.moveThreshold=75,this.timeThreshold=200,this.$=t,this._init()}var t,n,i;return t=e,(n=[{key:"_init",value:function(){var t=this.$;t.event.special.swipe={setup:g},t.event.special.tap={setup:g},t.each(["left","up","down","right"],function(){t.event.special["swipe".concat(this)]={setup:function(){t(this).on("swipe",t.noop)}}})}}])&&s(t.prototype,n),i&&s(t,i),e}();c.setupSpotSwipe=function(t){t.spotSwipe=new v(t)},c.setupTouchHandler=function(i){i.fn.addTouch=function(){this.each(function(t,e){i(e).bind("touchstart touchmove touchend touchcancel",function(t){n(t)})});var n=function(t){var e,n=t.changedTouches[0],i={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup"}[t.type];"MouseEvent"in window&&"function"==typeof window.MouseEvent?e=new window.MouseEvent(i,{bubbles:!0,cancelable:!0,screenX:n.screenX,screenY:n.screenY,clientX:n.clientX,clientY:n.clientY}):(e=document.createEvent("MouseEvent")).initMouseEvent(i,!0,!0,window,1,n.screenX,n.screenY,n.clientX,n.clientY,!1,!1,!1,!1,0,null),n.target.dispatchEvent(e)}}},c.init=function(t){void 0===t.spotSwipe&&(c.setupSpotSwipe(t),c.setupTouchHandler(t))}},"./js/foundation.util.triggers.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Triggers",function(){return c});var i=n("jquery"),s=n.n(i),o=n("./js/foundation.core.utils.js"),a=n("./js/foundation.util.motion.js");function r(t){return(r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var l=function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if("".concat(t[e],"MutationObserver")in window)return window["".concat(t[e],"MutationObserver")];return!1}(),u=function(e,n){e.data(n).split(" ").forEach(function(t){s()("#".concat(t))["close"===n?"trigger":"triggerHandler"]("".concat(n,".zf.trigger"),[e])})},c={Listeners:{Basic:{},Global:{}},Initializers:{}};function d(e,t,n){var i,o=Array.prototype.slice.call(arguments,3);s()(window).off(t).on(t,function(t){i&&clearTimeout(i),i=setTimeout(function(){n.apply(null,o)},e||10)})}c.Listeners.Basic={openListener:function(){u(s()(this),"open")},closeListener:function(){s()(this).data("close")?u(s()(this),"close"):s()(this).trigger("close.zf.trigger")},toggleListener:function(){s()(this).data("toggle")?u(s()(this),"toggle"):s()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=s()(this).data("closable");""!==e?a.Motion.animateOut(s()(this),e,function(){s()(this).trigger("closed.zf")}):s()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=s()(this).data("toggle-focus");s()("#".concat(t)).triggerHandler("toggle.zf.trigger",[s()(this)])}},c.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",c.Listeners.Basic.openListener)},c.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",c.Listeners.Basic.closeListener)},c.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",c.Listeners.Basic.toggleListener)},c.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",c.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",c.Listeners.Basic.closeableListener)},c.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",c.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",c.Listeners.Basic.toggleFocusListener)},c.Listeners.Global={resizeListener:function(t){l||t.each(function(){s()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){l||t.each(function(){s()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var n=t.namespace.split(".")[0];s()("[data-".concat(n,"]")).not('[data-yeti-box="'.concat(e,'"]')).each(function(){var t=s()(this);t.triggerHandler("close.zf.trigger",[t])})}},c.Initializers.addClosemeListener=function(t){var e=s()("[data-yeti-box]"),n=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?n.push(t):"object"===r(t)&&"string"==typeof t[0]?n=n.concat(t):console.error("Plugin names must be strings")),e.length){var i=n.map(function(t){return"closeme.zf.".concat(t)}).join(" ");s()(window).off(i).on(i,c.Listeners.Global.closeMeListener)}},c.Initializers.addResizeListener=function(t){var e=s()("[data-resize]");e.length&&d(t,"resize.zf.trigger",c.Listeners.Global.resizeListener,e)},c.Initializers.addScrollListener=function(t){var e=s()("[data-scroll]");e.length&&d(t,"scroll.zf.trigger",c.Listeners.Global.scrollListener,e)},c.Initializers.addMutationEventsListener=function(t){if(!l)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),n=function(t){var e=s()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var i=0;i<=e.length-1;i++){new l(n).observe(e[i],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},c.Initializers.addSimpleListeners=function(){var t=s()(document);c.Initializers.addOpenListener(t),c.Initializers.addCloseListener(t),c.Initializers.addToggleListener(t),c.Initializers.addCloseableListener(t),c.Initializers.addToggleFocusListener(t)},c.Initializers.addGlobalListeners=function(){var t=s()(document);c.Initializers.addMutationEventsListener(t),c.Initializers.addResizeListener(),c.Initializers.addScrollListener(),c.Initializers.addClosemeListener()},c.init=function(t,e){Object(o.onLoad)(t(window),function(){!0!==t.triggersInitialized&&(c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners(),t.triggersInitialized=!0)}),e&&(e.Triggers=c,e.IHearYou=c.Initializers.addGlobalListeners)}},0:function(t,e,n){t.exports=n("./js/entries/foundation.js")},jquery:function(t,e){t.exports=n}})});
+//# sourceMappingURL=foundation.min.js.map
diff --git a/dist/js/foundation.min.js.map b/dist/js/foundation.min.js.map
new file mode 100644 (file)
index 0000000..55d678f
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.min.js"],"names":["root","factory","exports","module","require","define","amd","a","i","window","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./js/entries/foundation.js","__webpack_exports__","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core__WEBPACK_IMPORTED_MODULE_1__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_box__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_5__","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__","_foundation_util_nest__WEBPACK_IMPORTED_MODULE_8__","_foundation_util_timer__WEBPACK_IMPORTED_MODULE_9__","_foundation_util_touch__WEBPACK_IMPORTED_MODULE_10__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_11__","_foundation_abide__WEBPACK_IMPORTED_MODULE_12__","_foundation_accordion__WEBPACK_IMPORTED_MODULE_13__","_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_14__","_foundation_drilldown__WEBPACK_IMPORTED_MODULE_15__","_foundation_dropdown__WEBPACK_IMPORTED_MODULE_16__","_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_17__","_foundation_equalizer__WEBPACK_IMPORTED_MODULE_18__","_foundation_interchange__WEBPACK_IMPORTED_MODULE_19__","_foundation_magellan__WEBPACK_IMPORTED_MODULE_20__","_foundation_offcanvas__WEBPACK_IMPORTED_MODULE_21__","_foundation_orbit__WEBPACK_IMPORTED_MODULE_22__","_foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_23__","_foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_24__","_foundation_reveal__WEBPACK_IMPORTED_MODULE_25__","_foundation_slider__WEBPACK_IMPORTED_MODULE_26__","_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_27__","_foundation_sticky__WEBPACK_IMPORTED_MODULE_28__","_foundation_tabs__WEBPACK_IMPORTED_MODULE_29__","_foundation_toggler__WEBPACK_IMPORTED_MODULE_30__","_foundation_tooltip__WEBPACK_IMPORTED_MODULE_31__","_foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_32__","addToJquery","rtl","GetYoDigits","transitionend","RegExpEscape","onLoad","Box","onImagesLoaded","Keyboard","MediaQuery","Motion","Move","Nest","Timer","init","_init","plugin","./js/foundation.abide.js","Abide","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","undefined","$element","extend","defaults","data","className","_this2","$inputs","merge","find","not","$globalErrors","a11yAttributes","each","input","addA11yAttributes","error","addGlobalErrorA11yAttributes","_events","_this3","off","on","resetForm","validateForm","validateOn","e","validateInput","liveValidate","validateOnBlur","$el","attr","isGood","type","checked","opt","val","id","$error","siblings","formErrorSelector","parent","add","concat","$label","closest","$els","_this4","labels","map","el","findLabel","$formError","findFormError","addClass","labelErrorClass","formErrorClass","inputErrorClass","data-invalid","aria-invalid","$errors","$labels","filter","first","errorId","elemId","label","end","a11yErrorLevel","groupName","findRadioLabels","$formErrors","removeClass","removeRadioErrorClasses","clearRequire","requiredCheck","validated","customValidator","validator","equalTo","is","validateRadio","validateText","matchValidation","validators","goodToGo","indexOf","message","dependentElements","_this","trigger","_this5","acc","push","noError","elem","$elem","css","pattern","inputText","valid","patterns","test","RegExp","prop","$group","required","_this6","split","v","$form","opts","removeErrorClasses","alpha","alpha_numeric","integer","number","card","cvv","email","url","domain","datetime","date","time","dateISO","month_day_year","day_month_year","color","website","text","./js/foundation.accordion.js","Accordion","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__","register","ENTER","SPACE","ARROW_DOWN","ARROW_UP","_isInitializing","$tabs","children","idx","$content","linkId","aria-controls","role","aria-expanded","aria-selected","aria-labelledby","aria-hidden","$initActive","_initialAnchor","prev","_openSingleTab","_checkDeepLink","anchor","location","hash","$anchor","$link","isOwnAnchor","hasClass","_closeAllTabs","deepLinkSmudge","offset","animate","scrollTop","top","deepLinkSmudgeDelay","deepLink","$tabContent","preventDefault","toggle","handleKey","next","$a","focus","multiExpand","previous","handled","stopPropagation","$target","console","info","up","down","updateHistory","history","pushState","replaceState","_openTab","$targetItem","$othersItems","allowAllClosed","_closeTab","$activeContents","targetContentId","slideDown","slideSpeed","slideUp","$activeTabs","stop","./js/foundation.accordionMenu.js","AccordionMenu","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__","ARROW_RIGHT","ARROW_LEFT","ESCAPE","Feather","aria-multiselectable","multiOpen","$menuLinks","$sub","subId","isActive","parentLink","clone","prependTo","wrap","submenuToggle","after","submenuToggleText","initPanes","$submenu","$prevElement","$nextElement","$elements","eq","Math","max","min","parents","open","close","closeAll","hideAll","stopImmediatePropagation","$targetBranch","parentsUntil","$othersActiveSubmenus","$submenus","$allmenus","detach","remove","Burn","./js/foundation.core.js","Foundation","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__","version","_plugins","_uuids","_plugin","functionName","attrName","hyphenate","registerPlugin","pluginName","toLowerCase","uuid","unregisterPlugin","splice","removeAttr","removeData","reInit","plugins","isJQ","plgs","forEach","foundation","string","keys","err","reflow","addBack","warn","trim","str","isNaN","parseFloat","parseValue","er","getFnName","$","fn","method","$noJS","args","Array","slice","plugClass","Function","results","exec","toString","replace","util","throttle","func","delay","timer","context","setTimeout","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","navigator","userAgent","lastTime","callback","nextTime","clearTimeout","performance","start","oThis","aArgs","fToBind","fNOP","fBound","./js/foundation.core.plugin.js","Plugin","_setup","getPluginName","_destroy","./js/foundation.core.utils.js","ignoreMousedisappear","namespace","round","pow","random","transitions","transition","WebkitTransition","MozTransition","OTransition","document","createElement","style","triggerHandler","handler","didLoad","readyState","eventType","cb","one","_ref","_ref$ignoreLeaveWindo","ignoreLeaveWindow","_ref$ignoreReappear","ignoreReappear","eLeave","_len","rest","_key","relatedTarget","hasFocus","eReenter","currentTarget","has","./js/foundation.drilldown.js","Drilldown","_foundation_util_box__WEBPACK_IMPORTED_MODULE_4__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__","TAB","SHIFT_TAB","autoApplyClass","$submenuAnchors","$menuItems","$currentMenu","_prepareMenu","_registerEvents","_keyboardEvents","tabindex","$menu","backButtonPosition","append","backButton","prepend","_back","autoHeight","$wrapper","wrapper","animateHeight","_getMaxDims","max-width","min-height","_show","closeOnClick","$body","contains","_hideAll","_bindHandler","_scrollTop","_resize","$scrollTopElement","scrollTopElement","scrollPos","parseInt","scrollTopOffset","animationDuration","animationEasing","_hide","height","parentSubMenu","autoFocus","index","_setHideSubMenuClasses","isLastChild","_setShowSubMenuClasses","blur","maxHeight","result","GetDimensions","getBoundingClientRect","width","unwrap","./js/foundation.dropdown.js","Dropdown","_foundation_positionable__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__","_get","receiver","Reflect","base","_superPropBase","desc","getOwnPropertyDescriptor","_Positionable","$id","$anchors","data-is-focus","data-yeti-box","aria-haspopup","_setCurrentAnchor","parentClass","$parent","$currentAnchor","data-resize","position","match","horizontalPosition","alignment","open.zf.trigger","close.zf.trigger","toggle.zf.trigger","resizeme.zf.trigger","_setPosition","hover","bodyData","whatinput","timeout","hoverDelay","hoverPane","findFocusable","body","$focusable","_addBodyHandler","trapFocus","releaseFocus","hide","vOffset","hOffset","allowOverlap","allowBottomOverlap","./js/foundation.dropdownMenu.js","DropdownMenu","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_nest__WEBPACK_IMPORTED_MODULE_4__","_foundation_util_box__WEBPACK_IMPORTED_MODULE_5__","subs","verticalClass","rightClass","changed","hasTouch","ontouchstart","parClass","clickOpen","hasSub","hasClicked","forceFollow","closeOnClickInside","disableHover","autoclose","closingTime","isTab","nextSibling","prevSibling","openSub","closeSub","functions","_isVertical","_isRtl","$sibs","clear","ImNotTouchingYou","oldClass","$parentLi","$toClose","data-is-click","./js/foundation.equalizer.js","Equalizer","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__","eqId","$watched","hasNested","isNested","isOn","onResizeMeBound","_onResizeMe","onPostEqualizedBound","_onPostEqualized","tooSmall","imgs","equalizeOn","_checkMQ","_reflow",".zf.equalizer","mutateme.zf.trigger","_pauseEvents","equalizeOnStack","_isStacked","equalizeByRow","getHeightsByRow","applyHeightByRow","getHeights","applyHeight","heights","len","offsetHeight","lastElTopOffset","groups","group","elOffsetTop","j","ln","groupsILength","lenJ","./js/foundation.interchange.js","Interchange","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__","rules","currentPath","_addBreakpoints","_generateRules","rule","matchMedia","query","matches","path","queries","SPECIAL_QUERIES","rulesList","join","nodeName","background-image","response","html","landscape","portrait","retina","./js/foundation.magellan.js","Magellan","_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_3__","calcPoints","$targets","$links","data-scroll","$active","pageYOffset","documentElement","points","winHeight","innerHeight","clientHeight","docHeight","scrollHeight","$tar","pt","threshold","targetPoint","deepLinking","scrollToLoc","_updateActive","onLoadListener","scrollme.zf.trigger","arrival","getAttribute","_deepLinkScroll","loc","_inTransition","activeIdx","newScrollPos","isScrollingUp","visibleLinks","$oldActive","activeHash","isNewActive","isNewHash","activeClass","pathname","search","./js/foundation.offcanvas.js","OffCanvas","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__","contentClasses","reveal","$lastTrigger","$triggers","nested","contentId","contentOverlay","overlay","overlayPosition","setAttribute","$overlay","insertAfter","revealOnClass","revealClass","isRevealed","revealOn","_setMQChecker","transitionTime","_removeContentClasses","keydown.zf.offcanvas","_handleKeyboard","click.zf.offcanvas","atLeast","hasReveal","_addContentClasses","event","allowUp","allowDown","lastY","originalEvent","pageY","forceTo","scrollTo","contentScroll","_stopScrolling","_recordScrollable","_stopScrollPropagation","canvasFocus","./js/foundation.orbit.js","Orbit","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_6__","_foundation_util_touch__WEBPACK_IMPORTED_MODULE_7__","ltr","_reset","containerClass","$slides","slideClass","$images","initActive","useMUI","_prepareForOrbit","bullets","_loadBullets","autoPlay","geoSync","accessible","$bullets","boxOfBullets","duration","timerDelay","infinite","changeSlide","_setWrapperHeight","temp","counter","display","swipe","pauseOnHover","pause","navButtons","nextClass","prevClass","$slide","restart","show","_updateBullets","isLTR","chosenSlide","$curSlide","$newSlide","$firstSlide","$lastSlide","last","dirIn","dirOut","infiniteWrap","animateIn","animateOut","isPaused","span","animInFromRight","animOutToRight","animInFromLeft","animOutToLeft","./js/foundation.positionable.js","Positionable","_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","left","right","bottom","nextItem","item","array","currentIdx","triedPositions","_getDefaultPosition","_getDefaultAlignment","originalPosition","originalAlignment","_alignmentsExhausted","_realign","_addTriedPosition","isExhausted","GetExplicitOffsets","_getVOffset","_getHOffset","minOverlap","minCoordinates","_positionsExhausted","overlap","OverlapArea","_reposition","./js/foundation.responsiveAccordionTabs.js","ResponsiveAccordionTabs","_foundation_accordion__WEBPACK_IMPORTED_MODULE_4__","MenuPlugins","tabs","cssClass","accordion","currentMq","currentPlugin","rulesTree","ruleSize","rulePlugin","_getAllOptions","isEmptyObject","_checkMediaQueries","allOptions","dummyPlugin","tmpPlugin","keyKey","objObj","destroy","_changedZfMediaQueryHandler","matchedMq","storezfData","_handleMarkup","toSet","fromString","$panels","tabsTitle","linkClass","tabsPanel","panelClass","$liHeads","$liHeadsA","visibility","appendTo","$tabsContent","$placeholder","tempValue","./js/foundation.responsiveMenu.js","ResponsiveMenu","_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_4__","_foundation_drilldown__WEBPACK_IMPORTED_MODULE_5__","_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_6__","dropdown","drilldown","./js/foundation.responsiveToggle.js","ResponsiveToggle","targetID","$targetMenu","$toggler","animationIn","animationOut","_update","_updateMqHandler","toggleMenu","hideFor","./js/foundation.reveal.js","Reveal","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__","cached","mq","current","fullScreen","_makeOverlay","additionalOverlayClasses","outerWidth","outerHeight","margin","_updatePosition","_handleState","$activeAnchor","activeElement","multipleOpened","_disableScroll","focusableElements","_addGlobalClasses","showDelay","_addGlobalListeners","updateScrollbarClass","toggleClass","closeOnEsc","finishUp","_removeGlobalClasses","_enableScroll","hideDelay","resetOnClose","urlWithoutHash","title","./js/foundation.slider.js","Slider","_foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__","SHIFT_ARROW_RIGHT","SHIFT_ARROW_UP","SHIFT_ARROW_DOWN","SHIFT_ARROW_LEFT","HOME","END","inputs","handles","$handle","$input","$fill","vertical","disabled","disabledClass","binding","_setInitAttr","doubleSided","$handle2","$input2","setHandles","_setHandlePos","pctOfBar","percent","positionValueFunction","_logTransform","_powTransform","toFixed","nonLinearBase","log","$hndl","noInvert","isDbl","h2Val","step","h1Val","vert","hOrW","lOrT","handleDim","elemDim","_pctOfBar","movement","decimal","_setValues","dim","isLeftHndl","handlePct","handlePos","initialStart","moveTime","changedDelay","initVal","initialEnd","aria-valuemax","aria-valuemin","aria-valuenow","aria-orientation","hasVal","_adjustValue","param","direction","eventOffset","pageX","barDim","windowScroll","scrollLeft","elemOffset","clientY","barXY","eventFromBar","offsetPct","_value","absPosition","prev_val","div","_eventsForHandle","curHandle","handleChangeEvent","_handleEvent","keyCode","clickSelect","draggable","addTouch","newValue","_$handle","oldValue","decrease","increase","decrease_fast","increase_fast","frac","num","dir","clickPos","abs","invertVertical","./js/foundation.smoothScroll.js","SmoothScroll","$loc","_linkClickListener","_handleLinkClick","./js/foundation.sticky.js","Sticky","$container","wasWrapped","container","stickyClass","data-mutate","scrollCount","checkEvery","isStuck","containerHeight","elemHeight","_parsePoints","_setSizes","scroll","_calc","_removeSticky","topPoint","reverse","pts","topAnchor","btmAnchor","breaks","place","scrollListener","canStick","_eventsHandler","_pauseListeners","checkSizes","bottomPoint","_setSticky","stickTo","mrgn","notStuckTo","isTop","stickToTop","anchorPt","anchorHeight","topOrBottom","stickyOn","newElemWidth","comp","getComputedStyle","pdngl","pdngr","newContainerHeight","_setBreakPoints","mTop","emCalc","marginTop","mBtm","marginBottom","em","fontSize","./js/foundation.tabs.js","Tabs","_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__","$tabTitles","linkActiveClass","matchHeight","_setHeight","selectTab","_collapse","_addKeyHandler","_addClickHandler","_setHeightMqHandler","_handleTabChange","which","wrapOnKeys","historyHandled","activeCollapse","$oldTab","$tabLink","$targetContent","_collapseTab","panelActiveClass","$target_anchor","$activeTab","idStr","panel","./js/foundation.toggler.js","Toggler","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__","$trigger","controls","_updateARIA","./js/foundation.tooltip.js","Tooltip","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__","_foundation_positionable__WEBPACK_IMPORTED_MODULE_4__","isClick","tipText","template","_buildTemplate","allowHtml","aria-describedby","data-toggle","triggerClass","tooltipWidth","tooltipHeight","templateClasses","tooltipClass","data-is-active","showOn","fadeIn","fadeInDuration","fadeOut","fadeOutDuration","isFocus","disableForTouch","touchCloseText","./js/foundation.util.box.js","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__","lrOnly","tbOnly","ignoreBottom","GetOffsets","isOverflow","$eleDims","windowDims","$anchorDims","topOver","bottomOver","leftOver","rightOver","eleDims","parDims","sqrt","Error","rect","parRect","parentNode","winRect","winY","winX","pageXOffset","parentDims","topVal","leftVal","./js/foundation.util.imageLoader.js","images","unloaded","singleImageLoaded","complete","naturalWidth","image","Image","events","me","src","./js/foundation.util.keyboard.js","keyCodes","9","13","27","32","35","36","37","38","39","40","commands","parseKey","String","fromCharCode","toUpperCase","shiftKey","ctrlKey","altKey","kcs","k","kc","getKeyCodes","component","commandList","returnValue","unhandled","componentName","cmds","$firstFocusable","$lastFocusable","./js/foundation.util.mediaQuery.js","styleMedia","media","script","getElementsByTagName","insertBefore","head","appendChild","currentStyle","matchMedium","styleSheet","cssText","textContent","namedQueries","styleObject","extractedStyles","reduce","ret","parts","decodeURIComponent","isArray","_getCurrentSize","_watcher","size","matched","newSize","currentSize","./js/foundation.util.motion.js","initClasses","activeClasses","animation","anim","prog","move","ts","isIn","initClass","reset","offsetWidth","transitionDuration","./js/foundation.util.nest.js","menu","items","subMenuClass","subItemClass","hasSubClass","applyAria","$item","aria-label","data-submenu","./js/foundation.util.timer.js","nameSpace","remain","./js/foundation.util.touch.js","Touch","startPosX","startTime","elapsedTime","startEvent","isMoving","didMoved","onTouchEnd","removeEventListener","onTouchMove","tapEvent","Event","spotSwipe","x","touches","dx","moveThreshold","timeThreshold","onTouchStart","addEventListener","SpotSwipe","enabled","special","setup","tap","noop","setupSpotSwipe","setupTouchHandler","handleTouch","simulatedEvent","changedTouches","touchstart","touchmove","touchend","MouseEvent","bubbles","cancelable","screenX","screenY","clientX","createEvent","initMouseEvent","dispatchEvent","./js/foundation.util.triggers.js","Triggers","MutationObserver","prefixes","triggers","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","listener","openListener","closeListener","toggleListener","closeableListener","toggleFocusListener","addOpenListener","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","closeMeListener","pluginId","addClosemeListener","yetiBoxes","plugNames","listeners","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","attributeName","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","triggersInitialized","IHearYou","0","jquery"],"mappings":"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","file":"foundation.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"jquery\"], factory);\n\telse {\n\t\tvar a = typeof exports === 'object' ? factory(require(\"jquery\")) : factory(root[\"jQuery\"]);\n\t\tfor(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];\n\t}\n})(window, function(__WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./js/entries/foundation.js\":\n/*!**********************************!*\\\n  !*** ./js/entries/foundation.js ***!\n  \\**********************************/\n/*! exports provided: Foundation, CoreUtils, Box, onImagesLoaded, Keyboard, MediaQuery, Motion, Nest, Timer, Touch, Triggers, Abide, Accordion, AccordionMenu, Drilldown, Dropdown, DropdownMenu, Equalizer, Interchange, Magellan, OffCanvas, Orbit, ResponsiveMenu, ResponsiveToggle, Reveal, Slider, SmoothScroll, Sticky, Tabs, Toggler, Tooltip, ResponsiveAccordionTabs, default */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../foundation.core */ \"./js/foundation.core.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony reexport (module object) */ __webpack_require__.d(__webpack_exports__, \"CoreUtils\", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__; });\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../foundation.util.box */ \"./js/foundation.util.box.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Box\", function() { return _foundation_util_box__WEBPACK_IMPORTED_MODULE_3__[\"Box\"]; });\n\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../foundation.util.imageLoader */ \"./js/foundation.util.imageLoader.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"onImagesLoaded\", function() { return _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__[\"onImagesLoaded\"]; });\n\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ../foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Keyboard\", function() { return _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_5__[\"Keyboard\"]; });\n\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ../foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"MediaQuery\", function() { return _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__[\"MediaQuery\"]; });\n\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ../foundation.util.motion */ \"./js/foundation.util.motion.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Motion\", function() { return _foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__[\"Motion\"]; });\n\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ../foundation.util.nest */ \"./js/foundation.util.nest.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Nest\", function() { return _foundation_util_nest__WEBPACK_IMPORTED_MODULE_8__[\"Nest\"]; });\n\n/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ../foundation.util.timer */ \"./js/foundation.util.timer.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Timer\", function() { return _foundation_util_timer__WEBPACK_IMPORTED_MODULE_9__[\"Timer\"]; });\n\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ../foundation.util.touch */ \"./js/foundation.util.touch.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Touch\", function() { return _foundation_util_touch__WEBPACK_IMPORTED_MODULE_10__[\"Touch\"]; });\n\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ../foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_11__[\"Triggers\"]; });\n\n/* harmony import */ var _foundation_abide__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ../foundation.abide */ \"./js/foundation.abide.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Abide\", function() { return _foundation_abide__WEBPACK_IMPORTED_MODULE_12__[\"Abide\"]; });\n\n/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ../foundation.accordion */ \"./js/foundation.accordion.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Accordion\", function() { return _foundation_accordion__WEBPACK_IMPORTED_MODULE_13__[\"Accordion\"]; });\n\n/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ../foundation.accordionMenu */ \"./js/foundation.accordionMenu.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"AccordionMenu\", function() { return _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_14__[\"AccordionMenu\"]; });\n\n/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ../foundation.drilldown */ \"./js/foundation.drilldown.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Drilldown\", function() { return _foundation_drilldown__WEBPACK_IMPORTED_MODULE_15__[\"Drilldown\"]; });\n\n/* harmony import */ var _foundation_dropdown__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ../foundation.dropdown */ \"./js/foundation.dropdown.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Dropdown\", function() { return _foundation_dropdown__WEBPACK_IMPORTED_MODULE_16__[\"Dropdown\"]; });\n\n/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! ../foundation.dropdownMenu */ \"./js/foundation.dropdownMenu.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DropdownMenu\", function() { return _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_17__[\"DropdownMenu\"]; });\n\n/* harmony import */ var _foundation_equalizer__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! ../foundation.equalizer */ \"./js/foundation.equalizer.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Equalizer\", function() { return _foundation_equalizer__WEBPACK_IMPORTED_MODULE_18__[\"Equalizer\"]; });\n\n/* harmony import */ var _foundation_interchange__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(/*! ../foundation.interchange */ \"./js/foundation.interchange.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Interchange\", function() { return _foundation_interchange__WEBPACK_IMPORTED_MODULE_19__[\"Interchange\"]; });\n\n/* harmony import */ var _foundation_magellan__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(/*! ../foundation.magellan */ \"./js/foundation.magellan.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Magellan\", function() { return _foundation_magellan__WEBPACK_IMPORTED_MODULE_20__[\"Magellan\"]; });\n\n/* harmony import */ var _foundation_offcanvas__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(/*! ../foundation.offcanvas */ \"./js/foundation.offcanvas.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"OffCanvas\", function() { return _foundation_offcanvas__WEBPACK_IMPORTED_MODULE_21__[\"OffCanvas\"]; });\n\n/* harmony import */ var _foundation_orbit__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(/*! ../foundation.orbit */ \"./js/foundation.orbit.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Orbit\", function() { return _foundation_orbit__WEBPACK_IMPORTED_MODULE_22__[\"Orbit\"]; });\n\n/* harmony import */ var _foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(/*! ../foundation.responsiveMenu */ \"./js/foundation.responsiveMenu.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveMenu\", function() { return _foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_23__[\"ResponsiveMenu\"]; });\n\n/* harmony import */ var _foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(/*! ../foundation.responsiveToggle */ \"./js/foundation.responsiveToggle.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveToggle\", function() { return _foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_24__[\"ResponsiveToggle\"]; });\n\n/* harmony import */ var _foundation_reveal__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(/*! ../foundation.reveal */ \"./js/foundation.reveal.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Reveal\", function() { return _foundation_reveal__WEBPACK_IMPORTED_MODULE_25__[\"Reveal\"]; });\n\n/* harmony import */ var _foundation_slider__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(/*! ../foundation.slider */ \"./js/foundation.slider.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Slider\", function() { return _foundation_slider__WEBPACK_IMPORTED_MODULE_26__[\"Slider\"]; });\n\n/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(/*! ../foundation.smoothScroll */ \"./js/foundation.smoothScroll.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SmoothScroll\", function() { return _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_27__[\"SmoothScroll\"]; });\n\n/* harmony import */ var _foundation_sticky__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(/*! ../foundation.sticky */ \"./js/foundation.sticky.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Sticky\", function() { return _foundation_sticky__WEBPACK_IMPORTED_MODULE_28__[\"Sticky\"]; });\n\n/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(/*! ../foundation.tabs */ \"./js/foundation.tabs.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Tabs\", function() { return _foundation_tabs__WEBPACK_IMPORTED_MODULE_29__[\"Tabs\"]; });\n\n/* harmony import */ var _foundation_toggler__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(/*! ../foundation.toggler */ \"./js/foundation.toggler.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Toggler\", function() { return _foundation_toggler__WEBPACK_IMPORTED_MODULE_30__[\"Toggler\"]; });\n\n/* harmony import */ var _foundation_tooltip__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(/*! ../foundation.tooltip */ \"./js/foundation.tooltip.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Tooltip\", function() { return _foundation_tooltip__WEBPACK_IMPORTED_MODULE_31__[\"Tooltip\"]; });\n\n/* harmony import */ var _foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(/*! ../foundation.responsiveAccordionTabs */ \"./js/foundation.responsiveAccordionTabs.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveAccordionTabs\", function() { return _foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_32__[\"ResponsiveAccordionTabs\"]; });\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].addToJquery(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Add Foundation Utils to Foundation global namespace for backwards\n// compatibility.\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].rtl = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"rtl\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].GetYoDigits = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].transitionend = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"transitionend\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].RegExpEscape = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"RegExpEscape\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].onLoad = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"onLoad\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].Box = _foundation_util_box__WEBPACK_IMPORTED_MODULE_3__[\"Box\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].onImagesLoaded = _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__[\"onImagesLoaded\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].Keyboard = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_5__[\"Keyboard\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].MediaQuery = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__[\"MediaQuery\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].Motion = _foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__[\"Motion\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].Move = _foundation_util_motion__WEBPACK_IMPORTED_MODULE_7__[\"Move\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].Nest = _foundation_util_nest__WEBPACK_IMPORTED_MODULE_8__[\"Nest\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].Timer = _foundation_util_timer__WEBPACK_IMPORTED_MODULE_9__[\"Timer\"]; // Touch and Triggers previously were almost purely sede effect driven,\n// so no need to add it to Foundation, just init them.\n\n_foundation_util_touch__WEBPACK_IMPORTED_MODULE_10__[\"Touch\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_11__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a, _foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"]);\n\n_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_6__[\"MediaQuery\"]._init();\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_abide__WEBPACK_IMPORTED_MODULE_12__[\"Abide\"], 'Abide');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_accordion__WEBPACK_IMPORTED_MODULE_13__[\"Accordion\"], 'Accordion');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_14__[\"AccordionMenu\"], 'AccordionMenu');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_drilldown__WEBPACK_IMPORTED_MODULE_15__[\"Drilldown\"], 'Drilldown');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_dropdown__WEBPACK_IMPORTED_MODULE_16__[\"Dropdown\"], 'Dropdown');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_17__[\"DropdownMenu\"], 'DropdownMenu');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_equalizer__WEBPACK_IMPORTED_MODULE_18__[\"Equalizer\"], 'Equalizer');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_interchange__WEBPACK_IMPORTED_MODULE_19__[\"Interchange\"], 'Interchange');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_magellan__WEBPACK_IMPORTED_MODULE_20__[\"Magellan\"], 'Magellan');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_offcanvas__WEBPACK_IMPORTED_MODULE_21__[\"OffCanvas\"], 'OffCanvas');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_orbit__WEBPACK_IMPORTED_MODULE_22__[\"Orbit\"], 'Orbit');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_23__[\"ResponsiveMenu\"], 'ResponsiveMenu');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_24__[\"ResponsiveToggle\"], 'ResponsiveToggle');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_reveal__WEBPACK_IMPORTED_MODULE_25__[\"Reveal\"], 'Reveal');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_slider__WEBPACK_IMPORTED_MODULE_26__[\"Slider\"], 'Slider');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_27__[\"SmoothScroll\"], 'SmoothScroll');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_sticky__WEBPACK_IMPORTED_MODULE_28__[\"Sticky\"], 'Sticky');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_tabs__WEBPACK_IMPORTED_MODULE_29__[\"Tabs\"], 'Tabs');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_toggler__WEBPACK_IMPORTED_MODULE_30__[\"Toggler\"], 'Toggler');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_tooltip__WEBPACK_IMPORTED_MODULE_31__[\"Tooltip\"], 'Tooltip');\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].plugin(_foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_32__[\"ResponsiveAccordionTabs\"], 'ResponsiveAccordionTabs');\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"]);\n\n/***/ }),\n\n/***/ \"./js/foundation.abide.js\":\n/*!********************************!*\\\n  !*** ./js/foundation.abide.js ***!\n  \\********************************/\n/*! exports provided: Abide */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Abide\", function() { return Abide; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nvar Abide =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Abide, _Plugin);\n\n  function Abide() {\n    _classCallCheck(this, Abide);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Abide).apply(this, arguments));\n  }\n\n  _createClass(Abide, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Abide.\n     * @class\n     * @name Abide\n     * @fires Abide#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element) {\n      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(true, {}, Abide.defaults, this.$element.data(), options);\n      this.className = 'Abide'; // ie9 back compat\n\n      this._init();\n    }\n    /**\n     * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var _this2 = this;\n\n      this.$inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.merge( // Consider as input to validate:\n      this.$element.find('input').not('[type=submit]'), // * all input fields expect submit\n      this.$element.find('textarea, select') // * all textareas and select fields\n      );\n      var $globalErrors = this.$element.find('[data-abide-error]'); // Add a11y attributes to all fields\n\n      if (this.options.a11yAttributes) {\n        this.$inputs.each(function (i, input) {\n          return _this2.addA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(input));\n        });\n        $globalErrors.each(function (i, error) {\n          return _this2.addGlobalErrorA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(error));\n        });\n      }\n\n      this._events();\n    }\n    /**\n     * Initializes events for Abide.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this3 = this;\n\n      this.$element.off('.abide').on('reset.zf.abide', function () {\n        _this3.resetForm();\n      }).on('submit.zf.abide', function () {\n        return _this3.validateForm();\n      });\n\n      if (this.options.validateOn === 'fieldChange') {\n        this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) {\n          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));\n        });\n      }\n\n      if (this.options.liveValidate) {\n        this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) {\n          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));\n        });\n      }\n\n      if (this.options.validateOnBlur) {\n        this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) {\n          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));\n        });\n      }\n    }\n    /**\n     * Calls necessary functions to update Abide upon DOM change\n     * @private\n     */\n\n  }, {\n    key: \"_reflow\",\n    value: function _reflow() {\n      this._init();\n    }\n    /**\n     * Checks whether or not a form element has the required attribute and if it's checked or not\n     * @param {Object} element - jQuery object to check for required attribute\n     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n     */\n\n  }, {\n    key: \"requiredCheck\",\n    value: function requiredCheck($el) {\n      if (!$el.attr('required')) return true;\n      var isGood = true;\n\n      switch ($el[0].type) {\n        case 'checkbox':\n          isGood = $el[0].checked;\n          break;\n\n        case 'select':\n        case 'select-one':\n        case 'select-multiple':\n          var opt = $el.find('option:selected');\n          if (!opt.length || !opt.val()) isGood = false;\n          break;\n\n        default:\n          if (!$el.val() || !$el.val().length) isGood = false;\n      }\n\n      return isGood;\n    }\n    /**\n     * Get:\n     * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n     *   1. The element's direct sibling('s).\n     *   2. The element's parent's children.\n     * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n     *\n     * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n     *\n     * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n     * @returns {Object} jQuery object with the selector.\n     */\n\n  }, {\n    key: \"findFormError\",\n    value: function findFormError($el) {\n      var id = $el[0].id;\n      var $error = $el.siblings(this.options.formErrorSelector);\n\n      if (!$error.length) {\n        $error = $el.parent().find(this.options.formErrorSelector);\n      }\n\n      if (id) {\n        $error = $error.add(this.$element.find(\"[data-form-error-for=\\\"\".concat(id, \"\\\"]\")));\n      }\n\n      return $error;\n    }\n    /**\n     * Get the first element in this order:\n     * 2. The <label> with the attribute `[for=\"someInputId\"]`\n     * 3. The `.closest()` <label>\n     *\n     * @param {Object} $el - jQuery object to check for required attribute\n     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n     */\n\n  }, {\n    key: \"findLabel\",\n    value: function findLabel($el) {\n      var id = $el[0].id;\n      var $label = this.$element.find(\"label[for=\\\"\".concat(id, \"\\\"]\"));\n\n      if (!$label.length) {\n        return $el.closest('label');\n      }\n\n      return $label;\n    }\n    /**\n     * Get the set of labels associated with a set of radio els in this order\n     * 2. The <label> with the attribute `[for=\"someInputId\"]`\n     * 3. The `.closest()` <label>\n     *\n     * @param {Object} $el - jQuery object to check for required attribute\n     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n     */\n\n  }, {\n    key: \"findRadioLabels\",\n    value: function findRadioLabels($els) {\n      var _this4 = this;\n\n      var labels = $els.map(function (i, el) {\n        var id = el.id;\n\n        var $label = _this4.$element.find(\"label[for=\\\"\".concat(id, \"\\\"]\"));\n\n        if (!$label.length) {\n          $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).closest('label');\n        }\n\n        return $label[0];\n      });\n      return jquery__WEBPACK_IMPORTED_MODULE_0___default()(labels);\n    }\n    /**\n     * Adds the CSS error class as specified by the Abide settings to the label, input, and the form\n     * @param {Object} $el - jQuery object to add the class to\n     */\n\n  }, {\n    key: \"addErrorClasses\",\n    value: function addErrorClasses($el) {\n      var $label = this.findLabel($el);\n      var $formError = this.findFormError($el);\n\n      if ($label.length) {\n        $label.addClass(this.options.labelErrorClass);\n      }\n\n      if ($formError.length) {\n        $formError.addClass(this.options.formErrorClass);\n      }\n\n      $el.addClass(this.options.inputErrorClass).attr({\n        'data-invalid': '',\n        'aria-invalid': true\n      });\n    }\n    /**\n     * Adds [for] and [role=alert] attributes to all form error targetting $el,\n     * and [aria-describedby] attribute to $el toward the first form error.\n     * @param {Object} $el - jQuery object\n     */\n\n  }, {\n    key: \"addA11yAttributes\",\n    value: function addA11yAttributes($el) {\n      var $errors = this.findFormError($el);\n      var $labels = $errors.filter('label');\n      var $error = $errors.first();\n      if (!$errors.length) return; // Set [aria-describedby] on the input toward the first form error if it is not set\n\n      if (typeof $el.attr('aria-describedby') === 'undefined') {\n        // Get the first error ID or create one\n        var errorId = $error.attr('id');\n\n        if (typeof errorId === 'undefined') {\n          errorId = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'abide-error');\n          $error.attr('id', errorId);\n        }\n\n        ;\n        $el.attr('aria-describedby', errorId);\n      }\n\n      if ($labels.filter('[for]').length < $labels.length) {\n        // Get the input ID or create one\n        var elemId = $el.attr('id');\n\n        if (typeof elemId === 'undefined') {\n          elemId = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'abide-input');\n          $el.attr('id', elemId);\n        }\n\n        ; // For each label targeting $el, set [for] if it is not set.\n\n        $labels.each(function (i, label) {\n          var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label);\n          if (typeof $label.attr('for') === 'undefined') $label.attr('for', elemId);\n        });\n      } // For each error targeting $el, set [role=alert] if it is not set.\n\n\n      $errors.each(function (i, label) {\n        var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label);\n        if (typeof $label.attr('role') === 'undefined') $label.attr('role', 'alert');\n      }).end();\n    }\n    /**\n     * Adds [aria-live] attribute to the given global form error $el.\n     * @param {Object} $el - jQuery object to add the attribute to\n     */\n\n  }, {\n    key: \"addGlobalErrorA11yAttributes\",\n    value: function addGlobalErrorA11yAttributes($el) {\n      if (typeof $el.attr('aria-live') === 'undefined') $el.attr('aria-live', this.options.a11yErrorLevel);\n    }\n    /**\n     * Remove CSS error classes etc from an entire radio button group\n     * @param {String} groupName - A string that specifies the name of a radio button group\n     *\n     */\n\n  }, {\n    key: \"removeRadioErrorClasses\",\n    value: function removeRadioErrorClasses(groupName) {\n      var $els = this.$element.find(\":radio[name=\\\"\".concat(groupName, \"\\\"]\"));\n      var $labels = this.findRadioLabels($els);\n      var $formErrors = this.findFormError($els);\n\n      if ($labels.length) {\n        $labels.removeClass(this.options.labelErrorClass);\n      }\n\n      if ($formErrors.length) {\n        $formErrors.removeClass(this.options.formErrorClass);\n      }\n\n      $els.removeClass(this.options.inputErrorClass).attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n    }\n    /**\n     * Removes CSS error class as specified by the Abide settings from the label, input, and the form\n     * @param {Object} $el - jQuery object to remove the class from\n     */\n\n  }, {\n    key: \"removeErrorClasses\",\n    value: function removeErrorClasses($el) {\n      // radios need to clear all of the els\n      if ($el[0].type == 'radio') {\n        return this.removeRadioErrorClasses($el.attr('name'));\n      }\n\n      var $label = this.findLabel($el);\n      var $formError = this.findFormError($el);\n\n      if ($label.length) {\n        $label.removeClass(this.options.labelErrorClass);\n      }\n\n      if ($formError.length) {\n        $formError.removeClass(this.options.formErrorClass);\n      }\n\n      $el.removeClass(this.options.inputErrorClass).attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n    }\n    /**\n     * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.\n     * Ignores inputs with data-abide-ignore, type=\"hidden\" or disabled attributes set\n     * @fires Abide#invalid\n     * @fires Abide#valid\n     * @param {Object} element - jQuery object to validate, should be an HTML input\n     * @returns {Boolean} goodToGo - If the input is valid or not.\n     */\n\n  }, {\n    key: \"validateInput\",\n    value: function validateInput($el) {\n      var clearRequire = this.requiredCheck($el),\n          validated = false,\n          customValidator = true,\n          validator = $el.attr('data-validator'),\n          equalTo = true; // don't validate ignored inputs or hidden inputs or disabled inputs\n\n      if ($el.is('[data-abide-ignore]') || $el.is('[type=\"hidden\"]') || $el.is('[disabled]')) {\n        return true;\n      }\n\n      switch ($el[0].type) {\n        case 'radio':\n          validated = this.validateRadio($el.attr('name'));\n          break;\n\n        case 'checkbox':\n          validated = clearRequire;\n          break;\n\n        case 'select':\n        case 'select-one':\n        case 'select-multiple':\n          validated = clearRequire;\n          break;\n\n        default:\n          validated = this.validateText($el);\n      }\n\n      if (validator) {\n        customValidator = this.matchValidation($el, validator, $el.attr('required'));\n      }\n\n      if ($el.attr('data-equalto')) {\n        equalTo = this.options.validators.equalTo($el);\n      }\n\n      var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;\n      var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';\n\n      if (goodToGo) {\n        // Re-validate inputs that depend on this one with equalto\n        var dependentElements = this.$element.find(\"[data-equalto=\\\"\".concat($el.attr('id'), \"\\\"]\"));\n\n        if (dependentElements.length) {\n          var _this = this;\n\n          dependentElements.each(function () {\n            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val()) {\n              _this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n            }\n          });\n        }\n      }\n\n      this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);\n      /**\n       * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`\n       * Trigger includes the DOM element of the input.\n       * @event Abide#valid\n       * @event Abide#invalid\n       */\n\n      $el.trigger(message, [$el]);\n      return goodToGo;\n    }\n    /**\n     * Goes through a form and if there are any invalid inputs, it will display the form error element\n     * @returns {Boolean} noError - true if no errors were detected...\n     * @fires Abide#formvalid\n     * @fires Abide#forminvalid\n     */\n\n  }, {\n    key: \"validateForm\",\n    value: function validateForm() {\n      var _this5 = this;\n\n      var acc = [];\n\n      var _this = this;\n\n      this.$inputs.each(function () {\n        acc.push(_this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)));\n      });\n      var noError = acc.indexOf(false) === -1;\n      this.$element.find('[data-abide-error]').each(function (i, elem) {\n        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem); // Ensure a11y attributes are set\n\n        if (_this5.options.a11yAttributes) _this5.addGlobalErrorA11yAttributes($elem); // Show or hide the error\n\n        $elem.css('display', noError ? 'none' : 'block');\n      });\n      /**\n       * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.\n       * Trigger includes the element of the form.\n       * @event Abide#formvalid\n       * @event Abide#forminvalid\n       */\n\n      this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);\n      return noError;\n    }\n    /**\n     * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.\n     * @param {Object} $el - jQuery object to validate, should be a text input HTML element\n     * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns\n     * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified\n     */\n\n  }, {\n    key: \"validateText\",\n    value: function validateText($el, pattern) {\n      // A pattern can be passed to this function, or it will be infered from the input's \"pattern\" attribute, or it's \"type\" attribute\n      pattern = pattern || $el.attr('pattern') || $el.attr('type');\n      var inputText = $el.val();\n      var valid = false;\n\n      if (inputText.length) {\n        // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp\n        if (this.options.patterns.hasOwnProperty(pattern)) {\n          valid = this.options.patterns[pattern].test(inputText);\n        } // If the pattern name isn't also the type attribute of the field, then test it as a regexp\n        else if (pattern !== $el.attr('type')) {\n            valid = new RegExp(pattern).test(inputText);\n          } else {\n            valid = true;\n          }\n      } // An empty field is valid if it's not required\n      else if (!$el.prop('required')) {\n          valid = true;\n        }\n\n      return valid;\n    }\n    /**\n     * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.\n     * @param {String} groupName - A string that specifies the name of a radio button group\n     * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)\n     */\n\n  }, {\n    key: \"validateRadio\",\n    value: function validateRadio(groupName) {\n      // If at least one radio in the group has the `required` attribute, the group is considered required\n      // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice\n      var $group = this.$element.find(\":radio[name=\\\"\".concat(groupName, \"\\\"]\"));\n      var valid = false,\n          required = false; // For the group to be required, at least one radio needs to be required\n\n      $group.each(function (i, e) {\n        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).attr('required')) {\n          required = true;\n        }\n      });\n      if (!required) valid = true;\n\n      if (!valid) {\n        // For the group to be valid, at least one radio needs to be checked\n        $group.each(function (i, e) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).prop('checked')) {\n            valid = true;\n          }\n        });\n      }\n\n      ;\n      return valid;\n    }\n    /**\n     * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator=\"foo bar baz\"` in a space separated listed.\n     * @param {Object} $el - jQuery input element.\n     * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.\n     * @param {Boolean} required - self explanatory?\n     * @returns {Boolean} - true if validations passed.\n     */\n\n  }, {\n    key: \"matchValidation\",\n    value: function matchValidation($el, validators, required) {\n      var _this6 = this;\n\n      required = required ? true : false;\n      var clear = validators.split(' ').map(function (v) {\n        return _this6.options.validators[v]($el, required, $el.parent());\n      });\n      return clear.indexOf(false) === -1;\n    }\n    /**\n     * Resets form inputs and styles\n     * @fires Abide#formreset\n     */\n\n  }, {\n    key: \"resetForm\",\n    value: function resetForm() {\n      var $form = this.$element,\n          opts = this.options;\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\".\".concat(opts.labelErrorClass), $form).not('small').removeClass(opts.labelErrorClass);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\".\".concat(opts.inputErrorClass), $form).not('small').removeClass(opts.inputErrorClass);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"\".concat(opts.formErrorSelector, \".\").concat(opts.formErrorClass)).removeClass(opts.formErrorClass);\n      $form.find('[data-abide-error]').css('display', 'none');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n      /**\n       * Fires when the form has been reset.\n       * @event Abide#formreset\n       */\n\n      $form.trigger('formreset.zf.abide', [$form]);\n    }\n    /**\n     * Destroys an instance of Abide.\n     * Removes error styles and classes from elements, without resetting their values.\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      var _this = this;\n\n      this.$element.off('.abide').find('[data-abide-error]').css('display', 'none');\n      this.$inputs.off('.abide').each(function () {\n        _this.removeErrorClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n      });\n    }\n  }]);\n\n  return Abide;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nAbide.defaults = {\n  /**\n   * The default event to validate inputs. Checkboxes and radios validate immediately.\n   * Remove or change this value for manual validation.\n   * @option\n   * @type {?string}\n   * @default 'fieldChange'\n   */\n  validateOn: 'fieldChange',\n\n  /**\n   * Class to be applied to input labels on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-label'\n   */\n  labelErrorClass: 'is-invalid-label',\n\n  /**\n   * Class to be applied to inputs on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-input'\n   */\n  inputErrorClass: 'is-invalid-input',\n\n  /**\n   * Class selector to use to target Form Errors for show/hide.\n   * @option\n   * @type {string}\n   * @default '.form-error'\n   */\n  formErrorSelector: '.form-error',\n\n  /**\n   * Class added to Form Errors on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-visible'\n   */\n  formErrorClass: 'is-visible',\n\n  /**\n   * If true, automatically insert when possible:\n   * - `[aria-describedby]` on fields\n   * - `[role=alert]` on form errors and `[for]` on form error labels\n   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  a11yAttributes: true,\n\n  /**\n   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.\n   * Options are: 'assertive', 'polite' and 'off'/null\n   * @option\n   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions\n   * @type {string}\n   * @default 'assertive'\n   */\n  a11yErrorLevel: 'assertive',\n\n  /**\n   * Set to true to validate text inputs on any value change.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  liveValidate: false,\n\n  /**\n   * Set to true to validate inputs on blur.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  validateOnBlur: false,\n  patterns: {\n    alpha: /^[a-zA-Z]+$/,\n    alpha_numeric: /^[a-zA-Z0-9]+$/,\n    integer: /^[-+]?\\d+$/,\n    number: /^[-+]?\\d*(?:[\\.\\,]\\d+)?$/,\n    // amex, visa, diners\n    card: /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\\d{3})\\d{11})$/,\n    cvv: /^([0-9]){3,4}$/,\n    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address\n    email: /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,\n    // From CommonRegexJS (@talyssonoc)\n    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76\n    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.\n    url: /^((?:(https?|ftps?|file|ssh|sftp):\\/\\/|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}\\/)(?:[^\\s()<>]+|\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\))+(?:\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:\\'\".,<>?\\xab\\xbb\\u201c\\u201d\\u2018\\u2019]))$/,\n    // abc.de\n    domain: /^([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,8}$/,\n    datetime: /^([0-2][0-9]{3})\\-([0-1][0-9])\\-([0-3][0-9])T([0-5][0-9])\\:([0-5][0-9])\\:([0-5][0-9])(Z|([\\-\\+]([0-1][0-9])\\:00))$/,\n    // YYYY-MM-DD\n    date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,\n    // HH:MM:SS\n    time: /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,\n    dateISO: /^\\d{4}[\\/\\-]\\d{1,2}[\\/\\-]\\d{1,2}$/,\n    // MM/DD/YYYY\n    month_day_year: /^(0[1-9]|1[012])[- \\/.](0[1-9]|[12][0-9]|3[01])[- \\/.]\\d{4}$/,\n    // DD/MM/YYYY\n    day_month_year: /^(0[1-9]|[12][0-9]|3[01])[- \\/.](0[1-9]|1[012])[- \\/.]\\d{4}$/,\n    // #FFF or #FFFFFF\n    color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,\n    // Domain || URL\n    website: {\n      test: function test(text) {\n        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);\n      }\n    }\n  },\n\n  /**\n   * Optional validation functions to be used. `equalTo` being the only default included function.\n   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:\n   * el : The jQuery element to validate.\n   * required : Boolean value of the required attribute be present or not.\n   * parent : The direct parent of the input.\n   * @option\n   */\n  validators: {\n    equalTo: function equalTo(el, required, parent) {\n      return jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(el.attr('data-equalto'))).val() === el.val();\n    }\n  }\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.accordion.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.accordion.js ***!\n  \\************************************/\n/*! exports provided: Accordion */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Accordion\", function() { return Accordion; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n/**\n * Accordion module.\n * @module foundation.accordion\n * @requires foundation.util.keyboard\n */\n\nvar Accordion =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Accordion, _Plugin);\n\n  function Accordion() {\n    _classCallCheck(this, Accordion);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Accordion).apply(this, arguments));\n  }\n\n  _createClass(Accordion, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of an accordion.\n     * @class\n     * @name Accordion\n     * @fires Accordion#init\n     * @param {jQuery} element - jQuery object to make into an accordion.\n     * @param {Object} options - a plain object with settings to override the default options.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Accordion.defaults, this.$element.data(), options);\n      this.className = 'Accordion'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('Accordion', {\n        'ENTER': 'toggle',\n        'SPACE': 'toggle',\n        'ARROW_DOWN': 'next',\n        'ARROW_UP': 'previous'\n      });\n    }\n    /**\n     * Initializes the accordion by animating the preset active pane(s).\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var _this2 = this;\n\n      this._isInitializing = true;\n      this.$element.attr('role', 'tablist');\n      this.$tabs = this.$element.children('[data-accordion-item]');\n      this.$tabs.each(function (idx, el) {\n        var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el),\n            $content = $el.children('[data-tab-content]'),\n            id = $content[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'accordion'),\n            linkId = el.id ? \"\".concat(el.id, \"-label\") : \"\".concat(id, \"-label\");\n        $el.find('a:first').attr({\n          'aria-controls': id,\n          'role': 'tab',\n          'id': linkId,\n          'aria-expanded': false,\n          'aria-selected': false\n        });\n        $content.attr({\n          'role': 'tabpanel',\n          'aria-labelledby': linkId,\n          'aria-hidden': true,\n          'id': id\n        });\n      });\n      var $initActive = this.$element.find('.is-active').children('[data-tab-content]');\n\n      if ($initActive.length) {\n        // Save up the initial hash to return to it later when going back in history\n        this._initialAnchor = $initActive.prev('a').attr('href');\n\n        this._openSingleTab($initActive);\n      }\n\n      this._checkDeepLink = function () {\n        var anchor = window.location.hash;\n\n        if (!anchor.length) {\n          // If we are still initializing and there is no anchor, then there is nothing to do\n          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor\n\n          if (_this2._initialAnchor) anchor = _this2._initialAnchor;\n        }\n\n        var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor);\n\n        var $link = anchor && _this2.$element.find(\"[href$=\\\"\".concat(anchor, \"\\\"]\")); // Whether the anchor element that has been found is part of this element\n\n\n        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, open it (if not already active)\n\n        if ($anchor && $link && $link.length) {\n          if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {\n            _this2._openSingleTab($anchor);\n          }\n\n          ;\n        } // Otherwise, close everything\n        else {\n            _this2._closeAllTabs();\n          }\n\n        if (isOwnAnchor) {\n          // Roll up a little to show the titles\n          if (_this2.options.deepLinkSmudge) {\n            Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n              var offset = _this2.$element.offset();\n\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({\n                scrollTop: offset.top\n              }, _this2.options.deepLinkSmudgeDelay);\n            });\n          }\n          /**\n           * Fires when the plugin has deeplinked at pageload\n           * @event Accordion#deeplink\n           */\n\n\n          _this2.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);\n        }\n      }; //use browser to open a tab, if it exists in this tabset\n\n\n      if (this.options.deepLink) {\n        this._checkDeepLink();\n      }\n\n      this._events();\n\n      this._isInitializing = false;\n    }\n    /**\n     * Adds event handlers for items within the accordion.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this.$tabs.each(function () {\n        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n        var $tabContent = $elem.children('[data-tab-content]');\n\n        if ($tabContent.length) {\n          $elem.children('a').off('click.zf.accordion keydown.zf.accordion').on('click.zf.accordion', function (e) {\n            e.preventDefault();\n\n            _this.toggle($tabContent);\n          }).on('keydown.zf.accordion', function (e) {\n            _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'Accordion', {\n              toggle: function toggle() {\n                _this.toggle($tabContent);\n              },\n              next: function next() {\n                var $a = $elem.next().find('a').focus();\n\n                if (!_this.options.multiExpand) {\n                  $a.trigger('click.zf.accordion');\n                }\n              },\n              previous: function previous() {\n                var $a = $elem.prev().find('a').focus();\n\n                if (!_this.options.multiExpand) {\n                  $a.trigger('click.zf.accordion');\n                }\n              },\n              handled: function handled() {\n                e.preventDefault();\n                e.stopPropagation();\n              }\n            });\n          });\n        }\n      });\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink);\n      }\n    }\n    /**\n     * Toggles the selected content pane's open/close state.\n     * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).\n     * @function\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle($target) {\n      if ($target.closest('[data-accordion]').is('[disabled]')) {\n        console.info('Cannot toggle an accordion that is disabled.');\n        return;\n      }\n\n      if ($target.parent().hasClass('is-active')) {\n        this.up($target);\n      } else {\n        this.down($target);\n      } //either replace or update browser history\n\n\n      if (this.options.deepLink) {\n        var anchor = $target.prev('a').attr('href');\n\n        if (this.options.updateHistory) {\n          history.pushState({}, '', anchor);\n        } else {\n          history.replaceState({}, '', anchor);\n        }\n      }\n    }\n    /**\n     * Opens the accordion tab defined by `$target`.\n     * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).\n     * @fires Accordion#down\n     * @function\n     */\n\n  }, {\n    key: \"down\",\n    value: function down($target) {\n      if ($target.closest('[data-accordion]').is('[disabled]')) {\n        console.info('Cannot call down on an accordion that is disabled.');\n        return;\n      }\n\n      if (this.options.multiExpand) this._openTab($target);else this._openSingleTab($target);\n    }\n    /**\n     * Closes the tab defined by `$target`.\n     * It may be ignored if the Accordion options don't allow it.\n     *\n     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n     * @fires Accordion#up\n     * @function\n     */\n\n  }, {\n    key: \"up\",\n    value: function up($target) {\n      if (this.$element.is('[disabled]')) {\n        console.info('Cannot call up on an accordion that is disabled.');\n        return;\n      } // Don't close the item if it is already closed\n\n\n      var $targetItem = $target.parent();\n      if (!$targetItem.hasClass('is-active')) return; // Don't close the item if there is no other active item (unless with `allowAllClosed`)\n\n      var $othersItems = $targetItem.siblings();\n      if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;\n\n      this._closeTab($target);\n    }\n    /**\n     * Make the tab defined by `$target` the only opened tab, closing all others tabs.\n     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_openSingleTab\",\n    value: function _openSingleTab($target) {\n      // Close all the others active tabs.\n      var $activeContents = this.$element.children('.is-active').children('[data-tab-content]');\n\n      if ($activeContents.length) {\n        this._closeTab($activeContents.not($target));\n      } // Then open the target.\n\n\n      this._openTab($target);\n    }\n    /**\n     * Opens the tab defined by `$target`.\n     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n     * @fires Accordion#down\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_openTab\",\n    value: function _openTab($target) {\n      var _this3 = this;\n\n      var $targetItem = $target.parent();\n      var targetContentId = $target.attr('aria-labelledby');\n      $target.attr('aria-hidden', false);\n      $targetItem.addClass('is-active');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(targetContentId)).attr({\n        'aria-expanded': true,\n        'aria-selected': true\n      });\n      $target.slideDown(this.options.slideSpeed, function () {\n        /**\n         * Fires when the tab is done opening.\n         * @event Accordion#down\n         */\n        _this3.$element.trigger('down.zf.accordion', [$target]);\n      });\n    }\n    /**\n     * Closes the tab defined by `$target`.\n     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n     * @fires Accordion#up\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_closeTab\",\n    value: function _closeTab($target) {\n      var _this4 = this;\n\n      var $targetItem = $target.parent();\n      var targetContentId = $target.attr('aria-labelledby');\n      $target.attr('aria-hidden', true);\n      $targetItem.removeClass('is-active');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(targetContentId)).attr({\n        'aria-expanded': false,\n        'aria-selected': false\n      });\n      $target.slideUp(this.options.slideSpeed, function () {\n        /**\n         * Fires when the tab is done collapsing up.\n         * @event Accordion#up\n         */\n        _this4.$element.trigger('up.zf.accordion', [$target]);\n      });\n    }\n    /**\n     * Closes all active tabs\n     * @fires Accordion#up\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_closeAllTabs\",\n    value: function _closeAllTabs() {\n      var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');\n\n      if ($activeTabs.length) {\n        this._closeTab($activeTabs);\n      }\n    }\n    /**\n     * Destroys an instance of an accordion.\n     * @fires Accordion#destroyed\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');\n      this.$element.find('a').off('.zf.accordion');\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink);\n      }\n    }\n  }]);\n\n  return Accordion;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nAccordion.defaults = {\n  /**\n   * Amount of time to animate the opening of an accordion pane.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n\n  /**\n   * Allow the accordion to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multiExpand: false,\n\n  /**\n   * Allow the accordion to close all panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowAllClosed: false,\n\n  /**\n   * Link the location hash to the open pane.\n   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open accordion\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.accordionMenu.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.accordionMenu.js ***!\n  \\****************************************/\n/*! exports provided: AccordionMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"AccordionMenu\", function() { return AccordionMenu; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.nest */ \"./js/foundation.util.nest.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n */\n\nvar AccordionMenu =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(AccordionMenu, _Plugin);\n\n  function AccordionMenu() {\n    _classCallCheck(this, AccordionMenu);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(AccordionMenu).apply(this, arguments));\n  }\n\n  _createClass(AccordionMenu, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of an accordion menu.\n     * @class\n     * @name AccordionMenu\n     * @fires AccordionMenu#init\n     * @param {jQuery} element - jQuery object to make into an accordion menu.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n      this.className = 'AccordionMenu'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('AccordionMenu', {\n        'ENTER': 'toggle',\n        'SPACE': 'toggle',\n        'ARROW_RIGHT': 'open',\n        'ARROW_UP': 'up',\n        'ARROW_DOWN': 'down',\n        'ARROW_LEFT': 'close',\n        'ESCAPE': 'closeAll'\n      });\n    }\n    /**\n     * Initializes the accordion menu by hiding all nested menus.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__[\"Nest\"].Feather(this.$element, 'accordion');\n\n      var _this = this;\n\n      this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');\n\n      this.$element.attr({\n        'role': 'tree',\n        'aria-multiselectable': this.options.multiOpen\n      });\n      this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');\n      this.$menuLinks.each(function () {\n        var linkId = this.id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'acc-menu-link'),\n            $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $sub = $elem.children('[data-submenu]'),\n            subId = $sub[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'acc-menu'),\n            isActive = $sub.hasClass('is-active');\n\n        if (_this.options.parentLink) {\n          var $anchor = $elem.children('a');\n          $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-accordion-submenu-item\"></li>');\n        }\n\n        if (_this.options.submenuToggle) {\n          $elem.addClass('has-submenu-toggle');\n          $elem.children('a').after('<button id=\"' + linkId + '\" class=\"submenu-toggle\" aria-controls=\"' + subId + '\" aria-expanded=\"' + isActive + '\" title=\"' + _this.options.submenuToggleText + '\"><span class=\"submenu-toggle-text\">' + _this.options.submenuToggleText + '</span></button>');\n        } else {\n          $elem.attr({\n            'aria-controls': subId,\n            'aria-expanded': isActive,\n            'id': linkId\n          });\n        }\n\n        $sub.attr({\n          'aria-labelledby': linkId,\n          'aria-hidden': !isActive,\n          'role': 'group',\n          'id': subId\n        });\n      });\n      this.$element.find('li').attr({\n        'role': 'treeitem'\n      });\n      var initPanes = this.$element.find('.is-active');\n\n      if (initPanes.length) {\n        var _this = this;\n\n        initPanes.each(function () {\n          _this.down(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n        });\n      }\n\n      this._events();\n    }\n    /**\n     * Adds event handlers for items within the menu.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this.$element.find('li').each(function () {\n        var $submenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]');\n\n        if ($submenu.length) {\n          if (_this.options.submenuToggle) {\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {\n              _this.toggle($submenu);\n            });\n          } else {\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {\n              e.preventDefault();\n\n              _this.toggle($submenu);\n            });\n          }\n        }\n      }).on('keydown.zf.accordionmenu', function (e) {\n        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $elements = $element.parent('ul').children('li'),\n            $prevElement,\n            $nextElement,\n            $target = $element.children('[data-submenu]');\n        $elements.each(function (i) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {\n            $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first();\n            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first();\n\n            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]:visible').length) {\n              // has open sub menu\n              $nextElement = $element.find('li:first-child').find('a').first();\n            }\n\n            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':first-child')) {\n              // is first element of sub menu\n              $prevElement = $element.parents('li').first().find('a').first();\n            } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) {\n              // if previous element has open sub menu\n              $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();\n            }\n\n            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':last-child')) {\n              // is last element of sub menu\n              $nextElement = $element.parents('li').first().next('li').find('a').first();\n            }\n\n            return;\n          }\n        });\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'AccordionMenu', {\n          open: function open() {\n            if ($target.is(':hidden')) {\n              _this.down($target);\n\n              $target.find('li').first().find('a').first().focus();\n            }\n          },\n          close: function close() {\n            if ($target.length && !$target.is(':hidden')) {\n              // close active sub of this item\n              _this.up($target);\n            } else if ($element.parent('[data-submenu]').length) {\n              // close currently open sub\n              _this.up($element.parent('[data-submenu]'));\n\n              $element.parents('li').first().find('a').first().focus();\n            }\n          },\n          up: function up() {\n            $prevElement.focus();\n            return true;\n          },\n          down: function down() {\n            $nextElement.focus();\n            return true;\n          },\n          toggle: function toggle() {\n            if (_this.options.submenuToggle) {\n              return false;\n            }\n\n            if ($element.children('[data-submenu]').length) {\n              _this.toggle($element.children('[data-submenu]'));\n\n              return true;\n            }\n          },\n          closeAll: function closeAll() {\n            _this.hideAll();\n          },\n          handled: function handled(preventDefault) {\n            if (preventDefault) {\n              e.preventDefault();\n            }\n\n            e.stopImmediatePropagation();\n          }\n        });\n      }); //.attr('tabindex', 0);\n    }\n    /**\n     * Closes all panes of the menu.\n     * @function\n     */\n\n  }, {\n    key: \"hideAll\",\n    value: function hideAll() {\n      this.up(this.$element.find('[data-submenu]'));\n    }\n    /**\n     * Opens all panes of the menu.\n     * @function\n     */\n\n  }, {\n    key: \"showAll\",\n    value: function showAll() {\n      this.down(this.$element.find('[data-submenu]'));\n    }\n    /**\n     * Toggles the open/close state of a submenu.\n     * @function\n     * @param {jQuery} $target - the submenu to toggle\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle($target) {\n      if (!$target.is(':animated')) {\n        if (!$target.is(':hidden')) {\n          this.up($target);\n        } else {\n          this.down($target);\n        }\n      }\n    }\n    /**\n     * Opens the sub-menu defined by `$target`.\n     * @param {jQuery} $target - Sub-menu to open.\n     * @fires AccordionMenu#down\n     */\n\n  }, {\n    key: \"down\",\n    value: function down($target) {\n      var _this2 = this;\n\n      // If having multiple submenus active is disabled, close all the submenus\n      // that are not parents or children of the targeted submenu.\n      if (!this.options.multiOpen) {\n        // The \"branch\" of the targetted submenu, from the component root to\n        // the active submenus nested in it.\n        var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); // All the active submenus that are not in the branch.\n\n        var $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);\n        this.up($othersActiveSubmenus);\n      }\n\n      $target.addClass('is-active').attr({\n        'aria-hidden': false\n      });\n\n      if (this.options.submenuToggle) {\n        $target.prev('.submenu-toggle').attr({\n          'aria-expanded': true\n        });\n      } else {\n        $target.parent('.is-accordion-submenu-parent').attr({\n          'aria-expanded': true\n        });\n      }\n\n      $target.slideDown(this.options.slideSpeed, function () {\n        /**\n         * Fires when the menu is done opening.\n         * @event AccordionMenu#down\n         */\n        _this2.$element.trigger('down.zf.accordionMenu', [$target]);\n      });\n    }\n    /**\n     * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.\n     * @param {jQuery} $target - Sub-menu to close.\n     * @fires AccordionMenu#up\n     */\n\n  }, {\n    key: \"up\",\n    value: function up($target) {\n      var _this3 = this;\n\n      var $submenus = $target.find('[data-submenu]');\n      var $allmenus = $target.add($submenus);\n      $submenus.slideUp(0);\n      $allmenus.removeClass('is-active').attr('aria-hidden', true);\n\n      if (this.options.submenuToggle) {\n        $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);\n      } else {\n        $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\n      }\n\n      $target.slideUp(this.options.slideSpeed, function () {\n        /**\n         * Fires when the menu is done collapsing up.\n         * @event AccordionMenu#up\n         */\n        _this3.$element.trigger('up.zf.accordionMenu', [$target]);\n      });\n    }\n    /**\n     * Destroys an instance of accordion menu.\n     * @fires AccordionMenu#destroyed\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.find('[data-submenu]').slideDown(0).css('display', '');\n      this.$element.find('a').off('click.zf.accordionMenu');\n      this.$element.find('[data-is-parent-link]').detach();\n\n      if (this.options.submenuToggle) {\n        this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');\n        this.$element.find('.submenu-toggle').remove();\n      }\n\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__[\"Nest\"].Burn(this.$element, 'accordion');\n    }\n  }]);\n\n  return AccordionMenu;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__[\"Plugin\"]);\n\nAccordionMenu.defaults = {\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n\n  /**\n   * Amount of time to animate the opening of a submenu in ms.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n\n  /**\n   * Adds a separate submenu toggle button. This allows the parent item to have a link.\n   * @option\n   * @example true\n   */\n  submenuToggle: false,\n\n  /**\n   * The text used for the submenu toggle if enabled. This is used for screen readers only.\n   * @option\n   * @example true\n   */\n  submenuToggleText: 'Toggle menu',\n\n  /**\n   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.core.js\":\n/*!*******************************!*\\\n  !*** ./js/foundation.core.js ***!\n  \\*******************************/\n/*! exports provided: Foundation */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return Foundation; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\nvar FOUNDATION_VERSION = '6.5.3'; // Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\n\nvar Foundation = {\n  version: FOUNDATION_VERSION,\n\n  /**\n   * Stores initialized plugins.\n   */\n  _plugins: {},\n\n  /**\n   * Stores generated unique ids for plugin instances\n   */\n  _uuids: [],\n\n  /**\n   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n   * @param {Object} plugin - The constructor of the plugin.\n   */\n  plugin: function plugin(_plugin, name) {\n    // Object key to use when adding to global Foundation object\n    // Examples: Foundation.Reveal, Foundation.OffCanvas\n    var className = name || functionName(_plugin); // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n    // Examples: data-reveal, data-off-canvas\n\n    var attrName = hyphenate(className); // Add to the Foundation object and the plugins list (for reflowing)\n\n    this._plugins[attrName] = this[className] = _plugin;\n  },\n\n  /**\n   * @function\n   * Populates the _uuids array with pointers to each individual plugin instance.\n   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n   * Also fires the initialization event for each plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @param {String} name - the name of the plugin, passed as a camelCased string.\n   * @fires Plugin#init\n   */\n  registerPlugin: function registerPlugin(plugin, name) {\n    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n    plugin.uuid = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, pluginName);\n\n    if (!plugin.$element.attr(\"data-\".concat(pluginName))) {\n      plugin.$element.attr(\"data-\".concat(pluginName), plugin.uuid);\n    }\n\n    if (!plugin.$element.data('zfPlugin')) {\n      plugin.$element.data('zfPlugin', plugin);\n    }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n\n\n    plugin.$element.trigger(\"init.zf.\".concat(pluginName));\n\n    this._uuids.push(plugin.uuid);\n\n    return;\n  },\n\n  /**\n   * @function\n   * Removes the plugins uuid from the _uuids array.\n   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n   * Also fires the destroyed event for the plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @fires Plugin#destroyed\n   */\n  unregisterPlugin: function unregisterPlugin(plugin) {\n    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n\n    plugin.$element.removeAttr(\"data-\".concat(pluginName)).removeData('zfPlugin')\n    /**\n     * Fires when the plugin has been destroyed.\n     * @event Plugin#destroyed\n     */\n    .trigger(\"destroyed.zf.\".concat(pluginName));\n\n    for (var prop in plugin) {\n      plugin[prop] = null; //clean up script to prep for garbage collection.\n    }\n\n    return;\n  },\n\n  /**\n   * @function\n   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n   * @default If no argument is passed, reflow all currently active plugins.\n   */\n  reInit: function reInit(plugins) {\n    var isJQ = plugins instanceof jquery__WEBPACK_IMPORTED_MODULE_0___default.a;\n\n    try {\n      if (isJQ) {\n        plugins.each(function () {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('zfPlugin')._init();\n        });\n      } else {\n        var type = _typeof(plugins),\n            _this = this,\n            fns = {\n          'object': function object(plgs) {\n            plgs.forEach(function (p) {\n              p = hyphenate(p);\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + p + ']').foundation('_init');\n            });\n          },\n          'string': function string() {\n            plugins = hyphenate(plugins);\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + plugins + ']').foundation('_init');\n          },\n          'undefined': function undefined() {\n            this['object'](Object.keys(_this._plugins));\n          }\n        };\n\n        fns[type](plugins);\n      }\n    } catch (err) {\n      console.error(err);\n    } finally {\n      return plugins;\n    }\n  },\n\n  /**\n   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n   */\n  reflow: function reflow(elem, plugins) {\n    // If plugins is undefined, just grab everything\n    if (typeof plugins === 'undefined') {\n      plugins = Object.keys(this._plugins);\n    } // If plugins is a string, convert it to an array with one item\n    else if (typeof plugins === 'string') {\n        plugins = [plugins];\n      }\n\n    var _this = this; // Iterate through each plugin\n\n\n    jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(plugins, function (i, name) {\n      // Get the current plugin\n      var plugin = _this._plugins[name]; // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n\n      var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem).find('[data-' + name + ']').addBack('[data-' + name + ']'); // For each plugin found, initialize it\n\n      $elem.each(function () {\n        var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            opts = {}; // Don't double-dip on plugins\n\n        if ($el.data('zfPlugin')) {\n          console.warn(\"Tried to initialize \" + name + \" on an element that already has a Foundation plugin.\");\n          return;\n        }\n\n        if ($el.attr('data-options')) {\n          var thing = $el.attr('data-options').split(';').forEach(function (e, i) {\n            var opt = e.split(':').map(function (el) {\n              return el.trim();\n            });\n            if (opt[0]) opts[opt[0]] = parseValue(opt[1]);\n          });\n        }\n\n        try {\n          $el.data('zfPlugin', new plugin(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), opts));\n        } catch (er) {\n          console.error(er);\n        } finally {\n          return;\n        }\n      });\n    });\n  },\n  getFnName: functionName,\n  addToJquery: function addToJquery($) {\n    // TODO: consider not making this a jQuery function\n    // TODO: need way to reflow vs. re-initialize\n\n    /**\n     * The Foundation jQuery method.\n     * @param {String|Array} method - An action to perform on the current jQuery object.\n     */\n    var foundation = function foundation(method) {\n      var type = _typeof(method),\n          $noJS = $('.no-js');\n\n      if ($noJS.length) {\n        $noJS.removeClass('no-js');\n      }\n\n      if (type === 'undefined') {\n        //needs to initialize the Foundation object, or an individual plugin.\n        _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"]._init();\n\n        Foundation.reflow(this);\n      } else if (type === 'string') {\n        //an individual method to invoke on a plugin or group of plugins\n        var args = Array.prototype.slice.call(arguments, 1); //collect all the arguments, if necessary\n\n        var plugClass = this.data('zfPlugin'); //determine the class of plugin\n\n        if (typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined') {\n          //make sure both the class and method exist\n          if (this.length === 1) {\n            //if there's only one, call it directly.\n            plugClass[method].apply(plugClass, args);\n          } else {\n            this.each(function (i, el) {\n              //otherwise loop through the jQuery collection and invoke the method on each\n              plugClass[method].apply($(el).data('zfPlugin'), args);\n            });\n          }\n        } else {\n          //error for no class or no method\n          throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n        }\n      } else {\n        //error for invalid argument type\n        throw new TypeError(\"We're sorry, \".concat(type, \" is not a valid parameter. You must use a string representing the method you wish to invoke.\"));\n      }\n\n      return this;\n    };\n\n    $.fn.foundation = foundation;\n    return $;\n  }\n};\nFoundation.util = {\n  /**\n   * Function for applying a debounce effect to a function call.\n   * @function\n   * @param {Function} func - Function to be called at end of timeout.\n   * @param {Number} delay - Time in ms to delay the call of `func`.\n   * @returns function\n   */\n  throttle: function throttle(func, delay) {\n    var timer = null;\n    return function () {\n      var context = this,\n          args = arguments;\n\n      if (timer === null) {\n        timer = setTimeout(function () {\n          func.apply(context, args);\n          timer = null;\n        }, delay);\n      }\n    };\n  }\n};\nwindow.Foundation = Foundation; // Polyfill for requestAnimationFrame\n\n(function () {\n  if (!Date.now || !window.Date.now) window.Date.now = Date.now = function () {\n    return new Date().getTime();\n  };\n  var vendors = ['webkit', 'moz'];\n\n  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n    var vp = vendors[i];\n    window.requestAnimationFrame = window[vp + 'RequestAnimationFrame'];\n    window.cancelAnimationFrame = window[vp + 'CancelAnimationFrame'] || window[vp + 'CancelRequestAnimationFrame'];\n  }\n\n  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n    var lastTime = 0;\n\n    window.requestAnimationFrame = function (callback) {\n      var now = Date.now();\n      var nextTime = Math.max(lastTime + 16, now);\n      return setTimeout(function () {\n        callback(lastTime = nextTime);\n      }, nextTime - now);\n    };\n\n    window.cancelAnimationFrame = clearTimeout;\n  }\n  /**\n   * Polyfill for performance.now, required by rAF\n   */\n\n\n  if (!window.performance || !window.performance.now) {\n    window.performance = {\n      start: Date.now(),\n      now: function now() {\n        return Date.now() - this.start;\n      }\n    };\n  }\n})();\n\nif (!Function.prototype.bind) {\n  Function.prototype.bind = function (oThis) {\n    if (typeof this !== 'function') {\n      // closest thing possible to the ECMAScript 5\n      // internal IsCallable function\n      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n    }\n\n    var aArgs = Array.prototype.slice.call(arguments, 1),\n        fToBind = this,\n        fNOP = function fNOP() {},\n        fBound = function fBound() {\n      return fToBind.apply(this instanceof fNOP ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments)));\n    };\n\n    if (this.prototype) {\n      // native functions don't have a prototype\n      fNOP.prototype = this.prototype;\n    }\n\n    fBound.prototype = new fNOP();\n    return fBound;\n  };\n} // Polyfill to get the name of a function in IE9\n\n\nfunction functionName(fn) {\n  if (typeof Function.prototype.name === 'undefined') {\n    var funcNameRegex = /function\\s([^(]{1,})\\(/;\n    var results = funcNameRegex.exec(fn.toString());\n    return results && results.length > 1 ? results[1].trim() : \"\";\n  } else if (typeof fn.prototype === 'undefined') {\n    return fn.constructor.name;\n  } else {\n    return fn.prototype.constructor.name;\n  }\n}\n\nfunction parseValue(str) {\n  if ('true' === str) return true;else if ('false' === str) return false;else if (!isNaN(str * 1)) return parseFloat(str);\n  return str;\n} // Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\n\n\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.core.plugin.js\":\n/*!**************************************!*\\\n  !*** ./js/foundation.core.plugin.js ***!\n  \\**************************************/\n/*! exports provided: Plugin */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Plugin\", function() { return Plugin; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\n\n // Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\n\nvar Plugin =\n/*#__PURE__*/\nfunction () {\n  function Plugin(element, options) {\n    _classCallCheck(this, Plugin);\n\n    this._setup(element, options);\n\n    var pluginName = getPluginName(this);\n    this.uuid = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, pluginName);\n\n    if (!this.$element.attr(\"data-\".concat(pluginName))) {\n      this.$element.attr(\"data-\".concat(pluginName), this.uuid);\n    }\n\n    if (!this.$element.data('zfPlugin')) {\n      this.$element.data('zfPlugin', this);\n    }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n\n\n    this.$element.trigger(\"init.zf.\".concat(pluginName));\n  }\n\n  _createClass(Plugin, [{\n    key: \"destroy\",\n    value: function destroy() {\n      this._destroy();\n\n      var pluginName = getPluginName(this);\n      this.$element.removeAttr(\"data-\".concat(pluginName)).removeData('zfPlugin')\n      /**\n       * Fires when the plugin has been destroyed.\n       * @event Plugin#destroyed\n       */\n      .trigger(\"destroyed.zf.\".concat(pluginName));\n\n      for (var prop in this) {\n        this[prop] = null; //clean up script to prep for garbage collection.\n      }\n    }\n  }]);\n\n  return Plugin;\n}(); // Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\n\n\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n  if (typeof obj.constructor.name !== 'undefined') {\n    return hyphenate(obj.constructor.name);\n  } else {\n    return hyphenate(obj.className);\n  }\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.core.utils.js\":\n/*!*************************************!*\\\n  !*** ./js/foundation.core.utils.js ***!\n  \\*************************************/\n/*! exports provided: rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"rtl\", function() { return rtl; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"GetYoDigits\", function() { return GetYoDigits; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"RegExpEscape\", function() { return RegExpEscape; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"transitionend\", function() { return transitionend; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"onLoad\", function() { return onLoad; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ignoreMousedisappear\", function() { return ignoreMousedisappear; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\n // Core Foundation Utilities, utilized in a number of places.\n\n/**\n * Returns a boolean for RTL support\n */\n\nfunction rtl() {\n  return jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').attr('dir') === 'rtl';\n}\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\n\n\nfunction GetYoDigits(length, namespace) {\n  length = length || 6;\n  return Math.round(Math.pow(36, length + 1) - Math.random() * Math.pow(36, length)).toString(36).slice(1) + (namespace ? \"-\".concat(namespace) : '');\n}\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\n\n\nfunction RegExpEscape(str) {\n  return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem) {\n  var transitions = {\n    'transition': 'transitionend',\n    'WebkitTransition': 'webkitTransitionEnd',\n    'MozTransition': 'transitionend',\n    'OTransition': 'otransitionend'\n  };\n  var elem = document.createElement('div'),\n      end;\n\n  for (var t in transitions) {\n    if (typeof elem.style[t] !== 'undefined') {\n      end = transitions[t];\n    }\n  }\n\n  if (end) {\n    return end;\n  } else {\n    end = setTimeout(function () {\n      $elem.triggerHandler('transitionend', [$elem]);\n    }, 1);\n    return 'transitionend';\n  }\n}\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\n\n\nfunction onLoad($elem, handler) {\n  var didLoad = document.readyState === 'complete';\n  var eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n\n  var cb = function cb() {\n    return $elem.triggerHandler(eventType);\n  };\n\n  if ($elem) {\n    if (handler) $elem.one(eventType, handler);\n    if (didLoad) setTimeout(cb);else jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', cb);\n  }\n\n  return eventType;\n}\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n *   (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n *   outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\n\n\nfunction ignoreMousedisappear(handler) {\n  var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n      _ref$ignoreLeaveWindo = _ref.ignoreLeaveWindow,\n      ignoreLeaveWindow = _ref$ignoreLeaveWindo === void 0 ? false : _ref$ignoreLeaveWindo,\n      _ref$ignoreReappear = _ref.ignoreReappear,\n      ignoreReappear = _ref$ignoreReappear === void 0 ? false : _ref$ignoreReappear;\n\n  return function leaveEventHandler(eLeave) {\n    for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n      rest[_key - 1] = arguments[_key];\n    }\n\n    var callback = handler.bind.apply(handler, [this, eLeave].concat(rest)); // The mouse left: call the given callback if the mouse entered elsewhere\n\n    if (eLeave.relatedTarget !== null) {\n      return callback();\n    } // Otherwise, check if the mouse actually left the window.\n    // In firefox if the user switched between windows, the window sill have the focus by the time\n    // the event is triggered. We have to debounce the event to test this case.\n\n\n    setTimeout(function leaveEventDebouncer() {\n      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n        return callback();\n      } // Otherwise, wait for the mouse to reeapear outside of the element,\n\n\n      if (!ignoreReappear) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).one('mouseenter', function reenterEventHandler(eReenter) {\n          if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(eLeave.currentTarget).has(eReenter.target).length) {\n            // Fill where the mouse finally entered.\n            eLeave.relatedTarget = eReenter.target;\n            callback();\n          }\n        });\n      }\n    }, 0);\n  };\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.drilldown.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.drilldown.js ***!\n  \\************************************/\n/*! exports provided: Drilldown */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Drilldown\", function() { return Drilldown; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.nest */ \"./js/foundation.util.nest.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.box */ \"./js/foundation.util.box.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n/**\n * Drilldown module.\n * @module foundation.drilldown\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n * @requires foundation.util.box\n */\n\nvar Drilldown =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Drilldown, _Plugin);\n\n  function Drilldown() {\n    _classCallCheck(this, Drilldown);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Drilldown).apply(this, arguments));\n  }\n\n  _createClass(Drilldown, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a drilldown menu.\n     * @class\n     * @name Drilldown\n     * @param {jQuery} element - jQuery object to make into an accordion menu.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Drilldown.defaults, this.$element.data(), options);\n      this.className = 'Drilldown'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('Drilldown', {\n        'ENTER': 'open',\n        'SPACE': 'open',\n        'ARROW_RIGHT': 'next',\n        'ARROW_UP': 'up',\n        'ARROW_DOWN': 'down',\n        'ARROW_LEFT': 'previous',\n        'ESCAPE': 'close',\n        'TAB': 'down',\n        'SHIFT_TAB': 'up'\n      });\n    }\n    /**\n     * Initializes the drilldown by creating jQuery collections of elements\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__[\"Nest\"].Feather(this.$element, 'drilldown');\n\n      if (this.options.autoApplyClass) {\n        this.$element.addClass('drilldown');\n      }\n\n      this.$element.attr({\n        'role': 'tree',\n        'aria-multiselectable': false\n      });\n      this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');\n      this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');\n      this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a'); // Set the main menu as current by default (unless a submenu is selected)\n      // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu\n\n      this.$currentMenu = this.$element;\n      this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'drilldown'));\n\n      this._prepareMenu();\n\n      this._registerEvents();\n\n      this._keyboardEvents();\n    }\n    /**\n     * prepares drilldown menu by setting attributes to links and elements\n     * sets a min height to prevent content jumping\n     * wraps the element if not already wrapped\n     * @private\n     * @function\n     */\n\n  }, {\n    key: \"_prepareMenu\",\n    value: function _prepareMenu() {\n      var _this = this; // if(!this.options.holdOpen){\n      //   this._menuLinkEvents();\n      // }\n\n\n      this.$submenuAnchors.each(function () {\n        var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n        var $sub = $link.parent();\n\n        if (_this.options.parentLink) {\n          $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-drilldown-submenu-item\" role=\"menuitem\"></li>');\n        }\n\n        $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);\n        $link.children('[data-submenu]').attr({\n          'aria-hidden': true,\n          'tabindex': 0,\n          'role': 'group'\n        });\n\n        _this._events($link);\n      });\n      this.$submenus.each(function () {\n        var $menu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $back = $menu.find('.js-drilldown-back');\n\n        if (!$back.length) {\n          switch (_this.options.backButtonPosition) {\n            case \"bottom\":\n              $menu.append(_this.options.backButton);\n              break;\n\n            case \"top\":\n              $menu.prepend(_this.options.backButton);\n              break;\n\n            default:\n              console.error(\"Unsupported backButtonPosition value '\" + _this.options.backButtonPosition + \"'\");\n          }\n        }\n\n        _this._back($menu);\n      });\n      this.$submenus.addClass('invisible');\n\n      if (!this.options.autoHeight) {\n        this.$submenus.addClass('drilldown-submenu-cover-previous');\n      } // create a wrapper on element if it doesn't exist.\n\n\n      if (!this.$element.parent().hasClass('is-drilldown')) {\n        this.$wrapper = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.wrapper).addClass('is-drilldown');\n        if (this.options.animateHeight) this.$wrapper.addClass('animate-height');\n        this.$element.wrap(this.$wrapper);\n      } // set wrapper\n\n\n      this.$wrapper = this.$element.parent();\n      this.$wrapper.css(this._getMaxDims());\n    }\n  }, {\n    key: \"_resize\",\n    value: function _resize() {\n      this.$wrapper.css({\n        'max-width': 'none',\n        'min-height': 'none'\n      }); // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths\n\n      this.$wrapper.css(this._getMaxDims());\n    }\n    /**\n     * Adds event handlers to elements in the menu.\n     * @function\n     * @private\n     * @param {jQuery} $elem - the current menu item to add handlers to.\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events($elem) {\n      var _this = this;\n\n      $elem.off('click.zf.drilldown').on('click.zf.drilldown', function (e) {\n        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) {\n          e.stopImmediatePropagation();\n          e.preventDefault();\n        } // if(e.target !== e.currentTarget.firstElementChild){\n        //   return false;\n        // }\n\n\n        _this._show($elem.parent('li'));\n\n        if (_this.options.closeOnClick) {\n          var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');\n          $body.off('.zf.drilldown').on('click.zf.drilldown', function (e) {\n            if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target)) {\n              return;\n            }\n\n            e.preventDefault();\n\n            _this._hideAll();\n\n            $body.off('.zf.drilldown');\n          });\n        }\n      });\n    }\n    /**\n     * Adds event handlers to the menu element.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_registerEvents\",\n    value: function _registerEvents() {\n      if (this.options.scrollTop) {\n        this._bindHandler = this._scrollTop.bind(this);\n        this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown', this._bindHandler);\n      }\n\n      this.$element.on('mutateme.zf.trigger', this._resize.bind(this));\n    }\n    /**\n     * Scroll to Top of Element or data-scroll-top-element\n     * @function\n     * @fires Drilldown#scrollme\n     */\n\n  }, {\n    key: \"_scrollTop\",\n    value: function _scrollTop() {\n      var _this = this;\n\n      var $scrollTopElement = _this.options.scrollTopElement != '' ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(_this.options.scrollTopElement) : _this.$element,\n          scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({\n        scrollTop: scrollPos\n      }, _this.options.animationDuration, _this.options.animationEasing, function () {\n        /**\n          * Fires after the menu has scrolled\n          * @event Drilldown#scrollme\n          */\n        if (this === jquery__WEBPACK_IMPORTED_MODULE_0___default()('html')[0]) _this.$element.trigger('scrollme.zf.drilldown');\n      });\n    }\n    /**\n     * Adds keydown event listener to `li`'s in the menu.\n     * @private\n     */\n\n  }, {\n    key: \"_keyboardEvents\",\n    value: function _keyboardEvents() {\n      var _this = this;\n\n      this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function (e) {\n        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $elements = $element.parent('li').parent('ul').children('li').children('a'),\n            $prevElement,\n            $nextElement;\n        $elements.each(function (i) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {\n            $prevElement = $elements.eq(Math.max(0, i - 1));\n            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));\n            return;\n          }\n        });\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'Drilldown', {\n          next: function next() {\n            if ($element.is(_this.$submenuAnchors)) {\n              _this._show($element.parent('li'));\n\n              $element.parent('li').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($element), function () {\n                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n              });\n              return true;\n            }\n          },\n          previous: function previous() {\n            _this._hide($element.parent('li').parent('ul'));\n\n            $element.parent('li').parent('ul').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($element), function () {\n              setTimeout(function () {\n                $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n              }, 1);\n            });\n            return true;\n          },\n          up: function up() {\n            $prevElement.focus(); // Don't tap focus on first element in root ul\n\n            return !$element.is(_this.$element.find('> li:first-child > a'));\n          },\n          down: function down() {\n            $nextElement.focus(); // Don't tap focus on last element in root ul\n\n            return !$element.is(_this.$element.find('> li:last-child > a'));\n          },\n          close: function close() {\n            // Don't close on element in root ul\n            if (!$element.is(_this.$element.find('> li > a'))) {\n              _this._hide($element.parent().parent());\n\n              $element.parent().parent().siblings('a').focus();\n            }\n          },\n          open: function open() {\n            if (_this.options.parentLink && $element.attr('href')) {\n              // Link with href\n              return false;\n            } else if (!$element.is(_this.$menuItems)) {\n              // not menu item means back button\n              _this._hide($element.parent('li').parent('ul'));\n\n              $element.parent('li').parent('ul').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($element), function () {\n                setTimeout(function () {\n                  $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n                }, 1);\n              });\n              return true;\n            } else if ($element.is(_this.$submenuAnchors)) {\n              // Sub menu item\n              _this._show($element.parent('li'));\n\n              $element.parent('li').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($element), function () {\n                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n              });\n              return true;\n            }\n          },\n          handled: function handled(preventDefault) {\n            if (preventDefault) {\n              e.preventDefault();\n            }\n\n            e.stopImmediatePropagation();\n          }\n        });\n      }); // end keyboardAccess\n    }\n    /**\n     * Closes all open elements, and returns to root menu.\n     * @function\n     * @fires Drilldown#closed\n     */\n\n  }, {\n    key: \"_hideAll\",\n    value: function _hideAll() {\n      var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');\n      if (this.options.autoHeight) this.$wrapper.css({\n        height: $elem.parent().closest('ul').data('calcHeight')\n      });\n      $elem.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($elem), function (e) {\n        $elem.removeClass('is-active is-closing');\n      });\n      /**\n       * Fires when the menu is fully closed.\n       * @event Drilldown#closed\n       */\n\n      this.$element.trigger('closed.zf.drilldown');\n    }\n    /**\n     * Adds event listener for each `back` button, and closes open menus.\n     * @function\n     * @fires Drilldown#back\n     * @param {jQuery} $elem - the current sub-menu to add `back` event.\n     */\n\n  }, {\n    key: \"_back\",\n    value: function _back($elem) {\n      var _this = this;\n\n      $elem.off('click.zf.drilldown');\n      $elem.children('.js-drilldown-back').on('click.zf.drilldown', function (e) {\n        e.stopImmediatePropagation(); // console.log('mouseup on back');\n\n        _this._hide($elem); // If there is a parent submenu, call show\n\n\n        var parentSubMenu = $elem.parent('li').parent('ul').parent('li');\n\n        if (parentSubMenu.length) {\n          _this._show(parentSubMenu);\n        }\n      });\n    }\n    /**\n     * Adds event listener to menu items w/o submenus to close open menus on click.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_menuLinkEvents\",\n    value: function _menuLinkEvents() {\n      var _this = this;\n\n      this.$menuItems.not('.is-drilldown-submenu-parent').off('click.zf.drilldown').on('click.zf.drilldown', function (e) {\n        // e.stopImmediatePropagation();\n        setTimeout(function () {\n          _this._hideAll();\n        }, 0);\n      });\n    }\n    /**\n     * Sets the CSS classes for submenu to show it.\n     * @function\n     * @private\n     * @param {jQuery} $elem - the target submenu (`ul` tag)\n     * @param {boolean} trigger - trigger drilldown event\n     */\n\n  }, {\n    key: \"_setShowSubMenuClasses\",\n    value: function _setShowSubMenuClasses($elem, trigger) {\n      $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n      $elem.parent('li').attr('aria-expanded', true);\n\n      if (trigger === true) {\n        this.$element.trigger('open.zf.drilldown', [$elem]);\n      }\n    }\n    /**\n     * Sets the CSS classes for submenu to hide it.\n     * @function\n     * @private\n     * @param {jQuery} $elem - the target submenu (`ul` tag)\n     * @param {boolean} trigger - trigger drilldown event\n     */\n\n  }, {\n    key: \"_setHideSubMenuClasses\",\n    value: function _setHideSubMenuClasses($elem, trigger) {\n      $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);\n      $elem.parent('li').attr('aria-expanded', false);\n\n      if (trigger === true) {\n        $elem.trigger('hide.zf.drilldown', [$elem]);\n      }\n    }\n    /**\n     * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.\n     * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.\n     * @function\n     * @fires Drilldown#open\n     * @param {jQuery} $elem - the target (sub)menu (`ul` tag)\n     * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused\n     */\n\n  }, {\n    key: \"_showMenu\",\n    value: function _showMenu($elem, autoFocus) {\n      var _this = this; // Reset drilldown\n\n\n      var $expandedSubmenus = this.$element.find('li[aria-expanded=\"true\"] > ul[data-submenu]');\n      $expandedSubmenus.each(function (index) {\n        _this._setHideSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n      }); // Save the menu as the currently displayed one.\n\n      this.$currentMenu = $elem; // If target menu is root, focus first link & exit\n\n      if ($elem.is('[data-drilldown]')) {\n        if (autoFocus === true) $elem.find('li[role=\"treeitem\"] > a').first().focus();\n        if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));\n        return;\n      } // Find all submenus on way to root incl. the element itself\n\n\n      var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); // Open target menu and all submenus on its way to root\n\n      $submenus.each(function (index) {\n        // Update height of first child (target menu) if autoHeight option true\n        if (index === 0 && _this.options.autoHeight) {\n          _this.$wrapper.css('height', jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight'));\n        }\n\n        var isLastChild = index == $submenus.length - 1; // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link\n        // Last child makes sure the event gets always triggered even if going through several menus\n\n        if (isLastChild === true) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)), function () {\n            if (autoFocus === true) {\n              $elem.find('li[role=\"treeitem\"] > a').first().focus();\n            }\n          });\n        }\n\n        _this._setShowSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), isLastChild);\n      });\n    }\n    /**\n     * Opens a submenu.\n     * @function\n     * @fires Drilldown#open\n     * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.\n     */\n\n  }, {\n    key: \"_show\",\n    value: function _show($elem) {\n      var $submenu = $elem.children('[data-submenu]');\n      $elem.attr('aria-expanded', true);\n      this.$currentMenu = $submenu;\n      $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n\n      if (this.options.autoHeight) {\n        this.$wrapper.css({\n          height: $submenu.data('calcHeight')\n        });\n      }\n      /**\n       * Fires when the submenu has opened.\n       * @event Drilldown#open\n       */\n\n\n      this.$element.trigger('open.zf.drilldown', [$elem]);\n    }\n    /**\n     * Hides a submenu\n     * @function\n     * @fires Drilldown#hide\n     * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.\n     */\n\n  }, {\n    key: \"_hide\",\n    value: function _hide($elem) {\n      if (this.options.autoHeight) this.$wrapper.css({\n        height: $elem.parent().closest('ul').data('calcHeight')\n      });\n\n      var _this = this;\n\n      $elem.parent('li').attr('aria-expanded', false);\n      $elem.attr('aria-hidden', true);\n      $elem.addClass('is-closing').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($elem), function () {\n        $elem.removeClass('is-active is-closing');\n        $elem.blur().addClass('invisible');\n      });\n      /**\n       * Fires when the submenu has closed.\n       * @event Drilldown#hide\n       */\n\n      $elem.trigger('hide.zf.drilldown', [$elem]);\n    }\n    /**\n     * Iterates through the nested menus to calculate the min-height, and max-width for the menu.\n     * Prevents content jumping.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_getMaxDims\",\n    value: function _getMaxDims() {\n      var maxHeight = 0,\n          result = {},\n          _this = this; // Recalculate menu heights and total max height\n\n\n      this.$submenus.add(this.$element).each(function () {\n        var numOfElems = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('li').length;\n        var height = _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__[\"Box\"].GetDimensions(this).height;\n        maxHeight = height > maxHeight ? height : maxHeight;\n\n        if (_this.options.autoHeight) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight', height);\n        }\n      });\n      if (this.options.autoHeight) result['height'] = this.$currentMenu.data('calcHeight');else result['min-height'] = \"\".concat(maxHeight, \"px\");\n      result['max-width'] = \"\".concat(this.$element[0].getBoundingClientRect().width, \"px\");\n      return result;\n    }\n    /**\n     * Destroys the Drilldown Menu\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      if (this.options.scrollTop) this.$element.off('.zf.drilldown', this._bindHandler);\n\n      this._hideAll();\n\n      this.$element.off('mutateme.zf.trigger');\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__[\"Nest\"].Burn(this.$element, 'drilldown');\n      this.$element.unwrap().find('.js-drilldown-back, .is-submenu-parent-item').remove().end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu').end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');\n      this.$submenuAnchors.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off('.zf.drilldown');\n      });\n      this.$element.find('[data-is-parent-link]').detach();\n      this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');\n      this.$element.find('a').each(function () {\n        var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n        $link.removeAttr('tabindex');\n\n        if ($link.data('savedHref')) {\n          $link.attr('href', $link.data('savedHref')).removeData('savedHref');\n        } else {\n          return;\n        }\n      });\n    }\n  }]);\n\n  return Drilldown;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__[\"Plugin\"]);\n\nDrilldown.defaults = {\n  /**\n   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are\n   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.\n   * @option\n   * @type {boolian}\n   * @default true\n   */\n  autoApplyClass: true,\n\n  /**\n   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>'\n   */\n  backButton: '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>',\n\n  /**\n   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default top\n   */\n  backButtonPosition: 'top',\n\n  /**\n   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<div></div>'\n   */\n  wrapper: '<div></div>',\n\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n\n  /**\n   * Allow the menu to return to root list on body click.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false,\n\n  /**\n   * Allow the menu to auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoHeight: false,\n\n  /**\n   * Animate the auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animateHeight: false,\n\n  /**\n   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  scrollTop: false,\n\n  /**\n   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  scrollTopElement: '',\n\n  /**\n   * ScrollTop offset\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  scrollTopOffset: 0,\n\n  /**\n   * Scroll animation duration\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n\n  /**\n   * Scroll animation easing. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @see {@link https://api.jquery.com/animate|JQuery animate}\n   * @default 'swing'\n   */\n  animationEasing: 'swing' // holdOpen: false\n\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.dropdown.js\":\n/*!***********************************!*\\\n  !*** ./js/foundation.dropdown.js ***!\n  \\***********************************/\n/*! exports provided: Dropdown */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Dropdown\", function() { return Dropdown; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_positionable__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.positionable */ \"./js/foundation.positionable.js\");\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.touch */ \"./js/foundation.util.touch.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _get(target, property, receiver) { if (typeof Reflect !== \"undefined\" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); }\n\nfunction _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n/**\n * Dropdown module.\n * @module foundation.dropdown\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.triggers\n */\n\nvar Dropdown =\n/*#__PURE__*/\nfunction (_Positionable) {\n  _inherits(Dropdown, _Positionable);\n\n  function Dropdown() {\n    _classCallCheck(this, Dropdown);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Dropdown).apply(this, arguments));\n  }\n\n  _createClass(Dropdown, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a dropdown.\n     * @class\n     * @name Dropdown\n     * @param {jQuery} element - jQuery object to make into a dropdown.\n     *        Object should be of the dropdown panel, rather than its anchor.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Dropdown.defaults, this.$element.data(), options);\n      this.className = 'Dropdown'; // ie9 back compat\n      // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('Dropdown', {\n        'ENTER': 'toggle',\n        'SPACE': 'toggle',\n        'ESCAPE': 'close'\n      });\n    }\n    /**\n     * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var $id = this.$element.attr('id');\n      this.$anchors = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-toggle=\\\"\".concat($id, \"\\\"]\")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-toggle=\\\"\".concat($id, \"\\\"]\")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open=\\\"\".concat($id, \"\\\"]\"));\n      this.$anchors.attr({\n        'aria-controls': $id,\n        'data-is-focus': false,\n        'data-yeti-box': $id,\n        'aria-haspopup': true,\n        'aria-expanded': false\n      });\n\n      this._setCurrentAnchor(this.$anchors.first());\n\n      if (this.options.parentClass) {\n        this.$parent = this.$element.parents('.' + this.options.parentClass);\n      } else {\n        this.$parent = null;\n      } // Set [aria-labelledby] on the Dropdown if it is not set\n\n\n      if (typeof this.$element.attr('aria-labelledby') === 'undefined') {\n        // Get the anchor ID or create one\n        if (typeof this.$currentAnchor.attr('id') === 'undefined') {\n          this.$currentAnchor.attr('id', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'dd-anchor'));\n        }\n\n        ;\n        this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));\n      }\n\n      this.$element.attr({\n        'aria-hidden': 'true',\n        'data-yeti-box': $id,\n        'data-resize': $id\n      });\n\n      _get(_getPrototypeOf(Dropdown.prototype), \"_init\", this).call(this);\n\n      this._events();\n    }\n  }, {\n    key: \"_getDefaultPosition\",\n    value: function _getDefaultPosition() {\n      // handle legacy classnames\n      var position = this.$element[0].className.match(/(top|left|right|bottom)/g);\n\n      if (position) {\n        return position[0];\n      } else {\n        return 'bottom';\n      }\n    }\n  }, {\n    key: \"_getDefaultAlignment\",\n    value: function _getDefaultAlignment() {\n      // handle legacy float approach\n      var horizontalPosition = /float-(\\S+)/.exec(this.$currentAnchor.attr('class'));\n\n      if (horizontalPosition) {\n        return horizontalPosition[1];\n      }\n\n      return _get(_getPrototypeOf(Dropdown.prototype), \"_getDefaultAlignment\", this).call(this);\n    }\n    /**\n     * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.\n     * Recursively calls itself if a collision is detected, with a new position class.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_setPosition\",\n    value: function _setPosition() {\n      this.$element.removeClass(\"has-position-\".concat(this.position, \" has-alignment-\").concat(this.alignment));\n\n      _get(_getPrototypeOf(Dropdown.prototype), \"_setPosition\", this).call(this, this.$currentAnchor, this.$element, this.$parent);\n\n      this.$element.addClass(\"has-position-\".concat(this.position, \" has-alignment-\").concat(this.alignment));\n    }\n    /**\n     * Make it a current anchor.\n     * Current anchor as the reference for the position of Dropdown panes.\n     * @param {HTML} el - DOM element of the anchor.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_setCurrentAnchor\",\n    value: function _setCurrentAnchor(el) {\n      this.$currentAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el);\n    }\n    /**\n     * Adds event listeners to the element utilizing the triggers utility library.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this.$element.on({\n        'open.zf.trigger': this.open.bind(this),\n        'close.zf.trigger': this.close.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this),\n        'resizeme.zf.trigger': this._setPosition.bind(this)\n      });\n      this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function () {\n        _this._setCurrentAnchor(this);\n      });\n\n      if (this.options.hover) {\n        this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {\n          _this._setCurrentAnchor(this);\n\n          var bodyData = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').data();\n\n          if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') {\n            clearTimeout(_this.timeout);\n            _this.timeout = setTimeout(function () {\n              _this.open();\n\n              _this.$anchors.data('hover', true);\n            }, _this.options.hoverDelay);\n          }\n        }).on('mouseleave.zf.dropdown', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"ignoreMousedisappear\"])(function () {\n          clearTimeout(_this.timeout);\n          _this.timeout = setTimeout(function () {\n            _this.close();\n\n            _this.$anchors.data('hover', false);\n          }, _this.options.hoverDelay);\n        }));\n\n        if (this.options.hoverPane) {\n          this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {\n            clearTimeout(_this.timeout);\n          }).on('mouseleave.zf.dropdown', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"ignoreMousedisappear\"])(function () {\n            clearTimeout(_this.timeout);\n            _this.timeout = setTimeout(function () {\n              _this.close();\n\n              _this.$anchors.data('hover', false);\n            }, _this.options.hoverDelay);\n          }));\n        }\n      }\n\n      this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) {\n        var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            visibleFocusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].findFocusable(_this.$element);\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'Dropdown', {\n          open: function open() {\n            if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {\n              _this.open();\n\n              _this.$element.attr('tabindex', -1).focus();\n\n              e.preventDefault();\n            }\n          },\n          close: function close() {\n            _this.close();\n\n            _this.$anchors.focus();\n          }\n        });\n      });\n    }\n    /**\n     * Adds an event handler to the body to close any dropdowns on a click.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_addBodyHandler\",\n    value: function _addBodyHandler() {\n      var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).not(this.$element),\n          _this = this;\n\n      $body.off('click.zf.dropdown').on('click.zf.dropdown', function (e) {\n        if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {\n          return;\n        }\n\n        if (_this.$element.is(e.target) || _this.$element.find(e.target).length) {\n          return;\n        }\n\n        _this.close();\n\n        $body.off('click.zf.dropdown');\n      });\n    }\n    /**\n     * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.\n     * @function\n     * @fires Dropdown#closeme\n     * @fires Dropdown#show\n     */\n\n  }, {\n    key: \"open\",\n    value: function open() {\n      // var _this = this;\n\n      /**\n       * Fires to close other open dropdowns, typically when dropdown is opening\n       * @event Dropdown#closeme\n       */\n      this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));\n      this.$anchors.addClass('hover').attr({\n        'aria-expanded': true\n      }); // this.$element/*.show()*/;\n\n      this.$element.addClass('is-opening');\n\n      this._setPosition();\n\n      this.$element.removeClass('is-opening').addClass('is-open').attr({\n        'aria-hidden': false\n      });\n\n      if (this.options.autoFocus) {\n        var $focusable = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].findFocusable(this.$element);\n\n        if ($focusable.length) {\n          $focusable.eq(0).focus();\n        }\n      }\n\n      if (this.options.closeOnClick) {\n        this._addBodyHandler();\n      }\n\n      if (this.options.trapFocus) {\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].trapFocus(this.$element);\n      }\n      /**\n       * Fires once the dropdown is visible.\n       * @event Dropdown#show\n       */\n\n\n      this.$element.trigger('show.zf.dropdown', [this.$element]);\n    }\n    /**\n     * Closes the open dropdown pane.\n     * @function\n     * @fires Dropdown#hide\n     */\n\n  }, {\n    key: \"close\",\n    value: function close() {\n      if (!this.$element.hasClass('is-open')) {\n        return false;\n      }\n\n      this.$element.removeClass('is-open').attr({\n        'aria-hidden': true\n      });\n      this.$anchors.removeClass('hover').attr('aria-expanded', false);\n      /**\n       * Fires once the dropdown is no longer visible.\n       * @event Dropdown#hide\n       */\n\n      this.$element.trigger('hide.zf.dropdown', [this.$element]);\n\n      if (this.options.trapFocus) {\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].releaseFocus(this.$element);\n      }\n    }\n    /**\n     * Toggles the dropdown pane's visibility.\n     * @function\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle() {\n      if (this.$element.hasClass('is-open')) {\n        if (this.$anchors.data('hover')) return;\n        this.close();\n      } else {\n        this.open();\n      }\n    }\n    /**\n     * Destroys the dropdown.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.trigger').hide();\n      this.$anchors.off('.zf.dropdown');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('click.zf.dropdown');\n    }\n  }]);\n\n  return Dropdown;\n}(_foundation_positionable__WEBPACK_IMPORTED_MODULE_3__[\"Positionable\"]);\n\nDropdown.defaults = {\n  /**\n   * Class that designates bounding container of Dropdown (default: window)\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  parentClass: null,\n\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  hoverDelay: 250,\n\n  /**\n   * Allow submenus to open on hover events\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hover: false,\n\n  /**\n   * Don't close dropdown when hovering over dropdown pane\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hoverPane: false,\n\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n\n  /**\n   * Position of dropdown. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n\n  /**\n   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n\n  /**\n   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false,\n\n  /**\n   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows a click on the body to close the dropdown.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.dropdownMenu.js\":\n/*!***************************************!*\\\n  !*** ./js/foundation.dropdownMenu.js ***!\n  \\***************************************/\n/*! exports provided: DropdownMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"DropdownMenu\", function() { return DropdownMenu; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.nest */ \"./js/foundation.util.nest.js\");\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.box */ \"./js/foundation.util.box.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n/**\n * DropdownMenu module.\n * @module foundation.dropdown-menu\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.nest\n */\n\nvar DropdownMenu =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(DropdownMenu, _Plugin);\n\n  function DropdownMenu() {\n    _classCallCheck(this, DropdownMenu);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(DropdownMenu).apply(this, arguments));\n  }\n\n  _createClass(DropdownMenu, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of DropdownMenu.\n     * @class\n     * @name DropdownMenu\n     * @fires DropdownMenu#init\n     * @param {jQuery} element - jQuery object to make into a dropdown menu.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n      this.className = 'DropdownMenu'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_3__[\"Keyboard\"].register('DropdownMenu', {\n        'ENTER': 'open',\n        'SPACE': 'open',\n        'ARROW_RIGHT': 'next',\n        'ARROW_UP': 'up',\n        'ARROW_DOWN': 'down',\n        'ARROW_LEFT': 'previous',\n        'ESCAPE': 'close'\n      });\n    }\n    /**\n     * Initializes the plugin, and calls _prepareMenu\n     * @private\n     * @function\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_4__[\"Nest\"].Feather(this.$element, 'dropdown');\n      var subs = this.$element.find('li.is-dropdown-submenu-parent');\n      this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');\n      this.$menuItems = this.$element.find('[role=\"menuitem\"]');\n      this.$tabs = this.$element.children('[role=\"menuitem\"]');\n      this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);\n\n      if (this.options.alignment === 'auto') {\n        if (this.$element.hasClass(this.options.rightClass) || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"rtl\"])() || this.$element.parents('.top-bar-right').is('*')) {\n          this.options.alignment = 'right';\n          subs.addClass('opens-left');\n        } else {\n          this.options.alignment = 'left';\n          subs.addClass('opens-right');\n        }\n      } else {\n        if (this.options.alignment === 'right') {\n          subs.addClass('opens-left');\n        } else {\n          subs.addClass('opens-right');\n        }\n      }\n\n      this.changed = false;\n\n      this._events();\n    }\n  }, {\n    key: \"_isVertical\",\n    value: function _isVertical() {\n      return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';\n    }\n  }, {\n    key: \"_isRtl\",\n    value: function _isRtl() {\n      return this.$element.hasClass('align-right') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"rtl\"])() && !this.$element.hasClass('align-left');\n    }\n    /**\n     * Adds event listeners to elements within the menu\n     * @private\n     * @function\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this,\n          hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined',\n          parClass = 'is-dropdown-submenu-parent'; // used for onClick and in the keyboard handlers\n\n\n      var handleClickFn = function handleClickFn(e) {\n        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', \".\".concat(parClass)),\n            hasSub = $elem.hasClass(parClass),\n            hasClicked = $elem.attr('data-is-click') === 'true',\n            $sub = $elem.children('.is-dropdown-submenu');\n\n        if (hasSub) {\n          if (hasClicked) {\n            if (!_this.options.closeOnClick || !_this.options.clickOpen && !hasTouch || _this.options.forceFollow && hasTouch) {\n              return;\n            } else {\n              e.stopImmediatePropagation();\n              e.preventDefault();\n\n              _this._hide($elem);\n            }\n          } else {\n            e.preventDefault();\n            e.stopImmediatePropagation();\n\n            _this._show($sub);\n\n            $elem.add($elem.parentsUntil(_this.$element, \".\".concat(parClass))).attr('data-is-click', true);\n          }\n        }\n      };\n\n      if (this.options.clickOpen || hasTouch) {\n        this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);\n      } // Handle Leaf element Clicks\n\n\n      if (_this.options.closeOnClickInside) {\n        this.$menuItems.on('click.zf.dropdownmenu', function (e) {\n          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n              hasSub = $elem.hasClass(parClass);\n\n          if (!hasSub) {\n            _this._hide();\n          }\n        });\n      }\n\n      if (!this.options.disableHover) {\n        this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {\n          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n              hasSub = $elem.hasClass(parClass);\n\n          if (hasSub) {\n            clearTimeout($elem.data('_delay'));\n            $elem.data('_delay', setTimeout(function () {\n              _this._show($elem.children('.is-dropdown-submenu'));\n            }, _this.options.hoverDelay));\n          }\n        }).on('mouseleave.zf.dropdownMenu', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"ignoreMousedisappear\"])(function (e) {\n          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n              hasSub = $elem.hasClass(parClass);\n\n          if (hasSub && _this.options.autoclose) {\n            if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) {\n              return false;\n            }\n\n            clearTimeout($elem.data('_delay'));\n            $elem.data('_delay', setTimeout(function () {\n              _this._hide($elem);\n            }, _this.options.closingTime));\n          }\n        }));\n      }\n\n      this.$menuItems.on('keydown.zf.dropdownmenu', function (e) {\n        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', '[role=\"menuitem\"]'),\n            isTab = _this.$tabs.index($element) > -1,\n            $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),\n            $prevElement,\n            $nextElement;\n        $elements.each(function (i) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {\n            $prevElement = $elements.eq(i - 1);\n            $nextElement = $elements.eq(i + 1);\n            return;\n          }\n        });\n\n        var nextSibling = function nextSibling() {\n          $nextElement.children('a:first').focus();\n          e.preventDefault();\n        },\n            prevSibling = function prevSibling() {\n          $prevElement.children('a:first').focus();\n          e.preventDefault();\n        },\n            openSub = function openSub() {\n          var $sub = $element.children('ul.is-dropdown-submenu');\n\n          if ($sub.length) {\n            _this._show($sub);\n\n            $element.find('li > a:first').focus();\n            e.preventDefault();\n          } else {\n            return;\n          }\n        },\n            closeSub = function closeSub() {\n          //if ($element.is(':first-child')) {\n          var close = $element.parent('ul').parent('li');\n          close.children('a:first').focus();\n\n          _this._hide(close);\n\n          e.preventDefault(); //}\n        };\n\n        var functions = {\n          open: openSub,\n          close: function close() {\n            _this._hide(_this.$element);\n\n            _this.$menuItems.eq(0).children('a').focus(); // focus to first element\n\n\n            e.preventDefault();\n          },\n          handled: function handled() {\n            e.stopImmediatePropagation();\n          }\n        };\n\n        if (isTab) {\n          if (_this._isVertical()) {\n            // vertical menu\n            if (_this._isRtl()) {\n              // right aligned\n              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n                down: nextSibling,\n                up: prevSibling,\n                next: closeSub,\n                previous: openSub\n              });\n            } else {\n              // left aligned\n              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n                down: nextSibling,\n                up: prevSibling,\n                next: openSub,\n                previous: closeSub\n              });\n            }\n          } else {\n            // horizontal menu\n            if (_this._isRtl()) {\n              // right aligned\n              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n                next: prevSibling,\n                previous: nextSibling,\n                down: openSub,\n                up: closeSub\n              });\n            } else {\n              // left aligned\n              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n                next: nextSibling,\n                previous: prevSibling,\n                down: openSub,\n                up: closeSub\n              });\n            }\n          }\n        } else {\n          // not tabs -> one sub\n          if (_this._isRtl()) {\n            // right aligned\n            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n              next: closeSub,\n              previous: openSub,\n              down: nextSibling,\n              up: prevSibling\n            });\n          } else {\n            // left aligned\n            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n              next: openSub,\n              previous: closeSub,\n              down: nextSibling,\n              up: prevSibling\n            });\n          }\n        }\n\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_3__[\"Keyboard\"].handleKey(e, 'DropdownMenu', functions);\n      });\n    }\n    /**\n     * Adds an event handler to the body to close any dropdowns on a click.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_addBodyHandler\",\n    value: function _addBodyHandler() {\n      var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body),\n          _this = this;\n\n      $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu').on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function (e) {\n        var $link = _this.$element.find(e.target);\n\n        if ($link.length) {\n          return;\n        }\n\n        _this._hide();\n\n        $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');\n      });\n    }\n    /**\n     * Opens a dropdown pane, and checks for collisions first.\n     * @param {jQuery} $sub - ul element that is a submenu to show\n     * @function\n     * @private\n     * @fires Dropdownmenu#show\n     */\n\n  }, {\n    key: \"_show\",\n    value: function _show($sub) {\n      var idx = this.$tabs.index(this.$tabs.filter(function (i, el) {\n        return jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).find($sub).length > 0;\n      }));\n      var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');\n\n      this._hide($sibs, idx);\n\n      $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active');\n      var clear = _foundation_util_box__WEBPACK_IMPORTED_MODULE_5__[\"Box\"].ImNotTouchingYou($sub, null, true);\n\n      if (!clear) {\n        var oldClass = this.options.alignment === 'left' ? '-right' : '-left',\n            $parentLi = $sub.parent('.is-dropdown-submenu-parent');\n        $parentLi.removeClass(\"opens\".concat(oldClass)).addClass(\"opens-\".concat(this.options.alignment));\n        clear = _foundation_util_box__WEBPACK_IMPORTED_MODULE_5__[\"Box\"].ImNotTouchingYou($sub, null, true);\n\n        if (!clear) {\n          $parentLi.removeClass(\"opens-\".concat(this.options.alignment)).addClass('opens-inner');\n        }\n\n        this.changed = true;\n      }\n\n      $sub.css('visibility', '');\n\n      if (this.options.closeOnClick) {\n        this._addBodyHandler();\n      }\n      /**\n       * Fires when the new dropdown pane is visible.\n       * @event Dropdownmenu#show\n       */\n\n\n      this.$element.trigger('show.zf.dropdownmenu', [$sub]);\n    }\n    /**\n     * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.\n     * @function\n     * @param {jQuery} $elem - element with a submenu to hide\n     * @param {Number} idx - index of the $tabs collection to hide\n     * @private\n     */\n\n  }, {\n    key: \"_hide\",\n    value: function _hide($elem, idx) {\n      var $toClose;\n\n      if ($elem && $elem.length) {\n        $toClose = $elem;\n      } else if (typeof idx !== 'undefined') {\n        $toClose = this.$tabs.not(function (i, el) {\n          return i === idx;\n        });\n      } else {\n        $toClose = this.$element;\n      }\n\n      var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;\n\n      if (somethingToClose) {\n        $toClose.find('li.is-active').add($toClose).attr({\n          'data-is-click': false\n        }).removeClass('is-active');\n        $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');\n\n        if (this.changed || $toClose.find('opens-inner').length) {\n          var oldClass = this.options.alignment === 'left' ? 'right' : 'left';\n          $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass(\"opens-inner opens-\".concat(this.options.alignment)).addClass(\"opens-\".concat(oldClass));\n          this.changed = false;\n        }\n        /**\n         * Fires when the open menus are closed.\n         * @event Dropdownmenu#hide\n         */\n\n\n        this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);\n      }\n    }\n    /**\n     * Destroys the plugin.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click').removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('.zf.dropdownmenu');\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_4__[\"Nest\"].Burn(this.$element, 'dropdown');\n    }\n  }]);\n\n  return DropdownMenu;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nDropdownMenu.defaults = {\n  /**\n   * Disallows hover events from opening submenus\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n\n  /**\n   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoclose: true,\n\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  hoverDelay: 50,\n\n  /**\n   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  clickOpen: false,\n\n  /**\n   * Amount of time to delay closing a submenu on a mouseleave event.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  closingTime: 500,\n\n  /**\n   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow clicks on the body to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Allow clicks on leaf anchor links to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClickInside: true,\n\n  /**\n   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'vertical'\n   */\n  verticalClass: 'vertical',\n\n  /**\n   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'align-right'\n   */\n  rightClass: 'align-right',\n\n  /**\n   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  forceFollow: true\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.equalizer.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.equalizer.js ***!\n  \\************************************/\n/*! exports provided: Equalizer */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Equalizer\", function() { return Equalizer; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.imageLoader */ \"./js/foundation.util.imageLoader.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.imageLoader if equalizer contains images\n */\n\nvar Equalizer =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Equalizer, _Plugin);\n\n  function Equalizer() {\n    _classCallCheck(this, Equalizer);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Equalizer).apply(this, arguments));\n  }\n\n  _createClass(Equalizer, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Equalizer.\n     * @class\n     * @name Equalizer\n     * @fires Equalizer#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Equalizer.defaults, this.$element.data(), options);\n      this.className = 'Equalizer'; // ie9 back compat\n\n      this._init();\n    }\n    /**\n     * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var eqId = this.$element.attr('data-equalizer') || '';\n      var $watched = this.$element.find(\"[data-equalizer-watch=\\\"\".concat(eqId, \"\\\"]\"));\n\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init();\n\n      this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n      this.$element.attr('data-resize', eqId || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'eq'));\n      this.$element.attr('data-mutate', eqId || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'eq'));\n      this.hasNested = this.$element.find('[data-equalizer]').length > 0;\n      this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;\n      this.isOn = false;\n      this._bindHandler = {\n        onResizeMeBound: this._onResizeMe.bind(this),\n        onPostEqualizedBound: this._onPostEqualized.bind(this)\n      };\n      var imgs = this.$element.find('img');\n      var tooSmall;\n\n      if (this.options.equalizeOn) {\n        tooSmall = this._checkMQ();\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));\n      } else {\n        this._events();\n      }\n\n      if (typeof tooSmall !== 'undefined' && tooSmall === false || typeof tooSmall === 'undefined') {\n        if (imgs.length) {\n          Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__[\"onImagesLoaded\"])(imgs, this._reflow.bind(this));\n        } else {\n          this._reflow();\n        }\n      }\n    }\n    /**\n     * Removes event listeners if the breakpoint is too small.\n     * @private\n     */\n\n  }, {\n    key: \"_pauseEvents\",\n    value: function _pauseEvents() {\n      this.isOn = false;\n      this.$element.off({\n        '.zf.equalizer': this._bindHandler.onPostEqualizedBound,\n        'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,\n        'mutateme.zf.trigger': this._bindHandler.onResizeMeBound\n      });\n    }\n    /**\n     * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound\n     * @private\n     */\n\n  }, {\n    key: \"_onResizeMe\",\n    value: function _onResizeMe(e) {\n      this._reflow();\n    }\n    /**\n     * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound\n     * @private\n     */\n\n  }, {\n    key: \"_onPostEqualized\",\n    value: function _onPostEqualized(e) {\n      if (e.target !== this.$element[0]) {\n        this._reflow();\n      }\n    }\n    /**\n     * Initializes events for Equalizer.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this._pauseEvents();\n\n      if (this.hasNested) {\n        this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);\n      } else {\n        this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);\n        this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);\n      }\n\n      this.isOn = true;\n    }\n    /**\n     * Checks the current breakpoint to the minimum required size.\n     * @private\n     */\n\n  }, {\n    key: \"_checkMQ\",\n    value: function _checkMQ() {\n      var tooSmall = !_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].is(this.options.equalizeOn);\n\n      if (tooSmall) {\n        if (this.isOn) {\n          this._pauseEvents();\n\n          this.$watched.css('height', 'auto');\n        }\n      } else {\n        if (!this.isOn) {\n          this._events();\n        }\n      }\n\n      return tooSmall;\n    }\n    /**\n     * A noop version for the plugin\n     * @private\n     */\n\n  }, {\n    key: \"_killswitch\",\n    value: function _killswitch() {\n      return;\n    }\n    /**\n     * Calls necessary functions to update Equalizer upon DOM change\n     * @private\n     */\n\n  }, {\n    key: \"_reflow\",\n    value: function _reflow() {\n      if (!this.options.equalizeOnStack) {\n        if (this._isStacked()) {\n          this.$watched.css('height', 'auto');\n          return false;\n        }\n      }\n\n      if (this.options.equalizeByRow) {\n        this.getHeightsByRow(this.applyHeightByRow.bind(this));\n      } else {\n        this.getHeights(this.applyHeight.bind(this));\n      }\n    }\n    /**\n     * Manually determines if the first 2 elements are *NOT* stacked.\n     * @private\n     */\n\n  }, {\n    key: \"_isStacked\",\n    value: function _isStacked() {\n      if (!this.$watched[0] || !this.$watched[1]) {\n        return true;\n      }\n\n      return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;\n    }\n    /**\n     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n     * @param {Function} cb - A non-optional callback to return the heights array to.\n     * @returns {Array} heights - An array of heights of children within Equalizer container\n     */\n\n  }, {\n    key: \"getHeights\",\n    value: function getHeights(cb) {\n      var heights = [];\n\n      for (var i = 0, len = this.$watched.length; i < len; i++) {\n        this.$watched[i].style.height = 'auto';\n        heights.push(this.$watched[i].offsetHeight);\n      }\n\n      cb(heights);\n    }\n    /**\n     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n     * @param {Function} cb - A non-optional callback to return the heights array to.\n     * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n     */\n\n  }, {\n    key: \"getHeightsByRow\",\n    value: function getHeightsByRow(cb) {\n      var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0,\n          groups = [],\n          group = 0; //group by Row\n\n      groups[group] = [];\n\n      for (var i = 0, len = this.$watched.length; i < len; i++) {\n        this.$watched[i].style.height = 'auto'; //maybe could use this.$watched[i].offsetTop\n\n        var elOffsetTop = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$watched[i]).offset().top;\n\n        if (elOffsetTop != lastElTopOffset) {\n          group++;\n          groups[group] = [];\n          lastElTopOffset = elOffsetTop;\n        }\n\n        groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]);\n      }\n\n      for (var j = 0, ln = groups.length; j < ln; j++) {\n        var heights = jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[j]).map(function () {\n          return this[1];\n        }).get();\n        var max = Math.max.apply(null, heights);\n        groups[j].push(max);\n      }\n\n      cb(groups);\n    }\n    /**\n     * Changes the CSS height property of each child in an Equalizer parent to match the tallest\n     * @param {array} heights - An array of heights of children within Equalizer container\n     * @fires Equalizer#preequalized\n     * @fires Equalizer#postequalized\n     */\n\n  }, {\n    key: \"applyHeight\",\n    value: function applyHeight(heights) {\n      var max = Math.max.apply(null, heights);\n      /**\n       * Fires before the heights are applied\n       * @event Equalizer#preequalized\n       */\n\n      this.$element.trigger('preequalized.zf.equalizer');\n      this.$watched.css('height', max);\n      /**\n       * Fires when the heights have been applied\n       * @event Equalizer#postequalized\n       */\n\n      this.$element.trigger('postequalized.zf.equalizer');\n    }\n    /**\n     * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row\n     * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n     * @fires Equalizer#preequalized\n     * @fires Equalizer#preequalizedrow\n     * @fires Equalizer#postequalizedrow\n     * @fires Equalizer#postequalized\n     */\n\n  }, {\n    key: \"applyHeightByRow\",\n    value: function applyHeightByRow(groups) {\n      /**\n       * Fires before the heights are applied\n       */\n      this.$element.trigger('preequalized.zf.equalizer');\n\n      for (var i = 0, len = groups.length; i < len; i++) {\n        var groupsILength = groups[i].length,\n            max = groups[i][groupsILength - 1];\n\n        if (groupsILength <= 2) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][0][0]).css({\n            'height': 'auto'\n          });\n          continue;\n        }\n        /**\n          * Fires before the heights per row are applied\n          * @event Equalizer#preequalizedrow\n          */\n\n\n        this.$element.trigger('preequalizedrow.zf.equalizer');\n\n        for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][j][0]).css({\n            'height': max\n          });\n        }\n        /**\n          * Fires when the heights per row have been applied\n          * @event Equalizer#postequalizedrow\n          */\n\n\n        this.$element.trigger('postequalizedrow.zf.equalizer');\n      }\n      /**\n       * Fires when the heights have been applied\n       */\n\n\n      this.$element.trigger('postequalized.zf.equalizer');\n    }\n    /**\n     * Destroys an instance of Equalizer.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this._pauseEvents();\n\n      this.$watched.css('height', 'auto');\n    }\n  }]);\n\n  return Equalizer;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nEqualizer.defaults = {\n  /**\n   * Enable height equalization when stacked on smaller screens.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeOnStack: false,\n\n  /**\n   * Enable height equalization row by row.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeByRow: false,\n\n  /**\n   * String representing the minimum breakpoint size the plugin should equalize heights on.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  equalizeOn: ''\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.interchange.js\":\n/*!**************************************!*\\\n  !*** ./js/foundation.interchange.js ***!\n  \\**************************************/\n/*! exports provided: Interchange */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Interchange\", function() { return Interchange; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n */\n\nvar Interchange =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Interchange, _Plugin);\n\n  function Interchange() {\n    _classCallCheck(this, Interchange);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Interchange).apply(this, arguments));\n  }\n\n  _createClass(Interchange, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Interchange.\n     * @class\n     * @name Interchange\n     * @fires Interchange#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Interchange.defaults, options);\n      this.rules = [];\n      this.currentPath = '';\n      this.className = 'Interchange'; // ie9 back compat\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the Interchange plugin and calls functions to get interchange functioning on load.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init();\n\n      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'interchange');\n      this.$element.attr({\n        'data-resize': id,\n        'id': id\n      });\n\n      this._addBreakpoints();\n\n      this._generateRules();\n\n      this._reflow();\n    }\n    /**\n     * Initializes events for Interchange.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this2 = this;\n\n      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () {\n        return _this2._reflow();\n      });\n    }\n    /**\n     * Calls necessary functions to update Interchange upon DOM change\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_reflow\",\n    value: function _reflow() {\n      var match; // Iterate through each rule, but only save the last match\n\n      for (var i in this.rules) {\n        if (this.rules.hasOwnProperty(i)) {\n          var rule = this.rules[i];\n\n          if (window.matchMedia(rule.query).matches) {\n            match = rule;\n          }\n        }\n      }\n\n      if (match) {\n        this.replace(match.path);\n      }\n    }\n    /**\n     * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_addBreakpoints\",\n    value: function _addBreakpoints() {\n      for (var i in _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].queries) {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].queries.hasOwnProperty(i)) {\n          var query = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].queries[i];\n          Interchange.SPECIAL_QUERIES[query.name] = query.value;\n        }\n      }\n    }\n    /**\n     * Checks the Interchange element for the provided media query + content pairings\n     * @function\n     * @private\n     * @param {Object} element - jQuery object that is an Interchange instance\n     * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys\n     */\n\n  }, {\n    key: \"_generateRules\",\n    value: function _generateRules(element) {\n      var rulesList = [];\n      var rules;\n\n      if (this.options.rules) {\n        rules = this.options.rules;\n      } else {\n        rules = this.$element.data('interchange');\n      }\n\n      rules = typeof rules === 'string' ? rules.match(/\\[.*?, .*?\\]/g) : rules;\n\n      for (var i in rules) {\n        if (rules.hasOwnProperty(i)) {\n          var rule = rules[i].slice(1, -1).split(', ');\n          var path = rule.slice(0, -1).join('');\n          var query = rule[rule.length - 1];\n\n          if (Interchange.SPECIAL_QUERIES[query]) {\n            query = Interchange.SPECIAL_QUERIES[query];\n          }\n\n          rulesList.push({\n            path: path,\n            query: query\n          });\n        }\n      }\n\n      this.rules = rulesList;\n    }\n    /**\n     * Update the `src` property of an image, or change the HTML of a container, to the specified path.\n     * @function\n     * @param {String} path - Path to the image or HTML partial.\n     * @fires Interchange#replaced\n     */\n\n  }, {\n    key: \"replace\",\n    value: function replace(path) {\n      if (this.currentPath === path) return;\n\n      var _this = this,\n          trigger = 'replaced.zf.interchange'; // Replacing images\n\n\n      if (this.$element[0].nodeName === 'IMG') {\n        this.$element.attr('src', path).on('load', function () {\n          _this.currentPath = path;\n        }).trigger(trigger);\n      } // Replacing background images\n      else if (path.match(/\\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {\n          path = path.replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n          this.$element.css({\n            'background-image': 'url(' + path + ')'\n          }).trigger(trigger);\n        } // Replacing HTML\n        else {\n            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.get(path, function (response) {\n              _this.$element.html(response).trigger(trigger);\n\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()(response).foundation();\n              _this.currentPath = path;\n            });\n          }\n      /**\n       * Fires when content in an Interchange element is done being loaded.\n       * @event Interchange#replaced\n       */\n      // this.$element.trigger('replaced.zf.interchange');\n\n    }\n    /**\n     * Destroys an instance of interchange.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('resizeme.zf.trigger');\n    }\n  }]);\n\n  return Interchange;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nInterchange.defaults = {\n  /**\n   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.\n   * @option\n   * @type {?array}\n   * @default null\n   */\n  rules: null\n};\nInterchange.SPECIAL_QUERIES = {\n  'landscape': 'screen and (orientation: landscape)',\n  'portrait': 'screen and (orientation: portrait)',\n  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.magellan.js\":\n/*!***********************************!*\\\n  !*** ./js/foundation.magellan.js ***!\n  \\***********************************/\n/*! exports provided: Magellan */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Magellan\", function() { return Magellan; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.smoothScroll */ \"./js/foundation.smoothScroll.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n/**\n * Magellan module.\n * @module foundation.magellan\n * @requires foundation.smoothScroll\n */\n\nvar Magellan =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Magellan, _Plugin);\n\n  function Magellan() {\n    _classCallCheck(this, Magellan);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Magellan).apply(this, arguments));\n  }\n\n  _createClass(Magellan, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Magellan.\n     * @class\n     * @name Magellan\n     * @fires Magellan#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Magellan.defaults, this.$element.data(), options);\n      this.className = 'Magellan'; // ie9 back compat\n\n      this._init();\n\n      this.calcPoints();\n    }\n    /**\n     * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'magellan');\n\n      var _this = this;\n\n      this.$targets = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-magellan-target]');\n      this.$links = this.$element.find('a');\n      this.$element.attr({\n        'data-resize': id,\n        'data-scroll': id,\n        'id': id\n      });\n      this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      this.scrollPos = parseInt(window.pageYOffset, 10);\n\n      this._events();\n    }\n    /**\n     * Calculates an array of pixel values that are the demarcation lines between locations on the page.\n     * Can be invoked if new elements are added or the size of a location changes.\n     * @function\n     */\n\n  }, {\n    key: \"calcPoints\",\n    value: function calcPoints() {\n      var _this = this,\n          body = document.body,\n          html = document.documentElement;\n\n      this.points = [];\n      this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));\n      this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));\n      this.$targets.each(function () {\n        var $tar = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            pt = Math.round($tar.offset().top - _this.options.threshold);\n        $tar.targetPoint = pt;\n\n        _this.points.push(pt);\n      });\n    }\n    /**\n     * Initializes events for Magellan.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this,\n          $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body'),\n          opts = {\n        duration: _this.options.animationDuration,\n        easing: _this.options.animationEasing\n      };\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', function () {\n        if (_this.options.deepLinking) {\n          if (location.hash) {\n            _this.scrollToLoc(location.hash);\n          }\n        }\n\n        _this.calcPoints();\n\n        _this._updateActive();\n      });\n      _this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n        _this.$element.on({\n          'resizeme.zf.trigger': _this.reflow.bind(_this),\n          'scrollme.zf.trigger': _this._updateActive.bind(_this)\n        }).on('click.zf.magellan', 'a[href^=\"#\"]', function (e) {\n          e.preventDefault();\n          var arrival = this.getAttribute('href');\n\n          _this.scrollToLoc(arrival);\n        });\n      });\n\n      this._deepLinkScroll = function (e) {\n        if (_this.options.deepLinking) {\n          _this.scrollToLoc(window.location.hash);\n        }\n      };\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._deepLinkScroll);\n    }\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'\n     * @function\n     */\n\n  }, {\n    key: \"scrollToLoc\",\n    value: function scrollToLoc(loc) {\n      this._inTransition = true;\n\n      var _this = this;\n\n      var options = {\n        animationEasing: this.options.animationEasing,\n        animationDuration: this.options.animationDuration,\n        threshold: this.options.threshold,\n        offset: this.options.offset\n      };\n      _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_3__[\"SmoothScroll\"].scrollToLoc(loc, options, function () {\n        _this._inTransition = false;\n      });\n    }\n    /**\n     * Calls necessary functions to update Magellan upon DOM change\n     * @function\n     */\n\n  }, {\n    key: \"reflow\",\n    value: function reflow() {\n      this.calcPoints();\n\n      this._updateActive();\n    }\n    /**\n     * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.\n     * @private\n     * @function\n     * @fires Magellan#update\n     */\n\n  }, {\n    key: \"_updateActive\",\n    value: function _updateActive()\n    /*evt, elem, scrollPos*/\n    {\n      var _this2 = this;\n\n      if (this._inTransition) return;\n      var newScrollPos = parseInt(window.pageYOffset, 10);\n      var isScrollingUp = this.scrollPos > newScrollPos;\n      this.scrollPos = newScrollPos;\n      var activeIdx; // Before the first point: no link\n\n      if (newScrollPos < this.points[0]) {}\n      /* do nothing */\n      // At the bottom of the page: last link\n      else if (newScrollPos + this.winHeight === this.docHeight) {\n          activeIdx = this.points.length - 1;\n        } // Otherwhise, use the last visible link\n        else {\n            var visibleLinks = this.points.filter(function (p, i) {\n              return p - _this2.options.offset - (isScrollingUp ? _this2.options.threshold : 0) <= newScrollPos;\n            });\n            activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;\n          } // Get the new active link\n\n\n      var $oldActive = this.$active;\n      var activeHash = '';\n\n      if (typeof activeIdx !== 'undefined') {\n        this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(activeIdx).data('magellan-target') + '\"]');\n        if (this.$active.length) activeHash = this.$active[0].getAttribute('href');\n      } else {\n        this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      }\n\n      var isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);\n      var isNewHash = activeHash !== window.location.hash; // Update the active link element\n\n      if (isNewActive) {\n        $oldActive.removeClass(this.options.activeClass);\n        this.$active.addClass(this.options.activeClass);\n      } // Update the hash (it may have changed with the same active link)\n\n\n      if (this.options.deepLinking && isNewHash) {\n        if (window.history.pushState) {\n          // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384\n          var url = activeHash ? activeHash : window.location.pathname + window.location.search;\n          window.history.pushState(null, null, url);\n        } else {\n          window.location.hash = activeHash;\n        }\n      }\n\n      if (isNewActive) {\n        /**\n         * Fires when magellan is finished updating to the new active element.\n         * @event Magellan#update\n         */\n        this.$element.trigger('update.zf.magellan', [this.$active]);\n      }\n    }\n    /**\n     * Destroys an instance of Magellan and resets the url of the window.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.trigger .zf.magellan').find(\".\".concat(this.options.activeClass)).removeClass(this.options.activeClass);\n\n      if (this.options.deepLinking) {\n        var hash = this.$active[0].getAttribute('href');\n        window.location.hash.replace(hash, '');\n      }\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._deepLinkScroll);\n      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n    }\n  }]);\n\n  return Magellan;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nMagellan.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n\n  /**\n   * Class applied to the active locations link on the magellan container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  activeClass: 'is-active',\n\n  /**\n   * Allows the script to manipulate the url of the current page, and if supported, alter the history.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinking: false,\n\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.offcanvas.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.offcanvas.js ***!\n  \\************************************/\n/*! exports provided: OffCanvas */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"OffCanvas\", function() { return OffCanvas; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n/**\n * OffCanvas module.\n * @module foundation.offcanvas\n * @requires foundation.util.keyboard\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nvar OffCanvas =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(OffCanvas, _Plugin);\n\n  function OffCanvas() {\n    _classCallCheck(this, OffCanvas);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(OffCanvas).apply(this, arguments));\n  }\n\n  _createClass(OffCanvas, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of an off-canvas wrapper.\n     * @class\n     * @name OffCanvas\n     * @fires OffCanvas#init\n     * @param {Object} element - jQuery object to initialize.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      var _this2 = this;\n\n      this.className = 'OffCanvas'; // ie9 back compat\n\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, OffCanvas.defaults, this.$element.data(), options);\n      this.contentClasses = {\n        base: [],\n        reveal: []\n      };\n      this.$lastTrigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      this.position = 'left';\n      this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      this.nested = !!this.options.nested; // Defines the CSS transition/position classes of the off-canvas content container.\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(['push', 'overlap']).each(function (index, val) {\n        _this2.contentClasses.base.push('has-transition-' + val);\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(['left', 'right', 'top', 'bottom']).each(function (index, val) {\n        _this2.contentClasses.base.push('has-position-' + val);\n\n        _this2.contentClasses.reveal.push('has-reveal-' + val);\n      }); // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"]._init();\n\n      this._init();\n\n      this._events();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('OffCanvas', {\n        'ESCAPE': 'close'\n      });\n    }\n    /**\n     * Initializes the off-canvas wrapper by adding the exit overlay (if needed).\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var id = this.$element.attr('id');\n      this.$element.attr('aria-hidden', 'true'); // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)\n\n      if (this.options.contentId) {\n        this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + this.options.contentId);\n      } else if (this.$element.siblings('[data-off-canvas-content]').length) {\n        this.$content = this.$element.siblings('[data-off-canvas-content]').first();\n      } else {\n        this.$content = this.$element.closest('[data-off-canvas-content]').first();\n      }\n\n      if (!this.options.contentId) {\n        // Assume that the off-canvas element is nested if it isn't a sibling of the content\n        this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;\n      } else if (this.options.contentId && this.options.nested === null) {\n        // Warning if using content ID without setting the nested option\n        // Once the element is nested it is required to work properly in this case\n        console.warn('Remember to use the nested option if using the content ID option!');\n      }\n\n      if (this.nested === true) {\n        // Force transition overlap if nested\n        this.options.transition = 'overlap'; // Remove appropriate classes if already assigned in markup\n\n        this.$element.removeClass('is-transition-push');\n      }\n\n      this.$element.addClass(\"is-transition-\".concat(this.options.transition, \" is-closed\")); // Find triggers that affect this element and add aria-expanded to them\n\n      this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).find('[data-open=\"' + id + '\"], [data-close=\"' + id + '\"], [data-toggle=\"' + id + '\"]').attr('aria-expanded', 'false').attr('aria-controls', id); // Get position by checking for related CSS class\n\n      this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\\-(left|top|right|bottom)/)[1] : this.position; // Add an overlay over the content if necessary\n\n      if (this.options.contentOverlay === true) {\n        var overlay = document.createElement('div');\n        var overlayPosition = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$element).css(\"position\") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';\n        overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);\n        this.$overlay = jquery__WEBPACK_IMPORTED_MODULE_0___default()(overlay);\n\n        if (overlayPosition === 'is-overlay-fixed') {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$overlay).insertAfter(this.$element);\n        } else {\n          this.$content.append(this.$overlay);\n        }\n      } // Get the revealOn option from the class.\n\n\n      var revealOnRegExp = new RegExp(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"RegExpEscape\"])(this.options.revealClass) + '([^\\\\s]+)', 'g');\n      var revealOnClass = revealOnRegExp.exec(this.$element[0].className);\n\n      if (revealOnClass) {\n        this.options.isRevealed = true;\n        this.options.revealOn = this.options.revealOn || revealOnClass[1];\n      } // Ensure the `reveal-on-*` class is set.\n\n\n      if (this.options.isRevealed === true && this.options.revealOn) {\n        this.$element.first().addClass(\"\".concat(this.options.revealClass).concat(this.options.revealOn));\n\n        this._setMQChecker();\n      }\n\n      if (this.options.transitionTime) {\n        this.$element.css('transition-duration', this.options.transitionTime);\n      } // Initally remove all transition/position CSS classes from off-canvas content container.\n\n\n      this._removeContentClasses();\n    }\n    /**\n     * Adds event handlers to the off-canvas wrapper and the exit overlay.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this.$element.off('.zf.trigger .zf.offcanvas').on({\n        'open.zf.trigger': this.open.bind(this),\n        'close.zf.trigger': this.close.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this),\n        'keydown.zf.offcanvas': this._handleKeyboard.bind(this)\n      });\n\n      if (this.options.closeOnClick === true) {\n        var $target = this.options.contentOverlay ? this.$overlay : this.$content;\n        $target.on({\n          'click.zf.offcanvas': this.close.bind(this)\n        });\n      }\n    }\n    /**\n     * Applies event listener for elements that will reveal at certain breakpoints.\n     * @private\n     */\n\n  }, {\n    key: \"_setMQChecker\",\n    value: function _setMQChecker() {\n      var _this = this;\n\n      this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"].atLeast(_this.options.revealOn)) {\n          _this.reveal(true);\n        }\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"].atLeast(_this.options.revealOn)) {\n          _this.reveal(true);\n        } else {\n          _this.reveal(false);\n        }\n      });\n    }\n    /**\n     * Removes the CSS transition/position classes of the off-canvas content container.\n     * Removing the classes is important when another off-canvas gets opened that uses the same content container.\n     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n     * @private\n     */\n\n  }, {\n    key: \"_removeContentClasses\",\n    value: function _removeContentClasses(hasReveal) {\n      if (typeof hasReveal !== 'boolean') {\n        this.$content.removeClass(this.contentClasses.base.join(' '));\n      } else if (hasReveal === false) {\n        this.$content.removeClass(\"has-reveal-\".concat(this.position));\n      }\n    }\n    /**\n     * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.\n     * Beforehand any transition/position class gets removed.\n     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n     * @private\n     */\n\n  }, {\n    key: \"_addContentClasses\",\n    value: function _addContentClasses(hasReveal) {\n      this._removeContentClasses(hasReveal);\n\n      if (typeof hasReveal !== 'boolean') {\n        this.$content.addClass(\"has-transition-\".concat(this.options.transition, \" has-position-\").concat(this.position));\n      } else if (hasReveal === true) {\n        this.$content.addClass(\"has-reveal-\".concat(this.position));\n      }\n    }\n    /**\n     * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.\n     * @param {Boolean} isRevealed - true if element should be revealed.\n     * @function\n     */\n\n  }, {\n    key: \"reveal\",\n    value: function reveal(isRevealed) {\n      if (isRevealed) {\n        this.close();\n        this.isRevealed = true;\n        this.$element.attr('aria-hidden', 'false');\n        this.$element.off('open.zf.trigger toggle.zf.trigger');\n        this.$element.removeClass('is-closed');\n      } else {\n        this.isRevealed = false;\n        this.$element.attr('aria-hidden', 'true');\n        this.$element.off('open.zf.trigger toggle.zf.trigger').on({\n          'open.zf.trigger': this.open.bind(this),\n          'toggle.zf.trigger': this.toggle.bind(this)\n        });\n        this.$element.addClass('is-closed');\n      }\n\n      this._addContentClasses(isRevealed);\n    }\n    /**\n     * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.\n     * @private\n     */\n\n  }, {\n    key: \"_stopScrolling\",\n    value: function _stopScrolling(event) {\n      return false;\n    } // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios\n    // Only really works for y, not sure how to extend to x or if we need to.\n\n  }, {\n    key: \"_recordScrollable\",\n    value: function _recordScrollable(event) {\n      var elem = this; // called from event handler context with this as elem\n      // If the element is scrollable (content overflows), then...\n\n      if (elem.scrollHeight !== elem.clientHeight) {\n        // If we're at the top, scroll down one pixel to allow scrolling up\n        if (elem.scrollTop === 0) {\n          elem.scrollTop = 1;\n        } // If we're at the bottom, scroll up one pixel to allow scrolling down\n\n\n        if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {\n          elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;\n        }\n      }\n\n      elem.allowUp = elem.scrollTop > 0;\n      elem.allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight;\n      elem.lastY = event.originalEvent.pageY;\n    }\n  }, {\n    key: \"_stopScrollPropagation\",\n    value: function _stopScrollPropagation(event) {\n      var elem = this; // called from event handler context with this as elem\n\n      var up = event.pageY < elem.lastY;\n      var down = !up;\n      elem.lastY = event.pageY;\n\n      if (up && elem.allowUp || down && elem.allowDown) {\n        event.stopPropagation();\n      } else {\n        event.preventDefault();\n      }\n    }\n    /**\n     * Opens the off-canvas menu.\n     * @function\n     * @param {Object} event - Event object passed from listener.\n     * @param {jQuery} trigger - element that triggered the off-canvas to open.\n     * @fires Offcanvas#opened\n     * @todo also trigger 'open' event?\n     */\n\n  }, {\n    key: \"open\",\n    value: function open(event, trigger) {\n      if (this.$element.hasClass('is-open') || this.isRevealed) {\n        return;\n      }\n\n      var _this = this;\n\n      if (trigger) {\n        this.$lastTrigger = trigger;\n      }\n\n      if (this.options.forceTo === 'top') {\n        window.scrollTo(0, 0);\n      } else if (this.options.forceTo === 'bottom') {\n        window.scrollTo(0, document.body.scrollHeight);\n      }\n\n      if (this.options.transitionTime && this.options.transition !== 'overlap') {\n        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);\n      } else {\n        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');\n      }\n\n      this.$element.addClass('is-open').removeClass('is-closed');\n      this.$triggers.attr('aria-expanded', 'true');\n      this.$element.attr('aria-hidden', 'false');\n      this.$content.addClass('is-open-' + this.position); // If `contentScroll` is set to false, add class and disable scrolling on touch devices.\n\n      if (this.options.contentScroll === false) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);\n        this.$element.on('touchstart', this._recordScrollable);\n        this.$element.on('touchmove', this._stopScrollPropagation);\n      }\n\n      if (this.options.contentOverlay === true) {\n        this.$overlay.addClass('is-visible');\n      }\n\n      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n        this.$overlay.addClass('is-closable');\n      }\n\n      if (this.options.autoFocus === true) {\n        this.$element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"transitionend\"])(this.$element), function () {\n          if (!_this.$element.hasClass('is-open')) {\n            return; // exit if prematurely closed\n          }\n\n          var canvasFocus = _this.$element.find('[data-autofocus]');\n\n          if (canvasFocus.length) {\n            canvasFocus.eq(0).focus();\n          } else {\n            _this.$element.find('a, button').eq(0).focus();\n          }\n        });\n      }\n\n      if (this.options.trapFocus === true) {\n        this.$content.attr('tabindex', '-1');\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].trapFocus(this.$element);\n      }\n\n      this._addContentClasses();\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#opened\n       */\n\n\n      this.$element.trigger('opened.zf.offcanvas');\n    }\n    /**\n     * Closes the off-canvas menu.\n     * @function\n     * @param {Function} cb - optional cb to fire after closure.\n     * @fires Offcanvas#closed\n     */\n\n  }, {\n    key: \"close\",\n    value: function close(cb) {\n      if (!this.$element.hasClass('is-open') || this.isRevealed) {\n        return;\n      }\n\n      var _this = this;\n\n      this.$element.removeClass('is-open');\n      this.$element.attr('aria-hidden', 'true')\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#closed\n       */\n      .trigger('closed.zf.offcanvas');\n      this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom'); // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.\n\n      if (this.options.contentScroll === false) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);\n        this.$element.off('touchstart', this._recordScrollable);\n        this.$element.off('touchmove', this._stopScrollPropagation);\n      }\n\n      if (this.options.contentOverlay === true) {\n        this.$overlay.removeClass('is-visible');\n      }\n\n      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n        this.$overlay.removeClass('is-closable');\n      }\n\n      this.$triggers.attr('aria-expanded', 'false');\n\n      if (this.options.trapFocus === true) {\n        this.$content.removeAttr('tabindex');\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].releaseFocus(this.$element);\n      } // Listen to transitionEnd and add class when done.\n\n\n      this.$element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"transitionend\"])(this.$element), function (e) {\n        _this.$element.addClass('is-closed');\n\n        _this._removeContentClasses();\n      });\n    }\n    /**\n     * Toggles the off-canvas menu open or closed.\n     * @function\n     * @param {Object} event - Event object passed from listener.\n     * @param {jQuery} trigger - element that triggered the off-canvas to open.\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle(event, trigger) {\n      if (this.$element.hasClass('is-open')) {\n        this.close(event, trigger);\n      } else {\n        this.open(event, trigger);\n      }\n    }\n    /**\n     * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_handleKeyboard\",\n    value: function _handleKeyboard(e) {\n      var _this3 = this;\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'OffCanvas', {\n        close: function close() {\n          _this3.close();\n\n          _this3.$lastTrigger.focus();\n\n          return true;\n        },\n        handled: function handled() {\n          e.stopPropagation();\n          e.preventDefault();\n        }\n      });\n    }\n    /**\n     * Destroys the offcanvas plugin.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.close();\n      this.$element.off('.zf.trigger .zf.offcanvas');\n      this.$overlay.off('.zf.offcanvas');\n      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n    }\n  }]);\n\n  return OffCanvas;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__[\"Plugin\"]);\n\nOffCanvas.defaults = {\n  /**\n   * Allow the user to click outside of the menu to close it.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Adds an overlay on top of `[data-off-canvas-content]`.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentOverlay: true,\n\n  /**\n   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  contentId: null,\n\n  /**\n   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.\n   * @option\n   * @type {boolean}\n   * @default null\n   */\n  nested: null,\n\n  /**\n   * Enable/disable scrolling of the main content when an off canvas panel is open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentScroll: true,\n\n  /**\n   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.\n   * @option\n   * @type {number}\n   * @default null\n   */\n  transitionTime: null,\n\n  /**\n   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.\n   * @option\n   * @type {string}\n   * @default push\n   */\n  transition: 'push',\n\n  /**\n   * Force the page to scroll to top or bottom on open.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  forceTo: null,\n\n  /**\n   * Allow the offcanvas to remain open for certain breakpoints.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  isRevealed: false,\n\n  /**\n   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  revealOn: null,\n\n  /**\n   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoFocus: true,\n\n  /**\n   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.\n   * @option\n   * @type {string}\n   * @default reveal-for-\n   * @todo improve the regex testing for this.\n   */\n  revealClass: 'reveal-for-',\n\n  /**\n   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.orbit.js\":\n/*!********************************!*\\\n  !*** ./js/foundation.orbit.js ***!\n  \\********************************/\n/*! exports provided: Orbit */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Orbit\", function() { return Orbit; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./js/foundation.util.motion.js\");\n/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.timer */ \"./js/foundation.util.timer.js\");\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.imageLoader */ \"./js/foundation.util.imageLoader.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./foundation.util.touch */ \"./js/foundation.util.touch.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timer\n * @requires foundation.util.imageLoader\n * @requires foundation.util.touch\n */\n\nvar Orbit =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Orbit, _Plugin);\n\n  function Orbit() {\n    _classCallCheck(this, Orbit);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Orbit).apply(this, arguments));\n  }\n\n  _createClass(Orbit, [{\n    key: \"_setup\",\n\n    /**\n    * Creates a new instance of an orbit carousel.\n    * @class\n    * @name Orbit\n    * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n    * @param {Object} options - Overrides to the default plugin settings.\n    */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Orbit.defaults, this.$element.data(), options);\n      this.className = 'Orbit'; // ie9 back compat\n\n      _foundation_util_touch__WEBPACK_IMPORTED_MODULE_7__[\"Touch\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Touch init is idempotent, we just need to make sure it's initialied.\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('Orbit', {\n        'ltr': {\n          'ARROW_RIGHT': 'next',\n          'ARROW_LEFT': 'previous'\n        },\n        'rtl': {\n          'ARROW_LEFT': 'next',\n          'ARROW_RIGHT': 'previous'\n        }\n      });\n    }\n    /**\n    * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide\n      this._reset();\n\n      this.$wrapper = this.$element.find(\".\".concat(this.options.containerClass));\n      this.$slides = this.$element.find(\".\".concat(this.options.slideClass));\n      var $images = this.$element.find('img'),\n          initActive = this.$slides.filter('.is-active'),\n          id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__[\"GetYoDigits\"])(6, 'orbit');\n      this.$element.attr({\n        'data-resize': id,\n        'id': id\n      });\n\n      if (!initActive.length) {\n        this.$slides.eq(0).addClass('is-active');\n      }\n\n      if (!this.options.useMUI) {\n        this.$slides.addClass('no-motionui');\n      }\n\n      if ($images.length) {\n        Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__[\"onImagesLoaded\"])($images, this._prepareForOrbit.bind(this));\n      } else {\n        this._prepareForOrbit(); //hehe\n\n      }\n\n      if (this.options.bullets) {\n        this._loadBullets();\n      }\n\n      this._events();\n\n      if (this.options.autoPlay && this.$slides.length > 1) {\n        this.geoSync();\n      }\n\n      if (this.options.accessible) {\n        // allow wrapper to be focusable to enable arrow navigation\n        this.$wrapper.attr('tabindex', 0);\n      }\n    }\n    /**\n    * Creates a jQuery collection of bullets, if they are being used.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_loadBullets\",\n    value: function _loadBullets() {\n      this.$bullets = this.$element.find(\".\".concat(this.options.boxOfBullets)).find('button');\n    }\n    /**\n    * Sets a `timer` object on the orbit, and starts the counter for the next slide.\n    * @function\n    */\n\n  }, {\n    key: \"geoSync\",\n    value: function geoSync() {\n      var _this = this;\n\n      this.timer = new _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__[\"Timer\"](this.$element, {\n        duration: this.options.timerDelay,\n        infinite: false\n      }, function () {\n        _this.changeSlide(true);\n      });\n      this.timer.start();\n    }\n    /**\n    * Sets wrapper and slide heights for the orbit.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_prepareForOrbit\",\n    value: function _prepareForOrbit() {\n      var _this = this;\n\n      this._setWrapperHeight();\n    }\n    /**\n    * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.\n    * @function\n    * @private\n    * @param {Function} cb - a callback function to fire when complete.\n    */\n\n  }, {\n    key: \"_setWrapperHeight\",\n    value: function _setWrapperHeight(cb) {\n      //rewrite this to `for` loop\n      var max = 0,\n          temp,\n          counter = 0,\n          _this = this;\n\n      this.$slides.each(function () {\n        temp = this.getBoundingClientRect().height;\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('data-slide', counter); // hide all slides but the active one\n\n        if (!/mui/g.test(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css({\n            'display': 'none'\n          });\n        }\n\n        max = temp > max ? temp : max;\n        counter++;\n      });\n\n      if (counter === this.$slides.length) {\n        this.$wrapper.css({\n          'height': max\n        }); //only change the wrapper height property once.\n\n        if (cb) {\n          cb(max);\n        } //fire callback with max height dimension.\n\n      }\n    }\n    /**\n    * Sets the max-height of each slide.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_setSlideHeight\",\n    value: function _setSlideHeight(height) {\n      this.$slides.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css('max-height', height);\n      });\n    }\n    /**\n    * Adds event listeners to basically everything within the element.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this; //***************************************\n      //**Now using custom event - thanks to:**\n      //**      Yohai Ararat of Toronto      **\n      //***************************************\n      //\n\n\n      this.$element.off('.resizeme.zf.trigger').on({\n        'resizeme.zf.trigger': this._prepareForOrbit.bind(this)\n      });\n\n      if (this.$slides.length > 1) {\n        if (this.options.swipe) {\n          this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) {\n            e.preventDefault();\n\n            _this.changeSlide(true);\n          }).on('swiperight.zf.orbit', function (e) {\n            e.preventDefault();\n\n            _this.changeSlide(false);\n          });\n        } //***************************************\n\n\n        if (this.options.autoPlay) {\n          this.$slides.on('click.zf.orbit', function () {\n            _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);\n\n            _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();\n          });\n\n          if (this.options.pauseOnHover) {\n            this.$element.on('mouseenter.zf.orbit', function () {\n              _this.timer.pause();\n            }).on('mouseleave.zf.orbit', function () {\n              if (!_this.$element.data('clickedOn')) {\n                _this.timer.start();\n              }\n            });\n          }\n        }\n\n        if (this.options.navButtons) {\n          var $controls = this.$element.find(\".\".concat(this.options.nextClass, \", .\").concat(this.options.prevClass));\n          $controls.attr('tabindex', 0) //also need to handle enter/return and spacebar key presses\n          .on('click.zf.orbit touchend.zf.orbit', function (e) {\n            e.preventDefault();\n\n            _this.changeSlide(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).hasClass(_this.options.nextClass));\n          });\n        }\n\n        if (this.options.bullets) {\n          this.$bullets.on('click.zf.orbit touchend.zf.orbit', function () {\n            if (/is-active/g.test(this.className)) {\n              return false;\n            } //if this is active, kick out of function.\n\n\n            var idx = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('slide'),\n                ltr = idx > _this.$slides.filter('.is-active').data('slide'),\n                $slide = _this.$slides.eq(idx);\n\n            _this.changeSlide(ltr, $slide, idx);\n          });\n        }\n\n        if (this.options.accessible) {\n          this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) {\n            // handle keyboard event with keyboard util\n            _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'Orbit', {\n              next: function next() {\n                _this.changeSlide(true);\n              },\n              previous: function previous() {\n                _this.changeSlide(false);\n              },\n              handled: function handled() {\n                // if bullet is focused, make sure focus moves\n                if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is(_this.$bullets)) {\n                  _this.$bullets.filter('.is-active').focus();\n                }\n              }\n            });\n          });\n        }\n      }\n    }\n    /**\n     * Resets Orbit so it can be reinitialized\n     */\n\n  }, {\n    key: \"_reset\",\n    value: function _reset() {\n      // Don't do anything if there are no slides (first run)\n      if (typeof this.$slides == 'undefined') {\n        return;\n      }\n\n      if (this.$slides.length > 1) {\n        // Remove old events\n        this.$element.off('.zf.orbit').find('*').off('.zf.orbit'); // Restart timer if autoPlay is enabled\n\n        if (this.options.autoPlay) {\n          this.timer.restart();\n        } // Reset all sliddes\n\n\n        this.$slides.each(function (el) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide();\n        }); // Show the first slide\n\n        this.$slides.first().addClass('is-active').show(); // Triggers when the slide has finished animating\n\n        this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); // Select first bullet if bullets are present\n\n        if (this.options.bullets) {\n          this._updateBullets(0);\n        }\n      }\n    }\n    /**\n    * Changes the current slide to a new one.\n    * @function\n    * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.\n    * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.\n    * @param {Number} idx - the index of the new slide in its collection, if one chosen.\n    * @fires Orbit#slidechange\n    */\n\n  }, {\n    key: \"changeSlide\",\n    value: function changeSlide(isLTR, chosenSlide, idx) {\n      if (!this.$slides) {\n        return;\n      } // Don't freak out if we're in the middle of cleanup\n\n\n      var $curSlide = this.$slides.filter('.is-active').eq(0);\n\n      if (/mui/g.test($curSlide[0].className)) {\n        return false;\n      } //if the slide is currently animating, kick out of the function\n\n\n      var $firstSlide = this.$slides.first(),\n          $lastSlide = this.$slides.last(),\n          dirIn = isLTR ? 'Right' : 'Left',\n          dirOut = isLTR ? 'Left' : 'Right',\n          _this = this,\n          $newSlide;\n\n      if (!chosenSlide) {\n        //most of the time, this will be auto played or clicked from the navButtons.\n        $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!\n        this.options.infiniteWrap ? $curSlide.next(\".\".concat(this.options.slideClass)).length ? $curSlide.next(\".\".concat(this.options.slideClass)) : $firstSlide : $curSlide.next(\".\".concat(this.options.slideClass)) : //pick next slide if moving left to right\n        this.options.infiniteWrap ? $curSlide.prev(\".\".concat(this.options.slideClass)).length ? $curSlide.prev(\".\".concat(this.options.slideClass)) : $lastSlide : $curSlide.prev(\".\".concat(this.options.slideClass)); //pick prev slide if moving right to left\n      } else {\n        $newSlide = chosenSlide;\n      }\n\n      if ($newSlide.length) {\n        /**\n        * Triggers before the next slide starts animating in and only if a next slide has been found.\n        * @event Orbit#beforeslidechange\n        */\n        this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);\n\n        if (this.options.bullets) {\n          idx = idx || this.$slides.index($newSlide); //grab index to update bullets\n\n          this._updateBullets(idx);\n        }\n\n        if (this.options.useMUI && !this.$element.is(':hidden')) {\n          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateIn($newSlide.addClass('is-active'), this.options[\"animInFrom\".concat(dirIn)], function () {\n            $newSlide.css({\n              'display': 'block'\n            }).attr('aria-live', 'polite');\n          });\n          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut($curSlide.removeClass('is-active'), this.options[\"animOutTo\".concat(dirOut)], function () {\n            $curSlide.removeAttr('aria-live');\n\n            if (_this.options.autoPlay && !_this.timer.isPaused) {\n              _this.timer.restart();\n            } //do stuff?\n\n          });\n        } else {\n          $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();\n          $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();\n\n          if (this.options.autoPlay && !this.timer.isPaused) {\n            this.timer.restart();\n          }\n        }\n        /**\n        * Triggers when the slide has finished animating in.\n        * @event Orbit#slidechange\n        */\n\n\n        this.$element.trigger('slidechange.zf.orbit', [$newSlide]);\n      }\n    }\n    /**\n    * Updates the active state of the bullets, if displayed.\n    * @function\n    * @private\n    * @param {Number} idx - the index of the current slide.\n    */\n\n  }, {\n    key: \"_updateBullets\",\n    value: function _updateBullets(idx) {\n      var $oldBullet = this.$element.find(\".\".concat(this.options.boxOfBullets)).find('.is-active').removeClass('is-active').blur(),\n          span = $oldBullet.find('span:last').detach(),\n          $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);\n    }\n    /**\n    * Destroys the carousel and hides the element.\n    * @function\n    */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();\n    }\n  }]);\n\n  return Orbit;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_6__[\"Plugin\"]);\n\nOrbit.defaults = {\n  /**\n  * Tells the JS to look for and loadBullets.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  bullets: true,\n\n  /**\n  * Tells the JS to apply event listeners to nav buttons\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  navButtons: true,\n\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-right'\n  */\n  animInFromRight: 'slide-in-right',\n\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-right'\n  */\n  animOutToRight: 'slide-out-right',\n\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-left'\n  *\n  */\n  animInFromLeft: 'slide-in-left',\n\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-left'\n  */\n  animOutToLeft: 'slide-out-left',\n\n  /**\n  * Allows Orbit to automatically animate on page load.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  autoPlay: true,\n\n  /**\n  * Amount of time, in ms, between slide transitions\n  * @option\n   * @type {number}\n  * @default 5000\n  */\n  timerDelay: 5000,\n\n  /**\n  * Allows Orbit to infinitely loop through the slides\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  infiniteWrap: true,\n\n  /**\n  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  swipe: true,\n\n  /**\n  * Allows the timing function to pause animation on hover.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  pauseOnHover: true,\n\n  /**\n  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  accessible: true,\n\n  /**\n  * Class applied to the container of Orbit\n  * @option\n   * @type {string}\n  * @default 'orbit-container'\n  */\n  containerClass: 'orbit-container',\n\n  /**\n  * Class applied to individual slides.\n  * @option\n   * @type {string}\n  * @default 'orbit-slide'\n  */\n  slideClass: 'orbit-slide',\n\n  /**\n  * Class applied to the bullet container. You're welcome.\n  * @option\n   * @type {string}\n  * @default 'orbit-bullets'\n  */\n  boxOfBullets: 'orbit-bullets',\n\n  /**\n  * Class applied to the `next` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-next'\n  */\n  nextClass: 'orbit-next',\n\n  /**\n  * Class applied to the `previous` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-previous'\n  */\n  prevClass: 'orbit-previous',\n\n  /**\n  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  useMUI: true\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.positionable.js\":\n/*!***************************************!*\\\n  !*** ./js/foundation.positionable.js ***!\n  \\***************************************/\n/*! exports provided: Positionable */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Positionable\", function() { return Positionable; });\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.util.box */ \"./js/foundation.util.box.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\nvar POSITIONS = ['left', 'right', 'top', 'bottom'];\nvar VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nvar HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\nvar ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n};\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n\n  if (currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\nvar Positionable =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Positionable, _Plugin);\n\n  function Positionable() {\n    _classCallCheck(this, Positionable);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments));\n  }\n\n  _createClass(Positionable, [{\n    key: \"_init\",\n\n    /**\n     * Abstract class encapsulating the tether-like explicit positioning logic\n     * including repositioning based on overlap.\n     * Expects classes to define defaults for vOffset, hOffset, position,\n     * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n     * extending the defaults, or (for now recommended due to the way docs are\n     * generated) by explicitly declaring them.\n     *\n     **/\n    value: function _init() {\n      this.triedPositions = {};\n      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n      this.originalPosition = this.position;\n      this.originalAlignment = this.alignment;\n    }\n  }, {\n    key: \"_getDefaultPosition\",\n    value: function _getDefaultPosition() {\n      return 'bottom';\n    }\n  }, {\n    key: \"_getDefaultAlignment\",\n    value: function _getDefaultAlignment() {\n      switch (this.position) {\n        case 'bottom':\n        case 'top':\n          return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"rtl\"])() ? 'right' : 'left';\n\n        case 'left':\n        case 'right':\n          return 'bottom';\n      }\n    }\n    /**\n     * Adjusts the positionable possible positions by iterating through alignments\n     * and positions.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_reposition\",\n    value: function _reposition() {\n      if (this._alignmentsExhausted(this.position)) {\n        this.position = nextItem(this.position, POSITIONS);\n        this.alignment = ALIGNMENTS[this.position][0];\n      } else {\n        this._realign();\n      }\n    }\n    /**\n     * Adjusts the dropdown pane possible positions by iterating through alignments\n     * on the current position.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_realign\",\n    value: function _realign() {\n      this._addTriedPosition(this.position, this.alignment);\n\n      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);\n    }\n  }, {\n    key: \"_addTriedPosition\",\n    value: function _addTriedPosition(position, alignment) {\n      this.triedPositions[position] = this.triedPositions[position] || [];\n      this.triedPositions[position].push(alignment);\n    }\n  }, {\n    key: \"_positionsExhausted\",\n    value: function _positionsExhausted() {\n      var isExhausted = true;\n\n      for (var i = 0; i < POSITIONS.length; i++) {\n        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n      }\n\n      return isExhausted;\n    }\n  }, {\n    key: \"_alignmentsExhausted\",\n    value: function _alignmentsExhausted(position) {\n      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n    } // When we're trying to center, we don't want to apply offset that's going to\n    // take us just off center, so wrap around to return 0 for the appropriate\n    // offset in those alignments.  TODO: Figure out if we want to make this\n    // configurable behavior... it feels more intuitive, especially for tooltips, but\n    // it's possible someone might actually want to start from center and then nudge\n    // slightly off.\n\n  }, {\n    key: \"_getVOffset\",\n    value: function _getVOffset() {\n      return this.options.vOffset;\n    }\n  }, {\n    key: \"_getHOffset\",\n    value: function _getHOffset() {\n      return this.options.hOffset;\n    }\n  }, {\n    key: \"_setPosition\",\n    value: function _setPosition($anchor, $element, $parent) {\n      if ($anchor.attr('aria-expanded') === 'false') {\n        return false;\n      }\n\n      var $eleDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetDimensions($element),\n          $anchorDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetDimensions($anchor);\n\n      if (!this.options.allowOverlap) {\n        // restore original position & alignment before checking overlap\n        this.position = this.originalPosition;\n        this.alignment = this.originalAlignment;\n      }\n\n      $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n      if (!this.options.allowOverlap) {\n        var overlaps = {};\n        var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better\n\n        var minCoordinates = {\n          position: this.position,\n          alignment: this.alignment\n        };\n\n        while (!this._positionsExhausted()) {\n          var overlap = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n\n          if (overlap === 0) {\n            return;\n          }\n\n          if (overlap < minOverlap) {\n            minOverlap = overlap;\n            minCoordinates = {\n              position: this.position,\n              alignment: this.alignment\n            };\n          }\n\n          this._reposition();\n\n          $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n        } // If we get through the entire loop, there was no non-overlapping\n        // position available. Pick the version with least overlap.\n\n\n        this.position = minCoordinates.position;\n        this.alignment = minCoordinates.alignment;\n        $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n    }\n  }]);\n\n  return Positionable;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.responsiveAccordionTabs.js\":\n/*!**************************************************!*\\\n  !*** ./js/foundation.responsiveAccordionTabs.js ***!\n  \\**************************************************/\n/*! exports provided: ResponsiveAccordionTabs */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveAccordionTabs\", function() { return ResponsiveAccordionTabs; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.accordion */ \"./js/foundation.accordion.js\");\n/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.tabs */ \"./js/foundation.tabs.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n // The plugin matches the plugin classes with these plugin instances.\n\nvar MenuPlugins = {\n  tabs: {\n    cssClass: 'tabs',\n    plugin: _foundation_tabs__WEBPACK_IMPORTED_MODULE_5__[\"Tabs\"]\n  },\n  accordion: {\n    cssClass: 'accordion',\n    plugin: _foundation_accordion__WEBPACK_IMPORTED_MODULE_4__[\"Accordion\"]\n  }\n};\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nvar ResponsiveAccordionTabs =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(ResponsiveAccordionTabs, _Plugin);\n\n  function ResponsiveAccordionTabs() {\n    _classCallCheck(this, ResponsiveAccordionTabs);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveAccordionTabs).apply(this, arguments));\n  }\n\n  _createClass(ResponsiveAccordionTabs, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a responsive accordion tabs.\n     * @class\n     * @name ResponsiveAccordionTabs\n     * @fires ResponsiveAccordionTabs#init\n     * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.$element.data(), options);\n      this.rules = this.$element.data('responsive-accordion-tabs');\n      this.currentMq = null;\n      this.currentPlugin = null;\n      this.className = 'ResponsiveAccordionTabs'; // ie9 back compat\n\n      if (!this.$element.attr('id')) {\n        this.$element.attr('id', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'responsiveaccordiontabs'));\n      }\n\n      ;\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n\n\n      if (typeof this.rules === 'string') {\n        var rulesTree = {}; // Parse rules from \"classes\" pulled from data attribute\n\n        var rules = this.rules.split(' '); // Iterate through every rule found\n\n        for (var i = 0; i < rules.length; i++) {\n          var rule = rules[i].split('-');\n          var ruleSize = rule.length > 1 ? rule[0] : 'small';\n          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n          if (MenuPlugins[rulePlugin] !== null) {\n            rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n          }\n        }\n\n        this.rules = rulesTree;\n      }\n\n      this._getAllOptions();\n\n      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) {\n        this._checkMediaQueries();\n      }\n    }\n  }, {\n    key: \"_getAllOptions\",\n    value: function _getAllOptions() {\n      //get all defaults and options\n      var _this = this;\n\n      _this.allOptions = {};\n\n      for (var key in MenuPlugins) {\n        if (MenuPlugins.hasOwnProperty(key)) {\n          var obj = MenuPlugins[key];\n\n          try {\n            var dummyPlugin = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<ul></ul>');\n            var tmpPlugin = new obj.plugin(dummyPlugin, _this.options);\n\n            for (var keyKey in tmpPlugin.options) {\n              if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {\n                var objObj = tmpPlugin.options[keyKey];\n                _this.allOptions[keyKey] = objObj;\n              }\n            }\n\n            tmpPlugin.destroy();\n          } catch (e) {}\n        }\n      }\n    }\n    /**\n     * Initializes events for the Menu.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n    }\n    /**\n     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_checkMediaQueries\",\n    value: function _checkMediaQueries() {\n      var matchedMq,\n          _this = this; // Iterate through each rule and find the last matching rule\n\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].atLeast(key)) {\n          matchedMq = key;\n        }\n      }); // No match? No dice\n\n      if (!matchedMq) return; // Plugin already initialized? We good\n\n      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) {\n        _this.$element.removeClass(value.cssClass);\n      }); // Add the CSS class for the new plugin\n\n      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin\n\n      if (this.currentPlugin) {\n        //don't know why but on nested elements data zfPlugin get's lost\n        if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData);\n        this.currentPlugin.destroy();\n      }\n\n      this._handleMarkup(this.rules[matchedMq].cssClass);\n\n      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n      this.storezfData = this.currentPlugin.$element.data('zfPlugin');\n    }\n  }, {\n    key: \"_handleMarkup\",\n    value: function _handleMarkup(toSet) {\n      var _this = this,\n          fromString = 'accordion';\n\n      var $panels = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + this.$element.attr('id') + ']');\n      if ($panels.length) fromString = 'tabs';\n\n      if (fromString === toSet) {\n        return;\n      }\n\n      ;\n      var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title';\n      var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel';\n      this.$element.removeAttr('role');\n      var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');\n      var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');\n\n      if (fromString === 'tabs') {\n        $panels = $panels.children('.' + tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');\n        $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');\n      } else {\n        $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');\n      }\n\n      ;\n      $panels.css({\n        display: '',\n        visibility: ''\n      });\n      $liHeads.css({\n        display: '',\n        visibility: ''\n      });\n\n      if (toSet === 'accordion') {\n        $panels.each(function (key, value) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({\n            height: ''\n          });\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id=\"tabs-placeholder-' + _this.$element.attr('id') + '\"></div>').detach();\n          $liHeads.addClass('accordion-item').attr('data-accordion-item', '');\n          $liHeadsA.addClass('accordion-title');\n        });\n      } else if (toSet === 'tabs') {\n        var $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']');\n        var $placeholder = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#tabs-placeholder-' + _this.$element.attr('id'));\n\n        if ($placeholder.length) {\n          $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div class=\"tabs-content\"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));\n          $placeholder.remove();\n        } else {\n          $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div class=\"tabs-content\"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));\n        }\n\n        ;\n        $panels.each(function (key, value) {\n          var tempValue = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($tabsContent).addClass(tabsPanel);\n          var hash = $liHeadsA.get(key).hash.slice(1);\n          var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'accordion');\n\n          if (hash !== id) {\n            if (hash !== '') {\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash);\n            } else {\n              hash = id;\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash);\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href', jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);\n            }\n\n            ;\n          }\n\n          ;\n          var isActive = jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeads.get(key)).hasClass('is-active');\n\n          if (isActive) {\n            tempValue.addClass('is-active');\n          }\n\n          ;\n        });\n        $liHeads.addClass(tabsTitle);\n      }\n\n      ;\n    }\n    /**\n     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      if (this.currentPlugin) this.currentPlugin.destroy();\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n    }\n  }]);\n\n  return ResponsiveAccordionTabs;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nResponsiveAccordionTabs.defaults = {};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.responsiveMenu.js\":\n/*!*****************************************!*\\\n  !*** ./js/foundation.responsiveMenu.js ***!\n  \\*****************************************/\n/*! exports provided: ResponsiveMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveMenu\", function() { return ResponsiveMenu; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.dropdownMenu */ \"./js/foundation.dropdownMenu.js\");\n/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.drilldown */ \"./js/foundation.drilldown.js\");\n/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.accordionMenu */ \"./js/foundation.accordionMenu.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\nvar MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_4__[\"DropdownMenu\"]\n  },\n  drilldown: {\n    cssClass: 'drilldown',\n    plugin: _foundation_drilldown__WEBPACK_IMPORTED_MODULE_5__[\"Drilldown\"]\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_6__[\"AccordionMenu\"]\n  }\n}; // import \"foundation.util.triggers.js\";\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nvar ResponsiveMenu =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(ResponsiveMenu, _Plugin);\n\n  function ResponsiveMenu() {\n    _classCallCheck(this, ResponsiveMenu);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveMenu).apply(this, arguments));\n  }\n\n  _createClass(ResponsiveMenu, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a responsive menu.\n     * @class\n     * @name ResponsiveMenu\n     * @fires ResponsiveMenu#init\n     * @param {jQuery} element - jQuery object to make into a dropdown menu.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);\n      this.rules = this.$element.data('responsive-menu');\n      this.currentMq = null;\n      this.currentPlugin = null;\n      this.className = 'ResponsiveMenu'; // ie9 back compat\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n\n\n      if (typeof this.rules === 'string') {\n        var rulesTree = {}; // Parse rules from \"classes\" pulled from data attribute\n\n        var rules = this.rules.split(' '); // Iterate through every rule found\n\n        for (var i = 0; i < rules.length; i++) {\n          var rule = rules[i].split('-');\n          var ruleSize = rule.length > 1 ? rule[0] : 'small';\n          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n          if (MenuPlugins[rulePlugin] !== null) {\n            rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n          }\n        }\n\n        this.rules = rulesTree;\n      }\n\n      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) {\n        this._checkMediaQueries();\n      } // Add data-mutate since children may need it.\n\n\n      this.$element.attr('data-mutate', this.$element.attr('data-mutate') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'responsive-menu'));\n    }\n    /**\n     * Initializes events for the Menu.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () {\n        _this._checkMediaQueries();\n      }); // $(window).on('resize.zf.ResponsiveMenu', function() {\n      //   _this._checkMediaQueries();\n      // });\n    }\n    /**\n     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_checkMediaQueries\",\n    value: function _checkMediaQueries() {\n      var matchedMq,\n          _this = this; // Iterate through each rule and find the last matching rule\n\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].atLeast(key)) {\n          matchedMq = key;\n        }\n      }); // No match? No dice\n\n      if (!matchedMq) return; // Plugin already initialized? We good\n\n      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) {\n        _this.$element.removeClass(value.cssClass);\n      }); // Add the CSS class for the new plugin\n\n      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin\n\n      if (this.currentPlugin) this.currentPlugin.destroy();\n      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n    }\n    /**\n     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.currentPlugin.destroy();\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('.zf.ResponsiveMenu');\n    }\n  }]);\n\n  return ResponsiveMenu;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nResponsiveMenu.defaults = {};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.responsiveToggle.js\":\n/*!*******************************************!*\\\n  !*** ./js/foundation.responsiveToggle.js ***!\n  \\*******************************************/\n/*! exports provided: ResponsiveToggle */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveToggle\", function() { return ResponsiveToggle; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./js/foundation.util.motion.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion\n */\n\nvar ResponsiveToggle =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(ResponsiveToggle, _Plugin);\n\n  function ResponsiveToggle() {\n    _classCallCheck(this, ResponsiveToggle);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveToggle).apply(this, arguments));\n  }\n\n  _createClass(ResponsiveToggle, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Tab Bar.\n     * @class\n     * @name ResponsiveToggle\n     * @fires ResponsiveToggle#init\n     * @param {jQuery} element - jQuery object to attach tab bar functionality to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n      this.className = 'ResponsiveToggle'; // ie9 back compat\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the tab bar by finding the target element, toggling element, and running update().\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init();\n\n      var targetID = this.$element.data('responsive-toggle');\n\n      if (!targetID) {\n        console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');\n      }\n\n      this.$targetMenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(targetID));\n      this.$toggler = this.$element.find('[data-toggle]').filter(function () {\n        var target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n        return target === targetID || target === \"\";\n      });\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.options, this.$targetMenu.data()); // If they were set, parse the animation classes\n\n      if (this.options.animate) {\n        var input = this.options.animate.split(' ');\n        this.animationIn = input[0];\n        this.animationOut = input[1] || null;\n      }\n\n      this._update();\n    }\n    /**\n     * Adds necessary event handlers for the tab bar to work.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this._updateMqHandler = this._update.bind(this);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._updateMqHandler);\n      this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));\n    }\n    /**\n     * Checks the current media query to determine if the tab bar should be visible or hidden.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_update\",\n    value: function _update() {\n      // Mobile\n      if (!_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].atLeast(this.options.hideFor)) {\n        this.$element.show();\n        this.$targetMenu.hide();\n      } // Desktop\n      else {\n          this.$element.hide();\n          this.$targetMenu.show();\n        }\n    }\n    /**\n     * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.\n     * @function\n     * @fires ResponsiveToggle#toggled\n     */\n\n  }, {\n    key: \"toggleMenu\",\n    value: function toggleMenu() {\n      var _this2 = this;\n\n      if (!_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].atLeast(this.options.hideFor)) {\n        /**\n         * Fires when the element attached to the tab bar toggles.\n         * @event ResponsiveToggle#toggled\n         */\n        if (this.options.animate) {\n          if (this.$targetMenu.is(':hidden')) {\n            _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateIn(this.$targetMenu, this.animationIn, function () {\n              _this2.$element.trigger('toggled.zf.responsiveToggle');\n\n              _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');\n            });\n          } else {\n            _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(this.$targetMenu, this.animationOut, function () {\n              _this2.$element.trigger('toggled.zf.responsiveToggle');\n            });\n          }\n        } else {\n          this.$targetMenu.toggle(0);\n          this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');\n          this.$element.trigger('toggled.zf.responsiveToggle');\n        }\n      }\n    }\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.responsiveToggle');\n      this.$toggler.off('.zf.responsiveToggle');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._updateMqHandler);\n    }\n  }]);\n\n  return ResponsiveToggle;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nResponsiveToggle.defaults = {\n  /**\n   * The breakpoint after which the menu is always shown, and the tab bar is hidden.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  hideFor: 'medium',\n\n  /**\n   * To decide if the toggle should be animated or not.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.reveal.js\":\n/*!*********************************!*\\\n  !*** ./js/foundation.reveal.js ***!\n  \\*********************************/\n/*! exports provided: Reveal */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Reveal\", function() { return Reveal; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.motion */ \"./js/foundation.util.motion.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./foundation.util.touch */ \"./js/foundation.util.touch.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nvar Reveal =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Reveal, _Plugin);\n\n  function Reveal() {\n    _classCallCheck(this, Reveal);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Reveal).apply(this, arguments));\n  }\n\n  _createClass(Reveal, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Reveal.\n     * @class\n     * @name Reveal\n     * @param {jQuery} element - jQuery object to use for the modal.\n     * @param {Object} options - optional parameters.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Reveal.defaults, this.$element.data(), options);\n      this.className = 'Reveal'; // ie9 back compat\n\n      this._init(); // Triggers init is idempotent, just need to make sure it is initialized\n\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('Reveal', {\n        'ESCAPE': 'close'\n      });\n    }\n    /**\n     * Initializes the modal by adding the overlay and close buttons, (if selected).\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var _this2 = this;\n\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"]._init();\n\n      this.id = this.$element.attr('id');\n      this.isActive = false;\n      this.cached = {\n        mq: _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"].current\n      };\n      this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open=\\\"\".concat(this.id, \"\\\"]\")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open=\\\"\".concat(this.id, \"\\\"]\")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-toggle=\\\"\".concat(this.id, \"\\\"]\"));\n      this.$anchor.attr({\n        'aria-controls': this.id,\n        'aria-haspopup': true,\n        'tabindex': 0\n      });\n\n      if (this.options.fullScreen || this.$element.hasClass('full')) {\n        this.options.fullScreen = true;\n        this.options.overlay = false;\n      }\n\n      if (this.options.overlay && !this.$overlay) {\n        this.$overlay = this._makeOverlay(this.id);\n      }\n\n      this.$element.attr({\n        'role': 'dialog',\n        'aria-hidden': true,\n        'data-yeti-box': this.id,\n        'data-resize': this.id\n      });\n\n      if (this.$overlay) {\n        this.$element.detach().appendTo(this.$overlay);\n      } else {\n        this.$element.detach().appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo));\n        this.$element.addClass('without-overlay');\n      }\n\n      this._events();\n\n      if (this.options.deepLink && window.location.hash === \"#\".concat(this.id)) {\n        this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n          return _this2.open();\n        });\n      }\n    }\n    /**\n     * Creates an overlay div to display behind the modal.\n     * @private\n     */\n\n  }, {\n    key: \"_makeOverlay\",\n    value: function _makeOverlay() {\n      var additionalOverlayClasses = '';\n\n      if (this.options.additionalOverlayClasses) {\n        additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;\n      }\n\n      return jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div></div>').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo);\n    }\n    /**\n     * Updates position of modal\n     * TODO:  Figure out if we actually need to cache these values or if it doesn't matter\n     * @private\n     */\n\n  }, {\n    key: \"_updatePosition\",\n    value: function _updatePosition() {\n      var width = this.$element.outerWidth();\n      var outerWidth = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).width();\n      var height = this.$element.outerHeight();\n      var outerHeight = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height();\n      var left,\n          top = null;\n\n      if (this.options.hOffset === 'auto') {\n        left = parseInt((outerWidth - width) / 2, 10);\n      } else {\n        left = parseInt(this.options.hOffset, 10);\n      }\n\n      if (this.options.vOffset === 'auto') {\n        if (height > outerHeight) {\n          top = parseInt(Math.min(100, outerHeight / 10), 10);\n        } else {\n          top = parseInt((outerHeight - height) / 4, 10);\n        }\n      } else if (this.options.vOffset !== null) {\n        top = parseInt(this.options.vOffset, 10);\n      }\n\n      if (top !== null) {\n        this.$element.css({\n          top: top + 'px'\n        });\n      } // only worry about left if we don't have an overlay or we have a horizontal offset,\n      // otherwise we're perfectly in the middle\n\n\n      if (!this.$overlay || this.options.hOffset !== 'auto') {\n        this.$element.css({\n          left: left + 'px'\n        });\n        this.$element.css({\n          margin: '0px'\n        });\n      }\n    }\n    /**\n     * Adds event handlers for the modal.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this3 = this;\n\n      var _this = this;\n\n      this.$element.on({\n        'open.zf.trigger': this.open.bind(this),\n        'close.zf.trigger': function closeZfTrigger(event, $element) {\n          if (event.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default()(event.target).parents('[data-closable]')[0] === $element) {\n            // only close reveal when it's explicitly called\n            return _this3.close.apply(_this3);\n          }\n        },\n        'toggle.zf.trigger': this.toggle.bind(this),\n        'resizeme.zf.trigger': function resizemeZfTrigger() {\n          _this._updatePosition();\n        }\n      });\n\n      if (this.options.closeOnClick && this.options.overlay) {\n        this.$overlay.off('.zf.reveal').on('click.zf.reveal', function (e) {\n          if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) {\n            return;\n          }\n\n          _this.close();\n        });\n      }\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on(\"hashchange.zf.reveal:\".concat(this.id), this._handleState.bind(this));\n      }\n    }\n    /**\n     * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.\n     * @private\n     */\n\n  }, {\n    key: \"_handleState\",\n    value: function _handleState(e) {\n      if (window.location.hash === '#' + this.id && !this.isActive) {\n        this.open();\n      } else {\n        this.close();\n      }\n    }\n    /**\n    * Disables the scroll when Reveal is shown to prevent the background from shifting\n    * @param {number} scrollTop - Scroll to visually apply, window current scroll by default\n    */\n\n  }, {\n    key: \"_disableScroll\",\n    value: function _disableScroll(scrollTop) {\n      scrollTop = scrollTop || jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop();\n\n      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"html\").css(\"top\", -scrollTop);\n      }\n    }\n    /**\n    * Reenables the scroll when Reveal closes\n    * @param {number} scrollTop - Scroll to restore, html \"top\" property by default (as set by `_disableScroll`)\n    */\n\n  }, {\n    key: \"_enableScroll\",\n    value: function _enableScroll(scrollTop) {\n      scrollTop = scrollTop || parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"html\").css(\"top\"));\n\n      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"html\").css(\"top\", \"\");\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop(-scrollTop);\n      }\n    }\n    /**\n     * Opens the modal controlled by `this.$anchor`, and closes all others by default.\n     * @function\n     * @fires Reveal#closeme\n     * @fires Reveal#open\n     */\n\n  }, {\n    key: \"open\",\n    value: function open() {\n      var _this4 = this;\n\n      // either update or replace browser history\n      var hash = \"#\".concat(this.id);\n\n      if (this.options.deepLink && window.location.hash !== hash) {\n        if (window.history.pushState) {\n          if (this.options.updateHistory) {\n            window.history.pushState({}, '', hash);\n          } else {\n            window.history.replaceState({}, '', hash);\n          }\n        } else {\n          window.location.hash = hash;\n        }\n      } // Remember anchor that opened it to set focus back later, have general anchors as fallback\n\n\n      this.$activeAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement).is(this.$anchor) ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement) : this.$anchor;\n      this.isActive = true; // Make elements invisible, but remove display: none so we can get size and positioning\n\n      this.$element.css({\n        'visibility': 'hidden'\n      }).show().scrollTop(0);\n\n      if (this.options.overlay) {\n        this.$overlay.css({\n          'visibility': 'hidden'\n        }).show();\n      }\n\n      this._updatePosition();\n\n      this.$element.hide().css({\n        'visibility': ''\n      });\n\n      if (this.$overlay) {\n        this.$overlay.css({\n          'visibility': ''\n        }).hide();\n\n        if (this.$element.hasClass('fast')) {\n          this.$overlay.addClass('fast');\n        } else if (this.$element.hasClass('slow')) {\n          this.$overlay.addClass('slow');\n        }\n      }\n\n      if (!this.options.multipleOpened) {\n        /**\n         * Fires immediately before the modal opens.\n         * Closes any other modals that are currently open\n         * @event Reveal#closeme\n         */\n        this.$element.trigger('closeme.zf.reveal', this.id);\n      }\n\n      this._disableScroll();\n\n      var _this = this; // Motion UI method of reveal\n\n\n      if (this.options.animationIn) {\n        var afterAnimation = function afterAnimation() {\n          _this.$element.attr({\n            'aria-hidden': false,\n            'tabindex': -1\n          }).focus();\n\n          _this._addGlobalClasses();\n\n          _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].trapFocus(_this.$element);\n        };\n\n        if (this.options.overlay) {\n          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__[\"Motion\"].animateIn(this.$overlay, 'fade-in');\n        }\n\n        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__[\"Motion\"].animateIn(this.$element, this.options.animationIn, function () {\n          if (_this4.$element) {\n            // protect against object having been removed\n            _this4.focusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].findFocusable(_this4.$element);\n            afterAnimation();\n          }\n        });\n      } // jQuery method of reveal\n      else {\n          if (this.options.overlay) {\n            this.$overlay.show(0);\n          }\n\n          this.$element.show(this.options.showDelay);\n        } // handle accessibility\n\n\n      this.$element.attr({\n        'aria-hidden': false,\n        'tabindex': -1\n      }).focus();\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].trapFocus(this.$element);\n\n      this._addGlobalClasses();\n\n      this._addGlobalListeners();\n      /**\n       * Fires when the modal has successfully opened.\n       * @event Reveal#open\n       */\n\n\n      this.$element.trigger('open.zf.reveal');\n    }\n    /**\n     * Adds classes and listeners on document required by open modals.\n     *\n     * The following classes are added and updated:\n     * - `.is-reveal-open` - Prevents the scroll on document\n     * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the\n     *                       scroll was not disabled. This prevent a \"shift\" of the page content due\n     *                       the scrollbar disappearing when the modal opens.\n     *\n     * @private\n     */\n\n  }, {\n    key: \"_addGlobalClasses\",\n    value: function _addGlobalClasses() {\n      var updateScrollbarClass = function updateScrollbarClass() {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').toggleClass('zf-has-scroll', !!(jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()));\n      };\n\n      this.$element.on('resizeme.zf.trigger.revealScrollbarListener', function () {\n        return updateScrollbarClass();\n      });\n      updateScrollbarClass();\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').addClass('is-reveal-open');\n    }\n    /**\n     * Removes classes and listeners on document that were required by open modals.\n     * @private\n     */\n\n  }, {\n    key: \"_removeGlobalClasses\",\n    value: function _removeGlobalClasses() {\n      this.$element.off('resizeme.zf.trigger.revealScrollbarListener');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('is-reveal-open');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('zf-has-scroll');\n    }\n    /**\n     * Adds extra event handlers for the body and window if necessary.\n     * @private\n     */\n\n  }, {\n    key: \"_addGlobalListeners\",\n    value: function _addGlobalListeners() {\n      var _this = this;\n\n      if (!this.$element) {\n        return;\n      } // If we're in the middle of cleanup, don't freak out\n\n\n      this.focusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].findFocusable(this.$element);\n\n      if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').on('click.zf.reveal', function (e) {\n          if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) {\n            return;\n          }\n\n          _this.close();\n        });\n      }\n\n      if (this.options.closeOnEsc) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('keydown.zf.reveal', function (e) {\n          _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'Reveal', {\n            close: function close() {\n              if (_this.options.closeOnEsc) {\n                _this.close();\n              }\n            }\n          });\n        });\n      }\n    }\n    /**\n     * Closes the modal.\n     * @function\n     * @fires Reveal#closed\n     */\n\n  }, {\n    key: \"close\",\n    value: function close() {\n      if (!this.isActive || !this.$element.is(':visible')) {\n        return false;\n      }\n\n      var _this = this; // Motion UI method of hiding\n\n\n      if (this.options.animationOut) {\n        if (this.options.overlay) {\n          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__[\"Motion\"].animateOut(this.$overlay, 'fade-out');\n        }\n\n        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__[\"Motion\"].animateOut(this.$element, this.options.animationOut, finishUp);\n      } // jQuery method of hiding\n      else {\n          this.$element.hide(this.options.hideDelay);\n\n          if (this.options.overlay) {\n            this.$overlay.hide(0, finishUp);\n          } else {\n            finishUp();\n          }\n        } // Conditionals to remove extra event listeners added on open\n\n\n      if (this.options.closeOnEsc) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('keydown.zf.reveal');\n      }\n\n      if (!this.options.overlay && this.options.closeOnClick) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').off('click.zf.reveal');\n      }\n\n      this.$element.off('keydown.zf.reveal');\n\n      function finishUp() {\n        // Get the current top before the modal is closed and restore the scroll after.\n        // TODO: use component properties instead of HTML properties\n        // See https://github.com/zurb/foundation-sites/pull/10786\n        var scrollTop = parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"html\").css(\"top\"));\n\n        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) {\n          _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n\n        }\n\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].releaseFocus(_this.$element);\n\n        _this.$element.attr('aria-hidden', true);\n\n        _this._enableScroll(scrollTop);\n        /**\n        * Fires when the modal is done closing.\n        * @event Reveal#closed\n        */\n\n\n        _this.$element.trigger('closed.zf.reveal');\n      }\n      /**\n      * Resets the modal content\n      * This prevents a running video to keep going in the background\n      */\n\n\n      if (this.options.resetOnClose) {\n        this.$element.html(this.$element.html());\n      }\n\n      this.isActive = false; // If deepLink and we did not switched to an other modal...\n\n      if (_this.options.deepLink && window.location.hash === \"#\".concat(this.id)) {\n        // Remove the history hash\n        if (window.history.replaceState) {\n          var urlWithoutHash = window.location.pathname + window.location.search;\n\n          if (this.options.updateHistory) {\n            window.history.pushState({}, '', urlWithoutHash); // remove the hash\n          } else {\n            window.history.replaceState('', document.title, urlWithoutHash);\n          }\n        } else {\n          window.location.hash = '';\n        }\n      }\n\n      this.$activeAnchor.focus();\n    }\n    /**\n     * Toggles the open/closed state of a modal.\n     * @function\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle() {\n      if (this.isActive) {\n        this.close();\n      } else {\n        this.open();\n      }\n    }\n  }, {\n    key: \"_destroy\",\n\n    /**\n     * Destroys an instance of a modal.\n     * @function\n     */\n    value: function _destroy() {\n      if (this.options.overlay) {\n        this.$element.appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()\n\n        this.$overlay.hide().off().remove();\n      }\n\n      this.$element.hide().off();\n      this.$anchor.off('.zf');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(\".zf.reveal:\".concat(this.id));\n      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n\n      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) {\n        this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n\n      }\n    }\n  }]);\n\n  return Reveal;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_5__[\"Plugin\"]);\n\nReveal.defaults = {\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationIn: '',\n\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationOut: '',\n\n  /**\n   * Time, in ms, to delay the opening of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  showDelay: 0,\n\n  /**\n   * Time, in ms, to delay the closing of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hideDelay: 0,\n\n  /**\n   * Allows a click on the body/overlay to close the modal.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Allows the modal to close if the user presses the `ESCAPE` key.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnEsc: true,\n\n  /**\n   * If true, allows multiple modals to be displayed at once.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multipleOpened: false,\n\n  /**\n   * Distance, in pixels, the modal should push down from the top of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  vOffset: 'auto',\n\n  /**\n   * Distance, in pixels, the modal should push in from the side of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  hOffset: 'auto',\n\n  /**\n   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  fullScreen: false,\n\n  /**\n   * Allows the modal to generate an overlay div, which will cover the view when modal opens.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  overlay: true,\n\n  /**\n   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  resetOnClose: false,\n\n  /**\n   * Link the location hash to the modal.\n   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open modal\n   * @option\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n  * Allows the modal to append to custom div.\n  * @option\n  * @type {string}\n  * @default \"body\"\n  */\n  appendTo: \"body\",\n\n  /**\n   * Allows adding additional class names to the reveal overlay.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  additionalOverlayClasses: ''\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.slider.js\":\n/*!*********************************!*\\\n  !*** ./js/foundation.slider.js ***!\n  \\*********************************/\n/*! exports provided: Slider */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Slider\", function() { return Slider; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./js/foundation.util.motion.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.touch */ \"./js/foundation.util.touch.js\");\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n/**\n * Slider module.\n * @module foundation.slider\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n */\n\nvar Slider =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Slider, _Plugin);\n\n  function Slider() {\n    _classCallCheck(this, Slider);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Slider).apply(this, arguments));\n  }\n\n  _createClass(Slider, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a slider control.\n     * @class\n     * @name Slider\n     * @param {jQuery} element - jQuery object to make into a slider control.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Slider.defaults, this.$element.data(), options);\n      this.className = 'Slider'; // ie9 back compat\n      // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.\n\n      _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__[\"Touch\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_6__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('Slider', {\n        'ltr': {\n          'ARROW_RIGHT': 'increase',\n          'ARROW_UP': 'increase',\n          'ARROW_DOWN': 'decrease',\n          'ARROW_LEFT': 'decrease',\n          'SHIFT_ARROW_RIGHT': 'increase_fast',\n          'SHIFT_ARROW_UP': 'increase_fast',\n          'SHIFT_ARROW_DOWN': 'decrease_fast',\n          'SHIFT_ARROW_LEFT': 'decrease_fast',\n          'HOME': 'min',\n          'END': 'max'\n        },\n        'rtl': {\n          'ARROW_LEFT': 'increase',\n          'ARROW_RIGHT': 'decrease',\n          'SHIFT_ARROW_LEFT': 'increase_fast',\n          'SHIFT_ARROW_RIGHT': 'decrease_fast'\n        }\n      });\n    }\n    /**\n     * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      this.inputs = this.$element.find('input');\n      this.handles = this.$element.find('[data-slider-handle]');\n      this.$handle = this.handles.eq(0);\n      this.$input = this.inputs.length ? this.inputs.eq(0) : jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(this.$handle.attr('aria-controls')));\n      this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);\n\n      var isDbl = false,\n          _this = this;\n\n      if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {\n        this.options.disabled = true;\n        this.$element.addClass(this.options.disabledClass);\n      }\n\n      if (!this.inputs.length) {\n        this.inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default()().add(this.$input);\n        this.options.binding = true;\n      }\n\n      this._setInitAttr(0);\n\n      if (this.handles[1]) {\n        this.options.doubleSided = true;\n        this.$handle2 = this.handles.eq(1);\n        this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(this.$handle2.attr('aria-controls')));\n\n        if (!this.inputs[1]) {\n          this.inputs = this.inputs.add(this.$input2);\n        }\n\n        isDbl = true; // this.$handle.triggerHandler('click.zf.slider');\n\n        this._setInitAttr(1);\n      } // Set handle positions\n\n\n      this.setHandles();\n\n      this._events();\n    }\n  }, {\n    key: \"setHandles\",\n    value: function setHandles() {\n      var _this2 = this;\n\n      if (this.handles[1]) {\n        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, function () {\n          _this2._setHandlePos(_this2.$handle2, _this2.inputs.eq(1).val(), true);\n        });\n      } else {\n        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);\n      }\n    }\n  }, {\n    key: \"_reflow\",\n    value: function _reflow() {\n      this.setHandles();\n    }\n    /**\n    * @function\n    * @private\n    * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)\n    */\n\n  }, {\n    key: \"_pctOfBar\",\n    value: function _pctOfBar(value) {\n      var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start);\n\n      switch (this.options.positionValueFunction) {\n        case \"pow\":\n          pctOfBar = this._logTransform(pctOfBar);\n          break;\n\n        case \"log\":\n          pctOfBar = this._powTransform(pctOfBar);\n          break;\n      }\n\n      return pctOfBar.toFixed(2);\n    }\n    /**\n    * @function\n    * @private\n    * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value\n    */\n\n  }, {\n    key: \"_value\",\n    value: function _value(pctOfBar) {\n      switch (this.options.positionValueFunction) {\n        case \"pow\":\n          pctOfBar = this._powTransform(pctOfBar);\n          break;\n\n        case \"log\":\n          pctOfBar = this._logTransform(pctOfBar);\n          break;\n      }\n\n      var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);\n      return value;\n    }\n    /**\n    * @function\n    * @private\n    * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function\n    */\n\n  }, {\n    key: \"_logTransform\",\n    value: function _logTransform(value) {\n      return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1);\n    }\n    /**\n    * @function\n    * @private\n    * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function\n    */\n\n  }, {\n    key: \"_powTransform\",\n    value: function _powTransform(value) {\n      return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1);\n    }\n    /**\n     * Sets the position of the selected handle and fill bar.\n     * @function\n     * @private\n     * @param {jQuery} $hndl - the selected handle to move.\n     * @param {Number} location - floating point between the start and end values of the slider bar.\n     * @param {Function} cb - callback function to fire on completion.\n     * @fires Slider#moved\n     * @fires Slider#changed\n     */\n\n  }, {\n    key: \"_setHandlePos\",\n    value: function _setHandlePos($hndl, location, noInvert, cb) {\n      // don't move if the slider has been disabled since its initialization\n      if (this.$element.hasClass(this.options.disabledClass)) {\n        return;\n      } //might need to alter that slightly for bars that will have odd number selections.\n\n\n      location = parseFloat(location); //on input change events, convert string to number...grumble.\n      // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max\n\n      if (location < this.options.start) {\n        location = this.options.start;\n      } else if (location > this.options.end) {\n        location = this.options.end;\n      }\n\n      var isDbl = this.options.doubleSided; //this is for single-handled vertical sliders, it adjusts the value to account for the slider being \"upside-down\"\n      //for click and drag events, it's weird due to the scale(-1, 1) css property\n\n      if (this.options.vertical && !noInvert) {\n        location = this.options.end - location;\n      }\n\n      if (isDbl) {\n        //this block is to prevent 2 handles from crossing eachother. Could/should be improved.\n        if (this.handles.index($hndl) === 0) {\n          var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));\n          location = location >= h2Val ? h2Val - this.options.step : location;\n        } else {\n          var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));\n          location = location <= h1Val ? h1Val + this.options.step : location;\n        }\n      }\n\n      var _this = this,\n          vert = this.options.vertical,\n          hOrW = vert ? 'height' : 'width',\n          lOrT = vert ? 'top' : 'left',\n          handleDim = $hndl[0].getBoundingClientRect()[hOrW],\n          elemDim = this.$element[0].getBoundingClientRect()[hOrW],\n          //percentage of bar min/max value based on click or drag point\n      pctOfBar = this._pctOfBar(location),\n          //number of actual pixels to shift the handle, based on the percentage obtained above\n      pxToMove = (elemDim - handleDim) * pctOfBar,\n          //percentage of bar to shift the handle\n      movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value\n\n\n      location = parseFloat(location.toFixed(this.options.decimal)); // declare empty object for css adjustments, only used with 2 handled-sliders\n\n      var css = {};\n\n      this._setValues($hndl, location); // TODO update to calculate based on values set to respective inputs??\n\n\n      if (isDbl) {\n        var isLeftHndl = this.handles.index($hndl) === 0,\n            //empty variable, will be used for min-height/width for fill bar\n        dim,\n            //percentage w/h of the handle compared to the slider bar\n        handlePct = ~~(percent(handleDim, elemDim) * 100); //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar\n\n        if (isLeftHndl) {\n          //left or top percentage value to apply to the fill bar.\n          css[lOrT] = \"\".concat(movement, \"%\"); //calculate the new min-height/width for the fill bar.\n\n          dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider\n          //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.\n\n          if (cb && typeof cb === 'function') {\n            cb();\n          } //this is only needed for the initialization of 2 handled sliders\n\n        } else {\n          //just caching the value of the left/bottom handle's left/top property\n          var handlePos = parseFloat(this.$handle[0].style[lOrT]); //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0\n          //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself\n\n          dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct;\n        } // assign the min-height/width to our css object\n\n\n        css[\"min-\".concat(hOrW)] = \"\".concat(dim, \"%\");\n      }\n\n      this.$element.one('finished.zf.animate', function () {\n        /**\n         * Fires when the handle is done moving.\n         * @event Slider#moved\n         */\n        _this.$element.trigger('moved.zf.slider', [$hndl]);\n      }); //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.\n\n      var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime;\n      Object(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Move\"])(moveTime, $hndl, function () {\n        // adjusting the left/top property of the handle, based on the percentage calculated above\n        // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,\n        // fall back to next best guess.\n        if (isNaN(movement)) {\n          $hndl.css(lOrT, \"\".concat(pctOfBar * 100, \"%\"));\n        } else {\n          $hndl.css(lOrT, \"\".concat(movement, \"%\"));\n        }\n\n        if (!_this.options.doubleSided) {\n          //if single-handled, a simple method to expand the fill bar\n          _this.$fill.css(hOrW, \"\".concat(pctOfBar * 100, \"%\"));\n        } else {\n          //otherwise, use the css object we created above\n          _this.$fill.css(css);\n        }\n      });\n      /**\n       * Fires when the value has not been change for a given time.\n       * @event Slider#changed\n       */\n\n      clearTimeout(_this.timeout);\n      _this.timeout = setTimeout(function () {\n        _this.$element.trigger('changed.zf.slider', [$hndl]);\n      }, _this.options.changedDelay);\n    }\n    /**\n     * Sets the initial attribute for the slider element.\n     * @function\n     * @private\n     * @param {Number} idx - index of the current handle/input to use.\n     */\n\n  }, {\n    key: \"_setInitAttr\",\n    value: function _setInitAttr(idx) {\n      var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd;\n      var id = this.inputs.eq(idx).attr('id') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'slider');\n      this.inputs.eq(idx).attr({\n        'id': id,\n        'max': this.options.end,\n        'min': this.options.start,\n        'step': this.options.step\n      });\n      this.inputs.eq(idx).val(initVal);\n      this.handles.eq(idx).attr({\n        'role': 'slider',\n        'aria-controls': id,\n        'aria-valuemax': this.options.end,\n        'aria-valuemin': this.options.start,\n        'aria-valuenow': initVal,\n        'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',\n        'tabindex': 0\n      });\n    }\n    /**\n     * Sets the input and `aria-valuenow` values for the slider element.\n     * @function\n     * @private\n     * @param {jQuery} $handle - the currently selected handle.\n     * @param {Number} val - floating point of the new value.\n     */\n\n  }, {\n    key: \"_setValues\",\n    value: function _setValues($handle, val) {\n      var idx = this.options.doubleSided ? this.handles.index($handle) : 0;\n      this.inputs.eq(idx).val(val);\n      $handle.attr('aria-valuenow', val);\n    }\n    /**\n     * Handles events on the slider element.\n     * Calculates the new location of the current handle.\n     * If there are two handles and the bar was clicked, it determines which handle to move.\n     * @function\n     * @private\n     * @param {Object} e - the `event` object passed from the listener.\n     * @param {jQuery} $handle - the current handle to calculate for, if selected.\n     * @param {Number} val - floating point number for the new value of the slider.\n     * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.\n     */\n\n  }, {\n    key: \"_handleEvent\",\n    value: function _handleEvent(e, $handle, val) {\n      var value, hasVal;\n\n      if (!val) {\n        //click or drag events\n        e.preventDefault();\n\n        var _this = this,\n            vertical = this.options.vertical,\n            param = vertical ? 'height' : 'width',\n            direction = vertical ? 'top' : 'left',\n            eventOffset = vertical ? e.pageY : e.pageX,\n            halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,\n            barDim = this.$element[0].getBoundingClientRect()[param],\n            windowScroll = vertical ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop() : jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollLeft();\n\n        var elemOffset = this.$element.offset()[direction]; // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...\n        // best way to guess this is simulated is if clientY == pageY\n\n        if (e.clientY === e.pageY) {\n          eventOffset = eventOffset + windowScroll;\n        }\n\n        var eventFromBar = eventOffset - elemOffset;\n        var barXY;\n\n        if (eventFromBar < 0) {\n          barXY = 0;\n        } else if (eventFromBar > barDim) {\n          barXY = barDim;\n        } else {\n          barXY = eventFromBar;\n        }\n\n        var offsetPct = percent(barXY, barDim);\n        value = this._value(offsetPct); // turn everything around for RTL, yay math!\n\n        if (Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"rtl\"])() && !this.options.vertical) {\n          value = this.options.end - value;\n        }\n\n        value = _this._adjustValue(null, value); //boolean flag for the setHandlePos fn, specifically for vertical sliders\n\n        hasVal = false;\n\n        if (!$handle) {\n          //figure out which handle it is, pass it to the next function.\n          var firstHndlPos = absPosition(this.$handle, direction, barXY, param),\n              secndHndlPos = absPosition(this.$handle2, direction, barXY, param);\n          $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;\n        }\n      } else {\n        //change event on input\n        value = this._adjustValue(null, val);\n        hasVal = true;\n      }\n\n      this._setHandlePos($handle, value, hasVal);\n    }\n    /**\n     * Adjustes value for handle in regard to step value. returns adjusted value\n     * @function\n     * @private\n     * @param {jQuery} $handle - the selected handle.\n     * @param {Number} value - value to adjust. used if $handle is falsy\n     */\n\n  }, {\n    key: \"_adjustValue\",\n    value: function _adjustValue($handle, value) {\n      var val,\n          step = this.options.step,\n          div = parseFloat(step / 2),\n          left,\n          prev_val,\n          next_val;\n\n      if (!!$handle) {\n        val = parseFloat($handle.attr('aria-valuenow'));\n      } else {\n        val = value;\n      }\n\n      if (val >= 0) {\n        left = val % step;\n      } else {\n        left = step + val % step;\n      }\n\n      prev_val = val - left;\n      next_val = prev_val + step;\n\n      if (left === 0) {\n        return val;\n      }\n\n      val = val >= prev_val + div ? next_val : prev_val;\n      return val;\n    }\n    /**\n     * Adds event listeners to the slider elements.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this._eventsForHandle(this.$handle);\n\n      if (this.handles[1]) {\n        this._eventsForHandle(this.$handle2);\n      }\n    }\n    /**\n     * Adds event listeners a particular handle\n     * @function\n     * @private\n     * @param {jQuery} $handle - the current handle to apply listeners to.\n     */\n\n  }, {\n    key: \"_eventsForHandle\",\n    value: function _eventsForHandle($handle) {\n      var _this = this,\n          curHandle,\n          timer;\n\n      var handleChangeEvent = function handleChangeEvent(e) {\n        var idx = _this.inputs.index(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n\n        _this._handleEvent(e, _this.handles.eq(idx), jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val());\n      }; // IE only triggers the change event when the input loses focus which strictly follows the HTML specification\n      // listen for the enter key and trigger a change\n      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events\n\n\n      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {\n        if (e.keyCode == 13) handleChangeEvent.call(this, e);\n      });\n      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);\n\n      if (this.options.clickSelect) {\n        this.$element.off('click.zf.slider').on('click.zf.slider', function (e) {\n          if (_this.$element.data('dragging')) {\n            return false;\n          }\n\n          if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is('[data-slider-handle]')) {\n            if (_this.options.doubleSided) {\n              _this._handleEvent(e);\n            } else {\n              _this._handleEvent(e, _this.$handle);\n            }\n          }\n        });\n      }\n\n      if (this.options.draggable) {\n        this.handles.addTouch();\n        var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');\n        $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) {\n          $handle.addClass('is-dragging');\n\n          _this.$fill.addClass('is-dragging'); //\n\n\n          _this.$element.data('dragging', true);\n\n          curHandle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget);\n          $body.on('mousemove.zf.slider', function (e) {\n            e.preventDefault();\n\n            _this._handleEvent(e, curHandle);\n          }).on('mouseup.zf.slider', function (e) {\n            _this._handleEvent(e, curHandle);\n\n            $handle.removeClass('is-dragging');\n\n            _this.$fill.removeClass('is-dragging');\n\n            _this.$element.data('dragging', false);\n\n            $body.off('mousemove.zf.slider mouseup.zf.slider');\n          });\n        }) // prevent events triggered by touch\n        .on('selectstart.zf.slider touchmove.zf.slider', function (e) {\n          e.preventDefault();\n        });\n      }\n\n      $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) {\n        var _$handle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,\n            oldValue = parseFloat(_this.inputs.eq(idx).val()),\n            newValue; // handle keyboard event with keyboard util\n\n\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'Slider', {\n          decrease: function decrease() {\n            newValue = oldValue - _this.options.step;\n          },\n          increase: function increase() {\n            newValue = oldValue + _this.options.step;\n          },\n          decrease_fast: function decrease_fast() {\n            newValue = oldValue - _this.options.step * 10;\n          },\n          increase_fast: function increase_fast() {\n            newValue = oldValue + _this.options.step * 10;\n          },\n          min: function min() {\n            newValue = _this.options.start;\n          },\n          max: function max() {\n            newValue = _this.options.end;\n          },\n          handled: function handled() {\n            // only set handle pos when event was handled specially\n            e.preventDefault();\n\n            _this._setHandlePos(_$handle, newValue, true);\n          }\n        });\n        /*if (newValue) { // if pressed key has special function, update value\n          e.preventDefault();\n          _this._setHandlePos(_$handle, newValue);\n        }*/\n      });\n    }\n    /**\n     * Destroys the slider plugin.\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.handles.off('.zf.slider');\n      this.inputs.off('.zf.slider');\n      this.$element.off('.zf.slider');\n      clearTimeout(this.timeout);\n    }\n  }]);\n\n  return Slider;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__[\"Plugin\"]);\n\nSlider.defaults = {\n  /**\n   * Minimum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  start: 0,\n\n  /**\n   * Maximum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  end: 100,\n\n  /**\n   * Minimum value change per change event.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  step: 1,\n\n  /**\n   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  initialStart: 0,\n\n  /**\n   * Value at which the right handle/second input should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  initialEnd: 100,\n\n  /**\n   * Allows the input to be located outside the container and visible. Set to by the JS\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  binding: false,\n\n  /**\n   * Allows the user to click/tap on the slider bar to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickSelect: true,\n\n  /**\n   * Set to true and use the `vertical` class to change alignment to vertical.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  vertical: false,\n\n  /**\n   * Allows the user to drag the slider handle(s) to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  draggable: true,\n\n  /**\n   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disabled: false,\n\n  /**\n   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  doubleSided: false,\n\n  /**\n   * Potential future feature.\n   */\n  // steps: 100,\n\n  /**\n   * Number of decimal places the plugin should go to for floating point precision.\n   * @option\n   * @type {number}\n   * @default 2\n   */\n  decimal: 2,\n\n  /**\n   * Time delay for dragged elements.\n   */\n  // dragDelay: 0,\n\n  /**\n   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  moveTime: 200,\n  //update this if changing the transition time in the sass\n\n  /**\n   * Class applied to disabled sliders.\n   * @option\n   * @type {string}\n   * @default 'disabled'\n   */\n  disabledClass: 'disabled',\n\n  /**\n   * Will invert the default layout for a vertical<span data-tooltip title=\"who would do this???\"> </span>slider.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  invertVertical: false,\n\n  /**\n   * Milliseconds before the `changed.zf-slider` event is triggered after value change.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  changedDelay: 500,\n\n  /**\n  * Basevalue for non-linear sliders\n  * @option\n  * @type {number}\n  * @default 5\n  */\n  nonLinearBase: 5,\n\n  /**\n  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.\n  * @option\n  * @type {string}\n  * @default 'linear'\n  */\n  positionValueFunction: 'linear'\n};\n\nfunction percent(frac, num) {\n  return frac / num;\n}\n\nfunction absPosition($handle, dir, clickPos, param) {\n  return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos);\n}\n\nfunction baseLog(base, value) {\n  return Math.log(value) / Math.log(base);\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.smoothScroll.js\":\n/*!***************************************!*\\\n  !*** ./js/foundation.smoothScroll.js ***!\n  \\***************************************/\n/*! exports provided: SmoothScroll */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"SmoothScroll\", function() { return SmoothScroll; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n/**\n * SmoothScroll module.\n * @module foundation.smooth-scroll\n */\n\nvar SmoothScroll =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(SmoothScroll, _Plugin);\n\n  function SmoothScroll() {\n    _classCallCheck(this, SmoothScroll);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(SmoothScroll).apply(this, arguments));\n  }\n\n  _createClass(SmoothScroll, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of SmoothScroll.\n     * @class\n     * @name SmoothScroll\n     * @fires SmoothScroll#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, SmoothScroll.defaults, this.$element.data(), options);\n      this.className = 'SmoothScroll'; // ie9 back compat\n\n      this._init();\n    }\n    /**\n     * Initialize the SmoothScroll plugin\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'smooth-scroll');\n      this.$element.attr({\n        id: id\n      });\n\n      this._events();\n    }\n    /**\n     * Initializes events for SmoothScroll.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this._linkClickListener = this._handleLinkClick.bind(this);\n      this.$element.on('click.zf.smoothScroll', this._linkClickListener);\n      this.$element.on('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n    /**\n     * Handle the given event to smoothly scroll to the anchor pointed by the event target.\n     * @param {*} e - event\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_handleLinkClick\",\n    value: function _handleLinkClick(e) {\n      var _this = this;\n\n      // Follow the link if it does not point to an anchor.\n      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget).is('a[href^=\"#\"]')) return;\n      var arrival = e.currentTarget.getAttribute('href');\n      this._inTransition = true;\n      SmoothScroll.scrollToLoc(arrival, this.options, function () {\n        _this._inTransition = false;\n      });\n      e.preventDefault();\n    }\n  }, {\n    key: \"_destroy\",\n\n    /**\n     * Destroys the SmoothScroll instance.\n     * @function\n     */\n    value: function _destroy() {\n      this.$element.off('click.zf.smoothScroll', this._linkClickListener);\n      this.$element.off('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n  }], [{\n    key: \"scrollToLoc\",\n\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'\n     * @param {Object} options - The options to use.\n     * @param {Function} callback - The callback function.\n     * @static\n     * @function\n     */\n    value: function scrollToLoc(loc) {\n      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults;\n      var callback = arguments.length > 2 ? arguments[2] : undefined;\n      var $loc = jquery__WEBPACK_IMPORTED_MODULE_0___default()(loc); // Do nothing if target does not exist to prevent errors\n\n      if (!$loc.length) return false;\n      var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({\n        scrollTop: scrollPos\n      }, options.animationDuration, options.animationEasing, function () {\n        if (typeof callback === 'function') {\n          callback();\n        }\n      });\n    }\n  }]);\n\n  return SmoothScroll;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]);\n/**\n * Default settings for plugin.\n */\n\n\nSmoothScroll.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.sticky.js\":\n/*!*********************************!*\\\n  !*** ./js/foundation.sticky.js ***!\n  \\*********************************/\n/*! exports provided: Sticky */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Sticky\", function() { return Sticky; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nvar Sticky =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Sticky, _Plugin);\n\n  function Sticky() {\n    _classCallCheck(this, Sticky);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments));\n  }\n\n  _createClass(Sticky, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a sticky thing.\n     * @class\n     * @name Sticky\n     * @param {jQuery} element - jQuery object to make sticky.\n     * @param {Object} options - options object passed when creating the element programmatically.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Sticky.defaults, this.$element.data(), options);\n      this.className = 'Sticky'; // ie9 back compat\n      // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n    }\n    /**\n     * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"]._init();\n\n      var $parent = this.$element.parent('[data-sticky-container]'),\n          id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'sticky'),\n          _this = this;\n\n      if ($parent.length) {\n        this.$container = $parent;\n      } else {\n        this.wasWrapped = true;\n        this.$element.wrap(this.options.container);\n        this.$container = this.$element.parent();\n      }\n\n      this.$container.addClass(this.options.containerClass);\n      this.$element.addClass(this.options.stickyClass).attr({\n        'data-resize': id,\n        'data-mutate': id\n      });\n\n      if (this.options.anchor !== '') {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor).attr({\n          'data-mutate': id\n        });\n      }\n\n      this.scrollCount = this.options.checkEvery;\n      this.isStuck = false;\n      this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n        //We calculate the container height to have correct values for anchor points offset calculation.\n        _this.containerHeight = _this.$element.css(\"display\") == \"none\" ? 0 : _this.$element[0].getBoundingClientRect().height;\n\n        _this.$container.css('height', _this.containerHeight);\n\n        _this.elemHeight = _this.containerHeight;\n\n        if (_this.options.anchor !== '') {\n          _this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor);\n        } else {\n          _this._parsePoints();\n        }\n\n        _this._setSizes(function () {\n          var scroll = window.pageYOffset;\n\n          _this._calc(false, scroll); //Unstick the element will ensure that proper classes are set.\n\n\n          if (!_this.isStuck) {\n            _this._removeSticky(scroll >= _this.topPoint ? false : true);\n          }\n        });\n\n        _this._events(id.split('-').reverse().join('-'));\n      });\n    }\n    /**\n     * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_parsePoints\",\n    value: function _parsePoints() {\n      var top = this.options.topAnchor == \"\" ? 1 : this.options.topAnchor,\n          btm = this.options.btmAnchor == \"\" ? document.documentElement.scrollHeight : this.options.btmAnchor,\n          pts = [top, btm],\n          breaks = {};\n\n      for (var i = 0, len = pts.length; i < len && pts[i]; i++) {\n        var pt;\n\n        if (typeof pts[i] === 'number') {\n          pt = pts[i];\n        } else {\n          var place = pts[i].split(':'),\n              anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(place[0]));\n          pt = anchor.offset().top;\n\n          if (place[1] && place[1].toLowerCase() === 'bottom') {\n            pt += anchor[0].getBoundingClientRect().height;\n          }\n        }\n\n        breaks[i] = pt;\n      }\n\n      this.points = breaks;\n      return;\n    }\n    /**\n     * Adds event handlers for the scrolling element.\n     * @private\n     * @param {String} id - pseudo-random id for unique scroll event listener.\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events(id) {\n      var _this = this,\n          scrollListener = this.scrollListener = \"scroll.zf.\".concat(id);\n\n      if (this.isOn) {\n        return;\n      }\n\n      if (this.canStick) {\n        this.isOn = true;\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener).on(scrollListener, function (e) {\n          if (_this.scrollCount === 0) {\n            _this.scrollCount = _this.options.checkEvery;\n\n            _this._setSizes(function () {\n              _this._calc(false, window.pageYOffset);\n            });\n          } else {\n            _this.scrollCount--;\n\n            _this._calc(false, window.pageYOffset);\n          }\n        });\n      }\n\n      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n      });\n      this.$element.on('mutateme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n      });\n\n      if (this.$anchor) {\n        this.$anchor.on('mutateme.zf.trigger', function (e, el) {\n          _this._eventsHandler(id);\n        });\n      }\n    }\n    /**\n     * Handler for events.\n     * @private\n     * @param {String} id - pseudo-random id for unique scroll event listener.\n     */\n\n  }, {\n    key: \"_eventsHandler\",\n    value: function _eventsHandler(id) {\n      var _this = this,\n          scrollListener = this.scrollListener = \"scroll.zf.\".concat(id);\n\n      _this._setSizes(function () {\n        _this._calc(false);\n\n        if (_this.canStick) {\n          if (!_this.isOn) {\n            _this._events(id);\n          }\n        } else if (_this.isOn) {\n          _this._pauseListeners(scrollListener);\n        }\n      });\n    }\n    /**\n     * Removes event handlers for scroll and change events on anchor.\n     * @fires Sticky#pause\n     * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`\n     */\n\n  }, {\n    key: \"_pauseListeners\",\n    value: function _pauseListeners(scrollListener) {\n      this.isOn = false;\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener);\n      /**\n       * Fires when the plugin is paused due to resize event shrinking the view.\n       * @event Sticky#pause\n       * @private\n       */\n\n      this.$element.trigger('pause.zf.sticky');\n    }\n    /**\n     * Called on every `scroll` event and on `_init`\n     * fires functions based on booleans and cached values\n     * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.\n     * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.\n     */\n\n  }, {\n    key: \"_calc\",\n    value: function _calc(checkSizes, scroll) {\n      if (checkSizes) {\n        this._setSizes();\n      }\n\n      if (!this.canStick) {\n        if (this.isStuck) {\n          this._removeSticky(true);\n        }\n\n        return false;\n      }\n\n      if (!scroll) {\n        scroll = window.pageYOffset;\n      }\n\n      if (scroll >= this.topPoint) {\n        if (scroll <= this.bottomPoint) {\n          if (!this.isStuck) {\n            this._setSticky();\n          }\n        } else {\n          if (this.isStuck) {\n            this._removeSticky(false);\n          }\n        }\n      } else {\n        if (this.isStuck) {\n          this._removeSticky(true);\n        }\n      }\n    }\n    /**\n     * Causes the $element to become stuck.\n     * Adds `position: fixed;`, and helper classes.\n     * @fires Sticky#stuckto\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_setSticky\",\n    value: function _setSticky() {\n      var _this = this,\n          stickTo = this.options.stickTo,\n          mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',\n          notStuckTo = stickTo === 'top' ? 'bottom' : 'top',\n          css = {};\n\n      css[mrgn] = \"\".concat(this.options[mrgn], \"em\");\n      css[stickTo] = 0;\n      css[notStuckTo] = 'auto';\n      this.isStuck = true;\n      this.$element.removeClass(\"is-anchored is-at-\".concat(notStuckTo)).addClass(\"is-stuck is-at-\".concat(stickTo)).css(css)\n      /**\n       * Fires when the $element has become `position: fixed;`\n       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`\n       * @event Sticky#stuckto\n       */\n      .trigger(\"sticky.zf.stuckto:\".concat(stickTo));\n      this.$element.on(\"transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd\", function () {\n        _this._setSizes();\n      });\n    }\n    /**\n     * Causes the $element to become unstuck.\n     * Removes `position: fixed;`, and helper classes.\n     * Adds other helper classes.\n     * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.\n     * @fires Sticky#unstuckfrom\n     * @private\n     */\n\n  }, {\n    key: \"_removeSticky\",\n    value: function _removeSticky(isTop) {\n      var stickTo = this.options.stickTo,\n          stickToTop = stickTo === 'top',\n          css = {},\n          anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,\n          mrgn = stickToTop ? 'marginTop' : 'marginBottom',\n          notStuckTo = stickToTop ? 'bottom' : 'top',\n          topOrBottom = isTop ? 'top' : 'bottom';\n      css[mrgn] = 0;\n      css['bottom'] = 'auto';\n\n      if (isTop) {\n        css['top'] = 0;\n      } else {\n        css['top'] = anchorPt;\n      }\n\n      this.isStuck = false;\n      this.$element.removeClass(\"is-stuck is-at-\".concat(stickTo)).addClass(\"is-anchored is-at-\".concat(topOrBottom)).css(css)\n      /**\n       * Fires when the $element has become anchored.\n       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`\n       * @event Sticky#unstuckfrom\n       */\n      .trigger(\"sticky.zf.unstuckfrom:\".concat(topOrBottom));\n    }\n    /**\n     * Sets the $element and $container sizes for plugin.\n     * Calls `_setBreakPoints`.\n     * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.\n     * @private\n     */\n\n  }, {\n    key: \"_setSizes\",\n    value: function _setSizes(cb) {\n      this.canStick = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"].is(this.options.stickyOn);\n\n      if (!this.canStick) {\n        if (cb && typeof cb === 'function') {\n          cb();\n        }\n      }\n\n      var _this = this,\n          newElemWidth = this.$container[0].getBoundingClientRect().width,\n          comp = window.getComputedStyle(this.$container[0]),\n          pdngl = parseInt(comp['padding-left'], 10),\n          pdngr = parseInt(comp['padding-right'], 10);\n\n      if (this.$anchor && this.$anchor.length) {\n        this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;\n      } else {\n        this._parsePoints();\n      }\n\n      this.$element.css({\n        'max-width': \"\".concat(newElemWidth - pdngl - pdngr, \"px\")\n      });\n      var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;\n\n      if (this.$element.css(\"display\") == \"none\") {\n        newContainerHeight = 0;\n      }\n\n      this.containerHeight = newContainerHeight;\n      this.$container.css({\n        height: newContainerHeight\n      });\n      this.elemHeight = newContainerHeight;\n\n      if (!this.isStuck) {\n        if (this.$element.hasClass('is-at-bottom')) {\n          var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;\n          this.$element.css('top', anchorPt);\n        }\n      }\n\n      this._setBreakPoints(newContainerHeight, function () {\n        if (cb && typeof cb === 'function') {\n          cb();\n        }\n      });\n    }\n    /**\n     * Sets the upper and lower breakpoints for the element to become sticky/unsticky.\n     * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.\n     * @param {Function} cb - optional callback function to be called on completion.\n     * @private\n     */\n\n  }, {\n    key: \"_setBreakPoints\",\n    value: function _setBreakPoints(elemHeight, cb) {\n      if (!this.canStick) {\n        if (cb && typeof cb === 'function') {\n          cb();\n        } else {\n          return false;\n        }\n      }\n\n      var mTop = emCalc(this.options.marginTop),\n          mBtm = emCalc(this.options.marginBottom),\n          topPoint = this.points ? this.points[0] : this.$anchor.offset().top,\n          bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,\n          // topPoint = this.$anchor.offset().top || this.points[0],\n      // bottomPoint = topPoint + this.anchorHeight || this.points[1],\n      winHeight = window.innerHeight;\n\n      if (this.options.stickTo === 'top') {\n        topPoint -= mTop;\n        bottomPoint -= elemHeight + mTop;\n      } else if (this.options.stickTo === 'bottom') {\n        topPoint -= winHeight - (elemHeight + mBtm);\n        bottomPoint -= winHeight - mBtm;\n      } else {//this would be the stickTo: both option... tricky\n      }\n\n      this.topPoint = topPoint;\n      this.bottomPoint = bottomPoint;\n\n      if (cb && typeof cb === 'function') {\n        cb();\n      }\n    }\n    /**\n     * Destroys the current sticky element.\n     * Resets the element to the top position first.\n     * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this._removeSticky(true);\n\n      this.$element.removeClass(\"\".concat(this.options.stickyClass, \" is-anchored is-at-top\")).css({\n        height: '',\n        top: '',\n        bottom: '',\n        'max-width': ''\n      }).off('resizeme.zf.trigger').off('mutateme.zf.trigger');\n\n      if (this.$anchor && this.$anchor.length) {\n        this.$anchor.off('change.zf.sticky');\n      }\n\n      if (this.scrollListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.scrollListener);\n      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n\n      if (this.wasWrapped) {\n        this.$element.unwrap();\n      } else {\n        this.$container.removeClass(this.options.containerClass).css({\n          height: ''\n        });\n      }\n    }\n  }]);\n\n  return Sticky;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nSticky.defaults = {\n  /**\n   * Customizable container template. Add your own classes for styling and sizing.\n   * @option\n   * @type {string}\n   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'\n   */\n  container: '<div data-sticky-container></div>',\n\n  /**\n   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default 'top'\n   */\n  stickTo: 'top',\n\n  /**\n   * If anchored to a single element, the id of that element.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  anchor: '',\n\n  /**\n   * If using more than one element as anchor points, the id of the top anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  topAnchor: '',\n\n  /**\n   * If using more than one element as anchor points, the id of the bottom anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  btmAnchor: '',\n\n  /**\n   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginTop: 1,\n\n  /**\n   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginBottom: 1,\n\n  /**\n   * Breakpoint string that is the minimum screen size an element should become sticky.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  stickyOn: 'medium',\n\n  /**\n   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.\n   * @option\n   * @type {string}\n   * @default 'sticky'\n   */\n  stickyClass: 'sticky',\n\n  /**\n   * Class applied to sticky container. Foundation defaults to `sticky-container`.\n   * @option\n   * @type {string}\n   * @default 'sticky-container'\n   */\n  containerClass: 'sticky-container',\n\n  /**\n   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.\n   * @option\n   * @type {number}\n   * @default -1\n   */\n  checkEvery: -1\n};\n/**\n * Helper function to calculate em values\n * @param Number {em} - number of em's to calculate into pixels\n */\n\nfunction emCalc(em) {\n  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.tabs.js\":\n/*!*******************************!*\\\n  !*** ./js/foundation.tabs.js ***!\n  \\*******************************/\n/*! exports provided: Tabs */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Tabs\", function() { return Tabs; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.imageLoader */ \"./js/foundation.util.imageLoader.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.imageLoader if tabs contain images\n */\n\nvar Tabs =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Tabs, _Plugin);\n\n  function Tabs() {\n    _classCallCheck(this, Tabs);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments));\n  }\n\n  _createClass(Tabs, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of tabs.\n     * @class\n     * @name Tabs\n     * @fires Tabs#init\n     * @param {jQuery} element - jQuery object to make into tabs.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tabs.defaults, this.$element.data(), options);\n      this.className = 'Tabs'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('Tabs', {\n        'ENTER': 'open',\n        'SPACE': 'open',\n        'ARROW_RIGHT': 'next',\n        'ARROW_UP': 'previous',\n        'ARROW_DOWN': 'next',\n        'ARROW_LEFT': 'previous' // 'TAB': 'next',\n        // 'SHIFT_TAB': 'previous'\n\n      });\n    }\n    /**\n     * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var _this2 = this;\n\n      var _this = this;\n\n      this._isInitializing = true;\n      this.$element.attr({\n        'role': 'tablist'\n      });\n      this.$tabTitles = this.$element.find(\".\".concat(this.options.linkClass));\n      this.$tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-tabs-content=\\\"\".concat(this.$element[0].id, \"\\\"]\"));\n      this.$tabTitles.each(function () {\n        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $link = $elem.find('a'),\n            isActive = $elem.hasClass(\"\".concat(_this.options.linkActiveClass)),\n            hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),\n            linkId = $link[0].id ? $link[0].id : \"\".concat(hash, \"-label\"),\n            $tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(hash));\n        $elem.attr({\n          'role': 'presentation'\n        });\n        $link.attr({\n          'role': 'tab',\n          'aria-controls': hash,\n          'aria-selected': isActive,\n          'id': linkId,\n          'tabindex': isActive ? '0' : '-1'\n        });\n        $tabContent.attr({\n          'role': 'tabpanel',\n          'aria-labelledby': linkId\n        }); // Save up the initial hash to return to it later when going back in history\n\n        if (isActive) {\n          _this._initialAnchor = \"#\".concat(hash);\n        }\n\n        if (!isActive) {\n          $tabContent.attr('aria-hidden', 'true');\n        }\n\n        if (isActive && _this.options.autoFocus) {\n          _this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({\n              scrollTop: $elem.offset().top\n            }, _this.options.deepLinkSmudgeDelay, function () {\n              $link.focus();\n            });\n          });\n        }\n      });\n\n      if (this.options.matchHeight) {\n        var $images = this.$tabContent.find('img');\n\n        if ($images.length) {\n          Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__[\"onImagesLoaded\"])($images, this._setHeight.bind(this));\n        } else {\n          this._setHeight();\n        }\n      } // Current context-bound function to open tabs on page load or history hashchange\n\n\n      this._checkDeepLink = function () {\n        var anchor = window.location.hash;\n\n        if (!anchor.length) {\n          // If we are still initializing and there is no anchor, then there is nothing to do\n          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor\n\n          if (_this2._initialAnchor) anchor = _this2._initialAnchor;\n        }\n\n        var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor);\n\n        var $link = anchor && _this2.$element.find('[href$=\"' + anchor + '\"]'); // Whether the anchor element that has been found is part of this element\n\n\n        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, select it\n\n        if ($anchor && $anchor.length && $link && $link.length) {\n          _this2.selectTab($anchor, true);\n        } // Otherwise, collapse everything\n        else {\n            _this2._collapse();\n          }\n\n        if (isOwnAnchor) {\n          // Roll up a little to show the titles\n          if (_this2.options.deepLinkSmudge) {\n            var offset = _this2.$element.offset();\n\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({\n              scrollTop: offset.top\n            }, _this2.options.deepLinkSmudgeDelay);\n          }\n          /**\n           * Fires when the plugin has deeplinked at pageload\n           * @event Tabs#deeplink\n           */\n\n\n          _this2.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);\n        }\n      }; //use browser to open a tab, if it exists in this tabset\n\n\n      if (this.options.deepLink) {\n        this._checkDeepLink();\n      }\n\n      this._events();\n\n      this._isInitializing = false;\n    }\n    /**\n     * Adds event handlers for items within the tabs.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this._addKeyHandler();\n\n      this._addClickHandler();\n\n      this._setHeightMqHandler = null;\n\n      if (this.options.matchHeight) {\n        this._setHeightMqHandler = this._setHeight.bind(this);\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._setHeightMqHandler);\n      }\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink);\n      }\n    }\n    /**\n     * Adds click handlers for items within the tabs.\n     * @private\n     */\n\n  }, {\n    key: \"_addClickHandler\",\n    value: function _addClickHandler() {\n      var _this = this;\n\n      this.$element.off('click.zf.tabs').on('click.zf.tabs', \".\".concat(this.options.linkClass), function (e) {\n        e.preventDefault();\n        e.stopPropagation();\n\n        _this._handleTabChange(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n      });\n    }\n    /**\n     * Adds keyboard event handlers for items within the tabs.\n     * @private\n     */\n\n  }, {\n    key: \"_addKeyHandler\",\n    value: function _addKeyHandler() {\n      var _this = this;\n\n      this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) {\n        if (e.which === 9) return;\n        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $elements = $element.parent('ul').children('li'),\n            $prevElement,\n            $nextElement;\n        $elements.each(function (i) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {\n            if (_this.options.wrapOnKeys) {\n              $prevElement = i === 0 ? $elements.last() : $elements.eq(i - 1);\n              $nextElement = i === $elements.length - 1 ? $elements.first() : $elements.eq(i + 1);\n            } else {\n              $prevElement = $elements.eq(Math.max(0, i - 1));\n              $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));\n            }\n\n            return;\n          }\n        }); // handle keyboard event with keyboard util\n\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'Tabs', {\n          open: function open() {\n            $element.find('[role=\"tab\"]').focus();\n\n            _this._handleTabChange($element);\n          },\n          previous: function previous() {\n            $prevElement.find('[role=\"tab\"]').focus();\n\n            _this._handleTabChange($prevElement);\n          },\n          next: function next() {\n            $nextElement.find('[role=\"tab\"]').focus();\n\n            _this._handleTabChange($nextElement);\n          },\n          handled: function handled() {\n            e.stopPropagation();\n            e.preventDefault();\n          }\n        });\n      });\n    }\n    /**\n     * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.\n     * @param {jQuery} $target - Tab to open.\n     * @param {boolean} historyHandled - browser has already handled a history update\n     * @fires Tabs#change\n     * @function\n     */\n\n  }, {\n    key: \"_handleTabChange\",\n    value: function _handleTabChange($target, historyHandled) {\n      // With `activeCollapse`, if the target is the active Tab, collapse it.\n      if ($target.hasClass(\"\".concat(this.options.linkActiveClass))) {\n        if (this.options.activeCollapse) {\n          this._collapse();\n        }\n\n        return;\n      }\n\n      var $oldTab = this.$element.find(\".\".concat(this.options.linkClass, \".\").concat(this.options.linkActiveClass)),\n          $tabLink = $target.find('[role=\"tab\"]'),\n          target = $tabLink.attr('data-tabs-target'),\n          anchor = target && target.length ? \"#\".concat(target) : $tabLink[0].hash,\n          $targetContent = this.$tabContent.find(anchor); //close old tab\n\n      this._collapseTab($oldTab); //open new tab\n\n\n      this._openTab($target); //either replace or update browser history\n\n\n      if (this.options.deepLink && !historyHandled) {\n        if (this.options.updateHistory) {\n          history.pushState({}, '', anchor);\n        } else {\n          history.replaceState({}, '', anchor);\n        }\n      }\n      /**\n       * Fires when the plugin has successfully changed tabs.\n       * @event Tabs#change\n       */\n\n\n      this.$element.trigger('change.zf.tabs', [$target, $targetContent]); //fire to children a mutation event\n\n      $targetContent.find(\"[data-mutate]\").trigger(\"mutateme.zf.trigger\");\n    }\n    /**\n     * Opens the tab `$targetContent` defined by `$target`.\n     * @param {jQuery} $target - Tab to open.\n     * @function\n     */\n\n  }, {\n    key: \"_openTab\",\n    value: function _openTab($target) {\n      var $tabLink = $target.find('[role=\"tab\"]'),\n          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),\n          $targetContent = this.$tabContent.find(\"#\".concat(hash));\n      $target.addClass(\"\".concat(this.options.linkActiveClass));\n      $tabLink.attr({\n        'aria-selected': 'true',\n        'tabindex': '0'\n      });\n      $targetContent.addClass(\"\".concat(this.options.panelActiveClass)).removeAttr('aria-hidden');\n    }\n    /**\n     * Collapses `$targetContent` defined by `$target`.\n     * @param {jQuery} $target - Tab to collapse.\n     * @function\n     */\n\n  }, {\n    key: \"_collapseTab\",\n    value: function _collapseTab($target) {\n      var $target_anchor = $target.removeClass(\"\".concat(this.options.linkActiveClass)).find('[role=\"tab\"]').attr({\n        'aria-selected': 'false',\n        'tabindex': -1\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat($target_anchor.attr('aria-controls'))).removeClass(\"\".concat(this.options.panelActiveClass)).attr({\n        'aria-hidden': 'true'\n      });\n    }\n    /**\n     * Collapses the active Tab.\n     * @fires Tabs#collapse\n     * @function\n     */\n\n  }, {\n    key: \"_collapse\",\n    value: function _collapse() {\n      var $activeTab = this.$element.find(\".\".concat(this.options.linkClass, \".\").concat(this.options.linkActiveClass));\n\n      if ($activeTab.length) {\n        this._collapseTab($activeTab);\n        /**\n        * Fires when the plugin has successfully collapsed tabs.\n        * @event Tabs#collapse\n        */\n\n\n        this.$element.trigger('collapse.zf.tabs', [$activeTab]);\n      }\n    }\n    /**\n     * Public method for selecting a content pane to display.\n     * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.\n     * @param {boolean} historyHandled - browser has already handled a history update\n     * @function\n     */\n\n  }, {\n    key: \"selectTab\",\n    value: function selectTab(elem, historyHandled) {\n      var idStr;\n\n      if (_typeof(elem) === 'object') {\n        idStr = elem[0].id;\n      } else {\n        idStr = elem;\n      }\n\n      if (idStr.indexOf('#') < 0) {\n        idStr = \"#\".concat(idStr);\n      }\n\n      var $target = this.$tabTitles.has(\"[href$=\\\"\".concat(idStr, \"\\\"]\"));\n\n      this._handleTabChange($target, historyHandled);\n    }\n  }, {\n    key: \"_setHeight\",\n\n    /**\n     * Sets the height of each panel to the height of the tallest panel.\n     * If enabled in options, gets called on media query change.\n     * If loading content via external source, can be called directly or with _reflow.\n     * If enabled with `data-match-height=\"true\"`, tabs sets to equal height\n     * @function\n     * @private\n     */\n    value: function _setHeight() {\n      var max = 0,\n          _this = this; // Lock down the `this` value for the root tabs object\n\n\n      this.$tabContent.find(\".\".concat(this.options.panelClass)).css('height', '').each(function () {\n        var panel = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            isActive = panel.hasClass(\"\".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child\n\n        if (!isActive) {\n          panel.css({\n            'visibility': 'hidden',\n            'display': 'block'\n          });\n        }\n\n        var temp = this.getBoundingClientRect().height;\n\n        if (!isActive) {\n          panel.css({\n            'visibility': '',\n            'display': ''\n          });\n        }\n\n        max = temp > max ? temp : max;\n      }).css('height', \"\".concat(max, \"px\"));\n    }\n    /**\n     * Destroys an instance of tabs.\n     * @fires Tabs#destroyed\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.find(\".\".concat(this.options.linkClass)).off('.zf.tabs').hide().end().find(\".\".concat(this.options.panelClass)).hide();\n\n      if (this.options.matchHeight) {\n        if (this._setHeightMqHandler != null) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._setHeightMqHandler);\n        }\n      }\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink);\n      }\n\n      if (this.onLoadListener) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n      }\n    }\n  }]);\n\n  return Tabs;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_4__[\"Plugin\"]);\n\nTabs.defaults = {\n  /**\n   * Link the location hash to the active pane.\n   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open tab\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n   * Allows the window to scroll to content of active pane on load.\n   * Not recommended if more than one tab panel per page.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows keyboard input to 'wrap' around the tab links.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  wrapOnKeys: true,\n\n  /**\n   * Allows the tab content panes to match heights if set to true.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  matchHeight: false,\n\n  /**\n   * Allows active tabs to collapse when clicked.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  activeCollapse: false,\n\n  /**\n   * Class applied to `li`'s in tab link list.\n   * @option\n   * @type {string}\n   * @default 'tabs-title'\n   */\n  linkClass: 'tabs-title',\n\n  /**\n   * Class applied to the active `li` in tab link list.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  linkActiveClass: 'is-active',\n\n  /**\n   * Class applied to the content containers.\n   * @option\n   * @type {string}\n   * @default 'tabs-panel'\n   */\n  panelClass: 'tabs-panel',\n\n  /**\n   * Class applied to the active content container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  panelActiveClass: 'is-active'\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.toggler.js\":\n/*!**********************************!*\\\n  !*** ./js/foundation.toggler.js ***!\n  \\**********************************/\n/*! exports provided: Toggler */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Toggler\", function() { return Toggler; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.motion */ \"./js/foundation.util.motion.js\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nvar Toggler =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Toggler, _Plugin);\n\n  function Toggler() {\n    _classCallCheck(this, Toggler);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Toggler).apply(this, arguments));\n  }\n\n  _createClass(Toggler, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Toggler.\n     * @class\n     * @name Toggler\n     * @fires Toggler#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Toggler.defaults, element.data(), options);\n      this.className = '';\n      this.className = 'Toggler'; // ie9 back compat\n      // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var input; // Parse animation classes if they were set\n\n      if (this.options.animate) {\n        input = this.options.animate.split(' ');\n        this.animationIn = input[0];\n        this.animationOut = input[1] || null;\n      } // Otherwise, parse toggle class\n      else {\n          input = this.$element.data('toggler'); // Allow for a . at the beginning of the string\n\n          this.className = input[0] === '.' ? input.slice(1) : input;\n        } // Add ARIA attributes to triggers:\n\n\n      var id = this.$element[0].id,\n          $triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open~=\\\"\".concat(id, \"\\\"], [data-close~=\\\"\").concat(id, \"\\\"], [data-toggle~=\\\"\").concat(id, \"\\\"]\")); // - aria-expanded: according to the element visibility.\n\n      $triggers.attr('aria-expanded', !this.$element.is(':hidden')); // - aria-controls: adding the element id to it if not already in it.\n\n      $triggers.each(function (index, trigger) {\n        var $trigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()(trigger);\n        var controls = $trigger.attr('aria-controls') || '';\n        var containsId = new RegExp(\"\\\\b\".concat(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"RegExpEscape\"])(id), \"\\\\b\")).test(controls);\n        if (!containsId) $trigger.attr('aria-controls', controls ? \"\".concat(controls, \" \").concat(id) : id);\n      });\n    }\n    /**\n     * Initializes events for the toggle trigger.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));\n    }\n    /**\n     * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was \"on\" or \"off\".\n     * @function\n     * @fires Toggler#on\n     * @fires Toggler#off\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle() {\n      this[this.options.animate ? '_toggleAnimate' : '_toggleClass']();\n    }\n  }, {\n    key: \"_toggleClass\",\n    value: function _toggleClass() {\n      this.$element.toggleClass(this.className);\n      var isOn = this.$element.hasClass(this.className);\n\n      if (isOn) {\n        /**\n         * Fires if the target element has the class after a toggle.\n         * @event Toggler#on\n         */\n        this.$element.trigger('on.zf.toggler');\n      } else {\n        /**\n         * Fires if the target element does not have the class after a toggle.\n         * @event Toggler#off\n         */\n        this.$element.trigger('off.zf.toggler');\n      }\n\n      this._updateARIA(isOn);\n\n      this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');\n    }\n  }, {\n    key: \"_toggleAnimate\",\n    value: function _toggleAnimate() {\n      var _this = this;\n\n      if (this.$element.is(':hidden')) {\n        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__[\"Motion\"].animateIn(this.$element, this.animationIn, function () {\n          _this._updateARIA(true);\n\n          this.trigger('on.zf.toggler');\n          this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        });\n      } else {\n        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__[\"Motion\"].animateOut(this.$element, this.animationOut, function () {\n          _this._updateARIA(false);\n\n          this.trigger('off.zf.toggler');\n          this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        });\n      }\n    }\n  }, {\n    key: \"_updateARIA\",\n    value: function _updateARIA(isOn) {\n      var id = this.$element[0].id;\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open=\\\"\".concat(id, \"\\\"], [data-close=\\\"\").concat(id, \"\\\"], [data-toggle=\\\"\").concat(id, \"\\\"]\")).attr({\n        'aria-expanded': isOn ? true : false\n      });\n    }\n    /**\n     * Destroys the instance of Toggler on the element.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.toggler');\n    }\n  }]);\n\n  return Toggler;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]);\n\nToggler.defaults = {\n  /**\n   * Tells the plugin if the element should animated when toggled.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.tooltip.js\":\n/*!**********************************!*\\\n  !*** ./js/foundation.tooltip.js ***!\n  \\**********************************/\n/*! exports provided: Tooltip */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Tooltip\", function() { return Tooltip; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n/* harmony import */ var _foundation_positionable__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.positionable */ \"./js/foundation.positionable.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _get(target, property, receiver) { if (typeof Reflect !== \"undefined\" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); }\n\nfunction _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Tooltip module.\n * @module foundation.tooltip\n * @requires foundation.util.box\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nvar Tooltip =\n/*#__PURE__*/\nfunction (_Positionable) {\n  _inherits(Tooltip, _Positionable);\n\n  function Tooltip() {\n    _classCallCheck(this, Tooltip);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments));\n  }\n\n  _createClass(Tooltip, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a Tooltip.\n     * @class\n     * @name Tooltip\n     * @fires Tooltip#init\n     * @param {jQuery} element - jQuery object to attach a tooltip to.\n     * @param {Object} options - object to extend the default configuration.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tooltip.defaults, this.$element.data(), options);\n      this.className = 'Tooltip'; // ie9 back compat\n\n      this.isActive = false;\n      this.isClick = false; // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n    }\n    /**\n     * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"]._init();\n\n      var elemId = this.$element.attr('aria-describedby') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'tooltip');\n      this.options.tipText = this.options.tipText || this.$element.attr('title');\n      this.template = this.options.template ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.template) : this._buildTemplate(elemId);\n\n      if (this.options.allowHtml) {\n        this.template.appendTo(document.body).html(this.options.tipText).hide();\n      } else {\n        this.template.appendTo(document.body).text(this.options.tipText).hide();\n      }\n\n      this.$element.attr({\n        'title': '',\n        'aria-describedby': elemId,\n        'data-yeti-box': elemId,\n        'data-toggle': elemId,\n        'data-resize': elemId\n      }).addClass(this.options.triggerClass);\n\n      _get(_getPrototypeOf(Tooltip.prototype), \"_init\", this).call(this);\n\n      this._events();\n    }\n  }, {\n    key: \"_getDefaultPosition\",\n    value: function _getDefaultPosition() {\n      // handle legacy classnames\n      var position = this.$element[0].className.match(/\\b(top|left|right|bottom)\\b/g);\n      return position ? position[0] : 'top';\n    }\n  }, {\n    key: \"_getDefaultAlignment\",\n    value: function _getDefaultAlignment() {\n      return 'center';\n    }\n  }, {\n    key: \"_getHOffset\",\n    value: function _getHOffset() {\n      if (this.position === 'left' || this.position === 'right') {\n        return this.options.hOffset + this.options.tooltipWidth;\n      } else {\n        return this.options.hOffset;\n      }\n    }\n  }, {\n    key: \"_getVOffset\",\n    value: function _getVOffset() {\n      if (this.position === 'top' || this.position === 'bottom') {\n        return this.options.vOffset + this.options.tooltipHeight;\n      } else {\n        return this.options.vOffset;\n      }\n    }\n    /**\n     * builds the tooltip element, adds attributes, and returns the template.\n     * @private\n     */\n\n  }, {\n    key: \"_buildTemplate\",\n    value: function _buildTemplate(id) {\n      var templateClasses = \"\".concat(this.options.tooltipClass, \" \").concat(this.options.templateClasses).trim();\n      var $template = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div></div>').addClass(templateClasses).attr({\n        'role': 'tooltip',\n        'aria-hidden': true,\n        'data-is-active': false,\n        'data-is-focus': false,\n        'id': id\n      });\n      return $template;\n    }\n    /**\n     * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.\n     * if the tooltip is larger than the screen width, default to full width - any user selected margin\n     * @private\n     */\n\n  }, {\n    key: \"_setPosition\",\n    value: function _setPosition() {\n      _get(_getPrototypeOf(Tooltip.prototype), \"_setPosition\", this).call(this, this.$element, this.template);\n    }\n    /**\n     * reveals the tooltip, and fires an event to close any other open tooltips on the page\n     * @fires Tooltip#closeme\n     * @fires Tooltip#show\n     * @function\n     */\n\n  }, {\n    key: \"show\",\n    value: function show() {\n      if (this.options.showOn !== 'all' && !_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"].is(this.options.showOn)) {\n        // console.error('The screen is too small to display this tooltip');\n        return false;\n      }\n\n      var _this = this;\n\n      this.template.css('visibility', 'hidden').show();\n\n      this._setPosition();\n\n      this.template.removeClass('top bottom left right').addClass(this.position);\n      this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);\n      /**\n       * Fires to close all other open tooltips on the page\n       * @event Closeme#tooltip\n       */\n\n      this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));\n      this.template.attr({\n        'data-is-active': true,\n        'aria-hidden': false\n      });\n      _this.isActive = true; // console.log(this.template);\n\n      this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {//maybe do stuff?\n      });\n      /**\n       * Fires when the tooltip is shown\n       * @event Tooltip#show\n       */\n\n      this.$element.trigger('show.zf.tooltip');\n    }\n    /**\n     * Hides the current tooltip, and resets the positioning class if it was changed due to collision\n     * @fires Tooltip#hide\n     * @function\n     */\n\n  }, {\n    key: \"hide\",\n    value: function hide() {\n      // console.log('hiding', this.$element.data('yeti-box'));\n      var _this = this;\n\n      this.template.stop().attr({\n        'aria-hidden': true,\n        'data-is-active': false\n      }).fadeOut(this.options.fadeOutDuration, function () {\n        _this.isActive = false;\n        _this.isClick = false;\n      });\n      /**\n       * fires when the tooltip is hidden\n       * @event Tooltip#hide\n       */\n\n      this.$element.trigger('hide.zf.tooltip');\n    }\n    /**\n     * adds event listeners for the tooltip and its anchor\n     * TODO combine some of the listeners like focus and mouseenter, etc.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      var $template = this.template;\n      var isFocus = false;\n\n      if (!this.options.disableHover) {\n        this.$element.on('mouseenter.zf.tooltip', function (e) {\n          if (!_this.isActive) {\n            _this.timeout = setTimeout(function () {\n              _this.show();\n            }, _this.options.hoverDelay);\n          }\n        }).on('mouseleave.zf.tooltip', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"ignoreMousedisappear\"])(function (e) {\n          clearTimeout(_this.timeout);\n\n          if (!isFocus || _this.isClick && !_this.options.clickOpen) {\n            _this.hide();\n          }\n        }));\n      }\n\n      if (this.options.clickOpen) {\n        this.$element.on('mousedown.zf.tooltip', function (e) {\n          e.stopImmediatePropagation();\n\n          if (_this.isClick) {//_this.hide();\n            // _this.isClick = false;\n          } else {\n            _this.isClick = true;\n\n            if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {\n              _this.show();\n            }\n          }\n        });\n      } else {\n        this.$element.on('mousedown.zf.tooltip', function (e) {\n          e.stopImmediatePropagation();\n          _this.isClick = true;\n        });\n      }\n\n      if (!this.options.disableForTouch) {\n        this.$element.on('tap.zf.tooltip touchend.zf.tooltip', function (e) {\n          _this.isActive ? _this.hide() : _this.show();\n        });\n      }\n\n      this.$element.on({\n        // 'toggle.zf.trigger': this.toggle.bind(this),\n        // 'close.zf.trigger': this.hide.bind(this)\n        'close.zf.trigger': this.hide.bind(this)\n      });\n      this.$element.on('focus.zf.tooltip', function (e) {\n        isFocus = true;\n\n        if (_this.isClick) {\n          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't\n          // a real focus, otherwise on hover and come back we get bad behavior\n          if (!_this.options.clickOpen) {\n            isFocus = false;\n          }\n\n          return false;\n        } else {\n          _this.show();\n        }\n      }).on('focusout.zf.tooltip', function (e) {\n        isFocus = false;\n        _this.isClick = false;\n\n        _this.hide();\n      }).on('resizeme.zf.trigger', function () {\n        if (_this.isActive) {\n          _this._setPosition();\n        }\n      });\n    }\n    /**\n     * adds a toggle method, in addition to the static show() & hide() functions\n     * @function\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle() {\n      if (this.isActive) {\n        this.hide();\n      } else {\n        this.show();\n      }\n    }\n    /**\n     * Destroys an instance of tooltip, removes template element from the view.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass(this.options.triggerClass).removeClass('top right left bottom').removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n      this.template.remove();\n    }\n  }]);\n\n  return Tooltip;\n}(_foundation_positionable__WEBPACK_IMPORTED_MODULE_4__[\"Positionable\"]);\n\nTooltip.defaults = {\n  disableForTouch: false,\n\n  /**\n   * Time, in ms, before a tooltip should open on hover.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  hoverDelay: 200,\n\n  /**\n   * Time, in ms, a tooltip should take to fade into view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeInDuration: 150,\n\n  /**\n   * Time, in ms, a tooltip should take to fade out of view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeOutDuration: 150,\n\n  /**\n   * Disables hover events from opening the tooltip if set to true\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n\n  /**\n   * Optional addtional classes to apply to the tooltip template on init.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  templateClasses: '',\n\n  /**\n   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.\n   * @option\n   * @type {string}\n   * @default 'tooltip'\n   */\n  tooltipClass: 'tooltip',\n\n  /**\n   * Class applied to the tooltip anchor element.\n   * @option\n   * @type {string}\n   * @default 'has-tip'\n   */\n  triggerClass: 'has-tip',\n\n  /**\n   * Minimum breakpoint size at which to open the tooltip.\n   * @option\n   * @type {string}\n   * @default 'small'\n   */\n  showOn: 'small',\n\n  /**\n   * Custom template to be used to generate markup for tooltip.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  template: '',\n\n  /**\n   * Text displayed in the tooltip template on open.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  tipText: '',\n  touchCloseText: 'Tap to close.',\n\n  /**\n   * Allows the tooltip to remain open if triggered with a click or touch event.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickOpen: true,\n\n  /**\n   * Position of tooltip. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n\n  /**\n   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow overlap of container/window. If false, tooltip will first try to\n   * position as defined by data-position and data-alignment, but reposition if\n   * it would cause an overflow.  @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * Less common for tooltips.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowBottomOverlap: false,\n\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the Y axis.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the X axis\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip\n   * @option\n   * @type {number}\n   * @default 14\n   */\n  tooltipHeight: 14,\n\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip\n   * @option\n   * @type {number}\n   * @default 12\n   */\n  tooltipWidth: 12,\n\n  /**\n  * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,\n  * allowing HTML may open yourself up to XSS attacks.\n  * @option\n  * @type {boolean}\n  * @default false\n  */\n  allowHtml: false\n};\n/**\n * TODO utilize resize event trigger\n */\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.box.js\":\n/*!***********************************!*\\\n  !*** ./js/foundation.util.box.js ***!\n  \\***********************************/\n/*! exports provided: Box */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Box\", function() { return Box; });\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n\n\n\nvar Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  OverlapArea: OverlapArea,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets,\n  GetExplicitOffsets: GetExplicitOffsets\n  /**\n   * Compares the dimensions of an element to a container and determines collision events with container.\n   * @function\n   * @param {jQuery} element - jQuery object to test for collisions.\n   * @param {jQuery} parent - jQuery object to use as bounding container.\n   * @param {Boolean} lrOnly - set to true to check left and right values only.\n   * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n   * @default if no parent object passed, detects collisions with `window`.\n   * @returns {Boolean} - true if collision free, false if a collision in any direction.\n   */\n\n};\n\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n}\n\n;\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  var eleDims = GetDimensions(element),\n      topOver,\n      bottomOver,\n      leftOver,\n      rightOver;\n\n  if (parent) {\n    var parDims = GetDimensions(parent);\n    bottomOver = parDims.height + parDims.offset.top - (eleDims.offset.top + eleDims.height);\n    topOver = eleDims.offset.top - parDims.offset.top;\n    leftOver = eleDims.offset.left - parDims.offset.left;\n    rightOver = parDims.width + parDims.offset.left - (eleDims.offset.left + eleDims.width);\n  } else {\n    bottomOver = eleDims.windowDims.height + eleDims.windowDims.offset.top - (eleDims.offset.top + eleDims.height);\n    topOver = eleDims.offset.top - eleDims.windowDims.offset.top;\n    leftOver = eleDims.offset.left - eleDims.windowDims.offset.left;\n    rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n  }\n\n  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n  topOver = Math.min(topOver, 0);\n  leftOver = Math.min(leftOver, 0);\n  rightOver = Math.min(rightOver, 0);\n\n  if (lrOnly) {\n    return leftOver + rightOver;\n  }\n\n  if (tbOnly) {\n    return topOver + bottomOver;\n  } // use sum of squares b/c we care about overlap area.\n\n\n  return Math.sqrt(topOver * topOver + bottomOver * bottomOver + leftOver * leftOver + rightOver * rightOver);\n}\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\n\n\nfunction GetDimensions(elem) {\n  elem = elem.length ? elem[0] : elem;\n\n  if (elem === window || elem === document) {\n    throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n  }\n\n  var rect = elem.getBoundingClientRect(),\n      parRect = elem.parentNode.getBoundingClientRect(),\n      winRect = document.body.getBoundingClientRect(),\n      winY = window.pageYOffset,\n      winX = window.pageXOffset;\n  return {\n    width: rect.width,\n    height: rect.height,\n    offset: {\n      top: rect.top + winY,\n      left: rect.left + winX\n    },\n    parentDims: {\n      width: parRect.width,\n      height: parRect.height,\n      offset: {\n        top: parRect.top + winY,\n        left: parRect.left + winX\n      }\n    },\n    windowDims: {\n      width: winRect.width,\n      height: winRect.height,\n      offset: {\n        top: winY,\n        left: winX\n      }\n    }\n  };\n}\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\n\n\nfunction GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {\n  console.log(\"NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5\");\n\n  switch (position) {\n    case 'top':\n      return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__[\"rtl\"])() ? GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);\n\n    case 'bottom':\n      return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__[\"rtl\"])() ? GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n\n    case 'center top':\n      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);\n\n    case 'center bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);\n\n    case 'center left':\n      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);\n\n    case 'center right':\n      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);\n\n    case 'left bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);\n\n    case 'right bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    // Backwards compatibility... this along with the reveal and reveal full\n    // classes are the only ones that didn't reference anchor\n\n    case 'center':\n      return {\n        left: $eleDims.windowDims.offset.left + $eleDims.windowDims.width / 2 - $eleDims.width / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + $eleDims.windowDims.height / 2 - ($eleDims.height / 2 + vOffset)\n      };\n\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + vOffset\n      };\n\n    case 'reveal full':\n      return {\n        left: $eleDims.windowDims.offset.left,\n        top: $eleDims.windowDims.offset.top\n      };\n      break;\n\n    default:\n      return {\n        left: Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__[\"rtl\"])() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset : $anchorDims.offset.left + hOffset,\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      };\n  }\n}\n\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n  var topVal, leftVal; // set position related attribute\n\n  switch (position) {\n    case 'top':\n      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n      break;\n\n    case 'bottom':\n      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n      break;\n\n    case 'left':\n      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n      break;\n\n    case 'right':\n      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n      break;\n  } // set alignment related attribute\n\n\n  switch (position) {\n    case 'top':\n    case 'bottom':\n      switch (alignment) {\n        case 'left':\n          leftVal = $anchorDims.offset.left + hOffset;\n          break;\n\n        case 'right':\n          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n          break;\n\n        case 'center':\n          leftVal = isOverflow ? hOffset : $anchorDims.offset.left + $anchorDims.width / 2 - $eleDims.width / 2 + hOffset;\n          break;\n      }\n\n      break;\n\n    case 'right':\n    case 'left':\n      switch (alignment) {\n        case 'bottom':\n          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n          break;\n\n        case 'top':\n          topVal = $anchorDims.offset.top + vOffset;\n          break;\n\n        case 'center':\n          topVal = $anchorDims.offset.top + vOffset + $anchorDims.height / 2 - $eleDims.height / 2;\n          break;\n      }\n\n      break;\n  }\n\n  return {\n    top: topVal,\n    left: leftVal\n  };\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.imageLoader.js\":\n/*!*******************************************!*\\\n  !*** ./js/foundation.util.imageLoader.js ***!\n  \\*******************************************/\n/*! exports provided: onImagesLoaded */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"onImagesLoaded\", function() { return onImagesLoaded; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\n\nfunction onImagesLoaded(images, callback) {\n  var self = this,\n      unloaded = images.length;\n\n  if (unloaded === 0) {\n    callback();\n  }\n\n  images.each(function () {\n    // Check if image is loaded\n    if (this.complete && typeof this.naturalWidth !== 'undefined') {\n      singleImageLoaded();\n    } else {\n      // If the above check failed, simulate loading on detached element.\n      var image = new Image(); // Still count image as loaded if it finalizes with an error.\n\n      var events = \"load.zf.images error.zf.images\";\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(image).one(events, function me(event) {\n        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off(events, me);\n        singleImageLoaded();\n      });\n      image.src = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('src');\n    }\n  });\n\n  function singleImageLoaded() {\n    unloaded--;\n\n    if (unloaded === 0) {\n      callback();\n    }\n  }\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.keyboard.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.keyboard.js ***!\n  \\****************************************/\n/*! exports provided: Keyboard */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Keyboard\", function() { return Keyboard; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/*******************************************\n *                                         *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n *                                         *\n ******************************************/\n\n\n\n\nvar keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  35: 'END',\n  36: 'HOME',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n};\nvar commands = {}; // Functions pulled out to be referenceable from internals\n\nfunction findFocusable($element) {\n  if (!$element) {\n    return false;\n  }\n\n  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function () {\n    if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':visible') || jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('tabindex') < 0) {\n      return false;\n    } //only have visible elements and those that have a tabindex greater or equal 0\n\n\n    return true;\n  });\n}\n\nfunction parseKey(event) {\n  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase(); // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n\n  key = key.replace(/\\W+/, '');\n  if (event.shiftKey) key = \"SHIFT_\".concat(key);\n  if (event.ctrlKey) key = \"CTRL_\".concat(key);\n  if (event.altKey) key = \"ALT_\".concat(key); // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n\n  key = key.replace(/_$/, '');\n  return key;\n}\n\nvar Keyboard = {\n  keys: getKeyCodes(keyCodes),\n\n  /**\n   * Parses the (keyboard) event and returns a String that represents its key\n   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n   * @param {Event} event - the event generated by the event handler\n   * @return String key - String that represents the key pressed\n   */\n  parseKey: parseKey,\n\n  /**\n   * Handles the given (keyboard) event\n   * @param {Event} event - the event generated by the event handler\n   * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n   * @param {Objects} functions - collection of functions that are to be executed\n   */\n  handleKey: function handleKey(event, component, functions) {\n    var commandList = commands[component],\n        keyCode = this.parseKey(event),\n        cmds,\n        command,\n        fn;\n    if (!commandList) return console.warn('Component not defined!');\n\n    if (typeof commandList.ltr === 'undefined') {\n      // this component does not differentiate between ltr and rtl\n      cmds = commandList; // use plain list\n    } else {\n      // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n      if (Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"rtl\"])()) cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.ltr, commandList.rtl);else cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.rtl, commandList.ltr);\n    }\n\n    command = cmds[keyCode];\n    fn = functions[command];\n\n    if (fn && typeof fn === 'function') {\n      // execute function  if exists\n      var returnValue = fn.apply();\n\n      if (functions.handled || typeof functions.handled === 'function') {\n        // execute function when event was handled\n        functions.handled(returnValue);\n      }\n    } else {\n      if (functions.unhandled || typeof functions.unhandled === 'function') {\n        // execute function when event was not handled\n        functions.unhandled();\n      }\n    }\n  },\n\n  /**\n   * Finds all focusable elements within the given `$element`\n   * @param {jQuery} $element - jQuery object to search within\n   * @return {jQuery} $focusable - all focusable elements within `$element`\n   */\n  findFocusable: findFocusable,\n\n  /**\n   * Returns the component name name\n   * @param {Object} component - Foundation component, e.g. Slider or Reveal\n   * @return String componentName\n   */\n  register: function register(componentName, cmds) {\n    commands[componentName] = cmds;\n  },\n  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n  //\n\n  /**\n   * Traps the focus in the given element.\n   * @param  {jQuery} $element  jQuery object to trap the foucs into.\n   */\n  trapFocus: function trapFocus($element) {\n    var $focusable = findFocusable($element),\n        $firstFocusable = $focusable.eq(0),\n        $lastFocusable = $focusable.eq(-1);\n    $element.on('keydown.zf.trapfocus', function (event) {\n      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      } else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n        event.preventDefault();\n        $lastFocusable.focus();\n      }\n    });\n  },\n\n  /**\n   * Releases the trapped focus from the given element.\n   * @param  {jQuery} $element  jQuery object to release the focus for.\n   */\n  releaseFocus: function releaseFocus($element) {\n    $element.off('keydown.zf.trapfocus');\n  }\n};\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\n\nfunction getKeyCodes(kcs) {\n  var k = {};\n\n  for (var kc in kcs) {\n    k[kcs[kc]] = kcs[kc];\n  }\n\n  return k;\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.mediaQuery.js\":\n/*!******************************************!*\\\n  !*** ./js/foundation.util.mediaQuery.js ***!\n  \\******************************************/\n/*! exports provided: MediaQuery */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"MediaQuery\", function() { return MediaQuery; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n // Default set of media queries\n\nvar defaultQueries = {\n  'default': 'only screen',\n  landscape: 'only screen and (orientation: landscape)',\n  portrait: 'only screen and (orientation: portrait)',\n  retina: 'only screen and (-webkit-min-device-pixel-ratio: 2),' + 'only screen and (min--moz-device-pixel-ratio: 2),' + 'only screen and (-o-min-device-pixel-ratio: 2/1),' + 'only screen and (min-device-pixel-ratio: 2),' + 'only screen and (min-resolution: 192dpi),' + 'only screen and (min-resolution: 2dppx)'\n}; // matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n\n/* eslint-disable */\n\nwindow.matchMedia || (window.matchMedia = function () {\n  \"use strict\"; // For browsers that support matchMedium api such as IE 9 and webkit\n\n  var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium\n\n  if (!styleMedia) {\n    var style = document.createElement('style'),\n        script = document.getElementsByTagName('script')[0],\n        info = null;\n    style.type = 'text/css';\n    style.id = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n\n\n    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;\n    styleMedia = {\n      matchMedium: function matchMedium(media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        } // Test if media query is true or false\n\n\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function (media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n}());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init: function _init() {\n    var self = this;\n    var $meta = jquery__WEBPACK_IMPORTED_MODULE_0___default()('meta.foundation-mq');\n\n    if (!$meta.length) {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = jquery__WEBPACK_IMPORTED_MODULE_0___default()('.foundation-mq').css('font-family');\n    var namedQueries;\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if (namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: \"only screen and (min-width: \".concat(namedQueries[key], \")\")\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast: function atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is: function is(size) {\n    size = size.trim().split(' ');\n\n    if (size.length > 1 && size[1] === 'only') {\n      if (size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get: function get(size) {\n    for (var i in this.queries) {\n      if (this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize: function _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (_typeof(matched) === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher: function _watcher() {\n    var _this = this;\n\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {\n      var newSize = _this._getCurrentSize(),\n          currentSize = _this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        _this.current = newSize; // Broadcast the media query change on the window\n\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n}; // Thank you: https://github.com/sindresorhus/query-string\n\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function (ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key); // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n\n    return ret;\n  }, {});\n  return styleObject;\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.motion.js\":\n/*!**************************************!*\\\n  !*** ./js/foundation.util.motion.js ***!\n  \\**************************************/\n/*! exports provided: Move, Motion */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Move\", function() { return Move; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Motion\", function() { return Motion; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n\n\n\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nvar initClasses = ['mui-enter', 'mui-leave'];\nvar activeClasses = ['mui-enter-active', 'mui-leave-active'];\nvar Motion = {\n  animateIn: function animateIn(element, animation, cb) {\n    animate(true, element, animation, cb);\n  },\n  animateOut: function animateOut(element, animation, cb) {\n    animate(false, element, animation, cb);\n  }\n};\n\nfunction Move(duration, elem, fn) {\n  var anim,\n      prog,\n      start = null; // console.log('called');\n\n  if (duration === 0) {\n    fn.apply(elem);\n    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    return;\n  }\n\n  function move(ts) {\n    if (!start) start = ts; // console.log(start, ts);\n\n    prog = ts - start;\n    fn.apply(elem);\n\n    if (prog < duration) {\n      anim = window.requestAnimationFrame(move, elem);\n    } else {\n      window.cancelAnimationFrame(anim);\n      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    }\n  }\n\n  anim = window.requestAnimationFrame(move);\n}\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\n\n\nfunction animate(isIn, element, animation, cb) {\n  element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element).eq(0);\n  if (!element.length) return;\n  var initClass = isIn ? initClasses[0] : initClasses[1];\n  var activeClass = isIn ? activeClasses[0] : activeClasses[1]; // Set up the animation\n\n  reset();\n  element.addClass(animation).css('transition', 'none');\n  requestAnimationFrame(function () {\n    element.addClass(initClass);\n    if (isIn) element.show();\n  }); // Start the animation\n\n  requestAnimationFrame(function () {\n    element[0].offsetWidth;\n    element.css('transition', '').addClass(activeClass);\n  }); // Clean up the animation when it finishes\n\n  element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"transitionend\"])(element), finish); // Hides the element (for out animations), resets the element, and runs a callback\n\n  function finish() {\n    if (!isIn) element.hide();\n    reset();\n    if (cb) cb.apply(element);\n  } // Resets transitions and removes motion-specific classes\n\n\n  function reset() {\n    element[0].style.transitionDuration = 0;\n    element.removeClass(\"\".concat(initClass, \" \").concat(activeClass, \" \").concat(animation));\n  }\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.nest.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.util.nest.js ***!\n  \\************************************/\n/*! exports provided: Nest */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Nest\", function() { return Nest; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\nvar Nest = {\n  Feather: function Feather(menu) {\n    var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zf';\n    menu.attr('role', 'menubar');\n    var items = menu.find('li').attr({\n      'role': 'menuitem'\n    }),\n        subMenuClass = \"is-\".concat(type, \"-submenu\"),\n        subItemClass = \"\".concat(subMenuClass, \"-item\"),\n        hasSubClass = \"is-\".concat(type, \"-submenu-parent\"),\n        applyAria = type !== 'accordion'; // Accordions handle their own ARIA attriutes.\n\n    items.each(function () {\n      var $item = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item.addClass(hasSubClass);\n\n        if (applyAria) {\n          $item.attr({\n            'aria-haspopup': true,\n            'aria-label': $item.children('a:first').text()\n          }); // Note:  Drilldowns behave differently in how they hide, and so need\n          // additional attributes.  We should look if this possibly over-generalized\n          // utility (Nest) is appropriate when we rework menus in 6.4\n\n          if (type === 'drilldown') {\n            $item.attr({\n              'aria-expanded': false\n            });\n          }\n        }\n\n        $sub.addClass(\"submenu \".concat(subMenuClass)).attr({\n          'data-submenu': '',\n          'role': 'menubar'\n        });\n\n        if (type === 'drilldown') {\n          $sub.attr({\n            'aria-hidden': true\n          });\n        }\n      }\n\n      if ($item.parent('[data-submenu]').length) {\n        $item.addClass(\"is-submenu-item \".concat(subItemClass));\n      }\n    });\n    return;\n  },\n  Burn: function Burn(menu, type) {\n    var //items = menu.find('li'),\n    subMenuClass = \"is-\".concat(type, \"-submenu\"),\n        subItemClass = \"\".concat(subMenuClass, \"-item\"),\n        hasSubClass = \"is-\".concat(type, \"-submenu-parent\");\n    menu.find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li').removeClass(\"\".concat(subMenuClass, \" \").concat(subItemClass, \" \").concat(hasSubClass, \" is-submenu-item submenu is-active\")).removeAttr('data-submenu').css('display', '');\n  }\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.timer.js\":\n/*!*************************************!*\\\n  !*** ./js/foundation.util.timer.js ***!\n  \\*************************************/\n/*! exports provided: Timer */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Timer\", function() { return Timer; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\n\nfunction Timer(elem, options, cb) {\n  var _this = this,\n      duration = options.duration,\n      //options is an object for easily adding features later.\n  nameSpace = Object.keys(elem.data())[0] || 'timer',\n      remain = -1,\n      start,\n      timer;\n\n  this.isPaused = false;\n\n  this.restart = function () {\n    remain = -1;\n    clearTimeout(timer);\n    this.start();\n  };\n\n  this.start = function () {\n    this.isPaused = false; // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n\n    clearTimeout(timer);\n    remain = remain <= 0 ? duration : remain;\n    elem.data('paused', false);\n    start = Date.now();\n    timer = setTimeout(function () {\n      if (options.infinite) {\n        _this.restart(); //rerun the timer.\n\n      }\n\n      if (cb && typeof cb === 'function') {\n        cb();\n      }\n    }, remain);\n    elem.trigger(\"timerstart.zf.\".concat(nameSpace));\n  };\n\n  this.pause = function () {\n    this.isPaused = true; //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n\n    clearTimeout(timer);\n    elem.data('paused', true);\n    var end = Date.now();\n    remain = remain - (end - start);\n    elem.trigger(\"timerpaused.zf.\".concat(nameSpace));\n  };\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.touch.js\":\n/*!*************************************!*\\\n  !*** ./js/foundation.util.touch.js ***!\n  \\*************************************/\n/*! exports provided: Touch */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Touch\", function() { return Touch; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\n//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nvar Touch = {};\nvar startPosX,\n    startPosY,\n    startTime,\n    elapsedTime,\n    startEvent,\n    isMoving = false,\n    didMoved = false;\n\nfunction onTouchEnd(e) {\n  this.removeEventListener('touchmove', onTouchMove);\n  this.removeEventListener('touchend', onTouchEnd); // If the touch did not move, consider it as a \"tap\"\n\n  if (!didMoved) {\n    var tapEvent = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('tap', startEvent || e);\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(tapEvent);\n  }\n\n  startEvent = null;\n  isMoving = false;\n  didMoved = false;\n}\n\nfunction onTouchMove(e) {\n  if (jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.preventDefault) {\n    e.preventDefault();\n  }\n\n  if (isMoving) {\n    var x = e.touches[0].pageX;\n    var y = e.touches[0].pageY;\n    var dx = startPosX - x;\n    var dy = startPosY - y;\n    var dir;\n    didMoved = true;\n    elapsedTime = new Date().getTime() - startTime;\n\n    if (Math.abs(dx) >= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.moveThreshold && elapsedTime <= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.timeThreshold) {\n      dir = dx > 0 ? 'left' : 'right';\n    } // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n    //   dir = dy > 0 ? 'down' : 'up';\n    // }\n\n\n    if (dir) {\n      e.preventDefault();\n      onTouchEnd.apply(this, arguments);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('swipe', e), dir).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event(\"swipe\".concat(dir), e));\n    }\n  }\n}\n\nfunction onTouchStart(e) {\n  if (e.touches.length == 1) {\n    startPosX = e.touches[0].pageX;\n    startPosY = e.touches[0].pageY;\n    startEvent = e;\n    isMoving = true;\n    didMoved = false;\n    startTime = new Date().getTime();\n    this.addEventListener('touchmove', onTouchMove, false);\n    this.addEventListener('touchend', onTouchEnd, false);\n  }\n}\n\nfunction init() {\n  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);\n}\n\nfunction teardown() {\n  this.removeEventListener('touchstart', onTouchStart);\n}\n\nvar SpotSwipe =\n/*#__PURE__*/\nfunction () {\n  function SpotSwipe($) {\n    _classCallCheck(this, SpotSwipe);\n\n    this.version = '1.0.0';\n    this.enabled = 'ontouchstart' in document.documentElement;\n    this.preventDefault = false;\n    this.moveThreshold = 75;\n    this.timeThreshold = 200;\n    this.$ = $;\n\n    this._init();\n  }\n\n  _createClass(SpotSwipe, [{\n    key: \"_init\",\n    value: function _init() {\n      var $ = this.$;\n      $.event.special.swipe = {\n        setup: init\n      };\n      $.event.special.tap = {\n        setup: init\n      };\n      $.each(['left', 'up', 'down', 'right'], function () {\n        $.event.special[\"swipe\".concat(this)] = {\n          setup: function setup() {\n            $(this).on('swipe', $.noop);\n          }\n        };\n      });\n    }\n  }]);\n\n  return SpotSwipe;\n}();\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and    *\n * setupTouchHandler should be idempotent,          *\n * because they directly replace functions &        *\n * values, and do not add event handlers directly.  *\n ****************************************************/\n\n\nTouch.setupSpotSwipe = function ($) {\n  $.spotSwipe = new SpotSwipe($);\n};\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\n\n\nTouch.setupTouchHandler = function ($) {\n  $.fn.addTouch = function () {\n    this.each(function (i, el) {\n      $(el).bind('touchstart touchmove touchend touchcancel', function (event) {\n        //we pass the original event object because the jQuery event\n        //object is normalized to w3c specs and does not provide the TouchList\n        handleTouch(event);\n      });\n    });\n\n    var handleTouch = function handleTouch(event) {\n      var touches = event.changedTouches,\n          first = touches[0],\n          eventTypes = {\n        touchstart: 'mousedown',\n        touchmove: 'mousemove',\n        touchend: 'mouseup'\n      },\n          type = eventTypes[event.type],\n          simulatedEvent;\n\n      if ('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n        simulatedEvent = new window.MouseEvent(type, {\n          'bubbles': true,\n          'cancelable': true,\n          'screenX': first.screenX,\n          'screenY': first.screenY,\n          'clientX': first.clientX,\n          'clientY': first.clientY\n        });\n      } else {\n        simulatedEvent = document.createEvent('MouseEvent');\n        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0\n        /*left*/\n        , null);\n      }\n\n      first.target.dispatchEvent(simulatedEvent);\n    };\n  };\n};\n\nTouch.init = function ($) {\n  if (typeof $.spotSwipe === 'undefined') {\n    Touch.setupSpotSwipe($);\n    Touch.setupTouchHandler($);\n  }\n};\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./js/foundation.util.motion.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 0:\n/*!****************************************!*\\\n  !*** multi ./js/entries/foundation.js ***!\n  \\****************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/foundation.js */\"./js/entries/foundation.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.js.map"]}
\ No newline at end of file
index 8d94961e335d0c26f550e8848e135f9686f02fcc..4330eb4bd20556f7729bf4fa41005d834eaac07b 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.abide"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.abide"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 79);
+/******/       return __webpack_require__(__webpack_require__.s = 0);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 13:
+/***/ "./js/entries/plugins/foundation.abide.js":
+/*!************************************************!*\
+  !*** ./js/entries/plugins/foundation.abide.js ***!
+  \************************************************/
+/*! exports provided: Foundation, Abide */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_abide__ = __webpack_require__(43);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_abide__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.abide */ "./js/foundation.abide.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Abide", function() { return _foundation_abide__WEBPACK_IMPORTED_MODULE_1__["Abide"]; });
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_abide__["a" /* Abide */], 'Abide');
 
-/***/ }),
 
-/***/ 2:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_abide__WEBPACK_IMPORTED_MODULE_1__["Abide"], 'Abide');
 
-module.exports = {Plugin: window.Foundation.Plugin};
 
 /***/ }),
 
-/***/ 43:
+/***/ "./js/foundation.abide.js":
+/*!********************************!*\
+  !*** ./js/foundation.abide.js ***!
+  \********************************/
+/*! exports provided: Abide */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Abide; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_plugin__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Abide", function() { return Abide; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ "./foundation.core");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
 
-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 _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -131,17 +172,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @module foundation.abide
  */
 
-var Abide = function (_Plugin) {
+var Abide =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Abide, _Plugin);
 
   function Abide() {
     _classCallCheck(this, Abide);
 
-    return _possibleConstructorReturn(this, (Abide.__proto__ || Object.getPrototypeOf(Abide)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Abide).apply(this, arguments));
   }
 
   _createClass(Abide, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of Abide.
@@ -153,34 +196,46 @@ var Abide = function (_Plugin) {
      */
     value: function _setup(element) {
       var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
-
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(true, {}, Abide.defaults, this.$element.data(), options);
-
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(true, {}, Abide.defaults, this.$element.data(), options);
       this.className = 'Abide'; // ie9 back compat
+
       this._init();
     }
-
     /**
      * Initializes the Abide plugin and calls functions to get Abide functioning on load.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      this.$inputs = this.$element.find('input, textarea, select');
+      var _this2 = this;
+
+      this.$inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.merge( // Consider as input to validate:
+      this.$element.find('input').not('[type=submit]'), // * all input fields expect submit
+      this.$element.find('textarea, select') // * all textareas and select fields
+      );
+      var $globalErrors = this.$element.find('[data-abide-error]'); // Add a11y attributes to all fields
+
+      if (this.options.a11yAttributes) {
+        this.$inputs.each(function (i, input) {
+          return _this2.addA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(input));
+        });
+        $globalErrors.each(function (i, error) {
+          return _this2.addGlobalErrorA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(error));
+        });
+      }
 
       this._events();
     }
-
     /**
      * Initializes events for Abide.
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this3 = this;
 
@@ -192,34 +247,32 @@ var Abide = function (_Plugin) {
 
       if (this.options.validateOn === 'fieldChange') {
         this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) {
-          _this3.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target));
+          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));
         });
       }
 
       if (this.options.liveValidate) {
         this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) {
-          _this3.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target));
+          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));
         });
       }
 
       if (this.options.validateOnBlur) {
         this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) {
-          _this3.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target));
+          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));
         });
       }
     }
-
     /**
      * Calls necessary functions to update Abide upon DOM change
      * @private
      */
 
   }, {
-    key: '_reflow',
+    key: "_reflow",
     value: function _reflow() {
       this._init();
     }
-
     /**
      * Checks whether or not a form element has the required attribute and if it's checked or not
      * @param {Object} element - jQuery object to check for required attribute
@@ -227,10 +280,9 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'requiredCheck',
+    key: "requiredCheck",
     value: function requiredCheck($el) {
       if (!$el.attr('required')) return true;
-
       var isGood = true;
 
       switch ($el[0].type) {
@@ -251,7 +303,6 @@ var Abide = function (_Plugin) {
 
       return isGood;
     }
-
     /**
      * Get:
      * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:
@@ -266,7 +317,7 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'findFormError',
+    key: "findFormError",
     value: function findFormError($el) {
       var id = $el[0].id;
       var $error = $el.siblings(this.options.formErrorSelector);
@@ -275,11 +326,12 @@ var Abide = function (_Plugin) {
         $error = $el.parent().find(this.options.formErrorSelector);
       }
 
-      $error = $error.add(this.$element.find('[data-form-error-for="' + id + '"]'));
+      if (id) {
+        $error = $error.add(this.$element.find("[data-form-error-for=\"".concat(id, "\"]")));
+      }
 
       return $error;
     }
-
     /**
      * Get the first element in this order:
      * 2. The <label> with the attribute `[for="someInputId"]`
@@ -290,10 +342,10 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'findLabel',
+    key: "findLabel",
     value: function findLabel($el) {
       var id = $el[0].id;
-      var $label = this.$element.find('label[for="' + id + '"]');
+      var $label = this.$element.find("label[for=\"".concat(id, "\"]"));
 
       if (!$label.length) {
         return $el.closest('label');
@@ -301,7 +353,6 @@ var Abide = function (_Plugin) {
 
       return $label;
     }
-
     /**
      * Get the set of labels associated with a set of radio els in this order
      * 2. The <label> with the attribute `[for="someInputId"]`
@@ -312,30 +363,30 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'findRadioLabels',
+    key: "findRadioLabels",
     value: function findRadioLabels($els) {
       var _this4 = this;
 
       var labels = $els.map(function (i, el) {
         var id = el.id;
-        var $label = _this4.$element.find('label[for="' + id + '"]');
+
+        var $label = _this4.$element.find("label[for=\"".concat(id, "\"]"));
 
         if (!$label.length) {
-          $label = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el).closest('label');
+          $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).closest('label');
         }
+
         return $label[0];
       });
-
-      return __WEBPACK_IMPORTED_MODULE_0_jquery___default()(labels);
+      return jquery__WEBPACK_IMPORTED_MODULE_0___default()(labels);
     }
-
     /**
      * Adds the CSS error class as specified by the Abide settings to the label, input, and the form
      * @param {Object} $el - jQuery object to add the class to
      */
 
   }, {
-    key: 'addErrorClasses',
+    key: "addErrorClasses",
     value: function addErrorClasses($el) {
       var $label = this.findLabel($el);
       var $formError = this.findFormError($el);
@@ -348,9 +399,71 @@ var Abide = function (_Plugin) {
         $formError.addClass(this.options.formErrorClass);
       }
 
-      $el.addClass(this.options.inputErrorClass).attr('data-invalid', '');
+      $el.addClass(this.options.inputErrorClass).attr({
+        'data-invalid': '',
+        'aria-invalid': true
+      });
+    }
+    /**
+     * Adds [for] and [role=alert] attributes to all form error targetting $el,
+     * and [aria-describedby] attribute to $el toward the first form error.
+     * @param {Object} $el - jQuery object
+     */
+
+  }, {
+    key: "addA11yAttributes",
+    value: function addA11yAttributes($el) {
+      var $errors = this.findFormError($el);
+      var $labels = $errors.filter('label');
+      var $error = $errors.first();
+      if (!$errors.length) return; // Set [aria-describedby] on the input toward the first form error if it is not set
+
+      if (typeof $el.attr('aria-describedby') === 'undefined') {
+        // Get the first error ID or create one
+        var errorId = $error.attr('id');
+
+        if (typeof errorId === 'undefined') {
+          errorId = Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'abide-error');
+          $error.attr('id', errorId);
+        }
+
+        ;
+        $el.attr('aria-describedby', errorId);
+      }
+
+      if ($labels.filter('[for]').length < $labels.length) {
+        // Get the input ID or create one
+        var elemId = $el.attr('id');
+
+        if (typeof elemId === 'undefined') {
+          elemId = Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'abide-input');
+          $el.attr('id', elemId);
+        }
+
+        ; // For each label targeting $el, set [for] if it is not set.
+
+        $labels.each(function (i, label) {
+          var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label);
+          if (typeof $label.attr('for') === 'undefined') $label.attr('for', elemId);
+        });
+      } // For each error targeting $el, set [role=alert] if it is not set.
+
+
+      $errors.each(function (i, label) {
+        var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label);
+        if (typeof $label.attr('role') === 'undefined') $label.attr('role', 'alert');
+      }).end();
     }
+    /**
+     * Adds [aria-live] attribute to the given global form error $el.
+     * @param {Object} $el - jQuery object to add the attribute to
+     */
 
+  }, {
+    key: "addGlobalErrorA11yAttributes",
+    value: function addGlobalErrorA11yAttributes($el) {
+      if (typeof $el.attr('aria-live') === 'undefined') $el.attr('aria-live', this.options.a11yErrorLevel);
+    }
     /**
      * Remove CSS error classes etc from an entire radio button group
      * @param {String} groupName - A string that specifies the name of a radio button group
@@ -358,9 +471,9 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'removeRadioErrorClasses',
+    key: "removeRadioErrorClasses",
     value: function removeRadioErrorClasses(groupName) {
-      var $els = this.$element.find(':radio[name="' + groupName + '"]');
+      var $els = this.$element.find(":radio[name=\"".concat(groupName, "\"]"));
       var $labels = this.findRadioLabels($els);
       var $formErrors = this.findFormError($els);
 
@@ -372,16 +485,18 @@ var Abide = function (_Plugin) {
         $formErrors.removeClass(this.options.formErrorClass);
       }
 
-      $els.removeClass(this.options.inputErrorClass).removeAttr('data-invalid');
+      $els.removeClass(this.options.inputErrorClass).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
     }
-
     /**
      * Removes CSS error class as specified by the Abide settings from the label, input, and the form
      * @param {Object} $el - jQuery object to remove the class from
      */
 
   }, {
-    key: 'removeErrorClasses',
+    key: "removeErrorClasses",
     value: function removeErrorClasses($el) {
       // radios need to clear all of the els
       if ($el[0].type == 'radio') {
@@ -399,9 +514,11 @@ var Abide = function (_Plugin) {
         $formError.removeClass(this.options.formErrorClass);
       }
 
-      $el.removeClass(this.options.inputErrorClass).removeAttr('data-invalid');
+      $el.removeClass(this.options.inputErrorClass).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
     }
-
     /**
      * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.
      * Ignores inputs with data-abide-ignore, type="hidden" or disabled attributes set
@@ -412,15 +529,14 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'validateInput',
+    key: "validateInput",
     value: function validateInput($el) {
       var clearRequire = this.requiredCheck($el),
           validated = false,
           customValidator = true,
           validator = $el.attr('data-validator'),
-          equalTo = true;
+          equalTo = true; // don't validate ignored inputs or hidden inputs or disabled inputs
 
-      // don't validate ignored inputs or hidden inputs or disabled inputs
       if ($el.is('[data-abide-ignore]') || $el.is('[type="hidden"]') || $el.is('[disabled]')) {
         return true;
       }
@@ -457,30 +573,30 @@ var Abide = function (_Plugin) {
 
       if (goodToGo) {
         // Re-validate inputs that depend on this one with equalto
-        var dependentElements = this.$element.find('[data-equalto="' + $el.attr('id') + '"]');
+        var dependentElements = this.$element.find("[data-equalto=\"".concat($el.attr('id'), "\"]"));
+
         if (dependentElements.length) {
           var _this = this;
+
           dependentElements.each(function () {
-            if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).val()) {
-              _this.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
+            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val()) {
+              _this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
             }
           });
         }
       }
 
       this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);
-
       /**
        * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`
        * Trigger includes the DOM element of the input.
        * @event Abide#valid
        * @event Abide#invalid
        */
-      $el.trigger(message, [$el]);
 
+      $el.trigger(message, [$el]);
       return goodToGo;
     }
-
     /**
      * Goes through a form and if there are any invalid inputs, it will display the form error element
      * @returns {Boolean} noError - true if no errors were detected...
@@ -489,30 +605,35 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'validateForm',
+    key: "validateForm",
     value: function validateForm() {
+      var _this5 = this;
+
       var acc = [];
+
       var _this = this;
 
       this.$inputs.each(function () {
-        acc.push(_this.validateInput(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)));
+        acc.push(_this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)));
       });
-
       var noError = acc.indexOf(false) === -1;
+      this.$element.find('[data-abide-error]').each(function (i, elem) {
+        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem); // Ensure a11y attributes are set
 
-      this.$element.find('[data-abide-error]').css('display', noError ? 'none' : 'block');
+        if (_this5.options.a11yAttributes) _this5.addGlobalErrorA11yAttributes($elem); // Show or hide the error
 
+        $elem.css('display', noError ? 'none' : 'block');
+      });
       /**
        * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.
        * Trigger includes the element of the form.
        * @event Abide#formvalid
        * @event Abide#forminvalid
        */
-      this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);
 
+      this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);
       return noError;
     }
-
     /**
      * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.
      * @param {Object} $el - jQuery object to validate, should be a text input HTML element
@@ -521,7 +642,7 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'validateText',
+    key: "validateText",
     value: function validateText($el, pattern) {
       // A pattern can be passed to this function, or it will be infered from the input's "pattern" attribute, or it's "type" attribute
       pattern = pattern || $el.attr('pattern') || $el.attr('type');
@@ -532,22 +653,19 @@ var Abide = function (_Plugin) {
         // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp
         if (this.options.patterns.hasOwnProperty(pattern)) {
           valid = this.options.patterns[pattern].test(inputText);
-        }
-        // If the pattern name isn't also the type attribute of the field, then test it as a regexp
+        } // If the pattern name isn't also the type attribute of the field, then test it as a regexp
         else if (pattern !== $el.attr('type')) {
             valid = new RegExp(pattern).test(inputText);
           } else {
             valid = true;
           }
-      }
-      // An empty field is valid if it's not required
+      } // An empty field is valid if it's not required
       else if (!$el.prop('required')) {
           valid = true;
         }
 
       return valid;
     }
-
     /**
      * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.
      * @param {String} groupName - A string that specifies the name of a radio button group
@@ -555,17 +673,16 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'validateRadio',
+    key: "validateRadio",
     value: function validateRadio(groupName) {
       // If at least one radio in the group has the `required` attribute, the group is considered required
       // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice
-      var $group = this.$element.find(':radio[name="' + groupName + '"]');
+      var $group = this.$element.find(":radio[name=\"".concat(groupName, "\"]"));
       var valid = false,
-          required = false;
+          required = false; // For the group to be required, at least one radio needs to be required
 
-      // For the group to be required, at least one radio needs to be required
       $group.each(function (i, e) {
-        if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e).attr('required')) {
+        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).attr('required')) {
           required = true;
         }
       });
@@ -574,15 +691,15 @@ var Abide = function (_Plugin) {
       if (!valid) {
         // For the group to be valid, at least one radio needs to be checked
         $group.each(function (i, e) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e).prop('checked')) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).prop('checked')) {
             valid = true;
           }
         });
-      };
+      }
 
+      ;
       return valid;
     }
-
     /**
      * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator="foo bar baz"` in a space separated listed.
      * @param {Object} $el - jQuery input element.
@@ -592,63 +709,68 @@ var Abide = function (_Plugin) {
      */
 
   }, {
-    key: 'matchValidation',
+    key: "matchValidation",
     value: function matchValidation($el, validators, required) {
-      var _this5 = this;
+      var _this6 = this;
 
       required = required ? true : false;
-
       var clear = validators.split(' ').map(function (v) {
-        return _this5.options.validators[v]($el, required, $el.parent());
+        return _this6.options.validators[v]($el, required, $el.parent());
       });
       return clear.indexOf(false) === -1;
     }
-
     /**
      * Resets form inputs and styles
      * @fires Abide#formreset
      */
 
   }, {
-    key: 'resetForm',
+    key: "resetForm",
     value: function resetForm() {
       var $form = this.$element,
           opts = this.options;
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('.' + opts.labelErrorClass, $form).not('small').removeClass(opts.labelErrorClass);
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('.' + opts.inputErrorClass, $form).not('small').removeClass(opts.inputErrorClass);
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(opts.formErrorSelector + '.' + opts.formErrorClass).removeClass(opts.formErrorClass);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(".".concat(opts.labelErrorClass), $form).not('small').removeClass(opts.labelErrorClass);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(".".concat(opts.inputErrorClass), $form).not('small').removeClass(opts.inputErrorClass);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("".concat(opts.formErrorSelector, ".").concat(opts.formErrorClass)).removeClass(opts.formErrorClass);
       $form.find('[data-abide-error]').css('display', 'none');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').removeAttr('data-invalid');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).removeAttr('data-invalid');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).removeAttr('data-invalid');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).attr({
+        'data-invalid': null,
+        'aria-invalid': null
+      });
       /**
        * Fires when the form has been reset.
        * @event Abide#formreset
        */
+
       $form.trigger('formreset.zf.abide', [$form]);
     }
-
     /**
      * Destroys an instance of Abide.
      * Removes error styles and classes from elements, without resetting their values.
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       var _this = this;
-      this.$element.off('.abide').find('[data-abide-error]').css('display', 'none');
 
+      this.$element.off('.abide').find('[data-abide-error]').css('display', 'none');
       this.$inputs.off('.abide').each(function () {
-        _this.removeErrorClasses(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
+        _this.removeErrorClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
       });
     }
   }]);
 
   return Abide;
-}(__WEBPACK_IMPORTED_MODULE_1__foundation_plugin__["Plugin"]);
-
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 /**
  * Default settings for plugin
  */
@@ -696,6 +818,27 @@ Abide.defaults = {
    */
   formErrorClass: 'is-visible',
 
+  /**
+   * If true, automatically insert when possible:
+   * - `[aria-describedby]` on fields
+   * - `[role=alert]` on form errors and `[for]` on form error labels
+   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  a11yAttributes: true,
+
+  /**
+   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.
+   * Options are: 'assertive', 'polite' and 'off'/null
+   * @option
+   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions
+   * @type {string}
+   * @default 'assertive'
+   */
+  a11yErrorLevel: 'assertive',
+
   /**
    * Set to true to validate text inputs on any value change.
    * @option
@@ -711,24 +854,22 @@ Abide.defaults = {
    * @default false
    */
   validateOnBlur: false,
-
   patterns: {
     alpha: /^[a-zA-Z]+$/,
     alpha_numeric: /^[a-zA-Z0-9]+$/,
     integer: /^[-+]?\d+$/,
     number: /^[-+]?\d*(?:[\.\,]\d+)?$/,
-
     // amex, visa, diners
     card: /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,
     cvv: /^([0-9]){3,4}$/,
-
     // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address
     email: /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,
-
-    url: /^(https?|ftp|file|ssh):\/\/(((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/,
+    // From CommonRegexJS (@talyssonoc)
+    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76
+    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.
+    url: /^((?:(https?|ftps?|file|ssh|sftp):\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\))+(?:\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?\xab\xbb\u201c\u201d\u2018\u2019]))$/,
     // abc.de
     domain: /^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,
-
     datetime: /^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,
     // YYYY-MM-DD
     date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,
@@ -739,13 +880,11 @@ Abide.defaults = {
     month_day_year: /^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,
     // DD/MM/YYYY
     day_month_year: /^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,
-
     // #FFF or #FFFFFF
     color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,
-
     // Domain || URL
     website: {
-      test: function (text) {
+      test: function test(text) {
         return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);
       }
     }
@@ -760,22 +899,38 @@ Abide.defaults = {
    * @option
    */
   validators: {
-    equalTo: function (el, required, parent) {
-      return __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + el.attr('data-equalto')).val() === el.val();
+    equalTo: function equalTo(el, required, parent) {
+      return jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(el.attr('data-equalto'))).val() === el.val();
     }
   }
 };
 
 
-
 /***/ }),
 
-/***/ 79:
+/***/ 0:
+/*!******************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.abide.js ***!
+  \******************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(13);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.abide.js */"./js/entries/plugins/foundation.abide.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.abide.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.abide.js.map b/dist/js/plugins/foundation.abide.js.map
new file mode 100644 (file)
index 0000000..3680aad
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.abide.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.abide.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Abide","element","options","$element","$","extend","defaults","data","className","_init","$inputs","merge","find","not","$globalErrors","a11yAttributes","each","i","input","addA11yAttributes","error","addGlobalErrorA11yAttributes","_events","off","on","resetForm","validateForm","validateOn","e","validateInput","target","liveValidate","validateOnBlur","$el","attr","isGood","type","checked","opt","length","val","id","$error","siblings","formErrorSelector","parent","add","$label","closest","$els","labels","map","el","findLabel","$formError","findFormError","addClass","labelErrorClass","formErrorClass","inputErrorClass","$errors","$labels","filter","first","errorId","GetYoDigits","elemId","label","end","a11yErrorLevel","groupName","findRadioLabels","$formErrors","removeClass","removeRadioErrorClasses","clearRequire","requiredCheck","validated","customValidator","validator","equalTo","is","validateRadio","validateText","matchValidation","validators","goodToGo","indexOf","message","dependentElements","_this","trigger","acc","push","noError","elem","$elem","css","pattern","inputText","valid","patterns","hasOwnProperty","test","RegExp","prop","$group","required","clear","split","v","$form","opts","removeErrorClasses","Plugin","alpha","alpha_numeric","integer","number","card","cvv","email","url","domain","datetime","date","time","dateISO","month_day_year","day_month_year","color","website","text"],"mappings":"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","file":"foundation.abide.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.abide\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.abide\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\n\nimport { Abide } from '../../foundation.abide';\nFoundation.plugin(Abide, 'Abide');\n\nexport { Foundation, Abide };\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nclass Abide extends Plugin {\n  /**\n   * Creates a new instance of Abide.\n   * @class\n   * @name Abide\n   * @fires Abide#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options = {}) {\n    this.$element = element;\n    this.options  = $.extend(true, {}, Abide.defaults, this.$element.data(), options);\n\n    this.className = 'Abide'; // ie9 back compat\n    this._init();\n  }\n\n  /**\n   * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n   * @private\n   */\n  _init() {\n    this.$inputs = $.merge(                               // Consider as input to validate:\n      this.$element.find('input').not('[type=submit]'),   // * all input fields expect submit\n      this.$element.find('textarea, select')              // * all textareas and select fields\n    );\n    const $globalErrors = this.$element.find('[data-abide-error]');\n\n    // Add a11y attributes to all fields\n    if (this.options.a11yAttributes) {\n      this.$inputs.each((i, input) => this.addA11yAttributes($(input)));\n      $globalErrors.each((i, error) => this.addGlobalErrorA11yAttributes($(error)));\n    }\n\n    this._events();\n  }\n\n  /**\n   * Initializes events for Abide.\n   * @private\n   */\n  _events() {\n    this.$element.off('.abide')\n      .on('reset.zf.abide', () => {\n        this.resetForm();\n      })\n      .on('submit.zf.abide', () => {\n        return this.validateForm();\n      });\n\n    if (this.options.validateOn === 'fieldChange') {\n      this.$inputs\n        .off('change.zf.abide')\n        .on('change.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.liveValidate) {\n      this.$inputs\n        .off('input.zf.abide')\n        .on('input.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n\n    if (this.options.validateOnBlur) {\n      this.$inputs\n        .off('blur.zf.abide')\n        .on('blur.zf.abide', (e) => {\n          this.validateInput($(e.target));\n        });\n    }\n  }\n\n  /**\n   * Calls necessary functions to update Abide upon DOM change\n   * @private\n   */\n  _reflow() {\n    this._init();\n  }\n\n  /**\n   * Checks whether or not a form element has the required attribute and if it's checked or not\n   * @param {Object} element - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  requiredCheck($el) {\n    if (!$el.attr('required')) return true;\n\n    var isGood = true;\n\n    switch ($el[0].type) {\n      case 'checkbox':\n        isGood = $el[0].checked;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        var opt = $el.find('option:selected');\n        if (!opt.length || !opt.val()) isGood = false;\n        break;\n\n      default:\n        if(!$el.val() || !$el.val().length) isGood = false;\n    }\n\n    return isGood;\n  }\n\n  /**\n   * Get:\n   * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n   *   1. The element's direct sibling('s).\n   *   2. The element's parent's children.\n   * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n   *\n   * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n   *\n   * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n   * @returns {Object} jQuery object with the selector.\n   */\n  findFormError($el) {\n    var id = $el[0].id;\n    var $error = $el.siblings(this.options.formErrorSelector);\n\n    if (!$error.length) {\n      $error = $el.parent().find(this.options.formErrorSelector);\n    }\n\n    if (id) {\n      $error = $error.add(this.$element.find(`[data-form-error-for=\"${id}\"]`));\n    }\n\n    return $error;\n  }\n\n  /**\n   * Get the first element in this order:\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findLabel($el) {\n    var id = $el[0].id;\n    var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n    if (!$label.length) {\n      return $el.closest('label');\n    }\n\n    return $label;\n  }\n\n  /**\n   * Get the set of labels associated with a set of radio els in this order\n   * 2. The <label> with the attribute `[for=\"someInputId\"]`\n   * 3. The `.closest()` <label>\n   *\n   * @param {Object} $el - jQuery object to check for required attribute\n   * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n   */\n  findRadioLabels($els) {\n    var labels = $els.map((i, el) => {\n      var id = el.id;\n      var $label = this.$element.find(`label[for=\"${id}\"]`);\n\n      if (!$label.length) {\n        $label = $(el).closest('label');\n      }\n      return $label[0];\n    });\n\n    return $(labels);\n  }\n\n  /**\n   * Adds the CSS error class as specified by the Abide settings to the label, input, and the form\n   * @param {Object} $el - jQuery object to add the class to\n   */\n  addErrorClasses($el) {\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.addClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.addClass(this.options.formErrorClass);\n    }\n\n    $el.addClass(this.options.inputErrorClass).attr({\n      'data-invalid': '',\n      'aria-invalid': true\n    });\n  }\n\n  /**\n   * Adds [for] and [role=alert] attributes to all form error targetting $el,\n   * and [aria-describedby] attribute to $el toward the first form error.\n   * @param {Object} $el - jQuery object\n   */\n  addA11yAttributes($el) {\n    let $errors = this.findFormError($el);\n    let $labels = $errors.filter('label');\n    let $error = $errors.first();\n    if (!$errors.length) return;\n\n    // Set [aria-describedby] on the input toward the first form error if it is not set\n    if (typeof $el.attr('aria-describedby') === 'undefined') {\n      // Get the first error ID or create one\n      let errorId = $error.attr('id');\n      if (typeof errorId === 'undefined') {\n        errorId = GetYoDigits(6, 'abide-error');\n        $error.attr('id', errorId);\n      };\n\n      $el.attr('aria-describedby', errorId);\n    }\n\n    if ($labels.filter('[for]').length < $labels.length) {\n      // Get the input ID or create one\n      let elemId = $el.attr('id');\n      if (typeof elemId === 'undefined') {\n        elemId = GetYoDigits(6, 'abide-input');\n        $el.attr('id', elemId);\n      };\n\n      // For each label targeting $el, set [for] if it is not set.\n      $labels.each((i, label) => {\n        const $label = $(label);\n        if (typeof $label.attr('for') === 'undefined')\n          $label.attr('for', elemId);\n      });\n    }\n\n    // For each error targeting $el, set [role=alert] if it is not set.\n    $errors.each((i, label) => {\n      const $label = $(label);\n      if (typeof $label.attr('role') === 'undefined')\n        $label.attr('role', 'alert');\n    }).end();\n  }\n\n  /**\n   * Adds [aria-live] attribute to the given global form error $el.\n   * @param {Object} $el - jQuery object to add the attribute to\n   */\n  addGlobalErrorA11yAttributes($el) {\n    if (typeof $el.attr('aria-live') === 'undefined')\n      $el.attr('aria-live', this.options.a11yErrorLevel);\n  }\n\n  /**\n   * Remove CSS error classes etc from an entire radio button group\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   *\n   */\n  removeRadioErrorClasses(groupName) {\n    var $els = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var $labels = this.findRadioLabels($els);\n    var $formErrors = this.findFormError($els);\n\n    if ($labels.length) {\n      $labels.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formErrors.length) {\n      $formErrors.removeClass(this.options.formErrorClass);\n    }\n\n    $els.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n\n  }\n\n  /**\n   * Removes CSS error class as specified by the Abide settings from the label, input, and the form\n   * @param {Object} $el - jQuery object to remove the class from\n   */\n  removeErrorClasses($el) {\n    // radios need to clear all of the els\n    if($el[0].type == 'radio') {\n      return this.removeRadioErrorClasses($el.attr('name'));\n    }\n\n    var $label = this.findLabel($el);\n    var $formError = this.findFormError($el);\n\n    if ($label.length) {\n      $label.removeClass(this.options.labelErrorClass);\n    }\n\n    if ($formError.length) {\n      $formError.removeClass(this.options.formErrorClass);\n    }\n\n    $el.removeClass(this.options.inputErrorClass).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n  }\n\n  /**\n   * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.\n   * Ignores inputs with data-abide-ignore, type=\"hidden\" or disabled attributes set\n   * @fires Abide#invalid\n   * @fires Abide#valid\n   * @param {Object} element - jQuery object to validate, should be an HTML input\n   * @returns {Boolean} goodToGo - If the input is valid or not.\n   */\n  validateInput($el) {\n    var clearRequire = this.requiredCheck($el),\n        validated = false,\n        customValidator = true,\n        validator = $el.attr('data-validator'),\n        equalTo = true;\n\n    // don't validate ignored inputs or hidden inputs or disabled inputs\n    if ($el.is('[data-abide-ignore]') || $el.is('[type=\"hidden\"]') || $el.is('[disabled]')) {\n      return true;\n    }\n\n    switch ($el[0].type) {\n      case 'radio':\n        validated = this.validateRadio($el.attr('name'));\n        break;\n\n      case 'checkbox':\n        validated = clearRequire;\n        break;\n\n      case 'select':\n      case 'select-one':\n      case 'select-multiple':\n        validated = clearRequire;\n        break;\n\n      default:\n        validated = this.validateText($el);\n    }\n\n    if (validator) {\n      customValidator = this.matchValidation($el, validator, $el.attr('required'));\n    }\n\n    if ($el.attr('data-equalto')) {\n      equalTo = this.options.validators.equalTo($el);\n    }\n\n\n    var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;\n    var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';\n\n    if (goodToGo) {\n      // Re-validate inputs that depend on this one with equalto\n      const dependentElements = this.$element.find(`[data-equalto=\"${$el.attr('id')}\"]`);\n      if (dependentElements.length) {\n        let _this = this;\n        dependentElements.each(function() {\n          if ($(this).val()) {\n            _this.validateInput($(this));\n          }\n        });\n      }\n    }\n\n    this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);\n\n    /**\n     * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`\n     * Trigger includes the DOM element of the input.\n     * @event Abide#valid\n     * @event Abide#invalid\n     */\n    $el.trigger(message, [$el]);\n\n    return goodToGo;\n  }\n\n  /**\n   * Goes through a form and if there are any invalid inputs, it will display the form error element\n   * @returns {Boolean} noError - true if no errors were detected...\n   * @fires Abide#formvalid\n   * @fires Abide#forminvalid\n   */\n  validateForm() {\n    var acc = [];\n    var _this = this;\n\n    this.$inputs.each(function() {\n      acc.push(_this.validateInput($(this)));\n    });\n\n    var noError = acc.indexOf(false) === -1;\n\n    this.$element.find('[data-abide-error]').each((i, elem) => {\n      const $elem = $(elem);\n      // Ensure a11y attributes are set\n      if (this.options.a11yAttributes) this.addGlobalErrorA11yAttributes($elem);\n      // Show or hide the error\n      $elem.css('display', (noError ? 'none' : 'block'));\n    });\n\n    /**\n     * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.\n     * Trigger includes the element of the form.\n     * @event Abide#formvalid\n     * @event Abide#forminvalid\n     */\n    this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);\n\n    return noError;\n  }\n\n  /**\n   * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.\n   * @param {Object} $el - jQuery object to validate, should be a text input HTML element\n   * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns\n   * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified\n   */\n  validateText($el, pattern) {\n    // A pattern can be passed to this function, or it will be infered from the input's \"pattern\" attribute, or it's \"type\" attribute\n    pattern = (pattern || $el.attr('pattern') || $el.attr('type'));\n    var inputText = $el.val();\n    var valid = false;\n\n    if (inputText.length) {\n      // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp\n      if (this.options.patterns.hasOwnProperty(pattern)) {\n        valid = this.options.patterns[pattern].test(inputText);\n      }\n      // If the pattern name isn't also the type attribute of the field, then test it as a regexp\n      else if (pattern !== $el.attr('type')) {\n        valid = new RegExp(pattern).test(inputText);\n      }\n      else {\n        valid = true;\n      }\n    }\n    // An empty field is valid if it's not required\n    else if (!$el.prop('required')) {\n      valid = true;\n    }\n\n    return valid;\n   }\n\n  /**\n   * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.\n   * @param {String} groupName - A string that specifies the name of a radio button group\n   * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)\n   */\n  validateRadio(groupName) {\n    // If at least one radio in the group has the `required` attribute, the group is considered required\n    // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice\n    var $group = this.$element.find(`:radio[name=\"${groupName}\"]`);\n    var valid = false, required = false;\n\n    // For the group to be required, at least one radio needs to be required\n    $group.each((i, e) => {\n      if ($(e).attr('required')) {\n        required = true;\n      }\n    });\n    if(!required) valid=true;\n\n    if (!valid) {\n      // For the group to be valid, at least one radio needs to be checked\n      $group.each((i, e) => {\n        if ($(e).prop('checked')) {\n          valid = true;\n        }\n      });\n    };\n\n    return valid;\n  }\n\n  /**\n   * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator=\"foo bar baz\"` in a space separated listed.\n   * @param {Object} $el - jQuery input element.\n   * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.\n   * @param {Boolean} required - self explanatory?\n   * @returns {Boolean} - true if validations passed.\n   */\n  matchValidation($el, validators, required) {\n    required = required ? true : false;\n\n    var clear = validators.split(' ').map((v) => {\n      return this.options.validators[v]($el, required, $el.parent());\n    });\n    return clear.indexOf(false) === -1;\n  }\n\n  /**\n   * Resets form inputs and styles\n   * @fires Abide#formreset\n   */\n  resetForm() {\n    var $form = this.$element,\n        opts = this.options;\n\n    $(`.${opts.labelErrorClass}`, $form).not('small').removeClass(opts.labelErrorClass);\n    $(`.${opts.inputErrorClass}`, $form).not('small').removeClass(opts.inputErrorClass);\n    $(`${opts.formErrorSelector}.${opts.formErrorClass}`).removeClass(opts.formErrorClass);\n    $form.find('[data-abide-error]').css('display', 'none');\n    $(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:radio', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    $(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked',false).attr({\n      'data-invalid': null,\n      'aria-invalid': null\n    });\n    /**\n     * Fires when the form has been reset.\n     * @event Abide#formreset\n     */\n    $form.trigger('formreset.zf.abide', [$form]);\n  }\n\n  /**\n   * Destroys an instance of Abide.\n   * Removes error styles and classes from elements, without resetting their values.\n   */\n  _destroy() {\n    var _this = this;\n    this.$element\n      .off('.abide')\n      .find('[data-abide-error]')\n        .css('display', 'none');\n\n    this.$inputs\n      .off('.abide')\n      .each(function() {\n        _this.removeErrorClasses($(this));\n      });\n  }\n}\n\n/**\n * Default settings for plugin\n */\nAbide.defaults = {\n  /**\n   * The default event to validate inputs. Checkboxes and radios validate immediately.\n   * Remove or change this value for manual validation.\n   * @option\n   * @type {?string}\n   * @default 'fieldChange'\n   */\n  validateOn: 'fieldChange',\n\n  /**\n   * Class to be applied to input labels on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-label'\n   */\n  labelErrorClass: 'is-invalid-label',\n\n  /**\n   * Class to be applied to inputs on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-input'\n   */\n  inputErrorClass: 'is-invalid-input',\n\n  /**\n   * Class selector to use to target Form Errors for show/hide.\n   * @option\n   * @type {string}\n   * @default '.form-error'\n   */\n  formErrorSelector: '.form-error',\n\n  /**\n   * Class added to Form Errors on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-visible'\n   */\n  formErrorClass: 'is-visible',\n\n  /**\n   * If true, automatically insert when possible:\n   * - `[aria-describedby]` on fields\n   * - `[role=alert]` on form errors and `[for]` on form error labels\n   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  a11yAttributes: true,\n\n  /**\n   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.\n   * Options are: 'assertive', 'polite' and 'off'/null\n   * @option\n   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions\n   * @type {string}\n   * @default 'assertive'\n   */\n  a11yErrorLevel: 'assertive',\n\n  /**\n   * Set to true to validate text inputs on any value change.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  liveValidate: false,\n\n  /**\n   * Set to true to validate inputs on blur.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  validateOnBlur: false,\n\n  patterns: {\n    alpha : /^[a-zA-Z]+$/,\n    alpha_numeric : /^[a-zA-Z0-9]+$/,\n    integer : /^[-+]?\\d+$/,\n    number : /^[-+]?\\d*(?:[\\.\\,]\\d+)?$/,\n\n    // amex, visa, diners\n    card : /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\\d{3})\\d{11})$/,\n    cvv : /^([0-9]){3,4}$/,\n\n    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address\n    email : /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,\n\n    // From CommonRegexJS (@talyssonoc)\n    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76\n    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.\n    url: /^((?:(https?|ftps?|file|ssh|sftp):\\/\\/|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}\\/)(?:[^\\s()<>]+|\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\))+(?:\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:\\'\".,<>?\\xab\\xbb\\u201c\\u201d\\u2018\\u2019]))$/,\n\n    // abc.de\n    domain : /^([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,8}$/,\n\n    datetime : /^([0-2][0-9]{3})\\-([0-1][0-9])\\-([0-3][0-9])T([0-5][0-9])\\:([0-5][0-9])\\:([0-5][0-9])(Z|([\\-\\+]([0-1][0-9])\\:00))$/,\n    // YYYY-MM-DD\n    date : /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,\n    // HH:MM:SS\n    time : /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,\n    dateISO : /^\\d{4}[\\/\\-]\\d{1,2}[\\/\\-]\\d{1,2}$/,\n    // MM/DD/YYYY\n    month_day_year : /^(0[1-9]|1[012])[- \\/.](0[1-9]|[12][0-9]|3[01])[- \\/.]\\d{4}$/,\n    // DD/MM/YYYY\n    day_month_year : /^(0[1-9]|[12][0-9]|3[01])[- \\/.](0[1-9]|1[012])[- \\/.]\\d{4}$/,\n\n    // #FFF or #FFFFFF\n    color : /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,\n\n    // Domain || URL\n    website: {\n      test: (text) => {\n        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);\n      }\n    }\n  },\n\n  /**\n   * Optional validation functions to be used. `equalTo` being the only default included function.\n   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:\n   * el : The jQuery element to validate.\n   * required : Boolean value of the required attribute be present or not.\n   * parent : The direct parent of the input.\n   * @option\n   */\n  validators: {\n    equalTo: function (el, required, parent) {\n      return $(`#${el.attr('data-equalto')}`).val() === el.val();\n    }\n  }\n}\n\nexport {Abide};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 11a923c6e2987af4670465f84d4d19e7656c2b96..3a8c01bd27d9a7ca2cf94ddeb94a7f177a185f6b 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(r){if(a[r])return a[r].exports;var i=a[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,t),i.l=!0,i.exports}var a={};t.m=e,t.c=a,t.i=function(e){return e},t.d=function(e,a,r){t.o(e,a)||Object.defineProperty(e,a,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var a=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(a,"a",a),a},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=79)}({0:function(e,t){e.exports=jQuery},1:function(e,t){e.exports={Foundation:window.Foundation}},13:function(e,t,a){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=a(1),i=(a.n(r),a(43));r.Foundation.plugin(i.a,"Abide")},2:function(e,t){e.exports={Plugin:window.Foundation.Plugin}},43:function(e,t,a){"use strict";function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function i(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function n(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}a.d(t,"a",function(){return d});var o=a(0),s=a.n(o),u=a(2),l=(a.n(u),function(){function e(e,t){for(var a=0;a<t.length;a++){var r=t[a];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,a,r){return a&&e(t.prototype,a),r&&e(t,r),t}}()),d=function(e){function t(){return r(this,t),i(this,(t.__proto__||Object.getPrototypeOf(t)).apply(this,arguments))}return n(t,e),l(t,[{key:"_setup",value:function(e){var a=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.$element=e,this.options=s.a.extend(!0,{},t.defaults,this.$element.data(),a),this.className="Abide",this._init()}},{key:"_init",value:function(){this.$inputs=this.$element.find("input, textarea, select"),this._events()}},{key:"_events",value:function(){var e=this;this.$element.off(".abide").on("reset.zf.abide",function(){e.resetForm()}).on("submit.zf.abide",function(){return e.validateForm()}),"fieldChange"===this.options.validateOn&&this.$inputs.off("change.zf.abide").on("change.zf.abide",function(t){e.validateInput(s()(t.target))}),this.options.liveValidate&&this.$inputs.off("input.zf.abide").on("input.zf.abide",function(t){e.validateInput(s()(t.target))}),this.options.validateOnBlur&&this.$inputs.off("blur.zf.abide").on("blur.zf.abide",function(t){e.validateInput(s()(t.target))})}},{key:"_reflow",value:function(){this._init()}},{key:"requiredCheck",value:function(e){if(!e.attr("required"))return!0;var t=!0;switch(e[0].type){case"checkbox":t=e[0].checked;break;case"select":case"select-one":case"select-multiple":var a=e.find("option:selected");a.length&&a.val()||(t=!1);break;default:e.val()&&e.val().length||(t=!1)}return t}},{key:"findFormError",value:function(e){var t=e[0].id,a=e.siblings(this.options.formErrorSelector);return a.length||(a=e.parent().find(this.options.formErrorSelector)),a=a.add(this.$element.find('[data-form-error-for="'+t+'"]'))}},{key:"findLabel",value:function(e){var t=e[0].id,a=this.$element.find('label[for="'+t+'"]');return a.length?a:e.closest("label")}},{key:"findRadioLabels",value:function(e){var t=this,a=e.map(function(e,a){var r=a.id,i=t.$element.find('label[for="'+r+'"]');return i.length||(i=s()(a).closest("label")),i[0]});return s()(a)}},{key:"addErrorClasses",value:function(e){var t=this.findLabel(e),a=this.findFormError(e);t.length&&t.addClass(this.options.labelErrorClass),a.length&&a.addClass(this.options.formErrorClass),e.addClass(this.options.inputErrorClass).attr("data-invalid","")}},{key:"removeRadioErrorClasses",value:function(e){var t=this.$element.find(':radio[name="'+e+'"]'),a=this.findRadioLabels(t),r=this.findFormError(t);a.length&&a.removeClass(this.options.labelErrorClass),r.length&&r.removeClass(this.options.formErrorClass),t.removeClass(this.options.inputErrorClass).removeAttr("data-invalid")}},{key:"removeErrorClasses",value:function(e){if("radio"==e[0].type)return this.removeRadioErrorClasses(e.attr("name"));var t=this.findLabel(e),a=this.findFormError(e);t.length&&t.removeClass(this.options.labelErrorClass),a.length&&a.removeClass(this.options.formErrorClass),e.removeClass(this.options.inputErrorClass).removeAttr("data-invalid")}},{key:"validateInput",value:function(e){var t=this.requiredCheck(e),a=!1,r=!0,i=e.attr("data-validator"),n=!0;if(e.is("[data-abide-ignore]")||e.is('[type="hidden"]')||e.is("[disabled]"))return!0;switch(e[0].type){case"radio":a=this.validateRadio(e.attr("name"));break;case"checkbox":a=t;break;case"select":case"select-one":case"select-multiple":a=t;break;default:a=this.validateText(e)}i&&(r=this.matchValidation(e,i,e.attr("required"))),e.attr("data-equalto")&&(n=this.options.validators.equalTo(e));var o=-1===[t,a,r,n].indexOf(!1),u=(o?"valid":"invalid")+".zf.abide";if(o){var l=this.$element.find('[data-equalto="'+e.attr("id")+'"]');if(l.length){var d=this;l.each(function(){s()(this).val()&&d.validateInput(s()(this))})}}return this[o?"removeErrorClasses":"addErrorClasses"](e),e.trigger(u,[e]),o}},{key:"validateForm",value:function(){var e=[],t=this;this.$inputs.each(function(){e.push(t.validateInput(s()(this)))});var a=-1===e.indexOf(!1);return this.$element.find("[data-abide-error]").css("display",a?"none":"block"),this.$element.trigger((a?"formvalid":"forminvalid")+".zf.abide",[this.$element]),a}},{key:"validateText",value:function(e,t){t=t||e.attr("pattern")||e.attr("type");var a=e.val(),r=!1;return a.length?r=this.options.patterns.hasOwnProperty(t)?this.options.patterns[t].test(a):t===e.attr("type")||new RegExp(t).test(a):e.prop("required")||(r=!0),r}},{key:"validateRadio",value:function(e){var t=this.$element.find(':radio[name="'+e+'"]'),a=!1,r=!1;return t.each(function(e,t){s()(t).attr("required")&&(r=!0)}),r||(a=!0),a||t.each(function(e,t){s()(t).prop("checked")&&(a=!0)}),a}},{key:"matchValidation",value:function(e,t,a){var r=this;return a=!!a,-1===t.split(" ").map(function(t){return r.options.validators[t](e,a,e.parent())}).indexOf(!1)}},{key:"resetForm",value:function(){var e=this.$element,t=this.options;s()("."+t.labelErrorClass,e).not("small").removeClass(t.labelErrorClass),s()("."+t.inputErrorClass,e).not("small").removeClass(t.inputErrorClass),s()(t.formErrorSelector+"."+t.formErrorClass).removeClass(t.formErrorClass),e.find("[data-abide-error]").css("display","none"),s()(":input",e).not(":button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]").val("").removeAttr("data-invalid"),s()(":input:radio",e).not("[data-abide-ignore]").prop("checked",!1).removeAttr("data-invalid"),s()(":input:checkbox",e).not("[data-abide-ignore]").prop("checked",!1).removeAttr("data-invalid"),e.trigger("formreset.zf.abide",[e])}},{key:"_destroy",value:function(){var e=this;this.$element.off(".abide").find("[data-abide-error]").css("display","none"),this.$inputs.off(".abide").each(function(){e.removeErrorClasses(s()(this))})}}]),t}(u.Plugin);d.defaults={validateOn:"fieldChange",labelErrorClass:"is-invalid-label",inputErrorClass:"is-invalid-input",formErrorSelector:".form-error",formErrorClass:"is-visible",liveValidate:!1,validateOnBlur:!1,patterns:{alpha:/^[a-zA-Z]+$/,alpha_numeric:/^[a-zA-Z0-9]+$/,integer:/^[-+]?\d+$/,number:/^[-+]?\d*(?:[\.\,]\d+)?$/,card:/^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,cvv:/^([0-9]){3,4}$/,email:/^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,url:/^(https?|ftp|file|ssh):\/\/(((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:)*@)?(((\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d\d|2[0-4]\d|25[0-5]))|((([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-zA-Z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?)(:\d*)?)(\/((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)+(\/(([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)*)*)?)?(\?((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|[\uE000-\uF8FF]|\/|\?)*)?(\#((([a-zA-Z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(%[\da-f]{2})|[!\$&'\(\)\*\+,;=]|:|@)|\/|\?)*)?$/,domain:/^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,datetime:/^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,date:/(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,time:/^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,dateISO:/^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,month_day_year:/^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,day_month_year:/^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,color:/^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,website:{test:function(e){return d.defaults.patterns.domain.test(e)||d.defaults.patterns.url.test(e)}}},validators:{equalTo:function(e,t,a){return s()("#"+e.attr("data-equalto")).val()===e.val()}}}},79:function(e,t,a){e.exports=a(13)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],e):"object"==typeof exports?exports["foundation.abide"]=e(require("./foundation.core"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.abide"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.jQuery))}(window,function(r,a){return function(r){var a={};function i(t){if(a[t])return a[t].exports;var e=a[t]={i:t,l:!1,exports:{}};return r[t].call(e.exports,e,e.exports,i),e.l=!0,e.exports}return i.m=r,i.c=a,i.d=function(t,e,r){i.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},i.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},i.t=function(e,t){if(1&t&&(e=i(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var r=Object.create(null);if(i.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var a in e)i.d(r,a,function(t){return e[t]}.bind(null,a));return r},i.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return i.d(e,"a",e),e},i.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},i.p="",i(i.s=0)}({"./foundation.core":function(t,e){t.exports=r},"./js/entries/plugins/foundation.abide.js":function(t,e,r){"use strict";r.r(e);var a=r("./foundation.core");r.d(e,"Foundation",function(){return a.Foundation});var i=r("./js/foundation.abide.js");r.d(e,"Abide",function(){return i.Abide}),a.Foundation.plugin(i.Abide,"Abide")},"./js/foundation.abide.js":function(t,e,r){"use strict";r.r(e),r.d(e,"Abide",function(){return f});var a=r("jquery"),d=r.n(a),o=r("./foundation.core");function i(t){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function n(t,e){for(var r=0;r<e.length;r++){var a=e[r];a.enumerable=a.enumerable||!1,a.configurable=!0,"value"in a&&(a.writable=!0),Object.defineProperty(t,a.key,a)}}function s(t,e){return!e||"object"!==i(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function l(t){return(l=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function u(t,e){return(u=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var f=function(t){function r(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,r),s(this,l(r).apply(this,arguments))}var e,a,i;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&u(t,e)}(r,o["Plugin"]),e=r,(a=[{key:"_setup",value:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{};this.$element=t,this.options=d.a.extend(!0,{},r.defaults,this.$element.data(),e),this.className="Abide",this._init()}},{key:"_init",value:function(){var r=this;this.$inputs=d.a.merge(this.$element.find("input").not("[type=submit]"),this.$element.find("textarea, select"));var t=this.$element.find("[data-abide-error]");this.options.a11yAttributes&&(this.$inputs.each(function(t,e){return r.addA11yAttributes(d()(e))}),t.each(function(t,e){return r.addGlobalErrorA11yAttributes(d()(e))})),this._events()}},{key:"_events",value:function(){var e=this;this.$element.off(".abide").on("reset.zf.abide",function(){e.resetForm()}).on("submit.zf.abide",function(){return e.validateForm()}),"fieldChange"===this.options.validateOn&&this.$inputs.off("change.zf.abide").on("change.zf.abide",function(t){e.validateInput(d()(t.target))}),this.options.liveValidate&&this.$inputs.off("input.zf.abide").on("input.zf.abide",function(t){e.validateInput(d()(t.target))}),this.options.validateOnBlur&&this.$inputs.off("blur.zf.abide").on("blur.zf.abide",function(t){e.validateInput(d()(t.target))})}},{key:"_reflow",value:function(){this._init()}},{key:"requiredCheck",value:function(t){if(!t.attr("required"))return!0;var e=!0;switch(t[0].type){case"checkbox":e=t[0].checked;break;case"select":case"select-one":case"select-multiple":var r=t.find("option:selected");r.length&&r.val()||(e=!1);break;default:t.val()&&t.val().length||(e=!1)}return e}},{key:"findFormError",value:function(t){var e=t[0].id,r=t.siblings(this.options.formErrorSelector);return r.length||(r=t.parent().find(this.options.formErrorSelector)),e&&(r=r.add(this.$element.find('[data-form-error-for="'.concat(e,'"]')))),r}},{key:"findLabel",value:function(t){var e=t[0].id,r=this.$element.find('label[for="'.concat(e,'"]'));return r.length?r:t.closest("label")}},{key:"findRadioLabels",value:function(t){var i=this,e=t.map(function(t,e){var r=e.id,a=i.$element.find('label[for="'.concat(r,'"]'));return a.length||(a=d()(e).closest("label")),a[0]});return d()(e)}},{key:"addErrorClasses",value:function(t){var e=this.findLabel(t),r=this.findFormError(t);e.length&&e.addClass(this.options.labelErrorClass),r.length&&r.addClass(this.options.formErrorClass),t.addClass(this.options.inputErrorClass).attr({"data-invalid":"","aria-invalid":!0})}},{key:"addA11yAttributes",value:function(t){var e=this.findFormError(t),r=e.filter("label"),a=e.first();if(e.length){if(void 0===t.attr("aria-describedby")){var i=a.attr("id");void 0===i&&(i=Object(o.GetYoDigits)(6,"abide-error"),a.attr("id",i)),t.attr("aria-describedby",i)}if(r.filter("[for]").length<r.length){var n=t.attr("id");void 0===n&&(n=Object(o.GetYoDigits)(6,"abide-input"),t.attr("id",n)),r.each(function(t,e){var r=d()(e);void 0===r.attr("for")&&r.attr("for",n)})}e.each(function(t,e){var r=d()(e);void 0===r.attr("role")&&r.attr("role","alert")}).end()}}},{key:"addGlobalErrorA11yAttributes",value:function(t){void 0===t.attr("aria-live")&&t.attr("aria-live",this.options.a11yErrorLevel)}},{key:"removeRadioErrorClasses",value:function(t){var e=this.$element.find(':radio[name="'.concat(t,'"]')),r=this.findRadioLabels(e),a=this.findFormError(e);r.length&&r.removeClass(this.options.labelErrorClass),a.length&&a.removeClass(this.options.formErrorClass),e.removeClass(this.options.inputErrorClass).attr({"data-invalid":null,"aria-invalid":null})}},{key:"removeErrorClasses",value:function(t){if("radio"==t[0].type)return this.removeRadioErrorClasses(t.attr("name"));var e=this.findLabel(t),r=this.findFormError(t);e.length&&e.removeClass(this.options.labelErrorClass),r.length&&r.removeClass(this.options.formErrorClass),t.removeClass(this.options.inputErrorClass).attr({"data-invalid":null,"aria-invalid":null})}},{key:"validateInput",value:function(t){var e=this.requiredCheck(t),r=!1,a=!0,i=t.attr("data-validator"),n=!0;if(t.is("[data-abide-ignore]")||t.is('[type="hidden"]')||t.is("[disabled]"))return!0;switch(t[0].type){case"radio":r=this.validateRadio(t.attr("name"));break;case"checkbox":r=e;break;case"select":case"select-one":case"select-multiple":r=e;break;default:r=this.validateText(t)}i&&(a=this.matchValidation(t,i,t.attr("required"))),t.attr("data-equalto")&&(n=this.options.validators.equalTo(t));var o=-1===[e,r,a,n].indexOf(!1),s=(o?"valid":"invalid")+".zf.abide";if(o){var l=this.$element.find('[data-equalto="'.concat(t.attr("id"),'"]'));if(l.length){var u=this;l.each(function(){d()(this).val()&&u.validateInput(d()(this))})}}return this[o?"removeErrorClasses":"addErrorClasses"](t),t.trigger(s,[t]),o}},{key:"validateForm",value:function(){var a=this,t=[],e=this;this.$inputs.each(function(){t.push(e.validateInput(d()(this)))});var i=-1===t.indexOf(!1);return this.$element.find("[data-abide-error]").each(function(t,e){var r=d()(e);a.options.a11yAttributes&&a.addGlobalErrorA11yAttributes(r),r.css("display",i?"none":"block")}),this.$element.trigger((i?"formvalid":"forminvalid")+".zf.abide",[this.$element]),i}},{key:"validateText",value:function(t,e){e=e||t.attr("pattern")||t.attr("type");var r=t.val(),a=!1;return r.length?a=this.options.patterns.hasOwnProperty(e)?this.options.patterns[e].test(r):e===t.attr("type")||new RegExp(e).test(r):t.prop("required")||(a=!0),a}},{key:"validateRadio",value:function(t){var e=this.$element.find(':radio[name="'.concat(t,'"]')),r=!1,a=!1;return e.each(function(t,e){d()(e).attr("required")&&(a=!0)}),a||(r=!0),r||e.each(function(t,e){d()(e).prop("checked")&&(r=!0)}),r}},{key:"matchValidation",value:function(e,t,r){var a=this;return r=!!r,-1===t.split(" ").map(function(t){return a.options.validators[t](e,r,e.parent())}).indexOf(!1)}},{key:"resetForm",value:function(){var t=this.$element,e=this.options;d()(".".concat(e.labelErrorClass),t).not("small").removeClass(e.labelErrorClass),d()(".".concat(e.inputErrorClass),t).not("small").removeClass(e.inputErrorClass),d()("".concat(e.formErrorSelector,".").concat(e.formErrorClass)).removeClass(e.formErrorClass),t.find("[data-abide-error]").css("display","none"),d()(":input",t).not(":button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]").val("").attr({"data-invalid":null,"aria-invalid":null}),d()(":input:radio",t).not("[data-abide-ignore]").prop("checked",!1).attr({"data-invalid":null,"aria-invalid":null}),d()(":input:checkbox",t).not("[data-abide-ignore]").prop("checked",!1).attr({"data-invalid":null,"aria-invalid":null}),t.trigger("formreset.zf.abide",[t])}},{key:"_destroy",value:function(){var t=this;this.$element.off(".abide").find("[data-abide-error]").css("display","none"),this.$inputs.off(".abide").each(function(){t.removeErrorClasses(d()(this))})}}])&&n(e.prototype,a),i&&n(e,i),r}();f.defaults={validateOn:"fieldChange",labelErrorClass:"is-invalid-label",inputErrorClass:"is-invalid-input",formErrorSelector:".form-error",formErrorClass:"is-visible",a11yAttributes:!0,a11yErrorLevel:"assertive",liveValidate:!1,validateOnBlur:!1,patterns:{alpha:/^[a-zA-Z]+$/,alpha_numeric:/^[a-zA-Z0-9]+$/,integer:/^[-+]?\d+$/,number:/^[-+]?\d*(?:[\.\,]\d+)?$/,card:/^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11})$/,cvv:/^([0-9]){3,4}$/,email:/^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,url:/^((?:(https?|ftps?|file|ssh|sftp):\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\))+(?:\((?:[^\s()<>]+|(?:\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?\xab\xbb\u201c\u201d\u2018\u2019]))$/,domain:/^([a-zA-Z0-9]([a-zA-Z0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,8}$/,datetime:/^([0-2][0-9]{3})\-([0-1][0-9])\-([0-3][0-9])T([0-5][0-9])\:([0-5][0-9])\:([0-5][0-9])(Z|([\-\+]([0-1][0-9])\:00))$/,date:/(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,time:/^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,dateISO:/^\d{4}[\/\-]\d{1,2}[\/\-]\d{1,2}$/,month_day_year:/^(0[1-9]|1[012])[- \/.](0[1-9]|[12][0-9]|3[01])[- \/.]\d{4}$/,day_month_year:/^(0[1-9]|[12][0-9]|3[01])[- \/.](0[1-9]|1[012])[- \/.]\d{4}$/,color:/^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,website:{test:function(t){return f.defaults.patterns.domain.test(t)||f.defaults.patterns.url.test(t)}}},validators:{equalTo:function(t,e,r){return d()("#".concat(t.attr("data-equalto"))).val()===t.val()}}}},0:function(t,e,r){t.exports=r("./js/entries/plugins/foundation.abide.js")},jquery:function(t,e){t.exports=a}})});
+//# sourceMappingURL=foundation.abide.min.js.map
diff --git a/dist/js/plugins/foundation.abide.min.js.map b/dist/js/plugins/foundation.abide.min.js.map
new file mode 100644 (file)
index 0000000..769b7f4
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.abide.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.abide.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_abide__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.abide.js","Abide","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","undefined","$element","a","extend","defaults","data","className","_init","_this2","$inputs","merge","find","not","$globalErrors","a11yAttributes","each","input","addA11yAttributes","error","addGlobalErrorA11yAttributes","_events","_this3","off","on","resetForm","validateForm","validateOn","e","validateInput","liveValidate","validateOnBlur","$el","attr","isGood","type","checked","opt","val","id","$error","siblings","formErrorSelector","parent","add","concat","$label","closest","$els","_this4","labels","map","el","findLabel","$formError","findFormError","addClass","labelErrorClass","formErrorClass","inputErrorClass","data-invalid","aria-invalid","$errors","$labels","filter","first","errorId","elemId","label","end","a11yErrorLevel","groupName","findRadioLabels","$formErrors","removeClass","removeRadioErrorClasses","clearRequire","requiredCheck","validated","customValidator","validator","equalTo","is","validateRadio","validateText","matchValidation","validators","goodToGo","indexOf","message","dependentElements","_this","trigger","_this5","acc","push","noError","elem","$elem","css","pattern","inputText","valid","patterns","test","RegExp","prop","$group","required","_this6","split","v","$form","opts","removeErrorClasses","alpha","alpha_numeric","integer","number","card","cvv","email","url","domain","datetime","date","time","dateISO","month_day_year","day_month_year","color","website","text","0","jquery"],"mappings":"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","file":"foundation.abide.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.abide\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.abide\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.abide.js\":\n/*!************************************************!*\\\n  !*** ./js/entries/plugins/foundation.abide.js ***!\n  \\************************************************/\n/*! exports provided: Foundation, Abide */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_abide__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.abide */ \"./js/foundation.abide.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Abide\", function() { return _foundation_abide__WEBPACK_IMPORTED_MODULE_1__[\"Abide\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_abide__WEBPACK_IMPORTED_MODULE_1__[\"Abide\"], 'Abide');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.abide.js\":\n/*!********************************!*\\\n  !*** ./js/foundation.abide.js ***!\n  \\********************************/\n/*! exports provided: Abide */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Abide\", function() { return Abide; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n/**\n * Abide module.\n * @module foundation.abide\n */\n\nvar Abide =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Abide, _Plugin);\n\n  function Abide() {\n    _classCallCheck(this, Abide);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Abide).apply(this, arguments));\n  }\n\n  _createClass(Abide, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Abide.\n     * @class\n     * @name Abide\n     * @fires Abide#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element) {\n      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(true, {}, Abide.defaults, this.$element.data(), options);\n      this.className = 'Abide'; // ie9 back compat\n\n      this._init();\n    }\n    /**\n     * Initializes the Abide plugin and calls functions to get Abide functioning on load.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var _this2 = this;\n\n      this.$inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.merge( // Consider as input to validate:\n      this.$element.find('input').not('[type=submit]'), // * all input fields expect submit\n      this.$element.find('textarea, select') // * all textareas and select fields\n      );\n      var $globalErrors = this.$element.find('[data-abide-error]'); // Add a11y attributes to all fields\n\n      if (this.options.a11yAttributes) {\n        this.$inputs.each(function (i, input) {\n          return _this2.addA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(input));\n        });\n        $globalErrors.each(function (i, error) {\n          return _this2.addGlobalErrorA11yAttributes(jquery__WEBPACK_IMPORTED_MODULE_0___default()(error));\n        });\n      }\n\n      this._events();\n    }\n    /**\n     * Initializes events for Abide.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this3 = this;\n\n      this.$element.off('.abide').on('reset.zf.abide', function () {\n        _this3.resetForm();\n      }).on('submit.zf.abide', function () {\n        return _this3.validateForm();\n      });\n\n      if (this.options.validateOn === 'fieldChange') {\n        this.$inputs.off('change.zf.abide').on('change.zf.abide', function (e) {\n          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));\n        });\n      }\n\n      if (this.options.liveValidate) {\n        this.$inputs.off('input.zf.abide').on('input.zf.abide', function (e) {\n          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));\n        });\n      }\n\n      if (this.options.validateOnBlur) {\n        this.$inputs.off('blur.zf.abide').on('blur.zf.abide', function (e) {\n          _this3.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target));\n        });\n      }\n    }\n    /**\n     * Calls necessary functions to update Abide upon DOM change\n     * @private\n     */\n\n  }, {\n    key: \"_reflow\",\n    value: function _reflow() {\n      this._init();\n    }\n    /**\n     * Checks whether or not a form element has the required attribute and if it's checked or not\n     * @param {Object} element - jQuery object to check for required attribute\n     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n     */\n\n  }, {\n    key: \"requiredCheck\",\n    value: function requiredCheck($el) {\n      if (!$el.attr('required')) return true;\n      var isGood = true;\n\n      switch ($el[0].type) {\n        case 'checkbox':\n          isGood = $el[0].checked;\n          break;\n\n        case 'select':\n        case 'select-one':\n        case 'select-multiple':\n          var opt = $el.find('option:selected');\n          if (!opt.length || !opt.val()) isGood = false;\n          break;\n\n        default:\n          if (!$el.val() || !$el.val().length) isGood = false;\n      }\n\n      return isGood;\n    }\n    /**\n     * Get:\n     * - Based on $el, the first element(s) corresponding to `formErrorSelector` in this order:\n     *   1. The element's direct sibling('s).\n     *   2. The element's parent's children.\n     * - Element(s) with the attribute `[data-form-error-for]` set with the element's id.\n     *\n     * This allows for multiple form errors per input, though if none are found, no form errors will be shown.\n     *\n     * @param {Object} $el - jQuery object to use as reference to find the form error selector.\n     * @returns {Object} jQuery object with the selector.\n     */\n\n  }, {\n    key: \"findFormError\",\n    value: function findFormError($el) {\n      var id = $el[0].id;\n      var $error = $el.siblings(this.options.formErrorSelector);\n\n      if (!$error.length) {\n        $error = $el.parent().find(this.options.formErrorSelector);\n      }\n\n      if (id) {\n        $error = $error.add(this.$element.find(\"[data-form-error-for=\\\"\".concat(id, \"\\\"]\")));\n      }\n\n      return $error;\n    }\n    /**\n     * Get the first element in this order:\n     * 2. The <label> with the attribute `[for=\"someInputId\"]`\n     * 3. The `.closest()` <label>\n     *\n     * @param {Object} $el - jQuery object to check for required attribute\n     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n     */\n\n  }, {\n    key: \"findLabel\",\n    value: function findLabel($el) {\n      var id = $el[0].id;\n      var $label = this.$element.find(\"label[for=\\\"\".concat(id, \"\\\"]\"));\n\n      if (!$label.length) {\n        return $el.closest('label');\n      }\n\n      return $label;\n    }\n    /**\n     * Get the set of labels associated with a set of radio els in this order\n     * 2. The <label> with the attribute `[for=\"someInputId\"]`\n     * 3. The `.closest()` <label>\n     *\n     * @param {Object} $el - jQuery object to check for required attribute\n     * @returns {Boolean} Boolean value depends on whether or not attribute is checked or empty\n     */\n\n  }, {\n    key: \"findRadioLabels\",\n    value: function findRadioLabels($els) {\n      var _this4 = this;\n\n      var labels = $els.map(function (i, el) {\n        var id = el.id;\n\n        var $label = _this4.$element.find(\"label[for=\\\"\".concat(id, \"\\\"]\"));\n\n        if (!$label.length) {\n          $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).closest('label');\n        }\n\n        return $label[0];\n      });\n      return jquery__WEBPACK_IMPORTED_MODULE_0___default()(labels);\n    }\n    /**\n     * Adds the CSS error class as specified by the Abide settings to the label, input, and the form\n     * @param {Object} $el - jQuery object to add the class to\n     */\n\n  }, {\n    key: \"addErrorClasses\",\n    value: function addErrorClasses($el) {\n      var $label = this.findLabel($el);\n      var $formError = this.findFormError($el);\n\n      if ($label.length) {\n        $label.addClass(this.options.labelErrorClass);\n      }\n\n      if ($formError.length) {\n        $formError.addClass(this.options.formErrorClass);\n      }\n\n      $el.addClass(this.options.inputErrorClass).attr({\n        'data-invalid': '',\n        'aria-invalid': true\n      });\n    }\n    /**\n     * Adds [for] and [role=alert] attributes to all form error targetting $el,\n     * and [aria-describedby] attribute to $el toward the first form error.\n     * @param {Object} $el - jQuery object\n     */\n\n  }, {\n    key: \"addA11yAttributes\",\n    value: function addA11yAttributes($el) {\n      var $errors = this.findFormError($el);\n      var $labels = $errors.filter('label');\n      var $error = $errors.first();\n      if (!$errors.length) return; // Set [aria-describedby] on the input toward the first form error if it is not set\n\n      if (typeof $el.attr('aria-describedby') === 'undefined') {\n        // Get the first error ID or create one\n        var errorId = $error.attr('id');\n\n        if (typeof errorId === 'undefined') {\n          errorId = Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'abide-error');\n          $error.attr('id', errorId);\n        }\n\n        ;\n        $el.attr('aria-describedby', errorId);\n      }\n\n      if ($labels.filter('[for]').length < $labels.length) {\n        // Get the input ID or create one\n        var elemId = $el.attr('id');\n\n        if (typeof elemId === 'undefined') {\n          elemId = Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'abide-input');\n          $el.attr('id', elemId);\n        }\n\n        ; // For each label targeting $el, set [for] if it is not set.\n\n        $labels.each(function (i, label) {\n          var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label);\n          if (typeof $label.attr('for') === 'undefined') $label.attr('for', elemId);\n        });\n      } // For each error targeting $el, set [role=alert] if it is not set.\n\n\n      $errors.each(function (i, label) {\n        var $label = jquery__WEBPACK_IMPORTED_MODULE_0___default()(label);\n        if (typeof $label.attr('role') === 'undefined') $label.attr('role', 'alert');\n      }).end();\n    }\n    /**\n     * Adds [aria-live] attribute to the given global form error $el.\n     * @param {Object} $el - jQuery object to add the attribute to\n     */\n\n  }, {\n    key: \"addGlobalErrorA11yAttributes\",\n    value: function addGlobalErrorA11yAttributes($el) {\n      if (typeof $el.attr('aria-live') === 'undefined') $el.attr('aria-live', this.options.a11yErrorLevel);\n    }\n    /**\n     * Remove CSS error classes etc from an entire radio button group\n     * @param {String} groupName - A string that specifies the name of a radio button group\n     *\n     */\n\n  }, {\n    key: \"removeRadioErrorClasses\",\n    value: function removeRadioErrorClasses(groupName) {\n      var $els = this.$element.find(\":radio[name=\\\"\".concat(groupName, \"\\\"]\"));\n      var $labels = this.findRadioLabels($els);\n      var $formErrors = this.findFormError($els);\n\n      if ($labels.length) {\n        $labels.removeClass(this.options.labelErrorClass);\n      }\n\n      if ($formErrors.length) {\n        $formErrors.removeClass(this.options.formErrorClass);\n      }\n\n      $els.removeClass(this.options.inputErrorClass).attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n    }\n    /**\n     * Removes CSS error class as specified by the Abide settings from the label, input, and the form\n     * @param {Object} $el - jQuery object to remove the class from\n     */\n\n  }, {\n    key: \"removeErrorClasses\",\n    value: function removeErrorClasses($el) {\n      // radios need to clear all of the els\n      if ($el[0].type == 'radio') {\n        return this.removeRadioErrorClasses($el.attr('name'));\n      }\n\n      var $label = this.findLabel($el);\n      var $formError = this.findFormError($el);\n\n      if ($label.length) {\n        $label.removeClass(this.options.labelErrorClass);\n      }\n\n      if ($formError.length) {\n        $formError.removeClass(this.options.formErrorClass);\n      }\n\n      $el.removeClass(this.options.inputErrorClass).attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n    }\n    /**\n     * Goes through a form to find inputs and proceeds to validate them in ways specific to their type.\n     * Ignores inputs with data-abide-ignore, type=\"hidden\" or disabled attributes set\n     * @fires Abide#invalid\n     * @fires Abide#valid\n     * @param {Object} element - jQuery object to validate, should be an HTML input\n     * @returns {Boolean} goodToGo - If the input is valid or not.\n     */\n\n  }, {\n    key: \"validateInput\",\n    value: function validateInput($el) {\n      var clearRequire = this.requiredCheck($el),\n          validated = false,\n          customValidator = true,\n          validator = $el.attr('data-validator'),\n          equalTo = true; // don't validate ignored inputs or hidden inputs or disabled inputs\n\n      if ($el.is('[data-abide-ignore]') || $el.is('[type=\"hidden\"]') || $el.is('[disabled]')) {\n        return true;\n      }\n\n      switch ($el[0].type) {\n        case 'radio':\n          validated = this.validateRadio($el.attr('name'));\n          break;\n\n        case 'checkbox':\n          validated = clearRequire;\n          break;\n\n        case 'select':\n        case 'select-one':\n        case 'select-multiple':\n          validated = clearRequire;\n          break;\n\n        default:\n          validated = this.validateText($el);\n      }\n\n      if (validator) {\n        customValidator = this.matchValidation($el, validator, $el.attr('required'));\n      }\n\n      if ($el.attr('data-equalto')) {\n        equalTo = this.options.validators.equalTo($el);\n      }\n\n      var goodToGo = [clearRequire, validated, customValidator, equalTo].indexOf(false) === -1;\n      var message = (goodToGo ? 'valid' : 'invalid') + '.zf.abide';\n\n      if (goodToGo) {\n        // Re-validate inputs that depend on this one with equalto\n        var dependentElements = this.$element.find(\"[data-equalto=\\\"\".concat($el.attr('id'), \"\\\"]\"));\n\n        if (dependentElements.length) {\n          var _this = this;\n\n          dependentElements.each(function () {\n            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val()) {\n              _this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n            }\n          });\n        }\n      }\n\n      this[goodToGo ? 'removeErrorClasses' : 'addErrorClasses']($el);\n      /**\n       * Fires when the input is done checking for validation. Event trigger is either `valid.zf.abide` or `invalid.zf.abide`\n       * Trigger includes the DOM element of the input.\n       * @event Abide#valid\n       * @event Abide#invalid\n       */\n\n      $el.trigger(message, [$el]);\n      return goodToGo;\n    }\n    /**\n     * Goes through a form and if there are any invalid inputs, it will display the form error element\n     * @returns {Boolean} noError - true if no errors were detected...\n     * @fires Abide#formvalid\n     * @fires Abide#forminvalid\n     */\n\n  }, {\n    key: \"validateForm\",\n    value: function validateForm() {\n      var _this5 = this;\n\n      var acc = [];\n\n      var _this = this;\n\n      this.$inputs.each(function () {\n        acc.push(_this.validateInput(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)));\n      });\n      var noError = acc.indexOf(false) === -1;\n      this.$element.find('[data-abide-error]').each(function (i, elem) {\n        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem); // Ensure a11y attributes are set\n\n        if (_this5.options.a11yAttributes) _this5.addGlobalErrorA11yAttributes($elem); // Show or hide the error\n\n        $elem.css('display', noError ? 'none' : 'block');\n      });\n      /**\n       * Fires when the form is finished validating. Event trigger is either `formvalid.zf.abide` or `forminvalid.zf.abide`.\n       * Trigger includes the element of the form.\n       * @event Abide#formvalid\n       * @event Abide#forminvalid\n       */\n\n      this.$element.trigger((noError ? 'formvalid' : 'forminvalid') + '.zf.abide', [this.$element]);\n      return noError;\n    }\n    /**\n     * Determines whether or a not a text input is valid based on the pattern specified in the attribute. If no matching pattern is found, returns true.\n     * @param {Object} $el - jQuery object to validate, should be a text input HTML element\n     * @param {String} pattern - string value of one of the RegEx patterns in Abide.options.patterns\n     * @returns {Boolean} Boolean value depends on whether or not the input value matches the pattern specified\n     */\n\n  }, {\n    key: \"validateText\",\n    value: function validateText($el, pattern) {\n      // A pattern can be passed to this function, or it will be infered from the input's \"pattern\" attribute, or it's \"type\" attribute\n      pattern = pattern || $el.attr('pattern') || $el.attr('type');\n      var inputText = $el.val();\n      var valid = false;\n\n      if (inputText.length) {\n        // If the pattern attribute on the element is in Abide's list of patterns, then test that regexp\n        if (this.options.patterns.hasOwnProperty(pattern)) {\n          valid = this.options.patterns[pattern].test(inputText);\n        } // If the pattern name isn't also the type attribute of the field, then test it as a regexp\n        else if (pattern !== $el.attr('type')) {\n            valid = new RegExp(pattern).test(inputText);\n          } else {\n            valid = true;\n          }\n      } // An empty field is valid if it's not required\n      else if (!$el.prop('required')) {\n          valid = true;\n        }\n\n      return valid;\n    }\n    /**\n     * Determines whether or a not a radio input is valid based on whether or not it is required and selected. Although the function targets a single `<input>`, it validates by checking the `required` and `checked` properties of all radio buttons in its group.\n     * @param {String} groupName - A string that specifies the name of a radio button group\n     * @returns {Boolean} Boolean value depends on whether or not at least one radio input has been selected (if it's required)\n     */\n\n  }, {\n    key: \"validateRadio\",\n    value: function validateRadio(groupName) {\n      // If at least one radio in the group has the `required` attribute, the group is considered required\n      // Per W3C spec, all radio buttons in a group should have `required`, but we're being nice\n      var $group = this.$element.find(\":radio[name=\\\"\".concat(groupName, \"\\\"]\"));\n      var valid = false,\n          required = false; // For the group to be required, at least one radio needs to be required\n\n      $group.each(function (i, e) {\n        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).attr('required')) {\n          required = true;\n        }\n      });\n      if (!required) valid = true;\n\n      if (!valid) {\n        // For the group to be valid, at least one radio needs to be checked\n        $group.each(function (i, e) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e).prop('checked')) {\n            valid = true;\n          }\n        });\n      }\n\n      ;\n      return valid;\n    }\n    /**\n     * Determines if a selected input passes a custom validation function. Multiple validations can be used, if passed to the element with `data-validator=\"foo bar baz\"` in a space separated listed.\n     * @param {Object} $el - jQuery input element.\n     * @param {String} validators - a string of function names matching functions in the Abide.options.validators object.\n     * @param {Boolean} required - self explanatory?\n     * @returns {Boolean} - true if validations passed.\n     */\n\n  }, {\n    key: \"matchValidation\",\n    value: function matchValidation($el, validators, required) {\n      var _this6 = this;\n\n      required = required ? true : false;\n      var clear = validators.split(' ').map(function (v) {\n        return _this6.options.validators[v]($el, required, $el.parent());\n      });\n      return clear.indexOf(false) === -1;\n    }\n    /**\n     * Resets form inputs and styles\n     * @fires Abide#formreset\n     */\n\n  }, {\n    key: \"resetForm\",\n    value: function resetForm() {\n      var $form = this.$element,\n          opts = this.options;\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\".\".concat(opts.labelErrorClass), $form).not('small').removeClass(opts.labelErrorClass);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\".\".concat(opts.inputErrorClass), $form).not('small').removeClass(opts.inputErrorClass);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"\".concat(opts.formErrorSelector, \".\").concat(opts.formErrorClass)).removeClass(opts.formErrorClass);\n      $form.find('[data-abide-error]').css('display', 'none');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input', $form).not(':button, :submit, :reset, :hidden, :radio, :checkbox, [data-abide-ignore]').val('').attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:radio', $form).not('[data-abide-ignore]').prop('checked', false).attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(':input:checkbox', $form).not('[data-abide-ignore]').prop('checked', false).attr({\n        'data-invalid': null,\n        'aria-invalid': null\n      });\n      /**\n       * Fires when the form has been reset.\n       * @event Abide#formreset\n       */\n\n      $form.trigger('formreset.zf.abide', [$form]);\n    }\n    /**\n     * Destroys an instance of Abide.\n     * Removes error styles and classes from elements, without resetting their values.\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      var _this = this;\n\n      this.$element.off('.abide').find('[data-abide-error]').css('display', 'none');\n      this.$inputs.off('.abide').each(function () {\n        _this.removeErrorClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n      });\n    }\n  }]);\n\n  return Abide;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nAbide.defaults = {\n  /**\n   * The default event to validate inputs. Checkboxes and radios validate immediately.\n   * Remove or change this value for manual validation.\n   * @option\n   * @type {?string}\n   * @default 'fieldChange'\n   */\n  validateOn: 'fieldChange',\n\n  /**\n   * Class to be applied to input labels on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-label'\n   */\n  labelErrorClass: 'is-invalid-label',\n\n  /**\n   * Class to be applied to inputs on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-invalid-input'\n   */\n  inputErrorClass: 'is-invalid-input',\n\n  /**\n   * Class selector to use to target Form Errors for show/hide.\n   * @option\n   * @type {string}\n   * @default '.form-error'\n   */\n  formErrorSelector: '.form-error',\n\n  /**\n   * Class added to Form Errors on failed validation.\n   * @option\n   * @type {string}\n   * @default 'is-visible'\n   */\n  formErrorClass: 'is-visible',\n\n  /**\n   * If true, automatically insert when possible:\n   * - `[aria-describedby]` on fields\n   * - `[role=alert]` on form errors and `[for]` on form error labels\n   * - `[aria-live]` on global errors `[data-abide-error]` (see option `a11yErrorLevel`).\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  a11yAttributes: true,\n\n  /**\n   * [aria-live] attribute value to be applied on global errors `[data-abide-error]`.\n   * Options are: 'assertive', 'polite' and 'off'/null\n   * @option\n   * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/ARIA_Live_Regions\n   * @type {string}\n   * @default 'assertive'\n   */\n  a11yErrorLevel: 'assertive',\n\n  /**\n   * Set to true to validate text inputs on any value change.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  liveValidate: false,\n\n  /**\n   * Set to true to validate inputs on blur.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  validateOnBlur: false,\n  patterns: {\n    alpha: /^[a-zA-Z]+$/,\n    alpha_numeric: /^[a-zA-Z0-9]+$/,\n    integer: /^[-+]?\\d+$/,\n    number: /^[-+]?\\d*(?:[\\.\\,]\\d+)?$/,\n    // amex, visa, diners\n    card: /^(?:4[0-9]{12}(?:[0-9]{3})?|5[1-5][0-9]{14}|(?:222[1-9]|2[3-6][0-9]{2}|27[0-1][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\\d{3})\\d{11})$/,\n    cvv: /^([0-9]){3,4}$/,\n    // http://www.whatwg.org/specs/web-apps/current-work/multipage/states-of-the-type-attribute.html#valid-e-mail-address\n    email: /^[a-zA-Z0-9.!#$%&'*+\\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+$/,\n    // From CommonRegexJS (@talyssonoc)\n    // https://github.com/talyssonoc/CommonRegexJS/blob/e2901b9f57222bc14069dc8f0598d5f412555411/lib/commonregex.js#L76\n    // For more restrictive URL Regexs, see https://mathiasbynens.be/demo/url-regex.\n    url: /^((?:(https?|ftps?|file|ssh|sftp):\\/\\/|www\\d{0,3}[.]|[a-z0-9.\\-]+[.][a-z]{2,4}\\/)(?:[^\\s()<>]+|\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\))+(?:\\((?:[^\\s()<>]+|(?:\\([^\\s()<>]+\\)))*\\)|[^\\s`!()\\[\\]{};:\\'\".,<>?\\xab\\xbb\\u201c\\u201d\\u2018\\u2019]))$/,\n    // abc.de\n    domain: /^([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,8}$/,\n    datetime: /^([0-2][0-9]{3})\\-([0-1][0-9])\\-([0-3][0-9])T([0-5][0-9])\\:([0-5][0-9])\\:([0-5][0-9])(Z|([\\-\\+]([0-1][0-9])\\:00))$/,\n    // YYYY-MM-DD\n    date: /(?:19|20)[0-9]{2}-(?:(?:0[1-9]|1[0-2])-(?:0[1-9]|1[0-9]|2[0-9])|(?:(?!02)(?:0[1-9]|1[0-2])-(?:30))|(?:(?:0[13578]|1[02])-31))$/,\n    // HH:MM:SS\n    time: /^(0[0-9]|1[0-9]|2[0-3])(:[0-5][0-9]){2}$/,\n    dateISO: /^\\d{4}[\\/\\-]\\d{1,2}[\\/\\-]\\d{1,2}$/,\n    // MM/DD/YYYY\n    month_day_year: /^(0[1-9]|1[012])[- \\/.](0[1-9]|[12][0-9]|3[01])[- \\/.]\\d{4}$/,\n    // DD/MM/YYYY\n    day_month_year: /^(0[1-9]|[12][0-9]|3[01])[- \\/.](0[1-9]|1[012])[- \\/.]\\d{4}$/,\n    // #FFF or #FFFFFF\n    color: /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/,\n    // Domain || URL\n    website: {\n      test: function test(text) {\n        return Abide.defaults.patterns['domain'].test(text) || Abide.defaults.patterns['url'].test(text);\n      }\n    }\n  },\n\n  /**\n   * Optional validation functions to be used. `equalTo` being the only default included function.\n   * Functions should return only a boolean if the input is valid or not. Functions are given the following arguments:\n   * el : The jQuery element to validate.\n   * required : Boolean value of the required attribute be present or not.\n   * parent : The direct parent of the input.\n   * @option\n   */\n  validators: {\n    equalTo: function equalTo(el, required, parent) {\n      return jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(el.attr('data-equalto'))).val() === el.val();\n    }\n  }\n};\n\n\n/***/ }),\n\n/***/ 0:\n/*!******************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.abide.js ***!\n  \\******************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.abide.js */\"./js/entries/plugins/foundation.abide.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.abide.js.map"]}
\ No newline at end of file
index e1d18d89d87832bebc38975f458d459f6a9a3e61..0470560bbbc6626977c69d3266b1fb086643afb7 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.keyboard", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.accordion"] = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.accordion"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 80);
+/******/       return __webpack_require__(__webpack_require__.s = 1);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
 /***/ }),
 
-/***/ 14:
+/***/ "./js/entries/plugins/foundation.accordion.js":
+/*!****************************************************!*\
+  !*** ./js/entries/plugins/foundation.accordion.js ***!
+  \****************************************************/
+/*! exports provided: Foundation, Accordion */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_accordion__ = __webpack_require__(44);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.accordion */ "./js/foundation.accordion.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Accordion", function() { return _foundation_accordion__WEBPACK_IMPORTED_MODULE_1__["Accordion"]; });
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_accordion__["a" /* Accordion */], 'Accordion');
 
-/***/ }),
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_accordion__WEBPACK_IMPORTED_MODULE_1__["Accordion"], 'Accordion');
 
-/***/ 2:
-/***/ (function(module, exports) {
-
-module.exports = {Plugin: window.Foundation.Plugin};
 
 /***/ }),
 
-/***/ 3:
-/***/ (function(module, exports) {
-
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
-
-/***/ }),
-
-/***/ 44:
+/***/ "./js/foundation.accordion.js":
+/*!************************************!*\
+  !*** ./js/foundation.accordion.js ***!
+  \************************************/
+/*! exports provided: Accordion */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Accordion; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Accordion", function() { return Accordion; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return 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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -145,17 +187,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.keyboard
  */
 
-var Accordion = function (_Plugin) {
+var Accordion =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Accordion, _Plugin);
 
   function Accordion() {
     _classCallCheck(this, Accordion);
 
-    return _possibleConstructorReturn(this, (Accordion.__proto__ || Object.getPrototypeOf(Accordion)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Accordion).apply(this, arguments));
   }
 
   _createClass(Accordion, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of an accordion.
@@ -167,38 +211,36 @@ var Accordion = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Accordion.defaults, this.$element.data(), options);
-
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Accordion.defaults, this.$element.data(), options);
       this.className = 'Accordion'; // ie9 back compat
+
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('Accordion', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('Accordion', {
         'ENTER': 'toggle',
         'SPACE': 'toggle',
         'ARROW_DOWN': 'next',
         'ARROW_UP': 'previous'
       });
     }
-
     /**
      * Initializes the accordion by animating the preset active pane(s).
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      var _this3 = this;
+      var _this2 = this;
 
+      this._isInitializing = true;
       this.$element.attr('role', 'tablist');
       this.$tabs = this.$element.children('[data-accordion-item]');
-
       this.$tabs.each(function (idx, el) {
-        var $el = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el),
+        var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el),
             $content = $el.children('[data-tab-content]'),
-            id = $content[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["GetYoDigits"])(6, 'accordion'),
-            linkId = el.id || id + '-label';
-
+            id = $content[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'accordion'),
+            linkId = el.id ? "".concat(el.id, "-label") : "".concat(id, "-label");
         $el.find('a:first').attr({
           'aria-controls': id,
           'role': 'tab',
@@ -206,90 +248,119 @@ var Accordion = function (_Plugin) {
           'aria-expanded': false,
           'aria-selected': false
         });
-
-        $content.attr({ 'role': 'tabpanel', 'aria-labelledby': linkId, 'aria-hidden': true, 'id': id });
+        $content.attr({
+          'role': 'tabpanel',
+          'aria-labelledby': linkId,
+          'aria-hidden': true,
+          'id': id
+        });
       });
       var $initActive = this.$element.find('.is-active').children('[data-tab-content]');
-      this.firstTimeInit = true;
+
       if ($initActive.length) {
-        this.down($initActive, this.firstTimeInit);
-        this.firstTimeInit = false;
+        // Save up the initial hash to return to it later when going back in history
+        this._initialAnchor = $initActive.prev('a').attr('href');
+
+        this._openSingleTab($initActive);
       }
 
       this._checkDeepLink = function () {
         var anchor = window.location.hash;
-        //need a hash and a relevant anchor in this tabset
-        if (anchor.length) {
-          var $link = _this3.$element.find('[href$="' + anchor + '"]'),
-              $anchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(anchor);
-
-          if ($link.length && $anchor) {
-            if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {
-              _this3.down($anchor, _this3.firstTimeInit);
-              _this3.firstTimeInit = false;
-            };
-
-            //roll up a little to show the titles
-            if (_this3.options.deepLinkSmudge) {
-              var _this = _this3;
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).load(function () {
-                var offset = _this.$element.offset();
-                __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').animate({ scrollTop: offset.top }, _this.options.deepLinkSmudgeDelay);
-              });
-            }
-
-            /**
-              * Fires when the zplugin has deeplinked at pageload
-              * @event Accordion#deeplink
-              */
-            _this3.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);
+
+        if (!anchor.length) {
+          // If we are still initializing and there is no anchor, then there is nothing to do
+          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor
+
+          if (_this2._initialAnchor) anchor = _this2._initialAnchor;
+        }
+
+        var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor);
+
+        var $link = anchor && _this2.$element.find("[href$=\"".concat(anchor, "\"]")); // Whether the anchor element that has been found is part of this element
+
+
+        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, open it (if not already active)
+
+        if ($anchor && $link && $link.length) {
+          if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {
+            _this2._openSingleTab($anchor);
+          }
+
+          ;
+        } // Otherwise, close everything
+        else {
+            _this2._closeAllTabs();
           }
+
+        if (isOwnAnchor) {
+          // Roll up a little to show the titles
+          if (_this2.options.deepLinkSmudge) {
+            Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+              var offset = _this2.$element.offset();
+
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({
+                scrollTop: offset.top
+              }, _this2.options.deepLinkSmudgeDelay);
+            });
+          }
+          /**
+           * Fires when the plugin has deeplinked at pageload
+           * @event Accordion#deeplink
+           */
+
+
+          _this2.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);
         }
-      };
+      }; //use browser to open a tab, if it exists in this tabset
+
 
-      //use browser to open a tab, if it exists in this tabset
       if (this.options.deepLink) {
         this._checkDeepLink();
       }
 
       this._events();
-    }
 
+      this._isInitializing = false;
+    }
     /**
      * Adds event handlers for items within the accordion.
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this;
 
       this.$tabs.each(function () {
-        var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
         var $tabContent = $elem.children('[data-tab-content]');
+
         if ($tabContent.length) {
           $elem.children('a').off('click.zf.accordion keydown.zf.accordion').on('click.zf.accordion', function (e) {
             e.preventDefault();
+
             _this.toggle($tabContent);
           }).on('keydown.zf.accordion', function (e) {
-            __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'Accordion', {
-              toggle: function () {
+            _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'Accordion', {
+              toggle: function toggle() {
                 _this.toggle($tabContent);
               },
-              next: function () {
+              next: function next() {
                 var $a = $elem.next().find('a').focus();
+
                 if (!_this.options.multiExpand) {
                   $a.trigger('click.zf.accordion');
                 }
               },
-              previous: function () {
+              previous: function previous() {
                 var $a = $elem.prev().find('a').focus();
+
                 if (!_this.options.multiExpand) {
                   $a.trigger('click.zf.accordion');
                 }
               },
-              handled: function () {
+              handled: function handled() {
                 e.preventDefault();
                 e.stopPropagation();
               }
@@ -297,11 +368,11 @@ var Accordion = function (_Plugin) {
           });
         }
       });
+
       if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('popstate', this._checkDeepLink);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink);
       }
     }
-
     /**
      * Toggles the selected content pane's open/close state.
      * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).
@@ -309,18 +380,20 @@ var Accordion = function (_Plugin) {
      */
 
   }, {
-    key: 'toggle',
+    key: "toggle",
     value: function toggle($target) {
       if ($target.closest('[data-accordion]').is('[disabled]')) {
         console.info('Cannot toggle an accordion that is disabled.');
         return;
       }
+
       if ($target.parent().hasClass('is-active')) {
         this.up($target);
       } else {
         this.down($target);
-      }
-      //either replace or update browser history
+      } //either replace or update browser history
+
+
       if (this.options.deepLink) {
         var anchor = $target.prev('a').attr('href');
 
@@ -331,89 +404,143 @@ var Accordion = function (_Plugin) {
         }
       }
     }
-
     /**
      * Opens the accordion tab defined by `$target`.
      * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).
-     * @param {Boolean} firstTime - flag to determine if reflow should happen.
      * @fires Accordion#down
      * @function
      */
 
   }, {
-    key: 'down',
-    value: function down($target, firstTime) {
-      var _this4 = this;
-
-      /**
-       * checking firstTime allows for initial render of the accordion
-       * to render preset is-active panes.
-       */
-      if ($target.closest('[data-accordion]').is('[disabled]') && !firstTime) {
+    key: "down",
+    value: function down($target) {
+      if ($target.closest('[data-accordion]').is('[disabled]')) {
         console.info('Cannot call down on an accordion that is disabled.');
         return;
       }
-      $target.attr('aria-hidden', false).parent('[data-tab-content]').addBack().parent().addClass('is-active');
-
-      if (!this.options.multiExpand && !firstTime) {
-        var $currentActive = this.$element.children('.is-active').children('[data-tab-content]');
-        if ($currentActive.length) {
-          this.up($currentActive.not($target));
-        }
-      }
-
-      $target.slideDown(this.options.slideSpeed, function () {
-        /**
-         * Fires when the tab is done opening.
-         * @event Accordion#down
-         */
-        _this4.$element.trigger('down.zf.accordion', [$target]);
-      });
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + $target.attr('aria-labelledby')).attr({
-        'aria-expanded': true,
-        'aria-selected': true
-      });
+      if (this.options.multiExpand) this._openTab($target);else this._openSingleTab($target);
     }
-
     /**
      * Closes the tab defined by `$target`.
+     * It may be ignored if the Accordion options don't allow it.
+     *
      * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
      * @fires Accordion#up
      * @function
      */
 
   }, {
-    key: 'up',
+    key: "up",
     value: function up($target) {
-      if ($target.closest('[data-accordion]').is('[disabled]')) {
+      if (this.$element.is('[disabled]')) {
         console.info('Cannot call up on an accordion that is disabled.');
         return;
-      }
+      } // Don't close the item if it is already closed
 
-      var $aunts = $target.parent().siblings(),
-          _this = this;
 
-      if (!this.options.allowAllClosed && !$aunts.hasClass('is-active') || !$target.parent().hasClass('is-active')) {
-        return;
-      }
+      var $targetItem = $target.parent();
+      if (!$targetItem.hasClass('is-active')) return; // Don't close the item if there is no other active item (unless with `allowAllClosed`)
+
+      var $othersItems = $targetItem.siblings();
+      if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;
+
+      this._closeTab($target);
+    }
+    /**
+     * Make the tab defined by `$target` the only opened tab, closing all others tabs.
+     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_openSingleTab",
+    value: function _openSingleTab($target) {
+      // Close all the others active tabs.
+      var $activeContents = this.$element.children('.is-active').children('[data-tab-content]');
+
+      if ($activeContents.length) {
+        this._closeTab($activeContents.not($target));
+      } // Then open the target.
+
 
-      $target.slideUp(_this.options.slideSpeed, function () {
+      this._openTab($target);
+    }
+    /**
+     * Opens the tab defined by `$target`.
+     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).
+     * @fires Accordion#down
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_openTab",
+    value: function _openTab($target) {
+      var _this3 = this;
+
+      var $targetItem = $target.parent();
+      var targetContentId = $target.attr('aria-labelledby');
+      $target.attr('aria-hidden', false);
+      $targetItem.addClass('is-active');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetContentId)).attr({
+        'aria-expanded': true,
+        'aria-selected': true
+      });
+      $target.slideDown(this.options.slideSpeed, function () {
         /**
-         * Fires when the tab is done collapsing up.
-         * @event Accordion#up
+         * Fires when the tab is done opening.
+         * @event Accordion#down
          */
-        _this.$element.trigger('up.zf.accordion', [$target]);
+        _this3.$element.trigger('down.zf.accordion', [$target]);
       });
+    }
+    /**
+     * Closes the tab defined by `$target`.
+     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).
+     * @fires Accordion#up
+     * @function
+     * @private
+     */
 
-      $target.attr('aria-hidden', true).parent().removeClass('is-active');
+  }, {
+    key: "_closeTab",
+    value: function _closeTab($target) {
+      var _this4 = this;
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + $target.attr('aria-labelledby')).attr({
+      var $targetItem = $target.parent();
+      var targetContentId = $target.attr('aria-labelledby');
+      $target.attr('aria-hidden', true);
+      $targetItem.removeClass('is-active');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetContentId)).attr({
         'aria-expanded': false,
         'aria-selected': false
       });
+      $target.slideUp(this.options.slideSpeed, function () {
+        /**
+         * Fires when the tab is done collapsing up.
+         * @event Accordion#up
+         */
+        _this4.$element.trigger('up.zf.accordion', [$target]);
+      });
     }
+    /**
+     * Closes all active tabs
+     * @fires Accordion#up
+     * @function
+     * @private
+     */
 
+  }, {
+    key: "_closeAllTabs",
+    value: function _closeAllTabs() {
+      var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');
+
+      if ($activeTabs.length) {
+        this._closeTab($activeTabs);
+      }
+    }
     /**
      * Destroys an instance of an accordion.
      * @fires Accordion#destroyed
@@ -421,18 +548,19 @@ var Accordion = function (_Plugin) {
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');
       this.$element.find('a').off('.zf.accordion');
+
       if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('popstate', this._checkDeepLink);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink);
       }
     }
   }]);
 
   return Accordion;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 
 Accordion.defaults = {
   /**
@@ -442,6 +570,7 @@ Accordion.defaults = {
    * @default 250
    */
   slideSpeed: 250,
+
   /**
    * Allow the accordion to have multiple open panes.
    * @option
@@ -449,6 +578,7 @@ Accordion.defaults = {
    * @default false
    */
   multiExpand: false,
+
   /**
    * Allow the accordion to close all panes.
    * @option
@@ -456,8 +586,10 @@ Accordion.defaults = {
    * @default false
    */
   allowAllClosed: false,
+
   /**
-   * Allows the window to scroll to content of pane specified by hash anchor
+   * Link the location hash to the open pane.
+   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.
    * @option
    * @type {boolean}
    * @default false
@@ -465,7 +597,7 @@ Accordion.defaults = {
   deepLink: false,
 
   /**
-   * Adjust the deep link scroll to make sure the top of the accordion panel is visible
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible
    * @option
    * @type {boolean}
    * @default false
@@ -473,7 +605,7 @@ Accordion.defaults = {
   deepLinkSmudge: false,
 
   /**
-   * Animation time (ms) for the deep link adjustment
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
    * @option
    * @type {number}
    * @default 300
@@ -481,7 +613,7 @@ Accordion.defaults = {
   deepLinkSmudgeDelay: 300,
 
   /**
-   * Update the browser history with the open accordion
+   * If `deepLink` is enabled, update the browser history with the open accordion
    * @option
    * @type {boolean}
    * @default false
@@ -490,22 +622,31 @@ Accordion.defaults = {
 };
 
 
-
 /***/ }),
 
-/***/ 5:
-/***/ (function(module, exports) {
+/***/ 1:
+/*!**********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.accordion.js ***!
+  \**********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-module.exports = {Keyboard: window.Foundation.Keyboard};
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.accordion.js */"./js/entries/plugins/foundation.accordion.js");
 
-/***/ }),
 
-/***/ 80:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ }),
 
-module.exports = __webpack_require__(14);
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.accordion.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.accordion.js.map b/dist/js/plugins/foundation.accordion.js.map
new file mode 100644 (file)
index 0000000..83a560f
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.accordion.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.accordion.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Accordion","element","options","$element","$","extend","defaults","data","className","_init","Keyboard","register","_isInitializing","attr","$tabs","children","each","idx","el","$el","$content","id","GetYoDigits","linkId","find","$initActive","length","_initialAnchor","prev","_openSingleTab","_checkDeepLink","anchor","window","location","hash","$anchor","$link","isOwnAnchor","parent","hasClass","_closeAllTabs","deepLinkSmudge","onLoad","offset","animate","scrollTop","top","deepLinkSmudgeDelay","trigger","deepLink","_events","_this","$elem","$tabContent","off","on","e","preventDefault","toggle","handleKey","next","$a","focus","multiExpand","previous","handled","stopPropagation","$target","closest","is","console","info","up","down","updateHistory","history","pushState","replaceState","_openTab","$targetItem","$othersItems","siblings","allowAllClosed","_closeTab","$activeContents","not","targetContentId","addClass","slideDown","slideSpeed","removeClass","slideUp","$activeTabs","stop","css","Plugin"],"mappings":"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","file":"foundation.accordion.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.accordion\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.accordion\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 1);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","import { Foundation } from './foundation.core';\n\nimport { Accordion } from '../../foundation.accordion';\nFoundation.plugin(Accordion, 'Accordion');\n\nexport { Foundation, Accordion };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Accordion module.\n * @module foundation.accordion\n * @requires foundation.util.keyboard\n */\n\nclass Accordion extends Plugin {\n  /**\n   * Creates a new instance of an accordion.\n   * @class\n   * @name Accordion\n   * @fires Accordion#init\n   * @param {jQuery} element - jQuery object to make into an accordion.\n   * @param {Object} options - a plain object with settings to override the default options.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Accordion.defaults, this.$element.data(), options);\n\n    this.className = 'Accordion'; // ie9 back compat\n    this._init();\n\n    Keyboard.register('Accordion', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_DOWN': 'next',\n      'ARROW_UP': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the accordion by animating the preset active pane(s).\n   * @private\n   */\n  _init() {\n    this._isInitializing = true;\n\n    this.$element.attr('role', 'tablist');\n    this.$tabs = this.$element.children('[data-accordion-item]');\n\n    this.$tabs.each(function(idx, el) {\n      var $el = $(el),\n          $content = $el.children('[data-tab-content]'),\n          id = $content[0].id || GetYoDigits(6, 'accordion'),\n          linkId = (el.id) ? `${el.id}-label` : `${id}-label`;\n\n      $el.find('a:first').attr({\n        'aria-controls': id,\n        'role': 'tab',\n        'id': linkId,\n        'aria-expanded': false,\n        'aria-selected': false\n      });\n\n      $content.attr({'role': 'tabpanel', 'aria-labelledby': linkId, 'aria-hidden': true, 'id': id});\n    });\n\n    var $initActive = this.$element.find('.is-active').children('[data-tab-content]');\n    if ($initActive.length) {\n      // Save up the initial hash to return to it later when going back in history\n      this._initialAnchor = $initActive.prev('a').attr('href');\n      this._openSingleTab($initActive);\n    }\n\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find(`[href$=\"${anchor}\"]`);\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, open it (if not already active)\n      if ($anchor && $link && $link.length) {\n        if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {\n          this._openSingleTab($anchor);\n        };\n      }\n      // Otherwise, close everything\n      else {\n        this._closeAllTabs();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          onLoad($(window), () => {\n            var offset = this.$element.offset();\n            $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n          });\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Accordion#deeplink\n         */\n        this.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the accordion.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$tabs.each(function() {\n      var $elem = $(this);\n      var $tabContent = $elem.children('[data-tab-content]');\n      if ($tabContent.length) {\n        $elem.children('a').off('click.zf.accordion keydown.zf.accordion')\n               .on('click.zf.accordion', function(e) {\n          e.preventDefault();\n          _this.toggle($tabContent);\n        }).on('keydown.zf.accordion', function(e){\n          Keyboard.handleKey(e, 'Accordion', {\n            toggle: function() {\n              _this.toggle($tabContent);\n            },\n            next: function() {\n              var $a = $elem.next().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            previous: function() {\n              var $a = $elem.prev().find('a').focus();\n              if (!_this.options.multiExpand) {\n                $a.trigger('click.zf.accordion')\n              }\n            },\n            handled: function() {\n              e.preventDefault();\n              e.stopPropagation();\n            }\n          });\n        });\n      }\n    });\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Toggles the selected content pane's open/close state.\n   * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).\n   * @function\n   */\n  toggle($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]')) {\n      console.info('Cannot toggle an accordion that is disabled.');\n      return;\n    }\n    if($target.parent().hasClass('is-active')) {\n      this.up($target);\n    } else {\n      this.down($target);\n    }\n    //either replace or update browser history\n    if (this.options.deepLink) {\n      var anchor = $target.prev('a').attr('href');\n\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n  }\n\n  /**\n   * Opens the accordion tab defined by `$target`.\n   * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   */\n  down($target) {\n    if ($target.closest('[data-accordion]').is('[disabled]'))  {\n      console.info('Cannot call down on an accordion that is disabled.');\n      return;\n    }\n\n    if (this.options.multiExpand)\n      this._openTab($target);\n    else\n      this._openSingleTab($target);\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * It may be ignored if the Accordion options don't allow it.\n   *\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   */\n  up($target) {\n    if (this.$element.is('[disabled]')) {\n      console.info('Cannot call up on an accordion that is disabled.');\n      return;\n    }\n\n    // Don't close the item if it is already closed\n    const $targetItem = $target.parent();\n    if (!$targetItem.hasClass('is-active')) return;\n\n    // Don't close the item if there is no other active item (unless with `allowAllClosed`)\n    const $othersItems = $targetItem.siblings();\n    if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;\n\n    this._closeTab($target);\n  }\n\n  /**\n   * Make the tab defined by `$target` the only opened tab, closing all others tabs.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @function\n   * @private\n   */\n  _openSingleTab($target) {\n    // Close all the others active tabs.\n    const $activeContents = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeContents.length) {\n      this._closeTab($activeContents.not($target));\n    }\n\n    // Then open the target.\n    this._openTab($target);\n  }\n\n  /**\n   * Opens the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n   * @fires Accordion#down\n   * @function\n   * @private\n   */\n  _openTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', false);\n    $targetItem.addClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n      'aria-expanded': true,\n      'aria-selected': true\n    });\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done opening.\n       * @event Accordion#down\n       */\n      this.$element.trigger('down.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes the tab defined by `$target`.\n   * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeTab($target) {\n    const $targetItem = $target.parent();\n    const targetContentId = $target.attr('aria-labelledby');\n\n    $target.attr('aria-hidden', true)\n    $targetItem.removeClass('is-active');\n\n    $(`#${targetContentId}`).attr({\n     'aria-expanded': false,\n     'aria-selected': false\n    });\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the tab is done collapsing up.\n       * @event Accordion#up\n       */\n      this.$element.trigger('up.zf.accordion', [$target]);\n    });\n  }\n\n  /**\n   * Closes all active tabs\n   * @fires Accordion#up\n   * @function\n   * @private\n   */\n  _closeAllTabs() {\n    var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');\n    if ($activeTabs.length) {\n      this._closeTab($activeTabs);\n    }\n  }\n\n  /**\n   * Destroys an instance of an accordion.\n   * @fires Accordion#destroyed\n   * @function\n   */\n  _destroy() {\n    this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');\n    this.$element.find('a').off('.zf.accordion');\n    if(this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n  }\n}\n\nAccordion.defaults = {\n  /**\n   * Amount of time to animate the opening of an accordion pane.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Allow the accordion to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multiExpand: false,\n  /**\n   * Allow the accordion to close all panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowAllClosed: false,\n  /**\n   * Link the location hash to the open pane.\n   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open accordion\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false\n};\n\nexport {Accordion};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index fe01447a8bd79b974bd36a35e1101678b3deb940..b0ee656e5eeec1050b525b26b96e3e3722817737 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(i){if(n[i])return n[i].exports;var o=n[i]={i:i,l:!1,exports:{}};return t[i].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var n={};e.m=t,e.c=n,e.i=function(t){return t},e.d=function(t,n,i){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:i})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=80)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},14:function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=n(1),o=(n.n(i),n(44));i.Foundation.plugin(o.a,"Accordion")},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},3:function(t,e){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},44:function(t,e,n){"use strict";function i(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}n.d(e,"a",function(){return f});var r=n(0),s=n.n(r),c=n(5),d=(n.n(c),n(3)),l=(n.n(d),n(2)),u=(n.n(l),function(){function t(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}return function(e,n,i){return n&&t(e.prototype,n),i&&t(e,i),e}}()),f=function(t){function e(){return i(this,e),o(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return a(e,t),u(e,[{key:"_setup",value:function(t,n){this.$element=t,this.options=s.a.extend({},e.defaults,this.$element.data(),n),this.className="Accordion",this._init(),c.Keyboard.register("Accordion",{ENTER:"toggle",SPACE:"toggle",ARROW_DOWN:"next",ARROW_UP:"previous"})}},{key:"_init",value:function(){var t=this;this.$element.attr("role","tablist"),this.$tabs=this.$element.children("[data-accordion-item]"),this.$tabs.each(function(t,e){var i=s()(e),o=i.children("[data-tab-content]"),a=o[0].id||n.i(d.GetYoDigits)(6,"accordion"),r=e.id||a+"-label";i.find("a:first").attr({"aria-controls":a,role:"tab",id:r,"aria-expanded":!1,"aria-selected":!1}),o.attr({role:"tabpanel","aria-labelledby":r,"aria-hidden":!0,id:a})});var e=this.$element.find(".is-active").children("[data-tab-content]");this.firstTimeInit=!0,e.length&&(this.down(e,this.firstTimeInit),this.firstTimeInit=!1),this._checkDeepLink=function(){var e=window.location.hash;if(e.length){var n=t.$element.find('[href$="'+e+'"]'),i=s()(e);if(n.length&&i){if(n.parent("[data-accordion-item]").hasClass("is-active")||(t.down(i,t.firstTimeInit),t.firstTimeInit=!1),t.options.deepLinkSmudge){var o=t;s()(window).load(function(){var t=o.$element.offset();s()("html, body").animate({scrollTop:t.top},o.options.deepLinkSmudgeDelay)})}t.$element.trigger("deeplink.zf.accordion",[n,i])}}},this.options.deepLink&&this._checkDeepLink(),this._events()}},{key:"_events",value:function(){var t=this;this.$tabs.each(function(){var e=s()(this),n=e.children("[data-tab-content]");n.length&&e.children("a").off("click.zf.accordion keydown.zf.accordion").on("click.zf.accordion",function(e){e.preventDefault(),t.toggle(n)}).on("keydown.zf.accordion",function(i){c.Keyboard.handleKey(i,"Accordion",{toggle:function(){t.toggle(n)},next:function(){var n=e.next().find("a").focus();t.options.multiExpand||n.trigger("click.zf.accordion")},previous:function(){var n=e.prev().find("a").focus();t.options.multiExpand||n.trigger("click.zf.accordion")},handled:function(){i.preventDefault(),i.stopPropagation()}})})}),this.options.deepLink&&s()(window).on("popstate",this._checkDeepLink)}},{key:"toggle",value:function(t){if(t.closest("[data-accordion]").is("[disabled]"))return void console.info("Cannot toggle an accordion that is disabled.");if(t.parent().hasClass("is-active")?this.up(t):this.down(t),this.options.deepLink){var e=t.prev("a").attr("href");this.options.updateHistory?history.pushState({},"",e):history.replaceState({},"",e)}}},{key:"down",value:function(t,e){var n=this;if(t.closest("[data-accordion]").is("[disabled]")&&!e)return void console.info("Cannot call down on an accordion that is disabled.");if(t.attr("aria-hidden",!1).parent("[data-tab-content]").addBack().parent().addClass("is-active"),!this.options.multiExpand&&!e){var i=this.$element.children(".is-active").children("[data-tab-content]");i.length&&this.up(i.not(t))}t.slideDown(this.options.slideSpeed,function(){n.$element.trigger("down.zf.accordion",[t])}),s()("#"+t.attr("aria-labelledby")).attr({"aria-expanded":!0,"aria-selected":!0})}},{key:"up",value:function(t){if(t.closest("[data-accordion]").is("[disabled]"))return void console.info("Cannot call up on an accordion that is disabled.");var e=t.parent().siblings(),n=this;(this.options.allowAllClosed||e.hasClass("is-active"))&&t.parent().hasClass("is-active")&&(t.slideUp(n.options.slideSpeed,function(){n.$element.trigger("up.zf.accordion",[t])}),t.attr("aria-hidden",!0).parent().removeClass("is-active"),s()("#"+t.attr("aria-labelledby")).attr({"aria-expanded":!1,"aria-selected":!1}))}},{key:"_destroy",value:function(){this.$element.find("[data-tab-content]").stop(!0).slideUp(0).css("display",""),this.$element.find("a").off(".zf.accordion"),this.options.deepLink&&s()(window).off("popstate",this._checkDeepLink)}}]),e}(l.Plugin);f.defaults={slideSpeed:250,multiExpand:!1,allowAllClosed:!1,deepLink:!1,deepLinkSmudge:!1,deepLinkSmudgeDelay:300,updateHistory:!1}},5:function(t,e){t.exports={Keyboard:window.Foundation.Keyboard}},80:function(t,e,n){t.exports=n(14)}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("./foundation.util.keyboard"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.keyboard","jquery"],t):"object"==typeof exports?exports["foundation.accordion"]=t(require("./foundation.core"),require("./foundation.util.keyboard"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.accordion"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],e.jQuery))}(window,function(n,o,i){return function(n){var o={};function i(e){if(o[e])return o[e].exports;var t=o[e]={i:e,l:!1,exports:{}};return n[e].call(t.exports,t,t.exports,i),t.l=!0,t.exports}return i.m=n,i.c=o,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var o in t)i.d(n,o,function(e){return t[e]}.bind(null,o));return n},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="",i(i.s=1)}({"./foundation.core":function(e,t){e.exports=n},"./foundation.util.keyboard":function(e,t){e.exports=o},"./js/entries/plugins/foundation.accordion.js":function(e,t,n){"use strict";n.r(t);var o=n("./foundation.core");n.d(t,"Foundation",function(){return o.Foundation});var i=n("./js/foundation.accordion.js");n.d(t,"Accordion",function(){return i.Accordion}),o.Foundation.plugin(i.Accordion,"Accordion")},"./js/foundation.accordion.js":function(e,t,n){"use strict";n.r(t),n.d(t,"Accordion",function(){return f});var o=n("jquery"),r=n.n(o),c=n("./foundation.core"),a=n("./foundation.util.keyboard");function i(e){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function s(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}function l(e,t){return!t||"object"!==i(t)&&"function"!=typeof t?function(e){if(void 0!==e)return e;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(e):t}function d(e){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function u(e,t){return(u=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e})(e,t)}var f=function(e){function n(){return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,n),l(this,d(n).apply(this,arguments))}var t,o,i;return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&u(e,t)}(n,c["Plugin"]),t=n,(o=[{key:"_setup",value:function(e,t){this.$element=e,this.options=r.a.extend({},n.defaults,this.$element.data(),t),this.className="Accordion",this._init(),a.Keyboard.register("Accordion",{ENTER:"toggle",SPACE:"toggle",ARROW_DOWN:"next",ARROW_UP:"previous"})}},{key:"_init",value:function(){var i=this;this._isInitializing=!0,this.$element.attr("role","tablist"),this.$tabs=this.$element.children("[data-accordion-item]"),this.$tabs.each(function(e,t){var n=r()(t),o=n.children("[data-tab-content]"),i=o[0].id||Object(c.GetYoDigits)(6,"accordion"),a=t.id?"".concat(t.id,"-label"):"".concat(i,"-label");n.find("a:first").attr({"aria-controls":i,role:"tab",id:a,"aria-expanded":!1,"aria-selected":!1}),o.attr({role:"tabpanel","aria-labelledby":a,"aria-hidden":!0,id:i})});var e=this.$element.find(".is-active").children("[data-tab-content]");e.length&&(this._initialAnchor=e.prev("a").attr("href"),this._openSingleTab(e)),this._checkDeepLink=function(){var e=window.location.hash;if(!e.length){if(i._isInitializing)return;i._initialAnchor&&(e=i._initialAnchor)}var t=e&&r()(e),n=e&&i.$element.find('[href$="'.concat(e,'"]')),o=!(!t.length||!n.length);t&&n&&n.length?n.parent("[data-accordion-item]").hasClass("is-active")||i._openSingleTab(t):i._closeAllTabs(),o&&(i.options.deepLinkSmudge&&Object(c.onLoad)(r()(window),function(){var e=i.$element.offset();r()("html, body").animate({scrollTop:e.top},i.options.deepLinkSmudgeDelay)}),i.$element.trigger("deeplink.zf.accordion",[n,t]))},this.options.deepLink&&this._checkDeepLink(),this._events(),this._isInitializing=!1}},{key:"_events",value:function(){var o=this;this.$tabs.each(function(){var t=r()(this),n=t.children("[data-tab-content]");n.length&&t.children("a").off("click.zf.accordion keydown.zf.accordion").on("click.zf.accordion",function(e){e.preventDefault(),o.toggle(n)}).on("keydown.zf.accordion",function(e){a.Keyboard.handleKey(e,"Accordion",{toggle:function(){o.toggle(n)},next:function(){var e=t.next().find("a").focus();o.options.multiExpand||e.trigger("click.zf.accordion")},previous:function(){var e=t.prev().find("a").focus();o.options.multiExpand||e.trigger("click.zf.accordion")},handled:function(){e.preventDefault(),e.stopPropagation()}})})}),this.options.deepLink&&r()(window).on("hashchange",this._checkDeepLink)}},{key:"toggle",value:function(e){if(e.closest("[data-accordion]").is("[disabled]"))console.info("Cannot toggle an accordion that is disabled.");else if(e.parent().hasClass("is-active")?this.up(e):this.down(e),this.options.deepLink){var t=e.prev("a").attr("href");this.options.updateHistory?history.pushState({},"",t):history.replaceState({},"",t)}}},{key:"down",value:function(e){e.closest("[data-accordion]").is("[disabled]")?console.info("Cannot call down on an accordion that is disabled."):this.options.multiExpand?this._openTab(e):this._openSingleTab(e)}},{key:"up",value:function(e){if(this.$element.is("[disabled]"))console.info("Cannot call up on an accordion that is disabled.");else{var t=e.parent();if(t.hasClass("is-active")){var n=t.siblings();(this.options.allowAllClosed||n.hasClass("is-active"))&&this._closeTab(e)}}}},{key:"_openSingleTab",value:function(e){var t=this.$element.children(".is-active").children("[data-tab-content]");t.length&&this._closeTab(t.not(e)),this._openTab(e)}},{key:"_openTab",value:function(e){var t=this,n=e.parent(),o=e.attr("aria-labelledby");e.attr("aria-hidden",!1),n.addClass("is-active"),r()("#".concat(o)).attr({"aria-expanded":!0,"aria-selected":!0}),e.slideDown(this.options.slideSpeed,function(){t.$element.trigger("down.zf.accordion",[e])})}},{key:"_closeTab",value:function(e){var t=this,n=e.parent(),o=e.attr("aria-labelledby");e.attr("aria-hidden",!0),n.removeClass("is-active"),r()("#".concat(o)).attr({"aria-expanded":!1,"aria-selected":!1}),e.slideUp(this.options.slideSpeed,function(){t.$element.trigger("up.zf.accordion",[e])})}},{key:"_closeAllTabs",value:function(){var e=this.$element.children(".is-active").children("[data-tab-content]");e.length&&this._closeTab(e)}},{key:"_destroy",value:function(){this.$element.find("[data-tab-content]").stop(!0).slideUp(0).css("display",""),this.$element.find("a").off(".zf.accordion"),this.options.deepLink&&r()(window).off("hashchange",this._checkDeepLink)}}])&&s(t.prototype,o),i&&s(t,i),n}();f.defaults={slideSpeed:250,multiExpand:!1,allowAllClosed:!1,deepLink:!1,deepLinkSmudge:!1,deepLinkSmudgeDelay:300,updateHistory:!1}},1:function(e,t,n){e.exports=n("./js/entries/plugins/foundation.accordion.js")},jquery:function(e,t){e.exports=i}})});
+//# sourceMappingURL=foundation.accordion.min.js.map
diff --git a/dist/js/plugins/foundation.accordion.min.js.map b/dist/js/plugins/foundation.accordion.min.js.map
new file mode 100644 (file)
index 0000000..dcd689a
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.accordion.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.keyboard","./js/entries/plugins/foundation.accordion.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_accordion__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.accordion.js","Accordion","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","register","ENTER","SPACE","ARROW_DOWN","ARROW_UP","_this2","_isInitializing","attr","$tabs","children","each","idx","el","$el","$content","id","linkId","concat","find","aria-controls","role","aria-expanded","aria-selected","aria-labelledby","aria-hidden","$initActive","_initialAnchor","prev","_openSingleTab","_checkDeepLink","anchor","location","hash","$anchor","$link","isOwnAnchor","parent","hasClass","_closeAllTabs","deepLinkSmudge","offset","animate","scrollTop","top","deepLinkSmudgeDelay","trigger","deepLink","_events","_this","$elem","$tabContent","off","on","e","preventDefault","toggle","handleKey","next","$a","focus","multiExpand","previous","handled","stopPropagation","$target","closest","is","console","info","up","down","updateHistory","history","pushState","replaceState","_openTab","$targetItem","$othersItems","siblings","allowAllClosed","_closeTab","$activeContents","not","_this3","targetContentId","addClass","slideDown","slideSpeed","_this4","removeClass","slideUp","$activeTabs","stop","css","1","jquery"],"mappings":"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","file":"foundation.accordion.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.accordion\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.accordion\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 1);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.accordion.js\":\n/*!****************************************************!*\\\n  !*** ./js/entries/plugins/foundation.accordion.js ***!\n  \\****************************************************/\n/*! exports provided: Foundation, Accordion */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.accordion */ \"./js/foundation.accordion.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Accordion\", function() { return _foundation_accordion__WEBPACK_IMPORTED_MODULE_1__[\"Accordion\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_accordion__WEBPACK_IMPORTED_MODULE_1__[\"Accordion\"], 'Accordion');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.accordion.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.accordion.js ***!\n  \\************************************/\n/*! exports provided: Accordion */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Accordion\", function() { return Accordion; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n/**\n * Accordion module.\n * @module foundation.accordion\n * @requires foundation.util.keyboard\n */\n\nvar Accordion =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Accordion, _Plugin);\n\n  function Accordion() {\n    _classCallCheck(this, Accordion);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Accordion).apply(this, arguments));\n  }\n\n  _createClass(Accordion, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of an accordion.\n     * @class\n     * @name Accordion\n     * @fires Accordion#init\n     * @param {jQuery} element - jQuery object to make into an accordion.\n     * @param {Object} options - a plain object with settings to override the default options.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Accordion.defaults, this.$element.data(), options);\n      this.className = 'Accordion'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('Accordion', {\n        'ENTER': 'toggle',\n        'SPACE': 'toggle',\n        'ARROW_DOWN': 'next',\n        'ARROW_UP': 'previous'\n      });\n    }\n    /**\n     * Initializes the accordion by animating the preset active pane(s).\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var _this2 = this;\n\n      this._isInitializing = true;\n      this.$element.attr('role', 'tablist');\n      this.$tabs = this.$element.children('[data-accordion-item]');\n      this.$tabs.each(function (idx, el) {\n        var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el),\n            $content = $el.children('[data-tab-content]'),\n            id = $content[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'accordion'),\n            linkId = el.id ? \"\".concat(el.id, \"-label\") : \"\".concat(id, \"-label\");\n        $el.find('a:first').attr({\n          'aria-controls': id,\n          'role': 'tab',\n          'id': linkId,\n          'aria-expanded': false,\n          'aria-selected': false\n        });\n        $content.attr({\n          'role': 'tabpanel',\n          'aria-labelledby': linkId,\n          'aria-hidden': true,\n          'id': id\n        });\n      });\n      var $initActive = this.$element.find('.is-active').children('[data-tab-content]');\n\n      if ($initActive.length) {\n        // Save up the initial hash to return to it later when going back in history\n        this._initialAnchor = $initActive.prev('a').attr('href');\n\n        this._openSingleTab($initActive);\n      }\n\n      this._checkDeepLink = function () {\n        var anchor = window.location.hash;\n\n        if (!anchor.length) {\n          // If we are still initializing and there is no anchor, then there is nothing to do\n          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor\n\n          if (_this2._initialAnchor) anchor = _this2._initialAnchor;\n        }\n\n        var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor);\n\n        var $link = anchor && _this2.$element.find(\"[href$=\\\"\".concat(anchor, \"\\\"]\")); // Whether the anchor element that has been found is part of this element\n\n\n        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, open it (if not already active)\n\n        if ($anchor && $link && $link.length) {\n          if (!$link.parent('[data-accordion-item]').hasClass('is-active')) {\n            _this2._openSingleTab($anchor);\n          }\n\n          ;\n        } // Otherwise, close everything\n        else {\n            _this2._closeAllTabs();\n          }\n\n        if (isOwnAnchor) {\n          // Roll up a little to show the titles\n          if (_this2.options.deepLinkSmudge) {\n            Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n              var offset = _this2.$element.offset();\n\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({\n                scrollTop: offset.top\n              }, _this2.options.deepLinkSmudgeDelay);\n            });\n          }\n          /**\n           * Fires when the plugin has deeplinked at pageload\n           * @event Accordion#deeplink\n           */\n\n\n          _this2.$element.trigger('deeplink.zf.accordion', [$link, $anchor]);\n        }\n      }; //use browser to open a tab, if it exists in this tabset\n\n\n      if (this.options.deepLink) {\n        this._checkDeepLink();\n      }\n\n      this._events();\n\n      this._isInitializing = false;\n    }\n    /**\n     * Adds event handlers for items within the accordion.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this.$tabs.each(function () {\n        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n        var $tabContent = $elem.children('[data-tab-content]');\n\n        if ($tabContent.length) {\n          $elem.children('a').off('click.zf.accordion keydown.zf.accordion').on('click.zf.accordion', function (e) {\n            e.preventDefault();\n\n            _this.toggle($tabContent);\n          }).on('keydown.zf.accordion', function (e) {\n            _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'Accordion', {\n              toggle: function toggle() {\n                _this.toggle($tabContent);\n              },\n              next: function next() {\n                var $a = $elem.next().find('a').focus();\n\n                if (!_this.options.multiExpand) {\n                  $a.trigger('click.zf.accordion');\n                }\n              },\n              previous: function previous() {\n                var $a = $elem.prev().find('a').focus();\n\n                if (!_this.options.multiExpand) {\n                  $a.trigger('click.zf.accordion');\n                }\n              },\n              handled: function handled() {\n                e.preventDefault();\n                e.stopPropagation();\n              }\n            });\n          });\n        }\n      });\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink);\n      }\n    }\n    /**\n     * Toggles the selected content pane's open/close state.\n     * @param {jQuery} $target - jQuery object of the pane to toggle (`.accordion-content`).\n     * @function\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle($target) {\n      if ($target.closest('[data-accordion]').is('[disabled]')) {\n        console.info('Cannot toggle an accordion that is disabled.');\n        return;\n      }\n\n      if ($target.parent().hasClass('is-active')) {\n        this.up($target);\n      } else {\n        this.down($target);\n      } //either replace or update browser history\n\n\n      if (this.options.deepLink) {\n        var anchor = $target.prev('a').attr('href');\n\n        if (this.options.updateHistory) {\n          history.pushState({}, '', anchor);\n        } else {\n          history.replaceState({}, '', anchor);\n        }\n      }\n    }\n    /**\n     * Opens the accordion tab defined by `$target`.\n     * @param {jQuery} $target - Accordion pane to open (`.accordion-content`).\n     * @fires Accordion#down\n     * @function\n     */\n\n  }, {\n    key: \"down\",\n    value: function down($target) {\n      if ($target.closest('[data-accordion]').is('[disabled]')) {\n        console.info('Cannot call down on an accordion that is disabled.');\n        return;\n      }\n\n      if (this.options.multiExpand) this._openTab($target);else this._openSingleTab($target);\n    }\n    /**\n     * Closes the tab defined by `$target`.\n     * It may be ignored if the Accordion options don't allow it.\n     *\n     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n     * @fires Accordion#up\n     * @function\n     */\n\n  }, {\n    key: \"up\",\n    value: function up($target) {\n      if (this.$element.is('[disabled]')) {\n        console.info('Cannot call up on an accordion that is disabled.');\n        return;\n      } // Don't close the item if it is already closed\n\n\n      var $targetItem = $target.parent();\n      if (!$targetItem.hasClass('is-active')) return; // Don't close the item if there is no other active item (unless with `allowAllClosed`)\n\n      var $othersItems = $targetItem.siblings();\n      if (!this.options.allowAllClosed && !$othersItems.hasClass('is-active')) return;\n\n      this._closeTab($target);\n    }\n    /**\n     * Make the tab defined by `$target` the only opened tab, closing all others tabs.\n     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_openSingleTab\",\n    value: function _openSingleTab($target) {\n      // Close all the others active tabs.\n      var $activeContents = this.$element.children('.is-active').children('[data-tab-content]');\n\n      if ($activeContents.length) {\n        this._closeTab($activeContents.not($target));\n      } // Then open the target.\n\n\n      this._openTab($target);\n    }\n    /**\n     * Opens the tab defined by `$target`.\n     * @param {jQuery} $target - Accordion tab to open (`.accordion-content`).\n     * @fires Accordion#down\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_openTab\",\n    value: function _openTab($target) {\n      var _this3 = this;\n\n      var $targetItem = $target.parent();\n      var targetContentId = $target.attr('aria-labelledby');\n      $target.attr('aria-hidden', false);\n      $targetItem.addClass('is-active');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(targetContentId)).attr({\n        'aria-expanded': true,\n        'aria-selected': true\n      });\n      $target.slideDown(this.options.slideSpeed, function () {\n        /**\n         * Fires when the tab is done opening.\n         * @event Accordion#down\n         */\n        _this3.$element.trigger('down.zf.accordion', [$target]);\n      });\n    }\n    /**\n     * Closes the tab defined by `$target`.\n     * @param {jQuery} $target - Accordion tab to close (`.accordion-content`).\n     * @fires Accordion#up\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_closeTab\",\n    value: function _closeTab($target) {\n      var _this4 = this;\n\n      var $targetItem = $target.parent();\n      var targetContentId = $target.attr('aria-labelledby');\n      $target.attr('aria-hidden', true);\n      $targetItem.removeClass('is-active');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(targetContentId)).attr({\n        'aria-expanded': false,\n        'aria-selected': false\n      });\n      $target.slideUp(this.options.slideSpeed, function () {\n        /**\n         * Fires when the tab is done collapsing up.\n         * @event Accordion#up\n         */\n        _this4.$element.trigger('up.zf.accordion', [$target]);\n      });\n    }\n    /**\n     * Closes all active tabs\n     * @fires Accordion#up\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_closeAllTabs\",\n    value: function _closeAllTabs() {\n      var $activeTabs = this.$element.children('.is-active').children('[data-tab-content]');\n\n      if ($activeTabs.length) {\n        this._closeTab($activeTabs);\n      }\n    }\n    /**\n     * Destroys an instance of an accordion.\n     * @fires Accordion#destroyed\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.find('[data-tab-content]').stop(true).slideUp(0).css('display', '');\n      this.$element.find('a').off('.zf.accordion');\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink);\n      }\n    }\n  }]);\n\n  return Accordion;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n\nAccordion.defaults = {\n  /**\n   * Amount of time to animate the opening of an accordion pane.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n\n  /**\n   * Allow the accordion to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multiExpand: false,\n\n  /**\n   * Allow the accordion to close all panes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowAllClosed: false,\n\n  /**\n   * Link the location hash to the open pane.\n   * Set the location hash when the opened pane changes, and open and scroll to the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the accordion panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open accordion\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false\n};\n\n\n/***/ }),\n\n/***/ 1:\n/*!**********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.accordion.js ***!\n  \\**********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.accordion.js */\"./js/entries/plugins/foundation.accordion.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.accordion.js.map"]}
\ No newline at end of file
index 52edfdd596e0c3d020228819ecf20e8a50499a05..e1405e2718adc5e16598113ad48d33c25a61526d 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("./foundation.util.nest"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.keyboard", "./foundation.util.nest", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.accordionMenu"] = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("./foundation.util.nest"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.accordionMenu"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.nest"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 81);
+/******/       return __webpack_require__(__webpack_require__.s = 2);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
 /***/ }),
 
-/***/ 15:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
-
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_accordionMenu__ = __webpack_require__(45);
+/***/ "./foundation.util.nest":
+/*!************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.nest"],"amd":"./foundation.util.nest","commonjs":"./foundation.util.nest","commonjs2":"./foundation.util.nest"} ***!
+  \************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;
 
+/***/ }),
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_accordionMenu__["a" /* AccordionMenu */], 'AccordionMenu');
+/***/ "./js/entries/plugins/foundation.accordionMenu.js":
+/*!********************************************************!*\
+  !*** ./js/entries/plugins/foundation.accordionMenu.js ***!
+  \********************************************************/
+/*! exports provided: Foundation, AccordionMenu */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-/***/ }),
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-/***/ 2:
-/***/ (function(module, exports) {
+/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.accordionMenu */ "./js/foundation.accordionMenu.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "AccordionMenu", function() { return _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_1__["AccordionMenu"]; });
 
-module.exports = {Plugin: window.Foundation.Plugin};
 
-/***/ }),
 
-/***/ 3:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_1__["AccordionMenu"], 'AccordionMenu');
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
 /***/ }),
 
-/***/ 45:
+/***/ "./js/foundation.accordionMenu.js":
+/*!****************************************!*\
+  !*** ./js/foundation.accordionMenu.js ***!
+  \****************************************/
+/*! exports provided: AccordionMenu */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return AccordionMenu; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__ = __webpack_require__(9);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "AccordionMenu", function() { return AccordionMenu; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.nest */ "./foundation.util.nest");
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(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 _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -149,17 +202,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.nest
  */
 
-var AccordionMenu = function (_Plugin) {
+var AccordionMenu =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(AccordionMenu, _Plugin);
 
   function AccordionMenu() {
     _classCallCheck(this, AccordionMenu);
 
-    return _possibleConstructorReturn(this, (AccordionMenu.__proto__ || Object.getPrototypeOf(AccordionMenu)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(AccordionMenu).apply(this, arguments));
   }
 
   _createClass(AccordionMenu, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of an accordion menu.
@@ -171,12 +226,12 @@ var AccordionMenu = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, AccordionMenu.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, AccordionMenu.defaults, this.$element.data(), options);
       this.className = 'AccordionMenu'; // ie9 back compat
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('AccordionMenu', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('AccordionMenu', {
         'ENTER': 'toggle',
         'SPACE': 'toggle',
         'ARROW_RIGHT': 'open',
@@ -186,33 +241,37 @@ var AccordionMenu = function (_Plugin) {
         'ESCAPE': 'closeAll'
       });
     }
-
     /**
      * Initializes the accordion menu by hiding all nested menus.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["Nest"].Feather(this.$element, 'accordion');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__["Nest"].Feather(this.$element, 'accordion');
 
       var _this = this;
 
       this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');
+
       this.$element.attr({
         'role': 'tree',
         'aria-multiselectable': this.options.multiOpen
       });
-
       this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');
       this.$menuLinks.each(function () {
-        var linkId = this.id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["GetYoDigits"])(6, 'acc-menu-link'),
-            $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var linkId = this.id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'acc-menu-link'),
+            $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             $sub = $elem.children('[data-submenu]'),
-            subId = $sub[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["GetYoDigits"])(6, 'acc-menu'),
+            subId = $sub[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'acc-menu'),
             isActive = $sub.hasClass('is-active');
 
+        if (_this.options.parentLink) {
+          var $anchor = $elem.children('a');
+          $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-accordion-submenu-item"></li>');
+        }
+
         if (_this.options.submenuToggle) {
           $elem.addClass('has-submenu-toggle');
           $elem.children('a').after('<button id="' + linkId + '" class="submenu-toggle" aria-controls="' + subId + '" aria-expanded="' + isActive + '" title="' + _this.options.submenuToggleText + '"><span class="submenu-toggle-text">' + _this.options.submenuToggleText + '</span></button>');
@@ -223,6 +282,7 @@ var AccordionMenu = function (_Plugin) {
             'id': linkId
           });
         }
+
         $sub.attr({
           'aria-labelledby': linkId,
           'aria-hidden': !isActive,
@@ -234,64 +294,68 @@ var AccordionMenu = function (_Plugin) {
         'role': 'treeitem'
       });
       var initPanes = this.$element.find('.is-active');
+
       if (initPanes.length) {
         var _this = this;
+
         initPanes.each(function () {
-          _this.down(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
+          _this.down(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
         });
       }
+
       this._events();
     }
-
     /**
      * Adds event handlers for items within the menu.
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this;
 
       this.$element.find('li').each(function () {
-        var $submenu = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('[data-submenu]');
+        var $submenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]');
 
         if ($submenu.length) {
           if (_this.options.submenuToggle) {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
               _this.toggle($submenu);
             });
           } else {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {
               e.preventDefault();
+
               _this.toggle($submenu);
             });
           }
         }
       }).on('keydown.zf.accordionmenu', function (e) {
-        var $element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             $elements = $element.parent('ul').children('li'),
             $prevElement,
             $nextElement,
             $target = $element.children('[data-submenu]');
-
         $elements.each(function (i) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is($element)) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {
             $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first();
             $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first();
 
-            if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('[data-submenu]:visible').length) {
+            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]:visible').length) {
               // has open sub menu
               $nextElement = $element.find('li:first-child').find('a').first();
             }
-            if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is(':first-child')) {
+
+            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':first-child')) {
               // is first element of sub menu
               $prevElement = $element.parents('li').first().find('a').first();
             } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) {
               // if previous element has open sub menu
               $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();
             }
-            if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is(':last-child')) {
+
+            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':last-child')) {
               // is last element of sub menu
               $nextElement = $element.parents('li').first().next('li').find('a').first();
             }
@@ -299,76 +363,77 @@ var AccordionMenu = function (_Plugin) {
             return;
           }
         });
-
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'AccordionMenu', {
-          open: function () {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'AccordionMenu', {
+          open: function open() {
             if ($target.is(':hidden')) {
               _this.down($target);
+
               $target.find('li').first().find('a').first().focus();
             }
           },
-          close: function () {
+          close: function close() {
             if ($target.length && !$target.is(':hidden')) {
               // close active sub of this item
               _this.up($target);
             } else if ($element.parent('[data-submenu]').length) {
               // close currently open sub
               _this.up($element.parent('[data-submenu]'));
+
               $element.parents('li').first().find('a').first().focus();
             }
           },
-          up: function () {
+          up: function up() {
             $prevElement.focus();
             return true;
           },
-          down: function () {
+          down: function down() {
             $nextElement.focus();
             return true;
           },
-          toggle: function () {
+          toggle: function toggle() {
             if (_this.options.submenuToggle) {
               return false;
             }
+
             if ($element.children('[data-submenu]').length) {
               _this.toggle($element.children('[data-submenu]'));
+
               return true;
             }
           },
-          closeAll: function () {
+          closeAll: function closeAll() {
             _this.hideAll();
           },
-          handled: function (preventDefault) {
+          handled: function handled(preventDefault) {
             if (preventDefault) {
               e.preventDefault();
             }
+
             e.stopImmediatePropagation();
           }
         });
       }); //.attr('tabindex', 0);
     }
-
     /**
      * Closes all panes of the menu.
      * @function
      */
 
   }, {
-    key: 'hideAll',
+    key: "hideAll",
     value: function hideAll() {
       this.up(this.$element.find('[data-submenu]'));
     }
-
     /**
      * Opens all panes of the menu.
      * @function
      */
 
   }, {
-    key: 'showAll',
+    key: "showAll",
     value: function showAll() {
       this.down(this.$element.find('[data-submenu]'));
     }
-
     /**
      * Toggles the open/close state of a submenu.
      * @function
@@ -376,7 +441,7 @@ var AccordionMenu = function (_Plugin) {
      */
 
   }, {
-    key: 'toggle',
+    key: "toggle",
     value: function toggle($target) {
       if (!$target.is(':animated')) {
         if (!$target.is(':hidden')) {
@@ -386,7 +451,6 @@ var AccordionMenu = function (_Plugin) {
         }
       }
     }
-
     /**
      * Opens the sub-menu defined by `$target`.
      * @param {jQuery} $target - Sub-menu to open.
@@ -394,31 +458,43 @@ var AccordionMenu = function (_Plugin) {
      */
 
   }, {
-    key: 'down',
+    key: "down",
     value: function down($target) {
-      var _this = this;
+      var _this2 = this;
 
+      // If having multiple submenus active is disabled, close all the submenus
+      // that are not parents or children of the targeted submenu.
       if (!this.options.multiOpen) {
-        this.up(this.$element.find('.is-active').not($target.parentsUntil(this.$element).add($target)));
+        // The "branch" of the targetted submenu, from the component root to
+        // the active submenus nested in it.
+        var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); // All the active submenus that are not in the branch.
+
+        var $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);
+        this.up($othersActiveSubmenus);
       }
 
-      $target.addClass('is-active').attr({ 'aria-hidden': false });
+      $target.addClass('is-active').attr({
+        'aria-hidden': false
+      });
 
       if (this.options.submenuToggle) {
-        $target.prev('.submenu-toggle').attr({ 'aria-expanded': true });
+        $target.prev('.submenu-toggle').attr({
+          'aria-expanded': true
+        });
       } else {
-        $target.parent('.is-accordion-submenu-parent').attr({ 'aria-expanded': true });
+        $target.parent('.is-accordion-submenu-parent').attr({
+          'aria-expanded': true
+        });
       }
 
-      $target.slideDown(_this.options.slideSpeed, function () {
+      $target.slideDown(this.options.slideSpeed, function () {
         /**
          * Fires when the menu is done opening.
          * @event AccordionMenu#down
          */
-        _this.$element.trigger('down.zf.accordionMenu', [$target]);
+        _this2.$element.trigger('down.zf.accordionMenu', [$target]);
       });
     }
-
     /**
      * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.
      * @param {jQuery} $target - Sub-menu to close.
@@ -426,50 +502,62 @@ var AccordionMenu = function (_Plugin) {
      */
 
   }, {
-    key: 'up',
+    key: "up",
     value: function up($target) {
-      var _this = this;
-      $target.slideUp(_this.options.slideSpeed, function () {
-        /**
-         * Fires when the menu is done collapsing up.
-         * @event AccordionMenu#up
-         */
-        _this.$element.trigger('up.zf.accordionMenu', [$target]);
-      });
+      var _this3 = this;
 
-      var $menus = $target.find('[data-submenu]').slideUp(0).addBack().attr('aria-hidden', true);
+      var $submenus = $target.find('[data-submenu]');
+      var $allmenus = $target.add($submenus);
+      $submenus.slideUp(0);
+      $allmenus.removeClass('is-active').attr('aria-hidden', true);
 
       if (this.options.submenuToggle) {
-        $menus.prev('.submenu-toggle').attr('aria-expanded', false);
+        $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);
       } else {
-        $menus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);
+        $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);
       }
-    }
 
+      $target.slideUp(this.options.slideSpeed, function () {
+        /**
+         * Fires when the menu is done collapsing up.
+         * @event AccordionMenu#up
+         */
+        _this3.$element.trigger('up.zf.accordionMenu', [$target]);
+      });
+    }
     /**
      * Destroys an instance of accordion menu.
      * @fires AccordionMenu#destroyed
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.$element.find('[data-submenu]').slideDown(0).css('display', '');
       this.$element.find('a').off('click.zf.accordionMenu');
+      this.$element.find('[data-is-parent-link]').detach();
 
       if (this.options.submenuToggle) {
         this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');
         this.$element.find('.submenu-toggle').remove();
       }
 
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["Nest"].Burn(this.$element, 'accordion');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__["Nest"].Burn(this.$element, 'accordion');
     }
   }]);
 
   return AccordionMenu;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 
 AccordionMenu.defaults = {
+  /**
+   * Adds the parent link to the submenu.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  parentLink: false,
+
   /**
    * Amount of time to animate the opening of a submenu in ms.
    * @option
@@ -477,18 +565,21 @@ AccordionMenu.defaults = {
    * @default 250
    */
   slideSpeed: 250,
+
   /**
    * Adds a separate submenu toggle button. This allows the parent item to have a link.
    * @option
    * @example true
    */
   submenuToggle: false,
+
   /**
    * The text used for the submenu toggle if enabled. This is used for screen readers only.
    * @option
    * @example true
    */
   submenuToggleText: 'Toggle menu',
+
   /**
    * Allow the menu to have multiple open panes.
    * @option
@@ -499,29 +590,31 @@ AccordionMenu.defaults = {
 };
 
 
-
-/***/ }),
-
-/***/ 5:
-/***/ (function(module, exports) {
-
-module.exports = {Keyboard: window.Foundation.Keyboard};
-
 /***/ }),
 
-/***/ 81:
+/***/ 2:
+/*!**************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.accordionMenu.js ***!
+  \**************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(15);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.accordionMenu.js */"./js/entries/plugins/foundation.accordionMenu.js");
 
 
 /***/ }),
 
-/***/ 9:
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Nest: window.Foundation.Nest};
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.accordionMenu.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.accordionMenu.js.map b/dist/js/plugins/foundation.accordionMenu.js.map
new file mode 100644 (file)
index 0000000..07c7ca7
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.nest\"],\"amd\":\"./foundation.util.nest\",\"commonjs\":\"./foundation.util.nest\",\"commonjs2\":\"./foundation.util.nest\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.accordionMenu.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.accordionMenu.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","AccordionMenu","element","options","$element","$","extend","defaults","data","className","_init","Keyboard","register","Nest","Feather","_this","find","not","slideUp","attr","multiOpen","$menuLinks","each","linkId","id","GetYoDigits","$elem","$sub","children","subId","isActive","hasClass","parentLink","$anchor","clone","prependTo","wrap","submenuToggle","addClass","after","submenuToggleText","initPanes","length","down","_events","$submenu","off","on","e","toggle","preventDefault","$elements","parent","$prevElement","$nextElement","$target","i","is","eq","Math","max","first","min","parents","next","handleKey","open","focus","close","up","closeAll","hideAll","handled","stopImmediatePropagation","$targetBranch","parentsUntil","add","$othersActiveSubmenus","prev","slideDown","slideSpeed","trigger","$submenus","$allmenus","removeClass","css","detach","remove","Burn","Plugin"],"mappings":"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","file":"foundation.accordionMenu.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"./foundation.util.nest\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.accordionMenu\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.accordionMenu\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.nest\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 2);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;","import { Foundation } from './foundation.core';\n\nimport { AccordionMenu } from '../../foundation.accordionMenu';\nFoundation.plugin(AccordionMenu, 'AccordionMenu');\n\nexport { Foundation, AccordionMenu };\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n */\n\nclass AccordionMenu extends Plugin {\n  /**\n   * Creates a new instance of an accordion menu.\n   * @class\n   * @name AccordionMenu\n   * @fires AccordionMenu#init\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n    this.className = 'AccordionMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('AccordionMenu', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ARROW_RIGHT': 'open',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'close',\n      'ESCAPE': 'closeAll'\n    });\n  }\n\n\n\n  /**\n   * Initializes the accordion menu by hiding all nested menus.\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'accordion');\n\n    var _this = this;\n\n    this.$element.find('[data-submenu]').not('.is-active').slideUp(0);//.find('a').css('padding-left', '1rem');\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': this.options.multiOpen\n    });\n\n    this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');\n    this.$menuLinks.each(function(){\n      var linkId = this.id || GetYoDigits(6, 'acc-menu-link'),\n          $elem = $(this),\n          $sub = $elem.children('[data-submenu]'),\n          subId = $sub[0].id || GetYoDigits(6, 'acc-menu'),\n          isActive = $sub.hasClass('is-active');\n\n      if(_this.options.parentLink) {\n        let $anchor = $elem.children('a');\n        $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-accordion-submenu-item\"></li>');\n      }\n\n      if(_this.options.submenuToggle) {\n        $elem.addClass('has-submenu-toggle');\n        $elem.children('a').after('<button id=\"' + linkId + '\" class=\"submenu-toggle\" aria-controls=\"' + subId + '\" aria-expanded=\"' + isActive + '\" title=\"' + _this.options.submenuToggleText + '\"><span class=\"submenu-toggle-text\">' + _this.options.submenuToggleText + '</span></button>');\n      } else {\n        $elem.attr({\n          'aria-controls': subId,\n          'aria-expanded': isActive,\n          'id': linkId\n        });\n      }\n      $sub.attr({\n        'aria-labelledby': linkId,\n        'aria-hidden': !isActive,\n        'role': 'group',\n        'id': subId\n      });\n    });\n    this.$element.find('li').attr({\n      'role': 'treeitem'\n    });\n    var initPanes = this.$element.find('.is-active');\n    if(initPanes.length){\n      var _this = this;\n      initPanes.each(function(){\n        _this.down($(this));\n      });\n    }\n    this._events();\n  }\n\n  /**\n   * Adds event handlers for items within the menu.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.find('li').each(function() {\n      var $submenu = $(this).children('[data-submenu]');\n\n      if ($submenu.length) {\n        if(_this.options.submenuToggle) {\n          $(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n            _this.toggle($submenu);\n          });\n        } else {\n            $(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function(e) {\n              e.preventDefault();\n              _this.toggle($submenu);\n            });\n        }\n      }\n    }).on('keydown.zf.accordionmenu', function(e){\n      var $element = $(this),\n          $elements = $element.parent('ul').children('li'),\n          $prevElement,\n          $nextElement,\n          $target = $element.children('[data-submenu]');\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1)).find('a').first();\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1)).find('a').first();\n\n          if ($(this).children('[data-submenu]:visible').length) { // has open sub menu\n            $nextElement = $element.find('li:first-child').find('a').first();\n          }\n          if ($(this).is(':first-child')) { // is first element of sub menu\n            $prevElement = $element.parents('li').first().find('a').first();\n          } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) { // if previous element has open sub menu\n            $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();\n          }\n          if ($(this).is(':last-child')) { // is last element of sub menu\n            $nextElement = $element.parents('li').first().next('li').find('a').first();\n          }\n\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'AccordionMenu', {\n        open: function() {\n          if ($target.is(':hidden')) {\n            _this.down($target);\n            $target.find('li').first().find('a').first().focus();\n          }\n        },\n        close: function() {\n          if ($target.length && !$target.is(':hidden')) { // close active sub of this item\n            _this.up($target);\n          } else if ($element.parent('[data-submenu]').length) { // close currently open sub\n            _this.up($element.parent('[data-submenu]'));\n            $element.parents('li').first().find('a').first().focus();\n          }\n        },\n        up: function() {\n          $prevElement.focus();\n          return true;\n        },\n        down: function() {\n          $nextElement.focus();\n          return true;\n        },\n        toggle: function() {\n          if (_this.options.submenuToggle) {\n            return false;\n          }\n          if ($element.children('[data-submenu]').length) {\n            _this.toggle($element.children('[data-submenu]'));\n            return true;\n          }\n        },\n        closeAll: function() {\n          _this.hideAll();\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    });//.attr('tabindex', 0);\n  }\n\n  /**\n   * Closes all panes of the menu.\n   * @function\n   */\n  hideAll() {\n    this.up(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Opens all panes of the menu.\n   * @function\n   */\n  showAll() {\n    this.down(this.$element.find('[data-submenu]'));\n  }\n\n  /**\n   * Toggles the open/close state of a submenu.\n   * @function\n   * @param {jQuery} $target - the submenu to toggle\n   */\n  toggle($target){\n    if(!$target.is(':animated')) {\n      if (!$target.is(':hidden')) {\n        this.up($target);\n      }\n      else {\n        this.down($target);\n      }\n    }\n  }\n\n  /**\n   * Opens the sub-menu defined by `$target`.\n   * @param {jQuery} $target - Sub-menu to open.\n   * @fires AccordionMenu#down\n   */\n  down($target) {\n    // If having multiple submenus active is disabled, close all the submenus\n    // that are not parents or children of the targeted submenu.\n    if (!this.options.multiOpen) {\n      // The \"branch\" of the targetted submenu, from the component root to\n      // the active submenus nested in it.\n      const $targetBranch = $target.parentsUntil(this.$element)\n        .add($target)\n        .add($target.find('.is-active'));\n      // All the active submenus that are not in the branch.\n      const $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);\n\n      this.up($othersActiveSubmenus);\n    }\n\n    $target\n      .addClass('is-active')\n      .attr({ 'aria-hidden': false });\n\n    if(this.options.submenuToggle) {\n      $target.prev('.submenu-toggle').attr({'aria-expanded': true});\n    }\n    else {\n      $target.parent('.is-accordion-submenu-parent').attr({'aria-expanded': true});\n    }\n\n    $target.slideDown(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done opening.\n       * @event AccordionMenu#down\n       */\n      this.$element.trigger('down.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.\n   * @param {jQuery} $target - Sub-menu to close.\n   * @fires AccordionMenu#up\n   */\n  up($target) {\n    const $submenus = $target.find('[data-submenu]');\n    const $allmenus = $target.add($submenus);\n\n    $submenus.slideUp(0);\n    $allmenus\n      .removeClass('is-active')\n      .attr('aria-hidden', true);\n\n    if(this.options.submenuToggle) {\n      $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);\n    }\n    else {\n      $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\n    }\n\n    $target.slideUp(this.options.slideSpeed, () => {\n      /**\n       * Fires when the menu is done collapsing up.\n       * @event AccordionMenu#up\n       */\n      this.$element.trigger('up.zf.accordionMenu', [$target]);\n    });\n  }\n\n  /**\n   * Destroys an instance of accordion menu.\n   * @fires AccordionMenu#destroyed\n   */\n  _destroy() {\n    this.$element.find('[data-submenu]').slideDown(0).css('display', '');\n    this.$element.find('a').off('click.zf.accordionMenu');\n    this.$element.find('[data-is-parent-link]').detach();\n\n    if(this.options.submenuToggle) {\n      this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');\n      this.$element.find('.submenu-toggle').remove();\n    }\n\n    Nest.Burn(this.$element, 'accordion');\n  }\n}\n\nAccordionMenu.defaults = {\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Amount of time to animate the opening of a submenu in ms.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n  /**\n   * Adds a separate submenu toggle button. This allows the parent item to have a link.\n   * @option\n   * @example true\n   */\n  submenuToggle: false,\n  /**\n   * The text used for the submenu toggle if enabled. This is used for screen readers only.\n   * @option\n   * @example true\n   */\n  submenuToggleText: 'Toggle menu',\n  /**\n   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\nexport {AccordionMenu};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 21067479467815af1170d49d5b95bd11e5ee4968..1386ed41ec9ac58ad991fd6aa106fb1b00ad5a09 100644 (file)
@@ -1 +1,2 @@
-!function(e){function n(i){if(t[i])return t[i].exports;var o=t[i]={i:i,l:!1,exports:{}};return e[i].call(o.exports,o,o.exports,n),o.l=!0,o.exports}var t={};n.m=e,n.c=t,n.i=function(e){return e},n.d=function(e,t,i){n.o(e,t)||Object.defineProperty(e,t,{configurable:!1,enumerable:!0,get:i})},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},n.p="",n(n.s=81)}({0:function(e,n){e.exports=jQuery},1:function(e,n){e.exports={Foundation:window.Foundation}},15:function(e,n,t){"use strict";Object.defineProperty(n,"__esModule",{value:!0});var i=t(1),o=(t.n(i),t(45));i.Foundation.plugin(o.a,"AccordionMenu")},2:function(e,n){e.exports={Plugin:window.Foundation.Plugin}},3:function(e,n){e.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},45:function(e,n,t){"use strict";function i(e,n){if(!(e instanceof n))throw new TypeError("Cannot call a class as a function")}function o(e,n){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!n||"object"!=typeof n&&"function"!=typeof n?e:n}function s(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Super expression must either be null or a function, not "+typeof n);e.prototype=Object.create(n&&n.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),n&&(Object.setPrototypeOf?Object.setPrototypeOf(e,n):e.__proto__=n)}t.d(n,"a",function(){return h});var a=t(0),u=t.n(a),r=t(5),l=(t.n(r),t(9)),d=(t.n(l),t(3)),c=(t.n(d),t(2)),f=(t.n(c),function(){function e(e,n){for(var t=0;t<n.length;t++){var i=n[t];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(e,i.key,i)}}return function(n,t,i){return t&&e(n.prototype,t),i&&e(n,i),n}}()),h=function(e){function n(){return i(this,n),o(this,(n.__proto__||Object.getPrototypeOf(n)).apply(this,arguments))}return s(n,e),f(n,[{key:"_setup",value:function(e,t){this.$element=e,this.options=u.a.extend({},n.defaults,this.$element.data(),t),this.className="AccordionMenu",this._init(),r.Keyboard.register("AccordionMenu",{ENTER:"toggle",SPACE:"toggle",ARROW_RIGHT:"open",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"close",ESCAPE:"closeAll"})}},{key:"_init",value:function(){l.Nest.Feather(this.$element,"accordion");var e=this;this.$element.find("[data-submenu]").not(".is-active").slideUp(0),this.$element.attr({role:"tree","aria-multiselectable":this.options.multiOpen}),this.$menuLinks=this.$element.find(".is-accordion-submenu-parent"),this.$menuLinks.each(function(){var n=this.id||t.i(d.GetYoDigits)(6,"acc-menu-link"),i=u()(this),o=i.children("[data-submenu]"),s=o[0].id||t.i(d.GetYoDigits)(6,"acc-menu"),a=o.hasClass("is-active");e.options.submenuToggle?(i.addClass("has-submenu-toggle"),i.children("a").after('<button id="'+n+'" class="submenu-toggle" aria-controls="'+s+'" aria-expanded="'+a+'" title="'+e.options.submenuToggleText+'"><span class="submenu-toggle-text">'+e.options.submenuToggleText+"</span></button>")):i.attr({"aria-controls":s,"aria-expanded":a,id:n}),o.attr({"aria-labelledby":n,"aria-hidden":!a,role:"group",id:s})}),this.$element.find("li").attr({role:"treeitem"});var n=this.$element.find(".is-active");if(n.length){var e=this;n.each(function(){e.down(u()(this))})}this._events()}},{key:"_events",value:function(){var e=this;this.$element.find("li").each(function(){var n=u()(this).children("[data-submenu]");n.length&&(e.options.submenuToggle?u()(this).children(".submenu-toggle").off("click.zf.accordionMenu").on("click.zf.accordionMenu",function(t){e.toggle(n)}):u()(this).children("a").off("click.zf.accordionMenu").on("click.zf.accordionMenu",function(t){t.preventDefault(),e.toggle(n)}))}).on("keydown.zf.accordionmenu",function(n){var t,i,o=u()(this),s=o.parent("ul").children("li"),a=o.children("[data-submenu]");s.each(function(e){if(u()(this).is(o))return t=s.eq(Math.max(0,e-1)).find("a").first(),i=s.eq(Math.min(e+1,s.length-1)).find("a").first(),u()(this).children("[data-submenu]:visible").length&&(i=o.find("li:first-child").find("a").first()),u()(this).is(":first-child")?t=o.parents("li").first().find("a").first():t.parents("li").first().children("[data-submenu]:visible").length&&(t=t.parents("li").find("li:last-child").find("a").first()),void(u()(this).is(":last-child")&&(i=o.parents("li").first().next("li").find("a").first()))}),r.Keyboard.handleKey(n,"AccordionMenu",{open:function(){a.is(":hidden")&&(e.down(a),a.find("li").first().find("a").first().focus())},close:function(){a.length&&!a.is(":hidden")?e.up(a):o.parent("[data-submenu]").length&&(e.up(o.parent("[data-submenu]")),o.parents("li").first().find("a").first().focus())},up:function(){return t.focus(),!0},down:function(){return i.focus(),!0},toggle:function(){return!e.options.submenuToggle&&(o.children("[data-submenu]").length?(e.toggle(o.children("[data-submenu]")),!0):void 0)},closeAll:function(){e.hideAll()},handled:function(e){e&&n.preventDefault(),n.stopImmediatePropagation()}})})}},{key:"hideAll",value:function(){this.up(this.$element.find("[data-submenu]"))}},{key:"showAll",value:function(){this.down(this.$element.find("[data-submenu]"))}},{key:"toggle",value:function(e){e.is(":animated")||(e.is(":hidden")?this.down(e):this.up(e))}},{key:"down",value:function(e){var n=this;this.options.multiOpen||this.up(this.$element.find(".is-active").not(e.parentsUntil(this.$element).add(e))),e.addClass("is-active").attr({"aria-hidden":!1}),this.options.submenuToggle?e.prev(".submenu-toggle").attr({"aria-expanded":!0}):e.parent(".is-accordion-submenu-parent").attr({"aria-expanded":!0}),e.slideDown(n.options.slideSpeed,function(){n.$element.trigger("down.zf.accordionMenu",[e])})}},{key:"up",value:function(e){var n=this;e.slideUp(n.options.slideSpeed,function(){n.$element.trigger("up.zf.accordionMenu",[e])});var t=e.find("[data-submenu]").slideUp(0).addBack().attr("aria-hidden",!0);this.options.submenuToggle?t.prev(".submenu-toggle").attr("aria-expanded",!1):t.parent(".is-accordion-submenu-parent").attr("aria-expanded",!1)}},{key:"_destroy",value:function(){this.$element.find("[data-submenu]").slideDown(0).css("display",""),this.$element.find("a").off("click.zf.accordionMenu"),this.options.submenuToggle&&(this.$element.find(".has-submenu-toggle").removeClass("has-submenu-toggle"),this.$element.find(".submenu-toggle").remove()),l.Nest.Burn(this.$element,"accordion")}}]),n}(c.Plugin);h.defaults={slideSpeed:250,submenuToggle:!1,submenuToggleText:"Toggle menu",multiOpen:!0}},5:function(e,n){e.exports={Keyboard:window.Foundation.Keyboard}},81:function(e,n,t){e.exports=t(15)},9:function(e,n){e.exports={Nest:window.Foundation.Nest}}});
\ No newline at end of file
+!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n(require("./foundation.core"),require("./foundation.util.keyboard"),require("./foundation.util.nest"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.keyboard","./foundation.util.nest","jquery"],n):"object"==typeof exports?exports["foundation.accordionMenu"]=n(require("./foundation.core"),require("./foundation.util.keyboard"),require("./foundation.util.nest"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.accordionMenu"]=n(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],e.__FOUNDATION_EXTERNAL__["foundation.util.nest"],e.jQuery))}(window,function(t,i,o,u){return function(t){var i={};function o(e){if(i[e])return i[e].exports;var n=i[e]={i:e,l:!1,exports:{}};return t[e].call(n.exports,n,n.exports,o),n.l=!0,n.exports}return o.m=t,o.c=i,o.d=function(e,n,t){o.o(e,n)||Object.defineProperty(e,n,{enumerable:!0,get:t})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(n,e){if(1&e&&(n=o(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var t=Object.create(null);if(o.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var i in n)o.d(t,i,function(e){return n[e]}.bind(null,i));return t},o.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(n,"a",n),n},o.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},o.p="",o(o.s=2)}({"./foundation.core":function(e,n){e.exports=t},"./foundation.util.keyboard":function(e,n){e.exports=i},"./foundation.util.nest":function(e,n){e.exports=o},"./js/entries/plugins/foundation.accordionMenu.js":function(e,n,t){"use strict";t.r(n);var i=t("./foundation.core");t.d(n,"Foundation",function(){return i.Foundation});var o=t("./js/foundation.accordionMenu.js");t.d(n,"AccordionMenu",function(){return o.AccordionMenu}),i.Foundation.plugin(o.AccordionMenu,"AccordionMenu")},"./js/foundation.accordionMenu.js":function(e,n,t){"use strict";t.r(n),t.d(n,"AccordionMenu",function(){return p});var i=t("jquery"),a=t.n(i),s=t("./foundation.util.keyboard"),r=t("./foundation.util.nest"),l=t("./foundation.core");function o(e){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function u(e,n){for(var t=0;t<n.length;t++){var i=n[t];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(e,i.key,i)}}function d(e,n){return!n||"object"!==o(n)&&"function"!=typeof n?function(e){if(void 0!==e)return e;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(e):n}function c(e){return(c=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function f(e,n){return(f=Object.setPrototypeOf||function(e,n){return e.__proto__=n,e})(e,n)}var p=function(e){function t(){return function(e,n){if(!(e instanceof n))throw new TypeError("Cannot call a class as a function")}(this,t),d(this,c(t).apply(this,arguments))}var n,i,o;return function(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(n&&n.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),n&&f(e,n)}(t,l["Plugin"]),n=t,(i=[{key:"_setup",value:function(e,n){this.$element=e,this.options=a.a.extend({},t.defaults,this.$element.data(),n),this.className="AccordionMenu",this._init(),s.Keyboard.register("AccordionMenu",{ENTER:"toggle",SPACE:"toggle",ARROW_RIGHT:"open",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"close",ESCAPE:"closeAll"})}},{key:"_init",value:function(){r.Nest.Feather(this.$element,"accordion");var u=this;this.$element.find("[data-submenu]").not(".is-active").slideUp(0),this.$element.attr({role:"tree","aria-multiselectable":this.options.multiOpen}),this.$menuLinks=this.$element.find(".is-accordion-submenu-parent"),this.$menuLinks.each(function(){var e=this.id||Object(l.GetYoDigits)(6,"acc-menu-link"),n=a()(this),t=n.children("[data-submenu]"),i=t[0].id||Object(l.GetYoDigits)(6,"acc-menu"),o=t.hasClass("is-active");u.options.parentLink&&n.children("a").clone().prependTo(t).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-accordion-submenu-item"></li>');u.options.submenuToggle?(n.addClass("has-submenu-toggle"),n.children("a").after('<button id="'+e+'" class="submenu-toggle" aria-controls="'+i+'" aria-expanded="'+o+'" title="'+u.options.submenuToggleText+'"><span class="submenu-toggle-text">'+u.options.submenuToggleText+"</span></button>")):n.attr({"aria-controls":i,"aria-expanded":o,id:e}),t.attr({"aria-labelledby":e,"aria-hidden":!o,role:"group",id:i})}),this.$element.find("li").attr({role:"treeitem"});var e=this.$element.find(".is-active");if(e.length){u=this;e.each(function(){u.down(a()(this))})}this._events()}},{key:"_events",value:function(){var r=this;this.$element.find("li").each(function(){var n=a()(this).children("[data-submenu]");n.length&&(r.options.submenuToggle?a()(this).children(".submenu-toggle").off("click.zf.accordionMenu").on("click.zf.accordionMenu",function(e){r.toggle(n)}):a()(this).children("a").off("click.zf.accordionMenu").on("click.zf.accordionMenu",function(e){e.preventDefault(),r.toggle(n)}))}).on("keydown.zf.accordionmenu",function(n){var t,i,o=a()(this),u=o.parent("ul").children("li"),e=o.children("[data-submenu]");u.each(function(e){if(a()(this).is(o))return t=u.eq(Math.max(0,e-1)).find("a").first(),i=u.eq(Math.min(e+1,u.length-1)).find("a").first(),a()(this).children("[data-submenu]:visible").length&&(i=o.find("li:first-child").find("a").first()),a()(this).is(":first-child")?t=o.parents("li").first().find("a").first():t.parents("li").first().children("[data-submenu]:visible").length&&(t=t.parents("li").find("li:last-child").find("a").first()),void(a()(this).is(":last-child")&&(i=o.parents("li").first().next("li").find("a").first()))}),s.Keyboard.handleKey(n,"AccordionMenu",{open:function(){e.is(":hidden")&&(r.down(e),e.find("li").first().find("a").first().focus())},close:function(){e.length&&!e.is(":hidden")?r.up(e):o.parent("[data-submenu]").length&&(r.up(o.parent("[data-submenu]")),o.parents("li").first().find("a").first().focus())},up:function(){return t.focus(),!0},down:function(){return i.focus(),!0},toggle:function(){return!r.options.submenuToggle&&(o.children("[data-submenu]").length?(r.toggle(o.children("[data-submenu]")),!0):void 0)},closeAll:function(){r.hideAll()},handled:function(e){e&&n.preventDefault(),n.stopImmediatePropagation()}})})}},{key:"hideAll",value:function(){this.up(this.$element.find("[data-submenu]"))}},{key:"showAll",value:function(){this.down(this.$element.find("[data-submenu]"))}},{key:"toggle",value:function(e){e.is(":animated")||(e.is(":hidden")?this.down(e):this.up(e))}},{key:"down",value:function(e){var n=this;if(!this.options.multiOpen){var t=e.parentsUntil(this.$element).add(e).add(e.find(".is-active")),i=this.$element.find(".is-active").not(t);this.up(i)}e.addClass("is-active").attr({"aria-hidden":!1}),this.options.submenuToggle?e.prev(".submenu-toggle").attr({"aria-expanded":!0}):e.parent(".is-accordion-submenu-parent").attr({"aria-expanded":!0}),e.slideDown(this.options.slideSpeed,function(){n.$element.trigger("down.zf.accordionMenu",[e])})}},{key:"up",value:function(e){var n=this,t=e.find("[data-submenu]"),i=e.add(t);t.slideUp(0),i.removeClass("is-active").attr("aria-hidden",!0),this.options.submenuToggle?i.prev(".submenu-toggle").attr("aria-expanded",!1):i.parent(".is-accordion-submenu-parent").attr("aria-expanded",!1),e.slideUp(this.options.slideSpeed,function(){n.$element.trigger("up.zf.accordionMenu",[e])})}},{key:"_destroy",value:function(){this.$element.find("[data-submenu]").slideDown(0).css("display",""),this.$element.find("a").off("click.zf.accordionMenu"),this.$element.find("[data-is-parent-link]").detach(),this.options.submenuToggle&&(this.$element.find(".has-submenu-toggle").removeClass("has-submenu-toggle"),this.$element.find(".submenu-toggle").remove()),r.Nest.Burn(this.$element,"accordion")}}])&&u(n.prototype,i),o&&u(n,o),t}();p.defaults={parentLink:!1,slideSpeed:250,submenuToggle:!1,submenuToggleText:"Toggle menu",multiOpen:!0}},2:function(e,n,t){e.exports=t("./js/entries/plugins/foundation.accordionMenu.js")},jquery:function(e,n){e.exports=u}})});
+//# sourceMappingURL=foundation.accordionMenu.min.js.map
diff --git a/dist/js/plugins/foundation.accordionMenu.min.js.map b/dist/js/plugins/foundation.accordionMenu.min.js.map
new file mode 100644 (file)
index 0000000..54e8453
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.accordionMenu.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE__foundation_util_nest__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.keyboard","./foundation.util.nest","./js/entries/plugins/foundation.accordionMenu.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.accordionMenu.js","AccordionMenu","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","register","ENTER","SPACE","ARROW_RIGHT","ARROW_UP","ARROW_DOWN","ARROW_LEFT","ESCAPE","Feather","_this","find","not","slideUp","attr","role","aria-multiselectable","multiOpen","$menuLinks","each","linkId","id","$elem","$sub","children","subId","isActive","hasClass","parentLink","clone","prependTo","wrap","submenuToggle","addClass","after","submenuToggleText","aria-controls","aria-expanded","aria-labelledby","aria-hidden","initPanes","down","_events","$submenu","off","on","e","toggle","preventDefault","$prevElement","$nextElement","$elements","parent","$target","is","eq","Math","max","first","min","parents","next","handleKey","open","focus","close","up","closeAll","hideAll","handled","stopImmediatePropagation","_this2","$targetBranch","parentsUntil","add","$othersActiveSubmenus","prev","slideDown","slideSpeed","trigger","_this3","$submenus","$allmenus","removeClass","css","detach","remove","Burn","2","jquery"],"mappings":"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","file":"foundation.accordionMenu.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"./foundation.util.nest\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.accordionMenu\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.accordionMenu\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.nest\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 2);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./foundation.util.nest\":\n/*!************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.nest\"],\"amd\":\"./foundation.util.nest\",\"commonjs\":\"./foundation.util.nest\",\"commonjs2\":\"./foundation.util.nest\"} ***!\n  \\************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.accordionMenu.js\":\n/*!********************************************************!*\\\n  !*** ./js/entries/plugins/foundation.accordionMenu.js ***!\n  \\********************************************************/\n/*! exports provided: Foundation, AccordionMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.accordionMenu */ \"./js/foundation.accordionMenu.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"AccordionMenu\", function() { return _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_1__[\"AccordionMenu\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_1__[\"AccordionMenu\"], 'AccordionMenu');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.accordionMenu.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.accordionMenu.js ***!\n  \\****************************************/\n/*! exports provided: AccordionMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"AccordionMenu\", function() { return AccordionMenu; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.nest */ \"./foundation.util.nest\");\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * AccordionMenu module.\n * @module foundation.accordionMenu\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n */\n\nvar AccordionMenu =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(AccordionMenu, _Plugin);\n\n  function AccordionMenu() {\n    _classCallCheck(this, AccordionMenu);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(AccordionMenu).apply(this, arguments));\n  }\n\n  _createClass(AccordionMenu, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of an accordion menu.\n     * @class\n     * @name AccordionMenu\n     * @fires AccordionMenu#init\n     * @param {jQuery} element - jQuery object to make into an accordion menu.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, AccordionMenu.defaults, this.$element.data(), options);\n      this.className = 'AccordionMenu'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('AccordionMenu', {\n        'ENTER': 'toggle',\n        'SPACE': 'toggle',\n        'ARROW_RIGHT': 'open',\n        'ARROW_UP': 'up',\n        'ARROW_DOWN': 'down',\n        'ARROW_LEFT': 'close',\n        'ESCAPE': 'closeAll'\n      });\n    }\n    /**\n     * Initializes the accordion menu by hiding all nested menus.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__[\"Nest\"].Feather(this.$element, 'accordion');\n\n      var _this = this;\n\n      this.$element.find('[data-submenu]').not('.is-active').slideUp(0); //.find('a').css('padding-left', '1rem');\n\n      this.$element.attr({\n        'role': 'tree',\n        'aria-multiselectable': this.options.multiOpen\n      });\n      this.$menuLinks = this.$element.find('.is-accordion-submenu-parent');\n      this.$menuLinks.each(function () {\n        var linkId = this.id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'acc-menu-link'),\n            $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $sub = $elem.children('[data-submenu]'),\n            subId = $sub[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'acc-menu'),\n            isActive = $sub.hasClass('is-active');\n\n        if (_this.options.parentLink) {\n          var $anchor = $elem.children('a');\n          $anchor.clone().prependTo($sub).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-accordion-submenu-item\"></li>');\n        }\n\n        if (_this.options.submenuToggle) {\n          $elem.addClass('has-submenu-toggle');\n          $elem.children('a').after('<button id=\"' + linkId + '\" class=\"submenu-toggle\" aria-controls=\"' + subId + '\" aria-expanded=\"' + isActive + '\" title=\"' + _this.options.submenuToggleText + '\"><span class=\"submenu-toggle-text\">' + _this.options.submenuToggleText + '</span></button>');\n        } else {\n          $elem.attr({\n            'aria-controls': subId,\n            'aria-expanded': isActive,\n            'id': linkId\n          });\n        }\n\n        $sub.attr({\n          'aria-labelledby': linkId,\n          'aria-hidden': !isActive,\n          'role': 'group',\n          'id': subId\n        });\n      });\n      this.$element.find('li').attr({\n        'role': 'treeitem'\n      });\n      var initPanes = this.$element.find('.is-active');\n\n      if (initPanes.length) {\n        var _this = this;\n\n        initPanes.each(function () {\n          _this.down(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n        });\n      }\n\n      this._events();\n    }\n    /**\n     * Adds event handlers for items within the menu.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this.$element.find('li').each(function () {\n        var $submenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]');\n\n        if ($submenu.length) {\n          if (_this.options.submenuToggle) {\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('.submenu-toggle').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {\n              _this.toggle($submenu);\n            });\n          } else {\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('a').off('click.zf.accordionMenu').on('click.zf.accordionMenu', function (e) {\n              e.preventDefault();\n\n              _this.toggle($submenu);\n            });\n          }\n        }\n      }).on('keydown.zf.accordionmenu', function (e) {\n        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $elements = $element.parent('ul').children('li'),\n            $prevElement,\n            $nextElement,\n            $target = $element.children('[data-submenu]');\n        $elements.each(function (i) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {\n            $prevElement = $elements.eq(Math.max(0, i - 1)).find('a').first();\n            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1)).find('a').first();\n\n            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('[data-submenu]:visible').length) {\n              // has open sub menu\n              $nextElement = $element.find('li:first-child').find('a').first();\n            }\n\n            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':first-child')) {\n              // is first element of sub menu\n              $prevElement = $element.parents('li').first().find('a').first();\n            } else if ($prevElement.parents('li').first().children('[data-submenu]:visible').length) {\n              // if previous element has open sub menu\n              $prevElement = $prevElement.parents('li').find('li:last-child').find('a').first();\n            }\n\n            if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':last-child')) {\n              // is last element of sub menu\n              $nextElement = $element.parents('li').first().next('li').find('a').first();\n            }\n\n            return;\n          }\n        });\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'AccordionMenu', {\n          open: function open() {\n            if ($target.is(':hidden')) {\n              _this.down($target);\n\n              $target.find('li').first().find('a').first().focus();\n            }\n          },\n          close: function close() {\n            if ($target.length && !$target.is(':hidden')) {\n              // close active sub of this item\n              _this.up($target);\n            } else if ($element.parent('[data-submenu]').length) {\n              // close currently open sub\n              _this.up($element.parent('[data-submenu]'));\n\n              $element.parents('li').first().find('a').first().focus();\n            }\n          },\n          up: function up() {\n            $prevElement.focus();\n            return true;\n          },\n          down: function down() {\n            $nextElement.focus();\n            return true;\n          },\n          toggle: function toggle() {\n            if (_this.options.submenuToggle) {\n              return false;\n            }\n\n            if ($element.children('[data-submenu]').length) {\n              _this.toggle($element.children('[data-submenu]'));\n\n              return true;\n            }\n          },\n          closeAll: function closeAll() {\n            _this.hideAll();\n          },\n          handled: function handled(preventDefault) {\n            if (preventDefault) {\n              e.preventDefault();\n            }\n\n            e.stopImmediatePropagation();\n          }\n        });\n      }); //.attr('tabindex', 0);\n    }\n    /**\n     * Closes all panes of the menu.\n     * @function\n     */\n\n  }, {\n    key: \"hideAll\",\n    value: function hideAll() {\n      this.up(this.$element.find('[data-submenu]'));\n    }\n    /**\n     * Opens all panes of the menu.\n     * @function\n     */\n\n  }, {\n    key: \"showAll\",\n    value: function showAll() {\n      this.down(this.$element.find('[data-submenu]'));\n    }\n    /**\n     * Toggles the open/close state of a submenu.\n     * @function\n     * @param {jQuery} $target - the submenu to toggle\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle($target) {\n      if (!$target.is(':animated')) {\n        if (!$target.is(':hidden')) {\n          this.up($target);\n        } else {\n          this.down($target);\n        }\n      }\n    }\n    /**\n     * Opens the sub-menu defined by `$target`.\n     * @param {jQuery} $target - Sub-menu to open.\n     * @fires AccordionMenu#down\n     */\n\n  }, {\n    key: \"down\",\n    value: function down($target) {\n      var _this2 = this;\n\n      // If having multiple submenus active is disabled, close all the submenus\n      // that are not parents or children of the targeted submenu.\n      if (!this.options.multiOpen) {\n        // The \"branch\" of the targetted submenu, from the component root to\n        // the active submenus nested in it.\n        var $targetBranch = $target.parentsUntil(this.$element).add($target).add($target.find('.is-active')); // All the active submenus that are not in the branch.\n\n        var $othersActiveSubmenus = this.$element.find('.is-active').not($targetBranch);\n        this.up($othersActiveSubmenus);\n      }\n\n      $target.addClass('is-active').attr({\n        'aria-hidden': false\n      });\n\n      if (this.options.submenuToggle) {\n        $target.prev('.submenu-toggle').attr({\n          'aria-expanded': true\n        });\n      } else {\n        $target.parent('.is-accordion-submenu-parent').attr({\n          'aria-expanded': true\n        });\n      }\n\n      $target.slideDown(this.options.slideSpeed, function () {\n        /**\n         * Fires when the menu is done opening.\n         * @event AccordionMenu#down\n         */\n        _this2.$element.trigger('down.zf.accordionMenu', [$target]);\n      });\n    }\n    /**\n     * Closes the sub-menu defined by `$target`. All sub-menus inside the target will be closed as well.\n     * @param {jQuery} $target - Sub-menu to close.\n     * @fires AccordionMenu#up\n     */\n\n  }, {\n    key: \"up\",\n    value: function up($target) {\n      var _this3 = this;\n\n      var $submenus = $target.find('[data-submenu]');\n      var $allmenus = $target.add($submenus);\n      $submenus.slideUp(0);\n      $allmenus.removeClass('is-active').attr('aria-hidden', true);\n\n      if (this.options.submenuToggle) {\n        $allmenus.prev('.submenu-toggle').attr('aria-expanded', false);\n      } else {\n        $allmenus.parent('.is-accordion-submenu-parent').attr('aria-expanded', false);\n      }\n\n      $target.slideUp(this.options.slideSpeed, function () {\n        /**\n         * Fires when the menu is done collapsing up.\n         * @event AccordionMenu#up\n         */\n        _this3.$element.trigger('up.zf.accordionMenu', [$target]);\n      });\n    }\n    /**\n     * Destroys an instance of accordion menu.\n     * @fires AccordionMenu#destroyed\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.find('[data-submenu]').slideDown(0).css('display', '');\n      this.$element.find('a').off('click.zf.accordionMenu');\n      this.$element.find('[data-is-parent-link]').detach();\n\n      if (this.options.submenuToggle) {\n        this.$element.find('.has-submenu-toggle').removeClass('has-submenu-toggle');\n        this.$element.find('.submenu-toggle').remove();\n      }\n\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__[\"Nest\"].Burn(this.$element, 'accordion');\n    }\n  }]);\n\n  return AccordionMenu;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nAccordionMenu.defaults = {\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n\n  /**\n   * Amount of time to animate the opening of a submenu in ms.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  slideSpeed: 250,\n\n  /**\n   * Adds a separate submenu toggle button. This allows the parent item to have a link.\n   * @option\n   * @example true\n   */\n  submenuToggle: false,\n\n  /**\n   * The text used for the submenu toggle if enabled. This is used for screen readers only.\n   * @option\n   * @example true\n   */\n  submenuToggleText: 'Toggle menu',\n\n  /**\n   * Allow the menu to have multiple open panes.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  multiOpen: true\n};\n\n\n/***/ }),\n\n/***/ 2:\n/*!**************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.accordionMenu.js ***!\n  \\**************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.accordionMenu.js */\"./js/entries/plugins/foundation.accordionMenu.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.accordionMenu.js.map"]}
\ No newline at end of file
index aeffe6a68462fa15c53049155ddbebe1b717ce16..1e00353687f14dab27a4986b84e801f4dfce94f2 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.core"] = factory(require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.core"] = factory(root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 6);
+/******/       return __webpack_require__(__webpack_require__.s = 0);
 /******/ })
 /************************************************************************/
-/******/ ([
-/* 0 */
-/***/ (function(module, exports) {
+/******/ ({
 
-module.exports = jQuery;
-
-/***/ }),
-/* 1 */
+/***/ "./js/entries/plugins/foundation.core.js":
+/*!***********************************************!*\
+  !*** ./js/entries/plugins/foundation.core.js ***!
+  \***********************************************/
+/*! exports provided: Foundation, Plugin, rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return rtl; });
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return GetYoDigits; });
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return transitionend; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.core */ "./js/foundation.core.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"]; });
 
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../foundation.core.plugin */ "./js/foundation.core.plugin.js");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Plugin", function() { return _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["Plugin"]; });
 
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "rtl", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["rtl"]; });
 
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "GetYoDigits", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"]; });
 
-// Core Foundation Utilities, utilized in a number of places.
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "RegExpEscape", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["RegExpEscape"]; });
 
-/**
- * Returns a boolean for RTL support
- */
-function rtl() {
-  return __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html').attr('dir') === 'rtl';
-}
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "transitionend", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"]; });
 
-/**
- * returns a random base-36 uid with namespacing
- * @function
- * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.
- * @param {String} namespace - name of plugin to be incorporated in uid, optional.
- * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.
- * @returns {String} - unique id
- */
-function GetYoDigits(length, namespace) {
-  length = length || 6;
-  return Math.round(Math.pow(36, length + 1) - Math.random() * Math.pow(36, length)).toString(36).slice(1) + (namespace ? '-' + namespace : '');
-}
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onLoad", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["onLoad"]; });
 
-function transitionend($elem) {
-  var transitions = {
-    'transition': 'transitionend',
-    'WebkitTransition': 'webkitTransitionEnd',
-    'MozTransition': 'transitionend',
-    'OTransition': 'otransitionend'
-  };
-  var elem = document.createElement('div'),
-      end;
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ignoreMousedisappear", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["ignoreMousedisappear"]; });
 
-  for (var t in transitions) {
-    if (typeof elem.style[t] !== 'undefined') {
-      end = transitions[t];
-    }
-  }
-  if (end) {
-    return end;
-  } else {
-    end = setTimeout(function () {
-      $elem.triggerHandler('transitionend', [$elem]);
-    }, 1);
-    return 'transitionend';
-  }
-}
-
-
-
-/***/ }),
-/* 2 */
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+// --- Foundation Core API ---
+// Initialize Foundation and add some utilities to its public API for backward compatibility.
+// Please note that every utility do not have to be added to the core API.
 
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(4);
 
 
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].addToJquery(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].addToJquery(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Every plugin depends on plugin now, we can include that on the core for the
+// script inclusion path.
 
-// These are now separated out, but historically were a part of this module,
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].Plugin = _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["Plugin"]; // These are now separated out, but historically were a part of this module,
 // and since this is here for backwards compatibility we include them in
 // this entry.
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].rtl = __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["a" /* rtl */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].GetYoDigits = __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["b" /* GetYoDigits */];
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].transitionend = __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["c" /* transitionend */];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].rtl = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["rtl"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].GetYoDigits = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].transitionend = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].RegExpEscape = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["RegExpEscape"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"].onLoad = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["onLoad"];
+window.Foundation = _foundation_core__WEBPACK_IMPORTED_MODULE_1__["Foundation"]; // --- Foundation Core exports ---
+// Export "Plugin" and all core utilities, since the `foundation.core` entry plays the role of
+// all core source files.
 
-// Every plugin depends on plugin now, we can include that on the core for the
-// script inclusion path.
 
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */].Plugin = __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["a" /* Plugin */];
 
-window.Foundation = __WEBPACK_IMPORTED_MODULE_1__foundation_core__["a" /* Foundation */];
 
 /***/ }),
-/* 3 */
+
+/***/ "./js/foundation.core.js":
+/*!*******************************!*\
+  !*** ./js/foundation.core.js ***!
+  \*******************************/
+/*! exports provided: Foundation */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Foundation; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(5);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return Foundation; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
 
 
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
-var FOUNDATION_VERSION = '6.4.3';
 
-// Global Foundation object
+var FOUNDATION_VERSION = '6.5.3'; // Global Foundation object
 // This is attached to the window, or used as a module for AMD/Browserify
+
 var Foundation = {
   version: FOUNDATION_VERSION,
 
@@ -204,17 +196,17 @@ var Foundation = {
    * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.
    * @param {Object} plugin - The constructor of the plugin.
    */
-  plugin: function (plugin, name) {
+  plugin: function plugin(_plugin, name) {
     // Object key to use when adding to global Foundation object
     // Examples: Foundation.Reveal, Foundation.OffCanvas
-    var className = name || functionName(plugin);
-    // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin
+    var className = name || functionName(_plugin); // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin
     // Examples: data-reveal, data-off-canvas
-    var attrName = hyphenate(className);
 
-    // Add to the Foundation object and the plugins list (for reflowing)
-    this._plugins[attrName] = this[className] = plugin;
+    var attrName = hyphenate(className); // Add to the Foundation object and the plugins list (for reflowing)
+
+    this._plugins[attrName] = this[className] = _plugin;
   },
+
   /**
    * @function
    * Populates the _uuids array with pointers to each individual plugin instance.
@@ -224,13 +216,14 @@ var Foundation = {
    * @param {String} name - the name of the plugin, passed as a camelCased string.
    * @fires Plugin#init
    */
-  registerPlugin: function (plugin, name) {
+  registerPlugin: function registerPlugin(plugin, name) {
     var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();
-    plugin.uuid = __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["b" /* GetYoDigits */])(6, pluginName);
+    plugin.uuid = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, pluginName);
 
-    if (!plugin.$element.attr('data-' + pluginName)) {
-      plugin.$element.attr('data-' + pluginName, plugin.uuid);
+    if (!plugin.$element.attr("data-".concat(pluginName))) {
+      plugin.$element.attr("data-".concat(pluginName), plugin.uuid);
     }
+
     if (!plugin.$element.data('zfPlugin')) {
       plugin.$element.data('zfPlugin', plugin);
     }
@@ -238,12 +231,15 @@ var Foundation = {
      * Fires when the plugin has initialized.
      * @event Plugin#init
      */
-    plugin.$element.trigger('init.zf.' + pluginName);
+
+
+    plugin.$element.trigger("init.zf.".concat(pluginName));
 
     this._uuids.push(plugin.uuid);
 
     return;
   },
+
   /**
    * @function
    * Removes the plugins uuid from the _uuids array.
@@ -252,19 +248,22 @@ var Foundation = {
    * @param {Object} plugin - an instance of a plugin, usually `this` in context.
    * @fires Plugin#destroyed
    */
-  unregisterPlugin: function (plugin) {
+  unregisterPlugin: function unregisterPlugin(plugin) {
     var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));
 
     this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);
-    plugin.$element.removeAttr('data-' + pluginName).removeData('zfPlugin')
+
+    plugin.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin')
     /**
      * Fires when the plugin has been destroyed.
      * @event Plugin#destroyed
      */
-    .trigger('destroyed.zf.' + pluginName);
+    .trigger("destroyed.zf.".concat(pluginName));
+
     for (var prop in plugin) {
       plugin[prop] = null; //clean up script to prep for garbage collection.
     }
+
     return;
   },
 
@@ -274,31 +273,33 @@ var Foundation = {
    * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`
    * @default If no argument is passed, reflow all currently active plugins.
    */
-  reInit: function (plugins) {
-    var isJQ = plugins instanceof __WEBPACK_IMPORTED_MODULE_0_jquery___default.a;
+  reInit: function reInit(plugins) {
+    var isJQ = plugins instanceof jquery__WEBPACK_IMPORTED_MODULE_0___default.a;
+
     try {
       if (isJQ) {
         plugins.each(function () {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('zfPlugin')._init();
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('zfPlugin')._init();
         });
       } else {
-        var type = typeof plugins,
+        var type = _typeof(plugins),
             _this = this,
             fns = {
-          'object': function (plgs) {
+          'object': function object(plgs) {
             plgs.forEach(function (p) {
               p = hyphenate(p);
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + p + ']').foundation('_init');
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + p + ']').foundation('_init');
             });
           },
-          'string': function () {
+          'string': function string() {
             plugins = hyphenate(plugins);
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugins + ']').foundation('_init');
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + plugins + ']').foundation('_init');
           },
-          'undefined': function () {
+          'undefined': function undefined() {
             this['object'](Object.keys(_this._plugins));
           }
         };
+
         fns[type](plugins);
       }
     } catch (err) {
@@ -313,32 +314,28 @@ var Foundation = {
    * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.
    * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.
    */
-  reflow: function (elem, plugins) {
-
+  reflow: function reflow(elem, plugins) {
     // If plugins is undefined, just grab everything
     if (typeof plugins === 'undefined') {
       plugins = Object.keys(this._plugins);
-    }
-    // If plugins is a string, convert it to an array with one item
+    } // If plugins is a string, convert it to an array with one item
     else if (typeof plugins === 'string') {
         plugins = [plugins];
       }
 
-    var _this = this;
+    var _this = this; // Iterate through each plugin
 
-    // Iterate through each plugin
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(plugins, function (i, name) {
+
+    jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(plugins, function (i, name) {
       // Get the current plugin
-      var plugin = _this._plugins[name];
+      var plugin = _this._plugins[name]; // Localize the search to all elements inside elem, as well as elem itself, unless elem === document
 
-      // Localize the search to all elements inside elem, as well as elem itself, unless elem === document
-      var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(elem).find('[data-' + name + ']').addBack('[data-' + name + ']');
+      var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem).find('[data-' + name + ']').addBack('[data-' + name + ']'); // For each plugin found, initialize it
 
-      // For each plugin found, initialize it
       $elem.each(function () {
-        var $el = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            opts = {};
-        // Don't double-dip on plugins
+        var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            opts = {}; // Don't double-dip on plugins
+
         if ($el.data('zfPlugin')) {
           console.warn("Tried to initialize " + name + " on an element that already has a Foundation plugin.");
           return;
@@ -352,8 +349,9 @@ var Foundation = {
             if (opt[0]) opts[opt[0]] = parseValue(opt[1]);
           });
         }
+
         try {
-          $el.data('zfPlugin', new plugin(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), opts));
+          $el.data('zfPlugin', new plugin(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), opts));
         } catch (er) {
           console.error(er);
         } finally {
@@ -363,16 +361,16 @@ var Foundation = {
     });
   },
   getFnName: functionName,
-
-  addToJquery: function ($) {
+  addToJquery: function addToJquery($) {
     // TODO: consider not making this a jQuery function
     // TODO: need way to reflow vs. re-initialize
+
     /**
      * The Foundation jQuery method.
      * @param {String|Array} method - An action to perform on the current jQuery object.
      */
-    var foundation = function (method) {
-      var type = typeof method,
+    var foundation = function foundation(method) {
+      var type = _typeof(method),
           $noJS = $('.no-js');
 
       if ($noJS.length) {
@@ -381,14 +379,16 @@ var Foundation = {
 
       if (type === 'undefined') {
         //needs to initialize the Foundation object, or an individual plugin.
-        __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["a" /* MediaQuery */]._init();
+        _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"]._init();
+
         Foundation.reflow(this);
       } else if (type === 'string') {
         //an individual method to invoke on a plugin or group of plugins
         var args = Array.prototype.slice.call(arguments, 1); //collect all the arguments, if necessary
+
         var plugClass = this.data('zfPlugin'); //determine the class of plugin
 
-        if (plugClass !== undefined && plugClass[method] !== undefined) {
+        if (typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined') {
           //make sure both the class and method exist
           if (this.length === 1) {
             //if there's only one, call it directly.
@@ -405,15 +405,16 @@ var Foundation = {
         }
       } else {
         //error for invalid argument type
-        throw new TypeError('We\'re sorry, ' + type + ' is not a valid parameter. You must use a string representing the method you wish to invoke.');
+        throw new TypeError("We're sorry, ".concat(type, " is not a valid parameter. You must use a string representing the method you wish to invoke."));
       }
+
       return this;
     };
+
     $.fn.foundation = foundation;
     return $;
   }
 };
-
 Foundation.util = {
   /**
    * Function for applying a debounce effect to a function call.
@@ -422,9 +423,8 @@ Foundation.util = {
    * @param {Number} delay - Time in ms to delay the call of `func`.
    * @returns function
    */
-  throttle: function (func, delay) {
+  throttle: function throttle(func, delay) {
     var timer = null;
-
     return function () {
       var context = this,
           args = arguments;
@@ -438,23 +438,23 @@ Foundation.util = {
     };
   }
 };
+window.Foundation = Foundation; // Polyfill for requestAnimationFrame
 
-window.Foundation = Foundation;
-
-// Polyfill for requestAnimationFrame
 (function () {
   if (!Date.now || !window.Date.now) window.Date.now = Date.now = function () {
     return new Date().getTime();
   };
-
   var vendors = ['webkit', 'moz'];
+
   for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {
     var vp = vendors[i];
     window.requestAnimationFrame = window[vp + 'RequestAnimationFrame'];
     window.cancelAnimationFrame = window[vp + 'CancelAnimationFrame'] || window[vp + 'CancelRequestAnimationFrame'];
   }
+
   if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) || !window.requestAnimationFrame || !window.cancelAnimationFrame) {
     var lastTime = 0;
+
     window.requestAnimationFrame = function (callback) {
       var now = Date.now();
       var nextTime = Math.max(lastTime + 16, now);
@@ -462,20 +462,24 @@ window.Foundation = Foundation;
         callback(lastTime = nextTime);
       }, nextTime - now);
     };
+
     window.cancelAnimationFrame = clearTimeout;
   }
   /**
    * Polyfill for performance.now, required by rAF
    */
+
+
   if (!window.performance || !window.performance.now) {
     window.performance = {
       start: Date.now(),
-      now: function () {
+      now: function now() {
         return Date.now() - this.start;
       }
     };
   }
 })();
+
 if (!Function.prototype.bind) {
   Function.prototype.bind = function (oThis) {
     if (typeof this !== 'function') {
@@ -486,8 +490,8 @@ if (!Function.prototype.bind) {
 
     var aArgs = Array.prototype.slice.call(arguments, 1),
         fToBind = this,
-        fNOP = function () {},
-        fBound = function () {
+        fNOP = function fNOP() {},
+        fBound = function fBound() {
       return fToBind.apply(this instanceof fNOP ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments)));
     };
 
@@ -495,29 +499,32 @@ if (!Function.prototype.bind) {
       // native functions don't have a prototype
       fNOP.prototype = this.prototype;
     }
-    fBound.prototype = new fNOP();
 
+    fBound.prototype = new fNOP();
     return fBound;
   };
-}
-// Polyfill to get the name of a function in IE9
+} // Polyfill to get the name of a function in IE9
+
+
 function functionName(fn) {
-  if (Function.prototype.name === undefined) {
+  if (typeof Function.prototype.name === 'undefined') {
     var funcNameRegex = /function\s([^(]{1,})\(/;
     var results = funcNameRegex.exec(fn.toString());
     return results && results.length > 1 ? results[1].trim() : "";
-  } else if (fn.prototype === undefined) {
+  } else if (typeof fn.prototype === 'undefined') {
     return fn.constructor.name;
   } else {
     return fn.prototype.constructor.name;
   }
 }
+
 function parseValue(str) {
   if ('true' === str) return true;else if ('false' === str) return false;else if (!isNaN(str * 1)) return parseFloat(str);
   return str;
-}
-// Convert PascalCase to kebab-case
+} // Convert PascalCase to kebab-case
 // Thank you: http://stackoverflow.com/a/8955580
+
+
 function hyphenate(str) {
   return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();
 }
@@ -525,38 +532,48 @@ function hyphenate(str) {
 
 
 /***/ }),
-/* 4 */
+
+/***/ "./js/foundation.core.plugin.js":
+/*!**************************************!*\
+  !*** ./js/foundation.core.plugin.js ***!
+  \**************************************/
+/*! exports provided: Plugin */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Plugin; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(1);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Plugin", function() { return Plugin; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./js/foundation.core.utils.js");
 
-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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
 
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
 
-// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST
+ // Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST
 // {function} _setup (replaces previous constructor),
 // {function} _destroy (replaces previous destroy)
 
-var Plugin = function () {
+var Plugin =
+/*#__PURE__*/
+function () {
   function Plugin(element, options) {
     _classCallCheck(this, Plugin);
 
     this._setup(element, options);
+
     var pluginName = getPluginName(this);
-    this.uuid = __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["b" /* GetYoDigits */])(6, pluginName);
+    this.uuid = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, pluginName);
 
-    if (!this.$element.attr('data-' + pluginName)) {
-      this.$element.attr('data-' + pluginName, this.uuid);
+    if (!this.$element.attr("data-".concat(pluginName))) {
+      this.$element.attr("data-".concat(pluginName), this.uuid);
     }
+
     if (!this.$element.data('zfPlugin')) {
       this.$element.data('zfPlugin', this);
     }
@@ -564,20 +581,24 @@ var Plugin = function () {
      * Fires when the plugin has initialized.
      * @event Plugin#init
      */
-    this.$element.trigger('init.zf.' + pluginName);
+
+
+    this.$element.trigger("init.zf.".concat(pluginName));
   }
 
   _createClass(Plugin, [{
-    key: 'destroy',
+    key: "destroy",
     value: function destroy() {
       this._destroy();
+
       var pluginName = getPluginName(this);
-      this.$element.removeAttr('data-' + pluginName).removeData('zfPlugin')
+      this.$element.removeAttr("data-".concat(pluginName)).removeData('zfPlugin')
       /**
        * Fires when the plugin has been destroyed.
        * @event Plugin#destroyed
        */
-      .trigger('destroyed.zf.' + pluginName);
+      .trigger("destroyed.zf.".concat(pluginName));
+
       for (var prop in this) {
         this[prop] = null; //clean up script to prep for garbage collection.
       }
@@ -585,9 +606,7 @@ var Plugin = function () {
   }]);
 
   return Plugin;
-}();
-
-// Convert PascalCase to kebab-case
+}(); // Convert PascalCase to kebab-case
 // Thank you: http://stackoverflow.com/a/8955580
 
 
@@ -606,60 +625,240 @@ function getPluginName(obj) {
 
 
 /***/ }),
-/* 5 */
+
+/***/ "./js/foundation.core.utils.js":
+/*!*************************************!*\
+  !*** ./js/foundation.core.utils.js ***!
+  \*************************************/
+/*! exports provided: rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return MediaQuery; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "rtl", function() { return rtl; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "GetYoDigits", function() { return GetYoDigits; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "RegExpEscape", function() { return RegExpEscape; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "transitionend", function() { return transitionend; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onLoad", function() { return onLoad; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ignoreMousedisappear", function() { return ignoreMousedisappear; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 
 
+ // Core Foundation Utilities, utilized in a number of places.
 
+/**
+ * Returns a boolean for RTL support
+ */
+
+function rtl() {
+  return jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').attr('dir') === 'rtl';
+}
+/**
+ * returns a random base-36 uid with namespacing
+ * @function
+ * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.
+ * @param {String} namespace - name of plugin to be incorporated in uid, optional.
+ * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.
+ * @returns {String} - unique id
+ */
+
+
+function GetYoDigits(length, namespace) {
+  length = length || 6;
+  return Math.round(Math.pow(36, length + 1) - Math.random() * Math.pow(36, length)).toString(36).slice(1) + (namespace ? "-".concat(namespace) : '');
+}
+/**
+ * Escape a string so it can be used as a regexp pattern
+ * @function
+ * @see https://stackoverflow.com/a/9310752/4317384
+ *
+ * @param {String} str - string to escape.
+ * @returns {String} - escaped string
+ */
+
+
+function RegExpEscape(str) {
+  return str.replace(/[-[\]{}()*+?.,\\^$|#\s]/g, '\\$&');
+}
+
+function transitionend($elem) {
+  var transitions = {
+    'transition': 'transitionend',
+    'WebkitTransition': 'webkitTransitionEnd',
+    'MozTransition': 'transitionend',
+    'OTransition': 'otransitionend'
+  };
+  var elem = document.createElement('div'),
+      end;
+
+  for (var t in transitions) {
+    if (typeof elem.style[t] !== 'undefined') {
+      end = transitions[t];
+    }
+  }
+
+  if (end) {
+    return end;
+  } else {
+    end = setTimeout(function () {
+      $elem.triggerHandler('transitionend', [$elem]);
+    }, 1);
+    return 'transitionend';
+  }
+}
+/**
+ * Return an event type to listen for window load.
+ *
+ * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.
+ * If `handler` is passed, attach it to the event on `$elem`.
+ * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.
+ * @function
+ *
+ * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.
+ * @param {Function} [] handler - function to attach to the event.
+ * @returns {String} - event type that should or will be triggered.
+ */
+
+
+function onLoad($elem, handler) {
+  var didLoad = document.readyState === 'complete';
+  var eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';
+
+  var cb = function cb() {
+    return $elem.triggerHandler(eventType);
+  };
+
+  if ($elem) {
+    if (handler) $elem.one(eventType, handler);
+    if (didLoad) setTimeout(cb);else jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', cb);
+  }
+
+  return eventType;
+}
+/**
+ * Retuns an handler for the `mouseleave` that ignore disappeared mouses.
+ *
+ * If the mouse "disappeared" from the document (like when going on a browser UI element, See https://git.io/zf-11410),
+ * the event is ignored.
+ * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window
+ *   (like by switching to an other window with [Alt]+[Tab]).
+ * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document
+ *   outside of the element it left.
+ *
+ * @function
+ *
+ * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.
+ * @param {Object} [] options - object of options:
+ * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.
+ * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.
+ * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.
+ */
+
+
+function ignoreMousedisappear(handler) {
+  var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
+      _ref$ignoreLeaveWindo = _ref.ignoreLeaveWindow,
+      ignoreLeaveWindow = _ref$ignoreLeaveWindo === void 0 ? false : _ref$ignoreLeaveWindo,
+      _ref$ignoreReappear = _ref.ignoreReappear,
+      ignoreReappear = _ref$ignoreReappear === void 0 ? false : _ref$ignoreReappear;
+
+  return function leaveEventHandler(eLeave) {
+    for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
+      rest[_key - 1] = arguments[_key];
+    }
+
+    var callback = handler.bind.apply(handler, [this, eLeave].concat(rest)); // The mouse left: call the given callback if the mouse entered elsewhere
+
+    if (eLeave.relatedTarget !== null) {
+      return callback();
+    } // Otherwise, check if the mouse actually left the window.
+    // In firefox if the user switched between windows, the window sill have the focus by the time
+    // the event is triggered. We have to debounce the event to test this case.
+
+
+    setTimeout(function leaveEventDebouncer() {
+      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {
+        return callback();
+      } // Otherwise, wait for the mouse to reeapear outside of the element,
+
+
+      if (!ignoreReappear) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).one('mouseenter', function reenterEventHandler(eReenter) {
+          if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(eLeave.currentTarget).has(eReenter.target).length) {
+            // Fill where the mouse finally entered.
+            eLeave.relatedTarget = eReenter.target;
+            callback();
+          }
+        });
+      }
+    }, 0);
+  };
+}
+
+
+
+/***/ }),
+
+/***/ "./js/foundation.util.mediaQuery.js":
+/*!******************************************!*\
+  !*** ./js/foundation.util.mediaQuery.js ***!
+  \******************************************/
+/*! exports provided: MediaQuery */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MediaQuery", function() { return MediaQuery; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+ // Default set of media queries
 
-// Default set of media queries
 var defaultQueries = {
   'default': 'only screen',
   landscape: 'only screen and (orientation: landscape)',
   portrait: 'only screen and (orientation: portrait)',
   retina: 'only screen and (-webkit-min-device-pixel-ratio: 2),' + 'only screen and (min--moz-device-pixel-ratio: 2),' + 'only screen and (-o-min-device-pixel-ratio: 2/1),' + 'only screen and (min-device-pixel-ratio: 2),' + 'only screen and (min-resolution: 192dpi),' + 'only screen and (min-resolution: 2dppx)'
-};
+}; // matchMedia() polyfill - Test a CSS media type/query in JS.
+// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license
 
-// matchMedia() polyfill - Test a CSS media type/query in JS.
-// Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. Dual MIT/BSD license
-var matchMedia = window.matchMedia || function () {
-  'use strict';
+/* eslint-disable */
 
-  // For browsers that support matchMedium api such as IE 9 and webkit
+window.matchMedia || (window.matchMedia = function () {
+  "use strict"; // For browsers that support matchMedium api such as IE 9 and webkit
 
-  var styleMedia = window.styleMedia || window.media;
+  var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium
 
-  // For those that don't support matchMedium
   if (!styleMedia) {
     var style = document.createElement('style'),
         script = document.getElementsByTagName('script')[0],
         info = null;
-
     style.type = 'text/css';
     style.id = 'matchmediajs-test';
 
-    script && script.parentNode && script.parentNode.insertBefore(style, script);
+    if (!script) {
+      document.head.appendChild(style);
+    } else {
+      script.parentNode.insertBefore(style, script);
+    } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
 
-    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
-    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;
 
+    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;
     styleMedia = {
-      matchMedium: function (media) {
-        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';
+      matchMedium: function matchMedium(media) {
+        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
 
-        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
         if (style.styleSheet) {
           style.styleSheet.cssText = text;
         } else {
           style.textContent = text;
-        }
+        } // Test if media query is true or false
+
 
-        // Test if media query is true or false
         return info.width === '1px';
       }
     };
@@ -671,11 +870,11 @@ var matchMedia = window.matchMedia || function () {
       media: media || 'all'
     };
   };
-}();
+}());
+/* eslint-enable */
 
 var MediaQuery = {
   queries: [],
-
   current: '',
 
   /**
@@ -683,23 +882,23 @@ var MediaQuery = {
    * @function
    * @private
    */
-  _init: function () {
+  _init: function _init() {
     var self = this;
-    var $meta = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('meta.foundation-mq');
+    var $meta = jquery__WEBPACK_IMPORTED_MODULE_0___default()('meta.foundation-mq');
+
     if (!$meta.length) {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<meta class="foundation-mq">').appendTo(document.head);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('<meta class="foundation-mq">').appendTo(document.head);
     }
 
-    var extractedStyles = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('.foundation-mq').css('font-family');
+    var extractedStyles = jquery__WEBPACK_IMPORTED_MODULE_0___default()('.foundation-mq').css('font-family');
     var namedQueries;
-
     namedQueries = parseStyleToObject(extractedStyles);
 
     for (var key in namedQueries) {
       if (namedQueries.hasOwnProperty(key)) {
         self.queries.push({
           name: key,
-          value: 'only screen and (min-width: ' + namedQueries[key] + ')'
+          value: "only screen and (min-width: ".concat(namedQueries[key], ")")
         });
       }
     }
@@ -709,48 +908,47 @@ var MediaQuery = {
     this._watcher();
   },
 
-
   /**
    * Checks if the screen is at least as wide as a breakpoint.
    * @function
    * @param {String} size - Name of the breakpoint to check.
    * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.
    */
-  atLeast: function (size) {
+  atLeast: function atLeast(size) {
     var query = this.get(size);
 
     if (query) {
-      return matchMedia(query).matches;
+      return window.matchMedia(query).matches;
     }
 
     return false;
   },
 
-
   /**
    * Checks if the screen matches to a breakpoint.
    * @function
    * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.
    * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.
    */
-  is: function (size) {
+  is: function is(size) {
     size = size.trim().split(' ');
+
     if (size.length > 1 && size[1] === 'only') {
       if (size[0] === this._getCurrentSize()) return true;
     } else {
       return this.atLeast(size[0]);
     }
+
     return false;
   },
 
-
   /**
    * Gets the media query of a breakpoint.
    * @function
    * @param {String} size - Name of the breakpoint to get.
    * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.
    */
-  get: function (size) {
+  get: function get(size) {
     for (var i in this.queries) {
       if (this.queries.hasOwnProperty(i)) {
         var query = this.queries[i];
@@ -761,56 +959,52 @@ var MediaQuery = {
     return null;
   },
 
-
   /**
    * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).
    * @function
    * @private
    * @returns {String} Name of the current breakpoint.
    */
-  _getCurrentSize: function () {
+  _getCurrentSize: function _getCurrentSize() {
     var matched;
 
     for (var i = 0; i < this.queries.length; i++) {
       var query = this.queries[i];
 
-      if (matchMedia(query.value).matches) {
+      if (window.matchMedia(query.value).matches) {
         matched = query;
       }
     }
 
-    if (typeof matched === 'object') {
+    if (_typeof(matched) === 'object') {
       return matched.name;
     } else {
       return matched;
     }
   },
 
-
   /**
    * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.
    * @function
    * @private
    */
-  _watcher: function () {
+  _watcher: function _watcher() {
     var _this = this;
 
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {
       var newSize = _this._getCurrentSize(),
           currentSize = _this.current;
 
       if (newSize !== currentSize) {
         // Change the current media query
-        _this.current = newSize;
+        _this.current = newSize; // Broadcast the media query change on the window
 
-        // Broadcast the media query change on the window
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
       }
     });
   }
-};
+}; // Thank you: https://github.com/sindresorhus/query-string
 
-// Thank you: https://github.com/sindresorhus/query-string
 function parseStyleToObject(str) {
   var styleObject = {};
 
@@ -828,11 +1022,10 @@ function parseStyleToObject(str) {
     var parts = param.replace(/\+/g, ' ').split('=');
     var key = parts[0];
     var val = parts[1];
-    key = decodeURIComponent(key);
-
-    // missing `=` should be `null`:
+    key = decodeURIComponent(key); // missing `=` should be `null`:
     // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters
-    val = val === undefined ? null : decodeURIComponent(val);
+
+    val = typeof val === 'undefined' ? null : decodeURIComponent(val);
 
     if (!ret.hasOwnProperty(key)) {
       ret[key] = val;
@@ -841,20 +1034,39 @@ function parseStyleToObject(str) {
     } else {
       ret[key] = [ret[key], val];
     }
+
     return ret;
   }, {});
-
   return styleObject;
 }
 
 
 
 /***/ }),
-/* 6 */
+
+/***/ 0:
+/*!*****************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.core.js ***!
+  \*****************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(2);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.core.js */"./js/entries/plugins/foundation.core.js");
+
 
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
-/******/ ]);
\ No newline at end of file
+
+/******/ });
+});
+//# sourceMappingURL=foundation.core.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.core.js.map b/dist/js/plugins/foundation.core.js.map
new file mode 100644 (file)
index 0000000..f715d0f
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.core.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.core.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.core.plugin.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.core.utils.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.mediaQuery.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","addToJquery","$","Plugin","rtl","GetYoDigits","transitionend","RegExpEscape","onLoad","window","FOUNDATION_VERSION","version","_plugins","_uuids","plugin","name","className","functionName","attrName","hyphenate","registerPlugin","pluginName","constructor","toLowerCase","uuid","$element","attr","data","trigger","push","unregisterPlugin","splice","indexOf","removeAttr","removeData","prop","reInit","plugins","isJQ","each","_init","type","_this","fns","plgs","forEach","p","foundation","Object","keys","err","console","error","reflow","elem","i","$elem","find","addBack","$el","opts","warn","thing","split","e","opt","map","el","trim","parseValue","er","getFnName","method","$noJS","length","removeClass","MediaQuery","args","Array","prototype","slice","call","arguments","plugClass","apply","ReferenceError","TypeError","fn","util","throttle","func","delay","timer","context","setTimeout","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","test","navigator","userAgent","lastTime","callback","nextTime","Math","max","clearTimeout","performance","start","Function","bind","oThis","aArgs","fToBind","fNOP","fBound","concat","funcNameRegex","results","exec","toString","str","isNaN","parseFloat","replace","element","options","_setup","getPluginName","_destroy","obj","namespace","round","pow","random","transitions","document","createElement","end","t","style","triggerHandler","handler","didLoad","readyState","eventType","cb","one","ignoreMousedisappear","ignoreLeaveWindow","ignoreReappear","leaveEventHandler","eLeave","rest","relatedTarget","leaveEventDebouncer","hasFocus","reenterEventHandler","eReenter","currentTarget","has","target","defaultQueries","landscape","portrait","retina","matchMedia","styleMedia","media","script","getElementsByTagName","info","id","head","appendChild","parentNode","insertBefore","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","matches","queries","current","self","$meta","appendTo","extractedStyles","css","namedQueries","parseStyleToObject","key","hasOwnProperty","value","_getCurrentSize","_watcher","atLeast","size","query","get","is","matched","off","on","newSize","currentSize","styleObject","reduce","ret","param","parts","val","decodeURIComponent","isArray"],"mappings":"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","file":"foundation.core.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.core\"] = factory(require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"] = factory(root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 0);\n","// --- Foundation Core API ---\n// Initialize Foundation and add some utilities to its public API for backward compatibility.\n// Please note that every utility do not have to be added to the core API.\nimport $ from 'jquery';\nimport { Foundation } from '../../foundation.core';\nimport { Plugin } from '../../foundation.core.plugin';\nimport { rtl, GetYoDigits, transitionend, RegExpEscape, onLoad } from '../../foundation.core.utils';\n\nFoundation.addToJquery($);\n\n// Every plugin depends on plugin now, we can include that on the core for the\n// script inclusion path.\nFoundation.Plugin = Plugin;\n\n// These are now separated out, but historically were a part of this module,\n// and since this is here for backwards compatibility we include them in\n// this entry.\nFoundation.rtl = rtl;\nFoundation.GetYoDigits = GetYoDigits;\nFoundation.transitionend = transitionend;\nFoundation.RegExpEscape = RegExpEscape;\nFoundation.onLoad = onLoad;\n\nwindow.Foundation = Foundation;\n\n// --- Foundation Core exports ---\n// Export \"Plugin\" and all core utilities, since the `foundation.core` entry plays the role of\n// all core source files.\n\nexport { Foundation };\nexport * from '../../foundation.core.plugin';\nexport * from '../../foundation.core.utils';\n","\"use strict\";\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\n\nvar FOUNDATION_VERSION = '6.5.3';\n\n// Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\nvar Foundation = {\n  version: FOUNDATION_VERSION,\n\n  /**\n   * Stores initialized plugins.\n   */\n  _plugins: {},\n\n  /**\n   * Stores generated unique ids for plugin instances\n   */\n  _uuids: [],\n\n  /**\n   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n   * @param {Object} plugin - The constructor of the plugin.\n   */\n  plugin: function(plugin, name) {\n    // Object key to use when adding to global Foundation object\n    // Examples: Foundation.Reveal, Foundation.OffCanvas\n    var className = (name || functionName(plugin));\n    // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n    // Examples: data-reveal, data-off-canvas\n    var attrName  = hyphenate(className);\n\n    // Add to the Foundation object and the plugins list (for reflowing)\n    this._plugins[attrName] = this[className] = plugin;\n  },\n  /**\n   * @function\n   * Populates the _uuids array with pointers to each individual plugin instance.\n   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n   * Also fires the initialization event for each plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @param {String} name - the name of the plugin, passed as a camelCased string.\n   * @fires Plugin#init\n   */\n  registerPlugin: function(plugin, name){\n    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n    plugin.uuid = GetYoDigits(6, pluginName);\n\n    if(!plugin.$element.attr(`data-${pluginName}`)){ plugin.$element.attr(`data-${pluginName}`, plugin.uuid); }\n    if(!plugin.$element.data('zfPlugin')){ plugin.$element.data('zfPlugin', plugin); }\n          /**\n           * Fires when the plugin has initialized.\n           * @event Plugin#init\n           */\n    plugin.$element.trigger(`init.zf.${pluginName}`);\n\n    this._uuids.push(plugin.uuid);\n\n    return;\n  },\n  /**\n   * @function\n   * Removes the plugins uuid from the _uuids array.\n   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n   * Also fires the destroyed event for the plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @fires Plugin#destroyed\n   */\n  unregisterPlugin: function(plugin){\n    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n    plugin.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n          /**\n           * Fires when the plugin has been destroyed.\n           * @event Plugin#destroyed\n           */\n          .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in plugin){\n      plugin[prop] = null;//clean up script to prep for garbage collection.\n    }\n    return;\n  },\n\n  /**\n   * @function\n   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n   * @default If no argument is passed, reflow all currently active plugins.\n   */\n   reInit: function(plugins){\n     var isJQ = plugins instanceof $;\n     try{\n       if(isJQ){\n         plugins.each(function(){\n           $(this).data('zfPlugin')._init();\n         });\n       }else{\n         var type = typeof plugins,\n         _this = this,\n         fns = {\n           'object': function(plgs){\n             plgs.forEach(function(p){\n               p = hyphenate(p);\n               $('[data-'+ p +']').foundation('_init');\n             });\n           },\n           'string': function(){\n             plugins = hyphenate(plugins);\n             $('[data-'+ plugins +']').foundation('_init');\n           },\n           'undefined': function(){\n             this['object'](Object.keys(_this._plugins));\n           }\n         };\n         fns[type](plugins);\n       }\n     }catch(err){\n       console.error(err);\n     }finally{\n       return plugins;\n     }\n   },\n\n  /**\n   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n   */\n  reflow: function(elem, plugins) {\n\n    // If plugins is undefined, just grab everything\n    if (typeof plugins === 'undefined') {\n      plugins = Object.keys(this._plugins);\n    }\n    // If plugins is a string, convert it to an array with one item\n    else if (typeof plugins === 'string') {\n      plugins = [plugins];\n    }\n\n    var _this = this;\n\n    // Iterate through each plugin\n    $.each(plugins, function(i, name) {\n      // Get the current plugin\n      var plugin = _this._plugins[name];\n\n      // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n      var $elem = $(elem).find('[data-'+name+']').addBack('[data-'+name+']');\n\n      // For each plugin found, initialize it\n      $elem.each(function() {\n        var $el = $(this),\n            opts = {};\n        // Don't double-dip on plugins\n        if ($el.data('zfPlugin')) {\n          console.warn(\"Tried to initialize \"+name+\" on an element that already has a Foundation plugin.\");\n          return;\n        }\n\n        if($el.attr('data-options')){\n          var thing = $el.attr('data-options').split(';').forEach(function(e, i){\n            var opt = e.split(':').map(function(el){ return el.trim(); });\n            if(opt[0]) opts[opt[0]] = parseValue(opt[1]);\n          });\n        }\n        try{\n          $el.data('zfPlugin', new plugin($(this), opts));\n        }catch(er){\n          console.error(er);\n        }finally{\n          return;\n        }\n      });\n    });\n  },\n  getFnName: functionName,\n\n  addToJquery: function($) {\n    // TODO: consider not making this a jQuery function\n    // TODO: need way to reflow vs. re-initialize\n    /**\n     * The Foundation jQuery method.\n     * @param {String|Array} method - An action to perform on the current jQuery object.\n     */\n    var foundation = function(method) {\n      var type = typeof method,\n          $noJS = $('.no-js');\n\n      if($noJS.length){\n        $noJS.removeClass('no-js');\n      }\n\n      if(type === 'undefined'){//needs to initialize the Foundation object, or an individual plugin.\n        MediaQuery._init();\n        Foundation.reflow(this);\n      }else if(type === 'string'){//an individual method to invoke on a plugin or group of plugins\n        var args = Array.prototype.slice.call(arguments, 1);//collect all the arguments, if necessary\n        var plugClass = this.data('zfPlugin');//determine the class of plugin\n\n        if(typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined'){//make sure both the class and method exist\n          if(this.length === 1){//if there's only one, call it directly.\n              plugClass[method].apply(plugClass, args);\n          }else{\n            this.each(function(i, el){//otherwise loop through the jQuery collection and invoke the method on each\n              plugClass[method].apply($(el).data('zfPlugin'), args);\n            });\n          }\n        }else{//error for no class or no method\n          throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n        }\n      }else{//error for invalid argument type\n        throw new TypeError(`We're sorry, ${type} is not a valid parameter. You must use a string representing the method you wish to invoke.`);\n      }\n      return this;\n    };\n    $.fn.foundation = foundation;\n    return $;\n  }\n};\n\nFoundation.util = {\n  /**\n   * Function for applying a debounce effect to a function call.\n   * @function\n   * @param {Function} func - Function to be called at end of timeout.\n   * @param {Number} delay - Time in ms to delay the call of `func`.\n   * @returns function\n   */\n  throttle: function (func, delay) {\n    var timer = null;\n\n    return function () {\n      var context = this, args = arguments;\n\n      if (timer === null) {\n        timer = setTimeout(function () {\n          func.apply(context, args);\n          timer = null;\n        }, delay);\n      }\n    };\n  }\n};\n\nwindow.Foundation = Foundation;\n\n// Polyfill for requestAnimationFrame\n(function() {\n  if (!Date.now || !window.Date.now)\n    window.Date.now = Date.now = function() { return new Date().getTime(); };\n\n  var vendors = ['webkit', 'moz'];\n  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n      var vp = vendors[i];\n      window.requestAnimationFrame = window[vp+'RequestAnimationFrame'];\n      window.cancelAnimationFrame = (window[vp+'CancelAnimationFrame']\n                                 || window[vp+'CancelRequestAnimationFrame']);\n  }\n  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)\n    || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n    var lastTime = 0;\n    window.requestAnimationFrame = function(callback) {\n        var now = Date.now();\n        var nextTime = Math.max(lastTime + 16, now);\n        return setTimeout(function() { callback(lastTime = nextTime); },\n                          nextTime - now);\n    };\n    window.cancelAnimationFrame = clearTimeout;\n  }\n  /**\n   * Polyfill for performance.now, required by rAF\n   */\n  if(!window.performance || !window.performance.now){\n    window.performance = {\n      start: Date.now(),\n      now: function(){ return Date.now() - this.start; }\n    };\n  }\n})();\nif (!Function.prototype.bind) {\n  Function.prototype.bind = function(oThis) {\n    if (typeof this !== 'function') {\n      // closest thing possible to the ECMAScript 5\n      // internal IsCallable function\n      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n    }\n\n    var aArgs   = Array.prototype.slice.call(arguments, 1),\n        fToBind = this,\n        fNOP    = function() {},\n        fBound  = function() {\n          return fToBind.apply(this instanceof fNOP\n                 ? this\n                 : oThis,\n                 aArgs.concat(Array.prototype.slice.call(arguments)));\n        };\n\n    if (this.prototype) {\n      // native functions don't have a prototype\n      fNOP.prototype = this.prototype;\n    }\n    fBound.prototype = new fNOP();\n\n    return fBound;\n  };\n}\n// Polyfill to get the name of a function in IE9\nfunction functionName(fn) {\n  if (typeof Function.prototype.name === 'undefined') {\n    var funcNameRegex = /function\\s([^(]{1,})\\(/;\n    var results = (funcNameRegex).exec((fn).toString());\n    return (results && results.length > 1) ? results[1].trim() : \"\";\n  }\n  else if (typeof fn.prototype === 'undefined') {\n    return fn.constructor.name;\n  }\n  else {\n    return fn.prototype.constructor.name;\n  }\n}\nfunction parseValue(str){\n  if ('true' === str) return true;\n  else if ('false' === str) return false;\n  else if (!isNaN(str * 1)) return parseFloat(str);\n  return str;\n}\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nexport {Foundation};\n","'use strict';\n\nimport $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\n\n// Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\nclass Plugin {\n\n  constructor(element, options) {\n    this._setup(element, options);\n    var pluginName = getPluginName(this);\n    this.uuid = GetYoDigits(6, pluginName);\n\n    if(!this.$element.attr(`data-${pluginName}`)){ this.$element.attr(`data-${pluginName}`, this.uuid); }\n    if(!this.$element.data('zfPlugin')){ this.$element.data('zfPlugin', this); }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n    this.$element.trigger(`init.zf.${pluginName}`);\n  }\n\n  destroy() {\n    this._destroy();\n    var pluginName = getPluginName(this);\n    this.$element.removeAttr(`data-${pluginName}`).removeData('zfPlugin')\n        /**\n         * Fires when the plugin has been destroyed.\n         * @event Plugin#destroyed\n         */\n        .trigger(`destroyed.zf.${pluginName}`);\n    for(var prop in this){\n      this[prop] = null;//clean up script to prep for garbage collection.\n    }\n  }\n}\n\n// Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n  if(typeof(obj.constructor.name) !== 'undefined') {\n    return hyphenate(obj.constructor.name);\n  } else {\n    return hyphenate(obj.className);\n  }\n}\n\nexport {Plugin};\n","\"use strict\";\n\nimport $ from 'jquery';\n\n// Core Foundation Utilities, utilized in a number of places.\n\n  /**\n   * Returns a boolean for RTL support\n   */\nfunction rtl() {\n  return $('html').attr('dir') === 'rtl';\n}\n\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\nfunction GetYoDigits(length, namespace){\n  length = length || 6;\n  return Math.round((Math.pow(36, length + 1) - Math.random() * Math.pow(36, length))).toString(36).slice(1) + (namespace ? `-${namespace}` : '');\n}\n\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\nfunction RegExpEscape(str){\n  return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem){\n  var transitions = {\n    'transition': 'transitionend',\n    'WebkitTransition': 'webkitTransitionEnd',\n    'MozTransition': 'transitionend',\n    'OTransition': 'otransitionend'\n  };\n  var elem = document.createElement('div'),\n      end;\n\n  for (var t in transitions){\n    if (typeof elem.style[t] !== 'undefined'){\n      end = transitions[t];\n    }\n  }\n  if(end){\n    return end;\n  }else{\n    end = setTimeout(function(){\n      $elem.triggerHandler('transitionend', [$elem]);\n    }, 1);\n    return 'transitionend';\n  }\n}\n\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\nfunction onLoad($elem, handler) {\n  const didLoad = document.readyState === 'complete';\n  const eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n  const cb = () => $elem.triggerHandler(eventType);\n\n  if ($elem) {\n    if (handler) $elem.one(eventType, handler);\n\n    if (didLoad)\n      setTimeout(cb);\n    else\n      $(window).one('load', cb);\n  }\n\n  return eventType;\n}\n\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n *   (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n *   outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\nfunction ignoreMousedisappear(handler, { ignoreLeaveWindow = false, ignoreReappear = false } = {}) {\n  return function leaveEventHandler(eLeave, ...rest) {\n    const callback = handler.bind(this, eLeave, ...rest);\n\n    // The mouse left: call the given callback if the mouse entered elsewhere\n    if (eLeave.relatedTarget !== null) {\n      return callback();\n    }\n\n    // Otherwise, check if the mouse actually left the window.\n    // In firefox if the user switched between windows, the window sill have the focus by the time\n    // the event is triggered. We have to debounce the event to test this case.\n    setTimeout(function leaveEventDebouncer() {\n      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n        return callback();\n      }\n\n      // Otherwise, wait for the mouse to reeapear outside of the element,\n      if (!ignoreReappear) {\n        $(document).one('mouseenter', function reenterEventHandler(eReenter) {\n          if (!$(eLeave.currentTarget).has(eReenter.target).length) {\n            // Fill where the mouse finally entered.\n            eLeave.relatedTarget = eReenter.target;\n            callback();\n          }\n        });\n      }\n\n    }, 0);\n  };\n}\n\nexport { rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear };\n","'use strict';\n\nimport $ from 'jquery';\n\n// Default set of media queries\nconst defaultQueries = {\n  'default' : 'only screen',\n  landscape : 'only screen and (orientation: landscape)',\n  portrait : 'only screen and (orientation: portrait)',\n  retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' +\n    'only screen and (min--moz-device-pixel-ratio: 2),' +\n    'only screen and (-o-min-device-pixel-ratio: 2/1),' +\n    'only screen and (min-device-pixel-ratio: 2),' +\n    'only screen and (min-resolution: 192dpi),' +\n    'only screen and (min-resolution: 2dppx)'\n  };\n\n\n// matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n/* eslint-disable */\nwindow.matchMedia || (window.matchMedia = (function () {\n  \"use strict\";\n\n  // For browsers that support matchMedium api such as IE 9 and webkit\n  var styleMedia = (window.styleMedia || window.media);\n\n  // For those that don't support matchMedium\n  if (!styleMedia) {\n    var style   = document.createElement('style'),\n    script      = document.getElementsByTagName('script')[0],\n    info        = null;\n\n    style.type  = 'text/css';\n    style.id    = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    }\n\n    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n    info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;\n\n    styleMedia = {\n      matchMedium: function (media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';\n\n        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        }\n\n        // Test if media query is true or false\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function(media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n})());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init() {\n    var self = this;\n    var $meta = $('meta.foundation-mq');\n    if(!$meta.length){\n      $('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = $('.foundation-mq').css('font-family');\n    var namedQueries;\n\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if(namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: `only screen and (min-width: ${namedQueries[key]})`\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is(size) {\n    size = size.trim().split(' ');\n    if(size.length > 1 && size[1] === 'only') {\n      if(size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get(size) {\n    for (var i in this.queries) {\n      if(this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (typeof matched === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher() {\n    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', () => {\n      var newSize = this._getCurrentSize(), currentSize = this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        this.current = newSize;\n\n        // Broadcast the media query change on the window\n        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n};\n\n\n\n// Thank you: https://github.com/sindresorhus/query-string\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function(ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key);\n\n    // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n    return ret;\n  }, {});\n\n  return styleObject;\n}\n\nexport {MediaQuery};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index bd7be15f10c2a484d25705497aae3bffb7dbeecc..0bc8c0fa1864f2bc11b5b317299d05c9eb36e2eb 100644 (file)
@@ -1 +1,2 @@
-!function(t){function n(i){if(e[i])return e[i].exports;var r=e[i]={i:i,l:!1,exports:{}};return t[i].call(r.exports,r,r.exports,n),r.l=!0,r.exports}var e={};n.m=t,n.c=e,n.i=function(t){return t},n.d=function(t,e,i){n.o(t,e)||Object.defineProperty(t,e,{configurable:!1,enumerable:!0,get:i})},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,n){return Object.prototype.hasOwnProperty.call(t,n)},n.p="",n(n.s=6)}([function(t,n){t.exports=jQuery},function(t,n,e){"use strict";function i(){return"rtl"===u()("html").attr("dir")}function r(t,n){return t=t||6,Math.round(Math.pow(36,t+1)-Math.random()*Math.pow(36,t)).toString(36).slice(1)+(n?"-"+n:"")}function o(t){var n,e={transition:"transitionend",WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"otransitionend"},i=document.createElement("div");for(var r in e)void 0!==i.style[r]&&(n=e[r]);return n||(n=setTimeout(function(){t.triggerHandler("transitionend",[t])},1),"transitionend")}e.d(n,"a",function(){return i}),e.d(n,"b",function(){return r}),e.d(n,"c",function(){return o});var a=e(0),u=e.n(a)},function(t,n,e){"use strict";Object.defineProperty(n,"__esModule",{value:!0});var i=e(0),r=e.n(i),o=e(3),a=e(1),u=e(4);o.a.addToJquery(r.a),o.a.rtl=a.a,o.a.GetYoDigits=a.b,o.a.transitionend=a.c,o.a.Plugin=u.a,window.Foundation=o.a},function(t,n,e){"use strict";function i(t){if(void 0===Function.prototype.name){var n=/function\s([^(]{1,})\(/,e=n.exec(t.toString());return e&&e.length>1?e[1].trim():""}return void 0===t.prototype?t.constructor.name:t.prototype.constructor.name}function r(t){return"true"===t||"false"!==t&&(isNaN(1*t)?t:parseFloat(t))}function o(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}e.d(n,"a",function(){return l});var a=e(0),u=e.n(a),s=e(1),c=e(5),l={version:"6.4.3",_plugins:{},_uuids:[],plugin:function(t,n){var e=n||i(t),r=o(e);this._plugins[r]=this[e]=t},registerPlugin:function(t,n){var r=n?o(n):i(t.constructor).toLowerCase();t.uuid=e.i(s.b)(6,r),t.$element.attr("data-"+r)||t.$element.attr("data-"+r,t.uuid),t.$element.data("zfPlugin")||t.$element.data("zfPlugin",t),t.$element.trigger("init.zf."+r),this._uuids.push(t.uuid)},unregisterPlugin:function(t){var n=o(i(t.$element.data("zfPlugin").constructor));this._uuids.splice(this._uuids.indexOf(t.uuid),1),t.$element.removeAttr("data-"+n).removeData("zfPlugin").trigger("destroyed.zf."+n);for(var e in t)t[e]=null},reInit:function(t){var n=t instanceof u.a;try{if(n)t.each(function(){u()(this).data("zfPlugin")._init()});else{var e=typeof t,i=this;({object:function(t){t.forEach(function(t){t=o(t),u()("[data-"+t+"]").foundation("_init")})},string:function(){t=o(t),u()("[data-"+t+"]").foundation("_init")},undefined:function(){this.object(Object.keys(i._plugins))}})[e](t)}}catch(t){console.error(t)}finally{return t}},reflow:function(t,n){void 0===n?n=Object.keys(this._plugins):"string"==typeof n&&(n=[n]);var e=this;u.a.each(n,function(n,i){var o=e._plugins[i];u()(t).find("[data-"+i+"]").addBack("[data-"+i+"]").each(function(){var t=u()(this),n={};if(t.data("zfPlugin"))return void console.warn("Tried to initialize "+i+" on an element that already has a Foundation plugin.");t.attr("data-options")&&t.attr("data-options").split(";").forEach(function(t,e){var i=t.split(":").map(function(t){return t.trim()});i[0]&&(n[i[0]]=r(i[1]))});try{t.data("zfPlugin",new o(u()(this),n))}catch(t){console.error(t)}finally{return}})})},getFnName:i,addToJquery:function(t){var n=function(n){var e=typeof n,r=t(".no-js");if(r.length&&r.removeClass("no-js"),"undefined"===e)c.a._init(),l.reflow(this);else{if("string"!==e)throw new TypeError("We're sorry, "+e+" is not a valid parameter. You must use a string representing the method you wish to invoke.");var o=Array.prototype.slice.call(arguments,1),a=this.data("zfPlugin");if(void 0===a||void 0===a[n])throw new ReferenceError("We're sorry, '"+n+"' is not an available method for "+(a?i(a):"this element")+".");1===this.length?a[n].apply(a,o):this.each(function(e,i){a[n].apply(t(i).data("zfPlugin"),o)})}return this};return t.fn.foundation=n,t}};l.util={throttle:function(t,n){var e=null;return function(){var i=this,r=arguments;null===e&&(e=setTimeout(function(){t.apply(i,r),e=null},n))}}},window.Foundation=l,function(){Date.now&&window.Date.now||(window.Date.now=Date.now=function(){return(new Date).getTime()});for(var t=["webkit","moz"],n=0;n<t.length&&!window.requestAnimationFrame;++n){var e=t[n];window.requestAnimationFrame=window[e+"RequestAnimationFrame"],window.cancelAnimationFrame=window[e+"CancelAnimationFrame"]||window[e+"CancelRequestAnimationFrame"]}if(/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)||!window.requestAnimationFrame||!window.cancelAnimationFrame){var i=0;window.requestAnimationFrame=function(t){var n=Date.now(),e=Math.max(i+16,n);return setTimeout(function(){t(i=e)},e-n)},window.cancelAnimationFrame=clearTimeout}window.performance&&window.performance.now||(window.performance={start:Date.now(),now:function(){return Date.now()-this.start}})}(),Function.prototype.bind||(Function.prototype.bind=function(t){if("function"!=typeof this)throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable");var n=Array.prototype.slice.call(arguments,1),e=this,i=function(){},r=function(){return e.apply(this instanceof i?this:t,n.concat(Array.prototype.slice.call(arguments)))};return this.prototype&&(i.prototype=this.prototype),r.prototype=new i,r})},function(t,n,e){"use strict";function i(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}function r(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function o(t){return r(void 0!==t.constructor.name?t.constructor.name:t.className)}e.d(n,"a",function(){return c});var a=e(0),u=(e.n(a),e(1)),s=function(){function t(t,n){for(var e=0;e<n.length;e++){var i=n[e];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}return function(n,e,i){return e&&t(n.prototype,e),i&&t(n,i),n}}(),c=function(){function t(n,r){i(this,t),this._setup(n,r);var a=o(this);this.uuid=e.i(u.b)(6,a),this.$element.attr("data-"+a)||this.$element.attr("data-"+a,this.uuid),this.$element.data("zfPlugin")||this.$element.data("zfPlugin",this),this.$element.trigger("init.zf."+a)}return s(t,[{key:"destroy",value:function(){this._destroy();var t=o(this);this.$element.removeAttr("data-"+t).removeData("zfPlugin").trigger("destroyed.zf."+t);for(var n in this)this[n]=null}}]),t}()},function(t,n,e){"use strict";function i(t){var n={};return"string"!=typeof t?n:(t=t.trim().slice(1,-1))?n=t.split("&").reduce(function(t,n){var e=n.replace(/\+/g," ").split("="),i=e[0],r=e[1];return i=decodeURIComponent(i),r=void 0===r?null:decodeURIComponent(r),t.hasOwnProperty(i)?Array.isArray(t[i])?t[i].push(r):t[i]=[t[i],r]:t[i]=r,t},{}):n}e.d(n,"a",function(){return u});var r=e(0),o=e.n(r),a=window.matchMedia||function(){var t=window.styleMedia||window.media;if(!t){var n=document.createElement("style"),e=document.getElementsByTagName("script")[0],i=null;n.type="text/css",n.id="matchmediajs-test",e&&e.parentNode&&e.parentNode.insertBefore(n,e),i="getComputedStyle"in window&&window.getComputedStyle(n,null)||n.currentStyle,t={matchMedium:function(t){var e="@media "+t+"{ #matchmediajs-test { width: 1px; } }";return n.styleSheet?n.styleSheet.cssText=e:n.textContent=e,"1px"===i.width}}}return function(n){return{matches:t.matchMedium(n||"all"),media:n||"all"}}}(),u={queries:[],current:"",_init:function(){var t=this;o()("meta.foundation-mq").length||o()('<meta class="foundation-mq">').appendTo(document.head);var n,e=o()(".foundation-mq").css("font-family");n=i(e);for(var r in n)n.hasOwnProperty(r)&&t.queries.push({name:r,value:"only screen and (min-width: "+n[r]+")"});this.current=this._getCurrentSize(),this._watcher()},atLeast:function(t){var n=this.get(t);return!!n&&a(n).matches},is:function(t){return t=t.trim().split(" "),t.length>1&&"only"===t[1]?t[0]===this._getCurrentSize():this.atLeast(t[0])},get:function(t){for(var n in this.queries)if(this.queries.hasOwnProperty(n)){var e=this.queries[n];if(t===e.name)return e.value}return null},_getCurrentSize:function(){for(var t,n=0;n<this.queries.length;n++){var e=this.queries[n];a(e.value).matches&&(t=e)}return"object"==typeof t?t.name:t},_watcher:function(){var t=this;o()(window).off("resize.zf.mediaquery").on("resize.zf.mediaquery",function(){var n=t._getCurrentSize(),e=t.current;n!==e&&(t.current=n,o()(window).trigger("changed.zf.mediaquery",[n,e]))})}}},function(t,n,e){t.exports=e(2)}]);
\ No newline at end of file
+!function(t,n){"object"==typeof exports&&"object"==typeof module?module.exports=n(require("jquery")):"function"==typeof define&&define.amd?define(["jquery"],n):"object"==typeof exports?exports["foundation.core"]=n(require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.core"]=n(t.jQuery))}(window,function(e){return function(e){var o={};function r(t){if(o[t])return o[t].exports;var n=o[t]={i:t,l:!1,exports:{}};return e[t].call(n.exports,n,n.exports,r),n.l=!0,n.exports}return r.m=e,r.c=o,r.d=function(t,n,e){r.o(t,n)||Object.defineProperty(t,n,{enumerable:!0,get:e})},r.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},r.t=function(n,t){if(1&t&&(n=r(n)),8&t)return n;if(4&t&&"object"==typeof n&&n&&n.__esModule)return n;var e=Object.create(null);if(r.r(e),Object.defineProperty(e,"default",{enumerable:!0,value:n}),2&t&&"string"!=typeof n)for(var o in n)r.d(e,o,function(t){return n[t]}.bind(null,o));return e},r.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return r.d(n,"a",n),n},r.o=function(t,n){return Object.prototype.hasOwnProperty.call(t,n)},r.p="",r(r.s=0)}({"./js/entries/plugins/foundation.core.js":function(t,n,e){"use strict";e.r(n);var o=e("jquery"),r=e.n(o),i=e("./js/foundation.core.js");e.d(n,"Foundation",function(){return i.Foundation});var a=e("./js/foundation.core.plugin.js"),u=e("./js/foundation.core.utils.js");e.d(n,"Plugin",function(){return a.Plugin}),e.d(n,"rtl",function(){return u.rtl}),e.d(n,"GetYoDigits",function(){return u.GetYoDigits}),e.d(n,"RegExpEscape",function(){return u.RegExpEscape}),e.d(n,"transitionend",function(){return u.transitionend}),e.d(n,"onLoad",function(){return u.onLoad}),e.d(n,"ignoreMousedisappear",function(){return u.ignoreMousedisappear}),i.Foundation.addToJquery(r.a),i.Foundation.Plugin=a.Plugin,i.Foundation.rtl=u.rtl,i.Foundation.GetYoDigits=u.GetYoDigits,i.Foundation.transitionend=u.transitionend,i.Foundation.RegExpEscape=u.RegExpEscape,i.Foundation.onLoad=u.onLoad,window.Foundation=i.Foundation},"./js/foundation.core.js":function(t,n,e){"use strict";e.r(n),e.d(n,"Foundation",function(){return s});var o=e("jquery"),i=e.n(o),r=e("./js/foundation.core.utils.js"),a=e("./js/foundation.util.mediaQuery.js");function u(t){return(u="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var s={version:"6.5.3",_plugins:{},_uuids:[],plugin:function(t,n){var e=n||c(t),o=d(e);this._plugins[o]=this[e]=t},registerPlugin:function(t,n){var e=n?d(n):c(t.constructor).toLowerCase();t.uuid=Object(r.GetYoDigits)(6,e),t.$element.attr("data-".concat(e))||t.$element.attr("data-".concat(e),t.uuid),t.$element.data("zfPlugin")||t.$element.data("zfPlugin",t),t.$element.trigger("init.zf.".concat(e)),this._uuids.push(t.uuid)},unregisterPlugin:function(t){var n=d(c(t.$element.data("zfPlugin").constructor));for(var e in this._uuids.splice(this._uuids.indexOf(t.uuid),1),t.$element.removeAttr("data-".concat(n)).removeData("zfPlugin").trigger("destroyed.zf.".concat(n)),t)t[e]=null},reInit:function(t){var n=t instanceof i.a;try{if(n)t.each(function(){i()(this).data("zfPlugin")._init()});else{var e=u(t),o=this;({object:function(t){t.forEach(function(t){t=d(t),i()("[data-"+t+"]").foundation("_init")})},string:function(){t=d(t),i()("[data-"+t+"]").foundation("_init")},undefined:function(){this.object(Object.keys(o._plugins))}})[e](t)}}catch(t){console.error(t)}finally{return t}},reflow:function(o,t){void 0===t?t=Object.keys(this._plugins):"string"==typeof t&&(t=[t]);var r=this;i.a.each(t,function(t,n){var e=r._plugins[n];i()(o).find("[data-"+n+"]").addBack("[data-"+n+"]").each(function(){var t=i()(this),o={};if(t.data("zfPlugin"))console.warn("Tried to initialize "+n+" on an element that already has a Foundation plugin.");else{if(t.attr("data-options"))t.attr("data-options").split(";").forEach(function(t,n){var e=t.split(":").map(function(t){return t.trim()});e[0]&&(o[e[0]]=function(t){{if("true"===t)return!0;if("false"===t)return!1;if(!isNaN(1*t))return parseFloat(t)}return t}(e[1]))});try{t.data("zfPlugin",new e(i()(this),o))}catch(t){console.error(t)}finally{return}}})})},getFnName:c,addToJquery:function(i){return i.fn.foundation=function(e){var t=u(e),n=i(".no-js");if(n.length&&n.removeClass("no-js"),"undefined"===t)a.MediaQuery._init(),s.reflow(this);else{if("string"!==t)throw new TypeError("We're sorry, ".concat(t," is not a valid parameter. You must use a string representing the method you wish to invoke."));var o=Array.prototype.slice.call(arguments,1),r=this.data("zfPlugin");if(void 0===r||void 0===r[e])throw new ReferenceError("We're sorry, '"+e+"' is not an available method for "+(r?c(r):"this element")+".");1===this.length?r[e].apply(r,o):this.each(function(t,n){r[e].apply(i(n).data("zfPlugin"),o)})}return this},i}};function c(t){if(void 0!==Function.prototype.name)return void 0===t.prototype?t.constructor.name:t.prototype.constructor.name;var n=/function\s([^(]{1,})\(/.exec(t.toString());return n&&1<n.length?n[1].trim():""}function d(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}s.util={throttle:function(e,o){var r=null;return function(){var t=this,n=arguments;null===r&&(r=setTimeout(function(){e.apply(t,n),r=null},o))}}},window.Foundation=s,function(){Date.now&&window.Date.now||(window.Date.now=Date.now=function(){return(new Date).getTime()});for(var t=["webkit","moz"],n=0;n<t.length&&!window.requestAnimationFrame;++n){var e=t[n];window.requestAnimationFrame=window[e+"RequestAnimationFrame"],window.cancelAnimationFrame=window[e+"CancelAnimationFrame"]||window[e+"CancelRequestAnimationFrame"]}if(/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent)||!window.requestAnimationFrame||!window.cancelAnimationFrame){var o=0;window.requestAnimationFrame=function(t){var n=Date.now(),e=Math.max(o+16,n);return setTimeout(function(){t(o=e)},e-n)},window.cancelAnimationFrame=clearTimeout}window.performance&&window.performance.now||(window.performance={start:Date.now(),now:function(){return Date.now()-this.start}})}(),Function.prototype.bind||(Function.prototype.bind=function(t){if("function"!=typeof this)throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable");var n=Array.prototype.slice.call(arguments,1),e=this,o=function(){},r=function(){return e.apply(this instanceof o?this:t,n.concat(Array.prototype.slice.call(arguments)))};return this.prototype&&(o.prototype=this.prototype),r.prototype=new o,r})},"./js/foundation.core.plugin.js":function(t,n,e){"use strict";e.r(n),e.d(n,"Plugin",function(){return o});e("jquery");var r=e("./js/foundation.core.utils.js");function i(t,n){for(var e=0;e<n.length;e++){var o=n[e];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}var o=function(){function o(t,n){!function(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}(this,o),this._setup(t,n);var e=u(this);this.uuid=Object(r.GetYoDigits)(6,e),this.$element.attr("data-".concat(e))||this.$element.attr("data-".concat(e),this.uuid),this.$element.data("zfPlugin")||this.$element.data("zfPlugin",this),this.$element.trigger("init.zf.".concat(e))}var t,n,e;return t=o,(n=[{key:"destroy",value:function(){this._destroy();var t=u(this);for(var n in this.$element.removeAttr("data-".concat(t)).removeData("zfPlugin").trigger("destroyed.zf.".concat(t)),this)this[n]=null}}])&&i(t.prototype,n),e&&i(t,e),o}();function a(t){return t.replace(/([a-z])([A-Z])/g,"$1-$2").toLowerCase()}function u(t){return void 0!==t.constructor.name?a(t.constructor.name):a(t.className)}},"./js/foundation.core.utils.js":function(t,n,e){"use strict";e.r(n),e.d(n,"rtl",function(){return r}),e.d(n,"GetYoDigits",function(){return i}),e.d(n,"RegExpEscape",function(){return a}),e.d(n,"transitionend",function(){return u}),e.d(n,"onLoad",function(){return c}),e.d(n,"ignoreMousedisappear",function(){return d});var o=e("jquery"),s=e.n(o);function r(){return"rtl"===s()("html").attr("dir")}function i(t,n){return t=t||6,Math.round(Math.pow(36,t+1)-Math.random()*Math.pow(36,t)).toString(36).slice(1)+(n?"-".concat(n):"")}function a(t){return t.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&")}function u(t){var n,e={transition:"transitionend",WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"otransitionend"},o=document.createElement("div");for(var r in e)void 0!==o.style[r]&&(n=e[r]);return n||(n=setTimeout(function(){t.triggerHandler("transitionend",[t])},1),"transitionend")}function c(t,n){var e="complete"===document.readyState,o=(e?"_didLoad":"load")+".zf.util.onLoad",r=function(){return t.triggerHandler(o)};return t&&(n&&t.one(o,n),e?setTimeout(r):s()(window).one("load",r)),o}function d(i){var t=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{},n=t.ignoreLeaveWindow,a=void 0!==n&&n,e=t.ignoreReappear,u=void 0!==e&&e;return function(n){for(var t=arguments.length,e=new Array(1<t?t-1:0),o=1;o<t;o++)e[o-1]=arguments[o];var r=i.bind.apply(i,[this,n].concat(e));if(null!==n.relatedTarget)return r();setTimeout(function(){if(!a&&document.hasFocus&&!document.hasFocus())return r();u||s()(document).one("mouseenter",function(t){s()(n.currentTarget).has(t.target).length||(n.relatedTarget=t.target,r())})},0)}}},"./js/foundation.util.mediaQuery.js":function(t,n,e){"use strict";e.r(n),e.d(n,"MediaQuery",function(){return a});var o=e("jquery"),i=e.n(o);function r(t){return(r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}window.matchMedia||(window.matchMedia=function(){var n=window.styleMedia||window.media;if(!n){var e,o=document.createElement("style"),t=document.getElementsByTagName("script")[0];o.type="text/css",o.id="matchmediajs-test",t?t.parentNode.insertBefore(o,t):document.head.appendChild(o),e="getComputedStyle"in window&&window.getComputedStyle(o,null)||o.currentStyle,n={matchMedium:function(t){var n="@media "+t+"{ #matchmediajs-test { width: 1px; } }";return o.styleSheet?o.styleSheet.cssText=n:o.textContent=n,"1px"===e.width}}}return function(t){return{matches:n.matchMedium(t||"all"),media:t||"all"}}}());var a={queries:[],current:"",_init:function(){i()("meta.foundation-mq").length||i()('<meta class="foundation-mq">').appendTo(document.head);var t,n,e,o=i()(".foundation-mq").css("font-family");for(var r in e={},t="string"==typeof(n=o)&&(n=n.trim().slice(1,-1))?e=n.split("&").reduce(function(t,n){var e=n.replace(/\+/g," ").split("="),o=e[0],r=e[1];return o=decodeURIComponent(o),r=void 0===r?null:decodeURIComponent(r),t.hasOwnProperty(o)?Array.isArray(t[o])?t[o].push(r):t[o]=[t[o],r]:t[o]=r,t},{}):e)t.hasOwnProperty(r)&&this.queries.push({name:r,value:"only screen and (min-width: ".concat(t[r],")")});this.current=this._getCurrentSize(),this._watcher()},atLeast:function(t){var n=this.get(t);return!!n&&window.matchMedia(n).matches},is:function(t){return 1<(t=t.trim().split(" ")).length&&"only"===t[1]?t[0]===this._getCurrentSize():this.atLeast(t[0])},get:function(t){for(var n in this.queries)if(this.queries.hasOwnProperty(n)){var e=this.queries[n];if(t===e.name)return e.value}return null},_getCurrentSize:function(){for(var t,n=0;n<this.queries.length;n++){var e=this.queries[n];window.matchMedia(e.value).matches&&(t=e)}return"object"===r(t)?t.name:t},_watcher:function(){var e=this;i()(window).off("resize.zf.mediaquery").on("resize.zf.mediaquery",function(){var t=e._getCurrentSize(),n=e.current;t!==n&&(e.current=t,i()(window).trigger("changed.zf.mediaquery",[t,n]))})}}},0:function(t,n,e){t.exports=e("./js/entries/plugins/foundation.core.js")},jquery:function(t,n){t.exports=e}})});
+//# sourceMappingURL=foundation.core.min.js.map
diff --git a/dist/js/plugins/foundation.core.min.js.map b/dist/js/plugins/foundation.core.min.js.map
new file mode 100644 (file)
index 0000000..845ee9d
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.core.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./js/entries/plugins/foundation.core.js","__webpack_exports__","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core__WEBPACK_IMPORTED_MODULE_1__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__","addToJquery","a","Plugin","rtl","GetYoDigits","transitionend","RegExpEscape","onLoad","Foundation","./js/foundation.core.js","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__","_typeof","obj","iterator","constructor","version","_plugins","_uuids","plugin","_plugin","className","functionName","attrName","hyphenate","this","registerPlugin","pluginName","toLowerCase","uuid","$element","attr","concat","data","trigger","push","unregisterPlugin","prop","splice","indexOf","removeAttr","removeData","reInit","plugins","isJQ","each","_init","type","_this","plgs","forEach","foundation","string","undefined","keys","err","console","error","reflow","elem","find","addBack","$el","opts","warn","split","e","opt","map","el","trim","str","isNaN","parseFloat","parseValue","er","getFnName","$","fn","method","$noJS","length","removeClass","TypeError","args","Array","slice","arguments","plugClass","ReferenceError","apply","Function","results","exec","toString","replace","util","throttle","func","delay","timer","context","setTimeout","Date","now","getTime","vendors","requestAnimationFrame","vp","cancelAnimationFrame","test","navigator","userAgent","lastTime","callback","nextTime","Math","max","clearTimeout","performance","start","oThis","aArgs","fToBind","fNOP","fBound","./js/foundation.core.plugin.js","_defineProperties","target","props","descriptor","configurable","writable","element","options","instance","Constructor","_classCallCheck","_setup","getPluginName","protoProps","staticProps","_destroy","./js/foundation.core.utils.js","ignoreMousedisappear","namespace","round","pow","random","$elem","end","transitions","transition","WebkitTransition","MozTransition","OTransition","document","createElement","style","triggerHandler","handler","didLoad","readyState","eventType","cb","one","_ref","_ref$ignoreLeaveWindo","ignoreLeaveWindow","_ref$ignoreReappear","ignoreReappear","eLeave","_len","rest","_key","relatedTarget","hasFocus","eReenter","currentTarget","has","./js/foundation.util.mediaQuery.js","MediaQuery","matchMedia","styleMedia","media","info","script","getElementsByTagName","id","parentNode","insertBefore","head","appendChild","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","matches","queries","current","appendTo","namedQueries","styleObject","extractedStyles","css","reduce","ret","param","parts","val","decodeURIComponent","isArray","_getCurrentSize","_watcher","atLeast","size","query","is","matched","off","on","newSize","currentSize","0","jquery"],"mappings":"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","file":"foundation.core.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.core\"] = factory(require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"] = factory(root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 0);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./js/entries/plugins/foundation.core.js\":\n/*!***********************************************!*\\\n  !*** ./js/entries/plugins/foundation.core.js ***!\n  \\***********************************************/\n/*! exports provided: Foundation, Plugin, rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.core */ \"./js/foundation.core.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../foundation.core.plugin */ \"./js/foundation.core.plugin.js\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Plugin\", function() { return _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"rtl\", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"rtl\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"GetYoDigits\", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"RegExpEscape\", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"RegExpEscape\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"transitionend\", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"onLoad\", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"onLoad\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ignoreMousedisappear\", function() { return _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"ignoreMousedisappear\"]; });\n\n// --- Foundation Core API ---\n// Initialize Foundation and add some utilities to its public API for backward compatibility.\n// Please note that every utility do not have to be added to the core API.\n\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].addToJquery(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Every plugin depends on plugin now, we can include that on the core for the\n// script inclusion path.\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].Plugin = _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]; // These are now separated out, but historically were a part of this module,\n// and since this is here for backwards compatibility we include them in\n// this entry.\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].rtl = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"rtl\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].GetYoDigits = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].transitionend = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].RegExpEscape = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"RegExpEscape\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"].onLoad = _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"onLoad\"];\nwindow.Foundation = _foundation_core__WEBPACK_IMPORTED_MODULE_1__[\"Foundation\"]; // --- Foundation Core exports ---\n// Export \"Plugin\" and all core utilities, since the `foundation.core` entry plays the role of\n// all core source files.\n\n\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.core.js\":\n/*!*******************************!*\\\n  !*** ./js/foundation.core.js ***!\n  \\*******************************/\n/*! exports provided: Foundation */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return Foundation; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\nvar FOUNDATION_VERSION = '6.5.3'; // Global Foundation object\n// This is attached to the window, or used as a module for AMD/Browserify\n\nvar Foundation = {\n  version: FOUNDATION_VERSION,\n\n  /**\n   * Stores initialized plugins.\n   */\n  _plugins: {},\n\n  /**\n   * Stores generated unique ids for plugin instances\n   */\n  _uuids: [],\n\n  /**\n   * Defines a Foundation plugin, adding it to the `Foundation` namespace and the list of plugins to initialize when reflowing.\n   * @param {Object} plugin - The constructor of the plugin.\n   */\n  plugin: function plugin(_plugin, name) {\n    // Object key to use when adding to global Foundation object\n    // Examples: Foundation.Reveal, Foundation.OffCanvas\n    var className = name || functionName(_plugin); // Object key to use when storing the plugin, also used to create the identifying data attribute for the plugin\n    // Examples: data-reveal, data-off-canvas\n\n    var attrName = hyphenate(className); // Add to the Foundation object and the plugins list (for reflowing)\n\n    this._plugins[attrName] = this[className] = _plugin;\n  },\n\n  /**\n   * @function\n   * Populates the _uuids array with pointers to each individual plugin instance.\n   * Adds the `zfPlugin` data-attribute to programmatically created plugins to allow use of $(selector).foundation(method) calls.\n   * Also fires the initialization event for each plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @param {String} name - the name of the plugin, passed as a camelCased string.\n   * @fires Plugin#init\n   */\n  registerPlugin: function registerPlugin(plugin, name) {\n    var pluginName = name ? hyphenate(name) : functionName(plugin.constructor).toLowerCase();\n    plugin.uuid = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, pluginName);\n\n    if (!plugin.$element.attr(\"data-\".concat(pluginName))) {\n      plugin.$element.attr(\"data-\".concat(pluginName), plugin.uuid);\n    }\n\n    if (!plugin.$element.data('zfPlugin')) {\n      plugin.$element.data('zfPlugin', plugin);\n    }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n\n\n    plugin.$element.trigger(\"init.zf.\".concat(pluginName));\n\n    this._uuids.push(plugin.uuid);\n\n    return;\n  },\n\n  /**\n   * @function\n   * Removes the plugins uuid from the _uuids array.\n   * Removes the zfPlugin data attribute, as well as the data-plugin-name attribute.\n   * Also fires the destroyed event for the plugin, consolidating repetitive code.\n   * @param {Object} plugin - an instance of a plugin, usually `this` in context.\n   * @fires Plugin#destroyed\n   */\n  unregisterPlugin: function unregisterPlugin(plugin) {\n    var pluginName = hyphenate(functionName(plugin.$element.data('zfPlugin').constructor));\n\n    this._uuids.splice(this._uuids.indexOf(plugin.uuid), 1);\n\n    plugin.$element.removeAttr(\"data-\".concat(pluginName)).removeData('zfPlugin')\n    /**\n     * Fires when the plugin has been destroyed.\n     * @event Plugin#destroyed\n     */\n    .trigger(\"destroyed.zf.\".concat(pluginName));\n\n    for (var prop in plugin) {\n      plugin[prop] = null; //clean up script to prep for garbage collection.\n    }\n\n    return;\n  },\n\n  /**\n   * @function\n   * Causes one or more active plugins to re-initialize, resetting event listeners, recalculating positions, etc.\n   * @param {String} plugins - optional string of an individual plugin key, attained by calling `$(element).data('pluginName')`, or string of a plugin class i.e. `'dropdown'`\n   * @default If no argument is passed, reflow all currently active plugins.\n   */\n  reInit: function reInit(plugins) {\n    var isJQ = plugins instanceof jquery__WEBPACK_IMPORTED_MODULE_0___default.a;\n\n    try {\n      if (isJQ) {\n        plugins.each(function () {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('zfPlugin')._init();\n        });\n      } else {\n        var type = _typeof(plugins),\n            _this = this,\n            fns = {\n          'object': function object(plgs) {\n            plgs.forEach(function (p) {\n              p = hyphenate(p);\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + p + ']').foundation('_init');\n            });\n          },\n          'string': function string() {\n            plugins = hyphenate(plugins);\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-' + plugins + ']').foundation('_init');\n          },\n          'undefined': function undefined() {\n            this['object'](Object.keys(_this._plugins));\n          }\n        };\n\n        fns[type](plugins);\n      }\n    } catch (err) {\n      console.error(err);\n    } finally {\n      return plugins;\n    }\n  },\n\n  /**\n   * Initialize plugins on any elements within `elem` (and `elem` itself) that aren't already initialized.\n   * @param {Object} elem - jQuery object containing the element to check inside. Also checks the element itself, unless it's the `document` object.\n   * @param {String|Array} plugins - A list of plugins to initialize. Leave this out to initialize everything.\n   */\n  reflow: function reflow(elem, plugins) {\n    // If plugins is undefined, just grab everything\n    if (typeof plugins === 'undefined') {\n      plugins = Object.keys(this._plugins);\n    } // If plugins is a string, convert it to an array with one item\n    else if (typeof plugins === 'string') {\n        plugins = [plugins];\n      }\n\n    var _this = this; // Iterate through each plugin\n\n\n    jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(plugins, function (i, name) {\n      // Get the current plugin\n      var plugin = _this._plugins[name]; // Localize the search to all elements inside elem, as well as elem itself, unless elem === document\n\n      var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(elem).find('[data-' + name + ']').addBack('[data-' + name + ']'); // For each plugin found, initialize it\n\n      $elem.each(function () {\n        var $el = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            opts = {}; // Don't double-dip on plugins\n\n        if ($el.data('zfPlugin')) {\n          console.warn(\"Tried to initialize \" + name + \" on an element that already has a Foundation plugin.\");\n          return;\n        }\n\n        if ($el.attr('data-options')) {\n          var thing = $el.attr('data-options').split(';').forEach(function (e, i) {\n            var opt = e.split(':').map(function (el) {\n              return el.trim();\n            });\n            if (opt[0]) opts[opt[0]] = parseValue(opt[1]);\n          });\n        }\n\n        try {\n          $el.data('zfPlugin', new plugin(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), opts));\n        } catch (er) {\n          console.error(er);\n        } finally {\n          return;\n        }\n      });\n    });\n  },\n  getFnName: functionName,\n  addToJquery: function addToJquery($) {\n    // TODO: consider not making this a jQuery function\n    // TODO: need way to reflow vs. re-initialize\n\n    /**\n     * The Foundation jQuery method.\n     * @param {String|Array} method - An action to perform on the current jQuery object.\n     */\n    var foundation = function foundation(method) {\n      var type = _typeof(method),\n          $noJS = $('.no-js');\n\n      if ($noJS.length) {\n        $noJS.removeClass('no-js');\n      }\n\n      if (type === 'undefined') {\n        //needs to initialize the Foundation object, or an individual plugin.\n        _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"]._init();\n\n        Foundation.reflow(this);\n      } else if (type === 'string') {\n        //an individual method to invoke on a plugin or group of plugins\n        var args = Array.prototype.slice.call(arguments, 1); //collect all the arguments, if necessary\n\n        var plugClass = this.data('zfPlugin'); //determine the class of plugin\n\n        if (typeof plugClass !== 'undefined' && typeof plugClass[method] !== 'undefined') {\n          //make sure both the class and method exist\n          if (this.length === 1) {\n            //if there's only one, call it directly.\n            plugClass[method].apply(plugClass, args);\n          } else {\n            this.each(function (i, el) {\n              //otherwise loop through the jQuery collection and invoke the method on each\n              plugClass[method].apply($(el).data('zfPlugin'), args);\n            });\n          }\n        } else {\n          //error for no class or no method\n          throw new ReferenceError(\"We're sorry, '\" + method + \"' is not an available method for \" + (plugClass ? functionName(plugClass) : 'this element') + '.');\n        }\n      } else {\n        //error for invalid argument type\n        throw new TypeError(\"We're sorry, \".concat(type, \" is not a valid parameter. You must use a string representing the method you wish to invoke.\"));\n      }\n\n      return this;\n    };\n\n    $.fn.foundation = foundation;\n    return $;\n  }\n};\nFoundation.util = {\n  /**\n   * Function for applying a debounce effect to a function call.\n   * @function\n   * @param {Function} func - Function to be called at end of timeout.\n   * @param {Number} delay - Time in ms to delay the call of `func`.\n   * @returns function\n   */\n  throttle: function throttle(func, delay) {\n    var timer = null;\n    return function () {\n      var context = this,\n          args = arguments;\n\n      if (timer === null) {\n        timer = setTimeout(function () {\n          func.apply(context, args);\n          timer = null;\n        }, delay);\n      }\n    };\n  }\n};\nwindow.Foundation = Foundation; // Polyfill for requestAnimationFrame\n\n(function () {\n  if (!Date.now || !window.Date.now) window.Date.now = Date.now = function () {\n    return new Date().getTime();\n  };\n  var vendors = ['webkit', 'moz'];\n\n  for (var i = 0; i < vendors.length && !window.requestAnimationFrame; ++i) {\n    var vp = vendors[i];\n    window.requestAnimationFrame = window[vp + 'RequestAnimationFrame'];\n    window.cancelAnimationFrame = window[vp + 'CancelAnimationFrame'] || window[vp + 'CancelRequestAnimationFrame'];\n  }\n\n  if (/iP(ad|hone|od).*OS 6/.test(window.navigator.userAgent) || !window.requestAnimationFrame || !window.cancelAnimationFrame) {\n    var lastTime = 0;\n\n    window.requestAnimationFrame = function (callback) {\n      var now = Date.now();\n      var nextTime = Math.max(lastTime + 16, now);\n      return setTimeout(function () {\n        callback(lastTime = nextTime);\n      }, nextTime - now);\n    };\n\n    window.cancelAnimationFrame = clearTimeout;\n  }\n  /**\n   * Polyfill for performance.now, required by rAF\n   */\n\n\n  if (!window.performance || !window.performance.now) {\n    window.performance = {\n      start: Date.now(),\n      now: function now() {\n        return Date.now() - this.start;\n      }\n    };\n  }\n})();\n\nif (!Function.prototype.bind) {\n  Function.prototype.bind = function (oThis) {\n    if (typeof this !== 'function') {\n      // closest thing possible to the ECMAScript 5\n      // internal IsCallable function\n      throw new TypeError('Function.prototype.bind - what is trying to be bound is not callable');\n    }\n\n    var aArgs = Array.prototype.slice.call(arguments, 1),\n        fToBind = this,\n        fNOP = function fNOP() {},\n        fBound = function fBound() {\n      return fToBind.apply(this instanceof fNOP ? this : oThis, aArgs.concat(Array.prototype.slice.call(arguments)));\n    };\n\n    if (this.prototype) {\n      // native functions don't have a prototype\n      fNOP.prototype = this.prototype;\n    }\n\n    fBound.prototype = new fNOP();\n    return fBound;\n  };\n} // Polyfill to get the name of a function in IE9\n\n\nfunction functionName(fn) {\n  if (typeof Function.prototype.name === 'undefined') {\n    var funcNameRegex = /function\\s([^(]{1,})\\(/;\n    var results = funcNameRegex.exec(fn.toString());\n    return results && results.length > 1 ? results[1].trim() : \"\";\n  } else if (typeof fn.prototype === 'undefined') {\n    return fn.constructor.name;\n  } else {\n    return fn.prototype.constructor.name;\n  }\n}\n\nfunction parseValue(str) {\n  if ('true' === str) return true;else if ('false' === str) return false;else if (!isNaN(str * 1)) return parseFloat(str);\n  return str;\n} // Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\n\n\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.core.plugin.js\":\n/*!**************************************!*\\\n  !*** ./js/foundation.core.plugin.js ***!\n  \\**************************************/\n/*! exports provided: Plugin */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Plugin\", function() { return Plugin; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./js/foundation.core.utils.js\");\n\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\n\n // Abstract class for providing lifecycle hooks. Expect plugins to define AT LEAST\n// {function} _setup (replaces previous constructor),\n// {function} _destroy (replaces previous destroy)\n\nvar Plugin =\n/*#__PURE__*/\nfunction () {\n  function Plugin(element, options) {\n    _classCallCheck(this, Plugin);\n\n    this._setup(element, options);\n\n    var pluginName = getPluginName(this);\n    this.uuid = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, pluginName);\n\n    if (!this.$element.attr(\"data-\".concat(pluginName))) {\n      this.$element.attr(\"data-\".concat(pluginName), this.uuid);\n    }\n\n    if (!this.$element.data('zfPlugin')) {\n      this.$element.data('zfPlugin', this);\n    }\n    /**\n     * Fires when the plugin has initialized.\n     * @event Plugin#init\n     */\n\n\n    this.$element.trigger(\"init.zf.\".concat(pluginName));\n  }\n\n  _createClass(Plugin, [{\n    key: \"destroy\",\n    value: function destroy() {\n      this._destroy();\n\n      var pluginName = getPluginName(this);\n      this.$element.removeAttr(\"data-\".concat(pluginName)).removeData('zfPlugin')\n      /**\n       * Fires when the plugin has been destroyed.\n       * @event Plugin#destroyed\n       */\n      .trigger(\"destroyed.zf.\".concat(pluginName));\n\n      for (var prop in this) {\n        this[prop] = null; //clean up script to prep for garbage collection.\n      }\n    }\n  }]);\n\n  return Plugin;\n}(); // Convert PascalCase to kebab-case\n// Thank you: http://stackoverflow.com/a/8955580\n\n\nfunction hyphenate(str) {\n  return str.replace(/([a-z])([A-Z])/g, '$1-$2').toLowerCase();\n}\n\nfunction getPluginName(obj) {\n  if (typeof obj.constructor.name !== 'undefined') {\n    return hyphenate(obj.constructor.name);\n  } else {\n    return hyphenate(obj.className);\n  }\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.core.utils.js\":\n/*!*************************************!*\\\n  !*** ./js/foundation.core.utils.js ***!\n  \\*************************************/\n/*! exports provided: rtl, GetYoDigits, RegExpEscape, transitionend, onLoad, ignoreMousedisappear */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"rtl\", function() { return rtl; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"GetYoDigits\", function() { return GetYoDigits; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"RegExpEscape\", function() { return RegExpEscape; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"transitionend\", function() { return transitionend; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"onLoad\", function() { return onLoad; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ignoreMousedisappear\", function() { return ignoreMousedisappear; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\n // Core Foundation Utilities, utilized in a number of places.\n\n/**\n * Returns a boolean for RTL support\n */\n\nfunction rtl() {\n  return jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').attr('dir') === 'rtl';\n}\n/**\n * returns a random base-36 uid with namespacing\n * @function\n * @param {Number} length - number of random base-36 digits desired. Increase for more random strings.\n * @param {String} namespace - name of plugin to be incorporated in uid, optional.\n * @default {String} '' - if no plugin name is provided, nothing is appended to the uid.\n * @returns {String} - unique id\n */\n\n\nfunction GetYoDigits(length, namespace) {\n  length = length || 6;\n  return Math.round(Math.pow(36, length + 1) - Math.random() * Math.pow(36, length)).toString(36).slice(1) + (namespace ? \"-\".concat(namespace) : '');\n}\n/**\n * Escape a string so it can be used as a regexp pattern\n * @function\n * @see https://stackoverflow.com/a/9310752/4317384\n *\n * @param {String} str - string to escape.\n * @returns {String} - escaped string\n */\n\n\nfunction RegExpEscape(str) {\n  return str.replace(/[-[\\]{}()*+?.,\\\\^$|#\\s]/g, '\\\\$&');\n}\n\nfunction transitionend($elem) {\n  var transitions = {\n    'transition': 'transitionend',\n    'WebkitTransition': 'webkitTransitionEnd',\n    'MozTransition': 'transitionend',\n    'OTransition': 'otransitionend'\n  };\n  var elem = document.createElement('div'),\n      end;\n\n  for (var t in transitions) {\n    if (typeof elem.style[t] !== 'undefined') {\n      end = transitions[t];\n    }\n  }\n\n  if (end) {\n    return end;\n  } else {\n    end = setTimeout(function () {\n      $elem.triggerHandler('transitionend', [$elem]);\n    }, 1);\n    return 'transitionend';\n  }\n}\n/**\n * Return an event type to listen for window load.\n *\n * If `$elem` is passed, an event will be triggered on `$elem`. If window is already loaded, the event will still be triggered.\n * If `handler` is passed, attach it to the event on `$elem`.\n * Calling `onLoad` without handler allows you to get the event type that will be triggered before attaching the handler by yourself.\n * @function\n *\n * @param {Object} [] $elem - jQuery element on which the event will be triggered if passed.\n * @param {Function} [] handler - function to attach to the event.\n * @returns {String} - event type that should or will be triggered.\n */\n\n\nfunction onLoad($elem, handler) {\n  var didLoad = document.readyState === 'complete';\n  var eventType = (didLoad ? '_didLoad' : 'load') + '.zf.util.onLoad';\n\n  var cb = function cb() {\n    return $elem.triggerHandler(eventType);\n  };\n\n  if ($elem) {\n    if (handler) $elem.one(eventType, handler);\n    if (didLoad) setTimeout(cb);else jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', cb);\n  }\n\n  return eventType;\n}\n/**\n * Retuns an handler for the `mouseleave` that ignore disappeared mouses.\n *\n * If the mouse \"disappeared\" from the document (like when going on a browser UI element, See https://git.io/zf-11410),\n * the event is ignored.\n * - If the `ignoreLeaveWindow` is `true`, the event is ignored when the user actually left the window\n *   (like by switching to an other window with [Alt]+[Tab]).\n * - If the `ignoreReappear` is `true`, the event will be ignored when the mouse will reappear later on the document\n *   outside of the element it left.\n *\n * @function\n *\n * @param {Function} [] handler - handler for the filtered `mouseleave` event to watch.\n * @param {Object} [] options - object of options:\n * - {Boolean} [false] ignoreLeaveWindow - also ignore when the user switched windows.\n * - {Boolean} [false] ignoreReappear - also ignore when the mouse reappeared outside of the element it left.\n * @returns {Function} - filtered handler to use to listen on the `mouseleave` event.\n */\n\n\nfunction ignoreMousedisappear(handler) {\n  var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},\n      _ref$ignoreLeaveWindo = _ref.ignoreLeaveWindow,\n      ignoreLeaveWindow = _ref$ignoreLeaveWindo === void 0 ? false : _ref$ignoreLeaveWindo,\n      _ref$ignoreReappear = _ref.ignoreReappear,\n      ignoreReappear = _ref$ignoreReappear === void 0 ? false : _ref$ignoreReappear;\n\n  return function leaveEventHandler(eLeave) {\n    for (var _len = arguments.length, rest = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {\n      rest[_key - 1] = arguments[_key];\n    }\n\n    var callback = handler.bind.apply(handler, [this, eLeave].concat(rest)); // The mouse left: call the given callback if the mouse entered elsewhere\n\n    if (eLeave.relatedTarget !== null) {\n      return callback();\n    } // Otherwise, check if the mouse actually left the window.\n    // In firefox if the user switched between windows, the window sill have the focus by the time\n    // the event is triggered. We have to debounce the event to test this case.\n\n\n    setTimeout(function leaveEventDebouncer() {\n      if (!ignoreLeaveWindow && document.hasFocus && !document.hasFocus()) {\n        return callback();\n      } // Otherwise, wait for the mouse to reeapear outside of the element,\n\n\n      if (!ignoreReappear) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).one('mouseenter', function reenterEventHandler(eReenter) {\n          if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(eLeave.currentTarget).has(eReenter.target).length) {\n            // Fill where the mouse finally entered.\n            eLeave.relatedTarget = eReenter.target;\n            callback();\n          }\n        });\n      }\n    }, 0);\n  };\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.mediaQuery.js\":\n/*!******************************************!*\\\n  !*** ./js/foundation.util.mediaQuery.js ***!\n  \\******************************************/\n/*! exports provided: MediaQuery */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"MediaQuery\", function() { return MediaQuery; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n // Default set of media queries\n\nvar defaultQueries = {\n  'default': 'only screen',\n  landscape: 'only screen and (orientation: landscape)',\n  portrait: 'only screen and (orientation: portrait)',\n  retina: 'only screen and (-webkit-min-device-pixel-ratio: 2),' + 'only screen and (min--moz-device-pixel-ratio: 2),' + 'only screen and (-o-min-device-pixel-ratio: 2/1),' + 'only screen and (min-device-pixel-ratio: 2),' + 'only screen and (min-resolution: 192dpi),' + 'only screen and (min-resolution: 2dppx)'\n}; // matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n\n/* eslint-disable */\n\nwindow.matchMedia || (window.matchMedia = function () {\n  \"use strict\"; // For browsers that support matchMedium api such as IE 9 and webkit\n\n  var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium\n\n  if (!styleMedia) {\n    var style = document.createElement('style'),\n        script = document.getElementsByTagName('script')[0],\n        info = null;\n    style.type = 'text/css';\n    style.id = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n\n\n    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;\n    styleMedia = {\n      matchMedium: function matchMedium(media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        } // Test if media query is true or false\n\n\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function (media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n}());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init: function _init() {\n    var self = this;\n    var $meta = jquery__WEBPACK_IMPORTED_MODULE_0___default()('meta.foundation-mq');\n\n    if (!$meta.length) {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = jquery__WEBPACK_IMPORTED_MODULE_0___default()('.foundation-mq').css('font-family');\n    var namedQueries;\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if (namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: \"only screen and (min-width: \".concat(namedQueries[key], \")\")\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast: function atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is: function is(size) {\n    size = size.trim().split(' ');\n\n    if (size.length > 1 && size[1] === 'only') {\n      if (size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get: function get(size) {\n    for (var i in this.queries) {\n      if (this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize: function _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (_typeof(matched) === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher: function _watcher() {\n    var _this = this;\n\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {\n      var newSize = _this._getCurrentSize(),\n          currentSize = _this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        _this.current = newSize; // Broadcast the media query change on the window\n\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n}; // Thank you: https://github.com/sindresorhus/query-string\n\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function (ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key); // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n\n    return ret;\n  }, {});\n  return styleObject;\n}\n\n\n\n/***/ }),\n\n/***/ 0:\n/*!*****************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.core.js ***!\n  \\*****************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.core.js */\"./js/entries/plugins/foundation.core.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.core.js.map"]}
\ No newline at end of file
index a8aae3c3247fdf845903ea8e6913fe80069eb6a1..eda71c12050b331b0f6cfb0078c35b17ba50e9ee 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.box"), require("./foundation.util.keyboard"), require("./foundation.util.nest"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.box", "./foundation.util.keyboard", "./foundation.util.nest", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.drilldown"] = factory(require("./foundation.core"), require("./foundation.util.box"), require("./foundation.util.keyboard"), require("./foundation.util.nest"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.drilldown"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.box"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.nest"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 82);
+/******/       return __webpack_require__(__webpack_require__.s = 3);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.box":
+/*!********************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.box"],"amd":"./foundation.util.box","commonjs":"./foundation.util.box","commonjs2":"./foundation.util.box"} ***!
+  \********************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;
 
 /***/ }),
 
-/***/ 16:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_drilldown__ = __webpack_require__(46);
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
+/***/ }),
 
+/***/ "./foundation.util.nest":
+/*!************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.nest"],"amd":"./foundation.util.nest","commonjs":"./foundation.util.nest","commonjs2":"./foundation.util.nest"} ***!
+  \************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_drilldown__["a" /* Drilldown */], 'Drilldown');
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;
 
 /***/ }),
 
-/***/ 2:
-/***/ (function(module, exports) {
+/***/ "./js/entries/plugins/foundation.drilldown.js":
+/*!****************************************************!*\
+  !*** ./js/entries/plugins/foundation.drilldown.js ***!
+  \****************************************************/
+/*! exports provided: Foundation, Drilldown */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-/***/ }),
+/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.drilldown */ "./js/foundation.drilldown.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Drilldown", function() { return _foundation_drilldown__WEBPACK_IMPORTED_MODULE_1__["Drilldown"]; });
 
-/***/ 3:
-/***/ (function(module, exports) {
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
+
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_drilldown__WEBPACK_IMPORTED_MODULE_1__["Drilldown"], 'Drilldown');
+
 
 /***/ }),
 
-/***/ 46:
+/***/ "./js/foundation.drilldown.js":
+/*!************************************!*\
+  !*** ./js/foundation.drilldown.js ***!
+  \************************************/
+/*! exports provided: Drilldown */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Drilldown; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__ = __webpack_require__(9);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_box__ = __webpack_require__(8);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_box___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_util_box__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__foundation_plugin__);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Drilldown", function() { return Drilldown; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.nest */ "./foundation.util.nest");
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__);
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.box */ "./foundation.util.box");
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_box__WEBPACK_IMPORTED_MODULE_4__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(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 _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -153,17 +217,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.box
  */
 
-var Drilldown = function (_Plugin) {
+var Drilldown =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Drilldown, _Plugin);
 
   function Drilldown() {
     _classCallCheck(this, Drilldown);
 
-    return _possibleConstructorReturn(this, (Drilldown.__proto__ || Object.getPrototypeOf(Drilldown)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Drilldown).apply(this, arguments));
   }
 
   _createClass(Drilldown, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of a drilldown menu.
@@ -174,12 +240,12 @@ var Drilldown = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Drilldown.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Drilldown.defaults, this.$element.data(), options);
       this.className = 'Drilldown'; // ie9 back compat
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('Drilldown', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('Drilldown', {
         'ENTER': 'open',
         'SPACE': 'open',
         'ARROW_RIGHT': 'next',
@@ -191,16 +257,15 @@ var Drilldown = function (_Plugin) {
         'SHIFT_TAB': 'up'
       });
     }
-
     /**
      * Initializes the drilldown by creating jQuery collections of elements
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["Nest"].Feather(this.$element, 'drilldown');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__["Nest"].Feather(this.$element, 'drilldown');
 
       if (this.options.autoApplyClass) {
         this.$element.addClass('drilldown');
@@ -212,15 +277,18 @@ var Drilldown = function (_Plugin) {
       });
       this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');
       this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');
-      this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a');
-      this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["GetYoDigits"])(6, 'drilldown'));
+      this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a'); // Set the main menu as current by default (unless a submenu is selected)
+      // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu
+
+      this.$currentMenu = this.$element;
+      this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'drilldown'));
 
       this._prepareMenu();
+
       this._registerEvents();
 
       this._keyboardEvents();
     }
-
     /**
      * prepares drilldown menu by setting attributes to links and elements
      * sets a min height to prevent content jumping
@@ -230,67 +298,78 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_prepareMenu',
+    key: "_prepareMenu",
     value: function _prepareMenu() {
-      var _this = this;
-      // if(!this.options.holdOpen){
+      var _this = this; // if(!this.options.holdOpen){
       //   this._menuLinkEvents();
       // }
+
+
       this.$submenuAnchors.each(function () {
-        var $link = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+        var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
         var $sub = $link.parent();
+
         if (_this.options.parentLink) {
-          $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>');
+          $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>');
         }
+
         $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);
         $link.children('[data-submenu]').attr({
           'aria-hidden': true,
           'tabindex': 0,
           'role': 'group'
         });
+
         _this._events($link);
       });
       this.$submenus.each(function () {
-        var $menu = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var $menu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             $back = $menu.find('.js-drilldown-back');
+
         if (!$back.length) {
           switch (_this.options.backButtonPosition) {
             case "bottom":
               $menu.append(_this.options.backButton);
               break;
+
             case "top":
               $menu.prepend(_this.options.backButton);
               break;
+
             default:
               console.error("Unsupported backButtonPosition value '" + _this.options.backButtonPosition + "'");
           }
         }
+
         _this._back($menu);
       });
-
       this.$submenus.addClass('invisible');
+
       if (!this.options.autoHeight) {
         this.$submenus.addClass('drilldown-submenu-cover-previous');
-      }
+      } // create a wrapper on element if it doesn't exist.
+
 
-      // create a wrapper on element if it doesn't exist.
       if (!this.$element.parent().hasClass('is-drilldown')) {
-        this.$wrapper = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.options.wrapper).addClass('is-drilldown');
+        this.$wrapper = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.wrapper).addClass('is-drilldown');
         if (this.options.animateHeight) this.$wrapper.addClass('animate-height');
         this.$element.wrap(this.$wrapper);
-      }
-      // set wrapper
+      } // set wrapper
+
+
       this.$wrapper = this.$element.parent();
       this.$wrapper.css(this._getMaxDims());
     }
   }, {
-    key: '_resize',
+    key: "_resize",
     value: function _resize() {
-      this.$wrapper.css({ 'max-width': 'none', 'min-height': 'none' });
-      // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths
+      this.$wrapper.css({
+        'max-width': 'none',
+        'min-height': 'none'
+      }); // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths
+
       this.$wrapper.css(this._getMaxDims());
     }
-
     /**
      * Adds event handlers to elements in the menu.
      * @function
@@ -299,35 +378,37 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events($elem) {
       var _this = this;
 
       $elem.off('click.zf.drilldown').on('click.zf.drilldown', function (e) {
-        if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) {
+        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) {
           e.stopImmediatePropagation();
           e.preventDefault();
-        }
-
-        // if(e.target !== e.currentTarget.firstElementChild){
+        } // if(e.target !== e.currentTarget.firstElementChild){
         //   return false;
         // }
+
+
         _this._show($elem.parent('li'));
 
         if (_this.options.closeOnClick) {
-          var $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body');
+          var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');
           $body.off('.zf.drilldown').on('click.zf.drilldown', function (e) {
-            if (e.target === _this.$element[0] || __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(_this.$element[0], e.target)) {
+            if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target)) {
               return;
             }
+
             e.preventDefault();
+
             _this._hideAll();
+
             $body.off('.zf.drilldown');
           });
         }
       });
     }
-
     /**
      * Adds event handlers to the menu element.
      * @function
@@ -335,15 +416,15 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_registerEvents',
+    key: "_registerEvents",
     value: function _registerEvents() {
       if (this.options.scrollTop) {
         this._bindHandler = this._scrollTop.bind(this);
         this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown', this._bindHandler);
       }
+
       this.$element.on('mutateme.zf.trigger', this._resize.bind(this));
     }
-
     /**
      * Scroll to Top of Element or data-scroll-top-element
      * @function
@@ -351,108 +432,117 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_scrollTop',
+    key: "_scrollTop",
     value: function _scrollTop() {
       var _this = this;
-      var $scrollTopElement = _this.options.scrollTopElement != '' ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()(_this.options.scrollTopElement) : _this.$element,
+
+      var $scrollTopElement = _this.options.scrollTopElement != '' ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(_this.options.scrollTopElement) : _this.$element,
           scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10);
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing, function () {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({
+        scrollTop: scrollPos
+      }, _this.options.animationDuration, _this.options.animationEasing, function () {
         /**
           * Fires after the menu has scrolled
           * @event Drilldown#scrollme
           */
-        if (this === __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html')[0]) _this.$element.trigger('scrollme.zf.drilldown');
+        if (this === jquery__WEBPACK_IMPORTED_MODULE_0___default()('html')[0]) _this.$element.trigger('scrollme.zf.drilldown');
       });
     }
-
     /**
      * Adds keydown event listener to `li`'s in the menu.
      * @private
      */
 
   }, {
-    key: '_keyboardEvents',
+    key: "_keyboardEvents",
     value: function _keyboardEvents() {
       var _this = this;
 
       this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function (e) {
-        var $element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             $elements = $element.parent('li').parent('ul').children('li').children('a'),
             $prevElement,
             $nextElement;
-
         $elements.each(function (i) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is($element)) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {
             $prevElement = $elements.eq(Math.max(0, i - 1));
             $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
             return;
           }
         });
-
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'Drilldown', {
-          next: function () {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'Drilldown', {
+          next: function next() {
             if ($element.is(_this.$submenuAnchors)) {
               _this._show($element.parent('li'));
-              $element.parent('li').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["transitionend"])($element), function () {
-                $element.parent('li').find('ul li a').filter(_this.$menuItems).first().focus();
+
+              $element.parent('li').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($element), function () {
+                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
               });
               return true;
             }
           },
-          previous: function () {
+          previous: function previous() {
             _this._hide($element.parent('li').parent('ul'));
-            $element.parent('li').parent('ul').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["transitionend"])($element), function () {
+
+            $element.parent('li').parent('ul').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($element), function () {
               setTimeout(function () {
                 $element.parent('li').parent('ul').parent('li').children('a').first().focus();
               }, 1);
             });
             return true;
           },
-          up: function () {
-            $prevElement.focus();
-            // Don't tap focus on first element in root ul
+          up: function up() {
+            $prevElement.focus(); // Don't tap focus on first element in root ul
+
             return !$element.is(_this.$element.find('> li:first-child > a'));
           },
-          down: function () {
-            $nextElement.focus();
-            // Don't tap focus on last element in root ul
+          down: function down() {
+            $nextElement.focus(); // Don't tap focus on last element in root ul
+
             return !$element.is(_this.$element.find('> li:last-child > a'));
           },
-          close: function () {
+          close: function close() {
             // Don't close on element in root ul
             if (!$element.is(_this.$element.find('> li > a'))) {
               _this._hide($element.parent().parent());
+
               $element.parent().parent().siblings('a').focus();
             }
           },
-          open: function () {
-            if (!$element.is(_this.$menuItems)) {
+          open: function open() {
+            if (_this.options.parentLink && $element.attr('href')) {
+              // Link with href
+              return false;
+            } else if (!$element.is(_this.$menuItems)) {
               // not menu item means back button
               _this._hide($element.parent('li').parent('ul'));
-              $element.parent('li').parent('ul').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["transitionend"])($element), function () {
+
+              $element.parent('li').parent('ul').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($element), function () {
                 setTimeout(function () {
                   $element.parent('li').parent('ul').parent('li').children('a').first().focus();
                 }, 1);
               });
               return true;
             } else if ($element.is(_this.$submenuAnchors)) {
+              // Sub menu item
               _this._show($element.parent('li'));
-              $element.parent('li').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["transitionend"])($element), function () {
-                $element.parent('li').find('ul li a').filter(_this.$menuItems).first().focus();
+
+              $element.parent('li').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($element), function () {
+                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();
               });
               return true;
             }
           },
-          handled: function (preventDefault) {
+          handled: function handled(preventDefault) {
             if (preventDefault) {
               e.preventDefault();
             }
+
             e.stopImmediatePropagation();
           }
         });
       }); // end keyboardAccess
     }
-
     /**
      * Closes all open elements, and returns to root menu.
      * @function
@@ -460,20 +550,22 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_hideAll',
+    key: "_hideAll",
     value: function _hideAll() {
       var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');
-      if (this.options.autoHeight) this.$wrapper.css({ height: $elem.parent().closest('ul').data('calcHeight') });
-      $elem.one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["transitionend"])($elem), function (e) {
+      if (this.options.autoHeight) this.$wrapper.css({
+        height: $elem.parent().closest('ul').data('calcHeight')
+      });
+      $elem.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($elem), function (e) {
         $elem.removeClass('is-active is-closing');
       });
       /**
        * Fires when the menu is fully closed.
        * @event Drilldown#closed
        */
+
       this.$element.trigger('closed.zf.drilldown');
     }
-
     /**
      * Adds event listener for each `back` button, and closes open menus.
      * @function
@@ -482,23 +574,24 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_back',
+    key: "_back",
     value: function _back($elem) {
       var _this = this;
+
       $elem.off('click.zf.drilldown');
       $elem.children('.js-drilldown-back').on('click.zf.drilldown', function (e) {
-        e.stopImmediatePropagation();
-        // console.log('mouseup on back');
-        _this._hide($elem);
+        e.stopImmediatePropagation(); // console.log('mouseup on back');
+
+        _this._hide($elem); // If there is a parent submenu, call show
+
 
-        // If there is a parent submenu, call show
         var parentSubMenu = $elem.parent('li').parent('ul').parent('li');
+
         if (parentSubMenu.length) {
           _this._show(parentSubMenu);
         }
       });
     }
-
     /**
      * Adds event listener to menu items w/o submenus to close open menus on click.
      * @function
@@ -506,9 +599,10 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_menuLinkEvents',
+    key: "_menuLinkEvents",
     value: function _menuLinkEvents() {
       var _this = this;
+
       this.$menuItems.not('.is-drilldown-submenu-parent').off('click.zf.drilldown').on('click.zf.drilldown', function (e) {
         // e.stopImmediatePropagation();
         setTimeout(function () {
@@ -516,7 +610,93 @@ var Drilldown = function (_Plugin) {
         }, 0);
       });
     }
+    /**
+     * Sets the CSS classes for submenu to show it.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the target submenu (`ul` tag)
+     * @param {boolean} trigger - trigger drilldown event
+     */
 
+  }, {
+    key: "_setShowSubMenuClasses",
+    value: function _setShowSubMenuClasses($elem, trigger) {
+      $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+      $elem.parent('li').attr('aria-expanded', true);
+
+      if (trigger === true) {
+        this.$element.trigger('open.zf.drilldown', [$elem]);
+      }
+    }
+    /**
+     * Sets the CSS classes for submenu to hide it.
+     * @function
+     * @private
+     * @param {jQuery} $elem - the target submenu (`ul` tag)
+     * @param {boolean} trigger - trigger drilldown event
+     */
+
+  }, {
+    key: "_setHideSubMenuClasses",
+    value: function _setHideSubMenuClasses($elem, trigger) {
+      $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);
+      $elem.parent('li').attr('aria-expanded', false);
+
+      if (trigger === true) {
+        $elem.trigger('hide.zf.drilldown', [$elem]);
+      }
+    }
+    /**
+     * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.
+     * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.
+     * @function
+     * @fires Drilldown#open
+     * @param {jQuery} $elem - the target (sub)menu (`ul` tag)
+     * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused
+     */
+
+  }, {
+    key: "_showMenu",
+    value: function _showMenu($elem, autoFocus) {
+      var _this = this; // Reset drilldown
+
+
+      var $expandedSubmenus = this.$element.find('li[aria-expanded="true"] > ul[data-submenu]');
+      $expandedSubmenus.each(function (index) {
+        _this._setHideSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
+      }); // Save the menu as the currently displayed one.
+
+      this.$currentMenu = $elem; // If target menu is root, focus first link & exit
+
+      if ($elem.is('[data-drilldown]')) {
+        if (autoFocus === true) $elem.find('li[role="treeitem"] > a').first().focus();
+        if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));
+        return;
+      } // Find all submenus on way to root incl. the element itself
+
+
+      var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); // Open target menu and all submenus on its way to root
+
+      $submenus.each(function (index) {
+        // Update height of first child (target menu) if autoHeight option true
+        if (index === 0 && _this.options.autoHeight) {
+          _this.$wrapper.css('height', jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight'));
+        }
+
+        var isLastChild = index == $submenus.length - 1; // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link
+        // Last child makes sure the event gets always triggered even if going through several menus
+
+        if (isLastChild === true) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)), function () {
+            if (autoFocus === true) {
+              $elem.find('li[role="treeitem"] > a').first().focus();
+            }
+          });
+        }
+
+        _this._setShowSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), isLastChild);
+      });
+    }
     /**
      * Opens a submenu.
      * @function
@@ -525,33 +705,45 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_show',
+    key: "_show",
     value: function _show($elem) {
-      if (this.options.autoHeight) this.$wrapper.css({ height: $elem.children('[data-submenu]').data('calcHeight') });
+      var $submenu = $elem.children('[data-submenu]');
       $elem.attr('aria-expanded', true);
-      $elem.children('[data-submenu]').addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+      this.$currentMenu = $submenu;
+      $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);
+
+      if (this.options.autoHeight) {
+        this.$wrapper.css({
+          height: $submenu.data('calcHeight')
+        });
+      }
       /**
        * Fires when the submenu has opened.
        * @event Drilldown#open
        */
-      this.$element.trigger('open.zf.drilldown', [$elem]);
-    }
-  }, {
-    key: '_hide',
 
 
+      this.$element.trigger('open.zf.drilldown', [$elem]);
+    }
     /**
      * Hides a submenu
      * @function
      * @fires Drilldown#hide
      * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.
      */
+
+  }, {
+    key: "_hide",
     value: function _hide($elem) {
-      if (this.options.autoHeight) this.$wrapper.css({ height: $elem.parent().closest('ul').data('calcHeight') });
+      if (this.options.autoHeight) this.$wrapper.css({
+        height: $elem.parent().closest('ul').data('calcHeight')
+      });
+
       var _this = this;
+
       $elem.parent('li').attr('aria-expanded', false);
-      $elem.attr('aria-hidden', true).addClass('is-closing');
-      $elem.addClass('is-closing').one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["transitionend"])($elem), function () {
+      $elem.attr('aria-hidden', true);
+      $elem.addClass('is-closing').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["transitionend"])($elem), function () {
         $elem.removeClass('is-active is-closing');
         $elem.blur().addClass('invisible');
       });
@@ -559,9 +751,9 @@ var Drilldown = function (_Plugin) {
        * Fires when the submenu has closed.
        * @event Drilldown#hide
        */
+
       $elem.trigger('hide.zf.drilldown', [$elem]);
     }
-
     /**
      * Iterates through the nested menus to calculate the min-height, and max-width for the menu.
      * Prevents content jumping.
@@ -570,50 +762,50 @@ var Drilldown = function (_Plugin) {
      */
 
   }, {
-    key: '_getMaxDims',
+    key: "_getMaxDims",
     value: function _getMaxDims() {
       var maxHeight = 0,
           result = {},
-          _this = this;
+          _this = this; // Recalculate menu heights and total max height
+
+
       this.$submenus.add(this.$element).each(function () {
-        var numOfElems = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).children('li').length;
-        var height = __WEBPACK_IMPORTED_MODULE_4__foundation_util_box__["Box"].GetDimensions(this).height;
+        var numOfElems = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('li').length;
+        var height = _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__["Box"].GetDimensions(this).height;
         maxHeight = height > maxHeight ? height : maxHeight;
+
         if (_this.options.autoHeight) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('calcHeight', height);
-          if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).hasClass('is-drilldown-submenu')) result['height'] = height;
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight', height);
         }
       });
-
-      if (!this.options.autoHeight) result['min-height'] = maxHeight + 'px';
-
-      result['max-width'] = this.$element[0].getBoundingClientRect().width + 'px';
-
+      if (this.options.autoHeight) result['height'] = this.$currentMenu.data('calcHeight');else result['min-height'] = "".concat(maxHeight, "px");
+      result['max-width'] = "".concat(this.$element[0].getBoundingClientRect().width, "px");
       return result;
     }
-
     /**
      * Destroys the Drilldown Menu
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       if (this.options.scrollTop) this.$element.off('.zf.drilldown', this._bindHandler);
+
       this._hideAll();
+
       this.$element.off('mutateme.zf.trigger');
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["Nest"].Burn(this.$element, 'drilldown');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__["Nest"].Burn(this.$element, 'drilldown');
       this.$element.unwrap().find('.js-drilldown-back, .is-submenu-parent-item').remove().end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu').end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');
       this.$submenuAnchors.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).off('.zf.drilldown');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off('.zf.drilldown');
       });
-
+      this.$element.find('[data-is-parent-link]').detach();
       this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');
-
       this.$element.find('a').each(function () {
-        var $link = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+        var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
         $link.removeAttr('tabindex');
+
         if ($link.data('savedHref')) {
           $link.attr('href', $link.data('savedHref')).removeData('savedHref');
         } else {
@@ -624,7 +816,7 @@ var Drilldown = function (_Plugin) {
   }]);
 
   return Drilldown;
-}(__WEBPACK_IMPORTED_MODULE_5__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 
 Drilldown.defaults = {
   /**
@@ -635,6 +827,7 @@ Drilldown.defaults = {
    * @default true
    */
   autoApplyClass: true,
+
   /**
    * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\`) if copy and pasting.
    * @option
@@ -642,6 +835,7 @@ Drilldown.defaults = {
    * @default '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>'
    */
   backButton: '<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',
+
   /**
    * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.
    * @option
@@ -649,6 +843,7 @@ Drilldown.defaults = {
    * @default top
    */
   backButtonPosition: 'top',
+
   /**
    * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\`) if copy and pasting.
    * @option
@@ -656,6 +851,7 @@ Drilldown.defaults = {
    * @default '<div></div>'
    */
   wrapper: '<div></div>',
+
   /**
    * Adds the parent link to the submenu.
    * @option
@@ -663,6 +859,7 @@ Drilldown.defaults = {
    * @default false
    */
   parentLink: false,
+
   /**
    * Allow the menu to return to root list on body click.
    * @option
@@ -670,6 +867,7 @@ Drilldown.defaults = {
    * @default false
    */
   closeOnClick: false,
+
   /**
    * Allow the menu to auto adjust height.
    * @option
@@ -677,6 +875,7 @@ Drilldown.defaults = {
    * @default false
    */
   autoHeight: false,
+
   /**
    * Animate the auto adjust height.
    * @option
@@ -684,6 +883,7 @@ Drilldown.defaults = {
    * @default false
    */
   animateHeight: false,
+
   /**
    * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button
    * @option
@@ -691,6 +891,7 @@ Drilldown.defaults = {
    * @default false
    */
   scrollTop: false,
+
   /**
    * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken
    * @option
@@ -698,6 +899,7 @@ Drilldown.defaults = {
    * @default ''
    */
   scrollTopElement: '',
+
   /**
    * ScrollTop offset
    * @option
@@ -705,6 +907,7 @@ Drilldown.defaults = {
    * @default 0
    */
   scrollTopOffset: 0,
+
   /**
    * Scroll animation duration
    * @option
@@ -712,6 +915,7 @@ Drilldown.defaults = {
    * @default 500
    */
   animationDuration: 500,
+
   /**
    * Scroll animation easing. Can be `'swing'` or `'linear'`.
    * @option
@@ -719,41 +923,36 @@ Drilldown.defaults = {
    * @see {@link https://api.jquery.com/animate|JQuery animate}
    * @default 'swing'
    */
-  animationEasing: 'swing'
-  // holdOpen: false
-};
-
-
+  animationEasing: 'swing' // holdOpen: false
 
-/***/ }),
-
-/***/ 5:
-/***/ (function(module, exports) {
-
-module.exports = {Keyboard: window.Foundation.Keyboard};
-
-/***/ }),
-
-/***/ 8:
-/***/ (function(module, exports) {
+};
 
-module.exports = {Box: window.Foundation.Box};
 
 /***/ }),
 
-/***/ 82:
+/***/ 3:
+/*!**********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.drilldown.js ***!
+  \**********************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(16);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.drilldown.js */"./js/entries/plugins/foundation.drilldown.js");
 
 
 /***/ }),
 
-/***/ 9:
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Nest: window.Foundation.Nest};
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.drilldown.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.drilldown.js.map b/dist/js/plugins/foundation.drilldown.js.map
new file mode 100644 (file)
index 0000000..987ba5c
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.box\"],\"amd\":\"./foundation.util.box\",\"commonjs\":\"./foundation.util.box\",\"commonjs2\":\"./foundation.util.box\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.nest\"],\"amd\":\"./foundation.util.nest\",\"commonjs\":\"./foundation.util.nest\",\"commonjs2\":\"./foundation.util.nest\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.drilldown.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.drilldown.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Drilldown","element","options","$element","$","extend","defaults","data","className","_init","Keyboard","register","Nest","Feather","autoApplyClass","addClass","attr","$submenuAnchors","find","children","$submenus","parent","$menuItems","not","$currentMenu","GetYoDigits","_prepareMenu","_registerEvents","_keyboardEvents","_this","each","$link","$sub","parentLink","clone","prependTo","wrap","removeAttr","_events","$menu","$back","length","backButtonPosition","append","backButton","prepend","console","error","_back","autoHeight","hasClass","$wrapper","wrapper","animateHeight","css","_getMaxDims","$elem","off","on","e","target","parentsUntil","stopImmediatePropagation","preventDefault","_show","closeOnClick","$body","contains","_hideAll","scrollTop","_bindHandler","_scrollTop","bind","_resize","$scrollTopElement","scrollTopElement","scrollPos","parseInt","offset","top","scrollTopOffset","stop","animate","animationDuration","animationEasing","trigger","add","$elements","$prevElement","$nextElement","i","is","eq","Math","max","min","handleKey","next","one","transitionend","first","focus","previous","_hide","setTimeout","up","down","close","siblings","open","handled","height","closest","removeClass","parentSubMenu","autoFocus","$expandedSubmenus","index","_setHideSubMenuClasses","isLastChild","_setShowSubMenuClasses","$submenu","blur","maxHeight","result","numOfElems","Box","GetDimensions","getBoundingClientRect","width","Burn","unwrap","remove","end","detach","removeData","Plugin"],"mappings":"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","file":"foundation.drilldown.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.box\", \"./foundation.util.keyboard\", \"./foundation.util.nest\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.drilldown\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.drilldown\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.nest\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 3);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;","import { Foundation } from './foundation.core';\n\nimport { Drilldown } from '../../foundation.drilldown';\nFoundation.plugin(Drilldown, 'Drilldown');\n\nexport { Foundation, Drilldown };\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { GetYoDigits, transitionend } from './foundation.core.utils';\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Drilldown module.\n * @module foundation.drilldown\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n * @requires foundation.util.box\n */\n\nclass Drilldown extends Plugin {\n  /**\n   * Creates a new instance of a drilldown menu.\n   * @class\n   * @name Drilldown\n   * @param {jQuery} element - jQuery object to make into an accordion menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Drilldown.defaults, this.$element.data(), options);\n    this.className = 'Drilldown'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('Drilldown', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close',\n      'TAB': 'down',\n      'SHIFT_TAB': 'up'\n    });\n  }\n\n  /**\n   * Initializes the drilldown by creating jQuery collections of elements\n   * @private\n   */\n  _init() {\n    Nest.Feather(this.$element, 'drilldown');\n\n    if(this.options.autoApplyClass) {\n      this.$element.addClass('drilldown');\n    }\n\n    this.$element.attr({\n      'role': 'tree',\n      'aria-multiselectable': false\n    });\n    this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');\n    this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');\n    this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a');\n\n    // Set the main menu as current by default (unless a submenu is selected)\n    // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu\n    this.$currentMenu = this.$element;\n\n    this.$element.attr('data-mutate', (this.$element.attr('data-drilldown') || GetYoDigits(6, 'drilldown')));\n\n    this._prepareMenu();\n    this._registerEvents();\n\n    this._keyboardEvents();\n  }\n\n  /**\n   * prepares drilldown menu by setting attributes to links and elements\n   * sets a min height to prevent content jumping\n   * wraps the element if not already wrapped\n   * @private\n   * @function\n   */\n  _prepareMenu() {\n    var _this = this;\n    // if(!this.options.holdOpen){\n    //   this._menuLinkEvents();\n    // }\n    this.$submenuAnchors.each(function(){\n      var $link = $(this);\n      var $sub = $link.parent();\n      if(_this.options.parentLink){\n        $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-drilldown-submenu-item\" role=\"menuitem\"></li>');\n      }\n      $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);\n      $link.children('[data-submenu]')\n          .attr({\n            'aria-hidden': true,\n            'tabindex': 0,\n            'role': 'group'\n          });\n      _this._events($link);\n    });\n    this.$submenus.each(function(){\n      var $menu = $(this),\n          $back = $menu.find('.js-drilldown-back');\n      if(!$back.length){\n        switch (_this.options.backButtonPosition) {\n          case \"bottom\":\n            $menu.append(_this.options.backButton);\n            break;\n          case \"top\":\n            $menu.prepend(_this.options.backButton);\n            break;\n          default:\n            console.error(\"Unsupported backButtonPosition value '\" + _this.options.backButtonPosition + \"'\");\n        }\n      }\n      _this._back($menu);\n    });\n\n    this.$submenus.addClass('invisible');\n    if(!this.options.autoHeight) {\n      this.$submenus.addClass('drilldown-submenu-cover-previous');\n    }\n\n    // create a wrapper on element if it doesn't exist.\n    if(!this.$element.parent().hasClass('is-drilldown')){\n      this.$wrapper = $(this.options.wrapper).addClass('is-drilldown');\n      if(this.options.animateHeight) this.$wrapper.addClass('animate-height');\n      this.$element.wrap(this.$wrapper);\n    }\n    // set wrapper\n    this.$wrapper = this.$element.parent();\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  _resize() {\n    this.$wrapper.css({'max-width': 'none', 'min-height': 'none'});\n    // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths\n    this.$wrapper.css(this._getMaxDims());\n  }\n\n  /**\n   * Adds event handlers to elements in the menu.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the current menu item to add handlers to.\n   */\n  _events($elem) {\n    var _this = this;\n\n    $elem.off('click.zf.drilldown')\n    .on('click.zf.drilldown', function(e){\n      if($(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')){\n        e.stopImmediatePropagation();\n        e.preventDefault();\n      }\n\n      // if(e.target !== e.currentTarget.firstElementChild){\n      //   return false;\n      // }\n      _this._show($elem.parent('li'));\n\n      if(_this.options.closeOnClick){\n        var $body = $('body');\n        $body.off('.zf.drilldown').on('click.zf.drilldown', function(e){\n          if (e.target === _this.$element[0] || $.contains(_this.$element[0], e.target)) { return; }\n          e.preventDefault();\n          _this._hideAll();\n          $body.off('.zf.drilldown');\n        });\n      }\n    });\n  }\n\n  /**\n   * Adds event handlers to the menu element.\n   * @function\n   * @private\n   */\n  _registerEvents() {\n    if(this.options.scrollTop){\n      this._bindHandler = this._scrollTop.bind(this);\n      this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown',this._bindHandler);\n    }\n    this.$element.on('mutateme.zf.trigger', this._resize.bind(this));\n  }\n\n  /**\n   * Scroll to Top of Element or data-scroll-top-element\n   * @function\n   * @fires Drilldown#scrollme\n   */\n  _scrollTop() {\n    var _this = this;\n    var $scrollTopElement = _this.options.scrollTopElement!=''?$(_this.options.scrollTopElement):_this.$element,\n        scrollPos = parseInt($scrollTopElement.offset().top+_this.options.scrollTopOffset, 10);\n    $('html, body').stop(true).animate({ scrollTop: scrollPos }, _this.options.animationDuration, _this.options.animationEasing,function(){\n      /**\n        * Fires after the menu has scrolled\n        * @event Drilldown#scrollme\n        */\n      if(this===$('html')[0])_this.$element.trigger('scrollme.zf.drilldown');\n    });\n  }\n\n  /**\n   * Adds keydown event listener to `li`'s in the menu.\n   * @private\n   */\n  _keyboardEvents() {\n    var _this = this;\n\n    this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function(e){\n      var $element = $(this),\n          $elements = $element.parent('li').parent('ul').children('li').children('a'),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(Math.max(0, i-1));\n          $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          return;\n        }\n      });\n\n      Keyboard.handleKey(e, 'Drilldown', {\n        next: function() {\n          if ($element.is(_this.$submenuAnchors)) {\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        previous: function() {\n          _this._hide($element.parent('li').parent('ul'));\n          $element.parent('li').parent('ul').one(transitionend($element), function(){\n            setTimeout(function() {\n              $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n            }, 1);\n          });\n          return true;\n        },\n        up: function() {\n          $prevElement.focus();\n          // Don't tap focus on first element in root ul\n          return !$element.is(_this.$element.find('> li:first-child > a'));\n        },\n        down: function() {\n          $nextElement.focus();\n          // Don't tap focus on last element in root ul\n          return !$element.is(_this.$element.find('> li:last-child > a'));\n        },\n        close: function() {\n          // Don't close on element in root ul\n          if (!$element.is(_this.$element.find('> li > a'))) {\n            _this._hide($element.parent().parent());\n            $element.parent().parent().siblings('a').focus();\n          }\n        },\n        open: function() {\n          if (_this.options.parentLink && $element.attr('href')) { // Link with href\n            return false;\n          } else if (!$element.is(_this.$menuItems)) { // not menu item means back button\n            _this._hide($element.parent('li').parent('ul'));\n            $element.parent('li').parent('ul').one(transitionend($element), function(){\n              setTimeout(function() {\n                $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n              }, 1);\n            });\n            return true;\n          } else if ($element.is(_this.$submenuAnchors)) { // Sub menu item\n            _this._show($element.parent('li'));\n            $element.parent('li').one(transitionend($element), function(){\n              $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n            });\n            return true;\n          }\n        },\n        handled: function(preventDefault) {\n          if (preventDefault) {\n            e.preventDefault();\n          }\n          e.stopImmediatePropagation();\n        }\n      });\n    }); // end keyboardAccess\n  }\n\n  /**\n   * Closes all open elements, and returns to root menu.\n   * @function\n   * @fires Drilldown#closed\n   */\n  _hideAll() {\n    var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    $elem.one(transitionend($elem), function(e){\n      $elem.removeClass('is-active is-closing');\n    });\n        /**\n         * Fires when the menu is fully closed.\n         * @event Drilldown#closed\n         */\n    this.$element.trigger('closed.zf.drilldown');\n  }\n\n  /**\n   * Adds event listener for each `back` button, and closes open menus.\n   * @function\n   * @fires Drilldown#back\n   * @param {jQuery} $elem - the current sub-menu to add `back` event.\n   */\n  _back($elem) {\n    var _this = this;\n    $elem.off('click.zf.drilldown');\n    $elem.children('.js-drilldown-back')\n      .on('click.zf.drilldown', function(e){\n        e.stopImmediatePropagation();\n        // console.log('mouseup on back');\n        _this._hide($elem);\n\n        // If there is a parent submenu, call show\n        let parentSubMenu = $elem.parent('li').parent('ul').parent('li');\n        if (parentSubMenu.length) {\n          _this._show(parentSubMenu);\n        }\n      });\n  }\n\n  /**\n   * Adds event listener to menu items w/o submenus to close open menus on click.\n   * @function\n   * @private\n   */\n  _menuLinkEvents() {\n    var _this = this;\n    this.$menuItems.not('.is-drilldown-submenu-parent')\n        .off('click.zf.drilldown')\n        .on('click.zf.drilldown', function(e){\n          // e.stopImmediatePropagation();\n          setTimeout(function(){\n            _this._hideAll();\n          }, 0);\n      });\n  }\n\n  /**\n   * Sets the CSS classes for submenu to show it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setShowSubMenuClasses($elem, trigger) {\n    $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    $elem.parent('li').attr('aria-expanded', true);\n    if (trigger === true) {\n      this.$element.trigger('open.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Sets the CSS classes for submenu to hide it.\n   * @function\n   * @private\n   * @param {jQuery} $elem - the target submenu (`ul` tag)\n   * @param {boolean} trigger - trigger drilldown event\n   */\n  _setHideSubMenuClasses($elem, trigger) {\n    $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);\n    $elem.parent('li').attr('aria-expanded', false);\n    if (trigger === true) {\n      $elem.trigger('hide.zf.drilldown', [$elem]);\n    }\n  }\n\n  /**\n   * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.\n   * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the target (sub)menu (`ul` tag)\n   * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused\n   */\n  _showMenu($elem, autoFocus) {\n\n    var _this = this;\n\n    // Reset drilldown\n    var $expandedSubmenus = this.$element.find('li[aria-expanded=\"true\"] > ul[data-submenu]');\n    $expandedSubmenus.each(function(index) {\n      _this._setHideSubMenuClasses($(this));\n    });\n\n    // Save the menu as the currently displayed one.\n    this.$currentMenu = $elem;\n\n    // If target menu is root, focus first link & exit\n    if ($elem.is('[data-drilldown]')) {\n      if (autoFocus === true) $elem.find('li[role=\"treeitem\"] > a').first().focus();\n      if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));\n      return;\n    }\n\n    // Find all submenus on way to root incl. the element itself\n    var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]');\n\n    // Open target menu and all submenus on its way to root\n    $submenus.each(function(index) {\n\n      // Update height of first child (target menu) if autoHeight option true\n      if (index === 0 && _this.options.autoHeight) {\n        _this.$wrapper.css('height', $(this).data('calcHeight'));\n      }\n\n      var isLastChild = index == $submenus.length - 1;\n\n      // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link\n      // Last child makes sure the event gets always triggered even if going through several menus\n      if (isLastChild === true) {\n        $(this).one(transitionend($(this)), () => {\n          if (autoFocus === true) {\n            $elem.find('li[role=\"treeitem\"] > a').first().focus();\n          }\n        });\n      }\n\n      _this._setShowSubMenuClasses($(this), isLastChild);\n    });\n  }\n\n  /**\n   * Opens a submenu.\n   * @function\n   * @fires Drilldown#open\n   * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.\n   */\n  _show($elem) {\n    const $submenu = $elem.children('[data-submenu]');\n\n    $elem.attr('aria-expanded', true);\n\n    this.$currentMenu = $submenu;\n    $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n    if (this.options.autoHeight) {\n      this.$wrapper.css({ height: $submenu.data('calcHeight') });\n    }\n\n    /**\n     * Fires when the submenu has opened.\n     * @event Drilldown#open\n     */\n    this.$element.trigger('open.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Hides a submenu\n   * @function\n   * @fires Drilldown#hide\n   * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.\n   */\n  _hide($elem) {\n    if(this.options.autoHeight) this.$wrapper.css({height:$elem.parent().closest('ul').data('calcHeight')});\n    var _this = this;\n    $elem.parent('li').attr('aria-expanded', false);\n    $elem.attr('aria-hidden', true);\n    $elem.addClass('is-closing')\n         .one(transitionend($elem), function(){\n           $elem.removeClass('is-active is-closing');\n           $elem.blur().addClass('invisible');\n         });\n    /**\n     * Fires when the submenu has closed.\n     * @event Drilldown#hide\n     */\n    $elem.trigger('hide.zf.drilldown', [$elem]);\n  }\n\n  /**\n   * Iterates through the nested menus to calculate the min-height, and max-width for the menu.\n   * Prevents content jumping.\n   * @function\n   * @private\n   */\n  _getMaxDims() {\n    var maxHeight = 0, result = {}, _this = this;\n\n    // Recalculate menu heights and total max height\n    this.$submenus.add(this.$element).each(function(){\n      var numOfElems = $(this).children('li').length;\n      var height = Box.GetDimensions(this).height;\n\n      maxHeight = height > maxHeight ? height : maxHeight;\n\n      if(_this.options.autoHeight) {\n        $(this).data('calcHeight',height);\n      }\n    });\n\n    if (this.options.autoHeight)\n      result['height'] = this.$currentMenu.data('calcHeight');\n    else\n      result['min-height'] = `${maxHeight}px`;\n\n    result['max-width'] = `${this.$element[0].getBoundingClientRect().width}px`;\n\n    return result;\n  }\n\n  /**\n   * Destroys the Drilldown Menu\n   * @function\n   */\n  _destroy() {\n    if(this.options.scrollTop) this.$element.off('.zf.drilldown',this._bindHandler);\n    this._hideAll();\n\t  this.$element.off('mutateme.zf.trigger');\n    Nest.Burn(this.$element, 'drilldown');\n    this.$element.unwrap()\n                 .find('.js-drilldown-back, .is-submenu-parent-item').remove()\n                 .end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu')\n                 .end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');\n    this.$submenuAnchors.each(function() {\n      $(this).off('.zf.drilldown');\n    });\n\n    this.$element.find('[data-is-parent-link]').detach();\n    this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');\n\n    this.$element.find('a').each(function(){\n      var $link = $(this);\n      $link.removeAttr('tabindex');\n      if($link.data('savedHref')){\n        $link.attr('href', $link.data('savedHref')).removeData('savedHref');\n      }else{ return; }\n    });\n  };\n}\n\nDrilldown.defaults = {\n  /**\n   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are\n   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.\n   * @option\n   * @type {boolian}\n   * @default true\n   */\n  autoApplyClass: true,\n  /**\n   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>'\n   */\n  backButton: '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>',\n  /**\n   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default top\n   */\n  backButtonPosition: 'top',\n  /**\n   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<div></div>'\n   */\n  wrapper: '<div></div>',\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n  /**\n   * Allow the menu to return to root list on body click.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false,\n  /**\n   * Allow the menu to auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoHeight: false,\n  /**\n   * Animate the auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animateHeight: false,\n  /**\n   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  scrollTop: false,\n  /**\n   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  scrollTopElement: '',\n  /**\n   * ScrollTop offset\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  scrollTopOffset: 0,\n  /**\n   * Scroll animation duration\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Scroll animation easing. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @see {@link https://api.jquery.com/animate|JQuery animate}\n   * @default 'swing'\n   */\n  animationEasing: 'swing'\n  // holdOpen: false\n};\n\nexport {Drilldown};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 24b5b04c38ea501594b0ac985cc44510b5c7c542..a08efcf7181f32c882a88d57fd38ac36cce73c51 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(i){if(n[i])return n[i].exports;var o=n[i]={i:i,l:!1,exports:{}};return e[i].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,i){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:i})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=82)}({0:function(e,t){e.exports=jQuery},1:function(e,t){e.exports={Foundation:window.Foundation}},16:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var i=n(1),o=(n.n(i),n(46));i.Foundation.plugin(o.a,"Drilldown")},2:function(e,t){e.exports={Plugin:window.Foundation.Plugin}},3:function(e,t){e.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},46:function(e,t,n){"use strict";function i(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function o(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function s(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}n.d(t,"a",function(){return f});var r=n(0),a=n.n(r),l=n(5),u=(n.n(l),n(9)),d=(n.n(u),n(3)),c=(n.n(d),n(8)),h=(n.n(c),n(2)),p=(n.n(h),function(){function e(e,t){for(var n=0;n<t.length;n++){var i=t[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(e,i.key,i)}}return function(t,n,i){return n&&e(t.prototype,n),i&&e(t,i),t}}()),f=function(e){function t(){return i(this,t),o(this,(t.__proto__||Object.getPrototypeOf(t)).apply(this,arguments))}return s(t,e),p(t,[{key:"_setup",value:function(e,n){this.$element=e,this.options=a.a.extend({},t.defaults,this.$element.data(),n),this.className="Drilldown",this._init(),l.Keyboard.register("Drilldown",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close",TAB:"down",SHIFT_TAB:"up"})}},{key:"_init",value:function(){u.Nest.Feather(this.$element,"drilldown"),this.options.autoApplyClass&&this.$element.addClass("drilldown"),this.$element.attr({role:"tree","aria-multiselectable":!1}),this.$submenuAnchors=this.$element.find("li.is-drilldown-submenu-parent").children("a"),this.$submenus=this.$submenuAnchors.parent("li").children("[data-submenu]").attr("role","group"),this.$menuItems=this.$element.find("li").not(".js-drilldown-back").attr("role","treeitem").find("a"),this.$element.attr("data-mutate",this.$element.attr("data-drilldown")||n.i(d.GetYoDigits)(6,"drilldown")),this._prepareMenu(),this._registerEvents(),this._keyboardEvents()}},{key:"_prepareMenu",value:function(){var e=this;this.$submenuAnchors.each(function(){var t=a()(this),n=t.parent();e.options.parentLink&&t.clone().prependTo(n.children("[data-submenu]")).wrap('<li class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>'),t.data("savedHref",t.attr("href")).removeAttr("href").attr("tabindex",0),t.children("[data-submenu]").attr({"aria-hidden":!0,tabindex:0,role:"group"}),e._events(t)}),this.$submenus.each(function(){var t=a()(this);if(!t.find(".js-drilldown-back").length)switch(e.options.backButtonPosition){case"bottom":t.append(e.options.backButton);break;case"top":t.prepend(e.options.backButton);break;default:console.error("Unsupported backButtonPosition value '"+e.options.backButtonPosition+"'")}e._back(t)}),this.$submenus.addClass("invisible"),this.options.autoHeight||this.$submenus.addClass("drilldown-submenu-cover-previous"),this.$element.parent().hasClass("is-drilldown")||(this.$wrapper=a()(this.options.wrapper).addClass("is-drilldown"),this.options.animateHeight&&this.$wrapper.addClass("animate-height"),this.$element.wrap(this.$wrapper)),this.$wrapper=this.$element.parent(),this.$wrapper.css(this._getMaxDims())}},{key:"_resize",value:function(){this.$wrapper.css({"max-width":"none","min-height":"none"}),this.$wrapper.css(this._getMaxDims())}},{key:"_events",value:function(e){var t=this;e.off("click.zf.drilldown").on("click.zf.drilldown",function(n){if(a()(n.target).parentsUntil("ul","li").hasClass("is-drilldown-submenu-parent")&&(n.stopImmediatePropagation(),n.preventDefault()),t._show(e.parent("li")),t.options.closeOnClick){var i=a()("body");i.off(".zf.drilldown").on("click.zf.drilldown",function(e){e.target===t.$element[0]||a.a.contains(t.$element[0],e.target)||(e.preventDefault(),t._hideAll(),i.off(".zf.drilldown"))})}})}},{key:"_registerEvents",value:function(){this.options.scrollTop&&(this._bindHandler=this._scrollTop.bind(this),this.$element.on("open.zf.drilldown hide.zf.drilldown closed.zf.drilldown",this._bindHandler)),this.$element.on("mutateme.zf.trigger",this._resize.bind(this))}},{key:"_scrollTop",value:function(){var e=this,t=""!=e.options.scrollTopElement?a()(e.options.scrollTopElement):e.$element,n=parseInt(t.offset().top+e.options.scrollTopOffset,10);a()("html, body").stop(!0).animate({scrollTop:n},e.options.animationDuration,e.options.animationEasing,function(){this===a()("html")[0]&&e.$element.trigger("scrollme.zf.drilldown")})}},{key:"_keyboardEvents",value:function(){var e=this;this.$menuItems.add(this.$element.find(".js-drilldown-back > a, .is-submenu-parent-item > a")).on("keydown.zf.drilldown",function(t){var i,o,s=a()(this),r=s.parent("li").parent("ul").children("li").children("a");r.each(function(e){if(a()(this).is(s))return i=r.eq(Math.max(0,e-1)),void(o=r.eq(Math.min(e+1,r.length-1)))}),l.Keyboard.handleKey(t,"Drilldown",{next:function(){if(s.is(e.$submenuAnchors))return e._show(s.parent("li")),s.parent("li").one(n.i(d.transitionend)(s),function(){s.parent("li").find("ul li a").filter(e.$menuItems).first().focus()}),!0},previous:function(){return e._hide(s.parent("li").parent("ul")),s.parent("li").parent("ul").one(n.i(d.transitionend)(s),function(){setTimeout(function(){s.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0},up:function(){return i.focus(),!s.is(e.$element.find("> li:first-child > a"))},down:function(){return o.focus(),!s.is(e.$element.find("> li:last-child > a"))},close:function(){s.is(e.$element.find("> li > a"))||(e._hide(s.parent().parent()),s.parent().parent().siblings("a").focus())},open:function(){return s.is(e.$menuItems)?s.is(e.$submenuAnchors)?(e._show(s.parent("li")),s.parent("li").one(n.i(d.transitionend)(s),function(){s.parent("li").find("ul li a").filter(e.$menuItems).first().focus()}),!0):void 0:(e._hide(s.parent("li").parent("ul")),s.parent("li").parent("ul").one(n.i(d.transitionend)(s),function(){setTimeout(function(){s.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0)},handled:function(e){e&&t.preventDefault(),t.stopImmediatePropagation()}})})}},{key:"_hideAll",value:function(){var e=this.$element.find(".is-drilldown-submenu.is-active").addClass("is-closing");this.options.autoHeight&&this.$wrapper.css({height:e.parent().closest("ul").data("calcHeight")}),e.one(n.i(d.transitionend)(e),function(t){e.removeClass("is-active is-closing")}),this.$element.trigger("closed.zf.drilldown")}},{key:"_back",value:function(e){var t=this;e.off("click.zf.drilldown"),e.children(".js-drilldown-back").on("click.zf.drilldown",function(n){n.stopImmediatePropagation(),t._hide(e);var i=e.parent("li").parent("ul").parent("li");i.length&&t._show(i)})}},{key:"_menuLinkEvents",value:function(){var e=this;this.$menuItems.not(".is-drilldown-submenu-parent").off("click.zf.drilldown").on("click.zf.drilldown",function(t){setTimeout(function(){e._hideAll()},0)})}},{key:"_show",value:function(e){this.options.autoHeight&&this.$wrapper.css({height:e.children("[data-submenu]").data("calcHeight")}),e.attr("aria-expanded",!0),e.children("[data-submenu]").addClass("is-active").removeClass("invisible").attr("aria-hidden",!1),this.$element.trigger("open.zf.drilldown",[e])}},{key:"_hide",value:function(e){this.options.autoHeight&&this.$wrapper.css({height:e.parent().closest("ul").data("calcHeight")});e.parent("li").attr("aria-expanded",!1),e.attr("aria-hidden",!0).addClass("is-closing"),e.addClass("is-closing").one(n.i(d.transitionend)(e),function(){e.removeClass("is-active is-closing"),e.blur().addClass("invisible")}),e.trigger("hide.zf.drilldown",[e])}},{key:"_getMaxDims",value:function(){var e=0,t={},n=this;return this.$submenus.add(this.$element).each(function(){var i=(a()(this).children("li").length,c.Box.GetDimensions(this).height);e=i>e?i:e,n.options.autoHeight&&(a()(this).data("calcHeight",i),a()(this).hasClass("is-drilldown-submenu")||(t.height=i))}),this.options.autoHeight||(t["min-height"]=e+"px"),t["max-width"]=this.$element[0].getBoundingClientRect().width+"px",t}},{key:"_destroy",value:function(){this.options.scrollTop&&this.$element.off(".zf.drilldown",this._bindHandler),this._hideAll(),this.$element.off("mutateme.zf.trigger"),u.Nest.Burn(this.$element,"drilldown"),this.$element.unwrap().find(".js-drilldown-back, .is-submenu-parent-item").remove().end().find(".is-active, .is-closing, .is-drilldown-submenu").removeClass("is-active is-closing is-drilldown-submenu").end().find("[data-submenu]").removeAttr("aria-hidden tabindex role"),this.$submenuAnchors.each(function(){a()(this).off(".zf.drilldown")}),this.$submenus.removeClass("drilldown-submenu-cover-previous invisible"),this.$element.find("a").each(function(){var e=a()(this);e.removeAttr("tabindex"),e.data("savedHref")&&e.attr("href",e.data("savedHref")).removeData("savedHref")})}}]),t}(h.Plugin);f.defaults={autoApplyClass:!0,backButton:'<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',backButtonPosition:"top",wrapper:"<div></div>",parentLink:!1,closeOnClick:!1,autoHeight:!1,animateHeight:!1,scrollTop:!1,scrollTopElement:"",scrollTopOffset:0,animationDuration:500,animationEasing:"swing"}},5:function(e,t){e.exports={Keyboard:window.Foundation.Keyboard}},8:function(e,t){e.exports={Box:window.Foundation.Box}},82:function(e,t,n){e.exports=n(16)},9:function(e,t){e.exports={Nest:window.Foundation.Nest}}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("./foundation.util.box"),require("./foundation.util.keyboard"),require("./foundation.util.nest"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.box","./foundation.util.keyboard","./foundation.util.nest","jquery"],t):"object"==typeof exports?exports["foundation.drilldown"]=t(require("./foundation.core"),require("./foundation.util.box"),require("./foundation.util.keyboard"),require("./foundation.util.nest"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.drilldown"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.box"],e.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],e.__FOUNDATION_EXTERNAL__["foundation.util.nest"],e.jQuery))}(window,function(n,i,o,r,a){return function(n){var i={};function o(e){if(i[e])return i[e].exports;var t=i[e]={i:e,l:!1,exports:{}};return n[e].call(t.exports,t,t.exports,o),t.l=!0,t.exports}return o.m=n,o.c=i,o.d=function(e,t,n){o.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(t,e){if(1&e&&(t=o(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(o.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var i in t)o.d(n,i,function(e){return t[e]}.bind(null,i));return n},o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,"a",t),t},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.p="",o(o.s=3)}({"./foundation.core":function(e,t){e.exports=n},"./foundation.util.box":function(e,t){e.exports=i},"./foundation.util.keyboard":function(e,t){e.exports=o},"./foundation.util.nest":function(e,t){e.exports=r},"./js/entries/plugins/foundation.drilldown.js":function(e,t,n){"use strict";n.r(t);var i=n("./foundation.core");n.d(t,"Foundation",function(){return i.Foundation});var o=n("./js/foundation.drilldown.js");n.d(t,"Drilldown",function(){return o.Drilldown}),i.Foundation.plugin(o.Drilldown,"Drilldown")},"./js/foundation.drilldown.js":function(e,t,n){"use strict";n.r(t),n.d(t,"Drilldown",function(){return h});var i=n("jquery"),a=n.n(i),s=n("./foundation.util.keyboard"),r=n("./foundation.util.nest"),l=n("./foundation.core"),u=n("./foundation.util.box");function o(e){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function d(e,t){for(var n=0;n<t.length;n++){var i=t[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(e,i.key,i)}}function c(e,t){return!t||"object"!==o(t)&&"function"!=typeof t?function(e){if(void 0!==e)return e;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(e):t}function f(e){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function p(e,t){return(p=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e})(e,t)}var h=function(e){function n(){return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,n),c(this,f(n).apply(this,arguments))}var t,i,o;return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&p(e,t)}(n,l["Plugin"]),t=n,(i=[{key:"_setup",value:function(e,t){this.$element=e,this.options=a.a.extend({},n.defaults,this.$element.data(),t),this.className="Drilldown",this._init(),s.Keyboard.register("Drilldown",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close",TAB:"down",SHIFT_TAB:"up"})}},{key:"_init",value:function(){r.Nest.Feather(this.$element,"drilldown"),this.options.autoApplyClass&&this.$element.addClass("drilldown"),this.$element.attr({role:"tree","aria-multiselectable":!1}),this.$submenuAnchors=this.$element.find("li.is-drilldown-submenu-parent").children("a"),this.$submenus=this.$submenuAnchors.parent("li").children("[data-submenu]").attr("role","group"),this.$menuItems=this.$element.find("li").not(".js-drilldown-back").attr("role","treeitem").find("a"),this.$currentMenu=this.$element,this.$element.attr("data-mutate",this.$element.attr("data-drilldown")||Object(l.GetYoDigits)(6,"drilldown")),this._prepareMenu(),this._registerEvents(),this._keyboardEvents()}},{key:"_prepareMenu",value:function(){var n=this;this.$submenuAnchors.each(function(){var e=a()(this),t=e.parent();n.options.parentLink&&e.clone().prependTo(t.children("[data-submenu]")).wrap('<li data-is-parent-link class="is-submenu-parent-item is-submenu-item is-drilldown-submenu-item" role="menuitem"></li>'),e.data("savedHref",e.attr("href")).removeAttr("href").attr("tabindex",0),e.children("[data-submenu]").attr({"aria-hidden":!0,tabindex:0,role:"group"}),n._events(e)}),this.$submenus.each(function(){var e=a()(this);if(!e.find(".js-drilldown-back").length)switch(n.options.backButtonPosition){case"bottom":e.append(n.options.backButton);break;case"top":e.prepend(n.options.backButton);break;default:console.error("Unsupported backButtonPosition value '"+n.options.backButtonPosition+"'")}n._back(e)}),this.$submenus.addClass("invisible"),this.options.autoHeight||this.$submenus.addClass("drilldown-submenu-cover-previous"),this.$element.parent().hasClass("is-drilldown")||(this.$wrapper=a()(this.options.wrapper).addClass("is-drilldown"),this.options.animateHeight&&this.$wrapper.addClass("animate-height"),this.$element.wrap(this.$wrapper)),this.$wrapper=this.$element.parent(),this.$wrapper.css(this._getMaxDims())}},{key:"_resize",value:function(){this.$wrapper.css({"max-width":"none","min-height":"none"}),this.$wrapper.css(this._getMaxDims())}},{key:"_events",value:function(n){var i=this;n.off("click.zf.drilldown").on("click.zf.drilldown",function(e){if(a()(e.target).parentsUntil("ul","li").hasClass("is-drilldown-submenu-parent")&&(e.stopImmediatePropagation(),e.preventDefault()),i._show(n.parent("li")),i.options.closeOnClick){var t=a()("body");t.off(".zf.drilldown").on("click.zf.drilldown",function(e){e.target===i.$element[0]||a.a.contains(i.$element[0],e.target)||(e.preventDefault(),i._hideAll(),t.off(".zf.drilldown"))})}})}},{key:"_registerEvents",value:function(){this.options.scrollTop&&(this._bindHandler=this._scrollTop.bind(this),this.$element.on("open.zf.drilldown hide.zf.drilldown closed.zf.drilldown",this._bindHandler)),this.$element.on("mutateme.zf.trigger",this._resize.bind(this))}},{key:"_scrollTop",value:function(){var e=this,t=""!=e.options.scrollTopElement?a()(e.options.scrollTopElement):e.$element,n=parseInt(t.offset().top+e.options.scrollTopOffset,10);a()("html, body").stop(!0).animate({scrollTop:n},e.options.animationDuration,e.options.animationEasing,function(){this===a()("html")[0]&&e.$element.trigger("scrollme.zf.drilldown")})}},{key:"_keyboardEvents",value:function(){var e=this;this.$menuItems.add(this.$element.find(".js-drilldown-back > a, .is-submenu-parent-item > a")).on("keydown.zf.drilldown",function(t){var n,i,o=a()(this),r=o.parent("li").parent("ul").children("li").children("a");r.each(function(e){if(a()(this).is(o))return n=r.eq(Math.max(0,e-1)),void(i=r.eq(Math.min(e+1,r.length-1)))}),s.Keyboard.handleKey(t,"Drilldown",{next:function(){if(o.is(e.$submenuAnchors))return e._show(o.parent("li")),o.parent("li").one(Object(l.transitionend)(o),function(){o.parent("li").find("ul li a").not(".js-drilldown-back a").first().focus()}),!0},previous:function(){return e._hide(o.parent("li").parent("ul")),o.parent("li").parent("ul").one(Object(l.transitionend)(o),function(){setTimeout(function(){o.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0},up:function(){return n.focus(),!o.is(e.$element.find("> li:first-child > a"))},down:function(){return i.focus(),!o.is(e.$element.find("> li:last-child > a"))},close:function(){o.is(e.$element.find("> li > a"))||(e._hide(o.parent().parent()),o.parent().parent().siblings("a").focus())},open:function(){return(!e.options.parentLink||!o.attr("href"))&&(o.is(e.$menuItems)?o.is(e.$submenuAnchors)?(e._show(o.parent("li")),o.parent("li").one(Object(l.transitionend)(o),function(){o.parent("li").find("ul li a").not(".js-drilldown-back a").first().focus()}),!0):void 0:(e._hide(o.parent("li").parent("ul")),o.parent("li").parent("ul").one(Object(l.transitionend)(o),function(){setTimeout(function(){o.parent("li").parent("ul").parent("li").children("a").first().focus()},1)}),!0))},handled:function(e){e&&t.preventDefault(),t.stopImmediatePropagation()}})})}},{key:"_hideAll",value:function(){var t=this.$element.find(".is-drilldown-submenu.is-active").addClass("is-closing");this.options.autoHeight&&this.$wrapper.css({height:t.parent().closest("ul").data("calcHeight")}),t.one(Object(l.transitionend)(t),function(e){t.removeClass("is-active is-closing")}),this.$element.trigger("closed.zf.drilldown")}},{key:"_back",value:function(n){var i=this;n.off("click.zf.drilldown"),n.children(".js-drilldown-back").on("click.zf.drilldown",function(e){e.stopImmediatePropagation(),i._hide(n);var t=n.parent("li").parent("ul").parent("li");t.length&&i._show(t)})}},{key:"_menuLinkEvents",value:function(){var t=this;this.$menuItems.not(".is-drilldown-submenu-parent").off("click.zf.drilldown").on("click.zf.drilldown",function(e){setTimeout(function(){t._hideAll()},0)})}},{key:"_setShowSubMenuClasses",value:function(e,t){e.addClass("is-active").removeClass("invisible").attr("aria-hidden",!1),e.parent("li").attr("aria-expanded",!0),!0===t&&this.$element.trigger("open.zf.drilldown",[e])}},{key:"_setHideSubMenuClasses",value:function(e,t){e.removeClass("is-active").addClass("invisible").attr("aria-hidden",!0),e.parent("li").attr("aria-expanded",!1),!0===t&&e.trigger("hide.zf.drilldown",[e])}},{key:"_showMenu",value:function(n,i){var o=this;if(this.$element.find('li[aria-expanded="true"] > ul[data-submenu]').each(function(e){o._setHideSubMenuClasses(a()(this))}),(this.$currentMenu=n).is("[data-drilldown]"))return!0===i&&n.find('li[role="treeitem"] > a').first().focus(),void(this.options.autoHeight&&this.$wrapper.css("height",n.data("calcHeight")));var r=n.children().first().parentsUntil("[data-drilldown]","[data-submenu]");r.each(function(e){0===e&&o.options.autoHeight&&o.$wrapper.css("height",a()(this).data("calcHeight"));var t=e==r.length-1;!0===t&&a()(this).one(Object(l.transitionend)(a()(this)),function(){!0===i&&n.find('li[role="treeitem"] > a').first().focus()}),o._setShowSubMenuClasses(a()(this),t)})}},{key:"_show",value:function(e){var t=e.children("[data-submenu]");e.attr("aria-expanded",!0),(this.$currentMenu=t).addClass("is-active").removeClass("invisible").attr("aria-hidden",!1),this.options.autoHeight&&this.$wrapper.css({height:t.data("calcHeight")}),this.$element.trigger("open.zf.drilldown",[e])}},{key:"_hide",value:function(e){this.options.autoHeight&&this.$wrapper.css({height:e.parent().closest("ul").data("calcHeight")});e.parent("li").attr("aria-expanded",!1),e.attr("aria-hidden",!0),e.addClass("is-closing").one(Object(l.transitionend)(e),function(){e.removeClass("is-active is-closing"),e.blur().addClass("invisible")}),e.trigger("hide.zf.drilldown",[e])}},{key:"_getMaxDims",value:function(){var t=0,e={},n=this;return this.$submenus.add(this.$element).each(function(){a()(this).children("li").length;var e=u.Box.GetDimensions(this).height;t=t<e?e:t,n.options.autoHeight&&a()(this).data("calcHeight",e)}),this.options.autoHeight?e.height=this.$currentMenu.data("calcHeight"):e["min-height"]="".concat(t,"px"),e["max-width"]="".concat(this.$element[0].getBoundingClientRect().width,"px"),e}},{key:"_destroy",value:function(){this.options.scrollTop&&this.$element.off(".zf.drilldown",this._bindHandler),this._hideAll(),this.$element.off("mutateme.zf.trigger"),r.Nest.Burn(this.$element,"drilldown"),this.$element.unwrap().find(".js-drilldown-back, .is-submenu-parent-item").remove().end().find(".is-active, .is-closing, .is-drilldown-submenu").removeClass("is-active is-closing is-drilldown-submenu").end().find("[data-submenu]").removeAttr("aria-hidden tabindex role"),this.$submenuAnchors.each(function(){a()(this).off(".zf.drilldown")}),this.$element.find("[data-is-parent-link]").detach(),this.$submenus.removeClass("drilldown-submenu-cover-previous invisible"),this.$element.find("a").each(function(){var e=a()(this);e.removeAttr("tabindex"),e.data("savedHref")&&e.attr("href",e.data("savedHref")).removeData("savedHref")})}}])&&d(t.prototype,i),o&&d(t,o),n}();h.defaults={autoApplyClass:!0,backButton:'<li class="js-drilldown-back"><a tabindex="0">Back</a></li>',backButtonPosition:"top",wrapper:"<div></div>",parentLink:!1,closeOnClick:!1,autoHeight:!1,animateHeight:!1,scrollTop:!1,scrollTopElement:"",scrollTopOffset:0,animationDuration:500,animationEasing:"swing"}},3:function(e,t,n){e.exports=n("./js/entries/plugins/foundation.drilldown.js")},jquery:function(e,t){e.exports=a}})});
+//# sourceMappingURL=foundation.drilldown.min.js.map
diff --git a/dist/js/plugins/foundation.drilldown.min.js.map b/dist/js/plugins/foundation.drilldown.min.js.map
new file mode 100644 (file)
index 0000000..986ba83
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.drilldown.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_box__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE__foundation_util_nest__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.box","./foundation.util.keyboard","./foundation.util.nest","./js/entries/plugins/foundation.drilldown.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_drilldown__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.drilldown.js","Drilldown","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_box__WEBPACK_IMPORTED_MODULE_4__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","register","ENTER","SPACE","ARROW_RIGHT","ARROW_UP","ARROW_DOWN","ARROW_LEFT","ESCAPE","TAB","SHIFT_TAB","Feather","autoApplyClass","addClass","attr","role","aria-multiselectable","$submenuAnchors","find","children","$submenus","parent","$menuItems","not","$currentMenu","_prepareMenu","_registerEvents","_keyboardEvents","_this","each","$link","$sub","parentLink","clone","prependTo","wrap","removeAttr","aria-hidden","tabindex","_events","$menu","backButtonPosition","append","backButton","prepend","console","error","_back","autoHeight","hasClass","$wrapper","wrapper","animateHeight","css","_getMaxDims","max-width","min-height","$elem","off","on","e","parentsUntil","stopImmediatePropagation","preventDefault","_show","closeOnClick","$body","contains","_hideAll","scrollTop","_bindHandler","_scrollTop","_resize","$scrollTopElement","scrollTopElement","scrollPos","parseInt","offset","top","scrollTopOffset","stop","animate","animationDuration","animationEasing","trigger","add","$prevElement","$nextElement","$elements","is","eq","Math","max","min","handleKey","next","one","first","focus","previous","_hide","setTimeout","up","down","close","siblings","open","handled","height","closest","removeClass","parentSubMenu","autoFocus","index","_setHideSubMenuClasses","isLastChild","_setShowSubMenuClasses","$submenu","blur","maxHeight","result","GetDimensions","concat","getBoundingClientRect","width","Burn","unwrap","remove","end","detach","removeData","3","jquery"],"mappings":"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","file":"foundation.drilldown.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.box\", \"./foundation.util.keyboard\", \"./foundation.util.nest\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.drilldown\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.drilldown\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.nest\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 3);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.box\":\n/*!********************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.box\"],\"amd\":\"./foundation.util.box\",\"commonjs\":\"./foundation.util.box\",\"commonjs2\":\"./foundation.util.box\"} ***!\n  \\********************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./foundation.util.nest\":\n/*!************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.nest\"],\"amd\":\"./foundation.util.nest\",\"commonjs\":\"./foundation.util.nest\",\"commonjs2\":\"./foundation.util.nest\"} ***!\n  \\************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.drilldown.js\":\n/*!****************************************************!*\\\n  !*** ./js/entries/plugins/foundation.drilldown.js ***!\n  \\****************************************************/\n/*! exports provided: Foundation, Drilldown */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.drilldown */ \"./js/foundation.drilldown.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Drilldown\", function() { return _foundation_drilldown__WEBPACK_IMPORTED_MODULE_1__[\"Drilldown\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_drilldown__WEBPACK_IMPORTED_MODULE_1__[\"Drilldown\"], 'Drilldown');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.drilldown.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.drilldown.js ***!\n  \\************************************/\n/*! exports provided: Drilldown */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Drilldown\", function() { return Drilldown; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.nest */ \"./foundation.util.nest\");\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.box */ \"./foundation.util.box\");\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_box__WEBPACK_IMPORTED_MODULE_4__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n/**\n * Drilldown module.\n * @module foundation.drilldown\n * @requires foundation.util.keyboard\n * @requires foundation.util.nest\n * @requires foundation.util.box\n */\n\nvar Drilldown =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Drilldown, _Plugin);\n\n  function Drilldown() {\n    _classCallCheck(this, Drilldown);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Drilldown).apply(this, arguments));\n  }\n\n  _createClass(Drilldown, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a drilldown menu.\n     * @class\n     * @name Drilldown\n     * @param {jQuery} element - jQuery object to make into an accordion menu.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Drilldown.defaults, this.$element.data(), options);\n      this.className = 'Drilldown'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('Drilldown', {\n        'ENTER': 'open',\n        'SPACE': 'open',\n        'ARROW_RIGHT': 'next',\n        'ARROW_UP': 'up',\n        'ARROW_DOWN': 'down',\n        'ARROW_LEFT': 'previous',\n        'ESCAPE': 'close',\n        'TAB': 'down',\n        'SHIFT_TAB': 'up'\n      });\n    }\n    /**\n     * Initializes the drilldown by creating jQuery collections of elements\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__[\"Nest\"].Feather(this.$element, 'drilldown');\n\n      if (this.options.autoApplyClass) {\n        this.$element.addClass('drilldown');\n      }\n\n      this.$element.attr({\n        'role': 'tree',\n        'aria-multiselectable': false\n      });\n      this.$submenuAnchors = this.$element.find('li.is-drilldown-submenu-parent').children('a');\n      this.$submenus = this.$submenuAnchors.parent('li').children('[data-submenu]').attr('role', 'group');\n      this.$menuItems = this.$element.find('li').not('.js-drilldown-back').attr('role', 'treeitem').find('a'); // Set the main menu as current by default (unless a submenu is selected)\n      // Used to set the wrapper height when the drilldown is closed/reopened from any (sub)menu\n\n      this.$currentMenu = this.$element;\n      this.$element.attr('data-mutate', this.$element.attr('data-drilldown') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'drilldown'));\n\n      this._prepareMenu();\n\n      this._registerEvents();\n\n      this._keyboardEvents();\n    }\n    /**\n     * prepares drilldown menu by setting attributes to links and elements\n     * sets a min height to prevent content jumping\n     * wraps the element if not already wrapped\n     * @private\n     * @function\n     */\n\n  }, {\n    key: \"_prepareMenu\",\n    value: function _prepareMenu() {\n      var _this = this; // if(!this.options.holdOpen){\n      //   this._menuLinkEvents();\n      // }\n\n\n      this.$submenuAnchors.each(function () {\n        var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n        var $sub = $link.parent();\n\n        if (_this.options.parentLink) {\n          $link.clone().prependTo($sub.children('[data-submenu]')).wrap('<li data-is-parent-link class=\"is-submenu-parent-item is-submenu-item is-drilldown-submenu-item\" role=\"menuitem\"></li>');\n        }\n\n        $link.data('savedHref', $link.attr('href')).removeAttr('href').attr('tabindex', 0);\n        $link.children('[data-submenu]').attr({\n          'aria-hidden': true,\n          'tabindex': 0,\n          'role': 'group'\n        });\n\n        _this._events($link);\n      });\n      this.$submenus.each(function () {\n        var $menu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $back = $menu.find('.js-drilldown-back');\n\n        if (!$back.length) {\n          switch (_this.options.backButtonPosition) {\n            case \"bottom\":\n              $menu.append(_this.options.backButton);\n              break;\n\n            case \"top\":\n              $menu.prepend(_this.options.backButton);\n              break;\n\n            default:\n              console.error(\"Unsupported backButtonPosition value '\" + _this.options.backButtonPosition + \"'\");\n          }\n        }\n\n        _this._back($menu);\n      });\n      this.$submenus.addClass('invisible');\n\n      if (!this.options.autoHeight) {\n        this.$submenus.addClass('drilldown-submenu-cover-previous');\n      } // create a wrapper on element if it doesn't exist.\n\n\n      if (!this.$element.parent().hasClass('is-drilldown')) {\n        this.$wrapper = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.wrapper).addClass('is-drilldown');\n        if (this.options.animateHeight) this.$wrapper.addClass('animate-height');\n        this.$element.wrap(this.$wrapper);\n      } // set wrapper\n\n\n      this.$wrapper = this.$element.parent();\n      this.$wrapper.css(this._getMaxDims());\n    }\n  }, {\n    key: \"_resize\",\n    value: function _resize() {\n      this.$wrapper.css({\n        'max-width': 'none',\n        'min-height': 'none'\n      }); // _getMaxDims has side effects (boo) but calling it should update all other necessary heights & widths\n\n      this.$wrapper.css(this._getMaxDims());\n    }\n    /**\n     * Adds event handlers to elements in the menu.\n     * @function\n     * @private\n     * @param {jQuery} $elem - the current menu item to add handlers to.\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events($elem) {\n      var _this = this;\n\n      $elem.off('click.zf.drilldown').on('click.zf.drilldown', function (e) {\n        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', 'li').hasClass('is-drilldown-submenu-parent')) {\n          e.stopImmediatePropagation();\n          e.preventDefault();\n        } // if(e.target !== e.currentTarget.firstElementChild){\n        //   return false;\n        // }\n\n\n        _this._show($elem.parent('li'));\n\n        if (_this.options.closeOnClick) {\n          var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');\n          $body.off('.zf.drilldown').on('click.zf.drilldown', function (e) {\n            if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target)) {\n              return;\n            }\n\n            e.preventDefault();\n\n            _this._hideAll();\n\n            $body.off('.zf.drilldown');\n          });\n        }\n      });\n    }\n    /**\n     * Adds event handlers to the menu element.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_registerEvents\",\n    value: function _registerEvents() {\n      if (this.options.scrollTop) {\n        this._bindHandler = this._scrollTop.bind(this);\n        this.$element.on('open.zf.drilldown hide.zf.drilldown closed.zf.drilldown', this._bindHandler);\n      }\n\n      this.$element.on('mutateme.zf.trigger', this._resize.bind(this));\n    }\n    /**\n     * Scroll to Top of Element or data-scroll-top-element\n     * @function\n     * @fires Drilldown#scrollme\n     */\n\n  }, {\n    key: \"_scrollTop\",\n    value: function _scrollTop() {\n      var _this = this;\n\n      var $scrollTopElement = _this.options.scrollTopElement != '' ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(_this.options.scrollTopElement) : _this.$element,\n          scrollPos = parseInt($scrollTopElement.offset().top + _this.options.scrollTopOffset, 10);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({\n        scrollTop: scrollPos\n      }, _this.options.animationDuration, _this.options.animationEasing, function () {\n        /**\n          * Fires after the menu has scrolled\n          * @event Drilldown#scrollme\n          */\n        if (this === jquery__WEBPACK_IMPORTED_MODULE_0___default()('html')[0]) _this.$element.trigger('scrollme.zf.drilldown');\n      });\n    }\n    /**\n     * Adds keydown event listener to `li`'s in the menu.\n     * @private\n     */\n\n  }, {\n    key: \"_keyboardEvents\",\n    value: function _keyboardEvents() {\n      var _this = this;\n\n      this.$menuItems.add(this.$element.find('.js-drilldown-back > a, .is-submenu-parent-item > a')).on('keydown.zf.drilldown', function (e) {\n        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $elements = $element.parent('li').parent('ul').children('li').children('a'),\n            $prevElement,\n            $nextElement;\n        $elements.each(function (i) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {\n            $prevElement = $elements.eq(Math.max(0, i - 1));\n            $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));\n            return;\n          }\n        });\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'Drilldown', {\n          next: function next() {\n            if ($element.is(_this.$submenuAnchors)) {\n              _this._show($element.parent('li'));\n\n              $element.parent('li').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($element), function () {\n                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n              });\n              return true;\n            }\n          },\n          previous: function previous() {\n            _this._hide($element.parent('li').parent('ul'));\n\n            $element.parent('li').parent('ul').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($element), function () {\n              setTimeout(function () {\n                $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n              }, 1);\n            });\n            return true;\n          },\n          up: function up() {\n            $prevElement.focus(); // Don't tap focus on first element in root ul\n\n            return !$element.is(_this.$element.find('> li:first-child > a'));\n          },\n          down: function down() {\n            $nextElement.focus(); // Don't tap focus on last element in root ul\n\n            return !$element.is(_this.$element.find('> li:last-child > a'));\n          },\n          close: function close() {\n            // Don't close on element in root ul\n            if (!$element.is(_this.$element.find('> li > a'))) {\n              _this._hide($element.parent().parent());\n\n              $element.parent().parent().siblings('a').focus();\n            }\n          },\n          open: function open() {\n            if (_this.options.parentLink && $element.attr('href')) {\n              // Link with href\n              return false;\n            } else if (!$element.is(_this.$menuItems)) {\n              // not menu item means back button\n              _this._hide($element.parent('li').parent('ul'));\n\n              $element.parent('li').parent('ul').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($element), function () {\n                setTimeout(function () {\n                  $element.parent('li').parent('ul').parent('li').children('a').first().focus();\n                }, 1);\n              });\n              return true;\n            } else if ($element.is(_this.$submenuAnchors)) {\n              // Sub menu item\n              _this._show($element.parent('li'));\n\n              $element.parent('li').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($element), function () {\n                $element.parent('li').find('ul li a').not('.js-drilldown-back a').first().focus();\n              });\n              return true;\n            }\n          },\n          handled: function handled(preventDefault) {\n            if (preventDefault) {\n              e.preventDefault();\n            }\n\n            e.stopImmediatePropagation();\n          }\n        });\n      }); // end keyboardAccess\n    }\n    /**\n     * Closes all open elements, and returns to root menu.\n     * @function\n     * @fires Drilldown#closed\n     */\n\n  }, {\n    key: \"_hideAll\",\n    value: function _hideAll() {\n      var $elem = this.$element.find('.is-drilldown-submenu.is-active').addClass('is-closing');\n      if (this.options.autoHeight) this.$wrapper.css({\n        height: $elem.parent().closest('ul').data('calcHeight')\n      });\n      $elem.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($elem), function (e) {\n        $elem.removeClass('is-active is-closing');\n      });\n      /**\n       * Fires when the menu is fully closed.\n       * @event Drilldown#closed\n       */\n\n      this.$element.trigger('closed.zf.drilldown');\n    }\n    /**\n     * Adds event listener for each `back` button, and closes open menus.\n     * @function\n     * @fires Drilldown#back\n     * @param {jQuery} $elem - the current sub-menu to add `back` event.\n     */\n\n  }, {\n    key: \"_back\",\n    value: function _back($elem) {\n      var _this = this;\n\n      $elem.off('click.zf.drilldown');\n      $elem.children('.js-drilldown-back').on('click.zf.drilldown', function (e) {\n        e.stopImmediatePropagation(); // console.log('mouseup on back');\n\n        _this._hide($elem); // If there is a parent submenu, call show\n\n\n        var parentSubMenu = $elem.parent('li').parent('ul').parent('li');\n\n        if (parentSubMenu.length) {\n          _this._show(parentSubMenu);\n        }\n      });\n    }\n    /**\n     * Adds event listener to menu items w/o submenus to close open menus on click.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_menuLinkEvents\",\n    value: function _menuLinkEvents() {\n      var _this = this;\n\n      this.$menuItems.not('.is-drilldown-submenu-parent').off('click.zf.drilldown').on('click.zf.drilldown', function (e) {\n        // e.stopImmediatePropagation();\n        setTimeout(function () {\n          _this._hideAll();\n        }, 0);\n      });\n    }\n    /**\n     * Sets the CSS classes for submenu to show it.\n     * @function\n     * @private\n     * @param {jQuery} $elem - the target submenu (`ul` tag)\n     * @param {boolean} trigger - trigger drilldown event\n     */\n\n  }, {\n    key: \"_setShowSubMenuClasses\",\n    value: function _setShowSubMenuClasses($elem, trigger) {\n      $elem.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n      $elem.parent('li').attr('aria-expanded', true);\n\n      if (trigger === true) {\n        this.$element.trigger('open.zf.drilldown', [$elem]);\n      }\n    }\n    /**\n     * Sets the CSS classes for submenu to hide it.\n     * @function\n     * @private\n     * @param {jQuery} $elem - the target submenu (`ul` tag)\n     * @param {boolean} trigger - trigger drilldown event\n     */\n\n  }, {\n    key: \"_setHideSubMenuClasses\",\n    value: function _setHideSubMenuClasses($elem, trigger) {\n      $elem.removeClass('is-active').addClass('invisible').attr('aria-hidden', true);\n      $elem.parent('li').attr('aria-expanded', false);\n\n      if (trigger === true) {\n        $elem.trigger('hide.zf.drilldown', [$elem]);\n      }\n    }\n    /**\n     * Opens a specific drilldown (sub)menu no matter which (sub)menu in it is currently visible.\n     * Compared to _show() this lets you jump into any submenu without clicking through every submenu on the way to it.\n     * @function\n     * @fires Drilldown#open\n     * @param {jQuery} $elem - the target (sub)menu (`ul` tag)\n     * @param {boolean} autoFocus - if true the first link in the target (sub)menu gets auto focused\n     */\n\n  }, {\n    key: \"_showMenu\",\n    value: function _showMenu($elem, autoFocus) {\n      var _this = this; // Reset drilldown\n\n\n      var $expandedSubmenus = this.$element.find('li[aria-expanded=\"true\"] > ul[data-submenu]');\n      $expandedSubmenus.each(function (index) {\n        _this._setHideSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n      }); // Save the menu as the currently displayed one.\n\n      this.$currentMenu = $elem; // If target menu is root, focus first link & exit\n\n      if ($elem.is('[data-drilldown]')) {\n        if (autoFocus === true) $elem.find('li[role=\"treeitem\"] > a').first().focus();\n        if (this.options.autoHeight) this.$wrapper.css('height', $elem.data('calcHeight'));\n        return;\n      } // Find all submenus on way to root incl. the element itself\n\n\n      var $submenus = $elem.children().first().parentsUntil('[data-drilldown]', '[data-submenu]'); // Open target menu and all submenus on its way to root\n\n      $submenus.each(function (index) {\n        // Update height of first child (target menu) if autoHeight option true\n        if (index === 0 && _this.options.autoHeight) {\n          _this.$wrapper.css('height', jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight'));\n        }\n\n        var isLastChild = index == $submenus.length - 1; // Add transitionsend listener to last child (root due to reverse order) to open target menu's first link\n        // Last child makes sure the event gets always triggered even if going through several menus\n\n        if (isLastChild === true) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)), function () {\n            if (autoFocus === true) {\n              $elem.find('li[role=\"treeitem\"] > a').first().focus();\n            }\n          });\n        }\n\n        _this._setShowSubMenuClasses(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), isLastChild);\n      });\n    }\n    /**\n     * Opens a submenu.\n     * @function\n     * @fires Drilldown#open\n     * @param {jQuery} $elem - the current element with a submenu to open, i.e. the `li` tag.\n     */\n\n  }, {\n    key: \"_show\",\n    value: function _show($elem) {\n      var $submenu = $elem.children('[data-submenu]');\n      $elem.attr('aria-expanded', true);\n      this.$currentMenu = $submenu;\n      $submenu.addClass('is-active').removeClass('invisible').attr('aria-hidden', false);\n\n      if (this.options.autoHeight) {\n        this.$wrapper.css({\n          height: $submenu.data('calcHeight')\n        });\n      }\n      /**\n       * Fires when the submenu has opened.\n       * @event Drilldown#open\n       */\n\n\n      this.$element.trigger('open.zf.drilldown', [$elem]);\n    }\n    /**\n     * Hides a submenu\n     * @function\n     * @fires Drilldown#hide\n     * @param {jQuery} $elem - the current sub-menu to hide, i.e. the `ul` tag.\n     */\n\n  }, {\n    key: \"_hide\",\n    value: function _hide($elem) {\n      if (this.options.autoHeight) this.$wrapper.css({\n        height: $elem.parent().closest('ul').data('calcHeight')\n      });\n\n      var _this = this;\n\n      $elem.parent('li').attr('aria-expanded', false);\n      $elem.attr('aria-hidden', true);\n      $elem.addClass('is-closing').one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"transitionend\"])($elem), function () {\n        $elem.removeClass('is-active is-closing');\n        $elem.blur().addClass('invisible');\n      });\n      /**\n       * Fires when the submenu has closed.\n       * @event Drilldown#hide\n       */\n\n      $elem.trigger('hide.zf.drilldown', [$elem]);\n    }\n    /**\n     * Iterates through the nested menus to calculate the min-height, and max-width for the menu.\n     * Prevents content jumping.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_getMaxDims\",\n    value: function _getMaxDims() {\n      var maxHeight = 0,\n          result = {},\n          _this = this; // Recalculate menu heights and total max height\n\n\n      this.$submenus.add(this.$element).each(function () {\n        var numOfElems = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).children('li').length;\n        var height = _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__[\"Box\"].GetDimensions(this).height;\n        maxHeight = height > maxHeight ? height : maxHeight;\n\n        if (_this.options.autoHeight) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('calcHeight', height);\n        }\n      });\n      if (this.options.autoHeight) result['height'] = this.$currentMenu.data('calcHeight');else result['min-height'] = \"\".concat(maxHeight, \"px\");\n      result['max-width'] = \"\".concat(this.$element[0].getBoundingClientRect().width, \"px\");\n      return result;\n    }\n    /**\n     * Destroys the Drilldown Menu\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      if (this.options.scrollTop) this.$element.off('.zf.drilldown', this._bindHandler);\n\n      this._hideAll();\n\n      this.$element.off('mutateme.zf.trigger');\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_2__[\"Nest\"].Burn(this.$element, 'drilldown');\n      this.$element.unwrap().find('.js-drilldown-back, .is-submenu-parent-item').remove().end().find('.is-active, .is-closing, .is-drilldown-submenu').removeClass('is-active is-closing is-drilldown-submenu').end().find('[data-submenu]').removeAttr('aria-hidden tabindex role');\n      this.$submenuAnchors.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off('.zf.drilldown');\n      });\n      this.$element.find('[data-is-parent-link]').detach();\n      this.$submenus.removeClass('drilldown-submenu-cover-previous invisible');\n      this.$element.find('a').each(function () {\n        var $link = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n        $link.removeAttr('tabindex');\n\n        if ($link.data('savedHref')) {\n          $link.attr('href', $link.data('savedHref')).removeData('savedHref');\n        } else {\n          return;\n        }\n      });\n    }\n  }]);\n\n  return Drilldown;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nDrilldown.defaults = {\n  /**\n   * Drilldowns depend on styles in order to function properly; in the default build of Foundation these are\n   * on the `drilldown` class. This option auto-applies this class to the drilldown upon initialization.\n   * @option\n   * @type {boolian}\n   * @default true\n   */\n  autoApplyClass: true,\n\n  /**\n   * Markup used for JS generated back button. Prepended  or appended (see backButtonPosition) to submenu lists and deleted on `destroy` method, 'js-drilldown-back' class required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>'\n   */\n  backButton: '<li class=\"js-drilldown-back\"><a tabindex=\"0\">Back</a></li>',\n\n  /**\n   * Position the back button either at the top or bottom of drilldown submenus. Can be `'left'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default top\n   */\n  backButtonPosition: 'top',\n\n  /**\n   * Markup used to wrap drilldown menu. Use a class name for independent styling; the JS applied class: `is-drilldown` is required. Remove the backslash (`\\`) if copy and pasting.\n   * @option\n   * @type {string}\n   * @default '<div></div>'\n   */\n  wrapper: '<div></div>',\n\n  /**\n   * Adds the parent link to the submenu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  parentLink: false,\n\n  /**\n   * Allow the menu to return to root list on body click.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false,\n\n  /**\n   * Allow the menu to auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoHeight: false,\n\n  /**\n   * Animate the auto adjust height.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animateHeight: false,\n\n  /**\n   * Scroll to the top of the menu after opening a submenu or navigating back using the menu back button\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  scrollTop: false,\n\n  /**\n   * String jquery selector (for example 'body') of element to take offset().top from, if empty string the drilldown menu offset().top is taken\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  scrollTopElement: '',\n\n  /**\n   * ScrollTop offset\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  scrollTopOffset: 0,\n\n  /**\n   * Scroll animation duration\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n\n  /**\n   * Scroll animation easing. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @see {@link https://api.jquery.com/animate|JQuery animate}\n   * @default 'swing'\n   */\n  animationEasing: 'swing' // holdOpen: false\n\n};\n\n\n/***/ }),\n\n/***/ 3:\n/*!**********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.drilldown.js ***!\n  \\**********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.drilldown.js */\"./js/entries/plugins/foundation.drilldown.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.drilldown.js.map"]}
\ No newline at end of file
index 7a43c06da70aeac3c7639a499182ae00f07c1371..022ea460efc926692f8626021799514bdf0a0d7e 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.util.keyboard"), require("./foundation.core"), require("jquery"), require("./foundation.util.box"), require("./foundation.util.motion"), require("./foundation.util.touch"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.util.keyboard", "./foundation.core", "jquery", "./foundation.util.box", "./foundation.util.motion", "./foundation.util.touch"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.dropdown"] = factory(require("./foundation.util.keyboard"), require("./foundation.core"), require("jquery"), require("./foundation.util.box"), require("./foundation.util.motion"), require("./foundation.util.touch"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.dropdown"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.box"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.touch"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 83);
+/******/       return __webpack_require__(__webpack_require__.s = 4);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.box":
+/*!********************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.box"],"amd":"./foundation.util.box","commonjs":"./foundation.util.box","commonjs2":"./foundation.util.box"} ***!
+  \********************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;
 
 /***/ }),
 
-/***/ 11:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
-
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Positionable; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__ = __webpack_require__(8);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_util_box___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__);
-
-
-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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
-
-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; }
-
-
-
-
-
-var POSITIONS = ['left', 'right', 'top', 'bottom'];
-var VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];
-var HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];
-
-var ALIGNMENTS = {
-  'left': VERTICAL_ALIGNMENTS,
-  'right': VERTICAL_ALIGNMENTS,
-  'top': HORIZONTAL_ALIGNMENTS,
-  'bottom': HORIZONTAL_ALIGNMENTS
-};
-
-function nextItem(item, array) {
-  var currentIdx = array.indexOf(item);
-  if (currentIdx === array.length - 1) {
-    return array[0];
-  } else {
-    return array[currentIdx + 1];
-  }
-}
-
-var Positionable = function (_Plugin) {
-  _inherits(Positionable, _Plugin);
-
-  function Positionable() {
-    _classCallCheck(this, Positionable);
-
-    return _possibleConstructorReturn(this, (Positionable.__proto__ || Object.getPrototypeOf(Positionable)).apply(this, arguments));
-  }
-
-  _createClass(Positionable, [{
-    key: '_init',
-
-    /**
-     * Abstract class encapsulating the tether-like explicit positioning logic
-     * including repositioning based on overlap.
-     * Expects classes to define defaults for vOffset, hOffset, position,
-     * alignment, allowOverlap, and allowBottomOverlap. They can do this by
-     * extending the defaults, or (for now recommended due to the way docs are
-     * generated) by explicitly declaring them.
-     *
-     **/
-
-    value: function _init() {
-      this.triedPositions = {};
-      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;
-      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;
-    }
-  }, {
-    key: '_getDefaultPosition',
-    value: function _getDefaultPosition() {
-      return 'bottom';
-    }
-  }, {
-    key: '_getDefaultAlignment',
-    value: function _getDefaultAlignment() {
-      switch (this.position) {
-        case 'bottom':
-        case 'top':
-          return __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["rtl"])() ? 'right' : 'left';
-        case 'left':
-        case 'right':
-          return 'bottom';
-      }
-    }
-
-    /**
-     * Adjusts the positionable possible positions by iterating through alignments
-     * and positions.
-     * @function
-     * @private
-     */
-
-  }, {
-    key: '_reposition',
-    value: function _reposition() {
-      if (this._alignmentsExhausted(this.position)) {
-        this.position = nextItem(this.position, POSITIONS);
-        this.alignment = ALIGNMENTS[this.position][0];
-      } else {
-        this._realign();
-      }
-    }
-
-    /**
-     * Adjusts the dropdown pane possible positions by iterating through alignments
-     * on the current position.
-     * @function
-     * @private
-     */
-
-  }, {
-    key: '_realign',
-    value: function _realign() {
-      this._addTriedPosition(this.position, this.alignment);
-      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);
-    }
-  }, {
-    key: '_addTriedPosition',
-    value: function _addTriedPosition(position, alignment) {
-      this.triedPositions[position] = this.triedPositions[position] || [];
-      this.triedPositions[position].push(alignment);
-    }
-  }, {
-    key: '_positionsExhausted',
-    value: function _positionsExhausted() {
-      var isExhausted = true;
-      for (var i = 0; i < POSITIONS.length; i++) {
-        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);
-      }
-      return isExhausted;
-    }
-  }, {
-    key: '_alignmentsExhausted',
-    value: function _alignmentsExhausted(position) {
-      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;
-    }
-
-    // When we're trying to center, we don't want to apply offset that's going to
-    // take us just off center, so wrap around to return 0 for the appropriate
-    // offset in those alignments.  TODO: Figure out if we want to make this
-    // configurable behavior... it feels more intuitive, especially for tooltips, but
-    // it's possible someone might actually want to start from center and then nudge
-    // slightly off.
-
-  }, {
-    key: '_getVOffset',
-    value: function _getVOffset() {
-      return this.options.vOffset;
-    }
-  }, {
-    key: '_getHOffset',
-    value: function _getHOffset() {
-      return this.options.hOffset;
-    }
-  }, {
-    key: '_setPosition',
-    value: function _setPosition($anchor, $element, $parent) {
-      if ($anchor.attr('aria-expanded') === 'false') {
-        return false;
-      }
-      var $eleDims = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetDimensions($element),
-          $anchorDims = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetDimensions($anchor);
-
-      $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
-
-      if (!this.options.allowOverlap) {
-        var overlaps = {};
-        var minOverlap = 100000000;
-        // default coordinates to how we start, in case we can't figure out better
-        var minCoordinates = { position: this.position, alignment: this.alignment };
-        while (!this._positionsExhausted()) {
-          var overlap = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
-          if (overlap === 0) {
-            return;
-          }
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-          if (overlap < minOverlap) {
-            minOverlap = overlap;
-            minCoordinates = { position: this.position, alignment: this.alignment };
-          }
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
-          this._reposition();
+/***/ }),
 
-          $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
-        }
-        // If we get through the entire loop, there was no non-overlapping
-        // position available. Pick the version with least overlap.
-        this.position = minCoordinates.position;
-        this.alignment = minCoordinates.alignment;
-        $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
-      }
-    }
-  }]);
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-  return Positionable;
-}(__WEBPACK_IMPORTED_MODULE_1__foundation_plugin__["Plugin"]);
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
-Positionable.defaults = {
-  /**
-   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.
-   * @option
-   * @type {string}
-   * @default 'auto'
-   */
-  position: 'auto',
-  /**
-   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.
-   * @option
-   * @type {string}
-   * @default 'auto'
-   */
-  alignment: 'auto',
-  /**
-   * Allow overlap of container/window. If false, dropdown positionable first
-   * try to position as defined by data-position and data-alignment, but
-   * reposition if it would cause an overflow.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  allowOverlap: false,
-  /**
-   * Allow overlap of only the bottom of the container. This is the most common
-   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
-   * screen but not otherwise influence or break out of the container.
-   * @option
-   * @type {boolean}
-   * @default true
-   */
-  allowBottomOverlap: true,
-  /**
-   * Number of pixels the positionable should be separated vertically from anchor
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  vOffset: 0,
-  /**
-   * Number of pixels the positionable should be separated horizontally from anchor
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  hOffset: 0
-};
+/***/ }),
 
+/***/ "./foundation.util.touch":
+/*!****************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.touch"],"amd":"./foundation.util.touch","commonjs":"./foundation.util.touch","commonjs2":"./foundation.util.touch"} ***!
+  \****************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;
 
 /***/ }),
 
-/***/ 17:
+/***/ "./js/entries/plugins/foundation.dropdown.js":
+/*!***************************************************!*\
+  !*** ./js/entries/plugins/foundation.dropdown.js ***!
+  \***************************************************/
+/*! exports provided: Foundation, Dropdown */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_dropdown__ = __webpack_require__(47);
-
-
-
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_dropdown__["a" /* Dropdown */], 'Dropdown');
-
-/***/ }),
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-/***/ 2:
-/***/ (function(module, exports) {
+/* harmony import */ var _foundation_dropdown__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.dropdown */ "./js/foundation.dropdown.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Dropdown", function() { return _foundation_dropdown__WEBPACK_IMPORTED_MODULE_1__["Dropdown"]; });
 
-module.exports = {Plugin: window.Foundation.Plugin};
 
-/***/ }),
 
-/***/ 3:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_dropdown__WEBPACK_IMPORTED_MODULE_1__["Dropdown"], 'Dropdown');
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
 /***/ }),
 
-/***/ 4:
-/***/ (function(module, exports) {
+/***/ "./js/foundation.dropdown.js":
+/*!***********************************!*\
+  !*** ./js/foundation.dropdown.js ***!
+  \***********************************/
+/*! exports provided: Dropdown */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Dropdown", function() { return Dropdown; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_positionable__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.positionable */ "./js/foundation.positionable.js");
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.touch */ "./foundation.util.touch");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-/***/ }),
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-/***/ 47:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+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); } }
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Dropdown; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_positionable__ = __webpack_require__(11);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_triggers__ = __webpack_require__(7);
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
-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 _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-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); } };
+function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); }
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }
 
-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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-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 _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -413,17 +232,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.triggers
  */
 
-var Dropdown = function (_Positionable) {
+var Dropdown =
+/*#__PURE__*/
+function (_Positionable) {
   _inherits(Dropdown, _Positionable);
 
   function Dropdown() {
     _classCallCheck(this, Dropdown);
 
-    return _possibleConstructorReturn(this, (Dropdown.__proto__ || Object.getPrototypeOf(Dropdown)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Dropdown).apply(this, arguments));
   }
 
   _createClass(Dropdown, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of a dropdown.
@@ -435,21 +256,20 @@ var Dropdown = function (_Positionable) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Dropdown.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Dropdown.defaults, this.$element.data(), options);
       this.className = 'Dropdown'; // ie9 back compat
-
       // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_4__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('Dropdown', {
-        'ENTER': 'open',
-        'SPACE': 'open',
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('Dropdown', {
+        'ENTER': 'toggle',
+        'SPACE': 'toggle',
         'ESCAPE': 'close'
       });
     }
-
     /**
      * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.
      * @function
@@ -457,11 +277,10 @@ var Dropdown = function (_Positionable) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
       var $id = this.$element.attr('id');
-
-      this.$anchors = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-toggle="' + $id + '"]').length ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-toggle="' + $id + '"]') : __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-open="' + $id + '"]');
+      this.$anchors = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat($id, "\"]")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat($id, "\"]")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat($id, "\"]"));
       this.$anchors.attr({
         'aria-controls': $id,
         'data-is-focus': false,
@@ -476,22 +295,35 @@ var Dropdown = function (_Positionable) {
         this.$parent = this.$element.parents('.' + this.options.parentClass);
       } else {
         this.$parent = null;
+      } // Set [aria-labelledby] on the Dropdown if it is not set
+
+
+      if (typeof this.$element.attr('aria-labelledby') === 'undefined') {
+        // Get the anchor ID or create one
+        if (typeof this.$currentAnchor.attr('id') === 'undefined') {
+          this.$currentAnchor.attr('id', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'dd-anchor'));
+        }
+
+        ;
+        this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));
       }
 
       this.$element.attr({
         'aria-hidden': 'true',
         'data-yeti-box': $id,
-        'data-resize': $id,
-        'aria-labelledby': this.$currentAnchor.id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["GetYoDigits"])(6, 'dd-anchor')
+        'data-resize': $id
       });
-      _get(Dropdown.prototype.__proto__ || Object.getPrototypeOf(Dropdown.prototype), '_init', this).call(this);
+
+      _get(_getPrototypeOf(Dropdown.prototype), "_init", this).call(this);
+
       this._events();
     }
   }, {
-    key: '_getDefaultPosition',
+    key: "_getDefaultPosition",
     value: function _getDefaultPosition() {
       // handle legacy classnames
       var position = this.$element[0].className.match(/(top|left|right|bottom)/g);
+
       if (position) {
         return position[0];
       } else {
@@ -499,17 +331,17 @@ var Dropdown = function (_Positionable) {
       }
     }
   }, {
-    key: '_getDefaultAlignment',
+    key: "_getDefaultAlignment",
     value: function _getDefaultAlignment() {
       // handle legacy float approach
-      var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.className);
+      var horizontalPosition = /float-(\S+)/.exec(this.$currentAnchor.attr('class'));
+
       if (horizontalPosition) {
         return horizontalPosition[1];
       }
 
-      return _get(Dropdown.prototype.__proto__ || Object.getPrototypeOf(Dropdown.prototype), '_getDefaultAlignment', this).call(this);
+      return _get(_getPrototypeOf(Dropdown.prototype), "_getDefaultAlignment", this).call(this);
     }
-
     /**
      * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.
      * Recursively calls itself if a collision is detected, with a new position class.
@@ -518,11 +350,14 @@ var Dropdown = function (_Positionable) {
      */
 
   }, {
-    key: '_setPosition',
+    key: "_setPosition",
     value: function _setPosition() {
-      _get(Dropdown.prototype.__proto__ || Object.getPrototypeOf(Dropdown.prototype), '_setPosition', this).call(this, this.$currentAnchor, this.$element, this.$parent);
-    }
+      this.$element.removeClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment));
 
+      _get(_getPrototypeOf(Dropdown.prototype), "_setPosition", this).call(this, this.$currentAnchor, this.$element, this.$parent);
+
+      this.$element.addClass("has-position-".concat(this.position, " has-alignment-").concat(this.alignment));
+    }
     /**
      * Make it a current anchor.
      * Current anchor as the reference for the position of Dropdown panes.
@@ -532,11 +367,10 @@ var Dropdown = function (_Positionable) {
      */
 
   }, {
-    key: '_setCurrentAnchor',
+    key: "_setCurrentAnchor",
     value: function _setCurrentAnchor(el) {
-      this.$currentAnchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el);
+      this.$currentAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el);
     }
-
     /**
      * Adds event listeners to the element utilizing the triggers utility library.
      * @function
@@ -544,16 +378,16 @@ var Dropdown = function (_Positionable) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this;
+
       this.$element.on({
         'open.zf.trigger': this.open.bind(this),
         'close.zf.trigger': this.close.bind(this),
         'toggle.zf.trigger': this.toggle.bind(this),
         'resizeme.zf.trigger': this._setPosition.bind(this)
       });
-
       this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function () {
         _this._setCurrentAnchor(this);
       });
@@ -562,54 +396,60 @@ var Dropdown = function (_Positionable) {
         this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
           _this._setCurrentAnchor(this);
 
-          var bodyData = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').data();
+          var bodyData = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').data();
+
           if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') {
             clearTimeout(_this.timeout);
             _this.timeout = setTimeout(function () {
               _this.open();
+
               _this.$anchors.data('hover', true);
             }, _this.options.hoverDelay);
           }
-        }).on('mouseleave.zf.dropdown', function () {
+        }).on('mouseleave.zf.dropdown', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["ignoreMousedisappear"])(function () {
           clearTimeout(_this.timeout);
           _this.timeout = setTimeout(function () {
             _this.close();
+
             _this.$anchors.data('hover', false);
           }, _this.options.hoverDelay);
-        });
+        }));
+
         if (this.options.hoverPane) {
           this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {
             clearTimeout(_this.timeout);
-          }).on('mouseleave.zf.dropdown', function () {
+          }).on('mouseleave.zf.dropdown', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["ignoreMousedisappear"])(function () {
             clearTimeout(_this.timeout);
             _this.timeout = setTimeout(function () {
               _this.close();
+
               _this.$anchors.data('hover', false);
             }, _this.options.hoverDelay);
-          });
+          }));
         }
       }
-      this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) {
-
-        var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            visibleFocusableElements = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].findFocusable(_this.$element);
 
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'Dropdown', {
-          open: function () {
-            if ($target.is(_this.$anchors)) {
+      this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) {
+        var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            visibleFocusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].findFocusable(_this.$element);
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'Dropdown', {
+          open: function open() {
+            if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {
               _this.open();
+
               _this.$element.attr('tabindex', -1).focus();
+
               e.preventDefault();
             }
           },
-          close: function () {
+          close: function close() {
             _this.close();
+
             _this.$anchors.focus();
           }
         });
       });
     }
-
     /**
      * Adds an event handler to the body to close any dropdowns on a click.
      * @function
@@ -617,22 +457,25 @@ var Dropdown = function (_Positionable) {
      */
 
   }, {
-    key: '_addBodyHandler',
+    key: "_addBodyHandler",
     value: function _addBodyHandler() {
-      var $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document.body).not(this.$element),
+      var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).not(this.$element),
           _this = this;
+
       $body.off('click.zf.dropdown').on('click.zf.dropdown', function (e) {
         if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {
           return;
         }
-        if (_this.$element.find(e.target).length) {
+
+        if (_this.$element.is(e.target) || _this.$element.find(e.target).length) {
           return;
         }
+
         _this.close();
+
         $body.off('click.zf.dropdown');
       });
     }
-
     /**
      * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.
      * @function
@@ -641,175 +484,481 @@ var Dropdown = function (_Positionable) {
      */
 
   }, {
-    key: 'open',
+    key: "open",
     value: function open() {
       // var _this = this;
+
       /**
        * Fires to close other open dropdowns, typically when dropdown is opening
        * @event Dropdown#closeme
        */
       this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));
-      this.$anchors.addClass('hover').attr({ 'aria-expanded': true });
-      // this.$element/*.show()*/;
+      this.$anchors.addClass('hover').attr({
+        'aria-expanded': true
+      }); // this.$element/*.show()*/;
 
       this.$element.addClass('is-opening');
+
       this._setPosition();
-      this.$element.removeClass('is-opening').addClass('is-open').attr({ 'aria-hidden': false });
 
-      if (this.options.autoFocus) {
-        var $focusable = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].findFocusable(this.$element);
-        if ($focusable.length) {
-          $focusable.eq(0).focus();
-        }
-      }
+      this.$element.removeClass('is-opening').addClass('is-open').attr({
+        'aria-hidden': false
+      });
+
+      if (this.options.autoFocus) {
+        var $focusable = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].findFocusable(this.$element);
+
+        if ($focusable.length) {
+          $focusable.eq(0).focus();
+        }
+      }
+
+      if (this.options.closeOnClick) {
+        this._addBodyHandler();
+      }
+
+      if (this.options.trapFocus) {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].trapFocus(this.$element);
+      }
+      /**
+       * Fires once the dropdown is visible.
+       * @event Dropdown#show
+       */
+
+
+      this.$element.trigger('show.zf.dropdown', [this.$element]);
+    }
+    /**
+     * Closes the open dropdown pane.
+     * @function
+     * @fires Dropdown#hide
+     */
+
+  }, {
+    key: "close",
+    value: function close() {
+      if (!this.$element.hasClass('is-open')) {
+        return false;
+      }
+
+      this.$element.removeClass('is-open').attr({
+        'aria-hidden': true
+      });
+      this.$anchors.removeClass('hover').attr('aria-expanded', false);
+      /**
+       * Fires once the dropdown is no longer visible.
+       * @event Dropdown#hide
+       */
+
+      this.$element.trigger('hide.zf.dropdown', [this.$element]);
+
+      if (this.options.trapFocus) {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].releaseFocus(this.$element);
+      }
+    }
+    /**
+     * Toggles the dropdown pane's visibility.
+     * @function
+     */
+
+  }, {
+    key: "toggle",
+    value: function toggle() {
+      if (this.$element.hasClass('is-open')) {
+        if (this.$anchors.data('hover')) return;
+        this.close();
+      } else {
+        this.open();
+      }
+    }
+    /**
+     * Destroys the dropdown.
+     * @function
+     */
+
+  }, {
+    key: "_destroy",
+    value: function _destroy() {
+      this.$element.off('.zf.trigger').hide();
+      this.$anchors.off('.zf.dropdown');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('click.zf.dropdown');
+    }
+  }]);
+
+  return Dropdown;
+}(_foundation_positionable__WEBPACK_IMPORTED_MODULE_3__["Positionable"]);
+
+Dropdown.defaults = {
+  /**
+   * Class that designates bounding container of Dropdown (default: window)
+   * @option
+   * @type {?string}
+   * @default null
+   */
+  parentClass: null,
+
+  /**
+   * Amount of time to delay opening a submenu on hover event.
+   * @option
+   * @type {number}
+   * @default 250
+   */
+  hoverDelay: 250,
+
+  /**
+   * Allow submenus to open on hover events
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  hover: false,
+
+  /**
+   * Don't close dropdown when hovering over dropdown pane
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  hoverPane: false,
+
+  /**
+   * Number of pixels between the dropdown pane and the triggering element on open.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  vOffset: 0,
+
+  /**
+   * Number of pixels between the dropdown pane and the triggering element on open.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  hOffset: 0,
+
+  /**
+   * Position of dropdown. Can be left, right, bottom, top, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  position: 'auto',
+
+  /**
+   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * @option
+   * @type {string}
+   * @default 'auto'
+   */
+  alignment: 'auto',
+
+  /**
+   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  allowOverlap: false,
+
+  /**
+   * Allow overlap of only the bottom of the container. This is the most common
+   * behavior for dropdowns, allowing the dropdown to extend the bottom of the
+   * screen but not otherwise influence or break out of the container.
+   * @option
+   * @type {boolean}
+   * @default true
+   */
+  allowBottomOverlap: true,
+
+  /**
+   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  trapFocus: false,
+
+  /**
+   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  autoFocus: false,
+
+  /**
+   * Allows a click on the body to close the dropdown.
+   * @option
+   * @type {boolean}
+   * @default false
+   */
+  closeOnClick: false
+};
+
+
+/***/ }),
+
+/***/ "./js/foundation.positionable.js":
+/*!***************************************!*\
+  !*** ./js/foundation.positionable.js ***!
+  \***************************************/
+/*! exports provided: Positionable */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Positionable", function() { return Positionable; });
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.util.box */ "./foundation.util.box");
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ "./foundation.core");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
+
+
+
+
+var POSITIONS = ['left', 'right', 'top', 'bottom'];
+var VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];
+var HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];
+var ALIGNMENTS = {
+  'left': VERTICAL_ALIGNMENTS,
+  'right': VERTICAL_ALIGNMENTS,
+  'top': HORIZONTAL_ALIGNMENTS,
+  'bottom': HORIZONTAL_ALIGNMENTS
+};
+
+function nextItem(item, array) {
+  var currentIdx = array.indexOf(item);
+
+  if (currentIdx === array.length - 1) {
+    return array[0];
+  } else {
+    return array[currentIdx + 1];
+  }
+}
+
+var Positionable =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(Positionable, _Plugin);
+
+  function Positionable() {
+    _classCallCheck(this, Positionable);
+
+    return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments));
+  }
+
+  _createClass(Positionable, [{
+    key: "_init",
+
+    /**
+     * Abstract class encapsulating the tether-like explicit positioning logic
+     * including repositioning based on overlap.
+     * Expects classes to define defaults for vOffset, hOffset, position,
+     * alignment, allowOverlap, and allowBottomOverlap. They can do this by
+     * extending the defaults, or (for now recommended due to the way docs are
+     * generated) by explicitly declaring them.
+     *
+     **/
+    value: function _init() {
+      this.triedPositions = {};
+      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;
+      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;
+      this.originalPosition = this.position;
+      this.originalAlignment = this.alignment;
+    }
+  }, {
+    key: "_getDefaultPosition",
+    value: function _getDefaultPosition() {
+      return 'bottom';
+    }
+  }, {
+    key: "_getDefaultAlignment",
+    value: function _getDefaultAlignment() {
+      switch (this.position) {
+        case 'bottom':
+        case 'top':
+          return Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["rtl"])() ? 'right' : 'left';
+
+        case 'left':
+        case 'right':
+          return 'bottom';
+      }
+    }
+    /**
+     * Adjusts the positionable possible positions by iterating through alignments
+     * and positions.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_reposition",
+    value: function _reposition() {
+      if (this._alignmentsExhausted(this.position)) {
+        this.position = nextItem(this.position, POSITIONS);
+        this.alignment = ALIGNMENTS[this.position][0];
+      } else {
+        this._realign();
+      }
+    }
+    /**
+     * Adjusts the dropdown pane possible positions by iterating through alignments
+     * on the current position.
+     * @function
+     * @private
+     */
+
+  }, {
+    key: "_realign",
+    value: function _realign() {
+      this._addTriedPosition(this.position, this.alignment);
 
-      if (this.options.closeOnClick) {
-        this._addBodyHandler();
-      }
+      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);
+    }
+  }, {
+    key: "_addTriedPosition",
+    value: function _addTriedPosition(position, alignment) {
+      this.triedPositions[position] = this.triedPositions[position] || [];
+      this.triedPositions[position].push(alignment);
+    }
+  }, {
+    key: "_positionsExhausted",
+    value: function _positionsExhausted() {
+      var isExhausted = true;
 
-      if (this.options.trapFocus) {
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].trapFocus(this.$element);
+      for (var i = 0; i < POSITIONS.length; i++) {
+        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);
       }
 
-      /**
-       * Fires once the dropdown is visible.
-       * @event Dropdown#show
-       */
-      this.$element.trigger('show.zf.dropdown', [this.$element]);
+      return isExhausted;
     }
-
-    /**
-     * Closes the open dropdown pane.
-     * @function
-     * @fires Dropdown#hide
-     */
+  }, {
+    key: "_alignmentsExhausted",
+    value: function _alignmentsExhausted(position) {
+      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;
+    } // When we're trying to center, we don't want to apply offset that's going to
+    // take us just off center, so wrap around to return 0 for the appropriate
+    // offset in those alignments.  TODO: Figure out if we want to make this
+    // configurable behavior... it feels more intuitive, especially for tooltips, but
+    // it's possible someone might actually want to start from center and then nudge
+    // slightly off.
 
   }, {
-    key: 'close',
-    value: function close() {
-      if (!this.$element.hasClass('is-open')) {
+    key: "_getVOffset",
+    value: function _getVOffset() {
+      return this.options.vOffset;
+    }
+  }, {
+    key: "_getHOffset",
+    value: function _getHOffset() {
+      return this.options.hOffset;
+    }
+  }, {
+    key: "_setPosition",
+    value: function _setPosition($anchor, $element, $parent) {
+      if ($anchor.attr('aria-expanded') === 'false') {
         return false;
       }
-      this.$element.removeClass('is-open').attr({ 'aria-hidden': true });
 
-      this.$anchors.removeClass('hover').attr('aria-expanded', false);
-
-      /**
-       * Fires once the dropdown is no longer visible.
-       * @event Dropdown#hide
-       */
-      this.$element.trigger('hide.zf.dropdown', [this.$element]);
+      var $eleDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetDimensions($element),
+          $anchorDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetDimensions($anchor);
 
-      if (this.options.trapFocus) {
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].releaseFocus(this.$element);
+      if (!this.options.allowOverlap) {
+        // restore original position & alignment before checking overlap
+        this.position = this.originalPosition;
+        this.alignment = this.originalAlignment;
       }
-    }
 
-    /**
-     * Toggles the dropdown pane's visibility.
-     * @function
-     */
+      $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
 
-  }, {
-    key: 'toggle',
-    value: function toggle() {
-      if (this.$element.hasClass('is-open')) {
-        if (this.$anchors.data('hover')) return;
-        this.close();
-      } else {
-        this.open();
-      }
-    }
+      if (!this.options.allowOverlap) {
+        var overlaps = {};
+        var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better
 
-    /**
-     * Destroys the dropdown.
-     * @function
-     */
+        var minCoordinates = {
+          position: this.position,
+          alignment: this.alignment
+        };
 
-  }, {
-    key: '_destroy',
-    value: function _destroy() {
-      this.$element.off('.zf.trigger').hide();
-      this.$anchors.off('.zf.dropdown');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document.body).off('click.zf.dropdown');
+        while (!this._positionsExhausted()) {
+          var overlap = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
+
+          if (overlap === 0) {
+            return;
+          }
+
+          if (overlap < minOverlap) {
+            minOverlap = overlap;
+            minCoordinates = {
+              position: this.position,
+              alignment: this.alignment
+            };
+          }
+
+          this._reposition();
+
+          $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+        } // If we get through the entire loop, there was no non-overlapping
+        // position available. Pick the version with least overlap.
+
+
+        this.position = minCoordinates.position;
+        this.alignment = minCoordinates.alignment;
+        $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+      }
     }
   }]);
 
-  return Dropdown;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_positionable__["a" /* Positionable */]);
-
-Dropdown.defaults = {
-  /**
-   * Class that designates bounding container of Dropdown (default: window)
-   * @option
-   * @type {?string}
-   * @default null
-   */
-  parentClass: null,
-  /**
-   * Amount of time to delay opening a submenu on hover event.
-   * @option
-   * @type {number}
-   * @default 250
-   */
-  hoverDelay: 250,
-  /**
-   * Allow submenus to open on hover events
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  hover: false,
-  /**
-   * Don't close dropdown when hovering over dropdown pane
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  hoverPane: false,
-  /**
-   * Number of pixels between the dropdown pane and the triggering element on open.
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  vOffset: 0,
-  /**
-   * Number of pixels between the dropdown pane and the triggering element on open.
-   * @option
-   * @type {number}
-   * @default 0
-   */
-  hOffset: 0,
-  /**
-   * DEPRECATED: Class applied to adjust open position.
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  positionClass: '',
+  return Positionable;
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 
+Positionable.defaults = {
   /**
-   * Position of dropdown. Can be left, right, bottom, top, or auto.
+   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.
    * @option
    * @type {string}
    * @default 'auto'
    */
   position: 'auto',
+
   /**
-   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.
+   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.
    * @option
    * @type {string}
    * @default 'auto'
    */
   alignment: 'auto',
+
   /**
-   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.
+   * Allow overlap of container/window. If false, dropdown positionable first
+   * try to position as defined by data-position and data-alignment, but
+   * reposition if it would cause an overflow.
    * @option
    * @type {boolean}
    * @default false
    */
   allowOverlap: false,
+
   /**
    * Allow overlap of only the bottom of the container. This is the most common
    * behavior for dropdowns, allowing the dropdown to extend the bottom of the
@@ -819,49 +968,46 @@ Dropdown.defaults = {
    * @default true
    */
   allowBottomOverlap: true,
+
   /**
-   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.
-   * @option
-   * @type {boolean}
-   * @default false
-   */
-  trapFocus: false,
-  /**
-   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.
+   * Number of pixels the positionable should be separated vertically from anchor
    * @option
-   * @type {boolean}
-   * @default false
+   * @type {number}
+   * @default 0
    */
-  autoFocus: false,
+  vOffset: 0,
+
   /**
-   * Allows a click on the body to close the dropdown.
+   * Number of pixels the positionable should be separated horizontally from anchor
    * @option
-   * @type {boolean}
-   * @default false
+   * @type {number}
+   * @default 0
    */
-  closeOnClick: false
+  hOffset: 0
 };
 
 
-
-/***/ }),
-
-/***/ 5:
-/***/ (function(module, exports) {
-
-module.exports = {Keyboard: window.Foundation.Keyboard};
-
 /***/ }),
 
-/***/ 7:
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
@@ -869,17 +1015,19 @@ module.exports = {Keyboard: window.Foundation.Keyboard};
 
 var MutationObserver = function () {
   var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
   for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
     }
   }
+
   return false;
 }();
 
-var triggers = function (el, type) {
+var triggers = function triggers(el, type) {
   el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
   });
 };
 
@@ -890,138 +1038,142 @@ var Triggers = {
   },
   Initializers: {}
 };
-
 Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
   },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
     }
   },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
     }
   },
-  closeableListener: function (e) {
+  closeableListener: function closeableListener(e) {
     e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
     if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
       });
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
     }
   },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
-};
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
 Triggers.Initializers.addOpenListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
   $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
-
-// Elements with [data-close] will close a plugin that supports it when clicked.
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
 // If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
 Triggers.Initializers.addCloseListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
   $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 Triggers.Initializers.addToggleListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
   $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
 Triggers.Initializers.addCloseableListener = function ($elem) {
   $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
   $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
 Triggers.Initializers.addToggleFocusListener = function ($elem) {
   $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
   $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+}; // More Global/complex listeners and triggers
+
 
-// More Global/complex listeners and triggers
 Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
+  resizeListener: function resizeListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a resize event
+    } //trigger all listening elements and signal a resize event
+
+
     $nodes.attr('data-events', "resize");
   },
-  scrollListener: function ($nodes) {
+  scrollListener: function scrollListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a scroll event
+    } //trigger all listening elements and signal a scroll event
+
+
     $nodes.attr('data-events', "scroll");
   },
-  closeMeListener: function (e, pluginId) {
+  closeMeListener: function closeMeListener(e, pluginId) {
     var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
-
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
     plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+
       _this.triggerHandler('close.zf.trigger', [_this]);
     });
-  }
+  } // Global, parses whole document.
+
+};
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
       plugNames = ['dropdown', 'tooltip', 'reveal'];
 
   if (pluginName) {
     if (typeof pluginName === 'string') {
       plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
     } else {
       console.error('Plugin names must be strings');
     }
   }
+
   if (yetiBoxes.length) {
     var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
+      return "closeme.zf.".concat(name);
     }).join(' ');
-
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
   }
 };
 
 function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
+  var timer,
       args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
     if (timer) {
       clearTimeout(timer);
     }
+
     timer = setTimeout(function () {
       listener.apply(null, args);
     }, debounce || 10); //default time to emit scroll event
@@ -1029,14 +1181,16 @@ function debounceGlobalListener(debounce, trigger, listener) {
 }
 
 Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
   }
 };
 
 Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
   }
@@ -1046,25 +1200,27 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
   if (!MutationObserver) {
     return false;
   }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
 
-    //trigger the event handler for the element depending on type
     switch (mutationRecordsList[0].type) {
       case "attributes":
         if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
+
         if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
+
         if (mutationRecordsList[0].attributeName === "style") {
           $target.closest("[data-mutate]").attr("data-events", "mutate");
           $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
         }
+
         break;
 
       case "childList":
@@ -1082,14 +1238,19 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
     //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
     for (var i = 0; i <= $nodes.length - 1; i++) {
       var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
   }
 };
 
 Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addOpenListener($document);
   Triggers.Initializers.addCloseListener($document);
   Triggers.Initializers.addToggleListener($document);
@@ -1098,7 +1259,7 @@ Triggers.Initializers.addSimpleListeners = function () {
 };
 
 Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addMutationEventsListener($document);
   Triggers.Initializers.addResizeListener();
   Triggers.Initializers.addScrollListener();
@@ -1106,25 +1267,17 @@ Triggers.Initializers.addGlobalListeners = function () {
 };
 
 Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
-
-    if (document.readyState === "complete") {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
       Triggers.Initializers.addSimpleListeners();
       Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
-      });
+      $.triggersInitialized = true;
     }
-
-    $.triggersInitialized = true;
-  }
+  });
 
   if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
     Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
   }
 };
@@ -1133,19 +1286,29 @@ Triggers.init = function ($, Foundation) {
 
 /***/ }),
 
-/***/ 8:
-/***/ (function(module, exports) {
+/***/ 4:
+/*!*********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.dropdown.js ***!
+  \*********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-module.exports = {Box: window.Foundation.Box};
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.dropdown.js */"./js/entries/plugins/foundation.dropdown.js");
 
-/***/ }),
 
-/***/ 83:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ }),
 
-module.exports = __webpack_require__(17);
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.dropdown.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.dropdown.js.map b/dist/js/plugins/foundation.dropdown.js.map
new file mode 100644 (file)
index 0000000..b1bf05e
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.box\"],\"amd\":\"./foundation.util.box\",\"commonjs\":\"./foundation.util.box\",\"commonjs2\":\"./foundation.util.box\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.touch\"],\"amd\":\"./foundation.util.touch\",\"commonjs\":\"./foundation.util.touch\",\"commonjs2\":\"./foundation.util.touch\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.dropdown.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.dropdown.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.positionable.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Dropdown","element","options","$element","$","extend","defaults","data","className","Triggers","init","_init","Keyboard","register","$id","attr","$anchors","length","_setCurrentAnchor","first","parentClass","$parent","parents","$currentAnchor","GetYoDigits","_events","position","match","horizontalPosition","exec","removeClass","alignment","addClass","el","_this","on","open","bind","close","toggle","_setPosition","off","hover","bodyData","whatinput","clearTimeout","timeout","setTimeout","hoverDelay","ignoreMousedisappear","hoverPane","add","e","$target","visibleFocusableElements","findFocusable","handleKey","is","focus","preventDefault","$body","document","body","not","target","find","trigger","autoFocus","$focusable","eq","closeOnClick","_addBodyHandler","trapFocus","hasClass","releaseFocus","hide","Positionable","vOffset","hOffset","allowOverlap","allowBottomOverlap","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","nextItem","item","array","currentIdx","indexOf","triedPositions","_getDefaultPosition","_getDefaultAlignment","originalPosition","originalAlignment","Rtl","_alignmentsExhausted","_realign","_addTriedPosition","push","isExhausted","i","$anchor","$eleDims","Box","GetDimensions","$anchorDims","offset","GetExplicitOffsets","_getVOffset","_getHOffset","overlaps","minOverlap","minCoordinates","_positionsExhausted","overlap","OverlapArea","_reposition","Plugin","MutationObserver","prefixes","window","triggers","type","split","forEach","id","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","Motion","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","scrollListener","closeMeListener","pluginId","namespace","plugins","addClosemeListener","pluginName","yetiBoxes","plugNames","concat","console","error","listeners","map","name","join","debounceGlobalListener","debounce","listener","timer","args","Array","prototype","slice","call","arguments","apply","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","attributeName","pageYOffset","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","onLoad","triggersInitialized","IHearYou"],"mappings":"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","file":"foundation.dropdown.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.util.keyboard\"), require(\"./foundation.core\"), require(\"jquery\"), require(\"./foundation.util.box\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.util.keyboard\", \"./foundation.core\", \"jquery\", \"./foundation.util.box\", \"./foundation.util.motion\", \"./foundation.util.touch\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.dropdown\"] = factory(require(\"./foundation.util.keyboard\"), require(\"./foundation.core\"), require(\"jquery\"), require(\"./foundation.util.box\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.dropdown\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 4);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;","import { Foundation } from './foundation.core';\n\nimport { Dropdown } from '../../foundation.dropdown';\nFoundation.plugin(Dropdown, 'Dropdown');\n\nexport { Foundation, Dropdown };\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { Positionable } from './foundation.positionable';\n\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Dropdown module.\n * @module foundation.dropdown\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.triggers\n */\nclass Dropdown extends Positionable {\n  /**\n   * Creates a new instance of a dropdown.\n   * @class\n   * @name Dropdown\n   * @param {jQuery} element - jQuery object to make into a dropdown.\n   *        Object should be of the dropdown panel, rather than its anchor.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Dropdown.defaults, this.$element.data(), options);\n    this.className = 'Dropdown'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Dropdown', {\n      'ENTER': 'toggle',\n      'SPACE': 'toggle',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.\n   * @function\n   * @private\n   */\n  _init() {\n    var $id = this.$element.attr('id');\n\n    this.$anchors = $(`[data-toggle=\"${$id}\"]`).length ? $(`[data-toggle=\"${$id}\"]`) : $(`[data-open=\"${$id}\"]`);\n    this.$anchors.attr({\n      'aria-controls': $id,\n      'data-is-focus': false,\n      'data-yeti-box': $id,\n      'aria-haspopup': true,\n      'aria-expanded': false\n    });\n\n    this._setCurrentAnchor(this.$anchors.first());\n\n    if(this.options.parentClass){\n      this.$parent = this.$element.parents('.' + this.options.parentClass);\n    }else{\n      this.$parent = null;\n    }\n\n    // Set [aria-labelledby] on the Dropdown if it is not set\n    if (typeof this.$element.attr('aria-labelledby') === 'undefined') {\n      // Get the anchor ID or create one\n      if (typeof this.$currentAnchor.attr('id') === 'undefined') {\n        this.$currentAnchor.attr('id', GetYoDigits(6, 'dd-anchor'));\n      };\n\n      this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));\n    }\n\n    this.$element.attr({\n      'aria-hidden': 'true',\n      'data-yeti-box': $id,\n      'data-resize': $id,\n    });\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/(top|left|right|bottom)/g);\n    if(position) {\n      return position[0];\n    } else {\n      return 'bottom'\n    }\n  }\n\n  _getDefaultAlignment() {\n    // handle legacy float approach\n    var horizontalPosition = /float-(\\S+)/.exec(this.$currentAnchor.attr('class'));\n    if(horizontalPosition) {\n      return horizontalPosition[1];\n    }\n\n    return super._getDefaultAlignment();\n  }\n\n\n\n  /**\n   * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.\n   * Recursively calls itself if a collision is detected, with a new position class.\n   * @function\n   * @private\n   */\n  _setPosition() {\n    this.$element.removeClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n    super._setPosition(this.$currentAnchor, this.$element, this.$parent);\n    this.$element.addClass(`has-position-${this.position} has-alignment-${this.alignment}`);\n  }\n\n  /**\n   * Make it a current anchor.\n   * Current anchor as the reference for the position of Dropdown panes.\n   * @param {HTML} el - DOM element of the anchor.\n   * @function\n   * @private\n   */\n  _setCurrentAnchor(el) {\n    this.$currentAnchor = $(el);\n  }\n\n  /**\n   * Adds event listeners to the element utilizing the triggers utility library.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': this._setPosition.bind(this)\n    });\n\n    this.$anchors.off('click.zf.trigger')\n      .on('click.zf.trigger', function() { _this._setCurrentAnchor(this); });\n\n    if(this.options.hover){\n      this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n      .on('mouseenter.zf.dropdown', function(){\n        _this._setCurrentAnchor(this);\n\n        var bodyData = $('body').data();\n        if(typeof(bodyData.whatinput) === 'undefined' || bodyData.whatinput === 'mouse') {\n          clearTimeout(_this.timeout);\n          _this.timeout = setTimeout(function(){\n            _this.open();\n            _this.$anchors.data('hover', true);\n          }, _this.options.hoverDelay);\n        }\n      }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n        clearTimeout(_this.timeout);\n        _this.timeout = setTimeout(function(){\n          _this.close();\n          _this.$anchors.data('hover', false);\n        }, _this.options.hoverDelay);\n      }));\n      if(this.options.hoverPane){\n        this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown')\n            .on('mouseenter.zf.dropdown', function(){\n              clearTimeout(_this.timeout);\n            }).on('mouseleave.zf.dropdown', ignoreMousedisappear(function(){\n              clearTimeout(_this.timeout);\n              _this.timeout = setTimeout(function(){\n                _this.close();\n                _this.$anchors.data('hover', false);\n              }, _this.options.hoverDelay);\n            }));\n      }\n    }\n    this.$anchors.add(this.$element).on('keydown.zf.dropdown', function(e) {\n\n      var $target = $(this),\n        visibleFocusableElements = Keyboard.findFocusable(_this.$element);\n\n      Keyboard.handleKey(e, 'Dropdown', {\n        open: function() {\n          if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {\n            _this.open();\n            _this.$element.attr('tabindex', -1).focus();\n            e.preventDefault();\n          }\n        },\n        close: function() {\n          _this.close();\n          _this.$anchors.focus();\n        }\n      });\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n     var $body = $(document.body).not(this.$element),\n         _this = this;\n     $body.off('click.zf.dropdown')\n          .on('click.zf.dropdown', function(e){\n            if(_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {\n              return;\n            }\n            if(_this.$element.is(e.target) || _this.$element.find(e.target).length) {\n              return;\n            }\n            _this.close();\n            $body.off('click.zf.dropdown');\n          });\n  }\n\n  /**\n   * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.\n   * @function\n   * @fires Dropdown#closeme\n   * @fires Dropdown#show\n   */\n  open() {\n    // var _this = this;\n    /**\n     * Fires to close other open dropdowns, typically when dropdown is opening\n     * @event Dropdown#closeme\n     */\n    this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));\n    this.$anchors.addClass('hover')\n        .attr({'aria-expanded': true});\n    // this.$element/*.show()*/;\n\n    this.$element.addClass('is-opening');\n    this._setPosition();\n    this.$element.removeClass('is-opening').addClass('is-open')\n        .attr({'aria-hidden': false});\n\n    if(this.options.autoFocus){\n      var $focusable = Keyboard.findFocusable(this.$element);\n      if($focusable.length){\n        $focusable.eq(0).focus();\n      }\n    }\n\n    if(this.options.closeOnClick){ this._addBodyHandler(); }\n\n    if (this.options.trapFocus) {\n      Keyboard.trapFocus(this.$element);\n    }\n\n    /**\n     * Fires once the dropdown is visible.\n     * @event Dropdown#show\n     */\n    this.$element.trigger('show.zf.dropdown', [this.$element]);\n  }\n\n  /**\n   * Closes the open dropdown pane.\n   * @function\n   * @fires Dropdown#hide\n   */\n  close() {\n    if(!this.$element.hasClass('is-open')){\n      return false;\n    }\n    this.$element.removeClass('is-open')\n        .attr({'aria-hidden': true});\n\n    this.$anchors.removeClass('hover')\n        .attr('aria-expanded', false);\n\n    /**\n     * Fires once the dropdown is no longer visible.\n     * @event Dropdown#hide\n     */\n    this.$element.trigger('hide.zf.dropdown', [this.$element]);\n\n    if (this.options.trapFocus) {\n      Keyboard.releaseFocus(this.$element);\n    }\n  }\n\n  /**\n   * Toggles the dropdown pane's visibility.\n   * @function\n   */\n  toggle() {\n    if(this.$element.hasClass('is-open')){\n      if(this.$anchors.data('hover')) return;\n      this.close();\n    }else{\n      this.open();\n    }\n  }\n\n  /**\n   * Destroys the dropdown.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger').hide();\n    this.$anchors.off('.zf.dropdown');\n    $(document.body).off('click.zf.dropdown');\n\n  }\n}\n\nDropdown.defaults = {\n  /**\n   * Class that designates bounding container of Dropdown (default: window)\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  parentClass: null,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  hoverDelay: 250,\n  /**\n   * Allow submenus to open on hover events\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hover: false,\n  /**\n   * Don't close dropdown when hovering over dropdown pane\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hoverPane: false,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Position of dropdown. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false,\n  /**\n   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n  /**\n   * Allows a click on the body to close the dropdown.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false\n};\n\nexport {Dropdown};\n","'use strict';\n\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst POSITIONS = ['left', 'right', 'top', 'bottom'];\nconst VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nconst HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\n\nconst ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n}\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n  if(currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\n\nclass Positionable extends Plugin {\n  /**\n   * Abstract class encapsulating the tether-like explicit positioning logic\n   * including repositioning based on overlap.\n   * Expects classes to define defaults for vOffset, hOffset, position,\n   * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n   * extending the defaults, or (for now recommended due to the way docs are\n   * generated) by explicitly declaring them.\n   *\n   **/\n\n  _init() {\n    this.triedPositions = {};\n    this.position  = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n    this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n    this.originalPosition = this.position;\n    this.originalAlignment = this.alignment;\n  }\n\n  _getDefaultPosition () {\n    return 'bottom';\n  }\n\n  _getDefaultAlignment() {\n    switch(this.position) {\n      case 'bottom':\n      case 'top':\n        return Rtl() ? 'right' : 'left';\n      case 'left':\n      case 'right':\n        return 'bottom';\n    }\n  }\n\n  /**\n   * Adjusts the positionable possible positions by iterating through alignments\n   * and positions.\n   * @function\n   * @private\n   */\n  _reposition() {\n    if(this._alignmentsExhausted(this.position)) {\n      this.position = nextItem(this.position, POSITIONS);\n      this.alignment = ALIGNMENTS[this.position][0];\n    } else {\n      this._realign();\n    }\n  }\n\n  /**\n   * Adjusts the dropdown pane possible positions by iterating through alignments\n   * on the current position.\n   * @function\n   * @private\n   */\n  _realign() {\n    this._addTriedPosition(this.position, this.alignment)\n    this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position])\n  }\n\n  _addTriedPosition(position, alignment) {\n    this.triedPositions[position] = this.triedPositions[position] || []\n    this.triedPositions[position].push(alignment);\n  }\n\n  _positionsExhausted() {\n    var isExhausted = true;\n    for(var i = 0; i < POSITIONS.length; i++) {\n      isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n    }\n    return isExhausted;\n  }\n\n  _alignmentsExhausted(position) {\n    return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n  }\n\n\n  // When we're trying to center, we don't want to apply offset that's going to\n  // take us just off center, so wrap around to return 0 for the appropriate\n  // offset in those alignments.  TODO: Figure out if we want to make this\n  // configurable behavior... it feels more intuitive, especially for tooltips, but\n  // it's possible someone might actually want to start from center and then nudge\n  // slightly off.\n  _getVOffset() {\n    return this.options.vOffset;\n  }\n\n  _getHOffset() {\n    return this.options.hOffset;\n  }\n\n\n  _setPosition($anchor, $element, $parent) {\n    if($anchor.attr('aria-expanded') === 'false'){ return false; }\n    var $eleDims = Box.GetDimensions($element),\n        $anchorDims = Box.GetDimensions($anchor);\n\n\n    if (!this.options.allowOverlap) {\n      // restore original position & alignment before checking overlap\n      this.position = this.originalPosition;\n      this.alignment = this.originalAlignment;\n    }\n\n    $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n    if(!this.options.allowOverlap) {\n      var overlaps = {};\n      var minOverlap = 100000000;\n      // default coordinates to how we start, in case we can't figure out better\n      var minCoordinates = {position: this.position, alignment: this.alignment};\n      while(!this._positionsExhausted()) {\n        let overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n        if(overlap === 0) {\n          return;\n        }\n\n        if(overlap < minOverlap) {\n          minOverlap = overlap;\n          minCoordinates = {position: this.position, alignment: this.alignment};\n        }\n\n        this._reposition();\n\n        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n      // If we get through the entire loop, there was no non-overlapping\n      // position available. Pick the version with least overlap.\n      this.position = minCoordinates.position;\n      this.alignment = minCoordinates.alignment;\n      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n    }\n  }\n\n}\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n}\n\nexport {Positionable};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index a70b8d0a5a61dc73b82e28450f35bb7633062838..bd7001be5064afe2f3a06c1eef2880c3ac67f8bf 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(n){if(i[n])return i[n].exports;var o=i[n]={i:n,l:!1,exports:{}};return t[n].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var i={};e.m=t,e.c=i,e.i=function(t){return t},e.d=function(t,i,n){e.o(t,i)||Object.defineProperty(t,i,{configurable:!1,enumerable:!0,get:n})},e.n=function(t){var i=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(i,"a",i),i},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=83)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},11:function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function s(t,e){var i=e.indexOf(t);return i===e.length-1?e[0]:e[i+1]}i.d(e,"a",function(){return p});var a=i(8),l=(i.n(a),i(2)),u=(i.n(l),i(3)),c=(i.n(u),function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}()),f=["left","right","top","bottom"],d=["top","bottom","center"],h=["left","right","center"],g={left:d,right:d,top:h,bottom:h},p=function(t){function e(){return n(this,e),o(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return r(e,t),c(e,[{key:"_init",value:function(){this.triedPositions={},this.position="auto"===this.options.position?this._getDefaultPosition():this.options.position,this.alignment="auto"===this.options.alignment?this._getDefaultAlignment():this.options.alignment}},{key:"_getDefaultPosition",value:function(){return"bottom"}},{key:"_getDefaultAlignment",value:function(){switch(this.position){case"bottom":case"top":return i.i(u.rtl)()?"right":"left";case"left":case"right":return"bottom"}}},{key:"_reposition",value:function(){this._alignmentsExhausted(this.position)?(this.position=s(this.position,f),this.alignment=g[this.position][0]):this._realign()}},{key:"_realign",value:function(){this._addTriedPosition(this.position,this.alignment),this.alignment=s(this.alignment,g[this.position])}},{key:"_addTriedPosition",value:function(t,e){this.triedPositions[t]=this.triedPositions[t]||[],this.triedPositions[t].push(e)}},{key:"_positionsExhausted",value:function(){for(var t=!0,e=0;e<f.length;e++)t=t&&this._alignmentsExhausted(f[e]);return t}},{key:"_alignmentsExhausted",value:function(t){return this.triedPositions[t]&&this.triedPositions[t].length==g[t].length}},{key:"_getVOffset",value:function(){return this.options.vOffset}},{key:"_getHOffset",value:function(){return this.options.hOffset}},{key:"_setPosition",value:function(t,e,i){if("false"===t.attr("aria-expanded"))return!1;a.Box.GetDimensions(e),a.Box.GetDimensions(t);if(e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset())),!this.options.allowOverlap){for(var n=1e8,o={position:this.position,alignment:this.alignment};!this._positionsExhausted();){var r=a.Box.OverlapArea(e,i,!1,!1,this.options.allowBottomOverlap);if(0===r)return;r<n&&(n=r,o={position:this.position,alignment:this.alignment}),this._reposition(),e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}this.position=o.position,this.alignment=o.alignment,e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}}}]),e}(l.Plugin);p.defaults={position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,vOffset:0,hOffset:0}},17:function(t,e,i){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var n=i(1),o=(i.n(n),i(47));n.Foundation.plugin(o.a,"Dropdown")},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},3:function(t,e){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},4:function(t,e){t.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},47:function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return g});var s=i(0),a=i.n(s),l=i(5),u=(i.n(l),i(3)),c=(i.n(u),i(11)),f=i(7),d=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),h=function t(e,i,n){null===e&&(e=Function.prototype);var o=Object.getOwnPropertyDescriptor(e,i);if(void 0===o){var r=Object.getPrototypeOf(e);return null===r?void 0:t(r,i,n)}if("value"in o)return o.value;var s=o.get;if(void 0!==s)return s.call(n)},g=function(t){function e(){return n(this,e),o(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return r(e,t),d(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=a.a.extend({},e.defaults,this.$element.data(),i),this.className="Dropdown",f.a.init(a.a),this._init(),l.Keyboard.register("Dropdown",{ENTER:"open",SPACE:"open",ESCAPE:"close"})}},{key:"_init",value:function(){var t=this.$element.attr("id");this.$anchors=a()('[data-toggle="'+t+'"]').length?a()('[data-toggle="'+t+'"]'):a()('[data-open="'+t+'"]'),this.$anchors.attr({"aria-controls":t,"data-is-focus":!1,"data-yeti-box":t,"aria-haspopup":!0,"aria-expanded":!1}),this._setCurrentAnchor(this.$anchors.first()),this.options.parentClass?this.$parent=this.$element.parents("."+this.options.parentClass):this.$parent=null,this.$element.attr({"aria-hidden":"true","data-yeti-box":t,"data-resize":t,"aria-labelledby":this.$currentAnchor.id||i.i(u.GetYoDigits)(6,"dd-anchor")}),h(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_init",this).call(this),this._events()}},{key:"_getDefaultPosition",value:function(){var t=this.$element[0].className.match(/(top|left|right|bottom)/g);return t?t[0]:"bottom"}},{key:"_getDefaultAlignment",value:function(){var t=/float-(\S+)/.exec(this.$currentAnchor.className);return t?t[1]:h(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_getDefaultAlignment",this).call(this)}},{key:"_setPosition",value:function(){h(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_setPosition",this).call(this,this.$currentAnchor,this.$element,this.$parent)}},{key:"_setCurrentAnchor",value:function(t){this.$currentAnchor=a()(t)}},{key:"_events",value:function(){var t=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":this.close.bind(this),"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":this._setPosition.bind(this)}),this.$anchors.off("click.zf.trigger").on("click.zf.trigger",function(){t._setCurrentAnchor(this)}),this.options.hover&&(this.$anchors.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){t._setCurrentAnchor(this);var e=a()("body").data();void 0!==e.whatinput&&"mouse"!==e.whatinput||(clearTimeout(t.timeout),t.timeout=setTimeout(function(){t.open(),t.$anchors.data("hover",!0)},t.options.hoverDelay))}).on("mouseleave.zf.dropdown",function(){clearTimeout(t.timeout),t.timeout=setTimeout(function(){t.close(),t.$anchors.data("hover",!1)},t.options.hoverDelay)}),this.options.hoverPane&&this.$element.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){clearTimeout(t.timeout)}).on("mouseleave.zf.dropdown",function(){clearTimeout(t.timeout),t.timeout=setTimeout(function(){t.close(),t.$anchors.data("hover",!1)},t.options.hoverDelay)})),this.$anchors.add(this.$element).on("keydown.zf.dropdown",function(e){var i=a()(this);l.Keyboard.findFocusable(t.$element);l.Keyboard.handleKey(e,"Dropdown",{open:function(){i.is(t.$anchors)&&(t.open(),t.$element.attr("tabindex",-1).focus(),e.preventDefault())},close:function(){t.close(),t.$anchors.focus()}})})}},{key:"_addBodyHandler",value:function(){var t=a()(document.body).not(this.$element),e=this;t.off("click.zf.dropdown").on("click.zf.dropdown",function(i){e.$anchors.is(i.target)||e.$anchors.find(i.target).length||e.$element.find(i.target).length||(e.close(),t.off("click.zf.dropdown"))})}},{key:"open",value:function(){if(this.$element.trigger("closeme.zf.dropdown",this.$element.attr("id")),this.$anchors.addClass("hover").attr({"aria-expanded":!0}),this.$element.addClass("is-opening"),this._setPosition(),this.$element.removeClass("is-opening").addClass("is-open").attr({"aria-hidden":!1}),this.options.autoFocus){var t=l.Keyboard.findFocusable(this.$element);t.length&&t.eq(0).focus()}this.options.closeOnClick&&this._addBodyHandler(),this.options.trapFocus&&l.Keyboard.trapFocus(this.$element),this.$element.trigger("show.zf.dropdown",[this.$element])}},{key:"close",value:function(){if(!this.$element.hasClass("is-open"))return!1;this.$element.removeClass("is-open").attr({"aria-hidden":!0}),this.$anchors.removeClass("hover").attr("aria-expanded",!1),this.$element.trigger("hide.zf.dropdown",[this.$element]),this.options.trapFocus&&l.Keyboard.releaseFocus(this.$element)}},{key:"toggle",value:function(){if(this.$element.hasClass("is-open")){if(this.$anchors.data("hover"))return;this.close()}else this.open()}},{key:"_destroy",value:function(){this.$element.off(".zf.trigger").hide(),this.$anchors.off(".zf.dropdown"),a()(document.body).off("click.zf.dropdown")}}]),e}(c.a);g.defaults={parentClass:null,hoverDelay:250,hover:!1,hoverPane:!1,vOffset:0,hOffset:0,positionClass:"",position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,trapFocus:!1,autoFocus:!1,closeOnClick:!1}},5:function(t,e){t.exports={Keyboard:window.Foundation.Keyboard}},7:function(t,e,i){"use strict";function n(t,e,i){var n=void 0,o=Array.prototype.slice.call(arguments,3);r()(window).off(e).on(e,function(e){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,o)},t||10)})}i.d(e,"a",function(){return u});var o=i(0),r=i.n(o),s=i(4),a=(i.n(s),function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if(t[e]+"MutationObserver"in window)return window[t[e]+"MutationObserver"];return!1}()),l=function(t,e){t.data(e).split(" ").forEach(function(i){r()("#"+i)["close"===e?"trigger":"triggerHandler"](e+".zf.trigger",[t])})},u={Listeners:{Basic:{},Global:{}},Initializers:{}};u.Listeners.Basic={openListener:function(){l(r()(this),"open")},closeListener:function(){r()(this).data("close")?l(r()(this),"close"):r()(this).trigger("close.zf.trigger")},toggleListener:function(){r()(this).data("toggle")?l(r()(this),"toggle"):r()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=r()(this).data("closable");""!==e?s.Motion.animateOut(r()(this),e,function(){r()(this).trigger("closed.zf")}):r()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=r()(this).data("toggle-focus");r()("#"+t).triggerHandler("toggle.zf.trigger",[r()(this)])}},u.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",u.Listeners.Basic.openListener)},u.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",u.Listeners.Basic.closeListener)},u.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",u.Listeners.Basic.toggleListener)},u.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",u.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",u.Listeners.Basic.closeableListener)},u.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",u.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",u.Listeners.Basic.toggleFocusListener)},u.Listeners.Global={resizeListener:function(t){a||t.each(function(){r()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){a||t.each(function(){r()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];r()("[data-"+i+"]").not('[data-yeti-box="'+e+'"]').each(function(){var t=r()(this);t.triggerHandler("close.zf.trigger",[t])})}},u.Initializers.addClosemeListener=function(t){var e=r()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"==typeof t&&"string"==typeof t[0]?i.concat(t):console.error("Plugin names must be strings")),e.length){var n=i.map(function(t){return"closeme.zf."+t}).join(" ");r()(window).off(n).on(n,u.Listeners.Global.closeMeListener)}},u.Initializers.addResizeListener=function(t){var e=r()("[data-resize]");e.length&&n(t,"resize.zf.trigger",u.Listeners.Global.resizeListener,e)},u.Initializers.addScrollListener=function(t){var e=r()("[data-scroll]");e.length&&n(t,"scroll.zf.trigger",u.Listeners.Global.scrollListener,e)},u.Initializers.addMutationEventsListener=function(t){if(!a)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=r()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var n=0;n<=e.length-1;n++){var o=new a(i);o.observe(e[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},u.Initializers.addSimpleListeners=function(){var t=r()(document);u.Initializers.addOpenListener(t),u.Initializers.addCloseListener(t),u.Initializers.addToggleListener(t),u.Initializers.addCloseableListener(t),u.Initializers.addToggleFocusListener(t)},u.Initializers.addGlobalListeners=function(){var t=r()(document);u.Initializers.addMutationEventsListener(t),u.Initializers.addResizeListener(),u.Initializers.addScrollListener(),u.Initializers.addClosemeListener()},u.init=function(t,e){if(void 0===t.triggersInitialized){t(document);"complete"===document.readyState?(u.Initializers.addSimpleListeners(),u.Initializers.addGlobalListeners()):t(window).on("load",function(){u.Initializers.addSimpleListeners(),u.Initializers.addGlobalListeners()}),t.triggersInitialized=!0}e&&(e.Triggers=u,e.IHearYou=u.Initializers.addGlobalListeners)}},8:function(t,e){t.exports={Box:window.Foundation.Box}},83:function(t,e,i){t.exports=i(17)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.util.keyboard"),require("./foundation.core"),require("jquery"),require("./foundation.util.box"),require("./foundation.util.motion"),require("./foundation.util.touch")):"function"==typeof define&&define.amd?define(["./foundation.util.keyboard","./foundation.core","jquery","./foundation.util.box","./foundation.util.motion","./foundation.util.touch"],e):"object"==typeof exports?exports["foundation.dropdown"]=e(require("./foundation.util.keyboard"),require("./foundation.core"),require("jquery"),require("./foundation.util.box"),require("./foundation.util.motion"),require("./foundation.util.touch")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.dropdown"]=e(t.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],t.__FOUNDATION_EXTERNAL__["foundation.core"],t.jQuery,t.__FOUNDATION_EXTERNAL__["foundation.util.box"],t.__FOUNDATION_EXTERNAL__["foundation.util.motion"],t.__FOUNDATION_EXTERNAL__["foundation.util.touch"]))}(window,function(n,o,i,r,s,a){return function(n){var o={};function i(t){if(o[t])return o[t].exports;var e=o[t]={i:t,l:!1,exports:{}};return n[t].call(e.exports,e,e.exports,i),e.l=!0,e.exports}return i.m=n,i.c=o,i.d=function(t,e,n){i.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},i.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},i.t=function(e,t){if(1&t&&(e=i(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)i.d(n,o,function(t){return e[t]}.bind(null,o));return n},i.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return i.d(e,"a",e),e},i.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},i.p="",i(i.s=4)}({"./foundation.core":function(t,e){t.exports=o},"./foundation.util.box":function(t,e){t.exports=r},"./foundation.util.keyboard":function(t,e){t.exports=n},"./foundation.util.motion":function(t,e){t.exports=s},"./foundation.util.touch":function(t,e){t.exports=a},"./js/entries/plugins/foundation.dropdown.js":function(t,e,n){"use strict";n.r(e);var o=n("./foundation.core");n.d(e,"Foundation",function(){return o.Foundation});var i=n("./js/foundation.dropdown.js");n.d(e,"Dropdown",function(){return i.Dropdown}),o.Foundation.plugin(i.Dropdown,"Dropdown")},"./js/foundation.dropdown.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Dropdown",function(){return g});var o=n("jquery"),r=n.n(o),s=n("./foundation.util.keyboard"),a=n("./foundation.core"),l=n("./js/foundation.positionable.js"),u=n("./js/foundation.util.triggers.js");n("./foundation.util.touch");function i(t){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function c(t,e){for(var n=0;n<e.length;n++){var o=e[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}function f(t,e){return!e||"object"!==i(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t,e,n){return(d="undefined"!=typeof Reflect&&Reflect.get?Reflect.get:function(t,e,n){var o=function(t,e){for(;!Object.prototype.hasOwnProperty.call(t,e)&&null!==(t=h(t)););return t}(t,e);if(o){var i=Object.getOwnPropertyDescriptor(o,e);return i.get?i.get.call(n):i.value}})(t,e,n||t)}function h(t){return(h=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function p(t,e){return(p=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var g=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),f(this,h(n).apply(this,arguments))}var e,o,i;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&p(t,e)}(n,l["Positionable"]),e=n,(o=[{key:"_setup",value:function(t,e){this.$element=t,this.options=r.a.extend({},n.defaults,this.$element.data(),e),this.className="Dropdown",u.Triggers.init(r.a),this._init(),s.Keyboard.register("Dropdown",{ENTER:"toggle",SPACE:"toggle",ESCAPE:"close"})}},{key:"_init",value:function(){var t=this.$element.attr("id");this.$anchors=r()('[data-toggle="'.concat(t,'"]')).length?r()('[data-toggle="'.concat(t,'"]')):r()('[data-open="'.concat(t,'"]')),this.$anchors.attr({"aria-controls":t,"data-is-focus":!1,"data-yeti-box":t,"aria-haspopup":!0,"aria-expanded":!1}),this._setCurrentAnchor(this.$anchors.first()),this.options.parentClass?this.$parent=this.$element.parents("."+this.options.parentClass):this.$parent=null,void 0===this.$element.attr("aria-labelledby")&&(void 0===this.$currentAnchor.attr("id")&&this.$currentAnchor.attr("id",Object(a.GetYoDigits)(6,"dd-anchor")),this.$element.attr("aria-labelledby",this.$currentAnchor.attr("id"))),this.$element.attr({"aria-hidden":"true","data-yeti-box":t,"data-resize":t}),d(h(n.prototype),"_init",this).call(this),this._events()}},{key:"_getDefaultPosition",value:function(){var t=this.$element[0].className.match(/(top|left|right|bottom)/g);return t?t[0]:"bottom"}},{key:"_getDefaultAlignment",value:function(){var t=/float-(\S+)/.exec(this.$currentAnchor.attr("class"));return t?t[1]:d(h(n.prototype),"_getDefaultAlignment",this).call(this)}},{key:"_setPosition",value:function(){this.$element.removeClass("has-position-".concat(this.position," has-alignment-").concat(this.alignment)),d(h(n.prototype),"_setPosition",this).call(this,this.$currentAnchor,this.$element,this.$parent),this.$element.addClass("has-position-".concat(this.position," has-alignment-").concat(this.alignment))}},{key:"_setCurrentAnchor",value:function(t){this.$currentAnchor=r()(t)}},{key:"_events",value:function(){var n=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":this.close.bind(this),"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":this._setPosition.bind(this)}),this.$anchors.off("click.zf.trigger").on("click.zf.trigger",function(){n._setCurrentAnchor(this)}),this.options.hover&&(this.$anchors.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){n._setCurrentAnchor(this);var t=r()("body").data();void 0!==t.whatinput&&"mouse"!==t.whatinput||(clearTimeout(n.timeout),n.timeout=setTimeout(function(){n.open(),n.$anchors.data("hover",!0)},n.options.hoverDelay))}).on("mouseleave.zf.dropdown",Object(a.ignoreMousedisappear)(function(){clearTimeout(n.timeout),n.timeout=setTimeout(function(){n.close(),n.$anchors.data("hover",!1)},n.options.hoverDelay)})),this.options.hoverPane&&this.$element.off("mouseenter.zf.dropdown mouseleave.zf.dropdown").on("mouseenter.zf.dropdown",function(){clearTimeout(n.timeout)}).on("mouseleave.zf.dropdown",Object(a.ignoreMousedisappear)(function(){clearTimeout(n.timeout),n.timeout=setTimeout(function(){n.close(),n.$anchors.data("hover",!1)},n.options.hoverDelay)}))),this.$anchors.add(this.$element).on("keydown.zf.dropdown",function(t){var e=r()(this);s.Keyboard.findFocusable(n.$element);s.Keyboard.handleKey(t,"Dropdown",{open:function(){e.is(n.$anchors)&&!e.is("input, textarea")&&(n.open(),n.$element.attr("tabindex",-1).focus(),t.preventDefault())},close:function(){n.close(),n.$anchors.focus()}})})}},{key:"_addBodyHandler",value:function(){var e=r()(document.body).not(this.$element),n=this;e.off("click.zf.dropdown").on("click.zf.dropdown",function(t){n.$anchors.is(t.target)||n.$anchors.find(t.target).length||n.$element.is(t.target)||n.$element.find(t.target).length||(n.close(),e.off("click.zf.dropdown"))})}},{key:"open",value:function(){if(this.$element.trigger("closeme.zf.dropdown",this.$element.attr("id")),this.$anchors.addClass("hover").attr({"aria-expanded":!0}),this.$element.addClass("is-opening"),this._setPosition(),this.$element.removeClass("is-opening").addClass("is-open").attr({"aria-hidden":!1}),this.options.autoFocus){var t=s.Keyboard.findFocusable(this.$element);t.length&&t.eq(0).focus()}this.options.closeOnClick&&this._addBodyHandler(),this.options.trapFocus&&s.Keyboard.trapFocus(this.$element),this.$element.trigger("show.zf.dropdown",[this.$element])}},{key:"close",value:function(){if(!this.$element.hasClass("is-open"))return!1;this.$element.removeClass("is-open").attr({"aria-hidden":!0}),this.$anchors.removeClass("hover").attr("aria-expanded",!1),this.$element.trigger("hide.zf.dropdown",[this.$element]),this.options.trapFocus&&s.Keyboard.releaseFocus(this.$element)}},{key:"toggle",value:function(){if(this.$element.hasClass("is-open")){if(this.$anchors.data("hover"))return;this.close()}else this.open()}},{key:"_destroy",value:function(){this.$element.off(".zf.trigger").hide(),this.$anchors.off(".zf.dropdown"),r()(document.body).off("click.zf.dropdown")}}])&&c(e.prototype,o),i&&c(e,i),n}();g.defaults={parentClass:null,hoverDelay:250,hover:!1,hoverPane:!1,vOffset:0,hOffset:0,position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,trapFocus:!1,autoFocus:!1,closeOnClick:!1}},"./js/foundation.positionable.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Positionable",function(){return g});var s=n("./foundation.util.box"),r=n("./foundation.core");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function a(t,e){for(var n=0;n<e.length;n++){var o=e[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}function l(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function u(t){return(u=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function c(t,e){return(c=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var f=["left","right","top","bottom"],i=["top","bottom","center"],d=["left","right","center"],h={left:i,right:i,top:d,bottom:d};function p(t,e){var n=e.indexOf(t);return n===e.length-1?e[0]:e[n+1]}var g=function(t){function e(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,e),l(this,u(e).apply(this,arguments))}var n,o,i;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&c(t,e)}(e,r["Plugin"]),n=e,(o=[{key:"_init",value:function(){this.triedPositions={},this.position="auto"===this.options.position?this._getDefaultPosition():this.options.position,this.alignment="auto"===this.options.alignment?this._getDefaultAlignment():this.options.alignment,this.originalPosition=this.position,this.originalAlignment=this.alignment}},{key:"_getDefaultPosition",value:function(){return"bottom"}},{key:"_getDefaultAlignment",value:function(){switch(this.position){case"bottom":case"top":return Object(r.rtl)()?"right":"left";case"left":case"right":return"bottom"}}},{key:"_reposition",value:function(){this._alignmentsExhausted(this.position)?(this.position=p(this.position,f),this.alignment=h[this.position][0]):this._realign()}},{key:"_realign",value:function(){this._addTriedPosition(this.position,this.alignment),this.alignment=p(this.alignment,h[this.position])}},{key:"_addTriedPosition",value:function(t,e){this.triedPositions[t]=this.triedPositions[t]||[],this.triedPositions[t].push(e)}},{key:"_positionsExhausted",value:function(){for(var t=!0,e=0;e<f.length;e++)t=t&&this._alignmentsExhausted(f[e]);return t}},{key:"_alignmentsExhausted",value:function(t){return this.triedPositions[t]&&this.triedPositions[t].length==h[t].length}},{key:"_getVOffset",value:function(){return this.options.vOffset}},{key:"_getHOffset",value:function(){return this.options.hOffset}},{key:"_setPosition",value:function(t,e,n){if("false"===t.attr("aria-expanded"))return!1;s.Box.GetDimensions(e),s.Box.GetDimensions(t);if(this.options.allowOverlap||(this.position=this.originalPosition,this.alignment=this.originalAlignment),e.offset(s.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset())),!this.options.allowOverlap){for(var o=1e8,i={position:this.position,alignment:this.alignment};!this._positionsExhausted();){var r=s.Box.OverlapArea(e,n,!1,!1,this.options.allowBottomOverlap);if(0===r)return;r<o&&(o=r,i={position:this.position,alignment:this.alignment}),this._reposition(),e.offset(s.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}this.position=i.position,this.alignment=i.alignment,e.offset(s.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}}}])&&a(n.prototype,o),i&&a(n,i),e}();g.defaults={position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,vOffset:0,hOffset:0}},"./js/foundation.util.triggers.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Triggers",function(){return c});var o=n("jquery"),r=n.n(o),i=n("./foundation.core"),s=n("./foundation.util.motion");function a(t){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var l=function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if("".concat(t[e],"MutationObserver")in window)return window["".concat(t[e],"MutationObserver")];return!1}(),u=function(e,n){e.data(n).split(" ").forEach(function(t){r()("#".concat(t))["close"===n?"trigger":"triggerHandler"]("".concat(n,".zf.trigger"),[e])})},c={Listeners:{Basic:{},Global:{}},Initializers:{}};function f(e,t,n){var o,i=Array.prototype.slice.call(arguments,3);r()(window).off(t).on(t,function(t){o&&clearTimeout(o),o=setTimeout(function(){n.apply(null,i)},e||10)})}c.Listeners.Basic={openListener:function(){u(r()(this),"open")},closeListener:function(){r()(this).data("close")?u(r()(this),"close"):r()(this).trigger("close.zf.trigger")},toggleListener:function(){r()(this).data("toggle")?u(r()(this),"toggle"):r()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=r()(this).data("closable");""!==e?s.Motion.animateOut(r()(this),e,function(){r()(this).trigger("closed.zf")}):r()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=r()(this).data("toggle-focus");r()("#".concat(t)).triggerHandler("toggle.zf.trigger",[r()(this)])}},c.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",c.Listeners.Basic.openListener)},c.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",c.Listeners.Basic.closeListener)},c.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",c.Listeners.Basic.toggleListener)},c.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",c.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",c.Listeners.Basic.closeableListener)},c.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",c.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",c.Listeners.Basic.toggleFocusListener)},c.Listeners.Global={resizeListener:function(t){l||t.each(function(){r()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){l||t.each(function(){r()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var n=t.namespace.split(".")[0];r()("[data-".concat(n,"]")).not('[data-yeti-box="'.concat(e,'"]')).each(function(){var t=r()(this);t.triggerHandler("close.zf.trigger",[t])})}},c.Initializers.addClosemeListener=function(t){var e=r()("[data-yeti-box]"),n=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?n.push(t):"object"===a(t)&&"string"==typeof t[0]?n=n.concat(t):console.error("Plugin names must be strings")),e.length){var o=n.map(function(t){return"closeme.zf.".concat(t)}).join(" ");r()(window).off(o).on(o,c.Listeners.Global.closeMeListener)}},c.Initializers.addResizeListener=function(t){var e=r()("[data-resize]");e.length&&f(t,"resize.zf.trigger",c.Listeners.Global.resizeListener,e)},c.Initializers.addScrollListener=function(t){var e=r()("[data-scroll]");e.length&&f(t,"scroll.zf.trigger",c.Listeners.Global.scrollListener,e)},c.Initializers.addMutationEventsListener=function(t){if(!l)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),n=function(t){var e=r()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var o=0;o<=e.length-1;o++){new l(n).observe(e[o],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},c.Initializers.addSimpleListeners=function(){var t=r()(document);c.Initializers.addOpenListener(t),c.Initializers.addCloseListener(t),c.Initializers.addToggleListener(t),c.Initializers.addCloseableListener(t),c.Initializers.addToggleFocusListener(t)},c.Initializers.addGlobalListeners=function(){var t=r()(document);c.Initializers.addMutationEventsListener(t),c.Initializers.addResizeListener(),c.Initializers.addScrollListener(),c.Initializers.addClosemeListener()},c.init=function(t,e){Object(i.onLoad)(t(window),function(){!0!==t.triggersInitialized&&(c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners(),t.triggersInitialized=!0)}),e&&(e.Triggers=c,e.IHearYou=c.Initializers.addGlobalListeners)}},4:function(t,e,n){t.exports=n("./js/entries/plugins/foundation.dropdown.js")},jquery:function(t,e){t.exports=i}})});
+//# sourceMappingURL=foundation.dropdown.min.js.map
diff --git a/dist/js/plugins/foundation.dropdown.min.js.map b/dist/js/plugins/foundation.dropdown.min.js.map
new file mode 100644 (file)
index 0000000..53390d5
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.dropdown.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","__WEBPACK_EXTERNAL_MODULE__foundation_util_box__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE__foundation_util_touch__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.box","./foundation.util.keyboard","./foundation.util.motion","./foundation.util.touch","./js/entries/plugins/foundation.dropdown.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_dropdown__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.dropdown.js","Dropdown","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__","_foundation_positionable__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_get","receiver","Reflect","base","_getPrototypeOf","_superPropBase","desc","getOwnPropertyDescriptor","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Positionable","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","init","_init","register","ENTER","SPACE","ESCAPE","$id","attr","$anchors","concat","aria-controls","data-is-focus","data-yeti-box","aria-haspopup","aria-expanded","_setCurrentAnchor","first","parentClass","$parent","parents","$currentAnchor","aria-hidden","data-resize","_events","position","match","horizontalPosition","exec","removeClass","alignment","addClass","el","_this","on","open.zf.trigger","open","close.zf.trigger","close","toggle.zf.trigger","toggle","resizeme.zf.trigger","_setPosition","off","hover","bodyData","whatinput","clearTimeout","timeout","setTimeout","hoverDelay","hoverPane","add","e","$target","findFocusable","handleKey","is","focus","preventDefault","$body","document","body","not","find","trigger","autoFocus","$focusable","eq","closeOnClick","_addBodyHandler","trapFocus","hasClass","releaseFocus","hide","vOffset","hOffset","allowOverlap","allowBottomOverlap","./js/foundation.positionable.js","Positionable","_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","left","right","top","bottom","nextItem","item","array","currentIdx","indexOf","_Plugin","triedPositions","_getDefaultPosition","_getDefaultAlignment","originalPosition","originalAlignment","_alignmentsExhausted","_realign","_addTriedPosition","push","isExhausted","$anchor","GetDimensions","offset","GetExplicitOffsets","_getVOffset","_getHOffset","minOverlap","minCoordinates","_positionsExhausted","overlap","OverlapArea","_reposition","./js/foundation.util.triggers.js","Triggers","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","MutationObserver","prefixes","triggers","type","split","forEach","id","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","listener","timer","args","Array","slice","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","scrollListener","closeMeListener","pluginId","namespace","addClosemeListener","pluginName","yetiBoxes","plugNames","console","error","listeners","map","join","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","attributeName","pageYOffset","closest","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","$","Foundation","triggersInitialized","IHearYou","4","jquery"],"mappings":"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","file":"foundation.dropdown.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.util.keyboard\"), require(\"./foundation.core\"), require(\"jquery\"), require(\"./foundation.util.box\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.util.keyboard\", \"./foundation.core\", \"jquery\", \"./foundation.util.box\", \"./foundation.util.motion\", \"./foundation.util.touch\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.dropdown\"] = factory(require(\"./foundation.util.keyboard\"), require(\"./foundation.core\"), require(\"jquery\"), require(\"./foundation.util.box\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.dropdown\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 4);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.box\":\n/*!********************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.box\"],\"amd\":\"./foundation.util.box\",\"commonjs\":\"./foundation.util.box\",\"commonjs2\":\"./foundation.util.box\"} ***!\n  \\********************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./foundation.util.touch\":\n/*!****************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.touch\"],\"amd\":\"./foundation.util.touch\",\"commonjs\":\"./foundation.util.touch\",\"commonjs2\":\"./foundation.util.touch\"} ***!\n  \\****************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.dropdown.js\":\n/*!***************************************************!*\\\n  !*** ./js/entries/plugins/foundation.dropdown.js ***!\n  \\***************************************************/\n/*! exports provided: Foundation, Dropdown */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_dropdown__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.dropdown */ \"./js/foundation.dropdown.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Dropdown\", function() { return _foundation_dropdown__WEBPACK_IMPORTED_MODULE_1__[\"Dropdown\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_dropdown__WEBPACK_IMPORTED_MODULE_1__[\"Dropdown\"], 'Dropdown');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.dropdown.js\":\n/*!***********************************!*\\\n  !*** ./js/foundation.dropdown.js ***!\n  \\***********************************/\n/*! exports provided: Dropdown */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Dropdown\", function() { return Dropdown; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_positionable__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.positionable */ \"./js/foundation.positionable.js\");\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.touch */ \"./foundation.util.touch\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_touch__WEBPACK_IMPORTED_MODULE_5__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _get(target, property, receiver) { if (typeof Reflect !== \"undefined\" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); }\n\nfunction _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n/**\n * Dropdown module.\n * @module foundation.dropdown\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.triggers\n */\n\nvar Dropdown =\n/*#__PURE__*/\nfunction (_Positionable) {\n  _inherits(Dropdown, _Positionable);\n\n  function Dropdown() {\n    _classCallCheck(this, Dropdown);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Dropdown).apply(this, arguments));\n  }\n\n  _createClass(Dropdown, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a dropdown.\n     * @class\n     * @name Dropdown\n     * @param {jQuery} element - jQuery object to make into a dropdown.\n     *        Object should be of the dropdown panel, rather than its anchor.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Dropdown.defaults, this.$element.data(), options);\n      this.className = 'Dropdown'; // ie9 back compat\n      // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('Dropdown', {\n        'ENTER': 'toggle',\n        'SPACE': 'toggle',\n        'ESCAPE': 'close'\n      });\n    }\n    /**\n     * Initializes the plugin by setting/checking options and attributes, adding helper variables, and saving the anchor.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var $id = this.$element.attr('id');\n      this.$anchors = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-toggle=\\\"\".concat($id, \"\\\"]\")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-toggle=\\\"\".concat($id, \"\\\"]\")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open=\\\"\".concat($id, \"\\\"]\"));\n      this.$anchors.attr({\n        'aria-controls': $id,\n        'data-is-focus': false,\n        'data-yeti-box': $id,\n        'aria-haspopup': true,\n        'aria-expanded': false\n      });\n\n      this._setCurrentAnchor(this.$anchors.first());\n\n      if (this.options.parentClass) {\n        this.$parent = this.$element.parents('.' + this.options.parentClass);\n      } else {\n        this.$parent = null;\n      } // Set [aria-labelledby] on the Dropdown if it is not set\n\n\n      if (typeof this.$element.attr('aria-labelledby') === 'undefined') {\n        // Get the anchor ID or create one\n        if (typeof this.$currentAnchor.attr('id') === 'undefined') {\n          this.$currentAnchor.attr('id', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'dd-anchor'));\n        }\n\n        ;\n        this.$element.attr('aria-labelledby', this.$currentAnchor.attr('id'));\n      }\n\n      this.$element.attr({\n        'aria-hidden': 'true',\n        'data-yeti-box': $id,\n        'data-resize': $id\n      });\n\n      _get(_getPrototypeOf(Dropdown.prototype), \"_init\", this).call(this);\n\n      this._events();\n    }\n  }, {\n    key: \"_getDefaultPosition\",\n    value: function _getDefaultPosition() {\n      // handle legacy classnames\n      var position = this.$element[0].className.match(/(top|left|right|bottom)/g);\n\n      if (position) {\n        return position[0];\n      } else {\n        return 'bottom';\n      }\n    }\n  }, {\n    key: \"_getDefaultAlignment\",\n    value: function _getDefaultAlignment() {\n      // handle legacy float approach\n      var horizontalPosition = /float-(\\S+)/.exec(this.$currentAnchor.attr('class'));\n\n      if (horizontalPosition) {\n        return horizontalPosition[1];\n      }\n\n      return _get(_getPrototypeOf(Dropdown.prototype), \"_getDefaultAlignment\", this).call(this);\n    }\n    /**\n     * Sets the position and orientation of the dropdown pane, checks for collisions if allow-overlap is not true.\n     * Recursively calls itself if a collision is detected, with a new position class.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_setPosition\",\n    value: function _setPosition() {\n      this.$element.removeClass(\"has-position-\".concat(this.position, \" has-alignment-\").concat(this.alignment));\n\n      _get(_getPrototypeOf(Dropdown.prototype), \"_setPosition\", this).call(this, this.$currentAnchor, this.$element, this.$parent);\n\n      this.$element.addClass(\"has-position-\".concat(this.position, \" has-alignment-\").concat(this.alignment));\n    }\n    /**\n     * Make it a current anchor.\n     * Current anchor as the reference for the position of Dropdown panes.\n     * @param {HTML} el - DOM element of the anchor.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_setCurrentAnchor\",\n    value: function _setCurrentAnchor(el) {\n      this.$currentAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(el);\n    }\n    /**\n     * Adds event listeners to the element utilizing the triggers utility library.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this.$element.on({\n        'open.zf.trigger': this.open.bind(this),\n        'close.zf.trigger': this.close.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this),\n        'resizeme.zf.trigger': this._setPosition.bind(this)\n      });\n      this.$anchors.off('click.zf.trigger').on('click.zf.trigger', function () {\n        _this._setCurrentAnchor(this);\n      });\n\n      if (this.options.hover) {\n        this.$anchors.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {\n          _this._setCurrentAnchor(this);\n\n          var bodyData = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').data();\n\n          if (typeof bodyData.whatinput === 'undefined' || bodyData.whatinput === 'mouse') {\n            clearTimeout(_this.timeout);\n            _this.timeout = setTimeout(function () {\n              _this.open();\n\n              _this.$anchors.data('hover', true);\n            }, _this.options.hoverDelay);\n          }\n        }).on('mouseleave.zf.dropdown', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"ignoreMousedisappear\"])(function () {\n          clearTimeout(_this.timeout);\n          _this.timeout = setTimeout(function () {\n            _this.close();\n\n            _this.$anchors.data('hover', false);\n          }, _this.options.hoverDelay);\n        }));\n\n        if (this.options.hoverPane) {\n          this.$element.off('mouseenter.zf.dropdown mouseleave.zf.dropdown').on('mouseenter.zf.dropdown', function () {\n            clearTimeout(_this.timeout);\n          }).on('mouseleave.zf.dropdown', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"ignoreMousedisappear\"])(function () {\n            clearTimeout(_this.timeout);\n            _this.timeout = setTimeout(function () {\n              _this.close();\n\n              _this.$anchors.data('hover', false);\n            }, _this.options.hoverDelay);\n          }));\n        }\n      }\n\n      this.$anchors.add(this.$element).on('keydown.zf.dropdown', function (e) {\n        var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            visibleFocusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].findFocusable(_this.$element);\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'Dropdown', {\n          open: function open() {\n            if ($target.is(_this.$anchors) && !$target.is('input, textarea')) {\n              _this.open();\n\n              _this.$element.attr('tabindex', -1).focus();\n\n              e.preventDefault();\n            }\n          },\n          close: function close() {\n            _this.close();\n\n            _this.$anchors.focus();\n          }\n        });\n      });\n    }\n    /**\n     * Adds an event handler to the body to close any dropdowns on a click.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_addBodyHandler\",\n    value: function _addBodyHandler() {\n      var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).not(this.$element),\n          _this = this;\n\n      $body.off('click.zf.dropdown').on('click.zf.dropdown', function (e) {\n        if (_this.$anchors.is(e.target) || _this.$anchors.find(e.target).length) {\n          return;\n        }\n\n        if (_this.$element.is(e.target) || _this.$element.find(e.target).length) {\n          return;\n        }\n\n        _this.close();\n\n        $body.off('click.zf.dropdown');\n      });\n    }\n    /**\n     * Opens the dropdown pane, and fires a bubbling event to close other dropdowns.\n     * @function\n     * @fires Dropdown#closeme\n     * @fires Dropdown#show\n     */\n\n  }, {\n    key: \"open\",\n    value: function open() {\n      // var _this = this;\n\n      /**\n       * Fires to close other open dropdowns, typically when dropdown is opening\n       * @event Dropdown#closeme\n       */\n      this.$element.trigger('closeme.zf.dropdown', this.$element.attr('id'));\n      this.$anchors.addClass('hover').attr({\n        'aria-expanded': true\n      }); // this.$element/*.show()*/;\n\n      this.$element.addClass('is-opening');\n\n      this._setPosition();\n\n      this.$element.removeClass('is-opening').addClass('is-open').attr({\n        'aria-hidden': false\n      });\n\n      if (this.options.autoFocus) {\n        var $focusable = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].findFocusable(this.$element);\n\n        if ($focusable.length) {\n          $focusable.eq(0).focus();\n        }\n      }\n\n      if (this.options.closeOnClick) {\n        this._addBodyHandler();\n      }\n\n      if (this.options.trapFocus) {\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].trapFocus(this.$element);\n      }\n      /**\n       * Fires once the dropdown is visible.\n       * @event Dropdown#show\n       */\n\n\n      this.$element.trigger('show.zf.dropdown', [this.$element]);\n    }\n    /**\n     * Closes the open dropdown pane.\n     * @function\n     * @fires Dropdown#hide\n     */\n\n  }, {\n    key: \"close\",\n    value: function close() {\n      if (!this.$element.hasClass('is-open')) {\n        return false;\n      }\n\n      this.$element.removeClass('is-open').attr({\n        'aria-hidden': true\n      });\n      this.$anchors.removeClass('hover').attr('aria-expanded', false);\n      /**\n       * Fires once the dropdown is no longer visible.\n       * @event Dropdown#hide\n       */\n\n      this.$element.trigger('hide.zf.dropdown', [this.$element]);\n\n      if (this.options.trapFocus) {\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].releaseFocus(this.$element);\n      }\n    }\n    /**\n     * Toggles the dropdown pane's visibility.\n     * @function\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle() {\n      if (this.$element.hasClass('is-open')) {\n        if (this.$anchors.data('hover')) return;\n        this.close();\n      } else {\n        this.open();\n      }\n    }\n    /**\n     * Destroys the dropdown.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.trigger').hide();\n      this.$anchors.off('.zf.dropdown');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('click.zf.dropdown');\n    }\n  }]);\n\n  return Dropdown;\n}(_foundation_positionable__WEBPACK_IMPORTED_MODULE_3__[\"Positionable\"]);\n\nDropdown.defaults = {\n  /**\n   * Class that designates bounding container of Dropdown (default: window)\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  parentClass: null,\n\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 250\n   */\n  hoverDelay: 250,\n\n  /**\n   * Allow submenus to open on hover events\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hover: false,\n\n  /**\n   * Don't close dropdown when hovering over dropdown pane\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  hoverPane: false,\n\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n\n  /**\n   * Number of pixels between the dropdown pane and the triggering element on open.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n\n  /**\n   * Position of dropdown. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n\n  /**\n   * Alignment of dropdown relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow overlap of container/window. If false, dropdown will first try to position as defined by data-position and data-alignment, but reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n\n  /**\n   * Allow the plugin to trap focus to the dropdown pane if opened with keyboard commands.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false,\n\n  /**\n   * Allow the plugin to set focus to the first focusable element within the pane, regardless of method of opening.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows a click on the body to close the dropdown.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  closeOnClick: false\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.positionable.js\":\n/*!***************************************!*\\\n  !*** ./js/foundation.positionable.js ***!\n  \\***************************************/\n/*! exports provided: Positionable */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Positionable\", function() { return Positionable; });\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.util.box */ \"./foundation.util.box\");\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\nvar POSITIONS = ['left', 'right', 'top', 'bottom'];\nvar VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nvar HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\nvar ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n};\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n\n  if (currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\nvar Positionable =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Positionable, _Plugin);\n\n  function Positionable() {\n    _classCallCheck(this, Positionable);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments));\n  }\n\n  _createClass(Positionable, [{\n    key: \"_init\",\n\n    /**\n     * Abstract class encapsulating the tether-like explicit positioning logic\n     * including repositioning based on overlap.\n     * Expects classes to define defaults for vOffset, hOffset, position,\n     * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n     * extending the defaults, or (for now recommended due to the way docs are\n     * generated) by explicitly declaring them.\n     *\n     **/\n    value: function _init() {\n      this.triedPositions = {};\n      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n      this.originalPosition = this.position;\n      this.originalAlignment = this.alignment;\n    }\n  }, {\n    key: \"_getDefaultPosition\",\n    value: function _getDefaultPosition() {\n      return 'bottom';\n    }\n  }, {\n    key: \"_getDefaultAlignment\",\n    value: function _getDefaultAlignment() {\n      switch (this.position) {\n        case 'bottom':\n        case 'top':\n          return Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"rtl\"])() ? 'right' : 'left';\n\n        case 'left':\n        case 'right':\n          return 'bottom';\n      }\n    }\n    /**\n     * Adjusts the positionable possible positions by iterating through alignments\n     * and positions.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_reposition\",\n    value: function _reposition() {\n      if (this._alignmentsExhausted(this.position)) {\n        this.position = nextItem(this.position, POSITIONS);\n        this.alignment = ALIGNMENTS[this.position][0];\n      } else {\n        this._realign();\n      }\n    }\n    /**\n     * Adjusts the dropdown pane possible positions by iterating through alignments\n     * on the current position.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_realign\",\n    value: function _realign() {\n      this._addTriedPosition(this.position, this.alignment);\n\n      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);\n    }\n  }, {\n    key: \"_addTriedPosition\",\n    value: function _addTriedPosition(position, alignment) {\n      this.triedPositions[position] = this.triedPositions[position] || [];\n      this.triedPositions[position].push(alignment);\n    }\n  }, {\n    key: \"_positionsExhausted\",\n    value: function _positionsExhausted() {\n      var isExhausted = true;\n\n      for (var i = 0; i < POSITIONS.length; i++) {\n        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n      }\n\n      return isExhausted;\n    }\n  }, {\n    key: \"_alignmentsExhausted\",\n    value: function _alignmentsExhausted(position) {\n      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n    } // When we're trying to center, we don't want to apply offset that's going to\n    // take us just off center, so wrap around to return 0 for the appropriate\n    // offset in those alignments.  TODO: Figure out if we want to make this\n    // configurable behavior... it feels more intuitive, especially for tooltips, but\n    // it's possible someone might actually want to start from center and then nudge\n    // slightly off.\n\n  }, {\n    key: \"_getVOffset\",\n    value: function _getVOffset() {\n      return this.options.vOffset;\n    }\n  }, {\n    key: \"_getHOffset\",\n    value: function _getHOffset() {\n      return this.options.hOffset;\n    }\n  }, {\n    key: \"_setPosition\",\n    value: function _setPosition($anchor, $element, $parent) {\n      if ($anchor.attr('aria-expanded') === 'false') {\n        return false;\n      }\n\n      var $eleDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetDimensions($element),\n          $anchorDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetDimensions($anchor);\n\n      if (!this.options.allowOverlap) {\n        // restore original position & alignment before checking overlap\n        this.position = this.originalPosition;\n        this.alignment = this.originalAlignment;\n      }\n\n      $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n      if (!this.options.allowOverlap) {\n        var overlaps = {};\n        var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better\n\n        var minCoordinates = {\n          position: this.position,\n          alignment: this.alignment\n        };\n\n        while (!this._positionsExhausted()) {\n          var overlap = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n\n          if (overlap === 0) {\n            return;\n          }\n\n          if (overlap < minOverlap) {\n            minOverlap = overlap;\n            minCoordinates = {\n              position: this.position,\n              alignment: this.alignment\n            };\n          }\n\n          this._reposition();\n\n          $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n        } // If we get through the entire loop, there was no non-overlapping\n        // position available. Pick the version with least overlap.\n\n\n        this.position = minCoordinates.position;\n        this.alignment = minCoordinates.alignment;\n        $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n    }\n  }]);\n\n  return Positionable;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 4:\n/*!*********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.dropdown.js ***!\n  \\*********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.dropdown.js */\"./js/entries/plugins/foundation.dropdown.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.dropdown.js.map"]}
\ No newline at end of file
index c3d88fb1bcbe454a6783af2a747d55639907d36e..a82494b45382ab4975f5bef67c7aa40c956a8f73 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.box"), require("./foundation.util.keyboard"), require("./foundation.util.nest"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.box", "./foundation.util.keyboard", "./foundation.util.nest", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.dropdownMenu"] = factory(require("./foundation.core"), require("./foundation.util.box"), require("./foundation.util.keyboard"), require("./foundation.util.nest"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.dropdownMenu"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.box"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.nest"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 84);
+/******/       return __webpack_require__(__webpack_require__.s = 5);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.box":
+/*!********************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.box"],"amd":"./foundation.util.box","commonjs":"./foundation.util.box","commonjs2":"./foundation.util.box"} ***!
+  \********************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;
 
 /***/ }),
 
-/***/ 18:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_dropdownMenu__ = __webpack_require__(48);
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
+/***/ }),
 
+/***/ "./foundation.util.nest":
+/*!************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.nest"],"amd":"./foundation.util.nest","commonjs":"./foundation.util.nest","commonjs2":"./foundation.util.nest"} ***!
+  \************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_dropdownMenu__["a" /* DropdownMenu */], 'DropdownMenu');
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;
 
 /***/ }),
 
-/***/ 2:
-/***/ (function(module, exports) {
+/***/ "./js/entries/plugins/foundation.dropdownMenu.js":
+/*!*******************************************************!*\
+  !*** ./js/entries/plugins/foundation.dropdownMenu.js ***!
+  \*******************************************************/
+/*! exports provided: Foundation, DropdownMenu */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-module.exports = {Plugin: window.Foundation.Plugin};
+/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.dropdownMenu */ "./js/foundation.dropdownMenu.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "DropdownMenu", function() { return _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_1__["DropdownMenu"]; });
 
-/***/ }),
 
-/***/ 3:
-/***/ (function(module, exports) {
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_1__["DropdownMenu"], 'DropdownMenu');
+
 
 /***/ }),
 
-/***/ 48:
+/***/ "./js/foundation.dropdownMenu.js":
+/*!***************************************!*\
+  !*** ./js/foundation.dropdownMenu.js ***!
+  \***************************************/
+/*! exports provided: DropdownMenu */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return DropdownMenu; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__ = __webpack_require__(9);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_box__ = __webpack_require__(8);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_box___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_box__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__foundation_plugin__);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "DropdownMenu", function() { return DropdownMenu; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ "./foundation.core");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.nest */ "./foundation.util.nest");
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__);
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.box */ "./foundation.util.box");
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_box__WEBPACK_IMPORTED_MODULE_4__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(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 _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -153,17 +217,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.nest
  */
 
-var DropdownMenu = function (_Plugin) {
+var DropdownMenu =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(DropdownMenu, _Plugin);
 
   function DropdownMenu() {
     _classCallCheck(this, DropdownMenu);
 
-    return _possibleConstructorReturn(this, (DropdownMenu.__proto__ || Object.getPrototypeOf(DropdownMenu)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(DropdownMenu).apply(this, arguments));
   }
 
   _createClass(DropdownMenu, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of DropdownMenu.
@@ -175,12 +241,12 @@ var DropdownMenu = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, DropdownMenu.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, DropdownMenu.defaults, this.$element.data(), options);
       this.className = 'DropdownMenu'; // ie9 back compat
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('DropdownMenu', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('DropdownMenu', {
         'ENTER': 'open',
         'SPACE': 'open',
         'ARROW_RIGHT': 'next',
@@ -190,7 +256,6 @@ var DropdownMenu = function (_Plugin) {
         'ESCAPE': 'close'
       });
     }
-
     /**
      * Initializes the plugin, and calls _prepareMenu
      * @private
@@ -198,19 +263,17 @@ var DropdownMenu = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["Nest"].Feather(this.$element, 'dropdown');
-
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__["Nest"].Feather(this.$element, 'dropdown');
       var subs = this.$element.find('li.is-dropdown-submenu-parent');
       this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');
-
       this.$menuItems = this.$element.find('[role="menuitem"]');
       this.$tabs = this.$element.children('[role="menuitem"]');
       this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);
 
       if (this.options.alignment === 'auto') {
-        if (this.$element.hasClass(this.options.rightClass) || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_4__foundation_util_core__["rtl"])() || this.$element.parents('.top-bar-right').is('*')) {
+        if (this.$element.hasClass(this.options.rightClass) || Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["rtl"])() || this.$element.parents('.top-bar-right').is('*')) {
           this.options.alignment = 'right';
           subs.addClass('opens-left');
         } else {
@@ -224,20 +287,21 @@ var DropdownMenu = function (_Plugin) {
           subs.addClass('opens-right');
         }
       }
+
       this.changed = false;
+
       this._events();
     }
   }, {
-    key: '_isVertical',
+    key: "_isVertical",
     value: function _isVertical() {
       return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';
     }
   }, {
-    key: '_isRtl',
+    key: "_isRtl",
     value: function _isRtl() {
-      return this.$element.hasClass('align-right') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_4__foundation_util_core__["rtl"])() && !this.$element.hasClass('align-left');
+      return this.$element.hasClass('align-right') || Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["rtl"])() && !this.$element.hasClass('align-left');
     }
-
     /**
      * Adds event listeners to elements within the menu
      * @private
@@ -245,15 +309,15 @@ var DropdownMenu = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this,
           hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined',
-          parClass = 'is-dropdown-submenu-parent';
+          parClass = 'is-dropdown-submenu-parent'; // used for onClick and in the keyboard handlers
+
 
-      // used for onClick and in the keyboard handlers
-      var handleClickFn = function (e) {
-        var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).parentsUntil('ul', '.' + parClass),
+      var handleClickFn = function handleClickFn(e) {
+        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', ".".concat(parClass)),
             hasSub = $elem.hasClass(parClass),
             hasClicked = $elem.attr('data-is-click') === 'true',
             $sub = $elem.children('.is-dropdown-submenu');
@@ -265,26 +329,30 @@ var DropdownMenu = function (_Plugin) {
             } else {
               e.stopImmediatePropagation();
               e.preventDefault();
+
               _this._hide($elem);
             }
           } else {
             e.preventDefault();
             e.stopImmediatePropagation();
+
             _this._show($sub);
-            $elem.add($elem.parentsUntil(_this.$element, '.' + parClass)).attr('data-is-click', true);
+
+            $elem.add($elem.parentsUntil(_this.$element, ".".concat(parClass))).attr('data-is-click', true);
           }
         }
       };
 
       if (this.options.clickOpen || hasTouch) {
         this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);
-      }
+      } // Handle Leaf element Clicks
+
 
-      // Handle Leaf element Clicks
       if (_this.options.closeOnClickInside) {
         this.$menuItems.on('click.zf.dropdownmenu', function (e) {
-          var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
               hasSub = $elem.hasClass(parClass);
+
           if (!hasSub) {
             _this._hide();
           }
@@ -293,7 +361,7 @@ var DropdownMenu = function (_Plugin) {
 
       if (!this.options.disableHover) {
         this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {
-          var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
               hasSub = $elem.hasClass(parClass);
 
           if (hasSub) {
@@ -302,9 +370,10 @@ var DropdownMenu = function (_Plugin) {
               _this._show($elem.children('.is-dropdown-submenu'));
             }, _this.options.hoverDelay));
           }
-        }).on('mouseleave.zf.dropdownmenu', function (e) {
-          var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        }).on('mouseleave.zf.dropdownMenu', Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["ignoreMousedisappear"])(function (e) {
+          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
               hasSub = $elem.hasClass(parClass);
+
           if (hasSub && _this.options.autoclose) {
             if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) {
               return false;
@@ -315,57 +384,64 @@ var DropdownMenu = function (_Plugin) {
               _this._hide($elem);
             }, _this.options.closingTime));
           }
-        });
+        }));
       }
+
       this.$menuItems.on('keydown.zf.dropdownmenu', function (e) {
-        var $element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).parentsUntil('ul', '[role="menuitem"]'),
+        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', '[role="menuitem"]'),
             isTab = _this.$tabs.index($element) > -1,
             $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),
             $prevElement,
             $nextElement;
-
         $elements.each(function (i) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is($element)) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {
             $prevElement = $elements.eq(i - 1);
             $nextElement = $elements.eq(i + 1);
             return;
           }
         });
 
-        var nextSibling = function () {
+        var nextSibling = function nextSibling() {
           $nextElement.children('a:first').focus();
           e.preventDefault();
         },
-            prevSibling = function () {
+            prevSibling = function prevSibling() {
           $prevElement.children('a:first').focus();
           e.preventDefault();
         },
-            openSub = function () {
+            openSub = function openSub() {
           var $sub = $element.children('ul.is-dropdown-submenu');
+
           if ($sub.length) {
             _this._show($sub);
+
             $element.find('li > a:first').focus();
             e.preventDefault();
           } else {
             return;
           }
         },
-            closeSub = function () {
+            closeSub = function closeSub() {
           //if ($element.is(':first-child')) {
           var close = $element.parent('ul').parent('li');
           close.children('a:first').focus();
+
           _this._hide(close);
-          e.preventDefault();
-          //}
+
+          e.preventDefault(); //}
         };
+
         var functions = {
           open: openSub,
-          close: function () {
+          close: function close() {
             _this._hide(_this.$element);
+
             _this.$menuItems.eq(0).children('a').focus(); // focus to first element
+
+
             e.preventDefault();
           },
-          handled: function () {
+          handled: function handled() {
             e.stopImmediatePropagation();
           }
         };
@@ -375,7 +451,7 @@ var DropdownMenu = function (_Plugin) {
             // vertical menu
             if (_this._isRtl()) {
               // right aligned
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
+              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
                 down: nextSibling,
                 up: prevSibling,
                 next: closeSub,
@@ -383,7 +459,7 @@ var DropdownMenu = function (_Plugin) {
               });
             } else {
               // left aligned
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
+              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
                 down: nextSibling,
                 up: prevSibling,
                 next: openSub,
@@ -394,7 +470,7 @@ var DropdownMenu = function (_Plugin) {
             // horizontal menu
             if (_this._isRtl()) {
               // right aligned
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
+              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
                 next: prevSibling,
                 previous: nextSibling,
                 down: openSub,
@@ -402,7 +478,7 @@ var DropdownMenu = function (_Plugin) {
               });
             } else {
               // left aligned
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
+              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
                 next: nextSibling,
                 previous: prevSibling,
                 down: openSub,
@@ -414,7 +490,7 @@ var DropdownMenu = function (_Plugin) {
           // not tabs -> one sub
           if (_this._isRtl()) {
             // right aligned
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
               next: closeSub,
               previous: openSub,
               down: nextSibling,
@@ -422,7 +498,7 @@ var DropdownMenu = function (_Plugin) {
             });
           } else {
             // left aligned
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend(functions, {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {
               next: openSub,
               previous: closeSub,
               down: nextSibling,
@@ -430,10 +506,10 @@ var DropdownMenu = function (_Plugin) {
             });
           }
         }
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'DropdownMenu', functions);
+
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'DropdownMenu', functions);
       });
     }
-
     /**
      * Adds an event handler to the body to close any dropdowns on a click.
      * @function
@@ -441,60 +517,70 @@ var DropdownMenu = function (_Plugin) {
      */
 
   }, {
-    key: '_addBodyHandler',
+    key: "_addBodyHandler",
     value: function _addBodyHandler() {
-      var $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document.body),
+      var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body),
           _this = this;
+
       $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu').on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function (e) {
         var $link = _this.$element.find(e.target);
+
         if ($link.length) {
           return;
         }
 
         _this._hide();
+
         $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');
       });
     }
-
     /**
      * Opens a dropdown pane, and checks for collisions first.
      * @param {jQuery} $sub - ul element that is a submenu to show
      * @function
      * @private
-     * @fires DropdownMenu#show
+     * @fires Dropdownmenu#show
      */
 
   }, {
-    key: '_show',
+    key: "_show",
     value: function _show($sub) {
       var idx = this.$tabs.index(this.$tabs.filter(function (i, el) {
-        return __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el).find($sub).length > 0;
+        return jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).find($sub).length > 0;
       }));
       var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');
+
       this._hide($sibs, idx);
+
       $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active');
-      var clear = __WEBPACK_IMPORTED_MODULE_3__foundation_util_box__["Box"].ImNotTouchingYou($sub, null, true);
+      var clear = _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__["Box"].ImNotTouchingYou($sub, null, true);
+
       if (!clear) {
         var oldClass = this.options.alignment === 'left' ? '-right' : '-left',
             $parentLi = $sub.parent('.is-dropdown-submenu-parent');
-        $parentLi.removeClass('opens' + oldClass).addClass('opens-' + this.options.alignment);
-        clear = __WEBPACK_IMPORTED_MODULE_3__foundation_util_box__["Box"].ImNotTouchingYou($sub, null, true);
+        $parentLi.removeClass("opens".concat(oldClass)).addClass("opens-".concat(this.options.alignment));
+        clear = _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__["Box"].ImNotTouchingYou($sub, null, true);
+
         if (!clear) {
-          $parentLi.removeClass('opens-' + this.options.alignment).addClass('opens-inner');
+          $parentLi.removeClass("opens-".concat(this.options.alignment)).addClass('opens-inner');
         }
+
         this.changed = true;
       }
+
       $sub.css('visibility', '');
+
       if (this.options.closeOnClick) {
         this._addBodyHandler();
       }
       /**
        * Fires when the new dropdown pane is visible.
-       * @event DropdownMenu#show
+       * @event Dropdownmenu#show
        */
+
+
       this.$element.trigger('show.zf.dropdownmenu', [$sub]);
     }
-
     /**
      * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.
      * @function
@@ -504,57 +590,58 @@ var DropdownMenu = function (_Plugin) {
      */
 
   }, {
-    key: '_hide',
+    key: "_hide",
     value: function _hide($elem, idx) {
       var $toClose;
+
       if ($elem && $elem.length) {
         $toClose = $elem;
-      } else if (idx !== undefined) {
+      } else if (typeof idx !== 'undefined') {
         $toClose = this.$tabs.not(function (i, el) {
           return i === idx;
         });
       } else {
         $toClose = this.$element;
       }
+
       var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;
 
       if (somethingToClose) {
         $toClose.find('li.is-active').add($toClose).attr({
           'data-is-click': false
         }).removeClass('is-active');
-
         $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');
 
         if (this.changed || $toClose.find('opens-inner').length) {
           var oldClass = this.options.alignment === 'left' ? 'right' : 'left';
-          $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass('opens-inner opens-' + this.options.alignment).addClass('opens-' + oldClass);
+          $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass("opens-inner opens-".concat(this.options.alignment)).addClass("opens-".concat(oldClass));
           this.changed = false;
         }
         /**
          * Fires when the open menus are closed.
-         * @event DropdownMenu#hide
+         * @event Dropdownmenu#hide
          */
+
+
         this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);
       }
     }
-
     /**
      * Destroys the plugin.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click').removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document.body).off('.zf.dropdownmenu');
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_nest__["Nest"].Burn(this.$element, 'dropdown');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('.zf.dropdownmenu');
+      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__["Nest"].Burn(this.$element, 'dropdown');
     }
   }]);
 
   return DropdownMenu;
-}(__WEBPACK_IMPORTED_MODULE_5__foundation_plugin__["Plugin"]);
-
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 /**
  * Default settings for plugin
  */
@@ -568,6 +655,7 @@ DropdownMenu.defaults = {
    * @default false
    */
   disableHover: false,
+
   /**
    * Allow a submenu to automatically close on a mouseleave event, if not clicked open.
    * @option
@@ -575,6 +663,7 @@ DropdownMenu.defaults = {
    * @default true
    */
   autoclose: true,
+
   /**
    * Amount of time to delay opening a submenu on hover event.
    * @option
@@ -582,6 +671,7 @@ DropdownMenu.defaults = {
    * @default 50
    */
   hoverDelay: 50,
+
   /**
    * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.
    * @option
@@ -589,14 +679,15 @@ DropdownMenu.defaults = {
    * @default false
    */
   clickOpen: false,
+
   /**
    * Amount of time to delay closing a submenu on a mouseleave event.
    * @option
    * @type {number}
    * @default 500
    */
-
   closingTime: 500,
+
   /**
    * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.
    * @option
@@ -604,6 +695,7 @@ DropdownMenu.defaults = {
    * @default 'auto'
    */
   alignment: 'auto',
+
   /**
    * Allow clicks on the body to close any open submenus.
    * @option
@@ -611,6 +703,7 @@ DropdownMenu.defaults = {
    * @default true
    */
   closeOnClick: true,
+
   /**
    * Allow clicks on leaf anchor links to close any open submenus.
    * @option
@@ -618,6 +711,7 @@ DropdownMenu.defaults = {
    * @default true
    */
   closeOnClickInside: true,
+
   /**
    * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.
    * @option
@@ -625,6 +719,7 @@ DropdownMenu.defaults = {
    * @default 'vertical'
    */
   verticalClass: 'vertical',
+
   /**
    * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.
    * @option
@@ -632,6 +727,7 @@ DropdownMenu.defaults = {
    * @default 'align-right'
    */
   rightClass: 'align-right',
+
   /**
    * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.
    * @option
@@ -642,36 +738,31 @@ DropdownMenu.defaults = {
 };
 
 
-
 /***/ }),
 
 /***/ 5:
-/***/ (function(module, exports) {
-
-module.exports = {Keyboard: window.Foundation.Keyboard};
-
-/***/ }),
-
-/***/ 8:
-/***/ (function(module, exports) {
-
-module.exports = {Box: window.Foundation.Box};
-
-/***/ }),
-
-/***/ 84:
+/*!*************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.dropdownMenu.js ***!
+  \*************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(18);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.dropdownMenu.js */"./js/entries/plugins/foundation.dropdownMenu.js");
 
 
 /***/ }),
 
-/***/ 9:
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Nest: window.Foundation.Nest};
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.dropdownMenu.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.dropdownMenu.js.map b/dist/js/plugins/foundation.dropdownMenu.js.map
new file mode 100644 (file)
index 0000000..ecc3f5b
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.box\"],\"amd\":\"./foundation.util.box\",\"commonjs\":\"./foundation.util.box\",\"commonjs2\":\"./foundation.util.box\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.nest\"],\"amd\":\"./foundation.util.nest\",\"commonjs\":\"./foundation.util.nest\",\"commonjs2\":\"./foundation.util.nest\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.dropdownMenu.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.dropdownMenu.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","DropdownMenu","element","options","$element","$","extend","defaults","data","className","_init","Keyboard","register","Nest","Feather","subs","find","children","addClass","$menuItems","$tabs","verticalClass","alignment","hasClass","rightClass","Rtl","parents","is","changed","_events","css","_this","hasTouch","window","ontouchstart","parClass","handleClickFn","e","$elem","target","parentsUntil","hasSub","hasClicked","attr","$sub","closeOnClick","clickOpen","forceFollow","stopImmediatePropagation","preventDefault","_hide","_show","add","on","closeOnClickInside","disableHover","clearTimeout","setTimeout","hoverDelay","ignoreMousedisappear","autoclose","closingTime","isTab","index","$elements","siblings","$prevElement","$nextElement","each","i","eq","nextSibling","focus","prevSibling","openSub","length","closeSub","close","parent","functions","open","handled","_isVertical","_isRtl","down","up","next","previous","handleKey","$body","document","body","off","$link","idx","filter","el","$sibs","clear","Box","ImNotTouchingYou","oldClass","$parentLi","removeClass","_addBodyHandler","trigger","$toClose","not","somethingToClose","removeAttr","Burn","Plugin"],"mappings":"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","file":"foundation.dropdownMenu.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.box\", \"./foundation.util.keyboard\", \"./foundation.util.nest\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.dropdownMenu\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.dropdownMenu\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.nest\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 5);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;","import { Foundation } from './foundation.core';\n\nimport { DropdownMenu } from '../../foundation.dropdownMenu';\nFoundation.plugin(DropdownMenu, 'DropdownMenu');\n\nexport { Foundation, DropdownMenu};\n","'use strict';\n\nimport $ from 'jquery';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl, ignoreMousedisappear } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Nest } from './foundation.util.nest';\nimport { Box } from './foundation.util.box';\n\n/**\n * DropdownMenu module.\n * @module foundation.dropdown-menu\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.nest\n */\n\nclass DropdownMenu extends Plugin {\n  /**\n   * Creates a new instance of DropdownMenu.\n   * @class\n   * @name DropdownMenu\n   * @fires DropdownMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n    this.className = 'DropdownMenu'; // ie9 back compat\n\n    this._init();\n\n    Keyboard.register('DropdownMenu', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'up',\n      'ARROW_DOWN': 'down',\n      'ARROW_LEFT': 'previous',\n      'ESCAPE': 'close'\n    });\n  }\n\n  /**\n   * Initializes the plugin, and calls _prepareMenu\n   * @private\n   * @function\n   */\n  _init() {\n    Nest.Feather(this.$element, 'dropdown');\n\n    var subs = this.$element.find('li.is-dropdown-submenu-parent');\n    this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');\n\n    this.$menuItems = this.$element.find('[role=\"menuitem\"]');\n    this.$tabs = this.$element.children('[role=\"menuitem\"]');\n    this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);\n\n    if (this.options.alignment === 'auto') {\n        if (this.$element.hasClass(this.options.rightClass) || Rtl() || this.$element.parents('.top-bar-right').is('*')) {\n            this.options.alignment = 'right';\n            subs.addClass('opens-left');\n        } else {\n            this.options.alignment = 'left';\n            subs.addClass('opens-right');\n        }\n    } else {\n      if (this.options.alignment === 'right') {\n          subs.addClass('opens-left');\n      } else {\n          subs.addClass('opens-right');\n      }\n    }\n    this.changed = false;\n    this._events();\n  };\n\n  _isVertical() {\n    return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';\n  }\n\n  _isRtl() {\n    return this.$element.hasClass('align-right') || (Rtl() && !this.$element.hasClass('align-left'));\n  }\n\n  /**\n   * Adds event listeners to elements within the menu\n   * @private\n   * @function\n   */\n  _events() {\n    var _this = this,\n        hasTouch = 'ontouchstart' in window || (typeof window.ontouchstart !== 'undefined'),\n        parClass = 'is-dropdown-submenu-parent';\n\n    // used for onClick and in the keyboard handlers\n    var handleClickFn = function(e) {\n      var $elem = $(e.target).parentsUntil('ul', `.${parClass}`),\n          hasSub = $elem.hasClass(parClass),\n          hasClicked = $elem.attr('data-is-click') === 'true',\n          $sub = $elem.children('.is-dropdown-submenu');\n\n      if (hasSub) {\n        if (hasClicked) {\n          if (!_this.options.closeOnClick || (!_this.options.clickOpen && !hasTouch) || (_this.options.forceFollow && hasTouch)) { return; }\n          else {\n            e.stopImmediatePropagation();\n            e.preventDefault();\n            _this._hide($elem);\n          }\n        } else {\n          e.preventDefault();\n          e.stopImmediatePropagation();\n          _this._show($sub);\n          $elem.add($elem.parentsUntil(_this.$element, `.${parClass}`)).attr('data-is-click', true);\n        }\n      }\n    };\n\n    if (this.options.clickOpen || hasTouch) {\n      this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);\n    }\n\n    // Handle Leaf element Clicks\n    if(_this.options.closeOnClickInside){\n      this.$menuItems.on('click.zf.dropdownmenu', function(e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if(!hasSub){\n          _this._hide();\n        }\n      });\n    }\n\n    if (!this.options.disableHover) {\n      this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {\n        var $elem = $(this),\n          hasSub = $elem.hasClass(parClass);\n\n        if (hasSub) {\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._show($elem.children('.is-dropdown-submenu'));\n          }, _this.options.hoverDelay));\n        }\n      }).on('mouseleave.zf.dropdownMenu', ignoreMousedisappear(function (e) {\n        var $elem = $(this),\n            hasSub = $elem.hasClass(parClass);\n        if (hasSub && _this.options.autoclose) {\n          if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) { return false; }\n\n          clearTimeout($elem.data('_delay'));\n          $elem.data('_delay', setTimeout(function () {\n            _this._hide($elem);\n          }, _this.options.closingTime));\n        }\n      }));\n    }\n    this.$menuItems.on('keydown.zf.dropdownmenu', function(e) {\n      var $element = $(e.target).parentsUntil('ul', '[role=\"menuitem\"]'),\n          isTab = _this.$tabs.index($element) > -1,\n          $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),\n          $prevElement,\n          $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          $prevElement = $elements.eq(i-1);\n          $nextElement = $elements.eq(i+1);\n          return;\n        }\n      });\n\n      var nextSibling = function() {\n        $nextElement.children('a:first').focus();\n        e.preventDefault();\n      }, prevSibling = function() {\n        $prevElement.children('a:first').focus();\n        e.preventDefault();\n      }, openSub = function() {\n        var $sub = $element.children('ul.is-dropdown-submenu');\n        if ($sub.length) {\n          _this._show($sub);\n          $element.find('li > a:first').focus();\n          e.preventDefault();\n        } else { return; }\n      }, closeSub = function() {\n        //if ($element.is(':first-child')) {\n        var close = $element.parent('ul').parent('li');\n        close.children('a:first').focus();\n        _this._hide(close);\n        e.preventDefault();\n        //}\n      };\n      var functions = {\n        open: openSub,\n        close: function() {\n          _this._hide(_this.$element);\n          _this.$menuItems.eq(0).children('a').focus(); // focus to first element\n          e.preventDefault();\n        },\n        handled: function() {\n          e.stopImmediatePropagation();\n        }\n      };\n\n      if (isTab) {\n        if (_this._isVertical()) { // vertical menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: closeSub,\n              previous: openSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              down: nextSibling,\n              up: prevSibling,\n              next: openSub,\n              previous: closeSub\n            });\n          }\n        } else { // horizontal menu\n          if (_this._isRtl()) { // right aligned\n            $.extend(functions, {\n              next: prevSibling,\n              previous: nextSibling,\n              down: openSub,\n              up: closeSub\n            });\n          } else { // left aligned\n            $.extend(functions, {\n              next: nextSibling,\n              previous: prevSibling,\n              down: openSub,\n              up: closeSub\n            });\n          }\n        }\n      } else { // not tabs -> one sub\n        if (_this._isRtl()) { // right aligned\n          $.extend(functions, {\n            next: closeSub,\n            previous: openSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        } else { // left aligned\n          $.extend(functions, {\n            next: openSub,\n            previous: closeSub,\n            down: nextSibling,\n            up: prevSibling\n          });\n        }\n      }\n      Keyboard.handleKey(e, 'DropdownMenu', functions);\n\n    });\n  }\n\n  /**\n   * Adds an event handler to the body to close any dropdowns on a click.\n   * @function\n   * @private\n   */\n  _addBodyHandler() {\n    var $body = $(document.body),\n        _this = this;\n    $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu')\n         .on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function(e) {\n           var $link = _this.$element.find(e.target);\n           if ($link.length) { return; }\n\n           _this._hide();\n           $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');\n         });\n  }\n\n  /**\n   * Opens a dropdown pane, and checks for collisions first.\n   * @param {jQuery} $sub - ul element that is a submenu to show\n   * @function\n   * @private\n   * @fires Dropdownmenu#show\n   */\n  _show($sub) {\n    var idx = this.$tabs.index(this.$tabs.filter(function(i, el) {\n      return $(el).find($sub).length > 0;\n    }));\n    var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');\n    this._hide($sibs, idx);\n    $sub.css('visibility', 'hidden').addClass('js-dropdown-active')\n        .parent('li.is-dropdown-submenu-parent').addClass('is-active');\n    var clear = Box.ImNotTouchingYou($sub, null, true);\n    if (!clear) {\n      var oldClass = this.options.alignment === 'left' ? '-right' : '-left',\n          $parentLi = $sub.parent('.is-dropdown-submenu-parent');\n      $parentLi.removeClass(`opens${oldClass}`).addClass(`opens-${this.options.alignment}`);\n      clear = Box.ImNotTouchingYou($sub, null, true);\n      if (!clear) {\n        $parentLi.removeClass(`opens-${this.options.alignment}`).addClass('opens-inner');\n      }\n      this.changed = true;\n    }\n    $sub.css('visibility', '');\n    if (this.options.closeOnClick) { this._addBodyHandler(); }\n    /**\n     * Fires when the new dropdown pane is visible.\n     * @event Dropdownmenu#show\n     */\n    this.$element.trigger('show.zf.dropdownmenu', [$sub]);\n  }\n\n  /**\n   * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.\n   * @function\n   * @param {jQuery} $elem - element with a submenu to hide\n   * @param {Number} idx - index of the $tabs collection to hide\n   * @private\n   */\n  _hide($elem, idx) {\n    var $toClose;\n    if ($elem && $elem.length) {\n      $toClose = $elem;\n    } else if (typeof idx !== 'undefined') {\n      $toClose = this.$tabs.not(function(i, el) {\n        return i === idx;\n      });\n    }\n    else {\n      $toClose = this.$element;\n    }\n    var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;\n\n    if (somethingToClose) {\n      $toClose.find('li.is-active').add($toClose).attr({\n        'data-is-click': false\n      }).removeClass('is-active');\n\n      $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');\n\n      if (this.changed || $toClose.find('opens-inner').length) {\n        var oldClass = this.options.alignment === 'left' ? 'right' : 'left';\n        $toClose.find('li.is-dropdown-submenu-parent').add($toClose)\n                .removeClass(`opens-inner opens-${this.options.alignment}`)\n                .addClass(`opens-${oldClass}`);\n        this.changed = false;\n      }\n      /**\n       * Fires when the open menus are closed.\n       * @event Dropdownmenu#hide\n       */\n      this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);\n    }\n  }\n\n  /**\n   * Destroys the plugin.\n   * @function\n   */\n  _destroy() {\n    this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click')\n        .removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');\n    $(document.body).off('.zf.dropdownmenu');\n    Nest.Burn(this.$element, 'dropdown');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nDropdownMenu.defaults = {\n  /**\n   * Disallows hover events from opening submenus\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoclose: true,\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  hoverDelay: 50,\n  /**\n   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  clickOpen: false,\n  /**\n   * Amount of time to delay closing a submenu on a mouseleave event.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n\n  closingTime: 500,\n  /**\n   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow clicks on the body to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allow clicks on leaf anchor links to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClickInside: true,\n  /**\n   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'vertical'\n   */\n  verticalClass: 'vertical',\n  /**\n   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'align-right'\n   */\n  rightClass: 'align-right',\n  /**\n   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  forceFollow: true\n};\n\nexport {DropdownMenu};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 22c6600ca006daaa49d32f6449c5f215b139357d..1450221ae15ccc6df522831caf60a05e3a3277aa 100644 (file)
@@ -1 +1,2 @@
-!function(e){function n(o){if(t[o])return t[o].exports;var i=t[o]={i:o,l:!1,exports:{}};return e[o].call(i.exports,i,i.exports,n),i.l=!0,i.exports}var t={};n.m=e,n.c=t,n.i=function(e){return e},n.d=function(e,t,o){n.o(e,t)||Object.defineProperty(e,t,{configurable:!1,enumerable:!0,get:o})},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},n.p="",n(n.s=84)}({0:function(e,n){e.exports=jQuery},1:function(e,n){e.exports={Foundation:window.Foundation}},18:function(e,n,t){"use strict";Object.defineProperty(n,"__esModule",{value:!0});var o=t(1),i=(t.n(o),t(48));o.Foundation.plugin(i.a,"DropdownMenu")},2:function(e,n){e.exports={Plugin:window.Foundation.Plugin}},3:function(e,n){e.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},48:function(e,n,t){"use strict";function o(e,n){if(!(e instanceof n))throw new TypeError("Cannot call a class as a function")}function i(e,n){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!n||"object"!=typeof n&&"function"!=typeof n?e:n}function s(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Super expression must either be null or a function, not "+typeof n);e.prototype=Object.create(n&&n.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),n&&(Object.setPrototypeOf?Object.setPrototypeOf(e,n):e.__proto__=n)}t.d(n,"a",function(){return h});var r=t(0),a=t.n(r),u=t(5),d=(t.n(u),t(9)),l=(t.n(d),t(8)),p=(t.n(l),t(3)),c=(t.n(p),t(2)),f=(t.n(c),function(){function e(e,n){for(var t=0;t<n.length;t++){var o=n[t];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}return function(n,t,o){return t&&e(n.prototype,t),o&&e(n,o),n}}()),h=function(e){function n(){return o(this,n),i(this,(n.__proto__||Object.getPrototypeOf(n)).apply(this,arguments))}return s(n,e),f(n,[{key:"_setup",value:function(e,t){this.$element=e,this.options=a.a.extend({},n.defaults,this.$element.data(),t),this.className="DropdownMenu",this._init(),u.Keyboard.register("DropdownMenu",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close"})}},{key:"_init",value:function(){d.Nest.Feather(this.$element,"dropdown");var e=this.$element.find("li.is-dropdown-submenu-parent");this.$element.children(".is-dropdown-submenu-parent").children(".is-dropdown-submenu").addClass("first-sub"),this.$menuItems=this.$element.find('[role="menuitem"]'),this.$tabs=this.$element.children('[role="menuitem"]'),this.$tabs.find("ul.is-dropdown-submenu").addClass(this.options.verticalClass),"auto"===this.options.alignment?this.$element.hasClass(this.options.rightClass)||t.i(p.rtl)()||this.$element.parents(".top-bar-right").is("*")?(this.options.alignment="right",e.addClass("opens-left")):(this.options.alignment="left",e.addClass("opens-right")):"right"===this.options.alignment?e.addClass("opens-left"):e.addClass("opens-right"),this.changed=!1,this._events()}},{key:"_isVertical",value:function(){return"block"===this.$tabs.css("display")||"column"===this.$element.css("flex-direction")}},{key:"_isRtl",value:function(){return this.$element.hasClass("align-right")||t.i(p.rtl)()&&!this.$element.hasClass("align-left")}},{key:"_events",value:function(){var e=this,n="ontouchstart"in window||void 0!==window.ontouchstart,t="is-dropdown-submenu-parent",o=function(o){var i=a()(o.target).parentsUntil("ul","."+t),s=i.hasClass(t),r="true"===i.attr("data-is-click"),u=i.children(".is-dropdown-submenu");if(s)if(r){if(!e.options.closeOnClick||!e.options.clickOpen&&!n||e.options.forceFollow&&n)return;o.stopImmediatePropagation(),o.preventDefault(),e._hide(i)}else o.preventDefault(),o.stopImmediatePropagation(),e._show(u),i.add(i.parentsUntil(e.$element,"."+t)).attr("data-is-click",!0)};(this.options.clickOpen||n)&&this.$menuItems.on("click.zf.dropdownmenu touchstart.zf.dropdownmenu",o),e.options.closeOnClickInside&&this.$menuItems.on("click.zf.dropdownmenu",function(n){a()(this).hasClass(t)||e._hide()}),this.options.disableHover||this.$menuItems.on("mouseenter.zf.dropdownmenu",function(n){var o=a()(this);o.hasClass(t)&&(clearTimeout(o.data("_delay")),o.data("_delay",setTimeout(function(){e._show(o.children(".is-dropdown-submenu"))},e.options.hoverDelay)))}).on("mouseleave.zf.dropdownmenu",function(n){var o=a()(this);if(o.hasClass(t)&&e.options.autoclose){if("true"===o.attr("data-is-click")&&e.options.clickOpen)return!1;clearTimeout(o.data("_delay")),o.data("_delay",setTimeout(function(){e._hide(o)},e.options.closingTime))}}),this.$menuItems.on("keydown.zf.dropdownmenu",function(n){var t,o,i=a()(n.target).parentsUntil("ul",'[role="menuitem"]'),s=e.$tabs.index(i)>-1,r=s?e.$tabs:i.siblings("li").add(i);r.each(function(e){if(a()(this).is(i))return t=r.eq(e-1),void(o=r.eq(e+1))});var d=function(){o.children("a:first").focus(),n.preventDefault()},l=function(){t.children("a:first").focus(),n.preventDefault()},p=function(){var t=i.children("ul.is-dropdown-submenu");t.length&&(e._show(t),i.find("li > a:first").focus(),n.preventDefault())},c=function(){var t=i.parent("ul").parent("li");t.children("a:first").focus(),e._hide(t),n.preventDefault()},f={open:p,close:function(){e._hide(e.$element),e.$menuItems.eq(0).children("a").focus(),n.preventDefault()},handled:function(){n.stopImmediatePropagation()}};s?e._isVertical()?e._isRtl()?a.a.extend(f,{down:d,up:l,next:c,previous:p}):a.a.extend(f,{down:d,up:l,next:p,previous:c}):e._isRtl()?a.a.extend(f,{next:l,previous:d,down:p,up:c}):a.a.extend(f,{next:d,previous:l,down:p,up:c}):e._isRtl()?a.a.extend(f,{next:c,previous:p,down:d,up:l}):a.a.extend(f,{next:p,previous:c,down:d,up:l}),u.Keyboard.handleKey(n,"DropdownMenu",f)})}},{key:"_addBodyHandler",value:function(){var e=a()(document.body),n=this;e.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu").on("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu",function(t){n.$element.find(t.target).length||(n._hide(),e.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu"))})}},{key:"_show",value:function(e){var n=this.$tabs.index(this.$tabs.filter(function(n,t){return a()(t).find(e).length>0})),t=e.parent("li.is-dropdown-submenu-parent").siblings("li.is-dropdown-submenu-parent");this._hide(t,n),e.css("visibility","hidden").addClass("js-dropdown-active").parent("li.is-dropdown-submenu-parent").addClass("is-active");var o=l.Box.ImNotTouchingYou(e,null,!0);if(!o){var i="left"===this.options.alignment?"-right":"-left",s=e.parent(".is-dropdown-submenu-parent");s.removeClass("opens"+i).addClass("opens-"+this.options.alignment),o=l.Box.ImNotTouchingYou(e,null,!0),o||s.removeClass("opens-"+this.options.alignment).addClass("opens-inner"),this.changed=!0}e.css("visibility",""),this.options.closeOnClick&&this._addBodyHandler(),this.$element.trigger("show.zf.dropdownmenu",[e])}},{key:"_hide",value:function(e,n){var t;if(t=e&&e.length?e:void 0!==n?this.$tabs.not(function(e,t){return e===n}):this.$element,t.hasClass("is-active")||t.find(".is-active").length>0){if(t.find("li.is-active").add(t).attr({"data-is-click":!1}).removeClass("is-active"),t.find("ul.js-dropdown-active").removeClass("js-dropdown-active"),this.changed||t.find("opens-inner").length){var o="left"===this.options.alignment?"right":"left";t.find("li.is-dropdown-submenu-parent").add(t).removeClass("opens-inner opens-"+this.options.alignment).addClass("opens-"+o),this.changed=!1}this.$element.trigger("hide.zf.dropdownmenu",[t])}}},{key:"_destroy",value:function(){this.$menuItems.off(".zf.dropdownmenu").removeAttr("data-is-click").removeClass("is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner"),a()(document.body).off(".zf.dropdownmenu"),d.Nest.Burn(this.$element,"dropdown")}}]),n}(c.Plugin);h.defaults={disableHover:!1,autoclose:!0,hoverDelay:50,clickOpen:!1,closingTime:500,alignment:"auto",closeOnClick:!0,closeOnClickInside:!0,verticalClass:"vertical",rightClass:"align-right",forceFollow:!0}},5:function(e,n){e.exports={Keyboard:window.Foundation.Keyboard}},8:function(e,n){e.exports={Box:window.Foundation.Box}},84:function(e,n,t){e.exports=t(18)},9:function(e,n){e.exports={Nest:window.Foundation.Nest}}});
\ No newline at end of file
+!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n(require("./foundation.core"),require("./foundation.util.box"),require("./foundation.util.keyboard"),require("./foundation.util.nest"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.box","./foundation.util.keyboard","./foundation.util.nest","jquery"],n):"object"==typeof exports?exports["foundation.dropdownMenu"]=n(require("./foundation.core"),require("./foundation.util.box"),require("./foundation.util.keyboard"),require("./foundation.util.nest"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.dropdownMenu"]=n(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.box"],e.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],e.__FOUNDATION_EXTERNAL__["foundation.util.nest"],e.jQuery))}(window,function(t,o,i,r,s){return function(t){var o={};function i(e){if(o[e])return o[e].exports;var n=o[e]={i:e,l:!1,exports:{}};return t[e].call(n.exports,n,n.exports,i),n.l=!0,n.exports}return i.m=t,i.c=o,i.d=function(e,n,t){i.o(e,n)||Object.defineProperty(e,n,{enumerable:!0,get:t})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(n,e){if(1&e&&(n=i(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var t=Object.create(null);if(i.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var o in n)i.d(t,o,function(e){return n[e]}.bind(null,o));return t},i.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(n,"a",n),n},i.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},i.p="",i(i.s=5)}({"./foundation.core":function(e,n){e.exports=t},"./foundation.util.box":function(e,n){e.exports=o},"./foundation.util.keyboard":function(e,n){e.exports=i},"./foundation.util.nest":function(e,n){e.exports=r},"./js/entries/plugins/foundation.dropdownMenu.js":function(e,n,t){"use strict";t.r(n);var o=t("./foundation.core");t.d(n,"Foundation",function(){return o.Foundation});var i=t("./js/foundation.dropdownMenu.js");t.d(n,"DropdownMenu",function(){return i.DropdownMenu}),o.Foundation.plugin(i.DropdownMenu,"DropdownMenu")},"./js/foundation.dropdownMenu.js":function(e,n,t){"use strict";t.r(n),t.d(n,"DropdownMenu",function(){return h});var o=t("jquery"),f=t.n(o),u=t("./foundation.core"),p=t("./foundation.util.keyboard"),r=t("./foundation.util.nest"),s=t("./foundation.util.box");function i(e){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function a(e,n){for(var t=0;t<n.length;t++){var o=n[t];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}function d(e,n){return!n||"object"!==i(n)&&"function"!=typeof n?function(e){if(void 0!==e)return e;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(e):n}function l(e){return(l=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function c(e,n){return(c=Object.setPrototypeOf||function(e,n){return e.__proto__=n,e})(e,n)}var h=function(e){function t(){return function(e,n){if(!(e instanceof n))throw new TypeError("Cannot call a class as a function")}(this,t),d(this,l(t).apply(this,arguments))}var n,o,i;return function(e,n){if("function"!=typeof n&&null!==n)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(n&&n.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),n&&c(e,n)}(t,u["Plugin"]),n=t,(o=[{key:"_setup",value:function(e,n){this.$element=e,this.options=f.a.extend({},t.defaults,this.$element.data(),n),this.className="DropdownMenu",this._init(),p.Keyboard.register("DropdownMenu",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"up",ARROW_DOWN:"down",ARROW_LEFT:"previous",ESCAPE:"close"})}},{key:"_init",value:function(){r.Nest.Feather(this.$element,"dropdown");var e=this.$element.find("li.is-dropdown-submenu-parent");this.$element.children(".is-dropdown-submenu-parent").children(".is-dropdown-submenu").addClass("first-sub"),this.$menuItems=this.$element.find('[role="menuitem"]'),this.$tabs=this.$element.children('[role="menuitem"]'),this.$tabs.find("ul.is-dropdown-submenu").addClass(this.options.verticalClass),"auto"===this.options.alignment?this.$element.hasClass(this.options.rightClass)||Object(u.rtl)()||this.$element.parents(".top-bar-right").is("*")?(this.options.alignment="right",e.addClass("opens-left")):(this.options.alignment="left",e.addClass("opens-right")):"right"===this.options.alignment?e.addClass("opens-left"):e.addClass("opens-right"),this.changed=!1,this._events()}},{key:"_isVertical",value:function(){return"block"===this.$tabs.css("display")||"column"===this.$element.css("flex-direction")}},{key:"_isRtl",value:function(){return this.$element.hasClass("align-right")||Object(u.rtl)()&&!this.$element.hasClass("align-left")}},{key:"_events",value:function(){var c=this,r="ontouchstart"in window||void 0!==window.ontouchstart,s="is-dropdown-submenu-parent";(this.options.clickOpen||r)&&this.$menuItems.on("click.zf.dropdownmenu touchstart.zf.dropdownmenu",function(e){var n=f()(e.target).parentsUntil("ul",".".concat(s)),t=n.hasClass(s),o="true"===n.attr("data-is-click"),i=n.children(".is-dropdown-submenu");if(t)if(o){if(!c.options.closeOnClick||!c.options.clickOpen&&!r||c.options.forceFollow&&r)return;e.stopImmediatePropagation(),e.preventDefault(),c._hide(n)}else e.preventDefault(),e.stopImmediatePropagation(),c._show(i),n.add(n.parentsUntil(c.$element,".".concat(s))).attr("data-is-click",!0)}),c.options.closeOnClickInside&&this.$menuItems.on("click.zf.dropdownmenu",function(e){f()(this).hasClass(s)||c._hide()}),this.options.disableHover||this.$menuItems.on("mouseenter.zf.dropdownmenu",function(e){var n=f()(this);n.hasClass(s)&&(clearTimeout(n.data("_delay")),n.data("_delay",setTimeout(function(){c._show(n.children(".is-dropdown-submenu"))},c.options.hoverDelay)))}).on("mouseleave.zf.dropdownMenu",Object(u.ignoreMousedisappear)(function(e){var n=f()(this);if(n.hasClass(s)&&c.options.autoclose){if("true"===n.attr("data-is-click")&&c.options.clickOpen)return!1;clearTimeout(n.data("_delay")),n.data("_delay",setTimeout(function(){c._hide(n)},c.options.closingTime))}})),this.$menuItems.on("keydown.zf.dropdownmenu",function(n){var t,o,i=f()(n.target).parentsUntil("ul",'[role="menuitem"]'),e=-1<c.$tabs.index(i),r=e?c.$tabs:i.siblings("li").add(i);r.each(function(e){if(f()(this).is(i))return t=r.eq(e-1),void(o=r.eq(e+1))});var s=function(){o.children("a:first").focus(),n.preventDefault()},u=function(){t.children("a:first").focus(),n.preventDefault()},a=function(){var e=i.children("ul.is-dropdown-submenu");e.length&&(c._show(e),i.find("li > a:first").focus(),n.preventDefault())},d=function(){var e=i.parent("ul").parent("li");e.children("a:first").focus(),c._hide(e),n.preventDefault()},l={open:a,close:function(){c._hide(c.$element),c.$menuItems.eq(0).children("a").focus(),n.preventDefault()},handled:function(){n.stopImmediatePropagation()}};e?c._isVertical()?c._isRtl()?f.a.extend(l,{down:s,up:u,next:d,previous:a}):f.a.extend(l,{down:s,up:u,next:a,previous:d}):c._isRtl()?f.a.extend(l,{next:u,previous:s,down:a,up:d}):f.a.extend(l,{next:s,previous:u,down:a,up:d}):c._isRtl()?f.a.extend(l,{next:d,previous:a,down:s,up:u}):f.a.extend(l,{next:a,previous:d,down:s,up:u}),p.Keyboard.handleKey(n,"DropdownMenu",l)})}},{key:"_addBodyHandler",value:function(){var n=f()(document.body),t=this;n.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu").on("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu",function(e){t.$element.find(e.target).length||(t._hide(),n.off("mouseup.zf.dropdownmenu touchend.zf.dropdownmenu"))})}},{key:"_show",value:function(t){var e=this.$tabs.index(this.$tabs.filter(function(e,n){return 0<f()(n).find(t).length})),n=t.parent("li.is-dropdown-submenu-parent").siblings("li.is-dropdown-submenu-parent");this._hide(n,e),t.css("visibility","hidden").addClass("js-dropdown-active").parent("li.is-dropdown-submenu-parent").addClass("is-active");var o=s.Box.ImNotTouchingYou(t,null,!0);if(!o){var i="left"===this.options.alignment?"-right":"-left",r=t.parent(".is-dropdown-submenu-parent");r.removeClass("opens".concat(i)).addClass("opens-".concat(this.options.alignment)),(o=s.Box.ImNotTouchingYou(t,null,!0))||r.removeClass("opens-".concat(this.options.alignment)).addClass("opens-inner"),this.changed=!0}t.css("visibility",""),this.options.closeOnClick&&this._addBodyHandler(),this.$element.trigger("show.zf.dropdownmenu",[t])}},{key:"_hide",value:function(e,t){var n;if((n=e&&e.length?e:void 0!==t?this.$tabs.not(function(e,n){return e===t}):this.$element).hasClass("is-active")||0<n.find(".is-active").length){if(n.find("li.is-active").add(n).attr({"data-is-click":!1}).removeClass("is-active"),n.find("ul.js-dropdown-active").removeClass("js-dropdown-active"),this.changed||n.find("opens-inner").length){var o="left"===this.options.alignment?"right":"left";n.find("li.is-dropdown-submenu-parent").add(n).removeClass("opens-inner opens-".concat(this.options.alignment)).addClass("opens-".concat(o)),this.changed=!1}this.$element.trigger("hide.zf.dropdownmenu",[n])}}},{key:"_destroy",value:function(){this.$menuItems.off(".zf.dropdownmenu").removeAttr("data-is-click").removeClass("is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner"),f()(document.body).off(".zf.dropdownmenu"),r.Nest.Burn(this.$element,"dropdown")}}])&&a(n.prototype,o),i&&a(n,i),t}();h.defaults={disableHover:!1,autoclose:!0,hoverDelay:50,clickOpen:!1,closingTime:500,alignment:"auto",closeOnClick:!0,closeOnClickInside:!0,verticalClass:"vertical",rightClass:"align-right",forceFollow:!0}},5:function(e,n,t){e.exports=t("./js/entries/plugins/foundation.dropdownMenu.js")},jquery:function(e,n){e.exports=s}})});
+//# sourceMappingURL=foundation.dropdownMenu.min.js.map
diff --git a/dist/js/plugins/foundation.dropdownMenu.min.js.map b/dist/js/plugins/foundation.dropdownMenu.min.js.map
new file mode 100644 (file)
index 0000000..aa69335
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.dropdownMenu.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_box__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE__foundation_util_nest__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.box","./foundation.util.keyboard","./foundation.util.nest","./js/entries/plugins/foundation.dropdownMenu.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.dropdownMenu.js","DropdownMenu","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_box__WEBPACK_IMPORTED_MODULE_4__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","register","ENTER","SPACE","ARROW_RIGHT","ARROW_UP","ARROW_DOWN","ARROW_LEFT","ESCAPE","Feather","subs","find","children","addClass","$menuItems","$tabs","verticalClass","alignment","hasClass","rightClass","parents","is","changed","_events","css","_this","hasTouch","ontouchstart","parClass","clickOpen","on","e","$elem","parentsUntil","concat","hasSub","hasClicked","attr","$sub","closeOnClick","forceFollow","stopImmediatePropagation","preventDefault","_hide","_show","add","closeOnClickInside","disableHover","clearTimeout","setTimeout","hoverDelay","autoclose","closingTime","$prevElement","$nextElement","isTab","index","$elements","siblings","each","eq","nextSibling","focus","prevSibling","openSub","closeSub","close","parent","functions","open","handled","_isVertical","_isRtl","down","up","next","previous","handleKey","$body","document","body","off","idx","filter","el","$sibs","clear","ImNotTouchingYou","oldClass","$parentLi","removeClass","_addBodyHandler","trigger","$toClose","not","data-is-click","removeAttr","Burn","5","jquery"],"mappings":"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","file":"foundation.dropdownMenu.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.box\", \"./foundation.util.keyboard\", \"./foundation.util.nest\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.dropdownMenu\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.nest\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.dropdownMenu\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.nest\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 5);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.box\":\n/*!********************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.box\"],\"amd\":\"./foundation.util.box\",\"commonjs\":\"./foundation.util.box\",\"commonjs2\":\"./foundation.util.box\"} ***!\n  \\********************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./foundation.util.nest\":\n/*!************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.nest\"],\"amd\":\"./foundation.util.nest\",\"commonjs\":\"./foundation.util.nest\",\"commonjs2\":\"./foundation.util.nest\"} ***!\n  \\************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_nest__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.dropdownMenu.js\":\n/*!*******************************************************!*\\\n  !*** ./js/entries/plugins/foundation.dropdownMenu.js ***!\n  \\*******************************************************/\n/*! exports provided: Foundation, DropdownMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.dropdownMenu */ \"./js/foundation.dropdownMenu.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"DropdownMenu\", function() { return _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_1__[\"DropdownMenu\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_1__[\"DropdownMenu\"], 'DropdownMenu');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.dropdownMenu.js\":\n/*!***************************************!*\\\n  !*** ./js/foundation.dropdownMenu.js ***!\n  \\***************************************/\n/*! exports provided: DropdownMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"DropdownMenu\", function() { return DropdownMenu; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.nest */ \"./foundation.util.nest\");\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.box */ \"./foundation.util.box\");\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_box__WEBPACK_IMPORTED_MODULE_4__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n/**\n * DropdownMenu module.\n * @module foundation.dropdown-menu\n * @requires foundation.util.keyboard\n * @requires foundation.util.box\n * @requires foundation.util.nest\n */\n\nvar DropdownMenu =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(DropdownMenu, _Plugin);\n\n  function DropdownMenu() {\n    _classCallCheck(this, DropdownMenu);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(DropdownMenu).apply(this, arguments));\n  }\n\n  _createClass(DropdownMenu, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of DropdownMenu.\n     * @class\n     * @name DropdownMenu\n     * @fires DropdownMenu#init\n     * @param {jQuery} element - jQuery object to make into a dropdown menu.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, DropdownMenu.defaults, this.$element.data(), options);\n      this.className = 'DropdownMenu'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('DropdownMenu', {\n        'ENTER': 'open',\n        'SPACE': 'open',\n        'ARROW_RIGHT': 'next',\n        'ARROW_UP': 'up',\n        'ARROW_DOWN': 'down',\n        'ARROW_LEFT': 'previous',\n        'ESCAPE': 'close'\n      });\n    }\n    /**\n     * Initializes the plugin, and calls _prepareMenu\n     * @private\n     * @function\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__[\"Nest\"].Feather(this.$element, 'dropdown');\n      var subs = this.$element.find('li.is-dropdown-submenu-parent');\n      this.$element.children('.is-dropdown-submenu-parent').children('.is-dropdown-submenu').addClass('first-sub');\n      this.$menuItems = this.$element.find('[role=\"menuitem\"]');\n      this.$tabs = this.$element.children('[role=\"menuitem\"]');\n      this.$tabs.find('ul.is-dropdown-submenu').addClass(this.options.verticalClass);\n\n      if (this.options.alignment === 'auto') {\n        if (this.$element.hasClass(this.options.rightClass) || Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"rtl\"])() || this.$element.parents('.top-bar-right').is('*')) {\n          this.options.alignment = 'right';\n          subs.addClass('opens-left');\n        } else {\n          this.options.alignment = 'left';\n          subs.addClass('opens-right');\n        }\n      } else {\n        if (this.options.alignment === 'right') {\n          subs.addClass('opens-left');\n        } else {\n          subs.addClass('opens-right');\n        }\n      }\n\n      this.changed = false;\n\n      this._events();\n    }\n  }, {\n    key: \"_isVertical\",\n    value: function _isVertical() {\n      return this.$tabs.css('display') === 'block' || this.$element.css('flex-direction') === 'column';\n    }\n  }, {\n    key: \"_isRtl\",\n    value: function _isRtl() {\n      return this.$element.hasClass('align-right') || Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"rtl\"])() && !this.$element.hasClass('align-left');\n    }\n    /**\n     * Adds event listeners to elements within the menu\n     * @private\n     * @function\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this,\n          hasTouch = 'ontouchstart' in window || typeof window.ontouchstart !== 'undefined',\n          parClass = 'is-dropdown-submenu-parent'; // used for onClick and in the keyboard handlers\n\n\n      var handleClickFn = function handleClickFn(e) {\n        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', \".\".concat(parClass)),\n            hasSub = $elem.hasClass(parClass),\n            hasClicked = $elem.attr('data-is-click') === 'true',\n            $sub = $elem.children('.is-dropdown-submenu');\n\n        if (hasSub) {\n          if (hasClicked) {\n            if (!_this.options.closeOnClick || !_this.options.clickOpen && !hasTouch || _this.options.forceFollow && hasTouch) {\n              return;\n            } else {\n              e.stopImmediatePropagation();\n              e.preventDefault();\n\n              _this._hide($elem);\n            }\n          } else {\n            e.preventDefault();\n            e.stopImmediatePropagation();\n\n            _this._show($sub);\n\n            $elem.add($elem.parentsUntil(_this.$element, \".\".concat(parClass))).attr('data-is-click', true);\n          }\n        }\n      };\n\n      if (this.options.clickOpen || hasTouch) {\n        this.$menuItems.on('click.zf.dropdownmenu touchstart.zf.dropdownmenu', handleClickFn);\n      } // Handle Leaf element Clicks\n\n\n      if (_this.options.closeOnClickInside) {\n        this.$menuItems.on('click.zf.dropdownmenu', function (e) {\n          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n              hasSub = $elem.hasClass(parClass);\n\n          if (!hasSub) {\n            _this._hide();\n          }\n        });\n      }\n\n      if (!this.options.disableHover) {\n        this.$menuItems.on('mouseenter.zf.dropdownmenu', function (e) {\n          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n              hasSub = $elem.hasClass(parClass);\n\n          if (hasSub) {\n            clearTimeout($elem.data('_delay'));\n            $elem.data('_delay', setTimeout(function () {\n              _this._show($elem.children('.is-dropdown-submenu'));\n            }, _this.options.hoverDelay));\n          }\n        }).on('mouseleave.zf.dropdownMenu', Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"ignoreMousedisappear\"])(function (e) {\n          var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n              hasSub = $elem.hasClass(parClass);\n\n          if (hasSub && _this.options.autoclose) {\n            if ($elem.attr('data-is-click') === 'true' && _this.options.clickOpen) {\n              return false;\n            }\n\n            clearTimeout($elem.data('_delay'));\n            $elem.data('_delay', setTimeout(function () {\n              _this._hide($elem);\n            }, _this.options.closingTime));\n          }\n        }));\n      }\n\n      this.$menuItems.on('keydown.zf.dropdownmenu', function (e) {\n        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).parentsUntil('ul', '[role=\"menuitem\"]'),\n            isTab = _this.$tabs.index($element) > -1,\n            $elements = isTab ? _this.$tabs : $element.siblings('li').add($element),\n            $prevElement,\n            $nextElement;\n        $elements.each(function (i) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {\n            $prevElement = $elements.eq(i - 1);\n            $nextElement = $elements.eq(i + 1);\n            return;\n          }\n        });\n\n        var nextSibling = function nextSibling() {\n          $nextElement.children('a:first').focus();\n          e.preventDefault();\n        },\n            prevSibling = function prevSibling() {\n          $prevElement.children('a:first').focus();\n          e.preventDefault();\n        },\n            openSub = function openSub() {\n          var $sub = $element.children('ul.is-dropdown-submenu');\n\n          if ($sub.length) {\n            _this._show($sub);\n\n            $element.find('li > a:first').focus();\n            e.preventDefault();\n          } else {\n            return;\n          }\n        },\n            closeSub = function closeSub() {\n          //if ($element.is(':first-child')) {\n          var close = $element.parent('ul').parent('li');\n          close.children('a:first').focus();\n\n          _this._hide(close);\n\n          e.preventDefault(); //}\n        };\n\n        var functions = {\n          open: openSub,\n          close: function close() {\n            _this._hide(_this.$element);\n\n            _this.$menuItems.eq(0).children('a').focus(); // focus to first element\n\n\n            e.preventDefault();\n          },\n          handled: function handled() {\n            e.stopImmediatePropagation();\n          }\n        };\n\n        if (isTab) {\n          if (_this._isVertical()) {\n            // vertical menu\n            if (_this._isRtl()) {\n              // right aligned\n              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n                down: nextSibling,\n                up: prevSibling,\n                next: closeSub,\n                previous: openSub\n              });\n            } else {\n              // left aligned\n              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n                down: nextSibling,\n                up: prevSibling,\n                next: openSub,\n                previous: closeSub\n              });\n            }\n          } else {\n            // horizontal menu\n            if (_this._isRtl()) {\n              // right aligned\n              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n                next: prevSibling,\n                previous: nextSibling,\n                down: openSub,\n                up: closeSub\n              });\n            } else {\n              // left aligned\n              jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n                next: nextSibling,\n                previous: prevSibling,\n                down: openSub,\n                up: closeSub\n              });\n            }\n          }\n        } else {\n          // not tabs -> one sub\n          if (_this._isRtl()) {\n            // right aligned\n            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n              next: closeSub,\n              previous: openSub,\n              down: nextSibling,\n              up: prevSibling\n            });\n          } else {\n            // left aligned\n            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend(functions, {\n              next: openSub,\n              previous: closeSub,\n              down: nextSibling,\n              up: prevSibling\n            });\n          }\n        }\n\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'DropdownMenu', functions);\n      });\n    }\n    /**\n     * Adds an event handler to the body to close any dropdowns on a click.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_addBodyHandler\",\n    value: function _addBodyHandler() {\n      var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body),\n          _this = this;\n\n      $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu').on('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu', function (e) {\n        var $link = _this.$element.find(e.target);\n\n        if ($link.length) {\n          return;\n        }\n\n        _this._hide();\n\n        $body.off('mouseup.zf.dropdownmenu touchend.zf.dropdownmenu');\n      });\n    }\n    /**\n     * Opens a dropdown pane, and checks for collisions first.\n     * @param {jQuery} $sub - ul element that is a submenu to show\n     * @function\n     * @private\n     * @fires Dropdownmenu#show\n     */\n\n  }, {\n    key: \"_show\",\n    value: function _show($sub) {\n      var idx = this.$tabs.index(this.$tabs.filter(function (i, el) {\n        return jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).find($sub).length > 0;\n      }));\n      var $sibs = $sub.parent('li.is-dropdown-submenu-parent').siblings('li.is-dropdown-submenu-parent');\n\n      this._hide($sibs, idx);\n\n      $sub.css('visibility', 'hidden').addClass('js-dropdown-active').parent('li.is-dropdown-submenu-parent').addClass('is-active');\n      var clear = _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__[\"Box\"].ImNotTouchingYou($sub, null, true);\n\n      if (!clear) {\n        var oldClass = this.options.alignment === 'left' ? '-right' : '-left',\n            $parentLi = $sub.parent('.is-dropdown-submenu-parent');\n        $parentLi.removeClass(\"opens\".concat(oldClass)).addClass(\"opens-\".concat(this.options.alignment));\n        clear = _foundation_util_box__WEBPACK_IMPORTED_MODULE_4__[\"Box\"].ImNotTouchingYou($sub, null, true);\n\n        if (!clear) {\n          $parentLi.removeClass(\"opens-\".concat(this.options.alignment)).addClass('opens-inner');\n        }\n\n        this.changed = true;\n      }\n\n      $sub.css('visibility', '');\n\n      if (this.options.closeOnClick) {\n        this._addBodyHandler();\n      }\n      /**\n       * Fires when the new dropdown pane is visible.\n       * @event Dropdownmenu#show\n       */\n\n\n      this.$element.trigger('show.zf.dropdownmenu', [$sub]);\n    }\n    /**\n     * Hides a single, currently open dropdown pane, if passed a parameter, otherwise, hides everything.\n     * @function\n     * @param {jQuery} $elem - element with a submenu to hide\n     * @param {Number} idx - index of the $tabs collection to hide\n     * @private\n     */\n\n  }, {\n    key: \"_hide\",\n    value: function _hide($elem, idx) {\n      var $toClose;\n\n      if ($elem && $elem.length) {\n        $toClose = $elem;\n      } else if (typeof idx !== 'undefined') {\n        $toClose = this.$tabs.not(function (i, el) {\n          return i === idx;\n        });\n      } else {\n        $toClose = this.$element;\n      }\n\n      var somethingToClose = $toClose.hasClass('is-active') || $toClose.find('.is-active').length > 0;\n\n      if (somethingToClose) {\n        $toClose.find('li.is-active').add($toClose).attr({\n          'data-is-click': false\n        }).removeClass('is-active');\n        $toClose.find('ul.js-dropdown-active').removeClass('js-dropdown-active');\n\n        if (this.changed || $toClose.find('opens-inner').length) {\n          var oldClass = this.options.alignment === 'left' ? 'right' : 'left';\n          $toClose.find('li.is-dropdown-submenu-parent').add($toClose).removeClass(\"opens-inner opens-\".concat(this.options.alignment)).addClass(\"opens-\".concat(oldClass));\n          this.changed = false;\n        }\n        /**\n         * Fires when the open menus are closed.\n         * @event Dropdownmenu#hide\n         */\n\n\n        this.$element.trigger('hide.zf.dropdownmenu', [$toClose]);\n      }\n    }\n    /**\n     * Destroys the plugin.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$menuItems.off('.zf.dropdownmenu').removeAttr('data-is-click').removeClass('is-right-arrow is-left-arrow is-down-arrow opens-right opens-left opens-inner');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.body).off('.zf.dropdownmenu');\n      _foundation_util_nest__WEBPACK_IMPORTED_MODULE_3__[\"Nest\"].Burn(this.$element, 'dropdown');\n    }\n  }]);\n\n  return DropdownMenu;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nDropdownMenu.defaults = {\n  /**\n   * Disallows hover events from opening submenus\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n\n  /**\n   * Allow a submenu to automatically close on a mouseleave event, if not clicked open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoclose: true,\n\n  /**\n   * Amount of time to delay opening a submenu on hover event.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  hoverDelay: 50,\n\n  /**\n   * Allow a submenu to open/remain open on parent click event. Allows cursor to move away from menu.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  clickOpen: false,\n\n  /**\n   * Amount of time to delay closing a submenu on a mouseleave event.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  closingTime: 500,\n\n  /**\n   * Position of the menu relative to what direction the submenus should open. Handled by JS. Can be `'auto'`, `'left'` or `'right'`.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow clicks on the body to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Allow clicks on leaf anchor links to close any open submenus.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClickInside: true,\n\n  /**\n   * Class applied to vertical oriented menus, Foundation default is `vertical`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'vertical'\n   */\n  verticalClass: 'vertical',\n\n  /**\n   * Class applied to right-side oriented menus, Foundation default is `align-right`. Update this if using your own class.\n   * @option\n   * @type {string}\n   * @default 'align-right'\n   */\n  rightClass: 'align-right',\n\n  /**\n   * Boolean to force overide the clicking of links to perform default action, on second touch event for mobile.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  forceFollow: true\n};\n\n\n/***/ }),\n\n/***/ 5:\n/*!*************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.dropdownMenu.js ***!\n  \\*************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.dropdownMenu.js */\"./js/entries/plugins/foundation.dropdownMenu.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.dropdownMenu.js.map"]}
\ No newline at end of file
index 5e14b800fe82d3d35b087ba05eabfcb6768f67e4..9c472c9058f58377f2bd3f11ad58970986863648 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.imageLoader"), require("./foundation.util.mediaQuery"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.imageLoader", "./foundation.util.mediaQuery", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.equalizer"] = factory(require("./foundation.core"), require("./foundation.util.imageLoader"), require("./foundation.util.mediaQuery"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.equalizer"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.imageLoader"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 85);
+/******/       return __webpack_require__(__webpack_require__.s = 6);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.imageLoader":
+/*!****************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.imageLoader"],"amd":"./foundation.util.imageLoader","commonjs":"./foundation.util.imageLoader","commonjs2":"./foundation.util.imageLoader"} ***!
+  \****************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;
 
 /***/ }),
 
-/***/ 10:
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {onImagesLoaded: window.Foundation.onImagesLoaded};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
 
 /***/ }),
 
-/***/ 19:
+/***/ "./js/entries/plugins/foundation.equalizer.js":
+/*!****************************************************!*\
+  !*** ./js/entries/plugins/foundation.equalizer.js ***!
+  \****************************************************/
+/*! exports provided: Foundation, Equalizer */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_equalizer__ = __webpack_require__(49);
-
-
-
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_equalizer__["a" /* Equalizer */], 'Equalizer');
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-/***/ }),
+/* harmony import */ var _foundation_equalizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.equalizer */ "./js/foundation.equalizer.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Equalizer", function() { return _foundation_equalizer__WEBPACK_IMPORTED_MODULE_1__["Equalizer"]; });
 
-/***/ 2:
-/***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
 
-/***/ }),
-
-/***/ 3:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_equalizer__WEBPACK_IMPORTED_MODULE_1__["Equalizer"], 'Equalizer');
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
 /***/ }),
 
-/***/ 49:
+/***/ "./js/foundation.equalizer.js":
+/*!************************************!*\
+  !*** ./js/foundation.equalizer.js ***!
+  \************************************/
+/*! exports provided: Equalizer */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Equalizer; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__ = __webpack_require__(10);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Equalizer", function() { return Equalizer; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.imageLoader */ "./foundation.util.imageLoader");
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
 
-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 _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -156,17 +202,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.imageLoader if equalizer contains images
  */
 
-var Equalizer = function (_Plugin) {
+var Equalizer =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Equalizer, _Plugin);
 
   function Equalizer() {
     _classCallCheck(this, Equalizer);
 
-    return _possibleConstructorReturn(this, (Equalizer.__proto__ || Object.getPrototypeOf(Equalizer)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Equalizer).apply(this, arguments));
   }
 
   _createClass(Equalizer, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of Equalizer.
@@ -178,29 +226,27 @@ var Equalizer = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Equalizer.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Equalizer.defaults, this.$element.data(), options);
       this.className = 'Equalizer'; // ie9 back compat
 
       this._init();
     }
-
     /**
      * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
       var eqId = this.$element.attr('data-equalizer') || '';
-      var $watched = this.$element.find('[data-equalizer-watch="' + eqId + '"]');
+      var $watched = this.$element.find("[data-equalizer-watch=\"".concat(eqId, "\"]"));
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"]._init();
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init();
 
       this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');
-      this.$element.attr('data-resize', eqId || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["GetYoDigits"])(6, 'eq'));
-      this.$element.attr('data-mutate', eqId || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["GetYoDigits"])(6, 'eq'));
-
+      this.$element.attr('data-resize', eqId || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'eq'));
+      this.$element.attr('data-mutate', eqId || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'eq'));
       this.hasNested = this.$element.find('[data-equalizer]').length > 0;
       this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;
       this.isOn = false;
@@ -208,31 +254,31 @@ var Equalizer = function (_Plugin) {
         onResizeMeBound: this._onResizeMe.bind(this),
         onPostEqualizedBound: this._onPostEqualized.bind(this)
       };
-
       var imgs = this.$element.find('img');
       var tooSmall;
+
       if (this.options.equalizeOn) {
         tooSmall = this._checkMQ();
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));
       } else {
         this._events();
       }
-      if (tooSmall !== undefined && tooSmall === false || tooSmall === undefined) {
+
+      if (typeof tooSmall !== 'undefined' && tooSmall === false || typeof tooSmall === 'undefined') {
         if (imgs.length) {
-          __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__["onImagesLoaded"])(imgs, this._reflow.bind(this));
+          Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__["onImagesLoaded"])(imgs, this._reflow.bind(this));
         } else {
           this._reflow();
         }
       }
     }
-
     /**
      * Removes event listeners if the breakpoint is too small.
      * @private
      */
 
   }, {
-    key: '_pauseEvents',
+    key: "_pauseEvents",
     value: function _pauseEvents() {
       this.isOn = false;
       this.$element.off({
@@ -241,62 +287,63 @@ var Equalizer = function (_Plugin) {
         'mutateme.zf.trigger': this._bindHandler.onResizeMeBound
       });
     }
-
     /**
      * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound
      * @private
      */
 
   }, {
-    key: '_onResizeMe',
+    key: "_onResizeMe",
     value: function _onResizeMe(e) {
       this._reflow();
     }
-
     /**
      * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound
      * @private
      */
 
   }, {
-    key: '_onPostEqualized',
+    key: "_onPostEqualized",
     value: function _onPostEqualized(e) {
       if (e.target !== this.$element[0]) {
         this._reflow();
       }
     }
-
     /**
      * Initializes events for Equalizer.
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this;
+
       this._pauseEvents();
+
       if (this.hasNested) {
         this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);
       } else {
         this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);
         this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);
       }
+
       this.isOn = true;
     }
-
     /**
      * Checks the current breakpoint to the minimum required size.
      * @private
      */
 
   }, {
-    key: '_checkMQ',
+    key: "_checkMQ",
     value: function _checkMQ() {
-      var tooSmall = !__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"].is(this.options.equalizeOn);
+      var tooSmall = !_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].is(this.options.equalizeOn);
+
       if (tooSmall) {
         if (this.isOn) {
           this._pauseEvents();
+
           this.$watched.css('height', 'auto');
         }
       } else {
@@ -304,27 +351,26 @@ var Equalizer = function (_Plugin) {
           this._events();
         }
       }
+
       return tooSmall;
     }
-
     /**
      * A noop version for the plugin
      * @private
      */
 
   }, {
-    key: '_killswitch',
+    key: "_killswitch",
     value: function _killswitch() {
       return;
     }
-
     /**
      * Calls necessary functions to update Equalizer upon DOM change
      * @private
      */
 
   }, {
-    key: '_reflow',
+    key: "_reflow",
     value: function _reflow() {
       if (!this.options.equalizeOnStack) {
         if (this._isStacked()) {
@@ -332,27 +378,27 @@ var Equalizer = function (_Plugin) {
           return false;
         }
       }
+
       if (this.options.equalizeByRow) {
         this.getHeightsByRow(this.applyHeightByRow.bind(this));
       } else {
         this.getHeights(this.applyHeight.bind(this));
       }
     }
-
     /**
      * Manually determines if the first 2 elements are *NOT* stacked.
      * @private
      */
 
   }, {
-    key: '_isStacked',
+    key: "_isStacked",
     value: function _isStacked() {
       if (!this.$watched[0] || !this.$watched[1]) {
         return true;
       }
+
       return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;
     }
-
     /**
      * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
      * @param {Function} cb - A non-optional callback to return the heights array to.
@@ -360,16 +406,17 @@ var Equalizer = function (_Plugin) {
      */
 
   }, {
-    key: 'getHeights',
+    key: "getHeights",
     value: function getHeights(cb) {
       var heights = [];
+
       for (var i = 0, len = this.$watched.length; i < len; i++) {
         this.$watched[i].style.height = 'auto';
         heights.push(this.$watched[i].offsetHeight);
       }
+
       cb(heights);
     }
-
     /**
      * Finds the outer heights of children contained within an Equalizer parent and returns them in an array
      * @param {Function} cb - A non-optional callback to return the heights array to.
@@ -377,35 +424,38 @@ var Equalizer = function (_Plugin) {
      */
 
   }, {
-    key: 'getHeightsByRow',
+    key: "getHeightsByRow",
     value: function getHeightsByRow(cb) {
       var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0,
           groups = [],
-          group = 0;
-      //group by Row
+          group = 0; //group by Row
+
       groups[group] = [];
+
       for (var i = 0, len = this.$watched.length; i < len; i++) {
-        this.$watched[i].style.height = 'auto';
-        //maybe could use this.$watched[i].offsetTop
-        var elOffsetTop = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.$watched[i]).offset().top;
+        this.$watched[i].style.height = 'auto'; //maybe could use this.$watched[i].offsetTop
+
+        var elOffsetTop = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$watched[i]).offset().top;
+
         if (elOffsetTop != lastElTopOffset) {
           group++;
           groups[group] = [];
           lastElTopOffset = elOffsetTop;
         }
+
         groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]);
       }
 
       for (var j = 0, ln = groups.length; j < ln; j++) {
-        var heights = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(groups[j]).map(function () {
+        var heights = jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[j]).map(function () {
           return this[1];
         }).get();
         var max = Math.max.apply(null, heights);
         groups[j].push(max);
       }
+
       cb(groups);
     }
-
     /**
      * Changes the CSS height property of each child in an Equalizer parent to match the tallest
      * @param {array} heights - An array of heights of children within Equalizer container
@@ -414,24 +464,23 @@ var Equalizer = function (_Plugin) {
      */
 
   }, {
-    key: 'applyHeight',
+    key: "applyHeight",
     value: function applyHeight(heights) {
       var max = Math.max.apply(null, heights);
       /**
        * Fires before the heights are applied
        * @event Equalizer#preequalized
        */
-      this.$element.trigger('preequalized.zf.equalizer');
 
+      this.$element.trigger('preequalized.zf.equalizer');
       this.$watched.css('height', max);
-
       /**
        * Fires when the heights have been applied
        * @event Equalizer#postequalized
        */
+
       this.$element.trigger('postequalized.zf.equalizer');
     }
-
     /**
      * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row
      * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child
@@ -442,55 +491,67 @@ var Equalizer = function (_Plugin) {
      */
 
   }, {
-    key: 'applyHeightByRow',
+    key: "applyHeightByRow",
     value: function applyHeightByRow(groups) {
       /**
        * Fires before the heights are applied
        */
       this.$element.trigger('preequalized.zf.equalizer');
+
       for (var i = 0, len = groups.length; i < len; i++) {
         var groupsILength = groups[i].length,
             max = groups[i][groupsILength - 1];
+
         if (groupsILength <= 2) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(groups[i][0][0]).css({ 'height': 'auto' });
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][0][0]).css({
+            'height': 'auto'
+          });
           continue;
         }
         /**
           * Fires before the heights per row are applied
           * @event Equalizer#preequalizedrow
           */
+
+
         this.$element.trigger('preequalizedrow.zf.equalizer');
+
         for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(groups[i][j][0]).css({ 'height': max });
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][j][0]).css({
+            'height': max
+          });
         }
         /**
           * Fires when the heights per row have been applied
           * @event Equalizer#postequalizedrow
           */
+
+
         this.$element.trigger('postequalizedrow.zf.equalizer');
       }
       /**
        * Fires when the heights have been applied
        */
+
+
       this.$element.trigger('postequalized.zf.equalizer');
     }
-
     /**
      * Destroys an instance of Equalizer.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this._pauseEvents();
+
       this.$watched.css('height', 'auto');
     }
   }]);
 
   return Equalizer;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["Plugin"]);
-
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 /**
  * Default settings for plugin
  */
@@ -504,6 +565,7 @@ Equalizer.defaults = {
    * @default false
    */
   equalizeOnStack: false,
+
   /**
    * Enable height equalization row by row.
    * @option
@@ -511,6 +573,7 @@ Equalizer.defaults = {
    * @default false
    */
   equalizeByRow: false,
+
   /**
    * String representing the minimum breakpoint size the plugin should equalize heights on.
    * @option
@@ -521,22 +584,31 @@ Equalizer.defaults = {
 };
 
 
-
 /***/ }),
 
 /***/ 6:
-/***/ (function(module, exports) {
+/*!**********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.equalizer.js ***!
+  \**********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.equalizer.js */"./js/entries/plugins/foundation.equalizer.js");
 
-/***/ }),
 
-/***/ 85:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ }),
 
-module.exports = __webpack_require__(19);
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.equalizer.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.equalizer.js.map b/dist/js/plugins/foundation.equalizer.js.map
new file mode 100644 (file)
index 0000000..1d42f2e
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.imageLoader\"],\"amd\":\"./foundation.util.imageLoader\",\"commonjs\":\"./foundation.util.imageLoader\",\"commonjs2\":\"./foundation.util.imageLoader\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.equalizer.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.equalizer.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Equalizer","element","options","$element","$","extend","defaults","data","className","_init","eqId","attr","$watched","find","MediaQuery","length","GetYoDigits","hasNested","isNested","parentsUntil","document","body","isOn","_bindHandler","onResizeMeBound","_onResizeMe","bind","onPostEqualizedBound","_onPostEqualized","imgs","tooSmall","equalizeOn","_checkMQ","window","on","_events","onImagesLoaded","_reflow","off","e","target","_this","_pauseEvents","is","css","equalizeOnStack","_isStacked","equalizeByRow","getHeightsByRow","applyHeightByRow","getHeights","applyHeight","getBoundingClientRect","top","cb","heights","i","len","style","height","push","offsetHeight","lastElTopOffset","first","offset","groups","group","elOffsetTop","j","ln","map","get","max","Math","apply","trigger","groupsILength","lenJ","Plugin"],"mappings":"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","file":"foundation.equalizer.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.imageLoader\", \"./foundation.util.mediaQuery\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.equalizer\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.equalizer\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.imageLoader\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 6);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","import { Foundation } from './foundation.core';\n\nimport { Equalizer } from '../../foundation.equalizer';\nFoundation.plugin(Equalizer, 'Equalizer');\n\nexport { Foundation, Equalizer };\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.imageLoader if equalizer contains images\n */\n\nclass Equalizer extends Plugin {\n  /**\n   * Creates a new instance of Equalizer.\n   * @class\n   * @name Equalizer\n   * @fires Equalizer#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options){\n    this.$element = element;\n    this.options  = $.extend({}, Equalizer.defaults, this.$element.data(), options);\n    this.className = 'Equalizer'; // ie9 back compat\n\n    this._init();\n  }\n\n  /**\n   * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var eqId = this.$element.attr('data-equalizer') || '';\n    var $watched = this.$element.find(`[data-equalizer-watch=\"${eqId}\"]`);\n\n    MediaQuery._init();\n\n    this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n    this.$element.attr('data-resize', (eqId || GetYoDigits(6, 'eq')));\n    this.$element.attr('data-mutate', (eqId || GetYoDigits(6, 'eq')));\n\n    this.hasNested = this.$element.find('[data-equalizer]').length > 0;\n    this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;\n    this.isOn = false;\n    this._bindHandler = {\n      onResizeMeBound: this._onResizeMe.bind(this),\n      onPostEqualizedBound: this._onPostEqualized.bind(this)\n    };\n\n    var imgs = this.$element.find('img');\n    var tooSmall;\n    if(this.options.equalizeOn){\n      tooSmall = this._checkMQ();\n      $(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));\n    }else{\n      this._events();\n    }\n    if((typeof tooSmall !== 'undefined' && tooSmall === false) || typeof tooSmall === 'undefined'){\n      if(imgs.length){\n        onImagesLoaded(imgs, this._reflow.bind(this));\n      }else{\n        this._reflow();\n      }\n    }\n  }\n\n  /**\n   * Removes event listeners if the breakpoint is too small.\n   * @private\n   */\n  _pauseEvents() {\n    this.isOn = false;\n    this.$element.off({\n      '.zf.equalizer': this._bindHandler.onPostEqualizedBound,\n      'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,\n\t  'mutateme.zf.trigger': this._bindHandler.onResizeMeBound\n    });\n  }\n\n  /**\n   * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound\n   * @private\n   */\n  _onResizeMe(e) {\n    this._reflow();\n  }\n\n  /**\n   * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound\n   * @private\n   */\n  _onPostEqualized(e) {\n    if(e.target !== this.$element[0]){ this._reflow(); }\n  }\n\n  /**\n   * Initializes events for Equalizer.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    this._pauseEvents();\n    if(this.hasNested){\n      this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);\n    }else{\n      this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);\n\t  this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);\n    }\n    this.isOn = true;\n  }\n\n  /**\n   * Checks the current breakpoint to the minimum required size.\n   * @private\n   */\n  _checkMQ() {\n    var tooSmall = !MediaQuery.is(this.options.equalizeOn);\n    if(tooSmall){\n      if(this.isOn){\n        this._pauseEvents();\n        this.$watched.css('height', 'auto');\n      }\n    }else{\n      if(!this.isOn){\n        this._events();\n      }\n    }\n    return tooSmall;\n  }\n\n  /**\n   * A noop version for the plugin\n   * @private\n   */\n  _killswitch() {\n    return;\n  }\n\n  /**\n   * Calls necessary functions to update Equalizer upon DOM change\n   * @private\n   */\n  _reflow() {\n    if(!this.options.equalizeOnStack){\n      if(this._isStacked()){\n        this.$watched.css('height', 'auto');\n        return false;\n      }\n    }\n    if (this.options.equalizeByRow) {\n      this.getHeightsByRow(this.applyHeightByRow.bind(this));\n    }else{\n      this.getHeights(this.applyHeight.bind(this));\n    }\n  }\n\n  /**\n   * Manually determines if the first 2 elements are *NOT* stacked.\n   * @private\n   */\n  _isStacked() {\n    if (!this.$watched[0] || !this.$watched[1]) {\n      return true;\n    }\n    return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} heights - An array of heights of children within Equalizer container\n   */\n  getHeights(cb) {\n    var heights = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      heights.push(this.$watched[i].offsetHeight);\n    }\n    cb(heights);\n  }\n\n  /**\n   * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n   * @param {Function} cb - A non-optional callback to return the heights array to.\n   * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   */\n  getHeightsByRow(cb) {\n    var lastElTopOffset = (this.$watched.length ? this.$watched.first().offset().top : 0),\n        groups = [],\n        group = 0;\n    //group by Row\n    groups[group] = [];\n    for(var i = 0, len = this.$watched.length; i < len; i++){\n      this.$watched[i].style.height = 'auto';\n      //maybe could use this.$watched[i].offsetTop\n      var elOffsetTop = $(this.$watched[i]).offset().top;\n      if (elOffsetTop!=lastElTopOffset) {\n        group++;\n        groups[group] = [];\n        lastElTopOffset=elOffsetTop;\n      }\n      groups[group].push([this.$watched[i],this.$watched[i].offsetHeight]);\n    }\n\n    for (var j = 0, ln = groups.length; j < ln; j++) {\n      var heights = $(groups[j]).map(function(){ return this[1]; }).get();\n      var max         = Math.max.apply(null, heights);\n      groups[j].push(max);\n    }\n    cb(groups);\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest\n   * @param {array} heights - An array of heights of children within Equalizer container\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#postequalized\n   */\n  applyHeight(heights) {\n    var max = Math.max.apply(null, heights);\n    /**\n     * Fires before the heights are applied\n     * @event Equalizer#preequalized\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n\n    this.$watched.css('height', max);\n\n    /**\n     * Fires when the heights have been applied\n     * @event Equalizer#postequalized\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row\n   * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n   * @fires Equalizer#preequalized\n   * @fires Equalizer#preequalizedrow\n   * @fires Equalizer#postequalizedrow\n   * @fires Equalizer#postequalized\n   */\n  applyHeightByRow(groups) {\n    /**\n     * Fires before the heights are applied\n     */\n    this.$element.trigger('preequalized.zf.equalizer');\n    for (var i = 0, len = groups.length; i < len ; i++) {\n      var groupsILength = groups[i].length,\n          max = groups[i][groupsILength - 1];\n      if (groupsILength<=2) {\n        $(groups[i][0][0]).css({'height':'auto'});\n        continue;\n      }\n      /**\n        * Fires before the heights per row are applied\n        * @event Equalizer#preequalizedrow\n        */\n      this.$element.trigger('preequalizedrow.zf.equalizer');\n      for (var j = 0, lenJ = (groupsILength-1); j < lenJ ; j++) {\n        $(groups[i][j][0]).css({'height':max});\n      }\n      /**\n        * Fires when the heights per row have been applied\n        * @event Equalizer#postequalizedrow\n        */\n      this.$element.trigger('postequalizedrow.zf.equalizer');\n    }\n    /**\n     * Fires when the heights have been applied\n     */\n     this.$element.trigger('postequalized.zf.equalizer');\n  }\n\n  /**\n   * Destroys an instance of Equalizer.\n   * @function\n   */\n  _destroy() {\n    this._pauseEvents();\n    this.$watched.css('height', 'auto');\n  }\n}\n\n/**\n * Default settings for plugin\n */\nEqualizer.defaults = {\n  /**\n   * Enable height equalization when stacked on smaller screens.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeOnStack: false,\n  /**\n   * Enable height equalization row by row.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeByRow: false,\n  /**\n   * String representing the minimum breakpoint size the plugin should equalize heights on.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  equalizeOn: ''\n};\n\nexport {Equalizer};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 4368b10d9fcbe599a10915944566448dc244f40e..36fb1d7e069785d9d0810878cc139c4a47a8a8d1 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(n){if(i[n])return i[n].exports;var o=i[n]={i:n,l:!1,exports:{}};return e[n].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var i={};t.m=e,t.c=i,t.i=function(e){return e},t.d=function(e,i,n){t.o(e,i)||Object.defineProperty(e,i,{configurable:!1,enumerable:!0,get:n})},t.n=function(e){var i=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(i,"a",i),i},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=85)}({0:function(e,t){e.exports=jQuery},1:function(e,t){e.exports={Foundation:window.Foundation}},10:function(e,t){e.exports={onImagesLoaded:window.Foundation.onImagesLoaded}},19:function(e,t,i){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var n=i(1),o=(i.n(n),i(49));n.Foundation.plugin(o.a,"Equalizer")},2:function(e,t){e.exports={Plugin:window.Foundation.Plugin}},3:function(e,t){e.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},49:function(e,t,i){"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function o(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function s(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}i.d(t,"a",function(){return f});var a=i(0),r=i.n(a),u=i(6),h=(i.n(u),i(10)),l=(i.n(h),i(3)),d=(i.n(l),i(2)),c=(i.n(d),function(){function e(e,t){for(var i=0;i<t.length;i++){var n=t[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}return function(t,i,n){return i&&e(t.prototype,i),n&&e(t,n),t}}()),f=function(e){function t(){return n(this,t),o(this,(t.__proto__||Object.getPrototypeOf(t)).apply(this,arguments))}return s(t,e),c(t,[{key:"_setup",value:function(e,i){this.$element=e,this.options=r.a.extend({},t.defaults,this.$element.data(),i),this.className="Equalizer",this._init()}},{key:"_init",value:function(){var e=this.$element.attr("data-equalizer")||"",t=this.$element.find('[data-equalizer-watch="'+e+'"]');u.MediaQuery._init(),this.$watched=t.length?t:this.$element.find("[data-equalizer-watch]"),this.$element.attr("data-resize",e||i.i(l.GetYoDigits)(6,"eq")),this.$element.attr("data-mutate",e||i.i(l.GetYoDigits)(6,"eq")),this.hasNested=this.$element.find("[data-equalizer]").length>0,this.isNested=this.$element.parentsUntil(document.body,"[data-equalizer]").length>0,this.isOn=!1,this._bindHandler={onResizeMeBound:this._onResizeMe.bind(this),onPostEqualizedBound:this._onPostEqualized.bind(this)};var n,o=this.$element.find("img");this.options.equalizeOn?(n=this._checkMQ(),r()(window).on("changed.zf.mediaquery",this._checkMQ.bind(this))):this._events(),(void 0!==n&&!1===n||void 0===n)&&(o.length?i.i(h.onImagesLoaded)(o,this._reflow.bind(this)):this._reflow())}},{key:"_pauseEvents",value:function(){this.isOn=!1,this.$element.off({".zf.equalizer":this._bindHandler.onPostEqualizedBound,"resizeme.zf.trigger":this._bindHandler.onResizeMeBound,"mutateme.zf.trigger":this._bindHandler.onResizeMeBound})}},{key:"_onResizeMe",value:function(e){this._reflow()}},{key:"_onPostEqualized",value:function(e){e.target!==this.$element[0]&&this._reflow()}},{key:"_events",value:function(){this._pauseEvents(),this.hasNested?this.$element.on("postequalized.zf.equalizer",this._bindHandler.onPostEqualizedBound):(this.$element.on("resizeme.zf.trigger",this._bindHandler.onResizeMeBound),this.$element.on("mutateme.zf.trigger",this._bindHandler.onResizeMeBound)),this.isOn=!0}},{key:"_checkMQ",value:function(){var e=!u.MediaQuery.is(this.options.equalizeOn);return e?this.isOn&&(this._pauseEvents(),this.$watched.css("height","auto")):this.isOn||this._events(),e}},{key:"_killswitch",value:function(){}},{key:"_reflow",value:function(){if(!this.options.equalizeOnStack&&this._isStacked())return this.$watched.css("height","auto"),!1;this.options.equalizeByRow?this.getHeightsByRow(this.applyHeightByRow.bind(this)):this.getHeights(this.applyHeight.bind(this))}},{key:"_isStacked",value:function(){return!this.$watched[0]||!this.$watched[1]||this.$watched[0].getBoundingClientRect().top!==this.$watched[1].getBoundingClientRect().top}},{key:"getHeights",value:function(e){for(var t=[],i=0,n=this.$watched.length;i<n;i++)this.$watched[i].style.height="auto",t.push(this.$watched[i].offsetHeight);e(t)}},{key:"getHeightsByRow",value:function(e){var t=this.$watched.length?this.$watched.first().offset().top:0,i=[],n=0;i[n]=[];for(var o=0,s=this.$watched.length;o<s;o++){this.$watched[o].style.height="auto";var a=r()(this.$watched[o]).offset().top;a!=t&&(n++,i[n]=[],t=a),i[n].push([this.$watched[o],this.$watched[o].offsetHeight])}for(var u=0,h=i.length;u<h;u++){var l=r()(i[u]).map(function(){return this[1]}).get(),d=Math.max.apply(null,l);i[u].push(d)}e(i)}},{key:"applyHeight",value:function(e){var t=Math.max.apply(null,e);this.$element.trigger("preequalized.zf.equalizer"),this.$watched.css("height",t),this.$element.trigger("postequalized.zf.equalizer")}},{key:"applyHeightByRow",value:function(e){this.$element.trigger("preequalized.zf.equalizer");for(var t=0,i=e.length;t<i;t++){var n=e[t].length,o=e[t][n-1];if(n<=2)r()(e[t][0][0]).css({height:"auto"});else{this.$element.trigger("preequalizedrow.zf.equalizer");for(var s=0,a=n-1;s<a;s++)r()(e[t][s][0]).css({height:o});this.$element.trigger("postequalizedrow.zf.equalizer")}}this.$element.trigger("postequalized.zf.equalizer")}},{key:"_destroy",value:function(){this._pauseEvents(),this.$watched.css("height","auto")}}]),t}(d.Plugin);f.defaults={equalizeOnStack:!1,equalizeByRow:!1,equalizeOn:""}},6:function(e,t){e.exports={MediaQuery:window.Foundation.MediaQuery}},85:function(e,t,i){e.exports=i(19)}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("./foundation.util.imageLoader"),require("./foundation.util.mediaQuery"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.imageLoader","./foundation.util.mediaQuery","jquery"],t):"object"==typeof exports?exports["foundation.equalizer"]=t(require("./foundation.core"),require("./foundation.util.imageLoader"),require("./foundation.util.mediaQuery"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.equalizer"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.imageLoader"],e.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],e.jQuery))}(window,function(i,n,o,r){return function(i){var n={};function o(e){if(n[e])return n[e].exports;var t=n[e]={i:e,l:!1,exports:{}};return i[e].call(t.exports,t,t.exports,o),t.l=!0,t.exports}return o.m=i,o.c=n,o.d=function(e,t,i){o.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:i})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(t,e){if(1&e&&(t=o(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var i=Object.create(null);if(o.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var n in t)o.d(i,n,function(e){return t[e]}.bind(null,n));return i},o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,"a",t),t},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.p="",o(o.s=6)}({"./foundation.core":function(e,t){e.exports=i},"./foundation.util.imageLoader":function(e,t){e.exports=n},"./foundation.util.mediaQuery":function(e,t){e.exports=o},"./js/entries/plugins/foundation.equalizer.js":function(e,t,i){"use strict";i.r(t);var n=i("./foundation.core");i.d(t,"Foundation",function(){return n.Foundation});var o=i("./js/foundation.equalizer.js");i.d(t,"Equalizer",function(){return o.Equalizer}),n.Foundation.plugin(o.Equalizer,"Equalizer")},"./js/foundation.equalizer.js":function(e,t,i){"use strict";i.r(t),i.d(t,"Equalizer",function(){return c});var n=i("jquery"),h=i.n(n),r=i("./foundation.util.mediaQuery"),u=i("./foundation.util.imageLoader"),a=i("./foundation.core");function o(e){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function s(e,t){for(var i=0;i<t.length;i++){var n=t[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}function l(e,t){return!t||"object"!==o(t)&&"function"!=typeof t?function(e){if(void 0!==e)return e;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(e):t}function f(e){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function d(e,t){return(d=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e})(e,t)}var c=function(e){function i(){return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,i),l(this,f(i).apply(this,arguments))}var t,n,o;return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&d(e,t)}(i,a["Plugin"]),t=i,(n=[{key:"_setup",value:function(e,t){this.$element=e,this.options=h.a.extend({},i.defaults,this.$element.data(),t),this.className="Equalizer",this._init()}},{key:"_init",value:function(){var e=this.$element.attr("data-equalizer")||"",t=this.$element.find('[data-equalizer-watch="'.concat(e,'"]'));r.MediaQuery._init(),this.$watched=t.length?t:this.$element.find("[data-equalizer-watch]"),this.$element.attr("data-resize",e||Object(a.GetYoDigits)(6,"eq")),this.$element.attr("data-mutate",e||Object(a.GetYoDigits)(6,"eq")),this.hasNested=0<this.$element.find("[data-equalizer]").length,this.isNested=0<this.$element.parentsUntil(document.body,"[data-equalizer]").length,this.isOn=!1,this._bindHandler={onResizeMeBound:this._onResizeMe.bind(this),onPostEqualizedBound:this._onPostEqualized.bind(this)};var i,n=this.$element.find("img");this.options.equalizeOn?(i=this._checkMQ(),h()(window).on("changed.zf.mediaquery",this._checkMQ.bind(this))):this._events(),(void 0!==i&&!1===i||void 0===i)&&(n.length?Object(u.onImagesLoaded)(n,this._reflow.bind(this)):this._reflow())}},{key:"_pauseEvents",value:function(){this.isOn=!1,this.$element.off({".zf.equalizer":this._bindHandler.onPostEqualizedBound,"resizeme.zf.trigger":this._bindHandler.onResizeMeBound,"mutateme.zf.trigger":this._bindHandler.onResizeMeBound})}},{key:"_onResizeMe",value:function(e){this._reflow()}},{key:"_onPostEqualized",value:function(e){e.target!==this.$element[0]&&this._reflow()}},{key:"_events",value:function(){this._pauseEvents(),this.hasNested?this.$element.on("postequalized.zf.equalizer",this._bindHandler.onPostEqualizedBound):(this.$element.on("resizeme.zf.trigger",this._bindHandler.onResizeMeBound),this.$element.on("mutateme.zf.trigger",this._bindHandler.onResizeMeBound)),this.isOn=!0}},{key:"_checkMQ",value:function(){var e=!r.MediaQuery.is(this.options.equalizeOn);return e?this.isOn&&(this._pauseEvents(),this.$watched.css("height","auto")):this.isOn||this._events(),e}},{key:"_killswitch",value:function(){}},{key:"_reflow",value:function(){if(!this.options.equalizeOnStack&&this._isStacked())return this.$watched.css("height","auto"),!1;this.options.equalizeByRow?this.getHeightsByRow(this.applyHeightByRow.bind(this)):this.getHeights(this.applyHeight.bind(this))}},{key:"_isStacked",value:function(){return!this.$watched[0]||!this.$watched[1]||this.$watched[0].getBoundingClientRect().top!==this.$watched[1].getBoundingClientRect().top}},{key:"getHeights",value:function(e){for(var t=[],i=0,n=this.$watched.length;i<n;i++)this.$watched[i].style.height="auto",t.push(this.$watched[i].offsetHeight);e(t)}},{key:"getHeightsByRow",value:function(e){var t=this.$watched.length?this.$watched.first().offset().top:0,i=[],n=0;i[n]=[];for(var o=0,r=this.$watched.length;o<r;o++){this.$watched[o].style.height="auto";var u=h()(this.$watched[o]).offset().top;u!=t&&(i[++n]=[],t=u),i[n].push([this.$watched[o],this.$watched[o].offsetHeight])}for(var a=0,s=i.length;a<s;a++){var l=h()(i[a]).map(function(){return this[1]}).get(),f=Math.max.apply(null,l);i[a].push(f)}e(i)}},{key:"applyHeight",value:function(e){var t=Math.max.apply(null,e);this.$element.trigger("preequalized.zf.equalizer"),this.$watched.css("height",t),this.$element.trigger("postequalized.zf.equalizer")}},{key:"applyHeightByRow",value:function(e){this.$element.trigger("preequalized.zf.equalizer");for(var t=0,i=e.length;t<i;t++){var n=e[t].length,o=e[t][n-1];if(n<=2)h()(e[t][0][0]).css({height:"auto"});else{this.$element.trigger("preequalizedrow.zf.equalizer");for(var r=0,u=n-1;r<u;r++)h()(e[t][r][0]).css({height:o});this.$element.trigger("postequalizedrow.zf.equalizer")}}this.$element.trigger("postequalized.zf.equalizer")}},{key:"_destroy",value:function(){this._pauseEvents(),this.$watched.css("height","auto")}}])&&s(t.prototype,n),o&&s(t,o),i}();c.defaults={equalizeOnStack:!1,equalizeByRow:!1,equalizeOn:""}},6:function(e,t,i){e.exports=i("./js/entries/plugins/foundation.equalizer.js")},jquery:function(e,t){e.exports=r}})});
+//# sourceMappingURL=foundation.equalizer.min.js.map
diff --git a/dist/js/plugins/foundation.equalizer.min.js.map b/dist/js/plugins/foundation.equalizer.min.js.map
new file mode 100644 (file)
index 0000000..0b664b6
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.equalizer.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.imageLoader","./foundation.util.mediaQuery","./js/entries/plugins/foundation.equalizer.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_equalizer__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.equalizer.js","Equalizer","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","eqId","attr","$watched","find","concat","hasNested","isNested","parentsUntil","document","body","isOn","_bindHandler","onResizeMeBound","_onResizeMe","onPostEqualizedBound","_onPostEqualized","tooSmall","imgs","equalizeOn","_checkMQ","on","_events","_reflow","off",".zf.equalizer","resizeme.zf.trigger","mutateme.zf.trigger","e","_pauseEvents","is","css","equalizeOnStack","_isStacked","equalizeByRow","getHeightsByRow","applyHeightByRow","getHeights","applyHeight","getBoundingClientRect","top","cb","heights","len","style","height","push","offsetHeight","lastElTopOffset","first","offset","groups","group","elOffsetTop","j","ln","map","max","Math","trigger","groupsILength","lenJ","6","jquery"],"mappings":"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","file":"foundation.equalizer.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.imageLoader\", \"./foundation.util.mediaQuery\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.equalizer\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.equalizer\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.imageLoader\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 6);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.imageLoader\":\n/*!****************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.imageLoader\"],\"amd\":\"./foundation.util.imageLoader\",\"commonjs\":\"./foundation.util.imageLoader\",\"commonjs2\":\"./foundation.util.imageLoader\"} ***!\n  \\****************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.equalizer.js\":\n/*!****************************************************!*\\\n  !*** ./js/entries/plugins/foundation.equalizer.js ***!\n  \\****************************************************/\n/*! exports provided: Foundation, Equalizer */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_equalizer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.equalizer */ \"./js/foundation.equalizer.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Equalizer\", function() { return _foundation_equalizer__WEBPACK_IMPORTED_MODULE_1__[\"Equalizer\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_equalizer__WEBPACK_IMPORTED_MODULE_1__[\"Equalizer\"], 'Equalizer');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.equalizer.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.equalizer.js ***!\n  \\************************************/\n/*! exports provided: Equalizer */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Equalizer\", function() { return Equalizer; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.imageLoader */ \"./foundation.util.imageLoader\");\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Equalizer module.\n * @module foundation.equalizer\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.imageLoader if equalizer contains images\n */\n\nvar Equalizer =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Equalizer, _Plugin);\n\n  function Equalizer() {\n    _classCallCheck(this, Equalizer);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Equalizer).apply(this, arguments));\n  }\n\n  _createClass(Equalizer, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Equalizer.\n     * @class\n     * @name Equalizer\n     * @fires Equalizer#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Equalizer.defaults, this.$element.data(), options);\n      this.className = 'Equalizer'; // ie9 back compat\n\n      this._init();\n    }\n    /**\n     * Initializes the Equalizer plugin and calls functions to get equalizer functioning on load.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var eqId = this.$element.attr('data-equalizer') || '';\n      var $watched = this.$element.find(\"[data-equalizer-watch=\\\"\".concat(eqId, \"\\\"]\"));\n\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init();\n\n      this.$watched = $watched.length ? $watched : this.$element.find('[data-equalizer-watch]');\n      this.$element.attr('data-resize', eqId || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'eq'));\n      this.$element.attr('data-mutate', eqId || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'eq'));\n      this.hasNested = this.$element.find('[data-equalizer]').length > 0;\n      this.isNested = this.$element.parentsUntil(document.body, '[data-equalizer]').length > 0;\n      this.isOn = false;\n      this._bindHandler = {\n        onResizeMeBound: this._onResizeMe.bind(this),\n        onPostEqualizedBound: this._onPostEqualized.bind(this)\n      };\n      var imgs = this.$element.find('img');\n      var tooSmall;\n\n      if (this.options.equalizeOn) {\n        tooSmall = this._checkMQ();\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._checkMQ.bind(this));\n      } else {\n        this._events();\n      }\n\n      if (typeof tooSmall !== 'undefined' && tooSmall === false || typeof tooSmall === 'undefined') {\n        if (imgs.length) {\n          Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_2__[\"onImagesLoaded\"])(imgs, this._reflow.bind(this));\n        } else {\n          this._reflow();\n        }\n      }\n    }\n    /**\n     * Removes event listeners if the breakpoint is too small.\n     * @private\n     */\n\n  }, {\n    key: \"_pauseEvents\",\n    value: function _pauseEvents() {\n      this.isOn = false;\n      this.$element.off({\n        '.zf.equalizer': this._bindHandler.onPostEqualizedBound,\n        'resizeme.zf.trigger': this._bindHandler.onResizeMeBound,\n        'mutateme.zf.trigger': this._bindHandler.onResizeMeBound\n      });\n    }\n    /**\n     * function to handle $elements resizeme.zf.trigger, with bound this on _bindHandler.onResizeMeBound\n     * @private\n     */\n\n  }, {\n    key: \"_onResizeMe\",\n    value: function _onResizeMe(e) {\n      this._reflow();\n    }\n    /**\n     * function to handle $elements postequalized.zf.equalizer, with bound this on _bindHandler.onPostEqualizedBound\n     * @private\n     */\n\n  }, {\n    key: \"_onPostEqualized\",\n    value: function _onPostEqualized(e) {\n      if (e.target !== this.$element[0]) {\n        this._reflow();\n      }\n    }\n    /**\n     * Initializes events for Equalizer.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this._pauseEvents();\n\n      if (this.hasNested) {\n        this.$element.on('postequalized.zf.equalizer', this._bindHandler.onPostEqualizedBound);\n      } else {\n        this.$element.on('resizeme.zf.trigger', this._bindHandler.onResizeMeBound);\n        this.$element.on('mutateme.zf.trigger', this._bindHandler.onResizeMeBound);\n      }\n\n      this.isOn = true;\n    }\n    /**\n     * Checks the current breakpoint to the minimum required size.\n     * @private\n     */\n\n  }, {\n    key: \"_checkMQ\",\n    value: function _checkMQ() {\n      var tooSmall = !_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].is(this.options.equalizeOn);\n\n      if (tooSmall) {\n        if (this.isOn) {\n          this._pauseEvents();\n\n          this.$watched.css('height', 'auto');\n        }\n      } else {\n        if (!this.isOn) {\n          this._events();\n        }\n      }\n\n      return tooSmall;\n    }\n    /**\n     * A noop version for the plugin\n     * @private\n     */\n\n  }, {\n    key: \"_killswitch\",\n    value: function _killswitch() {\n      return;\n    }\n    /**\n     * Calls necessary functions to update Equalizer upon DOM change\n     * @private\n     */\n\n  }, {\n    key: \"_reflow\",\n    value: function _reflow() {\n      if (!this.options.equalizeOnStack) {\n        if (this._isStacked()) {\n          this.$watched.css('height', 'auto');\n          return false;\n        }\n      }\n\n      if (this.options.equalizeByRow) {\n        this.getHeightsByRow(this.applyHeightByRow.bind(this));\n      } else {\n        this.getHeights(this.applyHeight.bind(this));\n      }\n    }\n    /**\n     * Manually determines if the first 2 elements are *NOT* stacked.\n     * @private\n     */\n\n  }, {\n    key: \"_isStacked\",\n    value: function _isStacked() {\n      if (!this.$watched[0] || !this.$watched[1]) {\n        return true;\n      }\n\n      return this.$watched[0].getBoundingClientRect().top !== this.$watched[1].getBoundingClientRect().top;\n    }\n    /**\n     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n     * @param {Function} cb - A non-optional callback to return the heights array to.\n     * @returns {Array} heights - An array of heights of children within Equalizer container\n     */\n\n  }, {\n    key: \"getHeights\",\n    value: function getHeights(cb) {\n      var heights = [];\n\n      for (var i = 0, len = this.$watched.length; i < len; i++) {\n        this.$watched[i].style.height = 'auto';\n        heights.push(this.$watched[i].offsetHeight);\n      }\n\n      cb(heights);\n    }\n    /**\n     * Finds the outer heights of children contained within an Equalizer parent and returns them in an array\n     * @param {Function} cb - A non-optional callback to return the heights array to.\n     * @returns {Array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n     */\n\n  }, {\n    key: \"getHeightsByRow\",\n    value: function getHeightsByRow(cb) {\n      var lastElTopOffset = this.$watched.length ? this.$watched.first().offset().top : 0,\n          groups = [],\n          group = 0; //group by Row\n\n      groups[group] = [];\n\n      for (var i = 0, len = this.$watched.length; i < len; i++) {\n        this.$watched[i].style.height = 'auto'; //maybe could use this.$watched[i].offsetTop\n\n        var elOffsetTop = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$watched[i]).offset().top;\n\n        if (elOffsetTop != lastElTopOffset) {\n          group++;\n          groups[group] = [];\n          lastElTopOffset = elOffsetTop;\n        }\n\n        groups[group].push([this.$watched[i], this.$watched[i].offsetHeight]);\n      }\n\n      for (var j = 0, ln = groups.length; j < ln; j++) {\n        var heights = jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[j]).map(function () {\n          return this[1];\n        }).get();\n        var max = Math.max.apply(null, heights);\n        groups[j].push(max);\n      }\n\n      cb(groups);\n    }\n    /**\n     * Changes the CSS height property of each child in an Equalizer parent to match the tallest\n     * @param {array} heights - An array of heights of children within Equalizer container\n     * @fires Equalizer#preequalized\n     * @fires Equalizer#postequalized\n     */\n\n  }, {\n    key: \"applyHeight\",\n    value: function applyHeight(heights) {\n      var max = Math.max.apply(null, heights);\n      /**\n       * Fires before the heights are applied\n       * @event Equalizer#preequalized\n       */\n\n      this.$element.trigger('preequalized.zf.equalizer');\n      this.$watched.css('height', max);\n      /**\n       * Fires when the heights have been applied\n       * @event Equalizer#postequalized\n       */\n\n      this.$element.trigger('postequalized.zf.equalizer');\n    }\n    /**\n     * Changes the CSS height property of each child in an Equalizer parent to match the tallest by row\n     * @param {array} groups - An array of heights of children within Equalizer container grouped by row with element,height and max as last child\n     * @fires Equalizer#preequalized\n     * @fires Equalizer#preequalizedrow\n     * @fires Equalizer#postequalizedrow\n     * @fires Equalizer#postequalized\n     */\n\n  }, {\n    key: \"applyHeightByRow\",\n    value: function applyHeightByRow(groups) {\n      /**\n       * Fires before the heights are applied\n       */\n      this.$element.trigger('preequalized.zf.equalizer');\n\n      for (var i = 0, len = groups.length; i < len; i++) {\n        var groupsILength = groups[i].length,\n            max = groups[i][groupsILength - 1];\n\n        if (groupsILength <= 2) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][0][0]).css({\n            'height': 'auto'\n          });\n          continue;\n        }\n        /**\n          * Fires before the heights per row are applied\n          * @event Equalizer#preequalizedrow\n          */\n\n\n        this.$element.trigger('preequalizedrow.zf.equalizer');\n\n        for (var j = 0, lenJ = groupsILength - 1; j < lenJ; j++) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(groups[i][j][0]).css({\n            'height': max\n          });\n        }\n        /**\n          * Fires when the heights per row have been applied\n          * @event Equalizer#postequalizedrow\n          */\n\n\n        this.$element.trigger('postequalizedrow.zf.equalizer');\n      }\n      /**\n       * Fires when the heights have been applied\n       */\n\n\n      this.$element.trigger('postequalized.zf.equalizer');\n    }\n    /**\n     * Destroys an instance of Equalizer.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this._pauseEvents();\n\n      this.$watched.css('height', 'auto');\n    }\n  }]);\n\n  return Equalizer;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nEqualizer.defaults = {\n  /**\n   * Enable height equalization when stacked on smaller screens.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeOnStack: false,\n\n  /**\n   * Enable height equalization row by row.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  equalizeByRow: false,\n\n  /**\n   * String representing the minimum breakpoint size the plugin should equalize heights on.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  equalizeOn: ''\n};\n\n\n/***/ }),\n\n/***/ 6:\n/*!**********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.equalizer.js ***!\n  \\**********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.equalizer.js */\"./js/entries/plugins/foundation.equalizer.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.equalizer.js.map"]}
\ No newline at end of file
index c2d30e3eb9206db56de277dceb348f67fd4fff7e..169aacbc321bb19440e89a98f2cff3b8ca66b78f 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.mediaQuery"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.mediaQuery", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.interchange"] = factory(require("./foundation.core"), require("./foundation.util.mediaQuery"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.interchange"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 86);
+/******/       return __webpack_require__(__webpack_require__.s = 7);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
 
 /***/ }),
 
-/***/ 20:
+/***/ "./js/entries/plugins/foundation.interchange.js":
+/*!******************************************************!*\
+  !*** ./js/entries/plugins/foundation.interchange.js ***!
+  \******************************************************/
+/*! exports provided: Foundation, Interchange */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_interchange__ = __webpack_require__(50);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_interchange__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.interchange */ "./js/foundation.interchange.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Interchange", function() { return _foundation_interchange__WEBPACK_IMPORTED_MODULE_1__["Interchange"]; });
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_interchange__["a" /* Interchange */], 'Interchange');
 
-/***/ }),
-
-/***/ 3:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_interchange__WEBPACK_IMPORTED_MODULE_1__["Interchange"], 'Interchange');
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
 /***/ }),
 
-/***/ 50:
+/***/ "./js/foundation.interchange.js":
+/*!**************************************!*\
+  !*** ./js/foundation.interchange.js ***!
+  \**************************************/
+/*! exports provided: Interchange */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Interchange; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Interchange", function() { return Interchange; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ "./foundation.core");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return 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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -145,17 +187,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.mediaQuery
  */
 
-var Interchange = function (_Plugin) {
+var Interchange =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Interchange, _Plugin);
 
   function Interchange() {
     _classCallCheck(this, Interchange);
 
-    return _possibleConstructorReturn(this, (Interchange.__proto__ || Object.getPrototypeOf(Interchange)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Interchange).apply(this, arguments));
   }
 
   _createClass(Interchange, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of Interchange.
@@ -167,15 +211,15 @@ var Interchange = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Interchange.defaults, options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Interchange.defaults, options);
       this.rules = [];
       this.currentPath = '';
       this.className = 'Interchange'; // ie9 back compat
 
       this._init();
+
       this._events();
     }
-
     /**
      * Initializes the Interchange plugin and calls functions to get interchange functioning on load.
      * @function
@@ -183,21 +227,22 @@ var Interchange = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"]._init();
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init();
 
-      var id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["GetYoDigits"])(6, 'interchange');
+      var id = this.$element[0].id || Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'interchange');
       this.$element.attr({
         'data-resize': id,
         'id': id
       });
 
       this._addBreakpoints();
+
       this._generateRules();
+
       this._reflow();
     }
-
     /**
      * Initializes events for Interchange.
      * @function
@@ -205,15 +250,14 @@ var Interchange = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
-      var _this3 = this;
+      var _this2 = this;
 
       this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () {
-        return _this3._reflow();
+        return _this2._reflow();
       });
     }
-
     /**
      * Calls necessary functions to update Interchange upon DOM change
      * @function
@@ -221,14 +265,14 @@ var Interchange = function (_Plugin) {
      */
 
   }, {
-    key: '_reflow',
+    key: "_reflow",
     value: function _reflow() {
-      var match;
+      var match; // Iterate through each rule, but only save the last match
 
-      // Iterate through each rule, but only save the last match
       for (var i in this.rules) {
         if (this.rules.hasOwnProperty(i)) {
           var rule = this.rules[i];
+
           if (window.matchMedia(rule.query).matches) {
             match = rule;
           }
@@ -239,7 +283,6 @@ var Interchange = function (_Plugin) {
         this.replace(match.path);
       }
     }
-
     /**
      * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.
      * @function
@@ -247,16 +290,15 @@ var Interchange = function (_Plugin) {
      */
 
   }, {
-    key: '_addBreakpoints',
+    key: "_addBreakpoints",
     value: function _addBreakpoints() {
-      for (var i in __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"].queries) {
-        if (__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"].queries.hasOwnProperty(i)) {
-          var query = __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"].queries[i];
+      for (var i in _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].queries) {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].queries.hasOwnProperty(i)) {
+          var query = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].queries[i];
           Interchange.SPECIAL_QUERIES[query.name] = query.value;
         }
       }
     }
-
     /**
      * Checks the Interchange element for the provided media query + content pairings
      * @function
@@ -266,7 +308,7 @@ var Interchange = function (_Plugin) {
      */
 
   }, {
-    key: '_generateRules',
+    key: "_generateRules",
     value: function _generateRules(element) {
       var rulesList = [];
       var rules;
@@ -277,7 +319,7 @@ var Interchange = function (_Plugin) {
         rules = this.$element.data('interchange');
       }
 
-      rules = typeof rules === 'string' ? rules.match(/\[.*?\]/g) : rules;
+      rules = typeof rules === 'string' ? rules.match(/\[.*?, .*?\]/g) : rules;
 
       for (var i in rules) {
         if (rules.hasOwnProperty(i)) {
@@ -298,7 +340,6 @@ var Interchange = function (_Plugin) {
 
       this.rules = rulesList;
     }
-
     /**
      * Update the `src` property of an image, or change the HTML of a container, to the specified path.
      * @function
@@ -307,55 +348,54 @@ var Interchange = function (_Plugin) {
      */
 
   }, {
-    key: 'replace',
+    key: "replace",
     value: function replace(path) {
       if (this.currentPath === path) return;
 
       var _this = this,
-          trigger = 'replaced.zf.interchange';
+          trigger = 'replaced.zf.interchange'; // Replacing images
+
 
-      // Replacing images
       if (this.$element[0].nodeName === 'IMG') {
         this.$element.attr('src', path).on('load', function () {
           _this.currentPath = path;
         }).trigger(trigger);
-      }
-      // Replacing background images
+      } // Replacing background images
       else if (path.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {
           path = path.replace(/\(/g, '%28').replace(/\)/g, '%29');
-          this.$element.css({ 'background-image': 'url(' + path + ')' }).trigger(trigger);
-        }
-        // Replacing HTML
+          this.$element.css({
+            'background-image': 'url(' + path + ')'
+          }).trigger(trigger);
+        } // Replacing HTML
         else {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.get(path, function (response) {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.get(path, function (response) {
               _this.$element.html(response).trigger(trigger);
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()(response).foundation();
+
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()(response).foundation();
               _this.currentPath = path;
             });
           }
-
       /**
        * Fires when content in an Interchange element is done being loaded.
        * @event Interchange#replaced
        */
       // this.$element.trigger('replaced.zf.interchange');
-    }
 
+    }
     /**
      * Destroys an instance of interchange.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.$element.off('resizeme.zf.trigger');
     }
   }]);
 
   return Interchange;
-}(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__["Plugin"]);
-
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["Plugin"]);
 /**
  * Default settings for plugin
  */
@@ -370,7 +410,6 @@ Interchange.defaults = {
    */
   rules: null
 };
-
 Interchange.SPECIAL_QUERIES = {
   'landscape': 'screen and (orientation: landscape)',
   'portrait': 'screen and (orientation: portrait)',
@@ -378,22 +417,31 @@ Interchange.SPECIAL_QUERIES = {
 };
 
 
-
 /***/ }),
 
-/***/ 6:
-/***/ (function(module, exports) {
+/***/ 7:
+/*!************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.interchange.js ***!
+  \************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.interchange.js */"./js/entries/plugins/foundation.interchange.js");
 
-/***/ }),
 
-/***/ 86:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ }),
 
-module.exports = __webpack_require__(20);
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.interchange.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.interchange.js.map b/dist/js/plugins/foundation.interchange.js.map
new file mode 100644 (file)
index 0000000..7f2951a
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.interchange.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.interchange.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Interchange","element","options","$element","$","extend","defaults","rules","currentPath","className","_init","_events","MediaQuery","id","GetYoDigits","attr","_addBreakpoints","_generateRules","_reflow","off","on","match","i","hasOwnProperty","rule","window","matchMedia","query","matches","replace","path","queries","SPECIAL_QUERIES","name","value","rulesList","data","slice","split","join","length","push","_this","trigger","nodeName","css","get","response","html","foundation","Plugin"],"mappings":"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","file":"foundation.interchange.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.mediaQuery\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.interchange\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.interchange\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 7);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","import { Foundation } from './foundation.core';\n\nimport { Interchange } from '../../foundation.interchange';\nFoundation.plugin(Interchange, 'Interchange');\n\nexport { Foundation, Interchange };\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { GetYoDigits } from './foundation.core.utils';\n\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n */\n\nclass Interchange extends Plugin {\n  /**\n   * Creates a new instance of Interchange.\n   * @class\n   * @name Interchange\n   * @fires Interchange#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Interchange.defaults, options);\n    this.rules = [];\n    this.currentPath = '';\n    this.className = 'Interchange'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Interchange plugin and calls functions to get interchange functioning on load.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var id = this.$element[0].id || GetYoDigits(6, 'interchange');\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    this._addBreakpoints();\n    this._generateRules();\n    this._reflow();\n  }\n\n  /**\n   * Initializes events for Interchange.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', () => this._reflow());\n  }\n\n  /**\n   * Calls necessary functions to update Interchange upon DOM change\n   * @function\n   * @private\n   */\n  _reflow() {\n    var match;\n\n    // Iterate through each rule, but only save the last match\n    for (var i in this.rules) {\n      if(this.rules.hasOwnProperty(i)) {\n        var rule = this.rules[i];\n        if (window.matchMedia(rule.query).matches) {\n          match = rule;\n        }\n      }\n    }\n\n    if (match) {\n      this.replace(match.path);\n    }\n  }\n\n  /**\n   * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.\n   * @function\n   * @private\n   */\n  _addBreakpoints() {\n    for (var i in MediaQuery.queries) {\n      if (MediaQuery.queries.hasOwnProperty(i)) {\n        var query = MediaQuery.queries[i];\n        Interchange.SPECIAL_QUERIES[query.name] = query.value;\n      }\n    }\n  }\n\n  /**\n   * Checks the Interchange element for the provided media query + content pairings\n   * @function\n   * @private\n   * @param {Object} element - jQuery object that is an Interchange instance\n   * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys\n   */\n  _generateRules(element) {\n    var rulesList = [];\n    var rules;\n\n    if (this.options.rules) {\n      rules = this.options.rules;\n    }\n    else {\n      rules = this.$element.data('interchange');\n    }\n\n    rules =  typeof rules === 'string' ? rules.match(/\\[.*?, .*?\\]/g) : rules;\n\n    for (var i in rules) {\n      if(rules.hasOwnProperty(i)) {\n        var rule = rules[i].slice(1, -1).split(', ');\n        var path = rule.slice(0, -1).join('');\n        var query = rule[rule.length - 1];\n\n        if (Interchange.SPECIAL_QUERIES[query]) {\n          query = Interchange.SPECIAL_QUERIES[query];\n        }\n\n        rulesList.push({\n          path: path,\n          query: query\n        });\n      }\n    }\n\n    this.rules = rulesList;\n  }\n\n  /**\n   * Update the `src` property of an image, or change the HTML of a container, to the specified path.\n   * @function\n   * @param {String} path - Path to the image or HTML partial.\n   * @fires Interchange#replaced\n   */\n  replace(path) {\n    if (this.currentPath === path) return;\n\n    var _this = this,\n        trigger = 'replaced.zf.interchange';\n\n    // Replacing images\n    if (this.$element[0].nodeName === 'IMG') {\n      this.$element.attr('src', path).on('load', function() {\n        _this.currentPath = path;\n      })\n      .trigger(trigger);\n    }\n    // Replacing background images\n    else if (path.match(/\\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {\n      path = path.replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n      this.$element.css({ 'background-image': 'url('+path+')' })\n          .trigger(trigger);\n    }\n    // Replacing HTML\n    else {\n      $.get(path, function(response) {\n        _this.$element.html(response)\n             .trigger(trigger);\n        $(response).foundation();\n        _this.currentPath = path;\n      });\n    }\n\n    /**\n     * Fires when content in an Interchange element is done being loaded.\n     * @event Interchange#replaced\n     */\n    // this.$element.trigger('replaced.zf.interchange');\n  }\n\n  /**\n   * Destroys an instance of interchange.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('resizeme.zf.trigger')\n  }\n}\n\n/**\n * Default settings for plugin\n */\nInterchange.defaults = {\n  /**\n   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.\n   * @option\n   * @type {?array}\n   * @default null\n   */\n  rules: null\n};\n\nInterchange.SPECIAL_QUERIES = {\n  'landscape': 'screen and (orientation: landscape)',\n  'portrait': 'screen and (orientation: portrait)',\n  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'\n};\n\nexport {Interchange};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 526bf4609c0be24b4e92d2c6f876b3290eb9af47..5032082f317661707579d2534a9d04cbe5be1ffb 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(r){if(n[r])return n[r].exports;var i=n[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,t),i.l=!0,i.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=86)}({0:function(e,t){e.exports=jQuery},1:function(e,t){e.exports={Foundation:window.Foundation}},2:function(e,t){e.exports={Plugin:window.Foundation.Plugin}},20:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=n(1),i=(n.n(r),n(50));r.Foundation.plugin(i.a,"Interchange")},3:function(e,t){e.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},50:function(e,t,n){"use strict";function r(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function i(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function o(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}n.d(t,"a",function(){return p});var a=n(0),u=n.n(a),s=n(6),c=(n.n(s),n(2)),l=(n.n(c),n(3)),f=(n.n(l),function(){function e(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}return function(t,n,r){return n&&e(t.prototype,n),r&&e(t,r),t}}()),p=function(e){function t(){return r(this,t),i(this,(t.__proto__||Object.getPrototypeOf(t)).apply(this,arguments))}return o(t,e),f(t,[{key:"_setup",value:function(e,n){this.$element=e,this.options=u.a.extend({},t.defaults,n),this.rules=[],this.currentPath="",this.className="Interchange",this._init(),this._events()}},{key:"_init",value:function(){s.MediaQuery._init();var e=this.$element[0].id||n.i(l.GetYoDigits)(6,"interchange");this.$element.attr({"data-resize":e,id:e}),this._addBreakpoints(),this._generateRules(),this._reflow()}},{key:"_events",value:function(){var e=this;this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(){return e._reflow()})}},{key:"_reflow",value:function(){var e;for(var t in this.rules)if(this.rules.hasOwnProperty(t)){var n=this.rules[t];window.matchMedia(n.query).matches&&(e=n)}e&&this.replace(e.path)}},{key:"_addBreakpoints",value:function(){for(var e in s.MediaQuery.queries)if(s.MediaQuery.queries.hasOwnProperty(e)){var n=s.MediaQuery.queries[e];t.SPECIAL_QUERIES[n.name]=n.value}}},{key:"_generateRules",value:function(e){var n,r=[];n=this.options.rules?this.options.rules:this.$element.data("interchange"),n="string"==typeof n?n.match(/\[.*?\]/g):n;for(var i in n)if(n.hasOwnProperty(i)){var o=n[i].slice(1,-1).split(", "),a=o.slice(0,-1).join(""),u=o[o.length-1];t.SPECIAL_QUERIES[u]&&(u=t.SPECIAL_QUERIES[u]),r.push({path:a,query:u})}this.rules=r}},{key:"replace",value:function(e){if(this.currentPath!==e){var t=this,n="replaced.zf.interchange";"IMG"===this.$element[0].nodeName?this.$element.attr("src",e).on("load",function(){t.currentPath=e}).trigger(n):e.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)?(e=e.replace(/\(/g,"%28").replace(/\)/g,"%29"),this.$element.css({"background-image":"url("+e+")"}).trigger(n)):u.a.get(e,function(r){t.$element.html(r).trigger(n),u()(r).foundation(),t.currentPath=e})}}},{key:"_destroy",value:function(){this.$element.off("resizeme.zf.trigger")}}]),t}(c.Plugin);p.defaults={rules:null},p.SPECIAL_QUERIES={landscape:"screen and (orientation: landscape)",portrait:"screen and (orientation: portrait)",retina:"only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)"}},6:function(e,t){e.exports={MediaQuery:window.Foundation.MediaQuery}},86:function(e,t,n){e.exports=n(20)}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("./foundation.util.mediaQuery"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.mediaQuery","jquery"],t):"object"==typeof exports?exports["foundation.interchange"]=t(require("./foundation.core"),require("./foundation.util.mediaQuery"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.interchange"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],e.jQuery))}(window,function(n,r,i){return function(n){var r={};function i(e){if(r[e])return r[e].exports;var t=r[e]={i:e,l:!1,exports:{}};return n[e].call(t.exports,t,t.exports,i),t.l=!0,t.exports}return i.m=n,i.c=r,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var r in t)i.d(n,r,function(e){return t[e]}.bind(null,r));return n},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="",i(i.s=7)}({"./foundation.core":function(e,t){e.exports=n},"./foundation.util.mediaQuery":function(e,t){e.exports=r},"./js/entries/plugins/foundation.interchange.js":function(e,t,n){"use strict";n.r(t);var r=n("./foundation.core");n.d(t,"Foundation",function(){return r.Foundation});var i=n("./js/foundation.interchange.js");n.d(t,"Interchange",function(){return i.Interchange}),r.Foundation.plugin(i.Interchange,"Interchange")},"./js/foundation.interchange.js":function(e,t,n){"use strict";n.r(t),n.d(t,"Interchange",function(){return d});var r=n("jquery"),i=n.n(r),o=n("./foundation.util.mediaQuery"),u=n("./foundation.core");function a(e){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function c(e,t){for(var n=0;n<t.length;n++){var r=t[n];r.enumerable=r.enumerable||!1,r.configurable=!0,"value"in r&&(r.writable=!0),Object.defineProperty(e,r.key,r)}}function s(e,t){return!t||"object"!==a(t)&&"function"!=typeof t?function(e){if(void 0!==e)return e;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(e):t}function f(e){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function l(e,t){return(l=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e})(e,t)}var d=function(e){function a(){return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,a),s(this,f(a).apply(this,arguments))}var t,n,r;return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&l(e,t)}(a,u["Plugin"]),t=a,(n=[{key:"_setup",value:function(e,t){this.$element=e,this.options=i.a.extend({},a.defaults,t),this.rules=[],this.currentPath="",this.className="Interchange",this._init(),this._events()}},{key:"_init",value:function(){o.MediaQuery._init();var e=this.$element[0].id||Object(u.GetYoDigits)(6,"interchange");this.$element.attr({"data-resize":e,id:e}),this._addBreakpoints(),this._generateRules(),this._reflow()}},{key:"_events",value:function(){var e=this;this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(){return e._reflow()})}},{key:"_reflow",value:function(){var e;for(var t in this.rules)if(this.rules.hasOwnProperty(t)){var n=this.rules[t];window.matchMedia(n.query).matches&&(e=n)}e&&this.replace(e.path)}},{key:"_addBreakpoints",value:function(){for(var e in o.MediaQuery.queries)if(o.MediaQuery.queries.hasOwnProperty(e)){var t=o.MediaQuery.queries[e];a.SPECIAL_QUERIES[t.name]=t.value}}},{key:"_generateRules",value:function(e){var t,n=[];for(var r in t="string"==typeof(t=this.options.rules?this.options.rules:this.$element.data("interchange"))?t.match(/\[.*?, .*?\]/g):t)if(t.hasOwnProperty(r)){var i=t[r].slice(1,-1).split(", "),o=i.slice(0,-1).join(""),u=i[i.length-1];a.SPECIAL_QUERIES[u]&&(u=a.SPECIAL_QUERIES[u]),n.push({path:o,query:u})}this.rules=n}},{key:"replace",value:function(t){if(this.currentPath!==t){var n=this,r="replaced.zf.interchange";"IMG"===this.$element[0].nodeName?this.$element.attr("src",t).on("load",function(){n.currentPath=t}).trigger(r):t.match(/\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)?(t=t.replace(/\(/g,"%28").replace(/\)/g,"%29"),this.$element.css({"background-image":"url("+t+")"}).trigger(r)):i.a.get(t,function(e){n.$element.html(e).trigger(r),i()(e).foundation(),n.currentPath=t})}}},{key:"_destroy",value:function(){this.$element.off("resizeme.zf.trigger")}}])&&c(t.prototype,n),r&&c(t,r),a}();d.defaults={rules:null},d.SPECIAL_QUERIES={landscape:"screen and (orientation: landscape)",portrait:"screen and (orientation: portrait)",retina:"only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)"}},7:function(e,t,n){e.exports=n("./js/entries/plugins/foundation.interchange.js")},jquery:function(e,t){e.exports=i}})});
+//# sourceMappingURL=foundation.interchange.min.js.map
diff --git a/dist/js/plugins/foundation.interchange.min.js.map b/dist/js/plugins/foundation.interchange.min.js.map
new file mode 100644 (file)
index 0000000..8fc3497
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.interchange.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.mediaQuery","./js/entries/plugins/foundation.interchange.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_interchange__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.interchange.js","Interchange","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","rules","currentPath","className","_init","_events","id","attr","data-resize","_addBreakpoints","_generateRules","_reflow","_this2","off","on","match","rule","matchMedia","query","matches","replace","path","queries","SPECIAL_QUERIES","rulesList","data","slice","split","join","push","_this","trigger","nodeName","css","background-image","response","html","foundation","landscape","portrait","retina","7","jquery"],"mappings":"CAAA,SAA2CA,EAAMC,GAC1B,iBAAZC,SAA0C,iBAAXC,OACxCA,OAAOD,QAAUD,EAAQG,QAAQ,qBAAsBA,QAAQ,gCAAiCA,QAAQ,WAC/E,mBAAXC,QAAyBA,OAAOC,IAC9CD,OAAO,CAAC,oBAAqB,+BAAgC,UAAWJ,GAC9C,iBAAZC,QACdA,QAAQ,0BAA4BD,EAAQG,QAAQ,qBAAsBA,QAAQ,gCAAiCA,QAAQ,YAE3HJ,EAA8B,wBAAIA,EAA8B,yBAAK,GAAIA,EAA8B,wBAAE,0BAA4BC,EAAQD,EAA8B,wBAAE,mBAAoBA,EAA8B,wBAAE,8BAA+BA,EAAa,SAR/Q,CASGO,OAAQ,SAASC,EAA8CC,EAAyDC,GAC3H,OAAgB,SAAUC,GAEhB,IAAIC,EAAmB,GAGvB,SAASC,EAAoBC,GAG5B,GAAGF,EAAiBE,GACnB,OAAOF,EAAiBE,GAAUZ,QAGnC,IAAIC,EAASS,EAAiBE,GAAY,CACzCC,EAAGD,EACHE,GAAG,EACHd,QAAS,IAUV,OANAS,EAAQG,GAAUG,KAAKd,EAAOD,QAASC,EAAQA,EAAOD,QAASW,GAG/DV,EAAOa,GAAI,EAGJb,EAAOD,QA0Df,OArDAW,EAAoBK,EAAIP,EAGxBE,EAAoBM,EAAIP,EAGxBC,EAAoBO,EAAI,SAASlB,EAASmB,EAAMC,GAC3CT,EAAoBU,EAAErB,EAASmB,IAClCG,OAAOC,eAAevB,EAASmB,EAAM,CAAEK,YAAY,EAAMC,IAAKL,KAKhET,EAAoBe,EAAI,SAAS1B,GACX,oBAAX2B,QAA0BA,OAAOC,aAC1CN,OAAOC,eAAevB,EAAS2B,OAAOC,YAAa,CAAEC,MAAO,WAE7DP,OAAOC,eAAevB,EAAS,aAAc,CAAE6B,OAAO,KAQvDlB,EAAoBmB,EAAI,SAASD,EAAOE,GAEvC,GADU,EAAPA,IAAUF,EAAQlB,EAAoBkB,IAC/B,EAAPE,EAAU,OAAOF,EACpB,GAAW,EAAPE,GAA8B,iBAAVF,GAAsBA,GAASA,EAAMG,WAAY,OAAOH,EAChF,IAAII,EAAKX,OAAOY,OAAO,MAGvB,GAFAvB,EAAoBe,EAAEO,GACtBX,OAAOC,eAAeU,EAAI,UAAW,CAAET,YAAY,EAAMK,MAAOA,IACtD,EAAPE,GAA4B,iBAATF,EAAmB,IAAI,IAAIM,KAAON,EAAOlB,EAAoBO,EAAEe,EAAIE,EAAK,SAASA,GAAO,OAAON,EAAMM,IAAQC,KAAK,KAAMD,IAC9I,OAAOF,GAIRtB,EAAoB0B,EAAI,SAASpC,GAChC,IAAImB,EAASnB,GAAUA,EAAO+B,WAC7B,WAAwB,OAAO/B,EAAgB,SAC/C,WAA8B,OAAOA,GAEtC,OADAU,EAAoBO,EAAEE,EAAQ,IAAKA,GAC5BA,GAIRT,EAAoBU,EAAI,SAASiB,EAAQC,GAAY,OAAOjB,OAAOkB,UAAUC,eAAe1B,KAAKuB,EAAQC,IAGzG5B,EAAoB+B,EAAI,GAIjB/B,EAAoBA,EAAoBgC,EAAI,GAnF7C,CAsFN,CAEJC,oBAKA,SAAU3C,EAAQD,GAExBC,EAAOD,QAAUM,GAIXuC,+BAKA,SAAU5C,EAAQD,GAExBC,EAAOD,QAAUO,GAIXuC,iDAKA,SAAU7C,EAAQ8C,EAAqBpC,GAE7C,aACAA,EAAoBe,EAAEqB,GACD,IAAIC,EAAgDrC,EAA6C,qBAExFA,EAAoBO,EAAE6B,EAAqB,aAAc,WAAa,OAAOC,EAA0D,aAEhJ,IAAIC,EAAuDtC,EAAwD,kCAC1GA,EAAoBO,EAAE6B,EAAqB,cAAe,WAAa,OAAOE,EAAkE,cAI9KD,EAA0D,WAAEE,OAAOD,EAAkE,YAAG,gBAKlIE,iCAKA,SAAUlD,EAAQ8C,EAAqBpC,GAE7C,aACAA,EAAoBe,EAAEqB,GACSpC,EAAoBO,EAAE6B,EAAqB,cAAe,WAAa,OAAOK,IACxF,IAAIC,EAAsC1C,EAAkC,UACxE2C,EAA2D3C,EAAoB0B,EAAEgB,GACjFE,EAA2D5C,EAAwD,gCAEnH6C,EAAuD7C,EAAoD,qBAIpI,SAAS8C,EAAQC,GAAwT,OAAtOD,EAArD,mBAAX9B,QAAoD,iBAApBA,OAAOgC,SAAmC,SAAiBD,GAAO,cAAcA,GAA2B,SAAiBA,GAAO,OAAOA,GAAyB,mBAAX/B,QAAyB+B,EAAIE,cAAgBjC,QAAU+B,IAAQ/B,OAAOa,UAAY,gBAAkBkB,IAAyBA,GAIxV,SAASG,EAAkBC,EAAQC,GAAS,IAAK,IAAIlD,EAAI,EAAGA,EAAIkD,EAAMC,OAAQnD,IAAK,CAAE,IAAIoD,EAAaF,EAAMlD,GAAIoD,EAAWzC,WAAayC,EAAWzC,aAAc,EAAOyC,EAAWC,cAAe,EAAU,UAAWD,IAAYA,EAAWE,UAAW,GAAM7C,OAAOC,eAAeuC,EAAQG,EAAW9B,IAAK8B,IAI7S,SAASG,EAA2BC,EAAMtD,GAAQ,OAAIA,GAA2B,WAAlB0C,EAAQ1C,IAAsC,mBAATA,EAEpG,SAAgCsD,GAAQ,QAAa,IAATA,EAA4G,OAAOA,EAAhG,MAAM,IAAIC,eAAe,6DAF0DC,CAAuBF,GAAtCtD,EAInI,SAASyD,EAAgBnD,GAAwJ,OAAnJmD,EAAkBlD,OAAOmD,eAAiBnD,OAAOoD,eAAiB,SAAyBrD,GAAK,OAAOA,EAAEsD,WAAarD,OAAOoD,eAAerD,KAA8BA,GAIxM,SAASuD,EAAgBvD,EAAGqB,GAA+G,OAA1GkC,EAAkBtD,OAAOmD,gBAAkB,SAAyBpD,EAAGqB,GAAsB,OAAjBrB,EAAEsD,UAAYjC,EAAUrB,IAA6BA,EAAGqB,GAYrK,IAAIU,EAEJ,SAAUyB,GAGR,SAASzB,IAGP,OAlCJ,SAAyB0B,EAAUC,GAAe,KAAMD,aAAoBC,GAAgB,MAAM,IAAIC,UAAU,qCAgC5GC,CAAgBC,KAAM9B,GAEfgB,EAA2Bc,KAAMV,EAAgBpB,GAAa+B,MAAMD,KAAME,YA9BrF,IAAsBL,EAAaM,EAAYC,EAqO7C,OA7NF,SAAmBC,EAAUC,GAAc,GAA0B,mBAAfA,GAA4C,OAAfA,EAAuB,MAAM,IAAIR,UAAU,sDAAyDO,EAAS/C,UAAYlB,OAAOY,OAAOsD,GAAcA,EAAWhD,UAAW,CAAEoB,YAAa,CAAE/B,MAAO0D,EAAUpB,UAAU,EAAMD,cAAc,KAAesB,GAAYZ,EAAgBW,EAAUC,GAiBjXC,CAAUrC,EA6MVI,EAAqD,WAtOjCuB,EAiCP3B,GAjCoBiC,EAiCP,CAAC,CACzBlD,IAAK,SAULN,MAAO,SAAgB6D,EAASC,GAC9BT,KAAKU,SAAWF,EAChBR,KAAKS,QAAUrC,EAA4CuC,EAAEC,OAAO,GAAI1C,EAAY2C,SAAUJ,GAC9FT,KAAKc,MAAQ,GACbd,KAAKe,YAAc,GACnBf,KAAKgB,UAAY,cAEjBhB,KAAKiB,QAELjB,KAAKkB,YAQN,CACDjE,IAAK,QACLN,MAAO,WACL0B,EAAqE,WAAE4C,QAEvE,IAAIE,EAAKnB,KAAKU,SAAS,GAAGS,IAAM/E,OAAOkC,EAAkE,YAAzElC,CAA4E,EAAG,eAC/G4D,KAAKU,SAASU,KAAK,CACjBC,cAAeF,EACfA,GAAMA,IAGRnB,KAAKsB,kBAELtB,KAAKuB,iBAELvB,KAAKwB,YAQN,CACDvE,IAAK,UACLN,MAAO,WACL,IAAI8E,EAASzB,KAEbA,KAAKU,SAASgB,IAAI,uBAAuBC,GAAG,sBAAuB,WACjE,OAAOF,EAAOD,cASjB,CACDvE,IAAK,UACLN,MAAO,WACL,IAAIiF,EAEJ,IAAK,IAAIjG,KAAKqE,KAAKc,MACjB,GAAId,KAAKc,MAAMvD,eAAe5B,GAAI,CAChC,IAAIkG,EAAO7B,KAAKc,MAAMnF,GAElBR,OAAO2G,WAAWD,EAAKE,OAAOC,UAChCJ,EAAQC,GAKVD,GACF5B,KAAKiC,QAAQL,EAAMM,QAStB,CACDjF,IAAK,kBACLN,MAAO,WACL,IAAK,IAAIhB,KAAK0C,EAAqE,WAAE8D,QACnF,GAAI9D,EAAqE,WAAE8D,QAAQ5E,eAAe5B,GAAI,CACpG,IAAIoG,EAAQ1D,EAAqE,WAAE8D,QAAQxG,GAC3FuC,EAAYkE,gBAAgBL,EAAM9F,MAAQ8F,EAAMpF,SAYrD,CACDM,IAAK,iBACLN,MAAO,SAAwB6D,GAC7B,IACIM,EADAuB,EAAY,GAWhB,IAAK,IAAI1G,KAFTmF,EAAyB,iBALvBA,EADEd,KAAKS,QAAQK,MACPd,KAAKS,QAAQK,MAEbd,KAAKU,SAAS4B,KAAK,gBAGOxB,EAAMc,MAAM,iBAAmBd,EAGjE,GAAIA,EAAMvD,eAAe5B,GAAI,CAC3B,IAAIkG,EAAOf,EAAMnF,GAAG4G,MAAM,GAAI,GAAGC,MAAM,MACnCN,EAAOL,EAAKU,MAAM,GAAI,GAAGE,KAAK,IAC9BV,EAAQF,EAAKA,EAAK/C,OAAS,GAE3BZ,EAAYkE,gBAAgBL,KAC9BA,EAAQ7D,EAAYkE,gBAAgBL,IAGtCM,EAAUK,KAAK,CACbR,KAAMA,EACNH,MAAOA,IAKb/B,KAAKc,MAAQuB,IASd,CACDpF,IAAK,UACLN,MAAO,SAAiBuF,GACtB,GAAIlC,KAAKe,cAAgBmB,EAAzB,CAEA,IAAIS,EAAQ3C,KACR4C,EAAU,0BAGoB,QAA9B5C,KAAKU,SAAS,GAAGmC,SACnB7C,KAAKU,SAASU,KAAK,MAAOc,GAAMP,GAAG,OAAQ,WACzCgB,EAAM5B,YAAcmB,IACnBU,QAAQA,GAEJV,EAAKN,MAAM,4CAChBM,EAAOA,EAAKD,QAAQ,MAAO,OAAOA,QAAQ,MAAO,OACjDjC,KAAKU,SAASoC,IAAI,CAChBC,mBAAoB,OAASb,EAAO,MACnCU,QAAQA,IAGTxE,EAA4CuC,EAAEpE,IAAI2F,EAAM,SAAUc,GAChEL,EAAMjC,SAASuC,KAAKD,GAAUJ,QAAQA,GAEtCxE,GAAAA,CAA8C4E,GAAUE,aACxDP,EAAM5B,YAAcmB,OAe7B,CACDjF,IAAK,WACLN,MAAO,WACLqD,KAAKU,SAASgB,IAAI,4BAjOsD/C,EAAkBkB,EAAYvC,UAAW6C,GAAiBC,GAAazB,EAAkBkB,EAAaO,GAqO3KlC,EA7MT,GAoNAA,EAAY2C,SAAW,CAOrBC,MAAO,MAET5C,EAAYkE,gBAAkB,CAC5Be,UAAa,sCACbC,SAAY,qCACZC,OAAU,4RAMNC,EAKA,SAAUvI,EAAQD,EAASW,GAEjCV,EAAOD,QAAUW,EAA6H,mDAKxI8H,OAKA,SAAUxI,EAAQD,GAExBC,EAAOD,QAAUQ","file":"foundation.interchange.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.mediaQuery\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.interchange\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.interchange\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 7);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.interchange.js\":\n/*!******************************************************!*\\\n  !*** ./js/entries/plugins/foundation.interchange.js ***!\n  \\******************************************************/\n/*! exports provided: Foundation, Interchange */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_interchange__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.interchange */ \"./js/foundation.interchange.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Interchange\", function() { return _foundation_interchange__WEBPACK_IMPORTED_MODULE_1__[\"Interchange\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_interchange__WEBPACK_IMPORTED_MODULE_1__[\"Interchange\"], 'Interchange');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.interchange.js\":\n/*!**************************************!*\\\n  !*** ./js/foundation.interchange.js ***!\n  \\**************************************/\n/*! exports provided: Interchange */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Interchange\", function() { return Interchange; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n/**\n * Interchange module.\n * @module foundation.interchange\n * @requires foundation.util.mediaQuery\n */\n\nvar Interchange =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Interchange, _Plugin);\n\n  function Interchange() {\n    _classCallCheck(this, Interchange);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Interchange).apply(this, arguments));\n  }\n\n  _createClass(Interchange, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Interchange.\n     * @class\n     * @name Interchange\n     * @fires Interchange#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Interchange.defaults, options);\n      this.rules = [];\n      this.currentPath = '';\n      this.className = 'Interchange'; // ie9 back compat\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the Interchange plugin and calls functions to get interchange functioning on load.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init();\n\n      var id = this.$element[0].id || Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'interchange');\n      this.$element.attr({\n        'data-resize': id,\n        'id': id\n      });\n\n      this._addBreakpoints();\n\n      this._generateRules();\n\n      this._reflow();\n    }\n    /**\n     * Initializes events for Interchange.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this2 = this;\n\n      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function () {\n        return _this2._reflow();\n      });\n    }\n    /**\n     * Calls necessary functions to update Interchange upon DOM change\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_reflow\",\n    value: function _reflow() {\n      var match; // Iterate through each rule, but only save the last match\n\n      for (var i in this.rules) {\n        if (this.rules.hasOwnProperty(i)) {\n          var rule = this.rules[i];\n\n          if (window.matchMedia(rule.query).matches) {\n            match = rule;\n          }\n        }\n      }\n\n      if (match) {\n        this.replace(match.path);\n      }\n    }\n    /**\n     * Gets the Foundation breakpoints and adds them to the Interchange.SPECIAL_QUERIES object.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_addBreakpoints\",\n    value: function _addBreakpoints() {\n      for (var i in _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].queries) {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].queries.hasOwnProperty(i)) {\n          var query = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].queries[i];\n          Interchange.SPECIAL_QUERIES[query.name] = query.value;\n        }\n      }\n    }\n    /**\n     * Checks the Interchange element for the provided media query + content pairings\n     * @function\n     * @private\n     * @param {Object} element - jQuery object that is an Interchange instance\n     * @returns {Array} scenarios - Array of objects that have 'mq' and 'path' keys with corresponding keys\n     */\n\n  }, {\n    key: \"_generateRules\",\n    value: function _generateRules(element) {\n      var rulesList = [];\n      var rules;\n\n      if (this.options.rules) {\n        rules = this.options.rules;\n      } else {\n        rules = this.$element.data('interchange');\n      }\n\n      rules = typeof rules === 'string' ? rules.match(/\\[.*?, .*?\\]/g) : rules;\n\n      for (var i in rules) {\n        if (rules.hasOwnProperty(i)) {\n          var rule = rules[i].slice(1, -1).split(', ');\n          var path = rule.slice(0, -1).join('');\n          var query = rule[rule.length - 1];\n\n          if (Interchange.SPECIAL_QUERIES[query]) {\n            query = Interchange.SPECIAL_QUERIES[query];\n          }\n\n          rulesList.push({\n            path: path,\n            query: query\n          });\n        }\n      }\n\n      this.rules = rulesList;\n    }\n    /**\n     * Update the `src` property of an image, or change the HTML of a container, to the specified path.\n     * @function\n     * @param {String} path - Path to the image or HTML partial.\n     * @fires Interchange#replaced\n     */\n\n  }, {\n    key: \"replace\",\n    value: function replace(path) {\n      if (this.currentPath === path) return;\n\n      var _this = this,\n          trigger = 'replaced.zf.interchange'; // Replacing images\n\n\n      if (this.$element[0].nodeName === 'IMG') {\n        this.$element.attr('src', path).on('load', function () {\n          _this.currentPath = path;\n        }).trigger(trigger);\n      } // Replacing background images\n      else if (path.match(/\\.(gif|jpg|jpeg|png|svg|tiff)([?#].*)?/i)) {\n          path = path.replace(/\\(/g, '%28').replace(/\\)/g, '%29');\n          this.$element.css({\n            'background-image': 'url(' + path + ')'\n          }).trigger(trigger);\n        } // Replacing HTML\n        else {\n            jquery__WEBPACK_IMPORTED_MODULE_0___default.a.get(path, function (response) {\n              _this.$element.html(response).trigger(trigger);\n\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()(response).foundation();\n              _this.currentPath = path;\n            });\n          }\n      /**\n       * Fires when content in an Interchange element is done being loaded.\n       * @event Interchange#replaced\n       */\n      // this.$element.trigger('replaced.zf.interchange');\n\n    }\n    /**\n     * Destroys an instance of interchange.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('resizeme.zf.trigger');\n    }\n  }]);\n\n  return Interchange;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nInterchange.defaults = {\n  /**\n   * Rules to be applied to Interchange elements. Set with the `data-interchange` array notation.\n   * @option\n   * @type {?array}\n   * @default null\n   */\n  rules: null\n};\nInterchange.SPECIAL_QUERIES = {\n  'landscape': 'screen and (orientation: landscape)',\n  'portrait': 'screen and (orientation: portrait)',\n  'retina': 'only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (min--moz-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min-device-pixel-ratio: 2), only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx)'\n};\n\n\n/***/ }),\n\n/***/ 7:\n/*!************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.interchange.js ***!\n  \\************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.interchange.js */\"./js/entries/plugins/foundation.interchange.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.interchange.js.map"]}
\ No newline at end of file
index aeef6301369cba353fdbe3fc51b8fa960e96d65e..9f63d5bcb0613c165be21d74a6ad391f0e636856 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.smoothScroll"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.smoothScroll", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.magellan"] = factory(require("./foundation.core"), require("./foundation.smoothScroll"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.magellan"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.smoothScroll"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_smoothScroll__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 87);
+/******/       return __webpack_require__(__webpack_require__.s = 8);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.smoothScroll":
+/*!************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.smoothScroll"],"amd":"./foundation.smoothScroll","commonjs":"./foundation.smoothScroll","commonjs2":"./foundation.smoothScroll"} ***!
+  \************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_smoothScroll__;
 
 /***/ }),
 
-/***/ 21:
+/***/ "./js/entries/plugins/foundation.magellan.js":
+/*!***************************************************!*\
+  !*** ./js/entries/plugins/foundation.magellan.js ***!
+  \***************************************************/
+/*! exports provided: Foundation, Magellan */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_magellan__ = __webpack_require__(51);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_magellan__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.magellan */ "./js/foundation.magellan.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Magellan", function() { return _foundation_magellan__WEBPACK_IMPORTED_MODULE_1__["Magellan"]; });
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_magellan__["a" /* Magellan */], 'Magellan');
 
-/***/ }),
-
-/***/ 3:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_magellan__WEBPACK_IMPORTED_MODULE_1__["Magellan"], 'Magellan');
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
 /***/ }),
 
-/***/ 51:
+/***/ "./js/foundation.magellan.js":
+/*!***********************************!*\
+  !*** ./js/foundation.magellan.js ***!
+  \***********************************/
+/*! exports provided: Magellan */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Magellan; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_smoothScroll__ = __webpack_require__(76);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_smoothScroll___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_smoothScroll__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Magellan", function() { return Magellan; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.smoothScroll */ "./foundation.smoothScroll");
+/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-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 _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -145,17 +187,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.smoothScroll
  */
 
-var Magellan = function (_Plugin) {
+var Magellan =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Magellan, _Plugin);
 
   function Magellan() {
     _classCallCheck(this, Magellan);
 
-    return _possibleConstructorReturn(this, (Magellan.__proto__ || Object.getPrototypeOf(Magellan)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Magellan).apply(this, arguments));
   }
 
   _createClass(Magellan, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of Magellan.
@@ -167,36 +211,37 @@ var Magellan = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Magellan.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Magellan.defaults, this.$element.data(), options);
       this.className = 'Magellan'; // ie9 back compat
 
       this._init();
+
       this.calcPoints();
     }
-
     /**
      * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      var id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["GetYoDigits"])(6, 'magellan');
+      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'magellan');
+
       var _this = this;
-      this.$targets = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-magellan-target]');
+
+      this.$targets = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-magellan-target]');
       this.$links = this.$element.find('a');
       this.$element.attr({
         'data-resize': id,
         'data-scroll': id,
         'id': id
       });
-      this.$active = __WEBPACK_IMPORTED_MODULE_0_jquery___default()();
+      this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
       this.scrollPos = parseInt(window.pageYOffset, 10);
 
       this._events();
     }
-
     /**
      * Calculates an array of pixel values that are the demarcation lines between locations on the page.
      * Can be invoked if new elements are added or the size of a location changes.
@@ -204,7 +249,7 @@ var Magellan = function (_Plugin) {
      */
 
   }, {
-    key: 'calcPoints',
+    key: "calcPoints",
     value: function calcPoints() {
       var _this = this,
           body = document.body,
@@ -213,46 +258,50 @@ var Magellan = function (_Plugin) {
       this.points = [];
       this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));
       this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));
-
       this.$targets.each(function () {
-        var $tar = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var $tar = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             pt = Math.round($tar.offset().top - _this.options.threshold);
         $tar.targetPoint = pt;
+
         _this.points.push(pt);
       });
     }
-
     /**
      * Initializes events for Magellan.
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this,
-          $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body'),
+          $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body'),
           opts = {
         duration: _this.options.animationDuration,
         easing: _this.options.animationEasing
       };
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).one('load', function () {
+
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', function () {
         if (_this.options.deepLinking) {
           if (location.hash) {
             _this.scrollToLoc(location.hash);
           }
         }
+
         _this.calcPoints();
+
         _this._updateActive();
       });
-
-      this.$element.on({
-        'resizeme.zf.trigger': this.reflow.bind(this),
-        'scrollme.zf.trigger': this._updateActive.bind(this)
-      }).on('click.zf.magellan', 'a[href^="#"]', function (e) {
-        e.preventDefault();
-        var arrival = this.getAttribute('href');
-        _this.scrollToLoc(arrival);
+      _this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+        _this.$element.on({
+          'resizeme.zf.trigger': _this.reflow.bind(_this),
+          'scrollme.zf.trigger': _this._updateActive.bind(_this)
+        }).on('click.zf.magellan', 'a[href^="#"]', function (e) {
+          e.preventDefault();
+          var arrival = this.getAttribute('href');
+
+          _this.scrollToLoc(arrival);
+        });
       });
 
       this._deepLinkScroll = function (e) {
@@ -261,9 +310,8 @@ var Magellan = function (_Plugin) {
         }
       };
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('popstate', this._deepLinkScroll);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._deepLinkScroll);
     }
-
     /**
      * Function to scroll to a given location on the page.
      * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'
@@ -271,9 +319,10 @@ var Magellan = function (_Plugin) {
      */
 
   }, {
-    key: 'scrollToLoc',
+    key: "scrollToLoc",
     value: function scrollToLoc(loc) {
       this._inTransition = true;
+
       var _this = this;
 
       var options = {
@@ -282,25 +331,22 @@ var Magellan = function (_Plugin) {
         threshold: this.options.threshold,
         offset: this.options.offset
       };
-
-      __WEBPACK_IMPORTED_MODULE_3__foundation_smoothScroll__["SmoothScroll"].scrollToLoc(loc, options, function () {
+      _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2__["SmoothScroll"].scrollToLoc(loc, options, function () {
         _this._inTransition = false;
-        _this._updateActive();
       });
     }
-
     /**
      * Calls necessary functions to update Magellan upon DOM change
      * @function
      */
 
   }, {
-    key: 'reflow',
+    key: "reflow",
     value: function reflow() {
       this.calcPoints();
+
       this._updateActive();
     }
-
     /**
      * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.
      * @private
@@ -309,73 +355,91 @@ var Magellan = function (_Plugin) {
      */
 
   }, {
-    key: '_updateActive',
-    value: function _updateActive() /*evt, elem, scrollPos*/{
-      if (this._inTransition) {
-        return;
-      }
-      var winPos = /*scrollPos ||*/parseInt(window.pageYOffset, 10),
-          curIdx;
-
-      if (winPos + this.winHeight === this.docHeight) {
-        curIdx = this.points.length - 1;
-      } else if (winPos < this.points[0]) {
-        curIdx = undefined;
+    key: "_updateActive",
+    value: function _updateActive()
+    /*evt, elem, scrollPos*/
+    {
+      var _this2 = this;
+
+      if (this._inTransition) return;
+      var newScrollPos = parseInt(window.pageYOffset, 10);
+      var isScrollingUp = this.scrollPos > newScrollPos;
+      this.scrollPos = newScrollPos;
+      var activeIdx; // Before the first point: no link
+
+      if (newScrollPos < this.points[0]) {}
+      /* do nothing */
+      // At the bottom of the page: last link
+      else if (newScrollPos + this.winHeight === this.docHeight) {
+          activeIdx = this.points.length - 1;
+        } // Otherwhise, use the last visible link
+        else {
+            var visibleLinks = this.points.filter(function (p, i) {
+              return p - _this2.options.offset - (isScrollingUp ? _this2.options.threshold : 0) <= newScrollPos;
+            });
+            activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;
+          } // Get the new active link
+
+
+      var $oldActive = this.$active;
+      var activeHash = '';
+
+      if (typeof activeIdx !== 'undefined') {
+        this.$active = this.$links.filter('[href="#' + this.$targets.eq(activeIdx).data('magellan-target') + '"]');
+        if (this.$active.length) activeHash = this.$active[0].getAttribute('href');
       } else {
-        var isDown = this.scrollPos < winPos,
-            _this = this,
-            curVisible = this.points.filter(function (p, i) {
-          return isDown ? p - _this.options.offset <= winPos : p - _this.options.offset - _this.options.threshold <= winPos;
-        });
-        curIdx = curVisible.length ? curVisible.length - 1 : 0;
+        this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
       }
 
-      this.$active.removeClass(this.options.activeClass);
-      this.$active = this.$links.filter('[href="#' + this.$targets.eq(curIdx).data('magellan-target') + '"]').addClass(this.options.activeClass);
+      var isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);
+      var isNewHash = activeHash !== window.location.hash; // Update the active link element
 
-      if (this.options.deepLinking) {
-        var hash = "";
-        if (curIdx != undefined) {
-          hash = this.$active[0].getAttribute('href');
-        }
-        if (hash !== window.location.hash) {
-          if (window.history.pushState) {
-            window.history.pushState(null, null, hash);
-          } else {
-            window.location.hash = hash;
-          }
+      if (isNewActive) {
+        $oldActive.removeClass(this.options.activeClass);
+        this.$active.addClass(this.options.activeClass);
+      } // Update the hash (it may have changed with the same active link)
+
+
+      if (this.options.deepLinking && isNewHash) {
+        if (window.history.pushState) {
+          // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384
+          var url = activeHash ? activeHash : window.location.pathname + window.location.search;
+          window.history.pushState(null, null, url);
+        } else {
+          window.location.hash = activeHash;
         }
       }
 
-      this.scrollPos = winPos;
-      /**
-       * Fires when magellan is finished updating to the new active element.
-       * @event Magellan#update
-       */
-      this.$element.trigger('update.zf.magellan', [this.$active]);
+      if (isNewActive) {
+        /**
+         * Fires when magellan is finished updating to the new active element.
+         * @event Magellan#update
+         */
+        this.$element.trigger('update.zf.magellan', [this.$active]);
+      }
     }
-
     /**
      * Destroys an instance of Magellan and resets the url of the window.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
-      this.$element.off('.zf.trigger .zf.magellan').find('.' + this.options.activeClass).removeClass(this.options.activeClass);
+      this.$element.off('.zf.trigger .zf.magellan').find(".".concat(this.options.activeClass)).removeClass(this.options.activeClass);
 
       if (this.options.deepLinking) {
         var hash = this.$active[0].getAttribute('href');
         window.location.hash.replace(hash, '');
       }
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('popstate', this._deepLinkScroll);
+
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._deepLinkScroll);
+      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
     }
   }]);
 
   return Magellan;
-}(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__["Plugin"]);
-
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 /**
  * Default settings for plugin
  */
@@ -389,6 +453,7 @@ Magellan.defaults = {
    * @default 500
    */
   animationDuration: 500,
+
   /**
    * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
    * @option
@@ -397,6 +462,7 @@ Magellan.defaults = {
    * @see {@link https://api.jquery.com/animate|Jquery animate}
    */
   animationEasing: 'linear',
+
   /**
    * Number of pixels to use as a marker for location changes.
    * @option
@@ -404,6 +470,7 @@ Magellan.defaults = {
    * @default 50
    */
   threshold: 50,
+
   /**
    * Class applied to the active locations link on the magellan container.
    * @option
@@ -411,6 +478,7 @@ Magellan.defaults = {
    * @default 'is-active'
    */
   activeClass: 'is-active',
+
   /**
    * Allows the script to manipulate the url of the current page, and if supported, alter the history.
    * @option
@@ -418,6 +486,7 @@ Magellan.defaults = {
    * @default false
    */
   deepLinking: false,
+
   /**
    * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
    * @option
@@ -428,22 +497,31 @@ Magellan.defaults = {
 };
 
 
-
 /***/ }),
 
-/***/ 76:
-/***/ (function(module, exports) {
+/***/ 8:
+/*!*********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.magellan.js ***!
+  \*********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-module.exports = {SmoothScroll: window.Foundation.SmoothScroll};
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.magellan.js */"./js/entries/plugins/foundation.magellan.js");
 
-/***/ }),
 
-/***/ 87:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ }),
 
-module.exports = __webpack_require__(21);
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.magellan.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.magellan.js.map b/dist/js/plugins/foundation.magellan.js.map
new file mode 100644 (file)
index 0000000..95d00a3
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.smoothScroll\"],\"amd\":\"./foundation.smoothScroll\",\"commonjs\":\"./foundation.smoothScroll\",\"commonjs2\":\"./foundation.smoothScroll\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.magellan.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.magellan.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Magellan","element","options","$element","$","extend","defaults","data","className","_init","calcPoints","id","GetYoDigits","_this","$targets","$links","find","attr","$active","scrollPos","parseInt","window","pageYOffset","_events","body","document","html","documentElement","points","winHeight","Math","round","max","innerHeight","clientHeight","docHeight","scrollHeight","offsetHeight","each","$tar","pt","offset","top","threshold","targetPoint","push","$body","opts","duration","animationDuration","easing","animationEasing","one","deepLinking","location","hash","scrollToLoc","_updateActive","onLoadListener","onLoad","on","reflow","bind","e","preventDefault","arrival","getAttribute","_deepLinkScroll","loc","_inTransition","SmoothScroll","newScrollPos","isScrollingUp","activeIdx","length","visibleLinks","filter","p","i","$oldActive","activeHash","eq","isNewActive","is","isNewHash","removeClass","activeClass","addClass","history","pushState","url","pathname","search","trigger","off","replace","Plugin"],"mappings":"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","file":"foundation.magellan.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.smoothScroll\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.smoothScroll\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.magellan\"] = factory(require(\"./foundation.core\"), require(\"./foundation.smoothScroll\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.magellan\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.smoothScroll\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_smoothScroll__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 8);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_smoothScroll__;","import { Foundation } from './foundation.core';\n\nimport { Magellan } from '../../foundation.magellan';\nFoundation.plugin(Magellan, 'Magellan');\n\nexport { Foundation, Magellan };\n","'use strict';\n\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { SmoothScroll } from './foundation.smoothScroll';\n\n/**\n * Magellan module.\n * @module foundation.magellan\n * @requires foundation.smoothScroll\n */\n\nclass Magellan extends Plugin {\n  /**\n   * Creates a new instance of Magellan.\n   * @class\n   * @name Magellan\n   * @fires Magellan#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options  = $.extend({}, Magellan.defaults, this.$element.data(), options);\n    this.className = 'Magellan'; // ie9 back compat\n\n    this._init();\n    this.calcPoints();\n  }\n\n  /**\n   * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.\n   * @private\n   */\n  _init() {\n    var id = this.$element[0].id || GetYoDigits(6, 'magellan');\n    var _this = this;\n    this.$targets = $('[data-magellan-target]');\n    this.$links = this.$element.find('a');\n    this.$element.attr({\n      'data-resize': id,\n      'data-scroll': id,\n      'id': id\n    });\n    this.$active = $();\n    this.scrollPos = parseInt(window.pageYOffset, 10);\n\n    this._events();\n  }\n\n  /**\n   * Calculates an array of pixel values that are the demarcation lines between locations on the page.\n   * Can be invoked if new elements are added or the size of a location changes.\n   * @function\n   */\n  calcPoints() {\n    var _this = this,\n        body = document.body,\n        html = document.documentElement;\n\n    this.points = [];\n    this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));\n    this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));\n\n    this.$targets.each(function(){\n      var $tar = $(this),\n          pt = Math.round($tar.offset().top - _this.options.threshold);\n      $tar.targetPoint = pt;\n      _this.points.push(pt);\n    });\n  }\n\n  /**\n   * Initializes events for Magellan.\n   * @private\n   */\n  _events() {\n    var _this = this,\n        $body = $('html, body'),\n        opts = {\n          duration: _this.options.animationDuration,\n          easing:   _this.options.animationEasing\n        };\n\n    $(window).one('load', function(){\n      if(_this.options.deepLinking){\n        if(location.hash){\n          _this.scrollToLoc(location.hash);\n        }\n      }\n      _this.calcPoints();\n      _this._updateActive();\n    });\n\n    _this.onLoadListener = onLoad($(window), function () {\n      _this.$element\n        .on({\n          'resizeme.zf.trigger': _this.reflow.bind(_this),\n          'scrollme.zf.trigger': _this._updateActive.bind(_this)\n        })\n        .on('click.zf.magellan', 'a[href^=\"#\"]', function (e) {\n          e.preventDefault();\n          var arrival   = this.getAttribute('href');\n          _this.scrollToLoc(arrival);\n        });\n    });\n\n    this._deepLinkScroll = function(e) {\n      if(_this.options.deepLinking) {\n        _this.scrollToLoc(window.location.hash);\n      }\n    };\n\n    $(window).on('hashchange', this._deepLinkScroll);\n  }\n\n  /**\n   * Function to scroll to a given location on the page.\n   * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'\n   * @function\n   */\n  scrollToLoc(loc) {\n    this._inTransition = true;\n    var _this = this;\n\n    var options = {\n      animationEasing: this.options.animationEasing,\n      animationDuration: this.options.animationDuration,\n      threshold: this.options.threshold,\n      offset: this.options.offset\n    };\n\n    SmoothScroll.scrollToLoc(loc, options, function() {\n      _this._inTransition = false;\n    })\n  }\n\n  /**\n   * Calls necessary functions to update Magellan upon DOM change\n   * @function\n   */\n  reflow() {\n    this.calcPoints();\n    this._updateActive();\n  }\n\n  /**\n   * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.\n   * @private\n   * @function\n   * @fires Magellan#update\n   */\n  _updateActive(/*evt, elem, scrollPos*/) {\n    if(this._inTransition) return;\n\n    const newScrollPos = parseInt(window.pageYOffset, 10);\n    const isScrollingUp = this.scrollPos > newScrollPos;\n    this.scrollPos = newScrollPos;\n\n    let activeIdx;\n    // Before the first point: no link\n    if(newScrollPos < this.points[0]){ /* do nothing */ }\n    // At the bottom of the page: last link\n    else if(newScrollPos + this.winHeight === this.docHeight){ activeIdx = this.points.length - 1; }\n    // Otherwhise, use the last visible link\n    else{\n      const visibleLinks = this.points.filter((p, i) => {\n        return (p - this.options.offset - (isScrollingUp ? this.options.threshold : 0)) <= newScrollPos;\n      });\n      activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;\n    }\n\n    // Get the new active link\n    const $oldActive = this.$active;\n    let activeHash = '';\n    if(typeof activeIdx !== 'undefined'){\n      this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(activeIdx).data('magellan-target') + '\"]');\n      if (this.$active.length) activeHash = this.$active[0].getAttribute('href');\n    }else{\n      this.$active = $();\n    }\n    const isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);\n    const isNewHash = activeHash !== window.location.hash;\n\n    // Update the active link element\n    if(isNewActive) {\n      $oldActive.removeClass(this.options.activeClass);\n      this.$active.addClass(this.options.activeClass);\n    }\n\n    // Update the hash (it may have changed with the same active link)\n    if(this.options.deepLinking && isNewHash){\n      if(window.history.pushState){\n        // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384\n        const url = activeHash ? activeHash : window.location.pathname + window.location.search;\n        window.history.pushState(null, null, url);\n      }else{\n        window.location.hash = activeHash;\n      }\n    }\n\n    if (isNewActive) {\n      /**\n       * Fires when magellan is finished updating to the new active element.\n       * @event Magellan#update\n       */\n    \tthis.$element.trigger('update.zf.magellan', [this.$active]);\n\t  }\n  }\n\n  /**\n   * Destroys an instance of Magellan and resets the url of the window.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.trigger .zf.magellan')\n        .find(`.${this.options.activeClass}`).removeClass(this.options.activeClass);\n\n    if(this.options.deepLinking){\n      var hash = this.$active[0].getAttribute('href');\n      window.location.hash.replace(hash, '');\n    }\n\n    $(window).off('hashchange', this._deepLinkScroll)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\n/**\n * Default settings for plugin\n */\nMagellan.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Class applied to the active locations link on the magellan container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  activeClass: 'is-active',\n  /**\n   * Allows the script to manipulate the url of the current page, and if supported, alter the history.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinking: false,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {Magellan};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index a519cbc0ac4706ebd8f0b83bcb07954366802892..2c927d0c5d7447c54df73fad94dcf28b4a50390a 100644 (file)
@@ -1 +1,2 @@
-!function(t){function i(e){if(n[e])return n[e].exports;var o=n[e]={i:e,l:!1,exports:{}};return t[e].call(o.exports,o,o.exports,i),o.l=!0,o.exports}var n={};i.m=t,i.c=n,i.i=function(t){return t},i.d=function(t,n,e){i.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:e})},i.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return i.d(n,"a",n),n},i.o=function(t,i){return Object.prototype.hasOwnProperty.call(t,i)},i.p="",i(i.s=87)}({0:function(t,i){t.exports=jQuery},1:function(t,i){t.exports={Foundation:window.Foundation}},2:function(t,i){t.exports={Plugin:window.Foundation.Plugin}},21:function(t,i,n){"use strict";Object.defineProperty(i,"__esModule",{value:!0});var e=n(1),o=(n.n(e),n(51));e.Foundation.plugin(o.a,"Magellan")},3:function(t,i){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},51:function(t,i,n){"use strict";function e(t,i){if(!(t instanceof i))throw new TypeError("Cannot call a class as a function")}function o(t,i){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!i||"object"!=typeof i&&"function"!=typeof i?t:i}function s(t,i){if("function"!=typeof i&&null!==i)throw new TypeError("Super expression must either be null or a function, not "+typeof i);t.prototype=Object.create(i&&i.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),i&&(Object.setPrototypeOf?Object.setPrototypeOf(t,i):t.__proto__=i)}n.d(i,"a",function(){return f});var a=n(0),r=n.n(a),l=n(3),c=(n.n(l),n(2)),h=(n.n(c),n(76)),u=(n.n(h),function(){function t(t,i){for(var n=0;n<i.length;n++){var e=i[n];e.enumerable=e.enumerable||!1,e.configurable=!0,"value"in e&&(e.writable=!0),Object.defineProperty(t,e.key,e)}}return function(i,n,e){return n&&t(i.prototype,n),e&&t(i,e),i}}()),f=function(t){function i(){return e(this,i),o(this,(i.__proto__||Object.getPrototypeOf(i)).apply(this,arguments))}return s(i,t),u(i,[{key:"_setup",value:function(t,n){this.$element=t,this.options=r.a.extend({},i.defaults,this.$element.data(),n),this.className="Magellan",this._init(),this.calcPoints()}},{key:"_init",value:function(){var t=this.$element[0].id||n.i(l.GetYoDigits)(6,"magellan");this.$targets=r()("[data-magellan-target]"),this.$links=this.$element.find("a"),this.$element.attr({"data-resize":t,"data-scroll":t,id:t}),this.$active=r()(),this.scrollPos=parseInt(window.pageYOffset,10),this._events()}},{key:"calcPoints",value:function(){var t=this,i=document.body,n=document.documentElement;this.points=[],this.winHeight=Math.round(Math.max(window.innerHeight,n.clientHeight)),this.docHeight=Math.round(Math.max(i.scrollHeight,i.offsetHeight,n.clientHeight,n.scrollHeight,n.offsetHeight)),this.$targets.each(function(){var i=r()(this),n=Math.round(i.offset().top-t.options.threshold);i.targetPoint=n,t.points.push(n)})}},{key:"_events",value:function(){var t=this;r()("html, body"),t.options.animationDuration,t.options.animationEasing;r()(window).one("load",function(){t.options.deepLinking&&location.hash&&t.scrollToLoc(location.hash),t.calcPoints(),t._updateActive()}),this.$element.on({"resizeme.zf.trigger":this.reflow.bind(this),"scrollme.zf.trigger":this._updateActive.bind(this)}).on("click.zf.magellan",'a[href^="#"]',function(i){i.preventDefault();var n=this.getAttribute("href");t.scrollToLoc(n)}),this._deepLinkScroll=function(i){t.options.deepLinking&&t.scrollToLoc(window.location.hash)},r()(window).on("popstate",this._deepLinkScroll)}},{key:"scrollToLoc",value:function(t){this._inTransition=!0;var i=this,n={animationEasing:this.options.animationEasing,animationDuration:this.options.animationDuration,threshold:this.options.threshold,offset:this.options.offset};h.SmoothScroll.scrollToLoc(t,n,function(){i._inTransition=!1,i._updateActive()})}},{key:"reflow",value:function(){this.calcPoints(),this._updateActive()}},{key:"_updateActive",value:function(){if(!this._inTransition){var t,i=parseInt(window.pageYOffset,10);if(i+this.winHeight===this.docHeight)t=this.points.length-1;else if(i<this.points[0])t=void 0;else{var n=this.scrollPos<i,e=this,o=this.points.filter(function(t,o){return n?t-e.options.offset<=i:t-e.options.offset-e.options.threshold<=i});t=o.length?o.length-1:0}if(this.$active.removeClass(this.options.activeClass),this.$active=this.$links.filter('[href="#'+this.$targets.eq(t).data("magellan-target")+'"]').addClass(this.options.activeClass),this.options.deepLinking){var s="";void 0!=t&&(s=this.$active[0].getAttribute("href")),s!==window.location.hash&&(window.history.pushState?window.history.pushState(null,null,s):window.location.hash=s)}this.scrollPos=i,this.$element.trigger("update.zf.magellan",[this.$active])}}},{key:"_destroy",value:function(){if(this.$element.off(".zf.trigger .zf.magellan").find("."+this.options.activeClass).removeClass(this.options.activeClass),this.options.deepLinking){var t=this.$active[0].getAttribute("href");window.location.hash.replace(t,"")}r()(window).off("popstate",this._deepLinkScroll)}}]),i}(c.Plugin);f.defaults={animationDuration:500,animationEasing:"linear",threshold:50,activeClass:"is-active",deepLinking:!1,offset:0}},76:function(t,i){t.exports={SmoothScroll:window.Foundation.SmoothScroll}},87:function(t,i,n){t.exports=n(21)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("./foundation.smoothScroll"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.smoothScroll","jquery"],e):"object"==typeof exports?exports["foundation.magellan"]=e(require("./foundation.core"),require("./foundation.smoothScroll"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.magellan"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.smoothScroll"],t.jQuery))}(window,function(n,o,i){return function(n){var o={};function i(t){if(o[t])return o[t].exports;var e=o[t]={i:t,l:!1,exports:{}};return n[t].call(e.exports,e,e.exports,i),e.l=!0,e.exports}return i.m=n,i.c=o,i.d=function(t,e,n){i.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},i.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},i.t=function(e,t){if(1&t&&(e=i(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)i.d(n,o,function(t){return e[t]}.bind(null,o));return n},i.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return i.d(e,"a",e),e},i.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},i.p="",i(i.s=8)}({"./foundation.core":function(t,e){t.exports=n},"./foundation.smoothScroll":function(t,e){t.exports=o},"./js/entries/plugins/foundation.magellan.js":function(t,e,n){"use strict";n.r(e);var o=n("./foundation.core");n.d(e,"Foundation",function(){return o.Foundation});var i=n("./js/foundation.magellan.js");n.d(e,"Magellan",function(){return i.Magellan}),o.Foundation.plugin(i.Magellan,"Magellan")},"./js/foundation.magellan.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Magellan",function(){return h});var o=n("jquery"),c=n.n(o),r=n("./foundation.core"),a=n("./foundation.smoothScroll");function i(t){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function s(t,e){for(var n=0;n<e.length;n++){var o=e[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}function l(t,e){return!e||"object"!==i(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function u(t){return(u=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function f(t,e){return(f=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var h=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),l(this,u(n).apply(this,arguments))}var e,o,i;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&f(t,e)}(n,r["Plugin"]),e=n,(o=[{key:"_setup",value:function(t,e){this.$element=t,this.options=c.a.extend({},n.defaults,this.$element.data(),e),this.className="Magellan",this._init(),this.calcPoints()}},{key:"_init",value:function(){var t=this.$element[0].id||Object(r.GetYoDigits)(6,"magellan");this.$targets=c()("[data-magellan-target]"),this.$links=this.$element.find("a"),this.$element.attr({"data-resize":t,"data-scroll":t,id:t}),this.$active=c()(),this.scrollPos=parseInt(window.pageYOffset,10),this._events()}},{key:"calcPoints",value:function(){var n=this,t=document.body,e=document.documentElement;this.points=[],this.winHeight=Math.round(Math.max(window.innerHeight,e.clientHeight)),this.docHeight=Math.round(Math.max(t.scrollHeight,t.offsetHeight,e.clientHeight,e.scrollHeight,e.offsetHeight)),this.$targets.each(function(){var t=c()(this),e=Math.round(t.offset().top-n.options.threshold);t.targetPoint=e,n.points.push(e)})}},{key:"_events",value:function(){var n=this;c()("html, body"),n.options.animationDuration,n.options.animationEasing;c()(window).one("load",function(){n.options.deepLinking&&location.hash&&n.scrollToLoc(location.hash),n.calcPoints(),n._updateActive()}),n.onLoadListener=Object(r.onLoad)(c()(window),function(){n.$element.on({"resizeme.zf.trigger":n.reflow.bind(n),"scrollme.zf.trigger":n._updateActive.bind(n)}).on("click.zf.magellan",'a[href^="#"]',function(t){t.preventDefault();var e=this.getAttribute("href");n.scrollToLoc(e)})}),this._deepLinkScroll=function(t){n.options.deepLinking&&n.scrollToLoc(window.location.hash)},c()(window).on("hashchange",this._deepLinkScroll)}},{key:"scrollToLoc",value:function(t){this._inTransition=!0;var e=this,n={animationEasing:this.options.animationEasing,animationDuration:this.options.animationDuration,threshold:this.options.threshold,offset:this.options.offset};a.SmoothScroll.scrollToLoc(t,n,function(){e._inTransition=!1})}},{key:"reflow",value:function(){this.calcPoints(),this._updateActive()}},{key:"_updateActive",value:function(){var n=this;if(!this._inTransition){var t,o=parseInt(window.pageYOffset,10),i=this.scrollPos>o;if((this.scrollPos=o)<this.points[0]);else if(o+this.winHeight===this.docHeight)t=this.points.length-1;else{var e=this.points.filter(function(t,e){return t-n.options.offset-(i?n.options.threshold:0)<=o});t=e.length?e.length-1:0}var r=this.$active,a="";void 0!==t?(this.$active=this.$links.filter('[href="#'+this.$targets.eq(t).data("magellan-target")+'"]'),this.$active.length&&(a=this.$active[0].getAttribute("href"))):this.$active=c()();var s=!(!this.$active.length&&!r.length||this.$active.is(r)),l=a!==window.location.hash;if(s&&(r.removeClass(this.options.activeClass),this.$active.addClass(this.options.activeClass)),this.options.deepLinking&&l)if(window.history.pushState){var u=a||window.location.pathname+window.location.search;window.history.pushState(null,null,u)}else window.location.hash=a;s&&this.$element.trigger("update.zf.magellan",[this.$active])}}},{key:"_destroy",value:function(){if(this.$element.off(".zf.trigger .zf.magellan").find(".".concat(this.options.activeClass)).removeClass(this.options.activeClass),this.options.deepLinking){var t=this.$active[0].getAttribute("href");window.location.hash.replace(t,"")}c()(window).off("hashchange",this._deepLinkScroll),this.onLoadListener&&c()(window).off(this.onLoadListener)}}])&&s(e.prototype,o),i&&s(e,i),n}();h.defaults={animationDuration:500,animationEasing:"linear",threshold:50,activeClass:"is-active",deepLinking:!1,offset:0}},8:function(t,e,n){t.exports=n("./js/entries/plugins/foundation.magellan.js")},jquery:function(t,e){t.exports=i}})});
+//# sourceMappingURL=foundation.magellan.min.js.map
diff --git a/dist/js/plugins/foundation.magellan.min.js.map b/dist/js/plugins/foundation.magellan.min.js.map
new file mode 100644 (file)
index 0000000..053799d
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.magellan.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_smoothScroll__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.smoothScroll","./js/entries/plugins/foundation.magellan.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_magellan__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.magellan.js","Magellan","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","calcPoints","id","$targets","$links","find","attr","data-resize","data-scroll","$active","scrollPos","parseInt","pageYOffset","_events","_this","body","document","html","documentElement","points","winHeight","Math","round","max","innerHeight","clientHeight","docHeight","scrollHeight","offsetHeight","each","$tar","pt","offset","top","threshold","targetPoint","push","animationDuration","animationEasing","one","deepLinking","location","hash","scrollToLoc","_updateActive","onLoadListener","on","resizeme.zf.trigger","reflow","scrollme.zf.trigger","e","preventDefault","arrival","getAttribute","_deepLinkScroll","loc","_inTransition","_this2","activeIdx","newScrollPos","isScrollingUp","visibleLinks","filter","$oldActive","activeHash","eq","isNewActive","is","isNewHash","removeClass","activeClass","addClass","history","pushState","url","pathname","search","trigger","off","concat","replace","8","jquery"],"mappings":"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","file":"foundation.magellan.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.smoothScroll\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.smoothScroll\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.magellan\"] = factory(require(\"./foundation.core\"), require(\"./foundation.smoothScroll\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.magellan\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.smoothScroll\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_smoothScroll__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 8);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.smoothScroll\":\n/*!************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.smoothScroll\"],\"amd\":\"./foundation.smoothScroll\",\"commonjs\":\"./foundation.smoothScroll\",\"commonjs2\":\"./foundation.smoothScroll\"} ***!\n  \\************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_smoothScroll__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.magellan.js\":\n/*!***************************************************!*\\\n  !*** ./js/entries/plugins/foundation.magellan.js ***!\n  \\***************************************************/\n/*! exports provided: Foundation, Magellan */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_magellan__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.magellan */ \"./js/foundation.magellan.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Magellan\", function() { return _foundation_magellan__WEBPACK_IMPORTED_MODULE_1__[\"Magellan\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_magellan__WEBPACK_IMPORTED_MODULE_1__[\"Magellan\"], 'Magellan');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.magellan.js\":\n/*!***********************************!*\\\n  !*** ./js/foundation.magellan.js ***!\n  \\***********************************/\n/*! exports provided: Magellan */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Magellan\", function() { return Magellan; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.smoothScroll */ \"./foundation.smoothScroll\");\n/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n/**\n * Magellan module.\n * @module foundation.magellan\n * @requires foundation.smoothScroll\n */\n\nvar Magellan =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Magellan, _Plugin);\n\n  function Magellan() {\n    _classCallCheck(this, Magellan);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Magellan).apply(this, arguments));\n  }\n\n  _createClass(Magellan, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Magellan.\n     * @class\n     * @name Magellan\n     * @fires Magellan#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Magellan.defaults, this.$element.data(), options);\n      this.className = 'Magellan'; // ie9 back compat\n\n      this._init();\n\n      this.calcPoints();\n    }\n    /**\n     * Initializes the Magellan plugin and calls functions to get equalizer functioning on load.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'magellan');\n\n      var _this = this;\n\n      this.$targets = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-magellan-target]');\n      this.$links = this.$element.find('a');\n      this.$element.attr({\n        'data-resize': id,\n        'data-scroll': id,\n        'id': id\n      });\n      this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      this.scrollPos = parseInt(window.pageYOffset, 10);\n\n      this._events();\n    }\n    /**\n     * Calculates an array of pixel values that are the demarcation lines between locations on the page.\n     * Can be invoked if new elements are added or the size of a location changes.\n     * @function\n     */\n\n  }, {\n    key: \"calcPoints\",\n    value: function calcPoints() {\n      var _this = this,\n          body = document.body,\n          html = document.documentElement;\n\n      this.points = [];\n      this.winHeight = Math.round(Math.max(window.innerHeight, html.clientHeight));\n      this.docHeight = Math.round(Math.max(body.scrollHeight, body.offsetHeight, html.clientHeight, html.scrollHeight, html.offsetHeight));\n      this.$targets.each(function () {\n        var $tar = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            pt = Math.round($tar.offset().top - _this.options.threshold);\n        $tar.targetPoint = pt;\n\n        _this.points.push(pt);\n      });\n    }\n    /**\n     * Initializes events for Magellan.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this,\n          $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body'),\n          opts = {\n        duration: _this.options.animationDuration,\n        easing: _this.options.animationEasing\n      };\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).one('load', function () {\n        if (_this.options.deepLinking) {\n          if (location.hash) {\n            _this.scrollToLoc(location.hash);\n          }\n        }\n\n        _this.calcPoints();\n\n        _this._updateActive();\n      });\n      _this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n        _this.$element.on({\n          'resizeme.zf.trigger': _this.reflow.bind(_this),\n          'scrollme.zf.trigger': _this._updateActive.bind(_this)\n        }).on('click.zf.magellan', 'a[href^=\"#\"]', function (e) {\n          e.preventDefault();\n          var arrival = this.getAttribute('href');\n\n          _this.scrollToLoc(arrival);\n        });\n      });\n\n      this._deepLinkScroll = function (e) {\n        if (_this.options.deepLinking) {\n          _this.scrollToLoc(window.location.hash);\n        }\n      };\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._deepLinkScroll);\n    }\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - a properly formatted jQuery id selector. Example: '#foo'\n     * @function\n     */\n\n  }, {\n    key: \"scrollToLoc\",\n    value: function scrollToLoc(loc) {\n      this._inTransition = true;\n\n      var _this = this;\n\n      var options = {\n        animationEasing: this.options.animationEasing,\n        animationDuration: this.options.animationDuration,\n        threshold: this.options.threshold,\n        offset: this.options.offset\n      };\n      _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_2__[\"SmoothScroll\"].scrollToLoc(loc, options, function () {\n        _this._inTransition = false;\n      });\n    }\n    /**\n     * Calls necessary functions to update Magellan upon DOM change\n     * @function\n     */\n\n  }, {\n    key: \"reflow\",\n    value: function reflow() {\n      this.calcPoints();\n\n      this._updateActive();\n    }\n    /**\n     * Updates the visibility of an active location link, and updates the url hash for the page, if deepLinking enabled.\n     * @private\n     * @function\n     * @fires Magellan#update\n     */\n\n  }, {\n    key: \"_updateActive\",\n    value: function _updateActive()\n    /*evt, elem, scrollPos*/\n    {\n      var _this2 = this;\n\n      if (this._inTransition) return;\n      var newScrollPos = parseInt(window.pageYOffset, 10);\n      var isScrollingUp = this.scrollPos > newScrollPos;\n      this.scrollPos = newScrollPos;\n      var activeIdx; // Before the first point: no link\n\n      if (newScrollPos < this.points[0]) {}\n      /* do nothing */\n      // At the bottom of the page: last link\n      else if (newScrollPos + this.winHeight === this.docHeight) {\n          activeIdx = this.points.length - 1;\n        } // Otherwhise, use the last visible link\n        else {\n            var visibleLinks = this.points.filter(function (p, i) {\n              return p - _this2.options.offset - (isScrollingUp ? _this2.options.threshold : 0) <= newScrollPos;\n            });\n            activeIdx = visibleLinks.length ? visibleLinks.length - 1 : 0;\n          } // Get the new active link\n\n\n      var $oldActive = this.$active;\n      var activeHash = '';\n\n      if (typeof activeIdx !== 'undefined') {\n        this.$active = this.$links.filter('[href=\"#' + this.$targets.eq(activeIdx).data('magellan-target') + '\"]');\n        if (this.$active.length) activeHash = this.$active[0].getAttribute('href');\n      } else {\n        this.$active = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      }\n\n      var isNewActive = !(!this.$active.length && !$oldActive.length) && !this.$active.is($oldActive);\n      var isNewHash = activeHash !== window.location.hash; // Update the active link element\n\n      if (isNewActive) {\n        $oldActive.removeClass(this.options.activeClass);\n        this.$active.addClass(this.options.activeClass);\n      } // Update the hash (it may have changed with the same active link)\n\n\n      if (this.options.deepLinking && isNewHash) {\n        if (window.history.pushState) {\n          // Set or remove the hash (see: https://stackoverflow.com/a/5298684/4317384\n          var url = activeHash ? activeHash : window.location.pathname + window.location.search;\n          window.history.pushState(null, null, url);\n        } else {\n          window.location.hash = activeHash;\n        }\n      }\n\n      if (isNewActive) {\n        /**\n         * Fires when magellan is finished updating to the new active element.\n         * @event Magellan#update\n         */\n        this.$element.trigger('update.zf.magellan', [this.$active]);\n      }\n    }\n    /**\n     * Destroys an instance of Magellan and resets the url of the window.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.trigger .zf.magellan').find(\".\".concat(this.options.activeClass)).removeClass(this.options.activeClass);\n\n      if (this.options.deepLinking) {\n        var hash = this.$active[0].getAttribute('href');\n        window.location.hash.replace(hash, '');\n      }\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._deepLinkScroll);\n      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n    }\n  }]);\n\n  return Magellan;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n/**\n * Default settings for plugin\n */\n\n\nMagellan.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n\n  /**\n   * Class applied to the active locations link on the magellan container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  activeClass: 'is-active',\n\n  /**\n   * Allows the script to manipulate the url of the current page, and if supported, alter the history.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinking: false,\n\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n};\n\n\n/***/ }),\n\n/***/ 8:\n/*!*********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.magellan.js ***!\n  \\*********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.magellan.js */\"./js/entries/plugins/foundation.magellan.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.magellan.js.map"]}
\ No newline at end of file
index da5d31ad1485610232bd1d5f14773ef76da2c4f4..f95bdc2eea53b6bf51e799ad623bcf9bb9eb3ce5 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.keyboard", "./foundation.util.mediaQuery", "./foundation.util.motion", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.offcanvas"] = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.offcanvas"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 88);
+/******/       return __webpack_require__(__webpack_require__.s = 9);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
 
 /***/ }),
 
-/***/ 22:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
-
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_offcanvas__ = __webpack_require__(52);
-
-
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_offcanvas__["a" /* OffCanvas */], 'OffCanvas');
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
 /***/ }),
 
-/***/ 3:
-/***/ (function(module, exports) {
-
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
+/***/ "./js/entries/plugins/foundation.offcanvas.js":
+/*!****************************************************!*\
+  !*** ./js/entries/plugins/foundation.offcanvas.js ***!
+  \****************************************************/
+/*! exports provided: Foundation, OffCanvas */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-/***/ }),
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-/***/ 4:
-/***/ (function(module, exports) {
+/* harmony import */ var _foundation_offcanvas__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.offcanvas */ "./js/foundation.offcanvas.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "OffCanvas", function() { return _foundation_offcanvas__WEBPACK_IMPORTED_MODULE_1__["OffCanvas"]; });
 
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
 
-/***/ }),
 
-/***/ 5:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_offcanvas__WEBPACK_IMPORTED_MODULE_1__["OffCanvas"], 'OffCanvas');
 
-module.exports = {Keyboard: window.Foundation.Keyboard};
 
 /***/ }),
 
-/***/ 52:
+/***/ "./js/foundation.offcanvas.js":
+/*!************************************!*\
+  !*** ./js/foundation.offcanvas.js ***!
+  \************************************/
+/*! exports provided: OffCanvas */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return OffCanvas; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_triggers__ = __webpack_require__(7);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "OffCanvas", function() { return OffCanvas; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__);
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-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 _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -167,17 +216,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.triggers
  */
 
-var OffCanvas = function (_Plugin) {
+var OffCanvas =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(OffCanvas, _Plugin);
 
   function OffCanvas() {
     _classCallCheck(this, OffCanvas);
 
-    return _possibleConstructorReturn(this, (OffCanvas.__proto__ || Object.getPrototypeOf(OffCanvas)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(OffCanvas).apply(this, arguments));
   }
 
   _createClass(OffCanvas, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of an off-canvas wrapper.
@@ -188,39 +239,43 @@ var OffCanvas = function (_Plugin) {
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
-      var _this3 = this;
+      var _this2 = this;
 
       this.className = 'OffCanvas'; // ie9 back compat
+
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, OffCanvas.defaults, this.$element.data(), options);
-      this.contentClasses = { base: [], reveal: [] };
-      this.$lastTrigger = __WEBPACK_IMPORTED_MODULE_0_jquery___default()();
-      this.$triggers = __WEBPACK_IMPORTED_MODULE_0_jquery___default()();
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, OffCanvas.defaults, this.$element.data(), options);
+      this.contentClasses = {
+        base: [],
+        reveal: []
+      };
+      this.$lastTrigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
+      this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
       this.position = 'left';
-      this.$content = __WEBPACK_IMPORTED_MODULE_0_jquery___default()();
-      this.nested = !!this.options.nested;
+      this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()();
+      this.nested = !!this.options.nested; // Defines the CSS transition/position classes of the off-canvas content container.
 
-      // Defines the CSS transition/position classes of the off-canvas content container.
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(['push', 'overlap']).each(function (index, val) {
-        _this3.contentClasses.base.push('has-transition-' + val);
-      });
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(['left', 'right', 'top', 'bottom']).each(function (index, val) {
-        _this3.contentClasses.base.push('has-position-' + val);
-        _this3.contentClasses.reveal.push('has-reveal-' + val);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(['push', 'overlap']).each(function (index, val) {
+        _this2.contentClasses.base.push('has-transition-' + val);
       });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(['left', 'right', 'top', 'bottom']).each(function (index, val) {
+        _this2.contentClasses.base.push('has-position-' + val);
 
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_5__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"]._init();
+        _this2.contentClasses.reveal.push('has-reveal-' + val);
+      }); // Triggers init is idempotent, just need to make sure it is initialized
+
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"]._init();
 
       this._init();
+
       this._events();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('OffCanvas', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('OffCanvas', {
         'ESCAPE': 'close'
       });
     }
-
     /**
      * Initializes the off-canvas wrapper by adding the exit overlay (if needed).
      * @function
@@ -228,15 +283,13 @@ var OffCanvas = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
       var id = this.$element.attr('id');
+      this.$element.attr('aria-hidden', 'true'); // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)
 
-      this.$element.attr('aria-hidden', 'true');
-
-      // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)
       if (this.options.contentId) {
-        this.$content = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + this.options.contentId);
+        this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + this.options.contentId);
       } else if (this.$element.siblings('[data-off-canvas-content]').length) {
         this.$content = this.$element.siblings('[data-off-canvas-content]').first();
       } else {
@@ -254,47 +307,53 @@ var OffCanvas = function (_Plugin) {
 
       if (this.nested === true) {
         // Force transition overlap if nested
-        this.options.transition = 'overlap';
-        // Remove appropriate classes if already assigned in markup
+        this.options.transition = 'overlap'; // Remove appropriate classes if already assigned in markup
+
         this.$element.removeClass('is-transition-push');
       }
 
-      this.$element.addClass('is-transition-' + this.options.transition + ' is-closed');
+      this.$element.addClass("is-transition-".concat(this.options.transition, " is-closed")); // Find triggers that affect this element and add aria-expanded to them
 
-      // Find triggers that affect this element and add aria-expanded to them
-      this.$triggers = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id);
+      this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).find('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-expanded', 'false').attr('aria-controls', id); // Get position by checking for related CSS class
 
-      // Get position by checking for related CSS class
-      this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position;
+      this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\-(left|top|right|bottom)/)[1] : this.position; // Add an overlay over the content if necessary
 
-      // Add an overlay over the content if necessary
       if (this.options.contentOverlay === true) {
         var overlay = document.createElement('div');
-        var overlayPosition = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';
+        var overlayPosition = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$element).css("position") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';
         overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);
-        this.$overlay = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(overlay);
+        this.$overlay = jquery__WEBPACK_IMPORTED_MODULE_0___default()(overlay);
+
         if (overlayPosition === 'is-overlay-fixed') {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.$overlay).insertAfter(this.$element);
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$overlay).insertAfter(this.$element);
         } else {
           this.$content.append(this.$overlay);
         }
-      }
+      } // Get the revealOn option from the class.
+
 
-      this.options.isRevealed = this.options.isRevealed || new RegExp(this.options.revealClass, 'g').test(this.$element[0].className);
+      var revealOnRegExp = new RegExp(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["RegExpEscape"])(this.options.revealClass) + '([^\\s]+)', 'g');
+      var revealOnClass = revealOnRegExp.exec(this.$element[0].className);
+
+      if (revealOnClass) {
+        this.options.isRevealed = true;
+        this.options.revealOn = this.options.revealOn || revealOnClass[1];
+      } // Ensure the `reveal-on-*` class is set.
+
+
+      if (this.options.isRevealed === true && this.options.revealOn) {
+        this.$element.first().addClass("".concat(this.options.revealClass).concat(this.options.revealOn));
 
-      if (this.options.isRevealed === true) {
-        this.options.revealOn = this.options.revealOn || this.$element[0].className.match(/(reveal-for-medium|reveal-for-large)/g)[0].split('-')[2];
         this._setMQChecker();
       }
 
       if (this.options.transitionTime) {
         this.$element.css('transition-duration', this.options.transitionTime);
-      }
+      } // Initally remove all transition/position CSS classes from off-canvas content container.
+
 
-      // Initally remove all transition/position CSS classes from off-canvas content container.
       this._removeContentClasses();
     }
-
     /**
      * Adds event handlers to the off-canvas wrapper and the exit overlay.
      * @function
@@ -302,7 +361,7 @@ var OffCanvas = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       this.$element.off('.zf.trigger .zf.offcanvas').on({
         'open.zf.trigger': this.open.bind(this),
@@ -313,33 +372,34 @@ var OffCanvas = function (_Plugin) {
 
       if (this.options.closeOnClick === true) {
         var $target = this.options.contentOverlay ? this.$overlay : this.$content;
-        $target.on({ 'click.zf.offcanvas': this.close.bind(this) });
+        $target.on({
+          'click.zf.offcanvas': this.close.bind(this)
+        });
       }
     }
-
     /**
      * Applies event listener for elements that will reveal at certain breakpoints.
      * @private
      */
 
   }, {
-    key: '_setMQChecker',
+    key: "_setMQChecker",
     value: function _setMQChecker() {
       var _this = this;
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', function () {
-        if (__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"].atLeast(_this.options.revealOn)) {
+      this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"].atLeast(_this.options.revealOn)) {
           _this.reveal(true);
-        } else {
-          _this.reveal(false);
         }
-      }).one('load.zf.offcanvas', function () {
-        if (__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"].atLeast(_this.options.revealOn)) {
+      });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"].atLeast(_this.options.revealOn)) {
           _this.reveal(true);
+        } else {
+          _this.reveal(false);
         }
       });
     }
-
     /**
      * Removes the CSS transition/position classes of the off-canvas content container.
      * Removing the classes is important when another off-canvas gets opened that uses the same content container.
@@ -348,15 +408,14 @@ var OffCanvas = function (_Plugin) {
      */
 
   }, {
-    key: '_removeContentClasses',
+    key: "_removeContentClasses",
     value: function _removeContentClasses(hasReveal) {
       if (typeof hasReveal !== 'boolean') {
         this.$content.removeClass(this.contentClasses.base.join(' '));
       } else if (hasReveal === false) {
-        this.$content.removeClass('has-reveal-' + this.position);
+        this.$content.removeClass("has-reveal-".concat(this.position));
       }
     }
-
     /**
      * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.
      * Beforehand any transition/position class gets removed.
@@ -365,16 +424,16 @@ var OffCanvas = function (_Plugin) {
      */
 
   }, {
-    key: '_addContentClasses',
+    key: "_addContentClasses",
     value: function _addContentClasses(hasReveal) {
       this._removeContentClasses(hasReveal);
+
       if (typeof hasReveal !== 'boolean') {
-        this.$content.addClass('has-transition-' + this.options.transition + ' has-position-' + this.position);
+        this.$content.addClass("has-transition-".concat(this.options.transition, " has-position-").concat(this.position));
       } else if (hasReveal === true) {
-        this.$content.addClass('has-reveal-' + this.position);
+        this.$content.addClass("has-reveal-".concat(this.position));
       }
     }
-
     /**
      * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.
      * @param {Boolean} isRevealed - true if element should be revealed.
@@ -382,7 +441,7 @@ var OffCanvas = function (_Plugin) {
      */
 
   }, {
-    key: 'reveal',
+    key: "reveal",
     value: function reveal(isRevealed) {
       if (isRevealed) {
         this.close();
@@ -399,47 +458,48 @@ var OffCanvas = function (_Plugin) {
         });
         this.$element.addClass('is-closed');
       }
+
       this._addContentClasses(isRevealed);
     }
-
     /**
      * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.
      * @private
      */
 
   }, {
-    key: '_stopScrolling',
+    key: "_stopScrolling",
     value: function _stopScrolling(event) {
       return false;
-    }
-
-    // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios
+    } // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios
     // Only really works for y, not sure how to extend to x or if we need to.
 
   }, {
-    key: '_recordScrollable',
+    key: "_recordScrollable",
     value: function _recordScrollable(event) {
       var elem = this; // called from event handler context with this as elem
-
       // If the element is scrollable (content overflows), then...
+
       if (elem.scrollHeight !== elem.clientHeight) {
         // If we're at the top, scroll down one pixel to allow scrolling up
         if (elem.scrollTop === 0) {
           elem.scrollTop = 1;
-        }
-        // If we're at the bottom, scroll up one pixel to allow scrolling down
+        } // If we're at the bottom, scroll up one pixel to allow scrolling down
+
+
         if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {
           elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;
         }
       }
+
       elem.allowUp = elem.scrollTop > 0;
       elem.allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight;
       elem.lastY = event.originalEvent.pageY;
     }
   }, {
-    key: '_stopScrollPropagation',
+    key: "_stopScrollPropagation",
     value: function _stopScrollPropagation(event) {
       var elem = this; // called from event handler context with this as elem
+
       var up = event.pageY < elem.lastY;
       var down = !up;
       elem.lastY = event.pageY;
@@ -450,21 +510,22 @@ var OffCanvas = function (_Plugin) {
         event.preventDefault();
       }
     }
-
     /**
      * Opens the off-canvas menu.
      * @function
      * @param {Object} event - Event object passed from listener.
      * @param {jQuery} trigger - element that triggered the off-canvas to open.
-     * @fires OffCanvas#opened
+     * @fires Offcanvas#opened
+     * @todo also trigger 'open' event?
      */
 
   }, {
-    key: 'open',
+    key: "open",
     value: function open(event, trigger) {
       if (this.$element.hasClass('is-open') || this.isRevealed) {
         return;
       }
+
       var _this = this;
 
       if (trigger) {
@@ -483,20 +544,13 @@ var OffCanvas = function (_Plugin) {
         this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');
       }
 
-      /**
-       * Fires when the off-canvas menu opens.
-       * @event OffCanvas#opened
-       */
       this.$element.addClass('is-open').removeClass('is-closed');
-
       this.$triggers.attr('aria-expanded', 'true');
-      this.$element.attr('aria-hidden', 'false').trigger('opened.zf.offcanvas');
+      this.$element.attr('aria-hidden', 'false');
+      this.$content.addClass('is-open-' + this.position); // If `contentScroll` is set to false, add class and disable scrolling on touch devices.
 
-      this.$content.addClass('is-open-' + this.position);
-
-      // If `contentScroll` is set to false, add class and disable scrolling on touch devices.
       if (this.options.contentScroll === false) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);
         this.$element.on('touchstart', this._recordScrollable);
         this.$element.on('touchmove', this._stopScrollPropagation);
       }
@@ -510,11 +564,13 @@ var OffCanvas = function (_Plugin) {
       }
 
       if (this.options.autoFocus === true) {
-        this.$element.one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["transitionend"])(this.$element), function () {
+        this.$element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["transitionend"])(this.$element), function () {
           if (!_this.$element.hasClass('is-open')) {
             return; // exit if prematurely closed
           }
+
           var canvasFocus = _this.$element.find('[data-autofocus]');
+
           if (canvasFocus.length) {
             canvasFocus.eq(0).focus();
           } else {
@@ -525,21 +581,27 @@ var OffCanvas = function (_Plugin) {
 
       if (this.options.trapFocus === true) {
         this.$content.attr('tabindex', '-1');
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].trapFocus(this.$element);
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].trapFocus(this.$element);
       }
 
       this._addContentClasses();
-    }
+      /**
+       * Fires when the off-canvas menu opens.
+       * @event Offcanvas#opened
+       */
 
+
+      this.$element.trigger('opened.zf.offcanvas');
+    }
     /**
      * Closes the off-canvas menu.
      * @function
      * @param {Function} cb - optional cb to fire after closure.
-     * @fires OffCanvas#closed
+     * @fires Offcanvas#closed
      */
 
   }, {
-    key: 'close',
+    key: "close",
     value: function close(cb) {
       if (!this.$element.hasClass('is-open') || this.isRevealed) {
         return;
@@ -548,19 +610,16 @@ var OffCanvas = function (_Plugin) {
       var _this = this;
 
       this.$element.removeClass('is-open');
-
       this.$element.attr('aria-hidden', 'true')
       /**
        * Fires when the off-canvas menu opens.
-       * @event OffCanvas#closed
+       * @event Offcanvas#closed
        */
       .trigger('closed.zf.offcanvas');
+      this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom'); // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.
 
-      this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');
-
-      // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.
       if (this.options.contentScroll === false) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);
         this.$element.off('touchstart', this._recordScrollable);
         this.$element.off('touchmove', this._stopScrollPropagation);
       }
@@ -577,16 +636,16 @@ var OffCanvas = function (_Plugin) {
 
       if (this.options.trapFocus === true) {
         this.$content.removeAttr('tabindex');
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].releaseFocus(this.$element);
-      }
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].releaseFocus(this.$element);
+      } // Listen to transitionEnd and add class when done.
 
-      // Listen to transitionEnd and add class when done.
-      this.$element.one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["transitionend"])(this.$element), function (e) {
+
+      this.$element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["transitionend"])(this.$element), function (e) {
         _this.$element.addClass('is-closed');
+
         _this._removeContentClasses();
       });
     }
-
     /**
      * Toggles the off-canvas menu open or closed.
      * @function
@@ -595,7 +654,7 @@ var OffCanvas = function (_Plugin) {
      */
 
   }, {
-    key: 'toggle',
+    key: "toggle",
     value: function toggle(event, trigger) {
       if (this.$element.hasClass('is-open')) {
         this.close(event, trigger);
@@ -603,7 +662,6 @@ var OffCanvas = function (_Plugin) {
         this.open(event, trigger);
       }
     }
-
     /**
      * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.
      * @function
@@ -611,39 +669,41 @@ var OffCanvas = function (_Plugin) {
      */
 
   }, {
-    key: '_handleKeyboard',
+    key: "_handleKeyboard",
     value: function _handleKeyboard(e) {
-      var _this4 = this;
+      var _this3 = this;
+
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'OffCanvas', {
+        close: function close() {
+          _this3.close();
+
+          _this3.$lastTrigger.focus();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'OffCanvas', {
-        close: function () {
-          _this4.close();
-          _this4.$lastTrigger.focus();
           return true;
         },
-        handled: function () {
+        handled: function handled() {
           e.stopPropagation();
           e.preventDefault();
         }
       });
     }
-
     /**
      * Destroys the offcanvas plugin.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.close();
       this.$element.off('.zf.trigger .zf.offcanvas');
       this.$overlay.off('.zf.offcanvas');
+      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
     }
   }]);
 
   return OffCanvas;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 
 OffCanvas.defaults = {
   /**
@@ -753,25 +813,27 @@ OffCanvas.defaults = {
 };
 
 
-
-/***/ }),
-
-/***/ 6:
-/***/ (function(module, exports) {
-
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
-
 /***/ }),
 
-/***/ 7:
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
@@ -779,17 +841,19 @@ module.exports = {MediaQuery: window.Foundation.MediaQuery};
 
 var MutationObserver = function () {
   var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
   for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
     }
   }
+
   return false;
 }();
 
-var triggers = function (el, type) {
+var triggers = function triggers(el, type) {
   el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
   });
 };
 
@@ -800,138 +864,142 @@ var Triggers = {
   },
   Initializers: {}
 };
-
 Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
   },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
     }
   },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
     }
   },
-  closeableListener: function (e) {
+  closeableListener: function closeableListener(e) {
     e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
     if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
       });
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
     }
   },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
-};
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
 Triggers.Initializers.addOpenListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
   $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
-
-// Elements with [data-close] will close a plugin that supports it when clicked.
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
 // If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
 Triggers.Initializers.addCloseListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
   $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 Triggers.Initializers.addToggleListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
   $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
 Triggers.Initializers.addCloseableListener = function ($elem) {
   $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
   $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
 Triggers.Initializers.addToggleFocusListener = function ($elem) {
   $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
   $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+}; // More Global/complex listeners and triggers
+
 
-// More Global/complex listeners and triggers
 Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
+  resizeListener: function resizeListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a resize event
+    } //trigger all listening elements and signal a resize event
+
+
     $nodes.attr('data-events', "resize");
   },
-  scrollListener: function ($nodes) {
+  scrollListener: function scrollListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a scroll event
+    } //trigger all listening elements and signal a scroll event
+
+
     $nodes.attr('data-events', "scroll");
   },
-  closeMeListener: function (e, pluginId) {
+  closeMeListener: function closeMeListener(e, pluginId) {
     var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
-
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
     plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+
       _this.triggerHandler('close.zf.trigger', [_this]);
     });
-  }
+  } // Global, parses whole document.
+
+};
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
       plugNames = ['dropdown', 'tooltip', 'reveal'];
 
   if (pluginName) {
     if (typeof pluginName === 'string') {
       plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
     } else {
       console.error('Plugin names must be strings');
     }
   }
+
   if (yetiBoxes.length) {
     var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
+      return "closeme.zf.".concat(name);
     }).join(' ');
-
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
   }
 };
 
 function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
+  var timer,
       args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
     if (timer) {
       clearTimeout(timer);
     }
+
     timer = setTimeout(function () {
       listener.apply(null, args);
     }, debounce || 10); //default time to emit scroll event
@@ -939,14 +1007,16 @@ function debounceGlobalListener(debounce, trigger, listener) {
 }
 
 Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
   }
 };
 
 Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
   }
@@ -956,25 +1026,27 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
   if (!MutationObserver) {
     return false;
   }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
 
-    //trigger the event handler for the element depending on type
     switch (mutationRecordsList[0].type) {
       case "attributes":
         if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
+
         if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
+
         if (mutationRecordsList[0].attributeName === "style") {
           $target.closest("[data-mutate]").attr("data-events", "mutate");
           $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
         }
+
         break;
 
       case "childList":
@@ -992,14 +1064,19 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
     //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
     for (var i = 0; i <= $nodes.length - 1; i++) {
       var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
   }
 };
 
 Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addOpenListener($document);
   Triggers.Initializers.addCloseListener($document);
   Triggers.Initializers.addToggleListener($document);
@@ -1008,7 +1085,7 @@ Triggers.Initializers.addSimpleListeners = function () {
 };
 
 Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addMutationEventsListener($document);
   Triggers.Initializers.addResizeListener();
   Triggers.Initializers.addScrollListener();
@@ -1016,25 +1093,17 @@ Triggers.Initializers.addGlobalListeners = function () {
 };
 
 Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
-
-    if (document.readyState === "complete") {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
       Triggers.Initializers.addSimpleListeners();
       Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
-      });
+      $.triggersInitialized = true;
     }
-
-    $.triggersInitialized = true;
-  }
+  });
 
   if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
     Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
   }
 };
@@ -1043,12 +1112,29 @@ Triggers.init = function ($, Foundation) {
 
 /***/ }),
 
-/***/ 88:
+/***/ 9:
+/*!**********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.offcanvas.js ***!
+  \**********************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(22);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.offcanvas.js */"./js/entries/plugins/foundation.offcanvas.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.offcanvas.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.offcanvas.js.map b/dist/js/plugins/foundation.offcanvas.js.map
new file mode 100644 (file)
index 0000000..7ca9609
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.offcanvas.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.offcanvas.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","OffCanvas","element","options","className","$element","$","extend","defaults","data","contentClasses","base","reveal","$lastTrigger","$triggers","position","$content","nested","each","index","val","push","Triggers","init","MediaQuery","_init","_events","Keyboard","register","id","attr","contentId","siblings","length","first","closest","console","warn","transition","removeClass","addClass","document","find","is","match","contentOverlay","overlay","createElement","overlayPosition","css","setAttribute","$overlay","insertAfter","append","revealOnRegExp","RegExp","RegExpEscape","revealClass","revealOnClass","exec","isRevealed","revealOn","_setMQChecker","transitionTime","_removeContentClasses","off","on","open","bind","close","toggle","_handleKeyboard","closeOnClick","$target","_this","onLoadListener","onLoad","window","atLeast","hasReveal","join","_addContentClasses","event","elem","scrollHeight","clientHeight","scrollTop","allowUp","allowDown","lastY","originalEvent","pageY","up","down","stopPropagation","preventDefault","trigger","hasClass","forceTo","scrollTo","body","contentScroll","_stopScrolling","_recordScrollable","_stopScrollPropagation","autoFocus","one","transitionend","canvasFocus","eq","focus","trapFocus","cb","removeAttr","releaseFocus","e","handleKey","handled","Plugin","MutationObserver","prefixes","i","triggers","el","type","split","forEach","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","animation","Motion","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","scrollListener","closeMeListener","pluginId","namespace","plugins","not","addClosemeListener","pluginName","yetiBoxes","plugNames","concat","error","listeners","map","name","debounceGlobalListener","debounce","listener","timer","args","Array","prototype","slice","call","arguments","clearTimeout","setTimeout","apply","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","target","attributeName","pageYOffset","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","triggersInitialized","IHearYou"],"mappings":"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","file":"foundation.offcanvas.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.offcanvas\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.offcanvas\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 9);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","import { Foundation } from './foundation.core';\n\nimport { OffCanvas } from '../../foundation.offcanvas';\nFoundation.plugin(OffCanvas, 'OffCanvas');\n\nexport { Foundation, OffCanvas };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, transitionend, RegExpEscape } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * OffCanvas module.\n * @module foundation.offcanvas\n * @requires foundation.util.keyboard\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass OffCanvas extends Plugin {\n  /**\n   * Creates a new instance of an off-canvas wrapper.\n   * @class\n   * @name OffCanvas\n   * @fires OffCanvas#init\n   * @param {Object} element - jQuery object to initialize.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.className = 'OffCanvas'; // ie9 back compat\n    this.$element = element;\n    this.options = $.extend({}, OffCanvas.defaults, this.$element.data(), options);\n    this.contentClasses = { base: [], reveal: [] };\n    this.$lastTrigger = $();\n    this.$triggers = $();\n    this.position = 'left';\n    this.$content = $();\n    this.nested = !!(this.options.nested);\n\n    // Defines the CSS transition/position classes of the off-canvas content container.\n    $(['push', 'overlap']).each((index, val) => {\n      this.contentClasses.base.push('has-transition-'+val);\n    });\n    $(['left', 'right', 'top', 'bottom']).each((index, val) => {\n      this.contentClasses.base.push('has-position-'+val);\n      this.contentClasses.reveal.push('has-reveal-'+val);\n    });\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n    MediaQuery._init();\n\n    this._init();\n    this._events();\n\n    Keyboard.register('OffCanvas', {\n      'ESCAPE': 'close'\n    });\n\n  }\n\n  /**\n   * Initializes the off-canvas wrapper by adding the exit overlay (if needed).\n   * @function\n   * @private\n   */\n  _init() {\n    var id = this.$element.attr('id');\n\n    this.$element.attr('aria-hidden', 'true');\n\n    // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)\n    if (this.options.contentId) {\n      this.$content = $('#'+this.options.contentId);\n    } else if (this.$element.siblings('[data-off-canvas-content]').length) {\n      this.$content = this.$element.siblings('[data-off-canvas-content]').first();\n    } else {\n      this.$content = this.$element.closest('[data-off-canvas-content]').first();\n    }\n\n    if (!this.options.contentId) {\n      // Assume that the off-canvas element is nested if it isn't a sibling of the content\n      this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;\n\n    } else if (this.options.contentId && this.options.nested === null) {\n      // Warning if using content ID without setting the nested option\n      // Once the element is nested it is required to work properly in this case\n      console.warn('Remember to use the nested option if using the content ID option!');\n    }\n\n    if (this.nested === true) {\n      // Force transition overlap if nested\n      this.options.transition = 'overlap';\n      // Remove appropriate classes if already assigned in markup\n      this.$element.removeClass('is-transition-push');\n    }\n\n    this.$element.addClass(`is-transition-${this.options.transition} is-closed`);\n\n    // Find triggers that affect this element and add aria-expanded to them\n    this.$triggers = $(document)\n      .find('[data-open=\"'+id+'\"], [data-close=\"'+id+'\"], [data-toggle=\"'+id+'\"]')\n      .attr('aria-expanded', 'false')\n      .attr('aria-controls', id);\n\n    // Get position by checking for related CSS class\n    this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\\-(left|top|right|bottom)/)[1] : this.position;\n\n    // Add an overlay over the content if necessary\n    if (this.options.contentOverlay === true) {\n      var overlay = document.createElement('div');\n      var overlayPosition = $(this.$element).css(\"position\") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';\n      overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);\n      this.$overlay = $(overlay);\n      if(overlayPosition === 'is-overlay-fixed') {\n        $(this.$overlay).insertAfter(this.$element);\n      } else {\n        this.$content.append(this.$overlay);\n      }\n    }\n\n    // Get the revealOn option from the class.\n    var revealOnRegExp = new RegExp(RegExpEscape(this.options.revealClass) + '([^\\\\s]+)', 'g');\n    var revealOnClass = revealOnRegExp.exec(this.$element[0].className);\n    if (revealOnClass) {\n      this.options.isRevealed = true;\n      this.options.revealOn = this.options.revealOn || revealOnClass[1];\n    }\n\n    // Ensure the `reveal-on-*` class is set.\n    if (this.options.isRevealed === true && this.options.revealOn) {\n      this.$element.first().addClass(`${this.options.revealClass}${this.options.revealOn}`);\n      this._setMQChecker();\n    }\n\n    if (this.options.transitionTime) {\n      this.$element.css('transition-duration', this.options.transitionTime);\n    }\n\n    // Initally remove all transition/position CSS classes from off-canvas content container.\n    this._removeContentClasses();\n  }\n\n  /**\n   * Adds event handlers to the off-canvas wrapper and the exit overlay.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('.zf.trigger .zf.offcanvas').on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': this.close.bind(this),\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'keydown.zf.offcanvas': this._handleKeyboard.bind(this)\n    });\n\n    if (this.options.closeOnClick === true) {\n      var $target = this.options.contentOverlay ? this.$overlay : this.$content;\n      $target.on({'click.zf.offcanvas': this.close.bind(this)});\n    }\n  }\n\n  /**\n   * Applies event listener for elements that will reveal at certain breakpoints.\n   * @private\n   */\n  _setMQChecker() {\n    var _this = this;\n\n    this.onLoadListener = onLoad($(window), function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      }\n    });\n\n    $(window).on('changed.zf.mediaquery', function () {\n      if (MediaQuery.atLeast(_this.options.revealOn)) {\n        _this.reveal(true);\n      } else {\n        _this.reveal(false);\n      }\n    });\n  }\n\n  /**\n   * Removes the CSS transition/position classes of the off-canvas content container.\n   * Removing the classes is important when another off-canvas gets opened that uses the same content container.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _removeContentClasses(hasReveal) {\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.removeClass(this.contentClasses.base.join(' '));\n    } else if (hasReveal === false) {\n      this.$content.removeClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.\n   * Beforehand any transition/position class gets removed.\n   * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n   * @private\n   */\n  _addContentClasses(hasReveal) {\n    this._removeContentClasses(hasReveal);\n    if (typeof hasReveal !== 'boolean') {\n      this.$content.addClass(`has-transition-${this.options.transition} has-position-${this.position}`);\n    } else if (hasReveal === true) {\n      this.$content.addClass(`has-reveal-${this.position}`);\n    }\n  }\n\n  /**\n   * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.\n   * @param {Boolean} isRevealed - true if element should be revealed.\n   * @function\n   */\n  reveal(isRevealed) {\n    if (isRevealed) {\n      this.close();\n      this.isRevealed = true;\n      this.$element.attr('aria-hidden', 'false');\n      this.$element.off('open.zf.trigger toggle.zf.trigger');\n      this.$element.removeClass('is-closed');\n    } else {\n      this.isRevealed = false;\n      this.$element.attr('aria-hidden', 'true');\n      this.$element.off('open.zf.trigger toggle.zf.trigger').on({\n        'open.zf.trigger': this.open.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this)\n      });\n      this.$element.addClass('is-closed');\n    }\n    this._addContentClasses(isRevealed);\n  }\n\n  /**\n   * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.\n   * @private\n   */\n  _stopScrolling(event) {\n    return false;\n  }\n\n  // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios\n  // Only really works for y, not sure how to extend to x or if we need to.\n  _recordScrollable(event) {\n    let elem = this; // called from event handler context with this as elem\n\n     // If the element is scrollable (content overflows), then...\n    if (elem.scrollHeight !== elem.clientHeight) {\n      // If we're at the top, scroll down one pixel to allow scrolling up\n      if (elem.scrollTop === 0) {\n        elem.scrollTop = 1;\n      }\n      // If we're at the bottom, scroll up one pixel to allow scrolling down\n      if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {\n        elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;\n      }\n    }\n    elem.allowUp = elem.scrollTop > 0;\n    elem.allowDown = elem.scrollTop < (elem.scrollHeight - elem.clientHeight);\n    elem.lastY = event.originalEvent.pageY;\n  }\n\n  _stopScrollPropagation(event) {\n    let elem = this; // called from event handler context with this as elem\n    let up = event.pageY < elem.lastY;\n    let down = !up;\n    elem.lastY = event.pageY;\n\n    if((up && elem.allowUp) || (down && elem.allowDown)) {\n      event.stopPropagation();\n    } else {\n      event.preventDefault();\n    }\n  }\n\n  /**\n   * Opens the off-canvas menu.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   * @fires Offcanvas#opened\n   * @todo also trigger 'open' event?\n   */\n  open(event, trigger) {\n    if (this.$element.hasClass('is-open') || this.isRevealed) { return; }\n    var _this = this;\n\n    if (trigger) {\n      this.$lastTrigger = trigger;\n    }\n\n    if (this.options.forceTo === 'top') {\n      window.scrollTo(0, 0);\n    } else if (this.options.forceTo === 'bottom') {\n      window.scrollTo(0,document.body.scrollHeight);\n    }\n\n    if (this.options.transitionTime && this.options.transition !== 'overlap') {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);\n    } else {\n      this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');\n    }\n\n    this.$element.addClass('is-open').removeClass('is-closed');\n\n    this.$triggers.attr('aria-expanded', 'true');\n    this.$element.attr('aria-hidden', 'false');\n\n    this.$content.addClass('is-open-' + this.position);\n\n    // If `contentScroll` is set to false, add class and disable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);\n      this.$element.on('touchstart', this._recordScrollable);\n      this.$element.on('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.addClass('is-closable');\n    }\n\n    if (this.options.autoFocus === true) {\n      this.$element.one(transitionend(this.$element), function() {\n        if (!_this.$element.hasClass('is-open')) {\n          return; // exit if prematurely closed\n        }\n        var canvasFocus = _this.$element.find('[data-autofocus]');\n        if (canvasFocus.length) {\n            canvasFocus.eq(0).focus();\n        } else {\n            _this.$element.find('a, button').eq(0).focus();\n        }\n      });\n    }\n\n    if (this.options.trapFocus === true) {\n      this.$content.attr('tabindex', '-1');\n      Keyboard.trapFocus(this.$element);\n    }\n\n    this._addContentClasses();\n\n    /**\n     * Fires when the off-canvas menu opens.\n     * @event Offcanvas#opened\n     */\n    this.$element.trigger('opened.zf.offcanvas');\n  }\n\n  /**\n   * Closes the off-canvas menu.\n   * @function\n   * @param {Function} cb - optional cb to fire after closure.\n   * @fires Offcanvas#closed\n   */\n  close(cb) {\n    if (!this.$element.hasClass('is-open') || this.isRevealed) { return; }\n\n    var _this = this;\n\n    this.$element.removeClass('is-open');\n\n    this.$element.attr('aria-hidden', 'true')\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#closed\n       */\n        .trigger('closed.zf.offcanvas');\n\n    this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom');\n\n    // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.\n    if (this.options.contentScroll === false) {\n      $('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);\n      this.$element.off('touchstart', this._recordScrollable);\n      this.$element.off('touchmove', this._stopScrollPropagation);\n    }\n\n    if (this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-visible');\n    }\n\n    if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n      this.$overlay.removeClass('is-closable');\n    }\n\n    this.$triggers.attr('aria-expanded', 'false');\n\n    if (this.options.trapFocus === true) {\n      this.$content.removeAttr('tabindex');\n      Keyboard.releaseFocus(this.$element);\n    }\n\n    // Listen to transitionEnd and add class when done.\n    this.$element.one(transitionend(this.$element), function(e) {\n      _this.$element.addClass('is-closed');\n      _this._removeContentClasses();\n    });\n  }\n\n  /**\n   * Toggles the off-canvas menu open or closed.\n   * @function\n   * @param {Object} event - Event object passed from listener.\n   * @param {jQuery} trigger - element that triggered the off-canvas to open.\n   */\n  toggle(event, trigger) {\n    if (this.$element.hasClass('is-open')) {\n      this.close(event, trigger);\n    }\n    else {\n      this.open(event, trigger);\n    }\n  }\n\n  /**\n   * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.\n   * @function\n   * @private\n   */\n  _handleKeyboard(e) {\n    Keyboard.handleKey(e, 'OffCanvas', {\n      close: () => {\n        this.close();\n        this.$lastTrigger.focus();\n        return true;\n      },\n      handled: () => {\n        e.stopPropagation();\n        e.preventDefault();\n      }\n    });\n  }\n\n  /**\n   * Destroys the offcanvas plugin.\n   * @function\n   */\n  _destroy() {\n    this.close();\n    this.$element.off('.zf.trigger .zf.offcanvas');\n    this.$overlay.off('.zf.offcanvas');\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n  }\n}\n\nOffCanvas.defaults = {\n  /**\n   * Allow the user to click outside of the menu to close it.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Adds an overlay on top of `[data-off-canvas-content]`.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentOverlay: true,\n\n  /**\n   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  contentId: null,\n\n  /**\n   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.\n   * @option\n   * @type {boolean}\n   * @default null\n   */\n  nested: null,\n\n  /**\n   * Enable/disable scrolling of the main content when an off canvas panel is open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentScroll: true,\n\n  /**\n   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.\n   * @option\n   * @type {number}\n   * @default null\n   */\n  transitionTime: null,\n\n  /**\n   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.\n   * @option\n   * @type {string}\n   * @default push\n   */\n  transition: 'push',\n\n  /**\n   * Force the page to scroll to top or bottom on open.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  forceTo: null,\n\n  /**\n   * Allow the offcanvas to remain open for certain breakpoints.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  isRevealed: false,\n\n  /**\n   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  revealOn: null,\n\n  /**\n   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoFocus: true,\n\n  /**\n   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.\n   * @option\n   * @type {string}\n   * @default reveal-for-\n   * @todo improve the regex testing for this.\n   */\n  revealClass: 'reveal-for-',\n\n  /**\n   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false\n}\n\nexport {OffCanvas};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 9777bdfcb823e46579bfb15cb270196cb1106b84..414118e23795106f34ee3af057633ed9bd8c4952 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(n){if(i[n])return i[n].exports;var s=i[n]={i:n,l:!1,exports:{}};return t[n].call(s.exports,s,s.exports,e),s.l=!0,s.exports}var i={};e.m=t,e.c=i,e.i=function(t){return t},e.d=function(t,i,n){e.o(t,i)||Object.defineProperty(t,i,{configurable:!1,enumerable:!0,get:n})},e.n=function(t){var i=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(i,"a",i),i},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=88)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},22:function(t,e,i){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var n=i(1),s=(i.n(n),i(52));n.Foundation.plugin(s.a,"OffCanvas")},3:function(t,e){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},4:function(t,e){t.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},5:function(t,e){t.exports={Keyboard:window.Foundation.Keyboard}},52:function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return g});var a=i(0),r=i.n(a),l=i(5),c=(i.n(l),i(6)),d=(i.n(c),i(3)),f=(i.n(d),i(2)),u=(i.n(f),i(7)),h=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),g=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),h(e,[{key:"_setup",value:function(t,i){var n=this;this.className="OffCanvas",this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.contentClasses={base:[],reveal:[]},this.$lastTrigger=r()(),this.$triggers=r()(),this.position="left",this.$content=r()(),this.nested=!!this.options.nested,r()(["push","overlap"]).each(function(t,e){n.contentClasses.base.push("has-transition-"+e)}),r()(["left","right","top","bottom"]).each(function(t,e){n.contentClasses.base.push("has-position-"+e),n.contentClasses.reveal.push("has-reveal-"+e)}),u.a.init(r.a),c.MediaQuery._init(),this._init(),this._events(),l.Keyboard.register("OffCanvas",{ESCAPE:"close"})}},{key:"_init",value:function(){var t=this.$element.attr("id");if(this.$element.attr("aria-hidden","true"),this.options.contentId?this.$content=r()("#"+this.options.contentId):this.$element.siblings("[data-off-canvas-content]").length?this.$content=this.$element.siblings("[data-off-canvas-content]").first():this.$content=this.$element.closest("[data-off-canvas-content]").first(),this.options.contentId?this.options.contentId&&null===this.options.nested&&console.warn("Remember to use the nested option if using the content ID option!"):this.nested=0===this.$element.siblings("[data-off-canvas-content]").length,!0===this.nested&&(this.options.transition="overlap",this.$element.removeClass("is-transition-push")),this.$element.addClass("is-transition-"+this.options.transition+" is-closed"),this.$triggers=r()(document).find('[data-open="'+t+'"], [data-close="'+t+'"], [data-toggle="'+t+'"]').attr("aria-expanded","false").attr("aria-controls",t),this.position=this.$element.is(".position-left, .position-top, .position-right, .position-bottom")?this.$element.attr("class").match(/position\-(left|top|right|bottom)/)[1]:this.position,!0===this.options.contentOverlay){var e=document.createElement("div"),i="fixed"===r()(this.$element).css("position")?"is-overlay-fixed":"is-overlay-absolute";e.setAttribute("class","js-off-canvas-overlay "+i),this.$overlay=r()(e),"is-overlay-fixed"===i?r()(this.$overlay).insertAfter(this.$element):this.$content.append(this.$overlay)}this.options.isRevealed=this.options.isRevealed||new RegExp(this.options.revealClass,"g").test(this.$element[0].className),!0===this.options.isRevealed&&(this.options.revealOn=this.options.revealOn||this.$element[0].className.match(/(reveal-for-medium|reveal-for-large)/g)[0].split("-")[2],this._setMQChecker()),this.options.transitionTime&&this.$element.css("transition-duration",this.options.transitionTime),this._removeContentClasses()}},{key:"_events",value:function(){if(this.$element.off(".zf.trigger .zf.offcanvas").on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":this.close.bind(this),"toggle.zf.trigger":this.toggle.bind(this),"keydown.zf.offcanvas":this._handleKeyboard.bind(this)}),!0===this.options.closeOnClick){(this.options.contentOverlay?this.$overlay:this.$content).on({"click.zf.offcanvas":this.close.bind(this)})}}},{key:"_setMQChecker",value:function(){var t=this;r()(window).on("changed.zf.mediaquery",function(){c.MediaQuery.atLeast(t.options.revealOn)?t.reveal(!0):t.reveal(!1)}).one("load.zf.offcanvas",function(){c.MediaQuery.atLeast(t.options.revealOn)&&t.reveal(!0)})}},{key:"_removeContentClasses",value:function(t){"boolean"!=typeof t?this.$content.removeClass(this.contentClasses.base.join(" ")):!1===t&&this.$content.removeClass("has-reveal-"+this.position)}},{key:"_addContentClasses",value:function(t){this._removeContentClasses(t),"boolean"!=typeof t?this.$content.addClass("has-transition-"+this.options.transition+" has-position-"+this.position):!0===t&&this.$content.addClass("has-reveal-"+this.position)}},{key:"reveal",value:function(t){t?(this.close(),this.isRevealed=!0,this.$element.attr("aria-hidden","false"),this.$element.off("open.zf.trigger toggle.zf.trigger"),this.$element.removeClass("is-closed")):(this.isRevealed=!1,this.$element.attr("aria-hidden","true"),this.$element.off("open.zf.trigger toggle.zf.trigger").on({"open.zf.trigger":this.open.bind(this),"toggle.zf.trigger":this.toggle.bind(this)}),this.$element.addClass("is-closed")),this._addContentClasses(t)}},{key:"_stopScrolling",value:function(t){return!1}},{key:"_recordScrollable",value:function(t){var e=this;e.scrollHeight!==e.clientHeight&&(0===e.scrollTop&&(e.scrollTop=1),e.scrollTop===e.scrollHeight-e.clientHeight&&(e.scrollTop=e.scrollHeight-e.clientHeight-1)),e.allowUp=e.scrollTop>0,e.allowDown=e.scrollTop<e.scrollHeight-e.clientHeight,e.lastY=t.originalEvent.pageY}},{key:"_stopScrollPropagation",value:function(t){var e=this,i=t.pageY<e.lastY,n=!i;e.lastY=t.pageY,i&&e.allowUp||n&&e.allowDown?t.stopPropagation():t.preventDefault()}},{key:"open",value:function(t,e){if(!this.$element.hasClass("is-open")&&!this.isRevealed){var n=this;e&&(this.$lastTrigger=e),"top"===this.options.forceTo?window.scrollTo(0,0):"bottom"===this.options.forceTo&&window.scrollTo(0,document.body.scrollHeight),this.options.transitionTime&&"overlap"!==this.options.transition?this.$element.siblings("[data-off-canvas-content]").css("transition-duration",this.options.transitionTime):this.$element.siblings("[data-off-canvas-content]").css("transition-duration",""),this.$element.addClass("is-open").removeClass("is-closed"),this.$triggers.attr("aria-expanded","true"),this.$element.attr("aria-hidden","false").trigger("opened.zf.offcanvas"),this.$content.addClass("is-open-"+this.position),!1===this.options.contentScroll&&(r()("body").addClass("is-off-canvas-open").on("touchmove",this._stopScrolling),this.$element.on("touchstart",this._recordScrollable),this.$element.on("touchmove",this._stopScrollPropagation)),!0===this.options.contentOverlay&&this.$overlay.addClass("is-visible"),!0===this.options.closeOnClick&&!0===this.options.contentOverlay&&this.$overlay.addClass("is-closable"),!0===this.options.autoFocus&&this.$element.one(i.i(d.transitionend)(this.$element),function(){if(n.$element.hasClass("is-open")){var t=n.$element.find("[data-autofocus]");t.length?t.eq(0).focus():n.$element.find("a, button").eq(0).focus()}}),!0===this.options.trapFocus&&(this.$content.attr("tabindex","-1"),l.Keyboard.trapFocus(this.$element)),this._addContentClasses()}}},{key:"close",value:function(t){if(this.$element.hasClass("is-open")&&!this.isRevealed){var e=this;this.$element.removeClass("is-open"),this.$element.attr("aria-hidden","true").trigger("closed.zf.offcanvas"),this.$content.removeClass("is-open-left is-open-top is-open-right is-open-bottom"),!1===this.options.contentScroll&&(r()("body").removeClass("is-off-canvas-open").off("touchmove",this._stopScrolling),this.$element.off("touchstart",this._recordScrollable),this.$element.off("touchmove",this._stopScrollPropagation)),!0===this.options.contentOverlay&&this.$overlay.removeClass("is-visible"),!0===this.options.closeOnClick&&!0===this.options.contentOverlay&&this.$overlay.removeClass("is-closable"),this.$triggers.attr("aria-expanded","false"),!0===this.options.trapFocus&&(this.$content.removeAttr("tabindex"),l.Keyboard.releaseFocus(this.$element)),this.$element.one(i.i(d.transitionend)(this.$element),function(t){e.$element.addClass("is-closed"),e._removeContentClasses()})}}},{key:"toggle",value:function(t,e){this.$element.hasClass("is-open")?this.close(t,e):this.open(t,e)}},{key:"_handleKeyboard",value:function(t){var e=this;l.Keyboard.handleKey(t,"OffCanvas",{close:function(){return e.close(),e.$lastTrigger.focus(),!0},handled:function(){t.stopPropagation(),t.preventDefault()}})}},{key:"_destroy",value:function(){this.close(),this.$element.off(".zf.trigger .zf.offcanvas"),this.$overlay.off(".zf.offcanvas")}}]),e}(f.Plugin);g.defaults={closeOnClick:!0,contentOverlay:!0,contentId:null,nested:null,contentScroll:!0,transitionTime:null,transition:"push",forceTo:null,isRevealed:!1,revealOn:null,autoFocus:!0,revealClass:"reveal-for-",trapFocus:!1}},6:function(t,e){t.exports={MediaQuery:window.Foundation.MediaQuery}},7:function(t,e,i){"use strict";function n(t,e,i){var n=void 0,s=Array.prototype.slice.call(arguments,3);o()(window).off(e).on(e,function(e){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,s)},t||10)})}i.d(e,"a",function(){return c});var s=i(0),o=i.n(s),a=i(4),r=(i.n(a),function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if(t[e]+"MutationObserver"in window)return window[t[e]+"MutationObserver"];return!1}()),l=function(t,e){t.data(e).split(" ").forEach(function(i){o()("#"+i)["close"===e?"trigger":"triggerHandler"](e+".zf.trigger",[t])})},c={Listeners:{Basic:{},Global:{}},Initializers:{}};c.Listeners.Basic={openListener:function(){l(o()(this),"open")},closeListener:function(){o()(this).data("close")?l(o()(this),"close"):o()(this).trigger("close.zf.trigger")},toggleListener:function(){o()(this).data("toggle")?l(o()(this),"toggle"):o()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=o()(this).data("closable");""!==e?a.Motion.animateOut(o()(this),e,function(){o()(this).trigger("closed.zf")}):o()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=o()(this).data("toggle-focus");o()("#"+t).triggerHandler("toggle.zf.trigger",[o()(this)])}},c.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",c.Listeners.Basic.openListener)},c.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",c.Listeners.Basic.closeListener)},c.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",c.Listeners.Basic.toggleListener)},c.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",c.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",c.Listeners.Basic.closeableListener)},c.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",c.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",c.Listeners.Basic.toggleFocusListener)},c.Listeners.Global={resizeListener:function(t){r||t.each(function(){o()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){r||t.each(function(){o()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];o()("[data-"+i+"]").not('[data-yeti-box="'+e+'"]').each(function(){var t=o()(this);t.triggerHandler("close.zf.trigger",[t])})}},c.Initializers.addClosemeListener=function(t){var e=o()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"==typeof t&&"string"==typeof t[0]?i.concat(t):console.error("Plugin names must be strings")),e.length){var n=i.map(function(t){return"closeme.zf."+t}).join(" ");o()(window).off(n).on(n,c.Listeners.Global.closeMeListener)}},c.Initializers.addResizeListener=function(t){var e=o()("[data-resize]");e.length&&n(t,"resize.zf.trigger",c.Listeners.Global.resizeListener,e)},c.Initializers.addScrollListener=function(t){var e=o()("[data-scroll]");e.length&&n(t,"scroll.zf.trigger",c.Listeners.Global.scrollListener,e)},c.Initializers.addMutationEventsListener=function(t){if(!r)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=o()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var n=0;n<=e.length-1;n++){var s=new r(i);s.observe(e[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},c.Initializers.addSimpleListeners=function(){var t=o()(document);c.Initializers.addOpenListener(t),c.Initializers.addCloseListener(t),c.Initializers.addToggleListener(t),c.Initializers.addCloseableListener(t),c.Initializers.addToggleFocusListener(t)},c.Initializers.addGlobalListeners=function(){var t=o()(document);c.Initializers.addMutationEventsListener(t),c.Initializers.addResizeListener(),c.Initializers.addScrollListener(),c.Initializers.addClosemeListener()},c.init=function(t,e){if(void 0===t.triggersInitialized){t(document);"complete"===document.readyState?(c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners()):t(window).on("load",function(){c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners()}),t.triggersInitialized=!0}e&&(e.Triggers=c,e.IHearYou=c.Initializers.addGlobalListeners)}},88:function(t,e,i){t.exports=i(22)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("./foundation.util.keyboard"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.keyboard","./foundation.util.mediaQuery","./foundation.util.motion","jquery"],e):"object"==typeof exports?exports["foundation.offcanvas"]=e(require("./foundation.core"),require("./foundation.util.keyboard"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.offcanvas"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],t.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],t.__FOUNDATION_EXTERNAL__["foundation.util.motion"],t.jQuery))}(window,function(n,i,o,s,r){return function(n){var i={};function o(t){if(i[t])return i[t].exports;var e=i[t]={i:t,l:!1,exports:{}};return n[t].call(e.exports,e,e.exports,o),e.l=!0,e.exports}return o.m=n,o.c=i,o.d=function(t,e,n){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(o.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)o.d(n,i,function(t){return e[t]}.bind(null,i));return n},o.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return o.d(e,"a",e),e},o.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},o.p="",o(o.s=9)}({"./foundation.core":function(t,e){t.exports=n},"./foundation.util.keyboard":function(t,e){t.exports=i},"./foundation.util.mediaQuery":function(t,e){t.exports=o},"./foundation.util.motion":function(t,e){t.exports=s},"./js/entries/plugins/foundation.offcanvas.js":function(t,e,n){"use strict";n.r(e);var i=n("./foundation.core");n.d(e,"Foundation",function(){return i.Foundation});var o=n("./js/foundation.offcanvas.js");n.d(e,"OffCanvas",function(){return o.OffCanvas}),i.Foundation.plugin(o.OffCanvas,"OffCanvas")},"./js/foundation.offcanvas.js":function(t,e,n){"use strict";n.r(e),n.d(e,"OffCanvas",function(){return g});var i=n("jquery"),s=n.n(i),r=n("./foundation.core"),a=n("./foundation.util.keyboard"),l=n("./foundation.util.mediaQuery"),c=n("./js/foundation.util.triggers.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function f(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function u(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function h(t,e){return(h=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var g=function(t){function i(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),u(this,d(i).apply(this,arguments))}var e,n,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&h(t,e)}(i,r["Plugin"]),e=i,(n=[{key:"_setup",value:function(t,e){var n=this;this.className="OffCanvas",this.$element=t,this.options=s.a.extend({},i.defaults,this.$element.data(),e),this.contentClasses={base:[],reveal:[]},this.$lastTrigger=s()(),this.$triggers=s()(),this.position="left",this.$content=s()(),this.nested=!!this.options.nested,s()(["push","overlap"]).each(function(t,e){n.contentClasses.base.push("has-transition-"+e)}),s()(["left","right","top","bottom"]).each(function(t,e){n.contentClasses.base.push("has-position-"+e),n.contentClasses.reveal.push("has-reveal-"+e)}),c.Triggers.init(s.a),l.MediaQuery._init(),this._init(),this._events(),a.Keyboard.register("OffCanvas",{ESCAPE:"close"})}},{key:"_init",value:function(){var t=this.$element.attr("id");if(this.$element.attr("aria-hidden","true"),this.options.contentId?this.$content=s()("#"+this.options.contentId):this.$element.siblings("[data-off-canvas-content]").length?this.$content=this.$element.siblings("[data-off-canvas-content]").first():this.$content=this.$element.closest("[data-off-canvas-content]").first(),this.options.contentId?this.options.contentId&&null===this.options.nested&&console.warn("Remember to use the nested option if using the content ID option!"):this.nested=0===this.$element.siblings("[data-off-canvas-content]").length,!0===this.nested&&(this.options.transition="overlap",this.$element.removeClass("is-transition-push")),this.$element.addClass("is-transition-".concat(this.options.transition," is-closed")),this.$triggers=s()(document).find('[data-open="'+t+'"], [data-close="'+t+'"], [data-toggle="'+t+'"]').attr("aria-expanded","false").attr("aria-controls",t),this.position=this.$element.is(".position-left, .position-top, .position-right, .position-bottom")?this.$element.attr("class").match(/position\-(left|top|right|bottom)/)[1]:this.position,!0===this.options.contentOverlay){var e=document.createElement("div"),n="fixed"===s()(this.$element).css("position")?"is-overlay-fixed":"is-overlay-absolute";e.setAttribute("class","js-off-canvas-overlay "+n),this.$overlay=s()(e),"is-overlay-fixed"===n?s()(this.$overlay).insertAfter(this.$element):this.$content.append(this.$overlay)}var i=new RegExp(Object(r.RegExpEscape)(this.options.revealClass)+"([^\\s]+)","g").exec(this.$element[0].className);i&&(this.options.isRevealed=!0,this.options.revealOn=this.options.revealOn||i[1]),!0===this.options.isRevealed&&this.options.revealOn&&(this.$element.first().addClass("".concat(this.options.revealClass).concat(this.options.revealOn)),this._setMQChecker()),this.options.transitionTime&&this.$element.css("transition-duration",this.options.transitionTime),this._removeContentClasses()}},{key:"_events",value:function(){(this.$element.off(".zf.trigger .zf.offcanvas").on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":this.close.bind(this),"toggle.zf.trigger":this.toggle.bind(this),"keydown.zf.offcanvas":this._handleKeyboard.bind(this)}),!0===this.options.closeOnClick)&&(this.options.contentOverlay?this.$overlay:this.$content).on({"click.zf.offcanvas":this.close.bind(this)})}},{key:"_setMQChecker",value:function(){var t=this;this.onLoadListener=Object(r.onLoad)(s()(window),function(){l.MediaQuery.atLeast(t.options.revealOn)&&t.reveal(!0)}),s()(window).on("changed.zf.mediaquery",function(){l.MediaQuery.atLeast(t.options.revealOn)?t.reveal(!0):t.reveal(!1)})}},{key:"_removeContentClasses",value:function(t){"boolean"!=typeof t?this.$content.removeClass(this.contentClasses.base.join(" ")):!1===t&&this.$content.removeClass("has-reveal-".concat(this.position))}},{key:"_addContentClasses",value:function(t){this._removeContentClasses(t),"boolean"!=typeof t?this.$content.addClass("has-transition-".concat(this.options.transition," has-position-").concat(this.position)):!0===t&&this.$content.addClass("has-reveal-".concat(this.position))}},{key:"reveal",value:function(t){t?(this.close(),this.isRevealed=!0,this.$element.attr("aria-hidden","false"),this.$element.off("open.zf.trigger toggle.zf.trigger"),this.$element.removeClass("is-closed")):(this.isRevealed=!1,this.$element.attr("aria-hidden","true"),this.$element.off("open.zf.trigger toggle.zf.trigger").on({"open.zf.trigger":this.open.bind(this),"toggle.zf.trigger":this.toggle.bind(this)}),this.$element.addClass("is-closed")),this._addContentClasses(t)}},{key:"_stopScrolling",value:function(t){return!1}},{key:"_recordScrollable",value:function(t){var e=this;e.scrollHeight!==e.clientHeight&&(0===e.scrollTop&&(e.scrollTop=1),e.scrollTop===e.scrollHeight-e.clientHeight&&(e.scrollTop=e.scrollHeight-e.clientHeight-1)),e.allowUp=0<e.scrollTop,e.allowDown=e.scrollTop<e.scrollHeight-e.clientHeight,e.lastY=t.originalEvent.pageY}},{key:"_stopScrollPropagation",value:function(t){var e=t.pageY<this.lastY,n=!e;this.lastY=t.pageY,e&&this.allowUp||n&&this.allowDown?t.stopPropagation():t.preventDefault()}},{key:"open",value:function(t,e){if(!this.$element.hasClass("is-open")&&!this.isRevealed){var n=this;e&&(this.$lastTrigger=e),"top"===this.options.forceTo?window.scrollTo(0,0):"bottom"===this.options.forceTo&&window.scrollTo(0,document.body.scrollHeight),this.options.transitionTime&&"overlap"!==this.options.transition?this.$element.siblings("[data-off-canvas-content]").css("transition-duration",this.options.transitionTime):this.$element.siblings("[data-off-canvas-content]").css("transition-duration",""),this.$element.addClass("is-open").removeClass("is-closed"),this.$triggers.attr("aria-expanded","true"),this.$element.attr("aria-hidden","false"),this.$content.addClass("is-open-"+this.position),!1===this.options.contentScroll&&(s()("body").addClass("is-off-canvas-open").on("touchmove",this._stopScrolling),this.$element.on("touchstart",this._recordScrollable),this.$element.on("touchmove",this._stopScrollPropagation)),!0===this.options.contentOverlay&&this.$overlay.addClass("is-visible"),!0===this.options.closeOnClick&&!0===this.options.contentOverlay&&this.$overlay.addClass("is-closable"),!0===this.options.autoFocus&&this.$element.one(Object(r.transitionend)(this.$element),function(){if(n.$element.hasClass("is-open")){var t=n.$element.find("[data-autofocus]");t.length?t.eq(0).focus():n.$element.find("a, button").eq(0).focus()}}),!0===this.options.trapFocus&&(this.$content.attr("tabindex","-1"),a.Keyboard.trapFocus(this.$element)),this._addContentClasses(),this.$element.trigger("opened.zf.offcanvas")}}},{key:"close",value:function(t){if(this.$element.hasClass("is-open")&&!this.isRevealed){var e=this;this.$element.removeClass("is-open"),this.$element.attr("aria-hidden","true").trigger("closed.zf.offcanvas"),this.$content.removeClass("is-open-left is-open-top is-open-right is-open-bottom"),!1===this.options.contentScroll&&(s()("body").removeClass("is-off-canvas-open").off("touchmove",this._stopScrolling),this.$element.off("touchstart",this._recordScrollable),this.$element.off("touchmove",this._stopScrollPropagation)),!0===this.options.contentOverlay&&this.$overlay.removeClass("is-visible"),!0===this.options.closeOnClick&&!0===this.options.contentOverlay&&this.$overlay.removeClass("is-closable"),this.$triggers.attr("aria-expanded","false"),!0===this.options.trapFocus&&(this.$content.removeAttr("tabindex"),a.Keyboard.releaseFocus(this.$element)),this.$element.one(Object(r.transitionend)(this.$element),function(t){e.$element.addClass("is-closed"),e._removeContentClasses()})}}},{key:"toggle",value:function(t,e){this.$element.hasClass("is-open")?this.close(t,e):this.open(t,e)}},{key:"_handleKeyboard",value:function(t){var e=this;a.Keyboard.handleKey(t,"OffCanvas",{close:function(){return e.close(),e.$lastTrigger.focus(),!0},handled:function(){t.stopPropagation(),t.preventDefault()}})}},{key:"_destroy",value:function(){this.close(),this.$element.off(".zf.trigger .zf.offcanvas"),this.$overlay.off(".zf.offcanvas"),this.onLoadListener&&s()(window).off(this.onLoadListener)}}])&&f(e.prototype,n),o&&f(e,o),i}();g.defaults={closeOnClick:!0,contentOverlay:!0,contentId:null,nested:null,contentScroll:!0,transitionTime:null,transition:"push",forceTo:null,isRevealed:!1,revealOn:null,autoFocus:!0,revealClass:"reveal-for-",trapFocus:!1}},"./js/foundation.util.triggers.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Triggers",function(){return f});var i=n("jquery"),s=n.n(i),o=n("./foundation.core"),r=n("./foundation.util.motion");function a(t){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var l=function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if("".concat(t[e],"MutationObserver")in window)return window["".concat(t[e],"MutationObserver")];return!1}(),c=function(e,n){e.data(n).split(" ").forEach(function(t){s()("#".concat(t))["close"===n?"trigger":"triggerHandler"]("".concat(n,".zf.trigger"),[e])})},f={Listeners:{Basic:{},Global:{}},Initializers:{}};function u(e,t,n){var i,o=Array.prototype.slice.call(arguments,3);s()(window).off(t).on(t,function(t){i&&clearTimeout(i),i=setTimeout(function(){n.apply(null,o)},e||10)})}f.Listeners.Basic={openListener:function(){c(s()(this),"open")},closeListener:function(){s()(this).data("close")?c(s()(this),"close"):s()(this).trigger("close.zf.trigger")},toggleListener:function(){s()(this).data("toggle")?c(s()(this),"toggle"):s()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=s()(this).data("closable");""!==e?r.Motion.animateOut(s()(this),e,function(){s()(this).trigger("closed.zf")}):s()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=s()(this).data("toggle-focus");s()("#".concat(t)).triggerHandler("toggle.zf.trigger",[s()(this)])}},f.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",f.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",f.Listeners.Basic.openListener)},f.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",f.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",f.Listeners.Basic.closeListener)},f.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",f.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",f.Listeners.Basic.toggleListener)},f.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",f.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",f.Listeners.Basic.closeableListener)},f.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",f.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",f.Listeners.Basic.toggleFocusListener)},f.Listeners.Global={resizeListener:function(t){l||t.each(function(){s()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){l||t.each(function(){s()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var n=t.namespace.split(".")[0];s()("[data-".concat(n,"]")).not('[data-yeti-box="'.concat(e,'"]')).each(function(){var t=s()(this);t.triggerHandler("close.zf.trigger",[t])})}},f.Initializers.addClosemeListener=function(t){var e=s()("[data-yeti-box]"),n=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?n.push(t):"object"===a(t)&&"string"==typeof t[0]?n=n.concat(t):console.error("Plugin names must be strings")),e.length){var i=n.map(function(t){return"closeme.zf.".concat(t)}).join(" ");s()(window).off(i).on(i,f.Listeners.Global.closeMeListener)}},f.Initializers.addResizeListener=function(t){var e=s()("[data-resize]");e.length&&u(t,"resize.zf.trigger",f.Listeners.Global.resizeListener,e)},f.Initializers.addScrollListener=function(t){var e=s()("[data-scroll]");e.length&&u(t,"scroll.zf.trigger",f.Listeners.Global.scrollListener,e)},f.Initializers.addMutationEventsListener=function(t){if(!l)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),n=function(t){var e=s()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var i=0;i<=e.length-1;i++){new l(n).observe(e[i],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},f.Initializers.addSimpleListeners=function(){var t=s()(document);f.Initializers.addOpenListener(t),f.Initializers.addCloseListener(t),f.Initializers.addToggleListener(t),f.Initializers.addCloseableListener(t),f.Initializers.addToggleFocusListener(t)},f.Initializers.addGlobalListeners=function(){var t=s()(document);f.Initializers.addMutationEventsListener(t),f.Initializers.addResizeListener(),f.Initializers.addScrollListener(),f.Initializers.addClosemeListener()},f.init=function(t,e){Object(o.onLoad)(t(window),function(){!0!==t.triggersInitialized&&(f.Initializers.addSimpleListeners(),f.Initializers.addGlobalListeners(),t.triggersInitialized=!0)}),e&&(e.Triggers=f,e.IHearYou=f.Initializers.addGlobalListeners)}},9:function(t,e,n){t.exports=n("./js/entries/plugins/foundation.offcanvas.js")},jquery:function(t,e){t.exports=r}})});
+//# sourceMappingURL=foundation.offcanvas.min.js.map
diff --git a/dist/js/plugins/foundation.offcanvas.min.js.map b/dist/js/plugins/foundation.offcanvas.min.js.map
new file mode 100644 (file)
index 0000000..0da8fe7
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.offcanvas.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.keyboard","./foundation.util.mediaQuery","./foundation.util.motion","./js/entries/plugins/foundation.offcanvas.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_offcanvas__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.offcanvas.js","OffCanvas","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","_this2","className","$element","a","extend","defaults","data","contentClasses","base","reveal","$lastTrigger","$triggers","position","$content","nested","each","index","val","push","init","_init","_events","register","ESCAPE","id","attr","contentId","siblings","first","closest","console","warn","transition","removeClass","addClass","concat","document","find","is","match","contentOverlay","overlay","createElement","overlayPosition","css","setAttribute","$overlay","insertAfter","append","revealOnClass","RegExp","revealClass","exec","isRevealed","revealOn","_setMQChecker","transitionTime","_removeContentClasses","off","on","open.zf.trigger","open","close.zf.trigger","close","toggle.zf.trigger","toggle","keydown.zf.offcanvas","_handleKeyboard","closeOnClick","click.zf.offcanvas","_this","onLoadListener","atLeast","hasReveal","join","_addContentClasses","event","elem","scrollHeight","clientHeight","scrollTop","allowUp","allowDown","lastY","originalEvent","pageY","up","down","stopPropagation","preventDefault","trigger","hasClass","forceTo","scrollTo","body","contentScroll","_stopScrolling","_recordScrollable","_stopScrollPropagation","autoFocus","one","canvasFocus","eq","focus","trapFocus","cb","removeAttr","releaseFocus","e","_this3","handleKey","handled","./js/foundation.util.triggers.js","Triggers","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","MutationObserver","prefixes","triggers","el","type","split","forEach","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","listener","timer","args","Array","slice","clearTimeout","setTimeout","openListener","closeListener","toggleListener","closeableListener","animation","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","scrollListener","closeMeListener","pluginId","namespace","not","addClosemeListener","pluginName","yetiBoxes","plugNames","error","listeners","map","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","$target","attributeName","pageYOffset","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","$","Foundation","triggersInitialized","IHearYou","9","jquery"],"mappings":"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","file":"foundation.offcanvas.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.offcanvas\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.offcanvas\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 9);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.offcanvas.js\":\n/*!****************************************************!*\\\n  !*** ./js/entries/plugins/foundation.offcanvas.js ***!\n  \\****************************************************/\n/*! exports provided: Foundation, OffCanvas */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_offcanvas__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.offcanvas */ \"./js/foundation.offcanvas.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"OffCanvas\", function() { return _foundation_offcanvas__WEBPACK_IMPORTED_MODULE_1__[\"OffCanvas\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_offcanvas__WEBPACK_IMPORTED_MODULE_1__[\"OffCanvas\"], 'OffCanvas');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.offcanvas.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.offcanvas.js ***!\n  \\************************************/\n/*! exports provided: OffCanvas */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"OffCanvas\", function() { return OffCanvas; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n/**\n * OffCanvas module.\n * @module foundation.offcanvas\n * @requires foundation.util.keyboard\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nvar OffCanvas =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(OffCanvas, _Plugin);\n\n  function OffCanvas() {\n    _classCallCheck(this, OffCanvas);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(OffCanvas).apply(this, arguments));\n  }\n\n  _createClass(OffCanvas, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of an off-canvas wrapper.\n     * @class\n     * @name OffCanvas\n     * @fires OffCanvas#init\n     * @param {Object} element - jQuery object to initialize.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      var _this2 = this;\n\n      this.className = 'OffCanvas'; // ie9 back compat\n\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, OffCanvas.defaults, this.$element.data(), options);\n      this.contentClasses = {\n        base: [],\n        reveal: []\n      };\n      this.$lastTrigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      this.position = 'left';\n      this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()();\n      this.nested = !!this.options.nested; // Defines the CSS transition/position classes of the off-canvas content container.\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(['push', 'overlap']).each(function (index, val) {\n        _this2.contentClasses.base.push('has-transition-' + val);\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(['left', 'right', 'top', 'bottom']).each(function (index, val) {\n        _this2.contentClasses.base.push('has-position-' + val);\n\n        _this2.contentClasses.reveal.push('has-reveal-' + val);\n      }); // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_4__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"]._init();\n\n      this._init();\n\n      this._events();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('OffCanvas', {\n        'ESCAPE': 'close'\n      });\n    }\n    /**\n     * Initializes the off-canvas wrapper by adding the exit overlay (if needed).\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var id = this.$element.attr('id');\n      this.$element.attr('aria-hidden', 'true'); // Find off-canvas content, either by ID (if specified), by siblings or by closest selector (fallback)\n\n      if (this.options.contentId) {\n        this.$content = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + this.options.contentId);\n      } else if (this.$element.siblings('[data-off-canvas-content]').length) {\n        this.$content = this.$element.siblings('[data-off-canvas-content]').first();\n      } else {\n        this.$content = this.$element.closest('[data-off-canvas-content]').first();\n      }\n\n      if (!this.options.contentId) {\n        // Assume that the off-canvas element is nested if it isn't a sibling of the content\n        this.nested = this.$element.siblings('[data-off-canvas-content]').length === 0;\n      } else if (this.options.contentId && this.options.nested === null) {\n        // Warning if using content ID without setting the nested option\n        // Once the element is nested it is required to work properly in this case\n        console.warn('Remember to use the nested option if using the content ID option!');\n      }\n\n      if (this.nested === true) {\n        // Force transition overlap if nested\n        this.options.transition = 'overlap'; // Remove appropriate classes if already assigned in markup\n\n        this.$element.removeClass('is-transition-push');\n      }\n\n      this.$element.addClass(\"is-transition-\".concat(this.options.transition, \" is-closed\")); // Find triggers that affect this element and add aria-expanded to them\n\n      this.$triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).find('[data-open=\"' + id + '\"], [data-close=\"' + id + '\"], [data-toggle=\"' + id + '\"]').attr('aria-expanded', 'false').attr('aria-controls', id); // Get position by checking for related CSS class\n\n      this.position = this.$element.is('.position-left, .position-top, .position-right, .position-bottom') ? this.$element.attr('class').match(/position\\-(left|top|right|bottom)/)[1] : this.position; // Add an overlay over the content if necessary\n\n      if (this.options.contentOverlay === true) {\n        var overlay = document.createElement('div');\n        var overlayPosition = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$element).css(\"position\") === 'fixed' ? 'is-overlay-fixed' : 'is-overlay-absolute';\n        overlay.setAttribute('class', 'js-off-canvas-overlay ' + overlayPosition);\n        this.$overlay = jquery__WEBPACK_IMPORTED_MODULE_0___default()(overlay);\n\n        if (overlayPosition === 'is-overlay-fixed') {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.$overlay).insertAfter(this.$element);\n        } else {\n          this.$content.append(this.$overlay);\n        }\n      } // Get the revealOn option from the class.\n\n\n      var revealOnRegExp = new RegExp(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"RegExpEscape\"])(this.options.revealClass) + '([^\\\\s]+)', 'g');\n      var revealOnClass = revealOnRegExp.exec(this.$element[0].className);\n\n      if (revealOnClass) {\n        this.options.isRevealed = true;\n        this.options.revealOn = this.options.revealOn || revealOnClass[1];\n      } // Ensure the `reveal-on-*` class is set.\n\n\n      if (this.options.isRevealed === true && this.options.revealOn) {\n        this.$element.first().addClass(\"\".concat(this.options.revealClass).concat(this.options.revealOn));\n\n        this._setMQChecker();\n      }\n\n      if (this.options.transitionTime) {\n        this.$element.css('transition-duration', this.options.transitionTime);\n      } // Initally remove all transition/position CSS classes from off-canvas content container.\n\n\n      this._removeContentClasses();\n    }\n    /**\n     * Adds event handlers to the off-canvas wrapper and the exit overlay.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this.$element.off('.zf.trigger .zf.offcanvas').on({\n        'open.zf.trigger': this.open.bind(this),\n        'close.zf.trigger': this.close.bind(this),\n        'toggle.zf.trigger': this.toggle.bind(this),\n        'keydown.zf.offcanvas': this._handleKeyboard.bind(this)\n      });\n\n      if (this.options.closeOnClick === true) {\n        var $target = this.options.contentOverlay ? this.$overlay : this.$content;\n        $target.on({\n          'click.zf.offcanvas': this.close.bind(this)\n        });\n      }\n    }\n    /**\n     * Applies event listener for elements that will reveal at certain breakpoints.\n     * @private\n     */\n\n  }, {\n    key: \"_setMQChecker\",\n    value: function _setMQChecker() {\n      var _this = this;\n\n      this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"].atLeast(_this.options.revealOn)) {\n          _this.reveal(true);\n        }\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"].atLeast(_this.options.revealOn)) {\n          _this.reveal(true);\n        } else {\n          _this.reveal(false);\n        }\n      });\n    }\n    /**\n     * Removes the CSS transition/position classes of the off-canvas content container.\n     * Removing the classes is important when another off-canvas gets opened that uses the same content container.\n     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n     * @private\n     */\n\n  }, {\n    key: \"_removeContentClasses\",\n    value: function _removeContentClasses(hasReveal) {\n      if (typeof hasReveal !== 'boolean') {\n        this.$content.removeClass(this.contentClasses.base.join(' '));\n      } else if (hasReveal === false) {\n        this.$content.removeClass(\"has-reveal-\".concat(this.position));\n      }\n    }\n    /**\n     * Adds the CSS transition/position classes of the off-canvas content container, based on the opening off-canvas element.\n     * Beforehand any transition/position class gets removed.\n     * @param {Boolean} hasReveal - true if related off-canvas element is revealed.\n     * @private\n     */\n\n  }, {\n    key: \"_addContentClasses\",\n    value: function _addContentClasses(hasReveal) {\n      this._removeContentClasses(hasReveal);\n\n      if (typeof hasReveal !== 'boolean') {\n        this.$content.addClass(\"has-transition-\".concat(this.options.transition, \" has-position-\").concat(this.position));\n      } else if (hasReveal === true) {\n        this.$content.addClass(\"has-reveal-\".concat(this.position));\n      }\n    }\n    /**\n     * Handles the revealing/hiding the off-canvas at breakpoints, not the same as open.\n     * @param {Boolean} isRevealed - true if element should be revealed.\n     * @function\n     */\n\n  }, {\n    key: \"reveal\",\n    value: function reveal(isRevealed) {\n      if (isRevealed) {\n        this.close();\n        this.isRevealed = true;\n        this.$element.attr('aria-hidden', 'false');\n        this.$element.off('open.zf.trigger toggle.zf.trigger');\n        this.$element.removeClass('is-closed');\n      } else {\n        this.isRevealed = false;\n        this.$element.attr('aria-hidden', 'true');\n        this.$element.off('open.zf.trigger toggle.zf.trigger').on({\n          'open.zf.trigger': this.open.bind(this),\n          'toggle.zf.trigger': this.toggle.bind(this)\n        });\n        this.$element.addClass('is-closed');\n      }\n\n      this._addContentClasses(isRevealed);\n    }\n    /**\n     * Stops scrolling of the body when offcanvas is open on mobile Safari and other troublesome browsers.\n     * @private\n     */\n\n  }, {\n    key: \"_stopScrolling\",\n    value: function _stopScrolling(event) {\n      return false;\n    } // Taken and adapted from http://stackoverflow.com/questions/16889447/prevent-full-page-scrolling-ios\n    // Only really works for y, not sure how to extend to x or if we need to.\n\n  }, {\n    key: \"_recordScrollable\",\n    value: function _recordScrollable(event) {\n      var elem = this; // called from event handler context with this as elem\n      // If the element is scrollable (content overflows), then...\n\n      if (elem.scrollHeight !== elem.clientHeight) {\n        // If we're at the top, scroll down one pixel to allow scrolling up\n        if (elem.scrollTop === 0) {\n          elem.scrollTop = 1;\n        } // If we're at the bottom, scroll up one pixel to allow scrolling down\n\n\n        if (elem.scrollTop === elem.scrollHeight - elem.clientHeight) {\n          elem.scrollTop = elem.scrollHeight - elem.clientHeight - 1;\n        }\n      }\n\n      elem.allowUp = elem.scrollTop > 0;\n      elem.allowDown = elem.scrollTop < elem.scrollHeight - elem.clientHeight;\n      elem.lastY = event.originalEvent.pageY;\n    }\n  }, {\n    key: \"_stopScrollPropagation\",\n    value: function _stopScrollPropagation(event) {\n      var elem = this; // called from event handler context with this as elem\n\n      var up = event.pageY < elem.lastY;\n      var down = !up;\n      elem.lastY = event.pageY;\n\n      if (up && elem.allowUp || down && elem.allowDown) {\n        event.stopPropagation();\n      } else {\n        event.preventDefault();\n      }\n    }\n    /**\n     * Opens the off-canvas menu.\n     * @function\n     * @param {Object} event - Event object passed from listener.\n     * @param {jQuery} trigger - element that triggered the off-canvas to open.\n     * @fires Offcanvas#opened\n     * @todo also trigger 'open' event?\n     */\n\n  }, {\n    key: \"open\",\n    value: function open(event, trigger) {\n      if (this.$element.hasClass('is-open') || this.isRevealed) {\n        return;\n      }\n\n      var _this = this;\n\n      if (trigger) {\n        this.$lastTrigger = trigger;\n      }\n\n      if (this.options.forceTo === 'top') {\n        window.scrollTo(0, 0);\n      } else if (this.options.forceTo === 'bottom') {\n        window.scrollTo(0, document.body.scrollHeight);\n      }\n\n      if (this.options.transitionTime && this.options.transition !== 'overlap') {\n        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', this.options.transitionTime);\n      } else {\n        this.$element.siblings('[data-off-canvas-content]').css('transition-duration', '');\n      }\n\n      this.$element.addClass('is-open').removeClass('is-closed');\n      this.$triggers.attr('aria-expanded', 'true');\n      this.$element.attr('aria-hidden', 'false');\n      this.$content.addClass('is-open-' + this.position); // If `contentScroll` is set to false, add class and disable scrolling on touch devices.\n\n      if (this.options.contentScroll === false) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').addClass('is-off-canvas-open').on('touchmove', this._stopScrolling);\n        this.$element.on('touchstart', this._recordScrollable);\n        this.$element.on('touchmove', this._stopScrollPropagation);\n      }\n\n      if (this.options.contentOverlay === true) {\n        this.$overlay.addClass('is-visible');\n      }\n\n      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n        this.$overlay.addClass('is-closable');\n      }\n\n      if (this.options.autoFocus === true) {\n        this.$element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"transitionend\"])(this.$element), function () {\n          if (!_this.$element.hasClass('is-open')) {\n            return; // exit if prematurely closed\n          }\n\n          var canvasFocus = _this.$element.find('[data-autofocus]');\n\n          if (canvasFocus.length) {\n            canvasFocus.eq(0).focus();\n          } else {\n            _this.$element.find('a, button').eq(0).focus();\n          }\n        });\n      }\n\n      if (this.options.trapFocus === true) {\n        this.$content.attr('tabindex', '-1');\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].trapFocus(this.$element);\n      }\n\n      this._addContentClasses();\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#opened\n       */\n\n\n      this.$element.trigger('opened.zf.offcanvas');\n    }\n    /**\n     * Closes the off-canvas menu.\n     * @function\n     * @param {Function} cb - optional cb to fire after closure.\n     * @fires Offcanvas#closed\n     */\n\n  }, {\n    key: \"close\",\n    value: function close(cb) {\n      if (!this.$element.hasClass('is-open') || this.isRevealed) {\n        return;\n      }\n\n      var _this = this;\n\n      this.$element.removeClass('is-open');\n      this.$element.attr('aria-hidden', 'true')\n      /**\n       * Fires when the off-canvas menu opens.\n       * @event Offcanvas#closed\n       */\n      .trigger('closed.zf.offcanvas');\n      this.$content.removeClass('is-open-left is-open-top is-open-right is-open-bottom'); // If `contentScroll` is set to false, remove class and re-enable scrolling on touch devices.\n\n      if (this.options.contentScroll === false) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').removeClass('is-off-canvas-open').off('touchmove', this._stopScrolling);\n        this.$element.off('touchstart', this._recordScrollable);\n        this.$element.off('touchmove', this._stopScrollPropagation);\n      }\n\n      if (this.options.contentOverlay === true) {\n        this.$overlay.removeClass('is-visible');\n      }\n\n      if (this.options.closeOnClick === true && this.options.contentOverlay === true) {\n        this.$overlay.removeClass('is-closable');\n      }\n\n      this.$triggers.attr('aria-expanded', 'false');\n\n      if (this.options.trapFocus === true) {\n        this.$content.removeAttr('tabindex');\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].releaseFocus(this.$element);\n      } // Listen to transitionEnd and add class when done.\n\n\n      this.$element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"transitionend\"])(this.$element), function (e) {\n        _this.$element.addClass('is-closed');\n\n        _this._removeContentClasses();\n      });\n    }\n    /**\n     * Toggles the off-canvas menu open or closed.\n     * @function\n     * @param {Object} event - Event object passed from listener.\n     * @param {jQuery} trigger - element that triggered the off-canvas to open.\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle(event, trigger) {\n      if (this.$element.hasClass('is-open')) {\n        this.close(event, trigger);\n      } else {\n        this.open(event, trigger);\n      }\n    }\n    /**\n     * Handles keyboard input when detected. When the escape key is pressed, the off-canvas menu closes, and focus is restored to the element that opened the menu.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_handleKeyboard\",\n    value: function _handleKeyboard(e) {\n      var _this3 = this;\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'OffCanvas', {\n        close: function close() {\n          _this3.close();\n\n          _this3.$lastTrigger.focus();\n\n          return true;\n        },\n        handled: function handled() {\n          e.stopPropagation();\n          e.preventDefault();\n        }\n      });\n    }\n    /**\n     * Destroys the offcanvas plugin.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.close();\n      this.$element.off('.zf.trigger .zf.offcanvas');\n      this.$overlay.off('.zf.offcanvas');\n      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n    }\n  }]);\n\n  return OffCanvas;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n\nOffCanvas.defaults = {\n  /**\n   * Allow the user to click outside of the menu to close it.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Adds an overlay on top of `[data-off-canvas-content]`.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentOverlay: true,\n\n  /**\n   * Target an off-canvas content container by ID that may be placed anywhere. If null the closest content container will be taken.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  contentId: null,\n\n  /**\n   * Define the off-canvas element is nested in an off-canvas content. This is required when using the contentId option for a nested element.\n   * @option\n   * @type {boolean}\n   * @default null\n   */\n  nested: null,\n\n  /**\n   * Enable/disable scrolling of the main content when an off canvas panel is open.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  contentScroll: true,\n\n  /**\n   * Amount of time in ms the open and close transition requires. If none selected, pulls from body style.\n   * @option\n   * @type {number}\n   * @default null\n   */\n  transitionTime: null,\n\n  /**\n   * Type of transition for the offcanvas menu. Options are 'push', 'detached' or 'slide'.\n   * @option\n   * @type {string}\n   * @default push\n   */\n  transition: 'push',\n\n  /**\n   * Force the page to scroll to top or bottom on open.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  forceTo: null,\n\n  /**\n   * Allow the offcanvas to remain open for certain breakpoints.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  isRevealed: false,\n\n  /**\n   * Breakpoint at which to reveal. JS will use a RegExp to target standard classes, if changing classnames, pass your class with the `revealClass` option.\n   * @option\n   * @type {?string}\n   * @default null\n   */\n  revealOn: null,\n\n  /**\n   * Force focus to the offcanvas on open. If true, will focus the opening trigger on close.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  autoFocus: true,\n\n  /**\n   * Class used to force an offcanvas to remain open. Foundation defaults for this are `reveal-for-large` & `reveal-for-medium`.\n   * @option\n   * @type {string}\n   * @default reveal-for-\n   * @todo improve the regex testing for this.\n   */\n  revealClass: 'reveal-for-',\n\n  /**\n   * Triggers optional focus trapping when opening an offcanvas. Sets tabindex of [data-off-canvas-content] to -1 for accessibility purposes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  trapFocus: false\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 9:\n/*!**********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.offcanvas.js ***!\n  \\**********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.offcanvas.js */\"./js/entries/plugins/foundation.offcanvas.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.offcanvas.js.map"]}
\ No newline at end of file
index 94814ab8c46dde3ac6966ca218841866dc09fb99..84bddb1534b2fe3ca3ab42e0113ca53553d38f66 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.imageLoader"), require("./foundation.util.keyboard"), require("./foundation.util.motion"), require("./foundation.util.timer"), require("./foundation.util.touch"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.imageLoader", "./foundation.util.keyboard", "./foundation.util.motion", "./foundation.util.timer", "./foundation.util.touch", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.orbit"] = factory(require("./foundation.core"), require("./foundation.util.imageLoader"), require("./foundation.util.keyboard"), require("./foundation.util.motion"), require("./foundation.util.timer"), require("./foundation.util.touch"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.orbit"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.imageLoader"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.timer"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.touch"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_timer__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 89);
+/******/       return __webpack_require__(__webpack_require__.s = 10);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.imageLoader":
+/*!****************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.imageLoader"],"amd":"./foundation.util.imageLoader","commonjs":"./foundation.util.imageLoader","commonjs2":"./foundation.util.imageLoader"} ***!
+  \****************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;
 
 /***/ }),
 
-/***/ 10:
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {onImagesLoaded: window.Foundation.onImagesLoaded};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
 /***/ }),
 
-/***/ 12:
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Touch: window.Foundation.Touch};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.util.timer":
+/*!****************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.timer"],"amd":"./foundation.util.timer","commonjs":"./foundation.util.timer","commonjs2":"./foundation.util.timer"} ***!
+  \****************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_timer__;
 
 /***/ }),
 
-/***/ 23:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
-
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_orbit__ = __webpack_require__(53);
-
-
+/***/ "./foundation.util.touch":
+/*!****************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.touch"],"amd":"./foundation.util.touch","commonjs":"./foundation.util.touch","commonjs2":"./foundation.util.touch"} ***!
+  \****************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_orbit__["a" /* Orbit */], 'Orbit');
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;
 
 /***/ }),
 
-/***/ 3:
-/***/ (function(module, exports) {
-
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
+/***/ "./js/entries/plugins/foundation.orbit.js":
+/*!************************************************!*\
+  !*** ./js/entries/plugins/foundation.orbit.js ***!
+  \************************************************/
+/*! exports provided: Foundation, Orbit */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-/***/ }),
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-/***/ 4:
-/***/ (function(module, exports) {
+/* harmony import */ var _foundation_orbit__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.orbit */ "./js/foundation.orbit.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Orbit", function() { return _foundation_orbit__WEBPACK_IMPORTED_MODULE_1__["Orbit"]; });
 
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
 
-/***/ }),
 
-/***/ 5:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_orbit__WEBPACK_IMPORTED_MODULE_1__["Orbit"], 'Orbit');
 
-module.exports = {Keyboard: window.Foundation.Keyboard};
 
 /***/ }),
 
-/***/ 53:
+/***/ "./js/foundation.orbit.js":
+/*!********************************!*\
+  !*** ./js/foundation.orbit.js ***!
+  \********************************/
+/*! exports provided: Orbit */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Orbit; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_timer__ = __webpack_require__(78);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_timer___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_timer__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_imageLoader__ = __webpack_require__(10);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_imageLoader___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_util_imageLoader__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__foundation_util_touch__ = __webpack_require__(12);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_7__foundation_util_touch___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_7__foundation_util_touch__);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Orbit", function() { return Orbit; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.timer */ "./foundation.util.timer");
+/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__);
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.imageLoader */ "./foundation.util.imageLoader");
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__);
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.util.touch */ "./foundation.util.touch");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return 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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -189,17 +247,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.touch
  */
 
-var Orbit = function (_Plugin) {
+var Orbit =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Orbit, _Plugin);
 
   function Orbit() {
     _classCallCheck(this, Orbit);
 
-    return _possibleConstructorReturn(this, (Orbit.__proto__ || Object.getPrototypeOf(Orbit)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Orbit).apply(this, arguments));
   }
 
   _createClass(Orbit, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
     * Creates a new instance of an orbit carousel.
@@ -210,14 +270,14 @@ var Orbit = function (_Plugin) {
     */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Orbit.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Orbit.defaults, this.$element.data(), options);
       this.className = 'Orbit'; // ie9 back compat
 
-      __WEBPACK_IMPORTED_MODULE_7__foundation_util_touch__["Touch"].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a); // Touch init is idempotent, we just need to make sure it's initialied.
+      _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__["Touch"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Touch init is idempotent, we just need to make sure it's initialied.
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('Orbit', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('Orbit', {
         'ltr': {
           'ARROW_RIGHT': 'next',
           'ARROW_LEFT': 'previous'
@@ -228,7 +288,6 @@ var Orbit = function (_Plugin) {
         }
       });
     }
-
     /**
     * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.
     * @function
@@ -236,18 +295,16 @@ var Orbit = function (_Plugin) {
     */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
       // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide
       this._reset();
 
-      this.$wrapper = this.$element.find('.' + this.options.containerClass);
-      this.$slides = this.$element.find('.' + this.options.slideClass);
-
+      this.$wrapper = this.$element.find(".".concat(this.options.containerClass));
+      this.$slides = this.$element.find(".".concat(this.options.slideClass));
       var $images = this.$element.find('img'),
           initActive = this.$slides.filter('.is-active'),
-          id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_5__foundation_util_core__["GetYoDigits"])(6, 'orbit');
-
+          id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__["GetYoDigits"])(6, 'orbit');
       this.$element.attr({
         'data-resize': id,
         'id': id
@@ -262,9 +319,10 @@ var Orbit = function (_Plugin) {
       }
 
       if ($images.length) {
-        __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_4__foundation_util_imageLoader__["onImagesLoaded"])($images, this._prepareForOrbit.bind(this));
+        Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__["onImagesLoaded"])($images, this._prepareForOrbit.bind(this));
       } else {
         this._prepareForOrbit(); //hehe
+
       }
 
       if (this.options.bullets) {
@@ -282,7 +340,6 @@ var Orbit = function (_Plugin) {
         this.$wrapper.attr('tabindex', 0);
       }
     }
-
     /**
     * Creates a jQuery collection of bullets, if they are being used.
     * @function
@@ -290,21 +347,21 @@ var Orbit = function (_Plugin) {
     */
 
   }, {
-    key: '_loadBullets',
+    key: "_loadBullets",
     value: function _loadBullets() {
-      this.$bullets = this.$element.find('.' + this.options.boxOfBullets).find('button');
+      this.$bullets = this.$element.find(".".concat(this.options.boxOfBullets)).find('button');
     }
-
     /**
     * Sets a `timer` object on the orbit, and starts the counter for the next slide.
     * @function
     */
 
   }, {
-    key: 'geoSync',
+    key: "geoSync",
     value: function geoSync() {
       var _this = this;
-      this.timer = new __WEBPACK_IMPORTED_MODULE_3__foundation_util_timer__["Timer"](this.$element, {
+
+      this.timer = new _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__["Timer"](this.$element, {
         duration: this.options.timerDelay,
         infinite: false
       }, function () {
@@ -312,7 +369,6 @@ var Orbit = function (_Plugin) {
       });
       this.timer.start();
     }
-
     /**
     * Sets wrapper and slide heights for the orbit.
     * @function
@@ -320,12 +376,12 @@ var Orbit = function (_Plugin) {
     */
 
   }, {
-    key: '_prepareForOrbit',
+    key: "_prepareForOrbit",
     value: function _prepareForOrbit() {
       var _this = this;
+
       this._setWrapperHeight();
     }
-
     /**
     * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.
     * @function
@@ -334,7 +390,7 @@ var Orbit = function (_Plugin) {
     */
 
   }, {
-    key: '_setWrapperHeight',
+    key: "_setWrapperHeight",
     value: function _setWrapperHeight(cb) {
       //rewrite this to `for` loop
       var max = 0,
@@ -344,24 +400,29 @@ var Orbit = function (_Plugin) {
 
       this.$slides.each(function () {
         temp = this.getBoundingClientRect().height;
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).attr('data-slide', counter);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('data-slide', counter); // hide all slides but the active one
 
-        if (!/mui/g.test(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {
-          //if not the active slide, set css position and display property
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).css({ 'position': 'relative', 'display': 'none' });
+        if (!/mui/g.test(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css({
+            'display': 'none'
+          });
         }
+
         max = temp > max ? temp : max;
         counter++;
       });
 
       if (counter === this.$slides.length) {
-        this.$wrapper.css({ 'height': max }); //only change the wrapper height property once.
+        this.$wrapper.css({
+          'height': max
+        }); //only change the wrapper height property once.
+
         if (cb) {
           cb(max);
         } //fire callback with max height dimension.
+
       }
     }
-
     /**
     * Sets the max-height of each slide.
     * @function
@@ -369,13 +430,12 @@ var Orbit = function (_Plugin) {
     */
 
   }, {
-    key: '_setSlideHeight',
+    key: "_setSlideHeight",
     value: function _setSlideHeight(height) {
       this.$slides.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).css('max-height', height);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css('max-height', height);
       });
     }
-
     /**
     * Adds event listeners to basically everything within the element.
     * @function
@@ -383,34 +443,37 @@ var Orbit = function (_Plugin) {
     */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
-      var _this = this;
-
-      //***************************************
+      var _this = this; //***************************************
       //**Now using custom event - thanks to:**
       //**      Yohai Ararat of Toronto      **
       //***************************************
       //
+
+
       this.$element.off('.resizeme.zf.trigger').on({
         'resizeme.zf.trigger': this._prepareForOrbit.bind(this)
       });
-      if (this.$slides.length > 1) {
 
+      if (this.$slides.length > 1) {
         if (this.options.swipe) {
           this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) {
             e.preventDefault();
+
             _this.changeSlide(true);
           }).on('swiperight.zf.orbit', function (e) {
             e.preventDefault();
+
             _this.changeSlide(false);
           });
-        }
-        //***************************************
+        } //***************************************
+
 
         if (this.options.autoPlay) {
           this.$slides.on('click.zf.orbit', function () {
             _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);
+
             _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();
           });
 
@@ -426,12 +489,12 @@ var Orbit = function (_Plugin) {
         }
 
         if (this.options.navButtons) {
-          var $controls = this.$element.find('.' + this.options.nextClass + ', .' + this.options.prevClass);
-          $controls.attr('tabindex', 0)
-          //also need to handle enter/return and spacebar key presses
+          var $controls = this.$element.find(".".concat(this.options.nextClass, ", .").concat(this.options.prevClass));
+          $controls.attr('tabindex', 0) //also need to handle enter/return and spacebar key presses
           .on('click.zf.orbit touchend.zf.orbit', function (e) {
             e.preventDefault();
-            _this.changeSlide(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).hasClass(_this.options.nextClass));
+
+            _this.changeSlide(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).hasClass(_this.options.nextClass));
           });
         }
 
@@ -440,7 +503,9 @@ var Orbit = function (_Plugin) {
             if (/is-active/g.test(this.className)) {
               return false;
             } //if this is active, kick out of function.
-            var idx = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('slide'),
+
+
+            var idx = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('slide'),
                 ltr = idx > _this.$slides.filter('.is-active').data('slide'),
                 $slide = _this.$slides.eq(idx);
 
@@ -451,16 +516,16 @@ var Orbit = function (_Plugin) {
         if (this.options.accessible) {
           this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) {
             // handle keyboard event with keyboard util
-            __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'Orbit', {
-              next: function () {
+            _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'Orbit', {
+              next: function next() {
                 _this.changeSlide(true);
               },
-              previous: function () {
+              previous: function previous() {
                 _this.changeSlide(false);
               },
-              handled: function () {
+              handled: function handled() {
                 // if bullet is focused, make sure focus moves
-                if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).is(_this.$bullets)) {
+                if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is(_this.$bullets)) {
                   _this.$bullets.filter('.is-active').focus();
                 }
               }
@@ -469,13 +534,12 @@ var Orbit = function (_Plugin) {
         }
       }
     }
-
     /**
      * Resets Orbit so it can be reinitialized
      */
 
   }, {
-    key: '_reset',
+    key: "_reset",
     value: function _reset() {
       // Don't do anything if there are no slides (first run)
       if (typeof this.$slides == 'undefined') {
@@ -484,52 +548,50 @@ var Orbit = function (_Plugin) {
 
       if (this.$slides.length > 1) {
         // Remove old events
-        this.$element.off('.zf.orbit').find('*').off('.zf.orbit');
+        this.$element.off('.zf.orbit').find('*').off('.zf.orbit'); // Restart timer if autoPlay is enabled
 
-        // Restart timer if autoPlay is enabled
         if (this.options.autoPlay) {
           this.timer.restart();
-        }
+        } // Reset all sliddes
+
 
-        // Reset all sliddes
         this.$slides.each(function (el) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide();
-        });
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide();
+        }); // Show the first slide
 
-        // Show the first slide
-        this.$slides.first().addClass('is-active').show();
+        this.$slides.first().addClass('is-active').show(); // Triggers when the slide has finished animating
 
-        // Triggers when the slide has finished animating
-        this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);
+        this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); // Select first bullet if bullets are present
 
-        // Select first bullet if bullets are present
         if (this.options.bullets) {
           this._updateBullets(0);
         }
       }
     }
-
     /**
     * Changes the current slide to a new one.
     * @function
-    * @param {Boolean} isLTR - flag if the slide should move left to right.
+    * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.
     * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.
     * @param {Number} idx - the index of the new slide in its collection, if one chosen.
     * @fires Orbit#slidechange
     */
 
   }, {
-    key: 'changeSlide',
+    key: "changeSlide",
     value: function changeSlide(isLTR, chosenSlide, idx) {
       if (!this.$slides) {
         return;
       } // Don't freak out if we're in the middle of cleanup
+
+
       var $curSlide = this.$slides.filter('.is-active').eq(0);
 
       if (/mui/g.test($curSlide[0].className)) {
         return false;
       } //if the slide is currently animating, kick out of the function
 
+
       var $firstSlide = this.$slides.first(),
           $lastSlide = this.$slides.last(),
           dirIn = isLTR ? 'Right' : 'Left',
@@ -540,8 +602,8 @@ var Orbit = function (_Plugin) {
       if (!chosenSlide) {
         //most of the time, this will be auto played or clicked from the navButtons.
         $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!
-        this.options.infiniteWrap ? $curSlide.next('.' + this.options.slideClass).length ? $curSlide.next('.' + this.options.slideClass) : $firstSlide : $curSlide.next('.' + this.options.slideClass) : //pick next slide if moving left to right
-        this.options.infiniteWrap ? $curSlide.prev('.' + this.options.slideClass).length ? $curSlide.prev('.' + this.options.slideClass) : $lastSlide : $curSlide.prev('.' + this.options.slideClass); //pick prev slide if moving right to left
+        this.options.infiniteWrap ? $curSlide.next(".".concat(this.options.slideClass)).length ? $curSlide.next(".".concat(this.options.slideClass)) : $firstSlide : $curSlide.next(".".concat(this.options.slideClass)) : //pick next slide if moving left to right
+        this.options.infiniteWrap ? $curSlide.prev(".".concat(this.options.slideClass)).length ? $curSlide.prev(".".concat(this.options.slideClass)) : $lastSlide : $curSlide.prev(".".concat(this.options.slideClass)); //pick prev slide if moving right to left
       } else {
         $newSlide = chosenSlide;
       }
@@ -555,24 +617,28 @@ var Orbit = function (_Plugin) {
 
         if (this.options.bullets) {
           idx = idx || this.$slides.index($newSlide); //grab index to update bullets
+
           this._updateBullets(idx);
         }
 
         if (this.options.useMUI && !this.$element.is(':hidden')) {
-          __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["Motion"].animateIn($newSlide.addClass('is-active').css({ 'position': 'absolute', 'top': 0 }), this.options['animInFrom' + dirIn], function () {
-            $newSlide.css({ 'position': 'relative', 'display': 'block' }).attr('aria-live', 'polite');
+          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateIn($newSlide.addClass('is-active'), this.options["animInFrom".concat(dirIn)], function () {
+            $newSlide.css({
+              'display': 'block'
+            }).attr('aria-live', 'polite');
           });
-
-          __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["Motion"].animateOut($curSlide.removeClass('is-active'), this.options['animOutTo' + dirOut], function () {
+          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut($curSlide.removeClass('is-active'), this.options["animOutTo".concat(dirOut)], function () {
             $curSlide.removeAttr('aria-live');
+
             if (_this.options.autoPlay && !_this.timer.isPaused) {
               _this.timer.restart();
-            }
-            //do stuff?
+            } //do stuff?
+
           });
         } else {
           $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();
           $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();
+
           if (this.options.autoPlay && !this.timer.isPaused) {
             this.timer.restart();
           }
@@ -581,10 +647,11 @@ var Orbit = function (_Plugin) {
         * Triggers when the slide has finished animating in.
         * @event Orbit#slidechange
         */
+
+
         this.$element.trigger('slidechange.zf.orbit', [$newSlide]);
       }
     }
-
     /**
     * Updates the active state of the bullets, if displayed.
     * @function
@@ -593,27 +660,26 @@ var Orbit = function (_Plugin) {
     */
 
   }, {
-    key: '_updateBullets',
+    key: "_updateBullets",
     value: function _updateBullets(idx) {
-      var $oldBullet = this.$element.find('.' + this.options.boxOfBullets).find('.is-active').removeClass('is-active').blur(),
+      var $oldBullet = this.$element.find(".".concat(this.options.boxOfBullets)).find('.is-active').removeClass('is-active').blur(),
           span = $oldBullet.find('span:last').detach(),
           $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);
     }
-
     /**
     * Destroys the carousel and hides the element.
     * @function
     */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();
     }
   }]);
 
   return Orbit;
-}(__WEBPACK_IMPORTED_MODULE_6__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__["Plugin"]);
 
 Orbit.defaults = {
   /**
@@ -623,6 +689,7 @@ Orbit.defaults = {
   * @default true
   */
   bullets: true,
+
   /**
   * Tells the JS to apply event listeners to nav buttons
   * @option
@@ -630,6 +697,7 @@ Orbit.defaults = {
   * @default true
   */
   navButtons: true,
+
   /**
   * motion-ui animation class to apply
   * @option
@@ -637,6 +705,7 @@ Orbit.defaults = {
   * @default 'slide-in-right'
   */
   animInFromRight: 'slide-in-right',
+
   /**
   * motion-ui animation class to apply
   * @option
@@ -644,6 +713,7 @@ Orbit.defaults = {
   * @default 'slide-out-right'
   */
   animOutToRight: 'slide-out-right',
+
   /**
   * motion-ui animation class to apply
   * @option
@@ -652,6 +722,7 @@ Orbit.defaults = {
   *
   */
   animInFromLeft: 'slide-in-left',
+
   /**
   * motion-ui animation class to apply
   * @option
@@ -659,6 +730,7 @@ Orbit.defaults = {
   * @default 'slide-out-left'
   */
   animOutToLeft: 'slide-out-left',
+
   /**
   * Allows Orbit to automatically animate on page load.
   * @option
@@ -666,6 +738,7 @@ Orbit.defaults = {
   * @default true
   */
   autoPlay: true,
+
   /**
   * Amount of time, in ms, between slide transitions
   * @option
@@ -673,6 +746,7 @@ Orbit.defaults = {
   * @default 5000
   */
   timerDelay: 5000,
+
   /**
   * Allows Orbit to infinitely loop through the slides
   * @option
@@ -680,6 +754,7 @@ Orbit.defaults = {
   * @default true
   */
   infiniteWrap: true,
+
   /**
   * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library
   * @option
@@ -687,6 +762,7 @@ Orbit.defaults = {
   * @default true
   */
   swipe: true,
+
   /**
   * Allows the timing function to pause animation on hover.
   * @option
@@ -694,6 +770,7 @@ Orbit.defaults = {
   * @default true
   */
   pauseOnHover: true,
+
   /**
   * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys
   * @option
@@ -701,6 +778,7 @@ Orbit.defaults = {
   * @default true
   */
   accessible: true,
+
   /**
   * Class applied to the container of Orbit
   * @option
@@ -708,6 +786,7 @@ Orbit.defaults = {
   * @default 'orbit-container'
   */
   containerClass: 'orbit-container',
+
   /**
   * Class applied to individual slides.
   * @option
@@ -715,6 +794,7 @@ Orbit.defaults = {
   * @default 'orbit-slide'
   */
   slideClass: 'orbit-slide',
+
   /**
   * Class applied to the bullet container. You're welcome.
   * @option
@@ -722,6 +802,7 @@ Orbit.defaults = {
   * @default 'orbit-bullets'
   */
   boxOfBullets: 'orbit-bullets',
+
   /**
   * Class applied to the `next` navigation button.
   * @option
@@ -729,6 +810,7 @@ Orbit.defaults = {
   * @default 'orbit-next'
   */
   nextClass: 'orbit-next',
+
   /**
   * Class applied to the `previous` navigation button.
   * @option
@@ -736,8 +818,9 @@ Orbit.defaults = {
   * @default 'orbit-previous'
   */
   prevClass: 'orbit-previous',
+
   /**
-  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatability.
+  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.
   * @option
    * @type {boolean}
   * @default true
@@ -746,22 +829,31 @@ Orbit.defaults = {
 };
 
 
-
 /***/ }),
 
-/***/ 78:
-/***/ (function(module, exports) {
+/***/ 10:
+/*!******************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.orbit.js ***!
+  \******************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-module.exports = {Timer: window.Foundation.Timer};
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.orbit.js */"./js/entries/plugins/foundation.orbit.js");
 
-/***/ }),
 
-/***/ 89:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ }),
 
-module.exports = __webpack_require__(23);
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.orbit.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.orbit.js.map b/dist/js/plugins/foundation.orbit.js.map
new file mode 100644 (file)
index 0000000..83e0a22
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.imageLoader\"],\"amd\":\"./foundation.util.imageLoader\",\"commonjs\":\"./foundation.util.imageLoader\",\"commonjs2\":\"./foundation.util.imageLoader\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.timer\"],\"amd\":\"./foundation.util.timer\",\"commonjs\":\"./foundation.util.timer\",\"commonjs2\":\"./foundation.util.timer\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.touch\"],\"amd\":\"./foundation.util.touch\",\"commonjs\":\"./foundation.util.touch\",\"commonjs2\":\"./foundation.util.touch\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.orbit.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.orbit.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Orbit","element","options","$element","$","extend","defaults","data","className","Touch","init","_init","Keyboard","register","_reset","$wrapper","find","containerClass","$slides","slideClass","$images","initActive","filter","id","GetYoDigits","attr","length","eq","addClass","useMUI","onImagesLoaded","_prepareForOrbit","bind","bullets","_loadBullets","_events","autoPlay","geoSync","accessible","$bullets","boxOfBullets","_this","timer","Timer","duration","timerDelay","infinite","changeSlide","start","_setWrapperHeight","cb","max","temp","counter","each","getBoundingClientRect","height","test","css","off","on","swipe","e","preventDefault","pauseOnHover","pause","navButtons","$controls","nextClass","prevClass","hasClass","idx","ltr","$slide","add","handleKey","next","previous","handled","target","is","focus","restart","el","removeClass","removeAttr","hide","first","show","trigger","_updateBullets","isLTR","chosenSlide","$curSlide","$firstSlide","$lastSlide","last","dirIn","dirOut","$newSlide","infiniteWrap","prev","index","Motion","animateIn","animateOut","isPaused","$oldBullet","blur","span","detach","$newBullet","append","end","Plugin","animInFromRight","animOutToRight","animInFromLeft","animOutToLeft"],"mappings":"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","file":"foundation.orbit.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.timer\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.imageLoader\", \"./foundation.util.keyboard\", \"./foundation.util.motion\", \"./foundation.util.timer\", \"./foundation.util.touch\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.orbit\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.timer\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.orbit\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.imageLoader\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.timer\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_timer__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 10);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_timer__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;","import { Foundation } from './foundation.core';\n\nimport { Orbit } from '../../foundation.orbit';\nFoundation.plugin(Orbit, 'Orbit');\n\nexport { Foundation, Orbit };\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Motion } from './foundation.util.motion';\nimport { Timer } from './foundation.util.timer';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\nimport { Touch } from './foundation.util.touch'\n\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timer\n * @requires foundation.util.imageLoader\n * @requires foundation.util.touch\n */\n\nclass Orbit extends Plugin {\n  /**\n  * Creates a new instance of an orbit carousel.\n  * @class\n  * @name Orbit\n  * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n  * @param {Object} options - Overrides to the default plugin settings.\n  */\n  _setup(element, options){\n    this.$element = element;\n    this.options = $.extend({}, Orbit.defaults, this.$element.data(), options);\n    this.className = 'Orbit'; // ie9 back compat\n\n    Touch.init($); // Touch init is idempotent, we just need to make sure it's initialied.\n\n    this._init();\n\n    Keyboard.register('Orbit', {\n      'ltr': {\n        'ARROW_RIGHT': 'next',\n        'ARROW_LEFT': 'previous'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'next',\n        'ARROW_RIGHT': 'previous'\n      }\n    });\n  }\n\n  /**\n  * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.\n  * @function\n  * @private\n  */\n  _init() {\n    // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide\n    this._reset();\n\n    this.$wrapper = this.$element.find(`.${this.options.containerClass}`);\n    this.$slides = this.$element.find(`.${this.options.slideClass}`);\n\n    var $images = this.$element.find('img'),\n        initActive = this.$slides.filter('.is-active'),\n        id = this.$element[0].id || GetYoDigits(6, 'orbit');\n\n    this.$element.attr({\n      'data-resize': id,\n      'id': id\n    });\n\n    if (!initActive.length) {\n      this.$slides.eq(0).addClass('is-active');\n    }\n\n    if (!this.options.useMUI) {\n      this.$slides.addClass('no-motionui');\n    }\n\n    if ($images.length) {\n      onImagesLoaded($images, this._prepareForOrbit.bind(this));\n    } else {\n      this._prepareForOrbit();//hehe\n    }\n\n    if (this.options.bullets) {\n      this._loadBullets();\n    }\n\n    this._events();\n\n    if (this.options.autoPlay && this.$slides.length > 1) {\n      this.geoSync();\n    }\n\n    if (this.options.accessible) { // allow wrapper to be focusable to enable arrow navigation\n      this.$wrapper.attr('tabindex', 0);\n    }\n  }\n\n  /**\n  * Creates a jQuery collection of bullets, if they are being used.\n  * @function\n  * @private\n  */\n  _loadBullets() {\n    this.$bullets = this.$element.find(`.${this.options.boxOfBullets}`).find('button');\n  }\n\n  /**\n  * Sets a `timer` object on the orbit, and starts the counter for the next slide.\n  * @function\n  */\n  geoSync() {\n    var _this = this;\n    this.timer = new Timer(\n      this.$element,\n      {\n        duration: this.options.timerDelay,\n        infinite: false\n      },\n      function() {\n        _this.changeSlide(true);\n      });\n    this.timer.start();\n  }\n\n  /**\n  * Sets wrapper and slide heights for the orbit.\n  * @function\n  * @private\n  */\n  _prepareForOrbit() {\n    var _this = this;\n    this._setWrapperHeight();\n  }\n\n  /**\n  * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.\n  * @function\n  * @private\n  * @param {Function} cb - a callback function to fire when complete.\n  */\n  _setWrapperHeight(cb) {//rewrite this to `for` loop\n    var max = 0, temp, counter = 0, _this = this;\n\n    this.$slides.each(function() {\n      temp = this.getBoundingClientRect().height;\n      $(this).attr('data-slide', counter);\n\n      // hide all slides but the active one\n      if (!/mui/g.test($(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {\n        $(this).css({'display': 'none'});\n      }\n      max = temp > max ? temp : max;\n      counter++;\n    });\n\n    if (counter === this.$slides.length) {\n      this.$wrapper.css({'height': max}); //only change the wrapper height property once.\n      if(cb) {cb(max);} //fire callback with max height dimension.\n    }\n  }\n\n  /**\n  * Sets the max-height of each slide.\n  * @function\n  * @private\n  */\n  _setSlideHeight(height) {\n    this.$slides.each(function() {\n      $(this).css('max-height', height);\n    });\n  }\n\n  /**\n  * Adds event listeners to basically everything within the element.\n  * @function\n  * @private\n  */\n  _events() {\n    var _this = this;\n\n    //***************************************\n    //**Now using custom event - thanks to:**\n    //**      Yohai Ararat of Toronto      **\n    //***************************************\n    //\n    this.$element.off('.resizeme.zf.trigger').on({\n      'resizeme.zf.trigger': this._prepareForOrbit.bind(this)\n    })\n    if (this.$slides.length > 1) {\n\n      if (this.options.swipe) {\n        this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit')\n        .on('swipeleft.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(true);\n        }).on('swiperight.zf.orbit', function(e){\n          e.preventDefault();\n          _this.changeSlide(false);\n        });\n      }\n      //***************************************\n\n      if (this.options.autoPlay) {\n        this.$slides.on('click.zf.orbit', function() {\n          _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);\n          _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();\n        });\n\n        if (this.options.pauseOnHover) {\n          this.$element.on('mouseenter.zf.orbit', function() {\n            _this.timer.pause();\n          }).on('mouseleave.zf.orbit', function() {\n            if (!_this.$element.data('clickedOn')) {\n              _this.timer.start();\n            }\n          });\n        }\n      }\n\n      if (this.options.navButtons) {\n        var $controls = this.$element.find(`.${this.options.nextClass}, .${this.options.prevClass}`);\n        $controls.attr('tabindex', 0)\n        //also need to handle enter/return and spacebar key presses\n        .on('click.zf.orbit touchend.zf.orbit', function(e){\n\t  e.preventDefault();\n          _this.changeSlide($(this).hasClass(_this.options.nextClass));\n        });\n      }\n\n      if (this.options.bullets) {\n        this.$bullets.on('click.zf.orbit touchend.zf.orbit', function() {\n          if (/is-active/g.test(this.className)) { return false; }//if this is active, kick out of function.\n          var idx = $(this).data('slide'),\n          ltr = idx > _this.$slides.filter('.is-active').data('slide'),\n          $slide = _this.$slides.eq(idx);\n\n          _this.changeSlide(ltr, $slide, idx);\n        });\n      }\n\n      if (this.options.accessible) {\n        this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function(e) {\n          // handle keyboard event with keyboard util\n          Keyboard.handleKey(e, 'Orbit', {\n            next: function() {\n              _this.changeSlide(true);\n            },\n            previous: function() {\n              _this.changeSlide(false);\n            },\n            handled: function() { // if bullet is focused, make sure focus moves\n              if ($(e.target).is(_this.$bullets)) {\n                _this.$bullets.filter('.is-active').focus();\n              }\n            }\n          });\n        });\n      }\n    }\n  }\n\n  /**\n   * Resets Orbit so it can be reinitialized\n   */\n  _reset() {\n    // Don't do anything if there are no slides (first run)\n    if (typeof this.$slides == 'undefined') {\n      return;\n    }\n\n    if (this.$slides.length > 1) {\n      // Remove old events\n      this.$element.off('.zf.orbit').find('*').off('.zf.orbit')\n\n      // Restart timer if autoPlay is enabled\n      if (this.options.autoPlay) {\n        this.timer.restart();\n      }\n\n      // Reset all sliddes\n      this.$slides.each(function(el) {\n        $(el).removeClass('is-active is-active is-in')\n          .removeAttr('aria-live')\n          .hide();\n      });\n\n      // Show the first slide\n      this.$slides.first().addClass('is-active').show();\n\n      // Triggers when the slide has finished animating\n      this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]);\n\n      // Select first bullet if bullets are present\n      if (this.options.bullets) {\n        this._updateBullets(0);\n      }\n    }\n  }\n\n  /**\n  * Changes the current slide to a new one.\n  * @function\n  * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.\n  * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.\n  * @param {Number} idx - the index of the new slide in its collection, if one chosen.\n  * @fires Orbit#slidechange\n  */\n  changeSlide(isLTR, chosenSlide, idx) {\n    if (!this.$slides) {return; } // Don't freak out if we're in the middle of cleanup\n    var $curSlide = this.$slides.filter('.is-active').eq(0);\n\n    if (/mui/g.test($curSlide[0].className)) { return false; } //if the slide is currently animating, kick out of the function\n\n    var $firstSlide = this.$slides.first(),\n    $lastSlide = this.$slides.last(),\n    dirIn = isLTR ? 'Right' : 'Left',\n    dirOut = isLTR ? 'Left' : 'Right',\n    _this = this,\n    $newSlide;\n\n    if (!chosenSlide) { //most of the time, this will be auto played or clicked from the navButtons.\n      $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!\n      (this.options.infiniteWrap ? $curSlide.next(`.${this.options.slideClass}`).length ? $curSlide.next(`.${this.options.slideClass}`) : $firstSlide : $curSlide.next(`.${this.options.slideClass}`))//pick next slide if moving left to right\n      :\n      (this.options.infiniteWrap ? $curSlide.prev(`.${this.options.slideClass}`).length ? $curSlide.prev(`.${this.options.slideClass}`) : $lastSlide : $curSlide.prev(`.${this.options.slideClass}`));//pick prev slide if moving right to left\n    } else {\n      $newSlide = chosenSlide;\n    }\n\n    if ($newSlide.length) {\n      /**\n      * Triggers before the next slide starts animating in and only if a next slide has been found.\n      * @event Orbit#beforeslidechange\n      */\n      this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);\n\n      if (this.options.bullets) {\n        idx = idx || this.$slides.index($newSlide); //grab index to update bullets\n        this._updateBullets(idx);\n      }\n\n      if (this.options.useMUI && !this.$element.is(':hidden')) {\n        Motion.animateIn(\n          $newSlide.addClass('is-active'),\n          this.options[`animInFrom${dirIn}`],\n          function(){\n            $newSlide.css({'display': 'block'}).attr('aria-live', 'polite');\n        });\n\n        Motion.animateOut(\n          $curSlide.removeClass('is-active'),\n          this.options[`animOutTo${dirOut}`],\n          function(){\n            $curSlide.removeAttr('aria-live');\n            if(_this.options.autoPlay && !_this.timer.isPaused){\n              _this.timer.restart();\n            }\n            //do stuff?\n          });\n      } else {\n        $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();\n        $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();\n        if (this.options.autoPlay && !this.timer.isPaused) {\n          this.timer.restart();\n        }\n      }\n    /**\n    * Triggers when the slide has finished animating in.\n    * @event Orbit#slidechange\n    */\n      this.$element.trigger('slidechange.zf.orbit', [$newSlide]);\n    }\n  }\n\n  /**\n  * Updates the active state of the bullets, if displayed.\n  * @function\n  * @private\n  * @param {Number} idx - the index of the current slide.\n  */\n  _updateBullets(idx) {\n    var $oldBullet = this.$element.find(`.${this.options.boxOfBullets}`)\n    .find('.is-active').removeClass('is-active').blur(),\n    span = $oldBullet.find('span:last').detach(),\n    $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);\n  }\n\n  /**\n  * Destroys the carousel and hides the element.\n  * @function\n  */\n  _destroy() {\n    this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();\n  }\n}\n\nOrbit.defaults = {\n  /**\n  * Tells the JS to look for and loadBullets.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  bullets: true,\n  /**\n  * Tells the JS to apply event listeners to nav buttons\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  navButtons: true,\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-right'\n  */\n  animInFromRight: 'slide-in-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-right'\n  */\n  animOutToRight: 'slide-out-right',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-left'\n  *\n  */\n  animInFromLeft: 'slide-in-left',\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-left'\n  */\n  animOutToLeft: 'slide-out-left',\n  /**\n  * Allows Orbit to automatically animate on page load.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  autoPlay: true,\n  /**\n  * Amount of time, in ms, between slide transitions\n  * @option\n   * @type {number}\n  * @default 5000\n  */\n  timerDelay: 5000,\n  /**\n  * Allows Orbit to infinitely loop through the slides\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  infiniteWrap: true,\n  /**\n  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  swipe: true,\n  /**\n  * Allows the timing function to pause animation on hover.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  pauseOnHover: true,\n  /**\n  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  accessible: true,\n  /**\n  * Class applied to the container of Orbit\n  * @option\n   * @type {string}\n  * @default 'orbit-container'\n  */\n  containerClass: 'orbit-container',\n  /**\n  * Class applied to individual slides.\n  * @option\n   * @type {string}\n  * @default 'orbit-slide'\n  */\n  slideClass: 'orbit-slide',\n  /**\n  * Class applied to the bullet container. You're welcome.\n  * @option\n   * @type {string}\n  * @default 'orbit-bullets'\n  */\n  boxOfBullets: 'orbit-bullets',\n  /**\n  * Class applied to the `next` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-next'\n  */\n  nextClass: 'orbit-next',\n  /**\n  * Class applied to the `previous` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-previous'\n  */\n  prevClass: 'orbit-previous',\n  /**\n  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  useMUI: true\n};\n\nexport {Orbit};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index b86839353b3f8c828e1baccfd77631b888eaaca1..fb9dbabbfa709a128bb9a54b472898cc20672b8f 100644 (file)
@@ -1 +1,2 @@
-!function(t){function i(s){if(e[s])return e[s].exports;var n=e[s]={i:s,l:!1,exports:{}};return t[s].call(n.exports,n,n.exports,i),n.l=!0,n.exports}var e={};i.m=t,i.c=e,i.i=function(t){return t},i.d=function(t,e,s){i.o(t,e)||Object.defineProperty(t,e,{configurable:!1,enumerable:!0,get:s})},i.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return i.d(e,"a",e),e},i.o=function(t,i){return Object.prototype.hasOwnProperty.call(t,i)},i.p="",i(i.s=89)}({0:function(t,i){t.exports=jQuery},1:function(t,i){t.exports={Foundation:window.Foundation}},10:function(t,i){t.exports={onImagesLoaded:window.Foundation.onImagesLoaded}},12:function(t,i){t.exports={Touch:window.Foundation.Touch}},2:function(t,i){t.exports={Plugin:window.Foundation.Plugin}},23:function(t,i,e){"use strict";Object.defineProperty(i,"__esModule",{value:!0});var s=e(1),n=(e.n(s),e(53));s.Foundation.plugin(n.a,"Orbit")},3:function(t,i){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},4:function(t,i){t.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},5:function(t,i){t.exports={Keyboard:window.Foundation.Keyboard}},53:function(t,i,e){"use strict";function s(t,i){if(!(t instanceof i))throw new TypeError("Cannot call a class as a function")}function n(t,i){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!i||"object"!=typeof i&&"function"!=typeof i?t:i}function o(t,i){if("function"!=typeof i&&null!==i)throw new TypeError("Super expression must either be null or a function, not "+typeof i);t.prototype=Object.create(i&&i.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),i&&(Object.setPrototypeOf?Object.setPrototypeOf(t,i):t.__proto__=i)}e.d(i,"a",function(){return v});var r=e(0),a=e.n(r),l=e(5),u=(e.n(l),e(4)),h=(e.n(u),e(78)),d=(e.n(h),e(10)),f=(e.n(d),e(3)),c=(e.n(f),e(2)),p=(e.n(c),e(12)),b=(e.n(p),function(){function t(t,i){for(var e=0;e<i.length;e++){var s=i[e];s.enumerable=s.enumerable||!1,s.configurable=!0,"value"in s&&(s.writable=!0),Object.defineProperty(t,s.key,s)}}return function(i,e,s){return e&&t(i.prototype,e),s&&t(i,s),i}}()),v=function(t){function i(){return s(this,i),n(this,(i.__proto__||Object.getPrototypeOf(i)).apply(this,arguments))}return o(i,t),b(i,[{key:"_setup",value:function(t,e){this.$element=t,this.options=a.a.extend({},i.defaults,this.$element.data(),e),this.className="Orbit",p.Touch.init(a.a),this._init(),l.Keyboard.register("Orbit",{ltr:{ARROW_RIGHT:"next",ARROW_LEFT:"previous"},rtl:{ARROW_LEFT:"next",ARROW_RIGHT:"previous"}})}},{key:"_init",value:function(){this._reset(),this.$wrapper=this.$element.find("."+this.options.containerClass),this.$slides=this.$element.find("."+this.options.slideClass);var t=this.$element.find("img"),i=this.$slides.filter(".is-active"),s=this.$element[0].id||e.i(f.GetYoDigits)(6,"orbit");this.$element.attr({"data-resize":s,id:s}),i.length||this.$slides.eq(0).addClass("is-active"),this.options.useMUI||this.$slides.addClass("no-motionui"),t.length?e.i(d.onImagesLoaded)(t,this._prepareForOrbit.bind(this)):this._prepareForOrbit(),this.options.bullets&&this._loadBullets(),this._events(),this.options.autoPlay&&this.$slides.length>1&&this.geoSync(),this.options.accessible&&this.$wrapper.attr("tabindex",0)}},{key:"_loadBullets",value:function(){this.$bullets=this.$element.find("."+this.options.boxOfBullets).find("button")}},{key:"geoSync",value:function(){var t=this;this.timer=new h.Timer(this.$element,{duration:this.options.timerDelay,infinite:!1},function(){t.changeSlide(!0)}),this.timer.start()}},{key:"_prepareForOrbit",value:function(){this._setWrapperHeight()}},{key:"_setWrapperHeight",value:function(t){var i,e=0,s=0,n=this;this.$slides.each(function(){i=this.getBoundingClientRect().height,a()(this).attr("data-slide",s),/mui/g.test(a()(this)[0].className)||n.$slides.filter(".is-active")[0]===n.$slides.eq(s)[0]||a()(this).css({position:"relative",display:"none"}),e=i>e?i:e,s++}),s===this.$slides.length&&(this.$wrapper.css({height:e}),t&&t(e))}},{key:"_setSlideHeight",value:function(t){this.$slides.each(function(){a()(this).css("max-height",t)})}},{key:"_events",value:function(){var t=this;if(this.$element.off(".resizeme.zf.trigger").on({"resizeme.zf.trigger":this._prepareForOrbit.bind(this)}),this.$slides.length>1){if(this.options.swipe&&this.$slides.off("swipeleft.zf.orbit swiperight.zf.orbit").on("swipeleft.zf.orbit",function(i){i.preventDefault(),t.changeSlide(!0)}).on("swiperight.zf.orbit",function(i){i.preventDefault(),t.changeSlide(!1)}),this.options.autoPlay&&(this.$slides.on("click.zf.orbit",function(){t.$element.data("clickedOn",!t.$element.data("clickedOn")),t.timer[t.$element.data("clickedOn")?"pause":"start"]()}),this.options.pauseOnHover&&this.$element.on("mouseenter.zf.orbit",function(){t.timer.pause()}).on("mouseleave.zf.orbit",function(){t.$element.data("clickedOn")||t.timer.start()})),this.options.navButtons){this.$element.find("."+this.options.nextClass+", ."+this.options.prevClass).attr("tabindex",0).on("click.zf.orbit touchend.zf.orbit",function(i){i.preventDefault(),t.changeSlide(a()(this).hasClass(t.options.nextClass))})}this.options.bullets&&this.$bullets.on("click.zf.orbit touchend.zf.orbit",function(){if(/is-active/g.test(this.className))return!1;var i=a()(this).data("slide"),e=i>t.$slides.filter(".is-active").data("slide"),s=t.$slides.eq(i);t.changeSlide(e,s,i)}),this.options.accessible&&this.$wrapper.add(this.$bullets).on("keydown.zf.orbit",function(i){l.Keyboard.handleKey(i,"Orbit",{next:function(){t.changeSlide(!0)},previous:function(){t.changeSlide(!1)},handled:function(){a()(i.target).is(t.$bullets)&&t.$bullets.filter(".is-active").focus()}})})}}},{key:"_reset",value:function(){void 0!==this.$slides&&this.$slides.length>1&&(this.$element.off(".zf.orbit").find("*").off(".zf.orbit"),this.options.autoPlay&&this.timer.restart(),this.$slides.each(function(t){a()(t).removeClass("is-active is-active is-in").removeAttr("aria-live").hide()}),this.$slides.first().addClass("is-active").show(),this.$element.trigger("slidechange.zf.orbit",[this.$slides.first()]),this.options.bullets&&this._updateBullets(0))}},{key:"changeSlide",value:function(t,i,e){if(this.$slides){var s=this.$slides.filter(".is-active").eq(0);if(/mui/g.test(s[0].className))return!1;var n,o=this.$slides.first(),r=this.$slides.last(),a=t?"Right":"Left",l=t?"Left":"Right",h=this;n=i||(t?this.options.infiniteWrap?s.next("."+this.options.slideClass).length?s.next("."+this.options.slideClass):o:s.next("."+this.options.slideClass):this.options.infiniteWrap?s.prev("."+this.options.slideClass).length?s.prev("."+this.options.slideClass):r:s.prev("."+this.options.slideClass)),n.length&&(this.$element.trigger("beforeslidechange.zf.orbit",[s,n]),this.options.bullets&&(e=e||this.$slides.index(n),this._updateBullets(e)),this.options.useMUI&&!this.$element.is(":hidden")?(u.Motion.animateIn(n.addClass("is-active").css({position:"absolute",top:0}),this.options["animInFrom"+a],function(){n.css({position:"relative",display:"block"}).attr("aria-live","polite")}),u.Motion.animateOut(s.removeClass("is-active"),this.options["animOutTo"+l],function(){s.removeAttr("aria-live"),h.options.autoPlay&&!h.timer.isPaused&&h.timer.restart()})):(s.removeClass("is-active is-in").removeAttr("aria-live").hide(),n.addClass("is-active is-in").attr("aria-live","polite").show(),this.options.autoPlay&&!this.timer.isPaused&&this.timer.restart()),this.$element.trigger("slidechange.zf.orbit",[n]))}}},{key:"_updateBullets",value:function(t){var i=this.$element.find("."+this.options.boxOfBullets).find(".is-active").removeClass("is-active").blur(),e=i.find("span:last").detach();this.$bullets.eq(t).addClass("is-active").append(e)}},{key:"_destroy",value:function(){this.$element.off(".zf.orbit").find("*").off(".zf.orbit").end().hide()}}]),i}(c.Plugin);v.defaults={bullets:!0,navButtons:!0,animInFromRight:"slide-in-right",animOutToRight:"slide-out-right",animInFromLeft:"slide-in-left",animOutToLeft:"slide-out-left",autoPlay:!0,timerDelay:5e3,infiniteWrap:!0,swipe:!0,pauseOnHover:!0,accessible:!0,containerClass:"orbit-container",slideClass:"orbit-slide",boxOfBullets:"orbit-bullets",nextClass:"orbit-next",prevClass:"orbit-previous",useMUI:!0}},78:function(t,i){t.exports={Timer:window.Foundation.Timer}},89:function(t,i,e){t.exports=e(23)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("./foundation.util.imageLoader"),require("./foundation.util.keyboard"),require("./foundation.util.motion"),require("./foundation.util.timer"),require("./foundation.util.touch"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.imageLoader","./foundation.util.keyboard","./foundation.util.motion","./foundation.util.timer","./foundation.util.touch","jquery"],e):"object"==typeof exports?exports["foundation.orbit"]=e(require("./foundation.core"),require("./foundation.util.imageLoader"),require("./foundation.util.keyboard"),require("./foundation.util.motion"),require("./foundation.util.timer"),require("./foundation.util.touch"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.orbit"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.util.imageLoader"],t.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],t.__FOUNDATION_EXTERNAL__["foundation.util.motion"],t.__FOUNDATION_EXTERNAL__["foundation.util.timer"],t.__FOUNDATION_EXTERNAL__["foundation.util.touch"],t.jQuery))}(window,function(i,n,o,s,r,a,u){return function(i){var n={};function o(t){if(n[t])return n[t].exports;var e=n[t]={i:t,l:!1,exports:{}};return i[t].call(e.exports,e,e.exports,o),e.l=!0,e.exports}return o.m=i,o.c=n,o.d=function(t,e,i){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:i})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var i=Object.create(null);if(o.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)o.d(i,n,function(t){return e[t]}.bind(null,n));return i},o.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return o.d(e,"a",e),e},o.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},o.p="",o(o.s=10)}({"./foundation.core":function(t,e){t.exports=i},"./foundation.util.imageLoader":function(t,e){t.exports=n},"./foundation.util.keyboard":function(t,e){t.exports=o},"./foundation.util.motion":function(t,e){t.exports=s},"./foundation.util.timer":function(t,e){t.exports=r},"./foundation.util.touch":function(t,e){t.exports=a},"./js/entries/plugins/foundation.orbit.js":function(t,e,i){"use strict";i.r(e);var n=i("./foundation.core");i.d(e,"Foundation",function(){return n.Foundation});var o=i("./js/foundation.orbit.js");i.d(e,"Orbit",function(){return o.Orbit}),n.Foundation.plugin(o.Orbit,"Orbit")},"./js/foundation.orbit.js":function(t,e,i){"use strict";i.r(e),i.d(e,"Orbit",function(){return m});var n=i("jquery"),s=i.n(n),r=i("./foundation.util.keyboard"),f=i("./foundation.util.motion"),a=i("./foundation.util.timer"),u=i("./foundation.util.imageLoader"),l=i("./foundation.core"),c=i("./foundation.util.touch");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function d(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}function h(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function p(t){return(p=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function b(t,e){return(b=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var m=function(t){function i(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),h(this,p(i).apply(this,arguments))}var e,n,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&b(t,e)}(i,l["Plugin"]),e=i,(n=[{key:"_setup",value:function(t,e){this.$element=t,this.options=s.a.extend({},i.defaults,this.$element.data(),e),this.className="Orbit",c.Touch.init(s.a),this._init(),r.Keyboard.register("Orbit",{ltr:{ARROW_RIGHT:"next",ARROW_LEFT:"previous"},rtl:{ARROW_LEFT:"next",ARROW_RIGHT:"previous"}})}},{key:"_init",value:function(){this._reset(),this.$wrapper=this.$element.find(".".concat(this.options.containerClass)),this.$slides=this.$element.find(".".concat(this.options.slideClass));var t=this.$element.find("img"),e=this.$slides.filter(".is-active"),i=this.$element[0].id||Object(l.GetYoDigits)(6,"orbit");this.$element.attr({"data-resize":i,id:i}),e.length||this.$slides.eq(0).addClass("is-active"),this.options.useMUI||this.$slides.addClass("no-motionui"),t.length?Object(u.onImagesLoaded)(t,this._prepareForOrbit.bind(this)):this._prepareForOrbit(),this.options.bullets&&this._loadBullets(),this._events(),this.options.autoPlay&&1<this.$slides.length&&this.geoSync(),this.options.accessible&&this.$wrapper.attr("tabindex",0)}},{key:"_loadBullets",value:function(){this.$bullets=this.$element.find(".".concat(this.options.boxOfBullets)).find("button")}},{key:"geoSync",value:function(){var t=this;this.timer=new a.Timer(this.$element,{duration:this.options.timerDelay,infinite:!1},function(){t.changeSlide(!0)}),this.timer.start()}},{key:"_prepareForOrbit",value:function(){this._setWrapperHeight()}},{key:"_setWrapperHeight",value:function(t){var e,i=0,n=0,o=this;this.$slides.each(function(){e=this.getBoundingClientRect().height,s()(this).attr("data-slide",n),/mui/g.test(s()(this)[0].className)||o.$slides.filter(".is-active")[0]===o.$slides.eq(n)[0]||s()(this).css({display:"none"}),i=i<e?e:i,n++}),n===this.$slides.length&&(this.$wrapper.css({height:i}),t&&t(i))}},{key:"_setSlideHeight",value:function(t){this.$slides.each(function(){s()(this).css("max-height",t)})}},{key:"_events",value:function(){var n=this;if(this.$element.off(".resizeme.zf.trigger").on({"resizeme.zf.trigger":this._prepareForOrbit.bind(this)}),1<this.$slides.length){if(this.options.swipe&&this.$slides.off("swipeleft.zf.orbit swiperight.zf.orbit").on("swipeleft.zf.orbit",function(t){t.preventDefault(),n.changeSlide(!0)}).on("swiperight.zf.orbit",function(t){t.preventDefault(),n.changeSlide(!1)}),this.options.autoPlay&&(this.$slides.on("click.zf.orbit",function(){n.$element.data("clickedOn",!n.$element.data("clickedOn")),n.timer[n.$element.data("clickedOn")?"pause":"start"]()}),this.options.pauseOnHover&&this.$element.on("mouseenter.zf.orbit",function(){n.timer.pause()}).on("mouseleave.zf.orbit",function(){n.$element.data("clickedOn")||n.timer.start()})),this.options.navButtons)this.$element.find(".".concat(this.options.nextClass,", .").concat(this.options.prevClass)).attr("tabindex",0).on("click.zf.orbit touchend.zf.orbit",function(t){t.preventDefault(),n.changeSlide(s()(this).hasClass(n.options.nextClass))});this.options.bullets&&this.$bullets.on("click.zf.orbit touchend.zf.orbit",function(){if(/is-active/g.test(this.className))return!1;var t=s()(this).data("slide"),e=t>n.$slides.filter(".is-active").data("slide"),i=n.$slides.eq(t);n.changeSlide(e,i,t)}),this.options.accessible&&this.$wrapper.add(this.$bullets).on("keydown.zf.orbit",function(t){r.Keyboard.handleKey(t,"Orbit",{next:function(){n.changeSlide(!0)},previous:function(){n.changeSlide(!1)},handled:function(){s()(t.target).is(n.$bullets)&&n.$bullets.filter(".is-active").focus()}})})}}},{key:"_reset",value:function(){void 0!==this.$slides&&1<this.$slides.length&&(this.$element.off(".zf.orbit").find("*").off(".zf.orbit"),this.options.autoPlay&&this.timer.restart(),this.$slides.each(function(t){s()(t).removeClass("is-active is-active is-in").removeAttr("aria-live").hide()}),this.$slides.first().addClass("is-active").show(),this.$element.trigger("slidechange.zf.orbit",[this.$slides.first()]),this.options.bullets&&this._updateBullets(0))}},{key:"changeSlide",value:function(t,e,i){if(this.$slides){var n=this.$slides.filter(".is-active").eq(0);if(/mui/g.test(n[0].className))return!1;var o,s=this.$slides.first(),r=this.$slides.last(),a=t?"Right":"Left",u=t?"Left":"Right",l=this;(o=e||(t?this.options.infiniteWrap?n.next(".".concat(this.options.slideClass)).length?n.next(".".concat(this.options.slideClass)):s:n.next(".".concat(this.options.slideClass)):this.options.infiniteWrap?n.prev(".".concat(this.options.slideClass)).length?n.prev(".".concat(this.options.slideClass)):r:n.prev(".".concat(this.options.slideClass)))).length&&(this.$element.trigger("beforeslidechange.zf.orbit",[n,o]),this.options.bullets&&(i=i||this.$slides.index(o),this._updateBullets(i)),this.options.useMUI&&!this.$element.is(":hidden")?(f.Motion.animateIn(o.addClass("is-active"),this.options["animInFrom".concat(a)],function(){o.css({display:"block"}).attr("aria-live","polite")}),f.Motion.animateOut(n.removeClass("is-active"),this.options["animOutTo".concat(u)],function(){n.removeAttr("aria-live"),l.options.autoPlay&&!l.timer.isPaused&&l.timer.restart()})):(n.removeClass("is-active is-in").removeAttr("aria-live").hide(),o.addClass("is-active is-in").attr("aria-live","polite").show(),this.options.autoPlay&&!this.timer.isPaused&&this.timer.restart()),this.$element.trigger("slidechange.zf.orbit",[o]))}}},{key:"_updateBullets",value:function(t){var e=this.$element.find(".".concat(this.options.boxOfBullets)).find(".is-active").removeClass("is-active").blur().find("span:last").detach();this.$bullets.eq(t).addClass("is-active").append(e)}},{key:"_destroy",value:function(){this.$element.off(".zf.orbit").find("*").off(".zf.orbit").end().hide()}}])&&d(e.prototype,n),o&&d(e,o),i}();m.defaults={bullets:!0,navButtons:!0,animInFromRight:"slide-in-right",animOutToRight:"slide-out-right",animInFromLeft:"slide-in-left",animOutToLeft:"slide-out-left",autoPlay:!0,timerDelay:5e3,infiniteWrap:!0,swipe:!0,pauseOnHover:!0,accessible:!0,containerClass:"orbit-container",slideClass:"orbit-slide",boxOfBullets:"orbit-bullets",nextClass:"orbit-next",prevClass:"orbit-previous",useMUI:!0}},10:function(t,e,i){t.exports=i("./js/entries/plugins/foundation.orbit.js")},jquery:function(t,e){t.exports=u}})});
+//# sourceMappingURL=foundation.orbit.min.js.map
diff --git a/dist/js/plugins/foundation.orbit.min.js.map b/dist/js/plugins/foundation.orbit.min.js.map
new file mode 100644 (file)
index 0000000..2d99221
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.orbit.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE__foundation_util_timer__","__WEBPACK_EXTERNAL_MODULE__foundation_util_touch__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.imageLoader","./foundation.util.keyboard","./foundation.util.motion","./foundation.util.timer","./foundation.util.touch","./js/entries/plugins/foundation.orbit.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_orbit__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.orbit.js","Orbit","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__","_foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","init","_init","register","ltr","ARROW_RIGHT","ARROW_LEFT","rtl","_reset","$wrapper","find","concat","containerClass","$slides","slideClass","$images","initActive","filter","id","attr","data-resize","eq","addClass","useMUI","_prepareForOrbit","bullets","_loadBullets","_events","autoPlay","geoSync","accessible","$bullets","boxOfBullets","_this","timer","duration","timerDelay","infinite","changeSlide","start","_setWrapperHeight","cb","temp","max","counter","each","getBoundingClientRect","height","test","css","display","off","on","resizeme.zf.trigger","swipe","e","preventDefault","pauseOnHover","pause","navButtons","nextClass","prevClass","hasClass","idx","$slide","add","handleKey","next","previous","handled","is","focus","restart","el","removeClass","removeAttr","hide","first","show","trigger","_updateBullets","isLTR","chosenSlide","$curSlide","$newSlide","$firstSlide","$lastSlide","last","dirIn","dirOut","infiniteWrap","prev","index","animateIn","animateOut","isPaused","span","blur","detach","append","end","animInFromRight","animOutToRight","animInFromLeft","animOutToLeft","10","jquery"],"mappings":"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","file":"foundation.orbit.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.timer\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.imageLoader\", \"./foundation.util.keyboard\", \"./foundation.util.motion\", \"./foundation.util.timer\", \"./foundation.util.touch\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.orbit\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.timer\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.orbit\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.imageLoader\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.timer\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_timer__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 10);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.imageLoader\":\n/*!****************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.imageLoader\"],\"amd\":\"./foundation.util.imageLoader\",\"commonjs\":\"./foundation.util.imageLoader\",\"commonjs2\":\"./foundation.util.imageLoader\"} ***!\n  \\****************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./foundation.util.timer\":\n/*!****************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.timer\"],\"amd\":\"./foundation.util.timer\",\"commonjs\":\"./foundation.util.timer\",\"commonjs2\":\"./foundation.util.timer\"} ***!\n  \\****************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_timer__;\n\n/***/ }),\n\n/***/ \"./foundation.util.touch\":\n/*!****************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.touch\"],\"amd\":\"./foundation.util.touch\",\"commonjs\":\"./foundation.util.touch\",\"commonjs2\":\"./foundation.util.touch\"} ***!\n  \\****************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.orbit.js\":\n/*!************************************************!*\\\n  !*** ./js/entries/plugins/foundation.orbit.js ***!\n  \\************************************************/\n/*! exports provided: Foundation, Orbit */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_orbit__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.orbit */ \"./js/foundation.orbit.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Orbit\", function() { return _foundation_orbit__WEBPACK_IMPORTED_MODULE_1__[\"Orbit\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_orbit__WEBPACK_IMPORTED_MODULE_1__[\"Orbit\"], 'Orbit');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.orbit.js\":\n/*!********************************!*\\\n  !*** ./js/foundation.orbit.js ***!\n  \\********************************/\n/*! exports provided: Orbit */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Orbit\", function() { return Orbit; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.timer */ \"./foundation.util.timer\");\n/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.imageLoader */ \"./foundation.util.imageLoader\");\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__);\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.util.touch */ \"./foundation.util.touch\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n\n/**\n * Orbit module.\n * @module foundation.orbit\n * @requires foundation.util.keyboard\n * @requires foundation.util.motion\n * @requires foundation.util.timer\n * @requires foundation.util.imageLoader\n * @requires foundation.util.touch\n */\n\nvar Orbit =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Orbit, _Plugin);\n\n  function Orbit() {\n    _classCallCheck(this, Orbit);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Orbit).apply(this, arguments));\n  }\n\n  _createClass(Orbit, [{\n    key: \"_setup\",\n\n    /**\n    * Creates a new instance of an orbit carousel.\n    * @class\n    * @name Orbit\n    * @param {jQuery} element - jQuery object to make into an Orbit Carousel.\n    * @param {Object} options - Overrides to the default plugin settings.\n    */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Orbit.defaults, this.$element.data(), options);\n      this.className = 'Orbit'; // ie9 back compat\n\n      _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__[\"Touch\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a); // Touch init is idempotent, we just need to make sure it's initialied.\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('Orbit', {\n        'ltr': {\n          'ARROW_RIGHT': 'next',\n          'ARROW_LEFT': 'previous'\n        },\n        'rtl': {\n          'ARROW_LEFT': 'next',\n          'ARROW_RIGHT': 'previous'\n        }\n      });\n    }\n    /**\n    * Initializes the plugin by creating jQuery collections, setting attributes, and starting the animation.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      // @TODO: consider discussion on PR #9278 about DOM pollution by changeSlide\n      this._reset();\n\n      this.$wrapper = this.$element.find(\".\".concat(this.options.containerClass));\n      this.$slides = this.$element.find(\".\".concat(this.options.slideClass));\n      var $images = this.$element.find('img'),\n          initActive = this.$slides.filter('.is-active'),\n          id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__[\"GetYoDigits\"])(6, 'orbit');\n      this.$element.attr({\n        'data-resize': id,\n        'id': id\n      });\n\n      if (!initActive.length) {\n        this.$slides.eq(0).addClass('is-active');\n      }\n\n      if (!this.options.useMUI) {\n        this.$slides.addClass('no-motionui');\n      }\n\n      if ($images.length) {\n        Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_4__[\"onImagesLoaded\"])($images, this._prepareForOrbit.bind(this));\n      } else {\n        this._prepareForOrbit(); //hehe\n\n      }\n\n      if (this.options.bullets) {\n        this._loadBullets();\n      }\n\n      this._events();\n\n      if (this.options.autoPlay && this.$slides.length > 1) {\n        this.geoSync();\n      }\n\n      if (this.options.accessible) {\n        // allow wrapper to be focusable to enable arrow navigation\n        this.$wrapper.attr('tabindex', 0);\n      }\n    }\n    /**\n    * Creates a jQuery collection of bullets, if they are being used.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_loadBullets\",\n    value: function _loadBullets() {\n      this.$bullets = this.$element.find(\".\".concat(this.options.boxOfBullets)).find('button');\n    }\n    /**\n    * Sets a `timer` object on the orbit, and starts the counter for the next slide.\n    * @function\n    */\n\n  }, {\n    key: \"geoSync\",\n    value: function geoSync() {\n      var _this = this;\n\n      this.timer = new _foundation_util_timer__WEBPACK_IMPORTED_MODULE_3__[\"Timer\"](this.$element, {\n        duration: this.options.timerDelay,\n        infinite: false\n      }, function () {\n        _this.changeSlide(true);\n      });\n      this.timer.start();\n    }\n    /**\n    * Sets wrapper and slide heights for the orbit.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_prepareForOrbit\",\n    value: function _prepareForOrbit() {\n      var _this = this;\n\n      this._setWrapperHeight();\n    }\n    /**\n    * Calulates the height of each slide in the collection, and uses the tallest one for the wrapper height.\n    * @function\n    * @private\n    * @param {Function} cb - a callback function to fire when complete.\n    */\n\n  }, {\n    key: \"_setWrapperHeight\",\n    value: function _setWrapperHeight(cb) {\n      //rewrite this to `for` loop\n      var max = 0,\n          temp,\n          counter = 0,\n          _this = this;\n\n      this.$slides.each(function () {\n        temp = this.getBoundingClientRect().height;\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('data-slide', counter); // hide all slides but the active one\n\n        if (!/mui/g.test(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)[0].className) && _this.$slides.filter('.is-active')[0] !== _this.$slides.eq(counter)[0]) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css({\n            'display': 'none'\n          });\n        }\n\n        max = temp > max ? temp : max;\n        counter++;\n      });\n\n      if (counter === this.$slides.length) {\n        this.$wrapper.css({\n          'height': max\n        }); //only change the wrapper height property once.\n\n        if (cb) {\n          cb(max);\n        } //fire callback with max height dimension.\n\n      }\n    }\n    /**\n    * Sets the max-height of each slide.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_setSlideHeight\",\n    value: function _setSlideHeight(height) {\n      this.$slides.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).css('max-height', height);\n      });\n    }\n    /**\n    * Adds event listeners to basically everything within the element.\n    * @function\n    * @private\n    */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this; //***************************************\n      //**Now using custom event - thanks to:**\n      //**      Yohai Ararat of Toronto      **\n      //***************************************\n      //\n\n\n      this.$element.off('.resizeme.zf.trigger').on({\n        'resizeme.zf.trigger': this._prepareForOrbit.bind(this)\n      });\n\n      if (this.$slides.length > 1) {\n        if (this.options.swipe) {\n          this.$slides.off('swipeleft.zf.orbit swiperight.zf.orbit').on('swipeleft.zf.orbit', function (e) {\n            e.preventDefault();\n\n            _this.changeSlide(true);\n          }).on('swiperight.zf.orbit', function (e) {\n            e.preventDefault();\n\n            _this.changeSlide(false);\n          });\n        } //***************************************\n\n\n        if (this.options.autoPlay) {\n          this.$slides.on('click.zf.orbit', function () {\n            _this.$element.data('clickedOn', _this.$element.data('clickedOn') ? false : true);\n\n            _this.timer[_this.$element.data('clickedOn') ? 'pause' : 'start']();\n          });\n\n          if (this.options.pauseOnHover) {\n            this.$element.on('mouseenter.zf.orbit', function () {\n              _this.timer.pause();\n            }).on('mouseleave.zf.orbit', function () {\n              if (!_this.$element.data('clickedOn')) {\n                _this.timer.start();\n              }\n            });\n          }\n        }\n\n        if (this.options.navButtons) {\n          var $controls = this.$element.find(\".\".concat(this.options.nextClass, \", .\").concat(this.options.prevClass));\n          $controls.attr('tabindex', 0) //also need to handle enter/return and spacebar key presses\n          .on('click.zf.orbit touchend.zf.orbit', function (e) {\n            e.preventDefault();\n\n            _this.changeSlide(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).hasClass(_this.options.nextClass));\n          });\n        }\n\n        if (this.options.bullets) {\n          this.$bullets.on('click.zf.orbit touchend.zf.orbit', function () {\n            if (/is-active/g.test(this.className)) {\n              return false;\n            } //if this is active, kick out of function.\n\n\n            var idx = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('slide'),\n                ltr = idx > _this.$slides.filter('.is-active').data('slide'),\n                $slide = _this.$slides.eq(idx);\n\n            _this.changeSlide(ltr, $slide, idx);\n          });\n        }\n\n        if (this.options.accessible) {\n          this.$wrapper.add(this.$bullets).on('keydown.zf.orbit', function (e) {\n            // handle keyboard event with keyboard util\n            _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'Orbit', {\n              next: function next() {\n                _this.changeSlide(true);\n              },\n              previous: function previous() {\n                _this.changeSlide(false);\n              },\n              handled: function handled() {\n                // if bullet is focused, make sure focus moves\n                if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is(_this.$bullets)) {\n                  _this.$bullets.filter('.is-active').focus();\n                }\n              }\n            });\n          });\n        }\n      }\n    }\n    /**\n     * Resets Orbit so it can be reinitialized\n     */\n\n  }, {\n    key: \"_reset\",\n    value: function _reset() {\n      // Don't do anything if there are no slides (first run)\n      if (typeof this.$slides == 'undefined') {\n        return;\n      }\n\n      if (this.$slides.length > 1) {\n        // Remove old events\n        this.$element.off('.zf.orbit').find('*').off('.zf.orbit'); // Restart timer if autoPlay is enabled\n\n        if (this.options.autoPlay) {\n          this.timer.restart();\n        } // Reset all sliddes\n\n\n        this.$slides.each(function (el) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(el).removeClass('is-active is-active is-in').removeAttr('aria-live').hide();\n        }); // Show the first slide\n\n        this.$slides.first().addClass('is-active').show(); // Triggers when the slide has finished animating\n\n        this.$element.trigger('slidechange.zf.orbit', [this.$slides.first()]); // Select first bullet if bullets are present\n\n        if (this.options.bullets) {\n          this._updateBullets(0);\n        }\n      }\n    }\n    /**\n    * Changes the current slide to a new one.\n    * @function\n    * @param {Boolean} isLTR - if true the slide moves from right to left, if false the slide moves from left to right.\n    * @param {jQuery} chosenSlide - the jQuery element of the slide to show next, if one is selected.\n    * @param {Number} idx - the index of the new slide in its collection, if one chosen.\n    * @fires Orbit#slidechange\n    */\n\n  }, {\n    key: \"changeSlide\",\n    value: function changeSlide(isLTR, chosenSlide, idx) {\n      if (!this.$slides) {\n        return;\n      } // Don't freak out if we're in the middle of cleanup\n\n\n      var $curSlide = this.$slides.filter('.is-active').eq(0);\n\n      if (/mui/g.test($curSlide[0].className)) {\n        return false;\n      } //if the slide is currently animating, kick out of the function\n\n\n      var $firstSlide = this.$slides.first(),\n          $lastSlide = this.$slides.last(),\n          dirIn = isLTR ? 'Right' : 'Left',\n          dirOut = isLTR ? 'Left' : 'Right',\n          _this = this,\n          $newSlide;\n\n      if (!chosenSlide) {\n        //most of the time, this will be auto played or clicked from the navButtons.\n        $newSlide = isLTR ? //if wrapping enabled, check to see if there is a `next` or `prev` sibling, if not, select the first or last slide to fill in. if wrapping not enabled, attempt to select `next` or `prev`, if there's nothing there, the function will kick out on next step. CRAZY NESTED TERNARIES!!!!!\n        this.options.infiniteWrap ? $curSlide.next(\".\".concat(this.options.slideClass)).length ? $curSlide.next(\".\".concat(this.options.slideClass)) : $firstSlide : $curSlide.next(\".\".concat(this.options.slideClass)) : //pick next slide if moving left to right\n        this.options.infiniteWrap ? $curSlide.prev(\".\".concat(this.options.slideClass)).length ? $curSlide.prev(\".\".concat(this.options.slideClass)) : $lastSlide : $curSlide.prev(\".\".concat(this.options.slideClass)); //pick prev slide if moving right to left\n      } else {\n        $newSlide = chosenSlide;\n      }\n\n      if ($newSlide.length) {\n        /**\n        * Triggers before the next slide starts animating in and only if a next slide has been found.\n        * @event Orbit#beforeslidechange\n        */\n        this.$element.trigger('beforeslidechange.zf.orbit', [$curSlide, $newSlide]);\n\n        if (this.options.bullets) {\n          idx = idx || this.$slides.index($newSlide); //grab index to update bullets\n\n          this._updateBullets(idx);\n        }\n\n        if (this.options.useMUI && !this.$element.is(':hidden')) {\n          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateIn($newSlide.addClass('is-active'), this.options[\"animInFrom\".concat(dirIn)], function () {\n            $newSlide.css({\n              'display': 'block'\n            }).attr('aria-live', 'polite');\n          });\n          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut($curSlide.removeClass('is-active'), this.options[\"animOutTo\".concat(dirOut)], function () {\n            $curSlide.removeAttr('aria-live');\n\n            if (_this.options.autoPlay && !_this.timer.isPaused) {\n              _this.timer.restart();\n            } //do stuff?\n\n          });\n        } else {\n          $curSlide.removeClass('is-active is-in').removeAttr('aria-live').hide();\n          $newSlide.addClass('is-active is-in').attr('aria-live', 'polite').show();\n\n          if (this.options.autoPlay && !this.timer.isPaused) {\n            this.timer.restart();\n          }\n        }\n        /**\n        * Triggers when the slide has finished animating in.\n        * @event Orbit#slidechange\n        */\n\n\n        this.$element.trigger('slidechange.zf.orbit', [$newSlide]);\n      }\n    }\n    /**\n    * Updates the active state of the bullets, if displayed.\n    * @function\n    * @private\n    * @param {Number} idx - the index of the current slide.\n    */\n\n  }, {\n    key: \"_updateBullets\",\n    value: function _updateBullets(idx) {\n      var $oldBullet = this.$element.find(\".\".concat(this.options.boxOfBullets)).find('.is-active').removeClass('is-active').blur(),\n          span = $oldBullet.find('span:last').detach(),\n          $newBullet = this.$bullets.eq(idx).addClass('is-active').append(span);\n    }\n    /**\n    * Destroys the carousel and hides the element.\n    * @function\n    */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.orbit').find('*').off('.zf.orbit').end().hide();\n    }\n  }]);\n\n  return Orbit;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_5__[\"Plugin\"]);\n\nOrbit.defaults = {\n  /**\n  * Tells the JS to look for and loadBullets.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  bullets: true,\n\n  /**\n  * Tells the JS to apply event listeners to nav buttons\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  navButtons: true,\n\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-right'\n  */\n  animInFromRight: 'slide-in-right',\n\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-right'\n  */\n  animOutToRight: 'slide-out-right',\n\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-in-left'\n  *\n  */\n  animInFromLeft: 'slide-in-left',\n\n  /**\n  * motion-ui animation class to apply\n  * @option\n   * @type {string}\n  * @default 'slide-out-left'\n  */\n  animOutToLeft: 'slide-out-left',\n\n  /**\n  * Allows Orbit to automatically animate on page load.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  autoPlay: true,\n\n  /**\n  * Amount of time, in ms, between slide transitions\n  * @option\n   * @type {number}\n  * @default 5000\n  */\n  timerDelay: 5000,\n\n  /**\n  * Allows Orbit to infinitely loop through the slides\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  infiniteWrap: true,\n\n  /**\n  * Allows the Orbit slides to bind to swipe events for mobile, requires an additional util library\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  swipe: true,\n\n  /**\n  * Allows the timing function to pause animation on hover.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  pauseOnHover: true,\n\n  /**\n  * Allows Orbit to bind keyboard events to the slider, to animate frames with arrow keys\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  accessible: true,\n\n  /**\n  * Class applied to the container of Orbit\n  * @option\n   * @type {string}\n  * @default 'orbit-container'\n  */\n  containerClass: 'orbit-container',\n\n  /**\n  * Class applied to individual slides.\n  * @option\n   * @type {string}\n  * @default 'orbit-slide'\n  */\n  slideClass: 'orbit-slide',\n\n  /**\n  * Class applied to the bullet container. You're welcome.\n  * @option\n   * @type {string}\n  * @default 'orbit-bullets'\n  */\n  boxOfBullets: 'orbit-bullets',\n\n  /**\n  * Class applied to the `next` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-next'\n  */\n  nextClass: 'orbit-next',\n\n  /**\n  * Class applied to the `previous` navigation button.\n  * @option\n   * @type {string}\n  * @default 'orbit-previous'\n  */\n  prevClass: 'orbit-previous',\n\n  /**\n  * Boolean to flag the js to use motion ui classes or not. Default to true for backwards compatibility.\n  * @option\n   * @type {boolean}\n  * @default true\n  */\n  useMUI: true\n};\n\n\n/***/ }),\n\n/***/ 10:\n/*!******************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.orbit.js ***!\n  \\******************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.orbit.js */\"./js/entries/plugins/foundation.orbit.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.orbit.js.map"]}
\ No newline at end of file
index e319abaca361d669b4a5c2f65432051e47399ddb..2616d4580edf9e7262b8bcea621b5fd3608636f9 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.accordion"), require("./foundation.core"), require("./foundation.tabs"), require("./foundation.util.mediaQuery"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.accordion", "./foundation.core", "./foundation.tabs", "./foundation.util.mediaQuery", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.responsiveAccordionTabs"] = factory(require("./foundation.accordion"), require("./foundation.core"), require("./foundation.tabs"), require("./foundation.util.mediaQuery"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.responsiveAccordionTabs"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.accordion"], root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.tabs"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_accordion__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_tabs__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 90);
+/******/       return __webpack_require__(__webpack_require__.s = 11);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.accordion":
+/*!************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.accordion"],"amd":"./foundation.accordion","commonjs":"./foundation.accordion","commonjs2":"./foundation.accordion"} ***!
+  \************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_accordion__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.tabs":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.tabs"],"amd":"./foundation.tabs","commonjs":"./foundation.tabs","commonjs2":"./foundation.tabs"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_tabs__;
 
 /***/ }),
 
-/***/ 24:
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
+
+/***/ }),
+
+/***/ "./js/entries/plugins/foundation.responsiveAccordionTabs.js":
+/*!******************************************************************!*\
+  !*** ./js/entries/plugins/foundation.responsiveAccordionTabs.js ***!
+  \******************************************************************/
+/*! exports provided: Foundation, ResponsiveAccordionTabs */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_responsiveAccordionTabs__ = __webpack_require__(54);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.responsiveAccordionTabs */ "./js/foundation.responsiveAccordionTabs.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResponsiveAccordionTabs", function() { return _foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_1__["ResponsiveAccordionTabs"]; });
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_responsiveAccordionTabs__["a" /* ResponsiveAccordionTabs */], 'ResponsiveAccordionTabs');
 
-/***/ }),
-
-/***/ 3:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_1__["ResponsiveAccordionTabs"], 'ResponsiveAccordionTabs');
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
 /***/ }),
 
-/***/ 54:
+/***/ "./js/foundation.responsiveAccordionTabs.js":
+/*!**************************************************!*\
+  !*** ./js/foundation.responsiveAccordionTabs.js ***!
+  \**************************************************/
+/*! exports provided: ResponsiveAccordionTabs */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return ResponsiveAccordionTabs; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_accordion__ = __webpack_require__(72);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_accordion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_accordion__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_tabs__ = __webpack_require__(77);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_tabs___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__foundation_tabs__);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveAccordionTabs", function() { return ResponsiveAccordionTabs; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.accordion */ "./foundation.accordion");
+/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_accordion__WEBPACK_IMPORTED_MODULE_3__);
+/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.tabs */ "./foundation.tabs");
+/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_tabs__WEBPACK_IMPORTED_MODULE_4__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
 
-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 _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
 
-// The plugin matches the plugin classes with these plugin instances.
+
+
+ // The plugin matches the plugin classes with these plugin instances.
+
 var MenuPlugins = {
   tabs: {
     cssClass: 'tabs',
-    plugin: __WEBPACK_IMPORTED_MODULE_5__foundation_tabs__["Tabs"]
+    plugin: _foundation_tabs__WEBPACK_IMPORTED_MODULE_4__["Tabs"]
   },
   accordion: {
     cssClass: 'accordion',
-    plugin: __WEBPACK_IMPORTED_MODULE_4__foundation_accordion__["Accordion"]
+    plugin: _foundation_accordion__WEBPACK_IMPORTED_MODULE_3__["Accordion"]
   }
 };
-
 /**
  * ResponsiveAccordionTabs module.
  * @module foundation.responsiveAccordionTabs
@@ -166,17 +228,19 @@ var MenuPlugins = {
  * @requires foundation.tabs
  */
 
-var ResponsiveAccordionTabs = function (_Plugin) {
+var ResponsiveAccordionTabs =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(ResponsiveAccordionTabs, _Plugin);
 
   function ResponsiveAccordionTabs() {
     _classCallCheck(this, ResponsiveAccordionTabs);
 
-    return _possibleConstructorReturn(this, (ResponsiveAccordionTabs.__proto__ || Object.getPrototypeOf(ResponsiveAccordionTabs)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveAccordionTabs).apply(this, arguments));
   }
 
   _createClass(ResponsiveAccordionTabs, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of a responsive accordion tabs.
@@ -187,20 +251,23 @@ var ResponsiveAccordionTabs = function (_Plugin) {
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
-      this.$element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(element);
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, this.$element.data(), options);
+      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.$element.data(), options);
       this.rules = this.$element.data('responsive-accordion-tabs');
       this.currentMq = null;
       this.currentPlugin = null;
       this.className = 'ResponsiveAccordionTabs'; // ie9 back compat
+
       if (!this.$element.attr('id')) {
-        this.$element.attr('id', __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["GetYoDigits"])(6, 'responsiveaccordiontabs'));
-      };
+        this.$element.attr('id', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'responsiveaccordiontabs'));
+      }
+
+      ;
 
       this._init();
+
       this._events();
     }
-
     /**
      * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.
      * @function
@@ -208,18 +275,16 @@ var ResponsiveAccordionTabs = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"]._init();
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
+
 
-      // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
       if (typeof this.rules === 'string') {
-        var rulesTree = {};
+        var rulesTree = {}; // Parse rules from "classes" pulled from data attribute
 
-        // Parse rules from "classes" pulled from data attribute
-        var rules = this.rules.split(' ');
+        var rules = this.rules.split(' '); // Iterate through every rule found
 
-        // Iterate through every rule found
         for (var i = 0; i < rules.length; i++) {
           var rule = rules[i].split('-');
           var ruleSize = rule.length > 1 ? rule[0] : 'small';
@@ -235,34 +300,38 @@ var ResponsiveAccordionTabs = function (_Plugin) {
 
       this._getAllOptions();
 
-      if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.isEmptyObject(this.rules)) {
+      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) {
         this._checkMediaQueries();
       }
     }
   }, {
-    key: '_getAllOptions',
+    key: "_getAllOptions",
     value: function _getAllOptions() {
       //get all defaults and options
       var _this = this;
+
       _this.allOptions = {};
+
       for (var key in MenuPlugins) {
         if (MenuPlugins.hasOwnProperty(key)) {
           var obj = MenuPlugins[key];
+
           try {
-            var dummyPlugin = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<ul></ul>');
+            var dummyPlugin = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<ul></ul>');
             var tmpPlugin = new obj.plugin(dummyPlugin, _this.options);
+
             for (var keyKey in tmpPlugin.options) {
               if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {
                 var objObj = tmpPlugin.options[keyKey];
                 _this.allOptions[keyKey] = objObj;
               }
             }
+
             tmpPlugin.destroy();
           } catch (e) {}
         }
       }
     }
-
     /**
      * Initializes events for the Menu.
      * @function
@@ -270,15 +339,11 @@ var ResponsiveAccordionTabs = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
-      var _this = this;
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', function () {
-        _this._checkMediaQueries();
-      });
+      this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
     }
-
     /**
      * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
      * @function
@@ -286,55 +351,55 @@ var ResponsiveAccordionTabs = function (_Plugin) {
      */
 
   }, {
-    key: '_checkMediaQueries',
+    key: "_checkMediaQueries",
     value: function _checkMediaQueries() {
       var matchedMq,
-          _this = this;
-      // Iterate through each rule and find the last matching rule
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(this.rules, function (key) {
-        if (__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"].atLeast(key)) {
+          _this = this; // Iterate through each rule and find the last matching rule
+
+
+      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].atLeast(key)) {
           matchedMq = key;
         }
-      });
+      }); // No match? No dice
 
-      // No match? No dice
-      if (!matchedMq) return;
+      if (!matchedMq) return; // Plugin already initialized? We good
 
-      // Plugin already initialized? We good
-      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;
+      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes
 
-      // Remove existing plugin-specific CSS classes
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(MenuPlugins, function (key, value) {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) {
         _this.$element.removeClass(value.cssClass);
-      });
+      }); // Add the CSS class for the new plugin
 
-      // Add the CSS class for the new plugin
-      this.$element.addClass(this.rules[matchedMq].cssClass);
+      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin
 
-      // Create an instance of the new plugin
       if (this.currentPlugin) {
         //don't know why but on nested elements data zfPlugin get's lost
         if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData);
         this.currentPlugin.destroy();
       }
+
       this._handleMarkup(this.rules[matchedMq].cssClass);
+
       this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
       this.storezfData = this.currentPlugin.$element.data('zfPlugin');
     }
   }, {
-    key: '_handleMarkup',
+    key: "_handleMarkup",
     value: function _handleMarkup(toSet) {
       var _this = this,
           fromString = 'accordion';
-      var $panels = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-tabs-content=' + this.$element.attr('id') + ']');
+
+      var $panels = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + this.$element.attr('id') + ']');
       if ($panels.length) fromString = 'tabs';
+
       if (fromString === toSet) {
         return;
-      };
+      }
 
+      ;
       var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title';
       var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel';
-
       this.$element.removeAttr('role');
       var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');
       var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');
@@ -344,97 +409,114 @@ var ResponsiveAccordionTabs = function (_Plugin) {
         $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');
       } else {
         $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');
-      };
+      }
+
+      ;
+      $panels.css({
+        display: '',
+        visibility: ''
+      });
+      $liHeads.css({
+        display: '',
+        visibility: ''
+      });
 
-      $panels.css({ display: '', visibility: '' });
-      $liHeads.css({ display: '', visibility: '' });
       if (toSet === 'accordion') {
         $panels.each(function (key, value) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({ height: '' });
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id="tabs-placeholder-' + _this.$element.attr('id') + '"></div>').detach();
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({
+            height: ''
+          });
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id="tabs-placeholder-' + _this.$element.attr('id') + '"></div>').detach();
           $liHeads.addClass('accordion-item').attr('data-accordion-item', '');
           $liHeadsA.addClass('accordion-title');
         });
       } else if (toSet === 'tabs') {
-        var $tabsContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-tabs-content=' + _this.$element.attr('id') + ']');
-        var $placeholder = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#tabs-placeholder-' + _this.$element.attr('id'));
+        var $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']');
+        var $placeholder = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#tabs-placeholder-' + _this.$element.attr('id'));
+
         if ($placeholder.length) {
-          $tabsContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<div class="tabs-content"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));
+          $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div class="tabs-content"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));
           $placeholder.remove();
         } else {
-          $tabsContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<div class="tabs-content"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));
-        };
+          $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div class="tabs-content"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));
+        }
+
+        ;
         $panels.each(function (key, value) {
-          var tempValue = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).appendTo($tabsContent).addClass(tabsPanel);
+          var tempValue = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($tabsContent).addClass(tabsPanel);
           var hash = $liHeadsA.get(key).hash.slice(1);
-          var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).attr('id') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["GetYoDigits"])(6, 'accordion');
+          var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'accordion');
+
           if (hash !== id) {
             if (hash !== '') {
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).attr('id', hash);
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash);
             } else {
               hash = id;
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()(value).attr('id', hash);
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()($liHeadsA.get(key)).attr('href', __WEBPACK_IMPORTED_MODULE_0_jquery___default()($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);
-            };
-          };
-          var isActive = __WEBPACK_IMPORTED_MODULE_0_jquery___default()($liHeads.get(key)).hasClass('is-active');
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash);
+              jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href', jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);
+            }
+
+            ;
+          }
+
+          ;
+          var isActive = jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeads.get(key)).hasClass('is-active');
+
           if (isActive) {
             tempValue.addClass('is-active');
-          };
+          }
+
+          ;
         });
         $liHeads.addClass(tabsTitle);
-      };
-    }
+      }
 
+      ;
+    }
     /**
      * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       if (this.currentPlugin) this.currentPlugin.destroy();
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('.zf.ResponsiveAccordionTabs');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);
     }
   }]);
 
   return ResponsiveAccordionTabs;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["Plugin"]);
 
 ResponsiveAccordionTabs.defaults = {};
 
 
-
 /***/ }),
 
-/***/ 6:
-/***/ (function(module, exports) {
-
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
-
-/***/ }),
+/***/ 11:
+/*!************************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.responsiveAccordionTabs.js ***!
+  \************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-/***/ 72:
-/***/ (function(module, exports) {
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.responsiveAccordionTabs.js */"./js/entries/plugins/foundation.responsiveAccordionTabs.js");
 
-module.exports = {Accordion: window.Foundation.Accordion};
 
 /***/ }),
 
-/***/ 77:
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Tabs: window.Foundation.Tabs};
-
-/***/ }),
-
-/***/ 90:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(24);
-
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.responsiveAccordionTabs.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.responsiveAccordionTabs.js.map b/dist/js/plugins/foundation.responsiveAccordionTabs.js.map
new file mode 100644 (file)
index 0000000..afadf87
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.accordion\"],\"amd\":\"./foundation.accordion\",\"commonjs\":\"./foundation.accordion\",\"commonjs2\":\"./foundation.accordion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.tabs\"],\"amd\":\"./foundation.tabs\",\"commonjs\":\"./foundation.tabs\",\"commonjs2\":\"./foundation.tabs\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.responsiveAccordionTabs.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.responsiveAccordionTabs.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","ResponsiveAccordionTabs","MenuPlugins","tabs","cssClass","Tabs","accordion","Accordion","element","options","$element","$","extend","data","rules","currentMq","currentPlugin","className","attr","GetYoDigits","_init","_events","MediaQuery","rulesTree","split","i","length","rule","ruleSize","rulePlugin","_getAllOptions","isEmptyObject","_checkMediaQueries","_this","allOptions","key","hasOwnProperty","obj","dummyPlugin","tmpPlugin","keyKey","objObj","destroy","e","_changedZfMediaQueryHandler","bind","window","on","matchedMq","each","atLeast","value","removeClass","addClass","storezfData","_handleMarkup","toSet","fromString","$panels","tabsTitle","linkClass","tabsPanel","panelClass","removeAttr","$liHeads","children","$liHeadsA","css","display","visibility","appendTo","get","height","after","detach","$tabsContent","$placeholder","insertAfter","remove","tempValue","hash","slice","id","replace","isActive","hasClass","off","Plugin","defaults"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yEAAyE;AACzE,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;AClFA,mE;;;;;;;;;;;ACAA,8D;;;;;;;;;;;ACAA,8D;;;;;;;;;;;ACAA,yE;;;;;;;;;;;;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AACAA,2DAAU,CAACC,MAAX,CAAkBC,2FAAlB,EAA2C,yBAA3C;;;;;;;;;;;;;ACHA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAa;;;;;;;;;;;;;;;;;;;;AAEb;AACA;AACA;AACA;AAEA;CAGA;;AACA,IAAIC,WAAW,GAAG;AAChBC,MAAI,EAAE;AACJC,YAAQ,EAAE,MADN;AAEJJ,UAAM,EAAEK,qDAAIA;AAFR,GADU;AAKhBC,WAAS,EAAE;AACTF,YAAQ,EAAE,WADD;AAETJ,UAAM,EAAEO,+DAASA;AAFR;AALK,CAAlB;AAYA;;;;;;;;IAQMN,uB;;;;;;;;;;;;;;AACJ;;;;;;;;2BAQOO,O,EAASC,O,EAAS;AACvB,WAAKC,QAAL,GAAgBC,6CAAC,CAACH,OAAD,CAAjB;AACA,WAAKC,OAAL,GAAgBE,6CAAC,CAACC,MAAF,CAAS,EAAT,EAAa,KAAKF,QAAL,CAAcG,IAAd,EAAb,EAAmCJ,OAAnC,CAAhB;AACA,WAAKK,KAAL,GAAa,KAAKJ,QAAL,CAAcG,IAAd,CAAmB,2BAAnB,CAAb;AACA,WAAKE,SAAL,GAAiB,IAAjB;AACA,WAAKC,aAAL,GAAqB,IAArB;AACA,WAAKC,SAAL,GAAiB,yBAAjB,CANuB,CAMqB;;AAC5C,UAAI,CAAC,KAAKP,QAAL,CAAcQ,IAAd,CAAmB,IAAnB,CAAL,EAA+B;AAC7B,aAAKR,QAAL,CAAcQ,IAAd,CAAmB,IAAnB,EAAwBC,0EAAW,CAAC,CAAD,EAAI,yBAAJ,CAAnC;AACD;;AAAA;;AAED,WAAKC,KAAL;;AACA,WAAKC,OAAL;AACD;AAED;;;;;;;;4BAKQ;AACNC,4EAAU,CAACF,KAAX,GADM,CAGN;;;AACA,UAAI,OAAO,KAAKN,KAAZ,KAAsB,QAA1B,EAAoC;AAClC,YAAIS,SAAS,GAAG,EAAhB,CADkC,CAGlC;;AACA,YAAIT,KAAK,GAAG,KAAKA,KAAL,CAAWU,KAAX,CAAiB,GAAjB,CAAZ,CAJkC,CAMlC;;AACA,aAAK,IAAIC,CAAC,GAAG,CAAb,EAAgBA,CAAC,GAAGX,KAAK,CAACY,MAA1B,EAAkCD,CAAC,EAAnC,EAAuC;AACrC,cAAIE,IAAI,GAAGb,KAAK,CAACW,CAAD,CAAL,CAASD,KAAT,CAAe,GAAf,CAAX;AACA,cAAII,QAAQ,GAAGD,IAAI,CAACD,MAAL,GAAc,CAAd,GAAkBC,IAAI,CAAC,CAAD,CAAtB,GAA4B,OAA3C;AACA,cAAIE,UAAU,GAAGF,IAAI,CAACD,MAAL,GAAc,CAAd,GAAkBC,IAAI,CAAC,CAAD,CAAtB,GAA4BA,IAAI,CAAC,CAAD,CAAjD;;AAEA,cAAIzB,WAAW,CAAC2B,UAAD,CAAX,KAA4B,IAAhC,EAAsC;AACpCN,qBAAS,CAACK,QAAD,CAAT,GAAsB1B,WAAW,CAAC2B,UAAD,CAAjC;AACD;AACF;;AAED,aAAKf,KAAL,GAAaS,SAAb;AACD;;AAED,WAAKO,cAAL;;AAEA,UAAI,CAACnB,6CAAC,CAACoB,aAAF,CAAgB,KAAKjB,KAArB,CAAL,EAAkC;AAChC,aAAKkB,kBAAL;AACD;AACF;;;qCAEgB;AACf;AACA,UAAIC,KAAK,GAAG,IAAZ;;AACAA,WAAK,CAACC,UAAN,GAAmB,EAAnB;;AACA,WAAK,IAAIC,GAAT,IAAgBjC,WAAhB,EAA6B;AAC3B,YAAIA,WAAW,CAACkC,cAAZ,CAA2BD,GAA3B,CAAJ,EAAqC;AACnC,cAAIE,GAAG,GAAGnC,WAAW,CAACiC,GAAD,CAArB;;AACA,cAAI;AACF,gBAAIG,WAAW,GAAG3B,6CAAC,CAAC,WAAD,CAAnB;AACA,gBAAI4B,SAAS,GAAG,IAAIF,GAAG,CAACrC,MAAR,CAAesC,WAAf,EAA2BL,KAAK,CAACxB,OAAjC,CAAhB;;AACA,iBAAK,IAAI+B,MAAT,IAAmBD,SAAS,CAAC9B,OAA7B,EAAsC;AACpC,kBAAI8B,SAAS,CAAC9B,OAAV,CAAkB2B,cAAlB,CAAiCI,MAAjC,KAA4CA,MAAM,KAAK,UAA3D,EAAuE;AACrE,oBAAIC,MAAM,GAAGF,SAAS,CAAC9B,OAAV,CAAkB+B,MAAlB,CAAb;AACAP,qBAAK,CAACC,UAAN,CAAiBM,MAAjB,IAA2BC,MAA3B;AACD;AACF;;AACDF,qBAAS,CAACG,OAAV;AACD,WAVD,CAWA,OAAMC,CAAN,EAAS,CACR;AACF;AACF;AACF;AAED;;;;;;;;8BAKU;AACR,WAAKC,2BAAL,GAAmC,KAAKZ,kBAAL,CAAwBa,IAAxB,CAA6B,IAA7B,CAAnC;AACAlC,mDAAC,CAACmC,MAAD,CAAD,CAAUC,EAAV,CAAa,uBAAb,EAAsC,KAAKH,2BAA3C;AACD;AAED;;;;;;;;yCAKqB;AACnB,UAAII,SAAJ;AAAA,UAAef,KAAK,GAAG,IAAvB,CADmB,CAEnB;;;AACAtB,mDAAC,CAACsC,IAAF,CAAO,KAAKnC,KAAZ,EAAmB,UAASqB,GAAT,EAAc;AAC/B,YAAIb,sEAAU,CAAC4B,OAAX,CAAmBf,GAAnB,CAAJ,EAA6B;AAC3Ba,mBAAS,GAAGb,GAAZ;AACD;AACF,OAJD,EAHmB,CASnB;;AACA,UAAI,CAACa,SAAL,EAAgB,OAVG,CAYnB;;AACA,UAAI,KAAKhC,aAAL,YAA8B,KAAKF,KAAL,CAAWkC,SAAX,EAAsBhD,MAAxD,EAAgE,OAb7C,CAenB;;AACAW,mDAAC,CAACsC,IAAF,CAAO/C,WAAP,EAAoB,UAASiC,GAAT,EAAcgB,KAAd,EAAqB;AACvClB,aAAK,CAACvB,QAAN,CAAe0C,WAAf,CAA2BD,KAAK,CAAC/C,QAAjC;AACD,OAFD,EAhBmB,CAoBnB;;AACA,WAAKM,QAAL,CAAc2C,QAAd,CAAuB,KAAKvC,KAAL,CAAWkC,SAAX,EAAsB5C,QAA7C,EArBmB,CAuBnB;;AACA,UAAI,KAAKY,aAAT,EAAwB;AACtB;AACA,YAAI,CAAC,KAAKA,aAAL,CAAmBN,QAAnB,CAA4BG,IAA5B,CAAiC,UAAjC,CAAD,IAAiD,KAAKyC,WAA1D,EAAuE,KAAKtC,aAAL,CAAmBN,QAAnB,CAA4BG,IAA5B,CAAiC,UAAjC,EAA4C,KAAKyC,WAAjD;AACvE,aAAKtC,aAAL,CAAmB0B,OAAnB;AACD;;AACD,WAAKa,aAAL,CAAmB,KAAKzC,KAAL,CAAWkC,SAAX,EAAsB5C,QAAzC;;AACA,WAAKY,aAAL,GAAqB,IAAI,KAAKF,KAAL,CAAWkC,SAAX,EAAsBhD,MAA1B,CAAiC,KAAKU,QAAtC,EAAgD,EAAhD,CAArB;AACA,WAAK4C,WAAL,GAAmB,KAAKtC,aAAL,CAAmBN,QAAnB,CAA4BG,IAA5B,CAAiC,UAAjC,CAAnB;AAED;;;kCAEa2C,K,EAAM;AAClB,UAAIvB,KAAK,GAAG,IAAZ;AAAA,UAAkBwB,UAAU,GAAG,WAA/B;;AACA,UAAIC,OAAO,GAAG/C,6CAAC,CAAC,wBAAsB,KAAKD,QAAL,CAAcQ,IAAd,CAAmB,IAAnB,CAAtB,GAA+C,GAAhD,CAAf;AACA,UAAIwC,OAAO,CAAChC,MAAZ,EAAoB+B,UAAU,GAAG,MAAb;;AACpB,UAAIA,UAAU,KAAKD,KAAnB,EAA0B;AACxB;AACD;;AAAA;AAED,UAAIG,SAAS,GAAG1B,KAAK,CAACC,UAAN,CAAiB0B,SAAjB,GAA2B3B,KAAK,CAACC,UAAN,CAAiB0B,SAA5C,GAAsD,YAAtE;AACA,UAAIC,SAAS,GAAG5B,KAAK,CAACC,UAAN,CAAiB4B,UAAjB,GAA4B7B,KAAK,CAACC,UAAN,CAAiB4B,UAA7C,GAAwD,YAAxE;AAEA,WAAKpD,QAAL,CAAcqD,UAAd,CAAyB,MAAzB;AACA,UAAIC,QAAQ,GAAG,KAAKtD,QAAL,CAAcuD,QAAd,CAAuB,MAAIN,SAAJ,GAAc,wBAArC,EAA+DP,WAA/D,CAA2EO,SAA3E,EAAsFP,WAAtF,CAAkG,gBAAlG,EAAoHW,UAApH,CAA+H,qBAA/H,CAAf;AACA,UAAIG,SAAS,GAAGF,QAAQ,CAACC,QAAT,CAAkB,GAAlB,EAAuBb,WAAvB,CAAmC,iBAAnC,CAAhB;;AAEA,UAAIK,UAAU,KAAK,MAAnB,EAA2B;AACzBC,eAAO,GAAGA,OAAO,CAACO,QAAR,CAAiB,MAAIJ,SAArB,EAAgCT,WAAhC,CAA4CS,SAA5C,EAAuDE,UAAvD,CAAkE,MAAlE,EAA0EA,UAA1E,CAAqF,aAArF,EAAoGA,UAApG,CAA+G,iBAA/G,CAAV;AACAL,eAAO,CAACO,QAAR,CAAiB,GAAjB,EAAsBF,UAAtB,CAAiC,MAAjC,EAAyCA,UAAzC,CAAoD,eAApD,EAAqEA,UAArE,CAAgF,eAAhF;AACD,OAHD,MAGK;AACHL,eAAO,GAAGM,QAAQ,CAACC,QAAT,CAAkB,oBAAlB,EAAwCb,WAAxC,CAAoD,mBAApD,CAAV;AACD;;AAAA;AAEDM,aAAO,CAACS,GAAR,CAAY;AAACC,eAAO,EAAC,EAAT;AAAYC,kBAAU,EAAC;AAAvB,OAAZ;AACAL,cAAQ,CAACG,GAAT,CAAa;AAACC,eAAO,EAAC,EAAT;AAAYC,kBAAU,EAAC;AAAvB,OAAb;;AACA,UAAIb,KAAK,KAAK,WAAd,EAA2B;AACzBE,eAAO,CAACT,IAAR,CAAa,UAASd,GAAT,EAAagB,KAAb,EAAmB;AAC9BxC,uDAAC,CAACwC,KAAD,CAAD,CAASmB,QAAT,CAAkBN,QAAQ,CAACO,GAAT,CAAapC,GAAb,CAAlB,EAAqCkB,QAArC,CAA8C,mBAA9C,EAAmEnC,IAAnE,CAAwE,kBAAxE,EAA2F,EAA3F,EAA+FkC,WAA/F,CAA2G,WAA3G,EAAwHe,GAAxH,CAA4H;AAACK,kBAAM,EAAC;AAAR,WAA5H;AACA7D,uDAAC,CAAC,wBAAsBsB,KAAK,CAACvB,QAAN,CAAeQ,IAAf,CAAoB,IAApB,CAAtB,GAAgD,GAAjD,CAAD,CAAuDuD,KAAvD,CAA6D,+BAA6BxC,KAAK,CAACvB,QAAN,CAAeQ,IAAf,CAAoB,IAApB,CAA7B,GAAuD,UAApH,EAAgIwD,MAAhI;AACAV,kBAAQ,CAACX,QAAT,CAAkB,gBAAlB,EAAoCnC,IAApC,CAAyC,qBAAzC,EAA+D,EAA/D;AACAgD,mBAAS,CAACb,QAAV,CAAmB,iBAAnB;AACD,SALD;AAMD,OAPD,MAOM,IAAIG,KAAK,KAAK,MAAd,EAAqB;AACzB,YAAImB,YAAY,GAAGhE,6CAAC,CAAC,wBAAsBsB,KAAK,CAACvB,QAAN,CAAeQ,IAAf,CAAoB,IAApB,CAAtB,GAAgD,GAAjD,CAApB;AACA,YAAI0D,YAAY,GAAGjE,6CAAC,CAAC,uBAAqBsB,KAAK,CAACvB,QAAN,CAAeQ,IAAf,CAAoB,IAApB,CAAtB,CAApB;;AACA,YAAI0D,YAAY,CAAClD,MAAjB,EAAyB;AACvBiD,sBAAY,GAAGhE,6CAAC,CAAC,kCAAD,CAAD,CAAsCkE,WAAtC,CAAkDD,YAAlD,EAAgE1D,IAAhE,CAAqE,mBAArE,EAAyFe,KAAK,CAACvB,QAAN,CAAeQ,IAAf,CAAoB,IAApB,CAAzF,CAAf;AACA0D,sBAAY,CAACE,MAAb;AACD,SAHD,MAGK;AACHH,sBAAY,GAAGhE,6CAAC,CAAC,kCAAD,CAAD,CAAsCkE,WAAtC,CAAkD5C,KAAK,CAACvB,QAAxD,EAAkEQ,IAAlE,CAAuE,mBAAvE,EAA2Fe,KAAK,CAACvB,QAAN,CAAeQ,IAAf,CAAoB,IAApB,CAA3F,CAAf;AACD;;AAAA;AACDwC,eAAO,CAACT,IAAR,CAAa,UAASd,GAAT,EAAagB,KAAb,EAAmB;AAC9B,cAAI4B,SAAS,GAAGpE,6CAAC,CAACwC,KAAD,CAAD,CAASmB,QAAT,CAAkBK,YAAlB,EAAgCtB,QAAhC,CAAyCQ,SAAzC,CAAhB;AACA,cAAImB,IAAI,GAAGd,SAAS,CAACK,GAAV,CAAcpC,GAAd,EAAmB6C,IAAnB,CAAwBC,KAAxB,CAA8B,CAA9B,CAAX;AACA,cAAIC,EAAE,GAAGvE,6CAAC,CAACwC,KAAD,CAAD,CAASjC,IAAT,CAAc,IAAd,KAAuBC,0EAAW,CAAC,CAAD,EAAI,WAAJ,CAA3C;;AACA,cAAI6D,IAAI,KAAKE,EAAb,EAAiB;AACf,gBAAIF,IAAI,KAAK,EAAb,EAAiB;AACfrE,2DAAC,CAACwC,KAAD,CAAD,CAASjC,IAAT,CAAc,IAAd,EAAmB8D,IAAnB;AACD,aAFD,MAEK;AACHA,kBAAI,GAAGE,EAAP;AACAvE,2DAAC,CAACwC,KAAD,CAAD,CAASjC,IAAT,CAAc,IAAd,EAAmB8D,IAAnB;AACArE,2DAAC,CAACuD,SAAS,CAACK,GAAV,CAAcpC,GAAd,CAAD,CAAD,CAAsBjB,IAAtB,CAA2B,MAA3B,EAAkCP,6CAAC,CAACuD,SAAS,CAACK,GAAV,CAAcpC,GAAd,CAAD,CAAD,CAAsBjB,IAAtB,CAA2B,MAA3B,EAAmCiE,OAAnC,CAA2C,GAA3C,EAA+C,EAA/C,IAAmD,GAAnD,GAAuDH,IAAzF;AACD;;AAAA;AACF;;AAAA;AACD,cAAII,QAAQ,GAAGzE,6CAAC,CAACqD,QAAQ,CAACO,GAAT,CAAapC,GAAb,CAAD,CAAD,CAAqBkD,QAArB,CAA8B,WAA9B,CAAf;;AACA,cAAID,QAAJ,EAAc;AACZL,qBAAS,CAAC1B,QAAV,CAAmB,WAAnB;AACD;;AAAA;AACF,SAjBD;AAkBAW,gBAAQ,CAACX,QAAT,CAAkBM,SAAlB;AACD;;AAAA;AACF;AAED;;;;;;;+BAIW;AACT,UAAI,KAAK3C,aAAT,EAAwB,KAAKA,aAAL,CAAmB0B,OAAnB;AACxB/B,mDAAC,CAACmC,MAAD,CAAD,CAAUwC,GAAV,CAAc,uBAAd,EAAuC,KAAK1C,2BAA5C;AACD;;;;EA3MmC2C,6D;;AA8MtCtF,uBAAuB,CAACuF,QAAxB,GAAmC,EAAnC;;;;;;;;;;;;;;;;;;;;;;;;AC7OA,oD","file":"foundation.responsiveAccordionTabs.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.accordion\"), require(\"./foundation.core\"), require(\"./foundation.tabs\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.accordion\", \"./foundation.core\", \"./foundation.tabs\", \"./foundation.util.mediaQuery\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.responsiveAccordionTabs\"] = factory(require(\"./foundation.accordion\"), require(\"./foundation.core\"), require(\"./foundation.tabs\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.responsiveAccordionTabs\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.accordion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.tabs\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_accordion__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_tabs__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 11);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_accordion__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_tabs__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","import { Foundation } from './foundation.core';\n\nimport { ResponsiveAccordionTabs } from '../../foundation.responsiveAccordionTabs';\nFoundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');\n\nexport { Foundation, ResponsiveAccordionTabs };\n","'use strict';\n\nimport $ from 'jquery';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin }from './foundation.core.plugin';\n\nimport { Accordion } from './foundation.accordion';\nimport { Tabs } from './foundation.tabs';\n\n// The plugin matches the plugin classes with these plugin instances.\nvar MenuPlugins = {\n  tabs: {\n    cssClass: 'tabs',\n    plugin: Tabs\n  },\n  accordion: {\n    cssClass: 'accordion',\n    plugin: Accordion\n  }\n};\n\n\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nclass ResponsiveAccordionTabs extends Plugin{\n  /**\n   * Creates a new instance of a responsive accordion tabs.\n   * @class\n   * @name ResponsiveAccordionTabs\n   * @fires ResponsiveAccordionTabs#init\n   * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options  = $.extend({}, this.$element.data(), options);\n    this.rules = this.$element.data('responsive-accordion-tabs');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveAccordionTabs'; // ie9 back compat\n    if (!this.$element.attr('id')) {\n      this.$element.attr('id',GetYoDigits(6, 'responsiveaccordiontabs'));\n    };\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    this._getAllOptions();\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n  }\n\n  _getAllOptions() {\n    //get all defaults and options\n    var _this = this;\n    _this.allOptions = {};\n    for (var key in MenuPlugins) {\n      if (MenuPlugins.hasOwnProperty(key)) {\n        var obj = MenuPlugins[key];\n        try {\n          var dummyPlugin = $('<ul></ul>');\n          var tmpPlugin = new obj.plugin(dummyPlugin,_this.options);\n          for (var keyKey in tmpPlugin.options) {\n            if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {\n              var objObj = tmpPlugin.options[keyKey];\n              _this.allOptions[keyKey] = objObj;\n            }\n          }\n          tmpPlugin.destroy();\n        }\n        catch(e) {\n        }\n      }\n    }\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);\n    $(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) {\n      //don't know why but on nested elements data zfPlugin get's lost\n      if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin',this.storezfData);\n      this.currentPlugin.destroy();\n    }\n    this._handleMarkup(this.rules[matchedMq].cssClass);\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n    this.storezfData = this.currentPlugin.$element.data('zfPlugin');\n\n  }\n\n  _handleMarkup(toSet){\n    var _this = this, fromString = 'accordion';\n    var $panels = $('[data-tabs-content='+this.$element.attr('id')+']');\n    if ($panels.length) fromString = 'tabs';\n    if (fromString === toSet) {\n      return;\n    };\n\n    var tabsTitle = _this.allOptions.linkClass?_this.allOptions.linkClass:'tabs-title';\n    var tabsPanel = _this.allOptions.panelClass?_this.allOptions.panelClass:'tabs-panel';\n\n    this.$element.removeAttr('role');\n    var $liHeads = this.$element.children('.'+tabsTitle+',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');\n    var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');\n\n    if (fromString === 'tabs') {\n      $panels = $panels.children('.'+tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');\n      $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');\n    }else{\n      $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');\n    };\n\n    $panels.css({display:'',visibility:''});\n    $liHeads.css({display:'',visibility:''});\n    if (toSet === 'accordion') {\n      $panels.each(function(key,value){\n        $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content','').removeClass('is-active').css({height:''});\n        $('[data-tabs-content='+_this.$element.attr('id')+']').after('<div id=\"tabs-placeholder-'+_this.$element.attr('id')+'\"></div>').detach();\n        $liHeads.addClass('accordion-item').attr('data-accordion-item','');\n        $liHeadsA.addClass('accordion-title');\n      });\n    }else if (toSet === 'tabs'){\n      var $tabsContent = $('[data-tabs-content='+_this.$element.attr('id')+']');\n      var $placeholder = $('#tabs-placeholder-'+_this.$element.attr('id'));\n      if ($placeholder.length) {\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter($placeholder).attr('data-tabs-content',_this.$element.attr('id'));\n        $placeholder.remove();\n      }else{\n        $tabsContent = $('<div class=\"tabs-content\"></div>').insertAfter(_this.$element).attr('data-tabs-content',_this.$element.attr('id'));\n      };\n      $panels.each(function(key,value){\n        var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);\n        var hash = $liHeadsA.get(key).hash.slice(1);\n        var id = $(value).attr('id') || GetYoDigits(6, 'accordion');\n        if (hash !== id) {\n          if (hash !== '') {\n            $(value).attr('id',hash);\n          }else{\n            hash = id;\n            $(value).attr('id',hash);\n            $($liHeadsA.get(key)).attr('href',$($liHeadsA.get(key)).attr('href').replace('#','')+'#'+hash);\n          };\n        };\n        var isActive = $($liHeads.get(key)).hasClass('is-active');\n        if (isActive) {\n          tempValue.addClass('is-active');\n        };\n      });\n      $liHeads.addClass(tabsTitle);\n    };\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    $(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n  }\n}\n\nResponsiveAccordionTabs.defaults = {};\n\nexport {ResponsiveAccordionTabs};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 41a038d152bcae87399946956ee00a51548b52d8..de32535ed8c7e4ff8e3f347b80db9de221f5762a 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(i){if(n[i])return n[i].exports;var a=n[i]={i:i,l:!1,exports:{}};return t[i].call(a.exports,a,a.exports,e),a.l=!0,a.exports}var n={};e.m=t,e.c=n,e.i=function(t){return t},e.d=function(t,n,i){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:i})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=90)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},24:function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=n(1),a=(n.n(i),n(54));i.Foundation.plugin(a.a,"ResponsiveAccordionTabs")},3:function(t,e){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},54:function(t,e,n){"use strict";function i(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function a(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}n.d(e,"a",function(){return v});var o=n(0),s=n.n(o),l=n(6),c=(n.n(l),n(3)),u=(n.n(c),n(2)),d=(n.n(u),n(72)),f=(n.n(d),n(77)),h=(n.n(f),function(){function t(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}return function(e,n,i){return n&&t(e.prototype,n),i&&t(e,i),e}}()),p={tabs:{cssClass:"tabs",plugin:f.Tabs},accordion:{cssClass:"accordion",plugin:d.Accordion}},v=function(t){function e(){return i(this,e),a(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return r(e,t),h(e,[{key:"_setup",value:function(t,e){this.$element=s()(t),this.options=s.a.extend({},this.$element.data(),e),this.rules=this.$element.data("responsive-accordion-tabs"),this.currentMq=null,this.currentPlugin=null,this.className="ResponsiveAccordionTabs",this.$element.attr("id")||this.$element.attr("id",n.i(c.GetYoDigits)(6,"responsiveaccordiontabs")),this._init(),this._events()}},{key:"_init",value:function(){if(l.MediaQuery._init(),"string"==typeof this.rules){for(var t={},e=this.rules.split(" "),n=0;n<e.length;n++){var i=e[n].split("-"),a=i.length>1?i[0]:"small",r=i.length>1?i[1]:i[0];null!==p[r]&&(t[a]=p[r])}this.rules=t}this._getAllOptions(),s.a.isEmptyObject(this.rules)||this._checkMediaQueries()}},{key:"_getAllOptions",value:function(){var t=this;t.allOptions={};for(var e in p)if(p.hasOwnProperty(e)){var n=p[e];try{var i=s()("<ul></ul>"),a=new n.plugin(i,t.options);for(var r in a.options)if(a.options.hasOwnProperty(r)&&"zfPlugin"!==r){var o=a.options[r];t.allOptions[r]=o}a.destroy()}catch(t){}}}},{key:"_events",value:function(){var t=this;s()(window).on("changed.zf.mediaquery",function(){t._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var t,e=this;s.a.each(this.rules,function(e){l.MediaQuery.atLeast(e)&&(t=e)}),t&&(this.currentPlugin instanceof this.rules[t].plugin||(s.a.each(p,function(t,n){e.$element.removeClass(n.cssClass)}),this.$element.addClass(this.rules[t].cssClass),this.currentPlugin&&(!this.currentPlugin.$element.data("zfPlugin")&&this.storezfData&&this.currentPlugin.$element.data("zfPlugin",this.storezfData),this.currentPlugin.destroy()),this._handleMarkup(this.rules[t].cssClass),this.currentPlugin=new this.rules[t].plugin(this.$element,{}),this.storezfData=this.currentPlugin.$element.data("zfPlugin")))}},{key:"_handleMarkup",value:function(t){var e=this,i="accordion",a=s()("[data-tabs-content="+this.$element.attr("id")+"]");if(a.length&&(i="tabs"),i!==t){var r=e.allOptions.linkClass?e.allOptions.linkClass:"tabs-title",o=e.allOptions.panelClass?e.allOptions.panelClass:"tabs-panel";this.$element.removeAttr("role");var l=this.$element.children("."+r+",[data-accordion-item]").removeClass(r).removeClass("accordion-item").removeAttr("data-accordion-item"),u=l.children("a").removeClass("accordion-title");if("tabs"===i?(a=a.children("."+o).removeClass(o).removeAttr("role").removeAttr("aria-hidden").removeAttr("aria-labelledby"),a.children("a").removeAttr("role").removeAttr("aria-controls").removeAttr("aria-selected")):a=l.children("[data-tab-content]").removeClass("accordion-content"),a.css({display:"",visibility:""}),l.css({display:"",visibility:""}),"accordion"===t)a.each(function(t,n){s()(n).appendTo(l.get(t)).addClass("accordion-content").attr("data-tab-content","").removeClass("is-active").css({height:""}),s()("[data-tabs-content="+e.$element.attr("id")+"]").after('<div id="tabs-placeholder-'+e.$element.attr("id")+'"></div>').detach(),l.addClass("accordion-item").attr("data-accordion-item",""),u.addClass("accordion-title")});else if("tabs"===t){var d=s()("[data-tabs-content="+e.$element.attr("id")+"]"),f=s()("#tabs-placeholder-"+e.$element.attr("id"));f.length?(d=s()('<div class="tabs-content"></div>').insertAfter(f).attr("data-tabs-content",e.$element.attr("id")),f.remove()):d=s()('<div class="tabs-content"></div>').insertAfter(e.$element).attr("data-tabs-content",e.$element.attr("id")),a.each(function(t,e){var i=s()(e).appendTo(d).addClass(o),a=u.get(t).hash.slice(1),r=s()(e).attr("id")||n.i(c.GetYoDigits)(6,"accordion");a!==r&&(""!==a?s()(e).attr("id",a):(a=r,s()(e).attr("id",a),s()(u.get(t)).attr("href",s()(u.get(t)).attr("href").replace("#","")+"#"+a))),s()(l.get(t)).hasClass("is-active")&&i.addClass("is-active")}),l.addClass(r)}}}},{key:"_destroy",value:function(){this.currentPlugin&&this.currentPlugin.destroy(),s()(window).off(".zf.ResponsiveAccordionTabs")}}]),e}(u.Plugin);v.defaults={}},6:function(t,e){t.exports={MediaQuery:window.Foundation.MediaQuery}},72:function(t,e){t.exports={Accordion:window.Foundation.Accordion}},77:function(t,e){t.exports={Tabs:window.Foundation.Tabs}},90:function(t,e,n){t.exports=n(24)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.accordion"),require("./foundation.core"),require("./foundation.tabs"),require("./foundation.util.mediaQuery"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.accordion","./foundation.core","./foundation.tabs","./foundation.util.mediaQuery","jquery"],e):"object"==typeof exports?exports["foundation.responsiveAccordionTabs"]=e(require("./foundation.accordion"),require("./foundation.core"),require("./foundation.tabs"),require("./foundation.util.mediaQuery"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.responsiveAccordionTabs"]=e(t.__FOUNDATION_EXTERNAL__["foundation.accordion"],t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.tabs"],t.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],t.jQuery))}(window,function(n,o,i,r,a){return function(n){var o={};function i(t){if(o[t])return o[t].exports;var e=o[t]={i:t,l:!1,exports:{}};return n[t].call(e.exports,e,e.exports,i),e.l=!0,e.exports}return i.m=n,i.c=o,i.d=function(t,e,n){i.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},i.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},i.t=function(e,t){if(1&t&&(e=i(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)i.d(n,o,function(t){return e[t]}.bind(null,o));return n},i.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return i.d(e,"a",e),e},i.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},i.p="",i(i.s=11)}({"./foundation.accordion":function(t,e){t.exports=n},"./foundation.core":function(t,e){t.exports=o},"./foundation.tabs":function(t,e){t.exports=i},"./foundation.util.mediaQuery":function(t,e){t.exports=r},"./js/entries/plugins/foundation.responsiveAccordionTabs.js":function(t,e,n){"use strict";n.r(e);var o=n("./foundation.core");n.d(e,"Foundation",function(){return o.Foundation});var i=n("./js/foundation.responsiveAccordionTabs.js");n.d(e,"ResponsiveAccordionTabs",function(){return i.ResponsiveAccordionTabs}),o.Foundation.plugin(i.ResponsiveAccordionTabs,"ResponsiveAccordionTabs")},"./js/foundation.responsiveAccordionTabs.js":function(t,e,n){"use strict";n.r(e),n.d(e,"ResponsiveAccordionTabs",function(){return b});var o=n("jquery"),l=n.n(o),a=n("./foundation.util.mediaQuery"),d=n("./foundation.core"),i=n("./foundation.accordion"),r=n("./foundation.tabs");function s(t){return(s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var o=e[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}function c(t,e){return!e||"object"!==s(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function p(t,e){return(p=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var h={tabs:{cssClass:"tabs",plugin:r.Tabs},accordion:{cssClass:"accordion",plugin:i.Accordion}},b=function(t){function e(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,e),c(this,f(e).apply(this,arguments))}var n,o,i;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&p(t,e)}(e,d["Plugin"]),n=e,(o=[{key:"_setup",value:function(t,e){this.$element=l()(t),this.options=l.a.extend({},this.$element.data(),e),this.rules=this.$element.data("responsive-accordion-tabs"),this.currentMq=null,this.currentPlugin=null,this.className="ResponsiveAccordionTabs",this.$element.attr("id")||this.$element.attr("id",Object(d.GetYoDigits)(6,"responsiveaccordiontabs")),this._init(),this._events()}},{key:"_init",value:function(){if(a.MediaQuery._init(),"string"==typeof this.rules){for(var t={},e=this.rules.split(" "),n=0;n<e.length;n++){var o=e[n].split("-"),i=1<o.length?o[0]:"small",r=1<o.length?o[1]:o[0];null!==h[r]&&(t[i]=h[r])}this.rules=t}this._getAllOptions(),l.a.isEmptyObject(this.rules)||this._checkMediaQueries()}},{key:"_getAllOptions",value:function(){for(var t in this.allOptions={},h)if(h.hasOwnProperty(t)){var e=h[t];try{var n=l()("<ul></ul>"),o=new e.plugin(n,this.options);for(var i in o.options)if(o.options.hasOwnProperty(i)&&"zfPlugin"!==i){var r=o.options[i];this.allOptions[i]=r}o.destroy()}catch(t){}}}},{key:"_events",value:function(){this._changedZfMediaQueryHandler=this._checkMediaQueries.bind(this),l()(window).on("changed.zf.mediaquery",this._changedZfMediaQueryHandler)}},{key:"_checkMediaQueries",value:function(){var e,n=this;l.a.each(this.rules,function(t){a.MediaQuery.atLeast(t)&&(e=t)}),e&&(this.currentPlugin instanceof this.rules[e].plugin||(l.a.each(h,function(t,e){n.$element.removeClass(e.cssClass)}),this.$element.addClass(this.rules[e].cssClass),this.currentPlugin&&(!this.currentPlugin.$element.data("zfPlugin")&&this.storezfData&&this.currentPlugin.$element.data("zfPlugin",this.storezfData),this.currentPlugin.destroy()),this._handleMarkup(this.rules[e].cssClass),this.currentPlugin=new this.rules[e].plugin(this.$element,{}),this.storezfData=this.currentPlugin.$element.data("zfPlugin")))}},{key:"_handleMarkup",value:function(t){var n=this,e="accordion",o=l()("[data-tabs-content="+this.$element.attr("id")+"]");if(o.length&&(e="tabs"),e!==t){var i=n.allOptions.linkClass?n.allOptions.linkClass:"tabs-title",r=n.allOptions.panelClass?n.allOptions.panelClass:"tabs-panel";this.$element.removeAttr("role");var a=this.$element.children("."+i+",[data-accordion-item]").removeClass(i).removeClass("accordion-item").removeAttr("data-accordion-item"),s=a.children("a").removeClass("accordion-title");if("tabs"===e?(o=o.children("."+r).removeClass(r).removeAttr("role").removeAttr("aria-hidden").removeAttr("aria-labelledby")).children("a").removeAttr("role").removeAttr("aria-controls").removeAttr("aria-selected"):o=a.children("[data-tab-content]").removeClass("accordion-content"),o.css({display:"",visibility:""}),a.css({display:"",visibility:""}),"accordion"===t)o.each(function(t,e){l()(e).appendTo(a.get(t)).addClass("accordion-content").attr("data-tab-content","").removeClass("is-active").css({height:""}),l()("[data-tabs-content="+n.$element.attr("id")+"]").after('<div id="tabs-placeholder-'+n.$element.attr("id")+'"></div>').detach(),a.addClass("accordion-item").attr("data-accordion-item",""),s.addClass("accordion-title")});else if("tabs"===t){var u=l()("[data-tabs-content="+n.$element.attr("id")+"]"),c=l()("#tabs-placeholder-"+n.$element.attr("id"));c.length?(u=l()('<div class="tabs-content"></div>').insertAfter(c).attr("data-tabs-content",n.$element.attr("id")),c.remove()):u=l()('<div class="tabs-content"></div>').insertAfter(n.$element).attr("data-tabs-content",n.$element.attr("id")),o.each(function(t,e){var n=l()(e).appendTo(u).addClass(r),o=s.get(t).hash.slice(1),i=l()(e).attr("id")||Object(d.GetYoDigits)(6,"accordion");o!==i&&(""!==o?l()(e).attr("id",o):(o=i,l()(e).attr("id",o),l()(s.get(t)).attr("href",l()(s.get(t)).attr("href").replace("#","")+"#"+o))),l()(a.get(t)).hasClass("is-active")&&n.addClass("is-active")}),a.addClass(i)}}}},{key:"_destroy",value:function(){this.currentPlugin&&this.currentPlugin.destroy(),l()(window).off("changed.zf.mediaquery",this._changedZfMediaQueryHandler)}}])&&u(n.prototype,o),i&&u(n,i),e}();b.defaults={}},11:function(t,e,n){t.exports=n("./js/entries/plugins/foundation.responsiveAccordionTabs.js")},jquery:function(t,e){t.exports=a}})});
+//# sourceMappingURL=foundation.responsiveAccordionTabs.min.js.map
diff --git a/dist/js/plugins/foundation.responsiveAccordionTabs.min.js.map b/dist/js/plugins/foundation.responsiveAccordionTabs.min.js.map
new file mode 100644 (file)
index 0000000..ac48582
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.responsiveAccordionTabs.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_accordion__","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_tabs__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.accordion","./foundation.core","./foundation.tabs","./foundation.util.mediaQuery","./js/entries/plugins/foundation.responsiveAccordionTabs.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.responsiveAccordionTabs.js","ResponsiveAccordionTabs","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__","_foundation_accordion__WEBPACK_IMPORTED_MODULE_3__","_foundation_tabs__WEBPACK_IMPORTED_MODULE_4__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","MenuPlugins","tabs","cssClass","accordion","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","data","rules","currentMq","currentPlugin","className","attr","_init","_events","rulesTree","split","rule","ruleSize","rulePlugin","_getAllOptions","isEmptyObject","_checkMediaQueries","allOptions","dummyPlugin","tmpPlugin","keyKey","objObj","destroy","e","_changedZfMediaQueryHandler","on","matchedMq","_this","each","atLeast","removeClass","addClass","storezfData","_handleMarkup","toSet","fromString","$panels","tabsTitle","linkClass","tabsPanel","panelClass","removeAttr","$liHeads","children","$liHeadsA","css","display","visibility","appendTo","height","after","detach","$tabsContent","$placeholder","insertAfter","remove","tempValue","hash","slice","id","replace","hasClass","off","defaults","11","jquery"],"mappings":"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","file":"foundation.responsiveAccordionTabs.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.accordion\"), require(\"./foundation.core\"), require(\"./foundation.tabs\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.accordion\", \"./foundation.core\", \"./foundation.tabs\", \"./foundation.util.mediaQuery\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.responsiveAccordionTabs\"] = factory(require(\"./foundation.accordion\"), require(\"./foundation.core\"), require(\"./foundation.tabs\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.responsiveAccordionTabs\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.accordion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.tabs\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_accordion__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_tabs__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 11);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.accordion\":\n/*!************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.accordion\"],\"amd\":\"./foundation.accordion\",\"commonjs\":\"./foundation.accordion\",\"commonjs2\":\"./foundation.accordion\"} ***!\n  \\************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_accordion__;\n\n/***/ }),\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.tabs\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.tabs\"],\"amd\":\"./foundation.tabs\",\"commonjs\":\"./foundation.tabs\",\"commonjs2\":\"./foundation.tabs\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_tabs__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.responsiveAccordionTabs.js\":\n/*!******************************************************************!*\\\n  !*** ./js/entries/plugins/foundation.responsiveAccordionTabs.js ***!\n  \\******************************************************************/\n/*! exports provided: Foundation, ResponsiveAccordionTabs */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.responsiveAccordionTabs */ \"./js/foundation.responsiveAccordionTabs.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveAccordionTabs\", function() { return _foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_1__[\"ResponsiveAccordionTabs\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_responsiveAccordionTabs__WEBPACK_IMPORTED_MODULE_1__[\"ResponsiveAccordionTabs\"], 'ResponsiveAccordionTabs');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.responsiveAccordionTabs.js\":\n/*!**************************************************!*\\\n  !*** ./js/foundation.responsiveAccordionTabs.js ***!\n  \\**************************************************/\n/*! exports provided: ResponsiveAccordionTabs */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveAccordionTabs\", function() { return ResponsiveAccordionTabs; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.accordion */ \"./foundation.accordion\");\n/* harmony import */ var _foundation_accordion__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_accordion__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.tabs */ \"./foundation.tabs\");\n/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_tabs__WEBPACK_IMPORTED_MODULE_4__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n // The plugin matches the plugin classes with these plugin instances.\n\nvar MenuPlugins = {\n  tabs: {\n    cssClass: 'tabs',\n    plugin: _foundation_tabs__WEBPACK_IMPORTED_MODULE_4__[\"Tabs\"]\n  },\n  accordion: {\n    cssClass: 'accordion',\n    plugin: _foundation_accordion__WEBPACK_IMPORTED_MODULE_3__[\"Accordion\"]\n  }\n};\n/**\n * ResponsiveAccordionTabs module.\n * @module foundation.responsiveAccordionTabs\n * @requires foundation.util.motion\n * @requires foundation.accordion\n * @requires foundation.tabs\n */\n\nvar ResponsiveAccordionTabs =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(ResponsiveAccordionTabs, _Plugin);\n\n  function ResponsiveAccordionTabs() {\n    _classCallCheck(this, ResponsiveAccordionTabs);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveAccordionTabs).apply(this, arguments));\n  }\n\n  _createClass(ResponsiveAccordionTabs, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a responsive accordion tabs.\n     * @class\n     * @name ResponsiveAccordionTabs\n     * @fires ResponsiveAccordionTabs#init\n     * @param {jQuery} element - jQuery object to make into Responsive Accordion Tabs.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.$element.data(), options);\n      this.rules = this.$element.data('responsive-accordion-tabs');\n      this.currentMq = null;\n      this.currentPlugin = null;\n      this.className = 'ResponsiveAccordionTabs'; // ie9 back compat\n\n      if (!this.$element.attr('id')) {\n        this.$element.attr('id', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'responsiveaccordiontabs'));\n      }\n\n      ;\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n\n\n      if (typeof this.rules === 'string') {\n        var rulesTree = {}; // Parse rules from \"classes\" pulled from data attribute\n\n        var rules = this.rules.split(' '); // Iterate through every rule found\n\n        for (var i = 0; i < rules.length; i++) {\n          var rule = rules[i].split('-');\n          var ruleSize = rule.length > 1 ? rule[0] : 'small';\n          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n          if (MenuPlugins[rulePlugin] !== null) {\n            rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n          }\n        }\n\n        this.rules = rulesTree;\n      }\n\n      this._getAllOptions();\n\n      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) {\n        this._checkMediaQueries();\n      }\n    }\n  }, {\n    key: \"_getAllOptions\",\n    value: function _getAllOptions() {\n      //get all defaults and options\n      var _this = this;\n\n      _this.allOptions = {};\n\n      for (var key in MenuPlugins) {\n        if (MenuPlugins.hasOwnProperty(key)) {\n          var obj = MenuPlugins[key];\n\n          try {\n            var dummyPlugin = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<ul></ul>');\n            var tmpPlugin = new obj.plugin(dummyPlugin, _this.options);\n\n            for (var keyKey in tmpPlugin.options) {\n              if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {\n                var objObj = tmpPlugin.options[keyKey];\n                _this.allOptions[keyKey] = objObj;\n              }\n            }\n\n            tmpPlugin.destroy();\n          } catch (e) {}\n        }\n      }\n    }\n    /**\n     * Initializes events for the Menu.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this._changedZfMediaQueryHandler = this._checkMediaQueries.bind(this);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n    }\n    /**\n     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_checkMediaQueries\",\n    value: function _checkMediaQueries() {\n      var matchedMq,\n          _this = this; // Iterate through each rule and find the last matching rule\n\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].atLeast(key)) {\n          matchedMq = key;\n        }\n      }); // No match? No dice\n\n      if (!matchedMq) return; // Plugin already initialized? We good\n\n      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) {\n        _this.$element.removeClass(value.cssClass);\n      }); // Add the CSS class for the new plugin\n\n      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin\n\n      if (this.currentPlugin) {\n        //don't know why but on nested elements data zfPlugin get's lost\n        if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData);\n        this.currentPlugin.destroy();\n      }\n\n      this._handleMarkup(this.rules[matchedMq].cssClass);\n\n      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n      this.storezfData = this.currentPlugin.$element.data('zfPlugin');\n    }\n  }, {\n    key: \"_handleMarkup\",\n    value: function _handleMarkup(toSet) {\n      var _this = this,\n          fromString = 'accordion';\n\n      var $panels = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + this.$element.attr('id') + ']');\n      if ($panels.length) fromString = 'tabs';\n\n      if (fromString === toSet) {\n        return;\n      }\n\n      ;\n      var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title';\n      var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel';\n      this.$element.removeAttr('role');\n      var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');\n      var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');\n\n      if (fromString === 'tabs') {\n        $panels = $panels.children('.' + tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');\n        $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');\n      } else {\n        $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');\n      }\n\n      ;\n      $panels.css({\n        display: '',\n        visibility: ''\n      });\n      $liHeads.css({\n        display: '',\n        visibility: ''\n      });\n\n      if (toSet === 'accordion') {\n        $panels.each(function (key, value) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({\n            height: ''\n          });\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id=\"tabs-placeholder-' + _this.$element.attr('id') + '\"></div>').detach();\n          $liHeads.addClass('accordion-item').attr('data-accordion-item', '');\n          $liHeadsA.addClass('accordion-title');\n        });\n      } else if (toSet === 'tabs') {\n        var $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-tabs-content=' + _this.$element.attr('id') + ']');\n        var $placeholder = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#tabs-placeholder-' + _this.$element.attr('id'));\n\n        if ($placeholder.length) {\n          $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div class=\"tabs-content\"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));\n          $placeholder.remove();\n        } else {\n          $tabsContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div class=\"tabs-content\"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));\n        }\n\n        ;\n        $panels.each(function (key, value) {\n          var tempValue = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).appendTo($tabsContent).addClass(tabsPanel);\n          var hash = $liHeadsA.get(key).hash.slice(1);\n          var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'accordion');\n\n          if (hash !== id) {\n            if (hash !== '') {\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash);\n            } else {\n              hash = id;\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()(value).attr('id', hash);\n              jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href', jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);\n            }\n\n            ;\n          }\n\n          ;\n          var isActive = jquery__WEBPACK_IMPORTED_MODULE_0___default()($liHeads.get(key)).hasClass('is-active');\n\n          if (isActive) {\n            tempValue.addClass('is-active');\n          }\n\n          ;\n        });\n        $liHeads.addClass(tabsTitle);\n      }\n\n      ;\n    }\n    /**\n     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      if (this.currentPlugin) this.currentPlugin.destroy();\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._changedZfMediaQueryHandler);\n    }\n  }]);\n\n  return ResponsiveAccordionTabs;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]);\n\nResponsiveAccordionTabs.defaults = {};\n\n\n/***/ }),\n\n/***/ 11:\n/*!************************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.responsiveAccordionTabs.js ***!\n  \\************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.responsiveAccordionTabs.js */\"./js/entries/plugins/foundation.responsiveAccordionTabs.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.responsiveAccordionTabs.js.map"]}
\ No newline at end of file
index bddce47472bebffc776c0dafbfbabea097d09c5c..4dcaaf39f8c278c3fe141c9b3272e8dd3303b675 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.accordionMenu"), require("./foundation.core"), require("./foundation.drilldown"), require("./foundation.dropdownMenu"), require("./foundation.util.mediaQuery"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.accordionMenu", "./foundation.core", "./foundation.drilldown", "./foundation.dropdownMenu", "./foundation.util.mediaQuery", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.responsiveMenu"] = factory(require("./foundation.accordionMenu"), require("./foundation.core"), require("./foundation.drilldown"), require("./foundation.dropdownMenu"), require("./foundation.util.mediaQuery"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.responsiveMenu"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.accordionMenu"], root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.drilldown"], root["__FOUNDATION_EXTERNAL__"]["foundation.dropdownMenu"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_accordionMenu__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_drilldown__, __WEBPACK_EXTERNAL_MODULE__foundation_dropdownMenu__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 91);
+/******/       return __webpack_require__(__webpack_require__.s = 12);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.accordionMenu":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.accordionMenu"],"amd":"./foundation.accordionMenu","commonjs":"./foundation.accordionMenu","commonjs2":"./foundation.accordionMenu"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_accordionMenu__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.drilldown":
+/*!************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.drilldown"],"amd":"./foundation.drilldown","commonjs":"./foundation.drilldown","commonjs2":"./foundation.drilldown"} ***!
+  \************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_drilldown__;
 
 /***/ }),
 
-/***/ 25:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+/***/ "./foundation.dropdownMenu":
+/*!************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.dropdownMenu"],"amd":"./foundation.dropdownMenu","commonjs":"./foundation.dropdownMenu","commonjs2":"./foundation.dropdownMenu"} ***!
+  \************************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_responsiveMenu__ = __webpack_require__(55);
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_dropdownMenu__;
 
+/***/ }),
 
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_responsiveMenu__["a" /* ResponsiveMenu */], 'ResponsiveMenu');
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
 
 /***/ }),
 
-/***/ 3:
-/***/ (function(module, exports) {
+/***/ "./js/entries/plugins/foundation.responsiveMenu.js":
+/*!*********************************************************!*\
+  !*** ./js/entries/plugins/foundation.responsiveMenu.js ***!
+  \*********************************************************/
+/*! exports provided: Foundation, ResponsiveMenu */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
+
+/* harmony import */ var _foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.responsiveMenu */ "./js/foundation.responsiveMenu.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResponsiveMenu", function() { return _foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_1__["ResponsiveMenu"]; });
+
+
+
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_1__["ResponsiveMenu"], 'ResponsiveMenu');
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
 /***/ }),
 
-/***/ 55:
+/***/ "./js/foundation.responsiveMenu.js":
+/*!*****************************************!*\
+  !*** ./js/foundation.responsiveMenu.js ***!
+  \*****************************************/
+/*! exports provided: ResponsiveMenu */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return ResponsiveMenu; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_dropdownMenu__ = __webpack_require__(75);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_dropdownMenu___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_dropdownMenu__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_drilldown__ = __webpack_require__(74);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_drilldown___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__foundation_drilldown__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_accordionMenu__ = __webpack_require__(73);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_accordionMenu___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_6__foundation_accordionMenu__);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveMenu", function() { return ResponsiveMenu; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.dropdownMenu */ "./foundation.dropdownMenu");
+/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3__);
+/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.drilldown */ "./foundation.drilldown");
+/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_drilldown__WEBPACK_IMPORTED_MODULE_4__);
+/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.accordionMenu */ "./foundation.accordionMenu");
+/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-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 _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -153,20 +226,17 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
 var MenuPlugins = {
   dropdown: {
     cssClass: 'dropdown',
-    plugin: __WEBPACK_IMPORTED_MODULE_4__foundation_dropdownMenu__["DropdownMenu"]
+    plugin: _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3__["DropdownMenu"]
   },
   drilldown: {
     cssClass: 'drilldown',
-    plugin: __WEBPACK_IMPORTED_MODULE_5__foundation_drilldown__["Drilldown"]
+    plugin: _foundation_drilldown__WEBPACK_IMPORTED_MODULE_4__["Drilldown"]
   },
   accordion: {
     cssClass: 'accordion-menu',
-    plugin: __WEBPACK_IMPORTED_MODULE_6__foundation_accordionMenu__["AccordionMenu"]
+    plugin: _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5__["AccordionMenu"]
   }
-};
-
-// import "foundation.util.triggers.js";
-
+}; // import "foundation.util.triggers.js";
 
 /**
  * ResponsiveMenu module.
@@ -175,17 +245,19 @@ var MenuPlugins = {
  * @requires foundation.util.mediaQuery
  */
 
-var ResponsiveMenu = function (_Plugin) {
+var ResponsiveMenu =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(ResponsiveMenu, _Plugin);
 
   function ResponsiveMenu() {
     _classCallCheck(this, ResponsiveMenu);
 
-    return _possibleConstructorReturn(this, (ResponsiveMenu.__proto__ || Object.getPrototypeOf(ResponsiveMenu)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveMenu).apply(this, arguments));
   }
 
   _createClass(ResponsiveMenu, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of a responsive menu.
@@ -196,16 +268,16 @@ var ResponsiveMenu = function (_Plugin) {
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
-      this.$element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(element);
+      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);
       this.rules = this.$element.data('responsive-menu');
       this.currentMq = null;
       this.currentPlugin = null;
       this.className = 'ResponsiveMenu'; // ie9 back compat
 
       this._init();
+
       this._events();
     }
-
     /**
      * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.
      * @function
@@ -213,18 +285,16 @@ var ResponsiveMenu = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
+
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"]._init();
-      // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
       if (typeof this.rules === 'string') {
-        var rulesTree = {};
+        var rulesTree = {}; // Parse rules from "classes" pulled from data attribute
 
-        // Parse rules from "classes" pulled from data attribute
-        var rules = this.rules.split(' ');
+        var rules = this.rules.split(' '); // Iterate through every rule found
 
-        // Iterate through every rule found
         for (var i = 0; i < rules.length; i++) {
           var rule = rules[i].split('-');
           var ruleSize = rule.length > 1 ? rule[0] : 'small';
@@ -238,13 +308,13 @@ var ResponsiveMenu = function (_Plugin) {
         this.rules = rulesTree;
       }
 
-      if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.isEmptyObject(this.rules)) {
+      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) {
         this._checkMediaQueries();
-      }
-      // Add data-mutate since children may need it.
-      this.$element.attr('data-mutate', this.$element.attr('data-mutate') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["GetYoDigits"])(6, 'responsive-menu'));
-    }
+      } // Add data-mutate since children may need it.
 
+
+      this.$element.attr('data-mutate', this.$element.attr('data-mutate') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["GetYoDigits"])(6, 'responsive-menu'));
+    }
     /**
      * Initializes events for the Menu.
      * @function
@@ -252,18 +322,16 @@ var ResponsiveMenu = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this;
 
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', function () {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () {
         _this._checkMediaQueries();
-      });
-      // $(window).on('resize.zf.ResponsiveMenu', function() {
+      }); // $(window).on('resize.zf.ResponsiveMenu', function() {
       //   _this._checkMediaQueries();
       // });
     }
-
     /**
      * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
      * @function
@@ -271,92 +339,75 @@ var ResponsiveMenu = function (_Plugin) {
      */
 
   }, {
-    key: '_checkMediaQueries',
+    key: "_checkMediaQueries",
     value: function _checkMediaQueries() {
       var matchedMq,
-          _this = this;
-      // Iterate through each rule and find the last matching rule
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(this.rules, function (key) {
-        if (__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"].atLeast(key)) {
+          _this = this; // Iterate through each rule and find the last matching rule
+
+
+      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) {
+        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].atLeast(key)) {
           matchedMq = key;
         }
-      });
+      }); // No match? No dice
 
-      // No match? No dice
-      if (!matchedMq) return;
+      if (!matchedMq) return; // Plugin already initialized? We good
 
-      // Plugin already initialized? We good
-      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;
+      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes
 
-      // Remove existing plugin-specific CSS classes
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.each(MenuPlugins, function (key, value) {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) {
         _this.$element.removeClass(value.cssClass);
-      });
+      }); // Add the CSS class for the new plugin
 
-      // Add the CSS class for the new plugin
-      this.$element.addClass(this.rules[matchedMq].cssClass);
+      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin
 
-      // Create an instance of the new plugin
       if (this.currentPlugin) this.currentPlugin.destroy();
       this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
     }
-
     /**
      * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.currentPlugin.destroy();
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('.zf.ResponsiveMenu');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('.zf.ResponsiveMenu');
     }
   }]);
 
   return ResponsiveMenu;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__["Plugin"]);
 
 ResponsiveMenu.defaults = {};
 
 
-
-/***/ }),
-
-/***/ 6:
-/***/ (function(module, exports) {
-
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
-
 /***/ }),
 
-/***/ 73:
-/***/ (function(module, exports) {
-
-module.exports = {AccordionMenu: window.Foundation.AccordionMenu};
-
-/***/ }),
+/***/ 12:
+/*!***************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.responsiveMenu.js ***!
+  \***************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-/***/ 74:
-/***/ (function(module, exports) {
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.responsiveMenu.js */"./js/entries/plugins/foundation.responsiveMenu.js");
 
-module.exports = {Drilldown: window.Foundation.Drilldown};
 
 /***/ }),
 
-/***/ 75:
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {DropdownMenu: window.Foundation.DropdownMenu};
-
-/***/ }),
-
-/***/ 91:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(25);
-
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.responsiveMenu.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.responsiveMenu.js.map b/dist/js/plugins/foundation.responsiveMenu.js.map
new file mode 100644 (file)
index 0000000..4a21e13
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.accordionMenu\"],\"amd\":\"./foundation.accordionMenu\",\"commonjs\":\"./foundation.accordionMenu\",\"commonjs2\":\"./foundation.accordionMenu\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.drilldown\"],\"amd\":\"./foundation.drilldown\",\"commonjs\":\"./foundation.drilldown\",\"commonjs2\":\"./foundation.drilldown\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.dropdownMenu\"],\"amd\":\"./foundation.dropdownMenu\",\"commonjs\":\"./foundation.dropdownMenu\",\"commonjs2\":\"./foundation.dropdownMenu\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.responsiveMenu.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.responsiveMenu.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","ResponsiveMenu","MenuPlugins","dropdown","cssClass","DropdownMenu","drilldown","Drilldown","accordion","AccordionMenu","element","options","$element","$","rules","data","currentMq","currentPlugin","className","_init","_events","MediaQuery","rulesTree","split","i","length","rule","ruleSize","rulePlugin","isEmptyObject","_checkMediaQueries","attr","GetYoDigits","_this","window","on","matchedMq","each","key","atLeast","value","removeClass","addClass","destroy","off","Plugin","defaults"],"mappings":"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","file":"foundation.responsiveMenu.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.accordionMenu\"), require(\"./foundation.core\"), require(\"./foundation.drilldown\"), require(\"./foundation.dropdownMenu\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.accordionMenu\", \"./foundation.core\", \"./foundation.drilldown\", \"./foundation.dropdownMenu\", \"./foundation.util.mediaQuery\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.responsiveMenu\"] = factory(require(\"./foundation.accordionMenu\"), require(\"./foundation.core\"), require(\"./foundation.drilldown\"), require(\"./foundation.dropdownMenu\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.responsiveMenu\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.accordionMenu\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.drilldown\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.dropdownMenu\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_accordionMenu__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_drilldown__, __WEBPACK_EXTERNAL_MODULE__foundation_dropdownMenu__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 12);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_accordionMenu__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_drilldown__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_dropdownMenu__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","import { Foundation } from './foundation.core';\n\nimport { ResponsiveMenu } from '../../foundation.responsiveMenu';\nFoundation.plugin(ResponsiveMenu, 'ResponsiveMenu');\n\nexport { Foundation, ResponsiveMenu };\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\nimport { DropdownMenu } from './foundation.dropdownMenu';\nimport { Drilldown } from './foundation.drilldown';\nimport { AccordionMenu } from './foundation.accordionMenu';\n\nlet MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: DropdownMenu\n  },\n drilldown: {\n    cssClass: 'drilldown',\n    plugin: Drilldown\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: AccordionMenu\n  }\n};\n\n  // import \"foundation.util.triggers.js\";\n\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass ResponsiveMenu extends Plugin {\n  /**\n   * Creates a new instance of a responsive menu.\n   * @class\n   * @name ResponsiveMenu\n   * @fires ResponsiveMenu#init\n   * @param {jQuery} element - jQuery object to make into a dropdown menu.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.rules = this.$element.data('responsive-menu');\n    this.currentMq = null;\n    this.currentPlugin = null;\n    this.className = 'ResponsiveMenu'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.\n   * @function\n   * @private\n   */\n  _init() {\n\n    MediaQuery._init();\n    // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n    if (typeof this.rules === 'string') {\n      let rulesTree = {};\n\n      // Parse rules from \"classes\" pulled from data attribute\n      let rules = this.rules.split(' ');\n\n      // Iterate through every rule found\n      for (let i = 0; i < rules.length; i++) {\n        let rule = rules[i].split('-');\n        let ruleSize = rule.length > 1 ? rule[0] : 'small';\n        let rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n        if (MenuPlugins[rulePlugin] !== null) {\n          rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n        }\n      }\n\n      this.rules = rulesTree;\n    }\n\n    if (!$.isEmptyObject(this.rules)) {\n      this._checkMediaQueries();\n    }\n    // Add data-mutate since children may need it.\n    this.$element.attr('data-mutate', (this.$element.attr('data-mutate') || GetYoDigits(6, 'responsive-menu')));\n  }\n\n  /**\n   * Initializes events for the Menu.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    $(window).on('changed.zf.mediaquery', function() {\n      _this._checkMediaQueries();\n    });\n    // $(window).on('resize.zf.ResponsiveMenu', function() {\n    //   _this._checkMediaQueries();\n    // });\n  }\n\n  /**\n   * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n   * @function\n   * @private\n   */\n  _checkMediaQueries() {\n    var matchedMq, _this = this;\n    // Iterate through each rule and find the last matching rule\n    $.each(this.rules, function(key) {\n      if (MediaQuery.atLeast(key)) {\n        matchedMq = key;\n      }\n    });\n\n    // No match? No dice\n    if (!matchedMq) return;\n\n    // Plugin already initialized? We good\n    if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;\n\n    // Remove existing plugin-specific CSS classes\n    $.each(MenuPlugins, function(key, value) {\n      _this.$element.removeClass(value.cssClass);\n    });\n\n    // Add the CSS class for the new plugin\n    this.$element.addClass(this.rules[matchedMq].cssClass);\n\n    // Create an instance of the new plugin\n    if (this.currentPlugin) this.currentPlugin.destroy();\n    this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n  }\n\n  /**\n   * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n   * @function\n   */\n  _destroy() {\n    this.currentPlugin.destroy();\n    $(window).off('.zf.ResponsiveMenu');\n  }\n}\n\nResponsiveMenu.defaults = {};\n\nexport {ResponsiveMenu};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 2a71786588cf85bae82fef57d59e7bbf3994ec2a..ccc7cee1a04d44d111c076223088153fbb877447 100644 (file)
@@ -1 +1,2 @@
-!function(n){function e(i){if(t[i])return t[i].exports;var o=t[i]={i:i,l:!1,exports:{}};return n[i].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var t={};e.m=n,e.c=t,e.i=function(n){return n},e.d=function(n,t,i){e.o(n,t)||Object.defineProperty(n,t,{configurable:!1,enumerable:!0,get:i})},e.n=function(n){var t=n&&n.__esModule?function(){return n.default}:function(){return n};return e.d(t,"a",t),t},e.o=function(n,e){return Object.prototype.hasOwnProperty.call(n,e)},e.p="",e(e.s=91)}({0:function(n,e){n.exports=jQuery},1:function(n,e){n.exports={Foundation:window.Foundation}},2:function(n,e){n.exports={Plugin:window.Foundation.Plugin}},25:function(n,e,t){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=t(1),o=(t.n(i),t(55));i.Foundation.plugin(o.a,"ResponsiveMenu")},3:function(n,e){n.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},55:function(n,e,t){"use strict";function i(n,e){if(!(n instanceof e))throw new TypeError("Cannot call a class as a function")}function o(n,e){if(!n)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?n:e}function r(n,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);n.prototype=Object.create(e&&e.prototype,{constructor:{value:n,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(n,e):n.__proto__=e)}t.d(e,"a",function(){return y});var u=t(0),s=t.n(u),a=t(6),l=(t.n(a),t(3)),c=(t.n(l),t(2)),d=(t.n(c),t(75)),f=(t.n(d),t(74)),p=(t.n(f),t(73)),h=(t.n(p),function(){function n(n,e){for(var t=0;t<e.length;t++){var i=e[t];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(n,i.key,i)}}return function(e,t,i){return t&&n(e.prototype,t),i&&n(e,i),e}}()),w={dropdown:{cssClass:"dropdown",plugin:d.DropdownMenu},drilldown:{cssClass:"drilldown",plugin:f.Drilldown},accordion:{cssClass:"accordion-menu",plugin:p.AccordionMenu}},y=function(n){function e(){return i(this,e),o(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return r(e,n),h(e,[{key:"_setup",value:function(n,e){this.$element=s()(n),this.rules=this.$element.data("responsive-menu"),this.currentMq=null,this.currentPlugin=null,this.className="ResponsiveMenu",this._init(),this._events()}},{key:"_init",value:function(){if(a.MediaQuery._init(),"string"==typeof this.rules){for(var n={},e=this.rules.split(" "),i=0;i<e.length;i++){var o=e[i].split("-"),r=o.length>1?o[0]:"small",u=o.length>1?o[1]:o[0];null!==w[u]&&(n[r]=w[u])}this.rules=n}s.a.isEmptyObject(this.rules)||this._checkMediaQueries(),this.$element.attr("data-mutate",this.$element.attr("data-mutate")||t.i(l.GetYoDigits)(6,"responsive-menu"))}},{key:"_events",value:function(){var n=this;s()(window).on("changed.zf.mediaquery",function(){n._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var n,e=this;s.a.each(this.rules,function(e){a.MediaQuery.atLeast(e)&&(n=e)}),n&&(this.currentPlugin instanceof this.rules[n].plugin||(s.a.each(w,function(n,t){e.$element.removeClass(t.cssClass)}),this.$element.addClass(this.rules[n].cssClass),this.currentPlugin&&this.currentPlugin.destroy(),this.currentPlugin=new this.rules[n].plugin(this.$element,{})))}},{key:"_destroy",value:function(){this.currentPlugin.destroy(),s()(window).off(".zf.ResponsiveMenu")}}]),e}(c.Plugin);y.defaults={}},6:function(n,e){n.exports={MediaQuery:window.Foundation.MediaQuery}},73:function(n,e){n.exports={AccordionMenu:window.Foundation.AccordionMenu}},74:function(n,e){n.exports={Drilldown:window.Foundation.Drilldown}},75:function(n,e){n.exports={DropdownMenu:window.Foundation.DropdownMenu}},91:function(n,e,t){n.exports=t(25)}});
\ No newline at end of file
+!function(n,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.accordionMenu"),require("./foundation.core"),require("./foundation.drilldown"),require("./foundation.dropdownMenu"),require("./foundation.util.mediaQuery"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.accordionMenu","./foundation.core","./foundation.drilldown","./foundation.dropdownMenu","./foundation.util.mediaQuery","jquery"],e):"object"==typeof exports?exports["foundation.responsiveMenu"]=e(require("./foundation.accordionMenu"),require("./foundation.core"),require("./foundation.drilldown"),require("./foundation.dropdownMenu"),require("./foundation.util.mediaQuery"),require("jquery")):(n.__FOUNDATION_EXTERNAL__=n.__FOUNDATION_EXTERNAL__||{},n.__FOUNDATION_EXTERNAL__["foundation.responsiveMenu"]=e(n.__FOUNDATION_EXTERNAL__["foundation.accordionMenu"],n.__FOUNDATION_EXTERNAL__["foundation.core"],n.__FOUNDATION_EXTERNAL__["foundation.drilldown"],n.__FOUNDATION_EXTERNAL__["foundation.dropdownMenu"],n.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],n.jQuery))}(window,function(t,o,r,i,u,s){return function(t){var o={};function r(n){if(o[n])return o[n].exports;var e=o[n]={i:n,l:!1,exports:{}};return t[n].call(e.exports,e,e.exports,r),e.l=!0,e.exports}return r.m=t,r.c=o,r.d=function(n,e,t){r.o(n,e)||Object.defineProperty(n,e,{enumerable:!0,get:t})},r.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},r.t=function(e,n){if(1&n&&(e=r(e)),8&n)return e;if(4&n&&"object"==typeof e&&e&&e.__esModule)return e;var t=Object.create(null);if(r.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:e}),2&n&&"string"!=typeof e)for(var o in e)r.d(t,o,function(n){return e[n]}.bind(null,o));return t},r.n=function(n){var e=n&&n.__esModule?function(){return n.default}:function(){return n};return r.d(e,"a",e),e},r.o=function(n,e){return Object.prototype.hasOwnProperty.call(n,e)},r.p="",r(r.s=12)}({"./foundation.accordionMenu":function(n,e){n.exports=t},"./foundation.core":function(n,e){n.exports=o},"./foundation.drilldown":function(n,e){n.exports=r},"./foundation.dropdownMenu":function(n,e){n.exports=i},"./foundation.util.mediaQuery":function(n,e){n.exports=u},"./js/entries/plugins/foundation.responsiveMenu.js":function(n,e,t){"use strict";t.r(e);var o=t("./foundation.core");t.d(e,"Foundation",function(){return o.Foundation});var r=t("./js/foundation.responsiveMenu.js");t.d(e,"ResponsiveMenu",function(){return r.ResponsiveMenu}),o.Foundation.plugin(r.ResponsiveMenu,"ResponsiveMenu")},"./js/foundation.responsiveMenu.js":function(n,e,t){"use strict";t.r(e),t.d(e,"ResponsiveMenu",function(){return h});var o=t("jquery"),u=t.n(o),s=t("./foundation.util.mediaQuery"),a=t("./foundation.core"),r=t("./foundation.dropdownMenu"),i=t("./foundation.drilldown"),f=t("./foundation.accordionMenu");function c(n){return(c="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(n){return typeof n}:function(n){return n&&"function"==typeof Symbol&&n.constructor===Symbol&&n!==Symbol.prototype?"symbol":typeof n})(n)}function d(n,e){for(var t=0;t<e.length;t++){var o=e[t];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(n,o.key,o)}}function l(n,e){return!e||"object"!==c(e)&&"function"!=typeof e?function(n){if(void 0!==n)return n;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(n):e}function p(n){return(p=Object.setPrototypeOf?Object.getPrototypeOf:function(n){return n.__proto__||Object.getPrototypeOf(n)})(n)}function y(n,e){return(y=Object.setPrototypeOf||function(n,e){return n.__proto__=e,n})(n,e)}var _={dropdown:{cssClass:"dropdown",plugin:r.DropdownMenu},drilldown:{cssClass:"drilldown",plugin:i.Drilldown},accordion:{cssClass:"accordion-menu",plugin:f.AccordionMenu}},h=function(n){function e(){return function(n,e){if(!(n instanceof e))throw new TypeError("Cannot call a class as a function")}(this,e),l(this,p(e).apply(this,arguments))}var t,o,r;return function(n,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");n.prototype=Object.create(e&&e.prototype,{constructor:{value:n,writable:!0,configurable:!0}}),e&&y(n,e)}(e,a["Plugin"]),t=e,(o=[{key:"_setup",value:function(n,e){this.$element=u()(n),this.rules=this.$element.data("responsive-menu"),this.currentMq=null,this.currentPlugin=null,this.className="ResponsiveMenu",this._init(),this._events()}},{key:"_init",value:function(){if(s.MediaQuery._init(),"string"==typeof this.rules){for(var n={},e=this.rules.split(" "),t=0;t<e.length;t++){var o=e[t].split("-"),r=1<o.length?o[0]:"small",i=1<o.length?o[1]:o[0];null!==_[i]&&(n[r]=_[i])}this.rules=n}u.a.isEmptyObject(this.rules)||this._checkMediaQueries(),this.$element.attr("data-mutate",this.$element.attr("data-mutate")||Object(a.GetYoDigits)(6,"responsive-menu"))}},{key:"_events",value:function(){var n=this;u()(window).on("changed.zf.mediaquery",function(){n._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var e,t=this;u.a.each(this.rules,function(n){s.MediaQuery.atLeast(n)&&(e=n)}),e&&(this.currentPlugin instanceof this.rules[e].plugin||(u.a.each(_,function(n,e){t.$element.removeClass(e.cssClass)}),this.$element.addClass(this.rules[e].cssClass),this.currentPlugin&&this.currentPlugin.destroy(),this.currentPlugin=new this.rules[e].plugin(this.$element,{})))}},{key:"_destroy",value:function(){this.currentPlugin.destroy(),u()(window).off(".zf.ResponsiveMenu")}}])&&d(t.prototype,o),r&&d(t,r),e}();h.defaults={}},12:function(n,e,t){n.exports=t("./js/entries/plugins/foundation.responsiveMenu.js")},jquery:function(n,e){n.exports=s}})});
+//# sourceMappingURL=foundation.responsiveMenu.min.js.map
diff --git a/dist/js/plugins/foundation.responsiveMenu.min.js.map b/dist/js/plugins/foundation.responsiveMenu.min.js.map
new file mode 100644 (file)
index 0000000..8317d3c
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.responsiveMenu.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_accordionMenu__","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_drilldown__","__WEBPACK_EXTERNAL_MODULE__foundation_dropdownMenu__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.accordionMenu","./foundation.core","./foundation.drilldown","./foundation.dropdownMenu","./foundation.util.mediaQuery","./js/entries/plugins/foundation.responsiveMenu.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.responsiveMenu.js","ResponsiveMenu","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__","_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3__","_foundation_drilldown__WEBPACK_IMPORTED_MODULE_4__","_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","MenuPlugins","dropdown","cssClass","drilldown","accordion","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","rules","data","currentMq","currentPlugin","className","_init","_events","rulesTree","split","rule","ruleSize","rulePlugin","a","isEmptyObject","_checkMediaQueries","attr","_this","on","matchedMq","each","atLeast","removeClass","addClass","destroy","off","defaults","12","jquery"],"mappings":"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","file":"foundation.responsiveMenu.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.accordionMenu\"), require(\"./foundation.core\"), require(\"./foundation.drilldown\"), require(\"./foundation.dropdownMenu\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.accordionMenu\", \"./foundation.core\", \"./foundation.drilldown\", \"./foundation.dropdownMenu\", \"./foundation.util.mediaQuery\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.responsiveMenu\"] = factory(require(\"./foundation.accordionMenu\"), require(\"./foundation.core\"), require(\"./foundation.drilldown\"), require(\"./foundation.dropdownMenu\"), require(\"./foundation.util.mediaQuery\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.responsiveMenu\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.accordionMenu\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.drilldown\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.dropdownMenu\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_accordionMenu__, __WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_drilldown__, __WEBPACK_EXTERNAL_MODULE__foundation_dropdownMenu__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 12);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.accordionMenu\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.accordionMenu\"],\"amd\":\"./foundation.accordionMenu\",\"commonjs\":\"./foundation.accordionMenu\",\"commonjs2\":\"./foundation.accordionMenu\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_accordionMenu__;\n\n/***/ }),\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.drilldown\":\n/*!************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.drilldown\"],\"amd\":\"./foundation.drilldown\",\"commonjs\":\"./foundation.drilldown\",\"commonjs2\":\"./foundation.drilldown\"} ***!\n  \\************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_drilldown__;\n\n/***/ }),\n\n/***/ \"./foundation.dropdownMenu\":\n/*!************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.dropdownMenu\"],\"amd\":\"./foundation.dropdownMenu\",\"commonjs\":\"./foundation.dropdownMenu\",\"commonjs2\":\"./foundation.dropdownMenu\"} ***!\n  \\************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_dropdownMenu__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.responsiveMenu.js\":\n/*!*********************************************************!*\\\n  !*** ./js/entries/plugins/foundation.responsiveMenu.js ***!\n  \\*********************************************************/\n/*! exports provided: Foundation, ResponsiveMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.responsiveMenu */ \"./js/foundation.responsiveMenu.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveMenu\", function() { return _foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_1__[\"ResponsiveMenu\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_responsiveMenu__WEBPACK_IMPORTED_MODULE_1__[\"ResponsiveMenu\"], 'ResponsiveMenu');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.responsiveMenu.js\":\n/*!*****************************************!*\\\n  !*** ./js/foundation.responsiveMenu.js ***!\n  \\*****************************************/\n/*! exports provided: ResponsiveMenu */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveMenu\", function() { return ResponsiveMenu; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.dropdownMenu */ \"./foundation.dropdownMenu\");\n/* harmony import */ var _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.drilldown */ \"./foundation.drilldown\");\n/* harmony import */ var _foundation_drilldown__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_drilldown__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.accordionMenu */ \"./foundation.accordionMenu\");\n/* harmony import */ var _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(_foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\nvar MenuPlugins = {\n  dropdown: {\n    cssClass: 'dropdown',\n    plugin: _foundation_dropdownMenu__WEBPACK_IMPORTED_MODULE_3__[\"DropdownMenu\"]\n  },\n  drilldown: {\n    cssClass: 'drilldown',\n    plugin: _foundation_drilldown__WEBPACK_IMPORTED_MODULE_4__[\"Drilldown\"]\n  },\n  accordion: {\n    cssClass: 'accordion-menu',\n    plugin: _foundation_accordionMenu__WEBPACK_IMPORTED_MODULE_5__[\"AccordionMenu\"]\n  }\n}; // import \"foundation.util.triggers.js\";\n\n/**\n * ResponsiveMenu module.\n * @module foundation.responsiveMenu\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nvar ResponsiveMenu =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(ResponsiveMenu, _Plugin);\n\n  function ResponsiveMenu() {\n    _classCallCheck(this, ResponsiveMenu);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveMenu).apply(this, arguments));\n  }\n\n  _createClass(ResponsiveMenu, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a responsive menu.\n     * @class\n     * @name ResponsiveMenu\n     * @fires ResponsiveMenu#init\n     * @param {jQuery} element - jQuery object to make into a dropdown menu.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);\n      this.rules = this.$element.data('responsive-menu');\n      this.currentMq = null;\n      this.currentPlugin = null;\n      this.className = 'ResponsiveMenu'; // ie9 back compat\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the Menu by parsing the classes from the 'data-ResponsiveMenu' attribute on the element.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init(); // The first time an Interchange plugin is initialized, this.rules is converted from a string of \"classes\" to an object of rules\n\n\n      if (typeof this.rules === 'string') {\n        var rulesTree = {}; // Parse rules from \"classes\" pulled from data attribute\n\n        var rules = this.rules.split(' '); // Iterate through every rule found\n\n        for (var i = 0; i < rules.length; i++) {\n          var rule = rules[i].split('-');\n          var ruleSize = rule.length > 1 ? rule[0] : 'small';\n          var rulePlugin = rule.length > 1 ? rule[1] : rule[0];\n\n          if (MenuPlugins[rulePlugin] !== null) {\n            rulesTree[ruleSize] = MenuPlugins[rulePlugin];\n          }\n        }\n\n        this.rules = rulesTree;\n      }\n\n      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default.a.isEmptyObject(this.rules)) {\n        this._checkMediaQueries();\n      } // Add data-mutate since children may need it.\n\n\n      this.$element.attr('data-mutate', this.$element.attr('data-mutate') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"GetYoDigits\"])(6, 'responsive-menu'));\n    }\n    /**\n     * Initializes events for the Menu.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', function () {\n        _this._checkMediaQueries();\n      }); // $(window).on('resize.zf.ResponsiveMenu', function() {\n      //   _this._checkMediaQueries();\n      // });\n    }\n    /**\n     * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_checkMediaQueries\",\n    value: function _checkMediaQueries() {\n      var matchedMq,\n          _this = this; // Iterate through each rule and find the last matching rule\n\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(this.rules, function (key) {\n        if (_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].atLeast(key)) {\n          matchedMq = key;\n        }\n      }); // No match? No dice\n\n      if (!matchedMq) return; // Plugin already initialized? We good\n\n      if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return; // Remove existing plugin-specific CSS classes\n\n      jquery__WEBPACK_IMPORTED_MODULE_0___default.a.each(MenuPlugins, function (key, value) {\n        _this.$element.removeClass(value.cssClass);\n      }); // Add the CSS class for the new plugin\n\n      this.$element.addClass(this.rules[matchedMq].cssClass); // Create an instance of the new plugin\n\n      if (this.currentPlugin) this.currentPlugin.destroy();\n      this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});\n    }\n    /**\n     * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.currentPlugin.destroy();\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('.zf.ResponsiveMenu');\n    }\n  }]);\n\n  return ResponsiveMenu;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]);\n\nResponsiveMenu.defaults = {};\n\n\n/***/ }),\n\n/***/ 12:\n/*!***************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.responsiveMenu.js ***!\n  \\***************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.responsiveMenu.js */\"./js/entries/plugins/foundation.responsiveMenu.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.responsiveMenu.js.map"]}
\ No newline at end of file
index ffd6defb3370ef52d6c3a4b65a04dd5b447cdc21..ce56521915b10385d14e1ba098bd5746f4234f96 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.mediaQuery", "./foundation.util.motion", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.responsiveToggle"] = factory(require("./foundation.core"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.responsiveToggle"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 92);
+/******/       return __webpack_require__(__webpack_require__.s = 13);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
 /***/ }),
 
-/***/ 26:
+/***/ "./js/entries/plugins/foundation.responsiveToggle.js":
+/*!***********************************************************!*\
+  !*** ./js/entries/plugins/foundation.responsiveToggle.js ***!
+  \***********************************************************/
+/*! exports provided: Foundation, ResponsiveToggle */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_responsiveToggle__ = __webpack_require__(56);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.responsiveToggle */ "./js/foundation.responsiveToggle.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "ResponsiveToggle", function() { return _foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_1__["ResponsiveToggle"]; });
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_responsiveToggle__["a" /* ResponsiveToggle */], 'ResponsiveToggle');
 
-/***/ }),
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_1__["ResponsiveToggle"], 'ResponsiveToggle');
 
-/***/ 4:
-/***/ (function(module, exports) {
-
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
 
 /***/ }),
 
-/***/ 56:
+/***/ "./js/foundation.responsiveToggle.js":
+/*!*******************************************!*\
+  !*** ./js/foundation.responsiveToggle.js ***!
+  \*******************************************/
+/*! exports provided: ResponsiveToggle */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return ResponsiveToggle; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "ResponsiveToggle", function() { return ResponsiveToggle; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ "./foundation.core");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return 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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -147,17 +201,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.motion
  */
 
-var ResponsiveToggle = function (_Plugin) {
+var ResponsiveToggle =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(ResponsiveToggle, _Plugin);
 
   function ResponsiveToggle() {
     _classCallCheck(this, ResponsiveToggle);
 
-    return _possibleConstructorReturn(this, (ResponsiveToggle.__proto__ || Object.getPrototypeOf(ResponsiveToggle)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveToggle).apply(this, arguments));
   }
 
   _createClass(ResponsiveToggle, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of Tab Bar.
@@ -168,14 +224,14 @@ var ResponsiveToggle = function (_Plugin) {
      * @param {Object} options - Overrides to the default plugin settings.
      */
     value: function _setup(element, options) {
-      this.$element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(element);
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
+      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);
       this.className = 'ResponsiveToggle'; // ie9 back compat
 
       this._init();
+
       this._events();
     }
-
     /**
      * Initializes the tab bar by finding the target element, toggling element, and running update().
      * @function
@@ -183,32 +239,31 @@ var ResponsiveToggle = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"]._init();
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]._init();
+
       var targetID = this.$element.data('responsive-toggle');
+
       if (!targetID) {
         console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');
       }
 
-      this.$targetMenu = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + targetID);
+      this.$targetMenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(targetID));
       this.$toggler = this.$element.find('[data-toggle]').filter(function () {
-        var target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+        var target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
         return target === targetID || target === "";
       });
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, this.options, this.$targetMenu.data());
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.options, this.$targetMenu.data()); // If they were set, parse the animation classes
 
-      // If they were set, parse the animation classes
       if (this.options.animate) {
         var input = this.options.animate.split(' ');
-
         this.animationIn = input[0];
         this.animationOut = input[1] || null;
       }
 
       this._update();
     }
-
     /**
      * Adds necessary event handlers for the tab bar to work.
      * @function
@@ -216,17 +271,14 @@ var ResponsiveToggle = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this;
 
       this._updateMqHandler = this._update.bind(this);
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', this._updateMqHandler);
-
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._updateMqHandler);
       this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));
     }
-
     /**
      * Checks the current media query to determine if the tab bar should be visible or hidden.
      * @function
@@ -234,21 +286,18 @@ var ResponsiveToggle = function (_Plugin) {
      */
 
   }, {
-    key: '_update',
+    key: "_update",
     value: function _update() {
       // Mobile
-      if (!__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"].atLeast(this.options.hideFor)) {
+      if (!_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].atLeast(this.options.hideFor)) {
         this.$element.show();
         this.$targetMenu.hide();
-      }
-
-      // Desktop
+      } // Desktop
       else {
           this.$element.hide();
           this.$targetMenu.show();
         }
     }
-
     /**
      * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.
      * @function
@@ -256,24 +305,25 @@ var ResponsiveToggle = function (_Plugin) {
      */
 
   }, {
-    key: 'toggleMenu',
+    key: "toggleMenu",
     value: function toggleMenu() {
-      var _this3 = this;
+      var _this2 = this;
 
-      if (!__WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["MediaQuery"].atLeast(this.options.hideFor)) {
+      if (!_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"].atLeast(this.options.hideFor)) {
         /**
          * Fires when the element attached to the tab bar toggles.
          * @event ResponsiveToggle#toggled
          */
         if (this.options.animate) {
           if (this.$targetMenu.is(':hidden')) {
-            __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["Motion"].animateIn(this.$targetMenu, this.animationIn, function () {
-              _this3.$element.trigger('toggled.zf.responsiveToggle');
-              _this3.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
+            _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateIn(this.$targetMenu, this.animationIn, function () {
+              _this2.$element.trigger('toggled.zf.responsiveToggle');
+
+              _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');
             });
           } else {
-            __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["Motion"].animateOut(this.$targetMenu, this.animationOut, function () {
-              _this3.$element.trigger('toggled.zf.responsiveToggle');
+            _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(this.$targetMenu, this.animationOut, function () {
+              _this2.$element.trigger('toggled.zf.responsiveToggle');
             });
           }
         } else {
@@ -284,17 +334,16 @@ var ResponsiveToggle = function (_Plugin) {
       }
     }
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.$element.off('.zf.responsiveToggle');
       this.$toggler.off('.zf.responsiveToggle');
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('changed.zf.mediaquery', this._updateMqHandler);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._updateMqHandler);
     }
   }]);
 
   return ResponsiveToggle;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["Plugin"]);
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 
 ResponsiveToggle.defaults = {
   /**
@@ -315,22 +364,31 @@ ResponsiveToggle.defaults = {
 };
 
 
-
 /***/ }),
 
-/***/ 6:
-/***/ (function(module, exports) {
+/***/ 13:
+/*!*****************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.responsiveToggle.js ***!
+  \*****************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.responsiveToggle.js */"./js/entries/plugins/foundation.responsiveToggle.js");
 
-/***/ }),
 
-/***/ 92:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ }),
 
-module.exports = __webpack_require__(26);
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.responsiveToggle.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.responsiveToggle.js.map b/dist/js/plugins/foundation.responsiveToggle.js.map
new file mode 100644 (file)
index 0000000..f49dc41
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.responsiveToggle.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.responsiveToggle.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","ResponsiveToggle","element","options","$element","$","extend","defaults","data","className","_init","_events","MediaQuery","targetID","console","error","$targetMenu","$toggler","find","filter","target","animate","input","split","animationIn","animationOut","_update","_this","_updateMqHandler","bind","window","on","toggleMenu","atLeast","hideFor","show","hide","is","Motion","animateIn","trigger","triggerHandler","animateOut","toggle","off","Plugin"],"mappings":"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","file":"foundation.responsiveToggle.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.responsiveToggle\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.responsiveToggle\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 13);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","import { Foundation } from './foundation.core';\n\nimport { ResponsiveToggle } from '../../foundation.responsiveToggle';\nFoundation.plugin(ResponsiveToggle, 'ResponsiveToggle');\n\nexport { Foundation, ResponsiveToggle };\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion\n */\n\nclass ResponsiveToggle extends Plugin {\n  /**\n   * Creates a new instance of Tab Bar.\n   * @class\n   * @name ResponsiveToggle\n   * @fires ResponsiveToggle#init\n   * @param {jQuery} element - jQuery object to attach tab bar functionality to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = $(element);\n    this.options = $.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n    this.className = 'ResponsiveToggle'; // ie9 back compat\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the tab bar by finding the target element, toggling element, and running update().\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var targetID = this.$element.data('responsive-toggle');\n    if (!targetID) {\n      console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');\n    }\n\n    this.$targetMenu = $(`#${targetID}`);\n    this.$toggler = this.$element.find('[data-toggle]').filter(function() {\n      var target = $(this).data('toggle');\n      return (target === targetID || target === \"\");\n    });\n    this.options = $.extend({}, this.options, this.$targetMenu.data());\n\n    // If they were set, parse the animation classes\n    if(this.options.animate) {\n      let input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n\n    this._update();\n  }\n\n  /**\n   * Adds necessary event handlers for the tab bar to work.\n   * @function\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this._updateMqHandler = this._update.bind(this);\n\n    $(window).on('changed.zf.mediaquery', this._updateMqHandler);\n\n    this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));\n  }\n\n  /**\n   * Checks the current media query to determine if the tab bar should be visible or hidden.\n   * @function\n   * @private\n   */\n  _update() {\n    // Mobile\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      this.$element.show();\n      this.$targetMenu.hide();\n    }\n\n    // Desktop\n    else {\n      this.$element.hide();\n      this.$targetMenu.show();\n    }\n  }\n\n  /**\n   * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.\n   * @function\n   * @fires ResponsiveToggle#toggled\n   */\n  toggleMenu() {\n    if (!MediaQuery.atLeast(this.options.hideFor)) {\n      /**\n       * Fires when the element attached to the tab bar toggles.\n       * @event ResponsiveToggle#toggled\n       */\n      if(this.options.animate) {\n        if (this.$targetMenu.is(':hidden')) {\n          Motion.animateIn(this.$targetMenu, this.animationIn, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n            this.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');\n          });\n        }\n        else {\n          Motion.animateOut(this.$targetMenu, this.animationOut, () => {\n            this.$element.trigger('toggled.zf.responsiveToggle');\n          });\n        }\n      }\n      else {\n        this.$targetMenu.toggle(0);\n        this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        this.$element.trigger('toggled.zf.responsiveToggle');\n      }\n    }\n  };\n\n  _destroy() {\n    this.$element.off('.zf.responsiveToggle');\n    this.$toggler.off('.zf.responsiveToggle');\n\n    $(window).off('changed.zf.mediaquery', this._updateMqHandler);\n  }\n}\n\nResponsiveToggle.defaults = {\n  /**\n   * The breakpoint after which the menu is always shown, and the tab bar is hidden.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  hideFor: 'medium',\n\n  /**\n   * To decide if the toggle should be animated or not.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport { ResponsiveToggle };\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 677075087bfe5e0a8847e6f54423b1d2859e17b0..0849b459790602c6f92f9c2a26a29d940e8d96bb 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(i){if(n[i])return n[i].exports;var o=n[i]={i:i,l:!1,exports:{}};return t[i].call(o.exports,o,o.exports,e),o.l=!0,o.exports}var n={};e.m=t,e.c=n,e.i=function(t){return t},e.d=function(t,n,i){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:i})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=92)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},26:function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=n(1),o=(n.n(i),n(56));i.Foundation.plugin(o.a,"ResponsiveToggle")},4:function(t,e){t.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},56:function(t,e,n){"use strict";function i(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function o(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function r(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}n.d(e,"a",function(){return d});var a=n(0),u=n.n(a),s=n(6),l=(n.n(s),n(4)),f=(n.n(l),n(2)),g=(n.n(f),function(){function t(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}return function(e,n,i){return n&&t(e.prototype,n),i&&t(e,i),e}}()),d=function(t){function e(){return i(this,e),o(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return r(e,t),g(e,[{key:"_setup",value:function(t,n){this.$element=u()(t),this.options=u.a.extend({},e.defaults,this.$element.data(),n),this.className="ResponsiveToggle",this._init(),this._events()}},{key:"_init",value:function(){s.MediaQuery._init();var t=this.$element.data("responsive-toggle");if(t||console.error("Your tab bar needs an ID of a Menu as the value of data-tab-bar."),this.$targetMenu=u()("#"+t),this.$toggler=this.$element.find("[data-toggle]").filter(function(){var e=u()(this).data("toggle");return e===t||""===e}),this.options=u.a.extend({},this.options,this.$targetMenu.data()),this.options.animate){var e=this.options.animate.split(" ");this.animationIn=e[0],this.animationOut=e[1]||null}this._update()}},{key:"_events",value:function(){this._updateMqHandler=this._update.bind(this),u()(window).on("changed.zf.mediaquery",this._updateMqHandler),this.$toggler.on("click.zf.responsiveToggle",this.toggleMenu.bind(this))}},{key:"_update",value:function(){s.MediaQuery.atLeast(this.options.hideFor)?(this.$element.hide(),this.$targetMenu.show()):(this.$element.show(),this.$targetMenu.hide())}},{key:"toggleMenu",value:function(){var t=this;s.MediaQuery.atLeast(this.options.hideFor)||(this.options.animate?this.$targetMenu.is(":hidden")?l.Motion.animateIn(this.$targetMenu,this.animationIn,function(){t.$element.trigger("toggled.zf.responsiveToggle"),t.$targetMenu.find("[data-mutate]").triggerHandler("mutateme.zf.trigger")}):l.Motion.animateOut(this.$targetMenu,this.animationOut,function(){t.$element.trigger("toggled.zf.responsiveToggle")}):(this.$targetMenu.toggle(0),this.$targetMenu.find("[data-mutate]").trigger("mutateme.zf.trigger"),this.$element.trigger("toggled.zf.responsiveToggle")))}},{key:"_destroy",value:function(){this.$element.off(".zf.responsiveToggle"),this.$toggler.off(".zf.responsiveToggle"),u()(window).off("changed.zf.mediaquery",this._updateMqHandler)}}]),e}(f.Plugin);d.defaults={hideFor:"medium",animate:!1}},6:function(t,e){t.exports={MediaQuery:window.Foundation.MediaQuery}},92:function(t,e,n){t.exports=n(26)}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.mediaQuery","./foundation.util.motion","jquery"],t):"object"==typeof exports?exports["foundation.responsiveToggle"]=t(require("./foundation.core"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.responsiveToggle"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],e.__FOUNDATION_EXTERNAL__["foundation.util.motion"],e.jQuery))}(window,function(n,o,i,r){return function(n){var o={};function i(e){if(o[e])return o[e].exports;var t=o[e]={i:e,l:!1,exports:{}};return n[e].call(t.exports,t,t.exports,i),t.l=!0,t.exports}return i.m=n,i.c=o,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var o in t)i.d(n,o,function(e){return t[e]}.bind(null,o));return n},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="",i(i.s=13)}({"./foundation.core":function(e,t){e.exports=n},"./foundation.util.mediaQuery":function(e,t){e.exports=o},"./foundation.util.motion":function(e,t){e.exports=i},"./js/entries/plugins/foundation.responsiveToggle.js":function(e,t,n){"use strict";n.r(t);var o=n("./foundation.core");n.d(t,"Foundation",function(){return o.Foundation});var i=n("./js/foundation.responsiveToggle.js");n.d(t,"ResponsiveToggle",function(){return i.ResponsiveToggle}),o.Foundation.plugin(i.ResponsiveToggle,"ResponsiveToggle")},"./js/foundation.responsiveToggle.js":function(e,t,n){"use strict";n.r(t),n.d(t,"ResponsiveToggle",function(){return g});var o=n("jquery"),r=n.n(o),u=n("./foundation.util.mediaQuery"),a=n("./foundation.util.motion"),s=n("./foundation.core");function i(e){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function f(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}function l(e,t){return!t||"object"!==i(t)&&"function"!=typeof t?function(e){if(void 0!==e)return e;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(e):t}function d(e){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function c(e,t){return(c=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e})(e,t)}var g=function(e){function n(){return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,n),l(this,d(n).apply(this,arguments))}var t,o,i;return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&c(e,t)}(n,s["Plugin"]),t=n,(o=[{key:"_setup",value:function(e,t){this.$element=r()(e),this.options=r.a.extend({},n.defaults,this.$element.data(),t),this.className="ResponsiveToggle",this._init(),this._events()}},{key:"_init",value:function(){u.MediaQuery._init();var t=this.$element.data("responsive-toggle");if(t||console.error("Your tab bar needs an ID of a Menu as the value of data-tab-bar."),this.$targetMenu=r()("#".concat(t)),this.$toggler=this.$element.find("[data-toggle]").filter(function(){var e=r()(this).data("toggle");return e===t||""===e}),this.options=r.a.extend({},this.options,this.$targetMenu.data()),this.options.animate){var e=this.options.animate.split(" ");this.animationIn=e[0],this.animationOut=e[1]||null}this._update()}},{key:"_events",value:function(){this._updateMqHandler=this._update.bind(this),r()(window).on("changed.zf.mediaquery",this._updateMqHandler),this.$toggler.on("click.zf.responsiveToggle",this.toggleMenu.bind(this))}},{key:"_update",value:function(){u.MediaQuery.atLeast(this.options.hideFor)?(this.$element.hide(),this.$targetMenu.show()):(this.$element.show(),this.$targetMenu.hide())}},{key:"toggleMenu",value:function(){var e=this;u.MediaQuery.atLeast(this.options.hideFor)||(this.options.animate?this.$targetMenu.is(":hidden")?a.Motion.animateIn(this.$targetMenu,this.animationIn,function(){e.$element.trigger("toggled.zf.responsiveToggle"),e.$targetMenu.find("[data-mutate]").triggerHandler("mutateme.zf.trigger")}):a.Motion.animateOut(this.$targetMenu,this.animationOut,function(){e.$element.trigger("toggled.zf.responsiveToggle")}):(this.$targetMenu.toggle(0),this.$targetMenu.find("[data-mutate]").trigger("mutateme.zf.trigger"),this.$element.trigger("toggled.zf.responsiveToggle")))}},{key:"_destroy",value:function(){this.$element.off(".zf.responsiveToggle"),this.$toggler.off(".zf.responsiveToggle"),r()(window).off("changed.zf.mediaquery",this._updateMqHandler)}}])&&f(t.prototype,o),i&&f(t,i),n}();g.defaults={hideFor:"medium",animate:!1}},13:function(e,t,n){e.exports=n("./js/entries/plugins/foundation.responsiveToggle.js")},jquery:function(e,t){e.exports=r}})});
+//# sourceMappingURL=foundation.responsiveToggle.min.js.map
diff --git a/dist/js/plugins/foundation.responsiveToggle.min.js.map b/dist/js/plugins/foundation.responsiveToggle.min.js.map
new file mode 100644 (file)
index 0000000..45ad487
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.responsiveToggle.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.mediaQuery","./foundation.util.motion","./js/entries/plugins/foundation.responsiveToggle.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.responsiveToggle.js","ResponsiveToggle","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","_events","targetID","console","error","$targetMenu","concat","$toggler","find","filter","animate","input","split","animationIn","animationOut","_update","_updateMqHandler","on","toggleMenu","atLeast","hideFor","hide","show","_this2","is","animateIn","trigger","triggerHandler","animateOut","toggle","off","13","jquery"],"mappings":"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","file":"foundation.responsiveToggle.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.responsiveToggle\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.responsiveToggle\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 13);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.responsiveToggle.js\":\n/*!***********************************************************!*\\\n  !*** ./js/entries/plugins/foundation.responsiveToggle.js ***!\n  \\***********************************************************/\n/*! exports provided: Foundation, ResponsiveToggle */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.responsiveToggle */ \"./js/foundation.responsiveToggle.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveToggle\", function() { return _foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_1__[\"ResponsiveToggle\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_responsiveToggle__WEBPACK_IMPORTED_MODULE_1__[\"ResponsiveToggle\"], 'ResponsiveToggle');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.responsiveToggle.js\":\n/*!*******************************************!*\\\n  !*** ./js/foundation.responsiveToggle.js ***!\n  \\*******************************************/\n/*! exports provided: ResponsiveToggle */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"ResponsiveToggle\", function() { return ResponsiveToggle; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n/**\n * ResponsiveToggle module.\n * @module foundation.responsiveToggle\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion\n */\n\nvar ResponsiveToggle =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(ResponsiveToggle, _Plugin);\n\n  function ResponsiveToggle() {\n    _classCallCheck(this, ResponsiveToggle);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(ResponsiveToggle).apply(this, arguments));\n  }\n\n  _createClass(ResponsiveToggle, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Tab Bar.\n     * @class\n     * @name ResponsiveToggle\n     * @fires ResponsiveToggle#init\n     * @param {jQuery} element - jQuery object to attach tab bar functionality to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element);\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, ResponsiveToggle.defaults, this.$element.data(), options);\n      this.className = 'ResponsiveToggle'; // ie9 back compat\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the tab bar by finding the target element, toggling element, and running update().\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]._init();\n\n      var targetID = this.$element.data('responsive-toggle');\n\n      if (!targetID) {\n        console.error('Your tab bar needs an ID of a Menu as the value of data-tab-bar.');\n      }\n\n      this.$targetMenu = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(targetID));\n      this.$toggler = this.$element.find('[data-toggle]').filter(function () {\n        var target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n        return target === targetID || target === \"\";\n      });\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, this.options, this.$targetMenu.data()); // If they were set, parse the animation classes\n\n      if (this.options.animate) {\n        var input = this.options.animate.split(' ');\n        this.animationIn = input[0];\n        this.animationOut = input[1] || null;\n      }\n\n      this._update();\n    }\n    /**\n     * Adds necessary event handlers for the tab bar to work.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      this._updateMqHandler = this._update.bind(this);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._updateMqHandler);\n      this.$toggler.on('click.zf.responsiveToggle', this.toggleMenu.bind(this));\n    }\n    /**\n     * Checks the current media query to determine if the tab bar should be visible or hidden.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_update\",\n    value: function _update() {\n      // Mobile\n      if (!_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].atLeast(this.options.hideFor)) {\n        this.$element.show();\n        this.$targetMenu.hide();\n      } // Desktop\n      else {\n          this.$element.hide();\n          this.$targetMenu.show();\n        }\n    }\n    /**\n     * Toggles the element attached to the tab bar. The toggle only happens if the screen is small enough to allow it.\n     * @function\n     * @fires ResponsiveToggle#toggled\n     */\n\n  }, {\n    key: \"toggleMenu\",\n    value: function toggleMenu() {\n      var _this2 = this;\n\n      if (!_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"].atLeast(this.options.hideFor)) {\n        /**\n         * Fires when the element attached to the tab bar toggles.\n         * @event ResponsiveToggle#toggled\n         */\n        if (this.options.animate) {\n          if (this.$targetMenu.is(':hidden')) {\n            _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateIn(this.$targetMenu, this.animationIn, function () {\n              _this2.$element.trigger('toggled.zf.responsiveToggle');\n\n              _this2.$targetMenu.find('[data-mutate]').triggerHandler('mutateme.zf.trigger');\n            });\n          } else {\n            _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(this.$targetMenu, this.animationOut, function () {\n              _this2.$element.trigger('toggled.zf.responsiveToggle');\n            });\n          }\n        } else {\n          this.$targetMenu.toggle(0);\n          this.$targetMenu.find('[data-mutate]').trigger('mutateme.zf.trigger');\n          this.$element.trigger('toggled.zf.responsiveToggle');\n        }\n      }\n    }\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.responsiveToggle');\n      this.$toggler.off('.zf.responsiveToggle');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._updateMqHandler);\n    }\n  }]);\n\n  return ResponsiveToggle;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nResponsiveToggle.defaults = {\n  /**\n   * The breakpoint after which the menu is always shown, and the tab bar is hidden.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  hideFor: 'medium',\n\n  /**\n   * To decide if the toggle should be animated or not.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\n\n/***/ }),\n\n/***/ 13:\n/*!*****************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.responsiveToggle.js ***!\n  \\*****************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.responsiveToggle.js */\"./js/entries/plugins/foundation.responsiveToggle.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.responsiveToggle.js.map"]}
\ No newline at end of file
index ca13c2bacf452ba9d409fe4fffa79d4817fc3264..015025b75d574fa6e55c760b14b6bf4fa1e08978 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("./foundation.util.touch"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.keyboard", "./foundation.util.mediaQuery", "./foundation.util.motion", "./foundation.util.touch", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.reveal"] = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("./foundation.util.touch"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.reveal"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.touch"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 93);
+/******/       return __webpack_require__(__webpack_require__.s = 14);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
 
 /***/ }),
 
-/***/ 27:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_reveal__ = __webpack_require__(57);
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
+/***/ }),
 
+/***/ "./foundation.util.touch":
+/*!****************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.touch"],"amd":"./foundation.util.touch","commonjs":"./foundation.util.touch","commonjs2":"./foundation.util.touch"} ***!
+  \****************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_reveal__["a" /* Reveal */], 'Reveal');
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;
 
 /***/ }),
 
-/***/ 4:
-/***/ (function(module, exports) {
+/***/ "./js/entries/plugins/foundation.reveal.js":
+/*!*************************************************!*\
+  !*** ./js/entries/plugins/foundation.reveal.js ***!
+  \*************************************************/
+/*! exports provided: Foundation, Reveal */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
+
+/* harmony import */ var _foundation_reveal__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.reveal */ "./js/foundation.reveal.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Reveal", function() { return _foundation_reveal__WEBPACK_IMPORTED_MODULE_1__["Reveal"]; });
 
-/***/ }),
 
-/***/ 5:
-/***/ (function(module, exports) {
 
-module.exports = {Keyboard: window.Foundation.Keyboard};
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_reveal__WEBPACK_IMPORTED_MODULE_1__["Reveal"], 'Reveal');
+
 
 /***/ }),
 
-/***/ 57:
+/***/ "./js/foundation.reveal.js":
+/*!*********************************!*\
+  !*** ./js/foundation.reveal.js ***!
+  \*********************************/
+/*! exports provided: Reveal */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Reveal; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_triggers__ = __webpack_require__(7);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Reveal", function() { return Reveal; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__);
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.util.touch */ "./foundation.util.touch");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-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; }
 
 
 
@@ -160,17 +234,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.motion if using animations
  */
 
-var Reveal = function (_Plugin) {
+var Reveal =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Reveal, _Plugin);
 
   function Reveal() {
     _classCallCheck(this, Reveal);
 
-    return _possibleConstructorReturn(this, (Reveal.__proto__ || Object.getPrototypeOf(Reveal)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Reveal).apply(this, arguments));
   }
 
   _createClass(Reveal, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of Reveal.
@@ -181,33 +257,35 @@ var Reveal = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Reveal.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Reveal.defaults, this.$element.data(), options);
       this.className = 'Reveal'; // ie9 back compat
-      this._init();
 
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_5__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+      this._init(); // Triggers init is idempotent, just need to make sure it is initialized
+
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('Reveal', {
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('Reveal', {
         'ESCAPE': 'close'
       });
     }
-
     /**
      * Initializes the modal by adding the overlay and close buttons, (if selected).
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"]._init();
+      var _this2 = this;
+
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"]._init();
+
       this.id = this.$element.attr('id');
       this.isActive = false;
-      this.cached = { mq: __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"].current };
-      this.isMobile = mobileSniff();
-
-      this.$anchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-open="' + this.id + '"]').length ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-open="' + this.id + '"]') : __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-toggle="' + this.id + '"]');
+      this.cached = {
+        mq: _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__["MediaQuery"].current
+      };
+      this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(this.id, "\"]")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(this.id, "\"]")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-toggle=\"".concat(this.id, "\"]"));
       this.$anchor.attr({
         'aria-controls': this.id,
         'aria-haspopup': true,
@@ -218,6 +296,7 @@ var Reveal = function (_Plugin) {
         this.options.fullScreen = true;
         this.options.overlay = false;
       }
+
       if (this.options.overlay && !this.$overlay) {
         this.$overlay = this._makeOverlay(this.id);
       }
@@ -232,22 +311,25 @@ var Reveal = function (_Plugin) {
       if (this.$overlay) {
         this.$element.detach().appendTo(this.$overlay);
       } else {
-        this.$element.detach().appendTo(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.options.appendTo));
+        this.$element.detach().appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo));
         this.$element.addClass('without-overlay');
       }
+
       this._events();
-      if (this.options.deepLink && window.location.hash === '#' + this.id) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).one('load.zf.reveal', this.open.bind(this));
+
+      if (this.options.deepLink && window.location.hash === "#".concat(this.id)) {
+        this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+          return _this2.open();
+        });
       }
     }
-
     /**
      * Creates an overlay div to display behind the modal.
      * @private
      */
 
   }, {
-    key: '_makeOverlay',
+    key: "_makeOverlay",
     value: function _makeOverlay() {
       var additionalOverlayClasses = '';
 
@@ -255,9 +337,8 @@ var Reveal = function (_Plugin) {
         additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;
       }
 
-      return __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<div></div>').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo);
+      return jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div></div>').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo);
     }
-
     /**
      * Updates position of modal
      * TODO:  Figure out if we actually need to cache these values or if it doesn't matter
@@ -265,43 +346,55 @@ var Reveal = function (_Plugin) {
      */
 
   }, {
-    key: '_updatePosition',
+    key: "_updatePosition",
     value: function _updatePosition() {
       var width = this.$element.outerWidth();
-      var outerWidth = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).width();
+      var outerWidth = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).width();
       var height = this.$element.outerHeight();
-      var outerHeight = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).height();
-      var left, top;
+      var outerHeight = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height();
+      var left,
+          top = null;
+
       if (this.options.hOffset === 'auto') {
         left = parseInt((outerWidth - width) / 2, 10);
       } else {
         left = parseInt(this.options.hOffset, 10);
       }
+
       if (this.options.vOffset === 'auto') {
         if (height > outerHeight) {
           top = parseInt(Math.min(100, outerHeight / 10), 10);
         } else {
           top = parseInt((outerHeight - height) / 4, 10);
         }
-      } else {
+      } else if (this.options.vOffset !== null) {
         top = parseInt(this.options.vOffset, 10);
       }
-      this.$element.css({ top: top + 'px' });
-      // only worry about left if we don't have an overlay or we havea  horizontal offset,
+
+      if (top !== null) {
+        this.$element.css({
+          top: top + 'px'
+        });
+      } // only worry about left if we don't have an overlay or we have a horizontal offset,
       // otherwise we're perfectly in the middle
+
+
       if (!this.$overlay || this.options.hOffset !== 'auto') {
-        this.$element.css({ left: left + 'px' });
-        this.$element.css({ margin: '0px' });
+        this.$element.css({
+          left: left + 'px'
+        });
+        this.$element.css({
+          margin: '0px'
+        });
       }
     }
-
     /**
      * Adds event handlers for the modal.
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this3 = this;
 
@@ -309,38 +402,39 @@ var Reveal = function (_Plugin) {
 
       this.$element.on({
         'open.zf.trigger': this.open.bind(this),
-        'close.zf.trigger': function (event, $element) {
-          if (event.target === _this.$element[0] || __WEBPACK_IMPORTED_MODULE_0_jquery___default()(event.target).parents('[data-closable]')[0] === $element) {
+        'close.zf.trigger': function closeZfTrigger(event, $element) {
+          if (event.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default()(event.target).parents('[data-closable]')[0] === $element) {
             // only close reveal when it's explicitly called
             return _this3.close.apply(_this3);
           }
         },
         'toggle.zf.trigger': this.toggle.bind(this),
-        'resizeme.zf.trigger': function () {
+        'resizeme.zf.trigger': function resizemeZfTrigger() {
           _this._updatePosition();
         }
       });
 
       if (this.options.closeOnClick && this.options.overlay) {
         this.$overlay.off('.zf.reveal').on('click.zf.reveal', function (e) {
-          if (e.target === _this.$element[0] || __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(_this.$element[0], e.target) || !__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(document, e.target)) {
+          if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) {
             return;
           }
+
           _this.close();
         });
       }
+
       if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('popstate.zf.reveal:' + this.id, this._handleState.bind(this));
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on("hashchange.zf.reveal:".concat(this.id), this._handleState.bind(this));
       }
     }
-
     /**
-     * Handles modal methods on back/forward button clicks or any other event that triggers popstate.
+     * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.
      * @private
      */
 
   }, {
-    key: '_handleState',
+    key: "_handleState",
     value: function _handleState(e) {
       if (window.location.hash === '#' + this.id && !this.isActive) {
         this.open();
@@ -348,7 +442,35 @@ var Reveal = function (_Plugin) {
         this.close();
       }
     }
+    /**
+    * Disables the scroll when Reveal is shown to prevent the background from shifting
+    * @param {number} scrollTop - Scroll to visually apply, window current scroll by default
+    */
+
+  }, {
+    key: "_disableScroll",
+    value: function _disableScroll(scrollTop) {
+      scrollTop = scrollTop || jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop();
+
+      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top", -scrollTop);
+      }
+    }
+    /**
+    * Reenables the scroll when Reveal closes
+    * @param {number} scrollTop - Scroll to restore, html "top" property by default (as set by `_disableScroll`)
+    */
+
+  }, {
+    key: "_enableScroll",
+    value: function _enableScroll(scrollTop) {
+      scrollTop = scrollTop || parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top"));
 
+      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top", "");
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop(-scrollTop);
+      }
+    }
     /**
      * Opens the modal controlled by `this.$anchor`, and closes all others by default.
      * @function
@@ -357,14 +479,14 @@ var Reveal = function (_Plugin) {
      */
 
   }, {
-    key: 'open',
+    key: "open",
     value: function open() {
       var _this4 = this;
 
       // either update or replace browser history
-      if (this.options.deepLink) {
-        var hash = '#' + this.id;
+      var hash = "#".concat(this.id);
 
+      if (this.options.deepLink && window.location.hash !== hash) {
         if (window.history.pushState) {
           if (this.options.updateHistory) {
             window.history.pushState({}, '', hash);
@@ -374,22 +496,33 @@ var Reveal = function (_Plugin) {
         } else {
           window.location.hash = hash;
         }
-      }
+      } // Remember anchor that opened it to set focus back later, have general anchors as fallback
+
 
-      this.isActive = true;
+      this.$activeAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement).is(this.$anchor) ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement) : this.$anchor;
+      this.isActive = true; // Make elements invisible, but remove display: none so we can get size and positioning
+
+      this.$element.css({
+        'visibility': 'hidden'
+      }).show().scrollTop(0);
 
-      // Make elements invisible, but remove display: none so we can get size and positioning
-      this.$element.css({ 'visibility': 'hidden' }).show().scrollTop(0);
       if (this.options.overlay) {
-        this.$overlay.css({ 'visibility': 'hidden' }).show();
+        this.$overlay.css({
+          'visibility': 'hidden'
+        }).show();
       }
 
       this._updatePosition();
 
-      this.$element.hide().css({ 'visibility': '' });
+      this.$element.hide().css({
+        'visibility': ''
+      });
 
       if (this.$overlay) {
-        this.$overlay.css({ 'visibility': '' }).hide();
+        this.$overlay.css({
+          'visibility': ''
+        }).hide();
+
         if (this.$element.hasClass('fast')) {
           this.$overlay.addClass('fast');
         } else if (this.$element.hasClass('slow')) {
@@ -406,93 +539,129 @@ var Reveal = function (_Plugin) {
         this.$element.trigger('closeme.zf.reveal', this.id);
       }
 
-      var _this = this;
+      this._disableScroll();
+
+      var _this = this; // Motion UI method of reveal
+
 
-      function addRevealOpenClasses() {
-        if (_this.isMobile) {
-          if (!_this.originalScrollPos) {
-            _this.originalScrollPos = window.pageYOffset;
-          }
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').addClass('is-reveal-open');
-        } else {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').addClass('is-reveal-open');
-        }
-      }
-      // Motion UI method of reveal
       if (this.options.animationIn) {
-        var afterAnimation = function () {
+        var afterAnimation = function afterAnimation() {
           _this.$element.attr({
             'aria-hidden': false,
             'tabindex': -1
           }).focus();
-          addRevealOpenClasses();
-          __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].trapFocus(_this.$element);
+
+          _this._addGlobalClasses();
+
+          _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].trapFocus(_this.$element);
         };
 
         if (this.options.overlay) {
-          __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__["Motion"].animateIn(this.$overlay, 'fade-in');
+          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__["Motion"].animateIn(this.$overlay, 'fade-in');
         }
-        __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__["Motion"].animateIn(this.$element, this.options.animationIn, function () {
+
+        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__["Motion"].animateIn(this.$element, this.options.animationIn, function () {
           if (_this4.$element) {
             // protect against object having been removed
-            _this4.focusableElements = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].findFocusable(_this4.$element);
+            _this4.focusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].findFocusable(_this4.$element);
             afterAnimation();
           }
         });
-      }
-      // jQuery method of reveal
+      } // jQuery method of reveal
       else {
           if (this.options.overlay) {
             this.$overlay.show(0);
           }
+
           this.$element.show(this.options.showDelay);
-        }
+        } // handle accessibility
+
 
-      // handle accessibility
       this.$element.attr({
         'aria-hidden': false,
         'tabindex': -1
       }).focus();
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].trapFocus(this.$element);
-
-      addRevealOpenClasses();
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].trapFocus(this.$element);
 
-      this._extraHandlers();
+      this._addGlobalClasses();
 
+      this._addGlobalListeners();
       /**
        * Fires when the modal has successfully opened.
        * @event Reveal#open
        */
+
+
       this.$element.trigger('open.zf.reveal');
     }
+    /**
+     * Adds classes and listeners on document required by open modals.
+     *
+     * The following classes are added and updated:
+     * - `.is-reveal-open` - Prevents the scroll on document
+     * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the
+     *                       scroll was not disabled. This prevent a "shift" of the page content due
+     *                       the scrollbar disappearing when the modal opens.
+     *
+     * @private
+     */
+
+  }, {
+    key: "_addGlobalClasses",
+    value: function _addGlobalClasses() {
+      var updateScrollbarClass = function updateScrollbarClass() {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').toggleClass('zf-has-scroll', !!(jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()));
+      };
+
+      this.$element.on('resizeme.zf.trigger.revealScrollbarListener', function () {
+        return updateScrollbarClass();
+      });
+      updateScrollbarClass();
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').addClass('is-reveal-open');
+    }
+    /**
+     * Removes classes and listeners on document that were required by open modals.
+     * @private
+     */
 
+  }, {
+    key: "_removeGlobalClasses",
+    value: function _removeGlobalClasses() {
+      this.$element.off('resizeme.zf.trigger.revealScrollbarListener');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('is-reveal-open');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('zf-has-scroll');
+    }
     /**
      * Adds extra event handlers for the body and window if necessary.
      * @private
      */
 
   }, {
-    key: '_extraHandlers',
-    value: function _extraHandlers() {
+    key: "_addGlobalListeners",
+    value: function _addGlobalListeners() {
       var _this = this;
+
       if (!this.$element) {
         return;
       } // If we're in the middle of cleanup, don't freak out
-      this.focusableElements = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].findFocusable(this.$element);
+
+
+      this.focusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].findFocusable(this.$element);
 
       if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').on('click.zf.reveal', function (e) {
-          if (e.target === _this.$element[0] || __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(_this.$element[0], e.target) || !__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.contains(document, e.target)) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').on('click.zf.reveal', function (e) {
+          if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) {
             return;
           }
+
           _this.close();
         });
       }
 
       if (this.options.closeOnEsc) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('keydown.zf.reveal', function (e) {
-          __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'Reveal', {
-            close: function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('keydown.zf.reveal', function (e) {
+          _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'Reveal', {
+            close: function close() {
               if (_this.options.closeOnEsc) {
                 _this.close();
               }
@@ -501,7 +670,6 @@ var Reveal = function (_Plugin) {
         });
       }
     }
-
     /**
      * Closes the modal.
      * @function
@@ -509,22 +677,22 @@ var Reveal = function (_Plugin) {
      */
 
   }, {
-    key: 'close',
+    key: "close",
     value: function close() {
       if (!this.isActive || !this.$element.is(':visible')) {
         return false;
       }
-      var _this = this;
 
-      // Motion UI method of hiding
+      var _this = this; // Motion UI method of hiding
+
+
       if (this.options.animationOut) {
         if (this.options.overlay) {
-          __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__["Motion"].animateOut(this.$overlay, 'fade-out');
+          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__["Motion"].animateOut(this.$overlay, 'fade-out');
         }
 
-        __WEBPACK_IMPORTED_MODULE_3__foundation_util_motion__["Motion"].animateOut(this.$element, this.options.animationOut, finishUp);
-      }
-      // jQuery method of hiding
+        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__["Motion"].animateOut(this.$element, this.options.animationOut, finishUp);
+      } // jQuery method of hiding
       else {
           this.$element.hide(this.options.hideDelay);
 
@@ -533,72 +701,79 @@ var Reveal = function (_Plugin) {
           } else {
             finishUp();
           }
-        }
+        } // Conditionals to remove extra event listeners added on open
+
 
-      // Conditionals to remove extra event listeners added on open
       if (this.options.closeOnEsc) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('keydown.zf.reveal');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('keydown.zf.reveal');
       }
 
       if (!this.options.overlay && this.options.closeOnClick) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').off('click.zf.reveal');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').off('click.zf.reveal');
       }
 
       this.$element.off('keydown.zf.reveal');
 
       function finishUp() {
-        if (_this.isMobile) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()('.reveal:visible').length === 0) {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').removeClass('is-reveal-open');
-          }
-          if (_this.originalScrollPos) {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').scrollTop(_this.originalScrollPos);
-            _this.originalScrollPos = null;
-          }
-        } else {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()('.reveal:visible').length === 0) {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body').removeClass('is-reveal-open');
-          }
+        // Get the current top before the modal is closed and restore the scroll after.
+        // TODO: use component properties instead of HTML properties
+        // See https://github.com/zurb/foundation-sites/pull/10786
+        var scrollTop = parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()("html").css("top"));
+
+        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) {
+          _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
+
         }
 
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].releaseFocus(_this.$element);
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].releaseFocus(_this.$element);
 
         _this.$element.attr('aria-hidden', true);
 
+        _this._enableScroll(scrollTop);
         /**
         * Fires when the modal is done closing.
         * @event Reveal#closed
         */
+
+
         _this.$element.trigger('closed.zf.reveal');
       }
-
       /**
       * Resets the modal content
       * This prevents a running video to keep going in the background
       */
+
+
       if (this.options.resetOnClose) {
         this.$element.html(this.$element.html());
       }
 
-      this.isActive = false;
-      if (_this.options.deepLink) {
+      this.isActive = false; // If deepLink and we did not switched to an other modal...
+
+      if (_this.options.deepLink && window.location.hash === "#".concat(this.id)) {
+        // Remove the history hash
         if (window.history.replaceState) {
-          window.history.replaceState('', document.title, window.location.href.replace('#' + this.id, ''));
+          var urlWithoutHash = window.location.pathname + window.location.search;
+
+          if (this.options.updateHistory) {
+            window.history.pushState({}, '', urlWithoutHash); // remove the hash
+          } else {
+            window.history.replaceState('', document.title, urlWithoutHash);
+          }
         } else {
           window.location.hash = '';
         }
       }
 
-      this.$anchor.focus();
+      this.$activeAnchor.focus();
     }
-
     /**
      * Toggles the open/closed state of a modal.
      * @function
      */
 
   }, {
-    key: 'toggle',
+    key: "toggle",
     value: function toggle() {
       if (this.isActive) {
         this.close();
@@ -607,8 +782,7 @@ var Reveal = function (_Plugin) {
       }
     }
   }, {
-    key: '_destroy',
-
+    key: "_destroy",
 
     /**
      * Destroys an instance of a modal.
@@ -616,17 +790,25 @@ var Reveal = function (_Plugin) {
      */
     value: function _destroy() {
       if (this.options.overlay) {
-        this.$element.appendTo(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()
+        this.$element.appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()
+
         this.$overlay.hide().off().remove();
       }
+
       this.$element.hide().off();
       this.$anchor.off('.zf');
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('.zf.reveal:' + this.id);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(".zf.reveal:".concat(this.id));
+      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
+
+      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) {
+        this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal
+
+      }
     }
   }]);
 
   return Reveal;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 
 Reveal.defaults = {
   /**
@@ -636,6 +818,7 @@ Reveal.defaults = {
    * @default ''
    */
   animationIn: '',
+
   /**
    * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.
    * @option
@@ -643,6 +826,7 @@ Reveal.defaults = {
    * @default ''
    */
   animationOut: '',
+
   /**
    * Time, in ms, to delay the opening of a modal after a click if no animation used.
    * @option
@@ -650,6 +834,7 @@ Reveal.defaults = {
    * @default 0
    */
   showDelay: 0,
+
   /**
    * Time, in ms, to delay the closing of a modal after a click if no animation used.
    * @option
@@ -657,6 +842,7 @@ Reveal.defaults = {
    * @default 0
    */
   hideDelay: 0,
+
   /**
    * Allows a click on the body/overlay to close the modal.
    * @option
@@ -664,6 +850,7 @@ Reveal.defaults = {
    * @default true
    */
   closeOnClick: true,
+
   /**
    * Allows the modal to close if the user presses the `ESCAPE` key.
    * @option
@@ -671,6 +858,7 @@ Reveal.defaults = {
    * @default true
    */
   closeOnEsc: true,
+
   /**
    * If true, allows multiple modals to be displayed at once.
    * @option
@@ -678,6 +866,7 @@ Reveal.defaults = {
    * @default false
    */
   multipleOpened: false,
+
   /**
    * Distance, in pixels, the modal should push down from the top of the screen.
    * @option
@@ -685,6 +874,7 @@ Reveal.defaults = {
    * @default auto
    */
   vOffset: 'auto',
+
   /**
    * Distance, in pixels, the modal should push in from the side of the screen.
    * @option
@@ -692,6 +882,7 @@ Reveal.defaults = {
    * @default auto
    */
   hOffset: 'auto',
+
   /**
    * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.
    * @option
@@ -699,13 +890,7 @@ Reveal.defaults = {
    * @default false
    */
   fullScreen: false,
-  /**
-   * Percentage of screen height the modal should push up from the bottom of the view.
-   * @option
-   * @type {number}
-   * @default 10
-   */
-  btmOffsetPct: 10,
+
   /**
    * Allows the modal to generate an overlay div, which will cover the view when modal opens.
    * @option
@@ -713,6 +898,7 @@ Reveal.defaults = {
    * @default true
    */
   overlay: true,
+
   /**
    * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.
    * @option
@@ -720,19 +906,23 @@ Reveal.defaults = {
    * @default false
    */
   resetOnClose: false,
+
   /**
-   * Allows the modal to alter the url on open/close, and allows the use of the `back` button to close modals. ALSO, allows a modal to auto-maniacally open on page load IF the hash === the modal's user-set id.
+   * Link the location hash to the modal.
+   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.
    * @option
    * @type {boolean}
    * @default false
    */
   deepLink: false,
+
   /**
-   * Update the browser history with the open modal
+   * If `deepLink` is enabled, update the browser history with the open modal
    * @option
    * @default false
    */
   updateHistory: false,
+
   /**
   * Allows the modal to append to custom div.
   * @option
@@ -740,6 +930,7 @@ Reveal.defaults = {
   * @default "body"
   */
   appendTo: "body",
+
   /**
    * Allows adding additional class names to the reveal overlay.
    * @option
@@ -749,40 +940,28 @@ Reveal.defaults = {
   additionalOverlayClasses: ''
 };
 
-function iPhoneSniff() {
-  return (/iP(ad|hone|od).*OS/.test(window.navigator.userAgent)
-  );
-}
-
-function androidSniff() {
-  return (/Android/.test(window.navigator.userAgent)
-  );
-}
-
-function mobileSniff() {
-  return iPhoneSniff() || androidSniff();
-}
-
-
 
 /***/ }),
 
-/***/ 6:
-/***/ (function(module, exports) {
-
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
-
-/***/ }),
-
-/***/ 7:
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
@@ -790,17 +969,19 @@ module.exports = {MediaQuery: window.Foundation.MediaQuery};
 
 var MutationObserver = function () {
   var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
   for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
     }
   }
+
   return false;
 }();
 
-var triggers = function (el, type) {
+var triggers = function triggers(el, type) {
   el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
   });
 };
 
@@ -811,138 +992,142 @@ var Triggers = {
   },
   Initializers: {}
 };
-
 Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
   },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
     }
   },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
     }
   },
-  closeableListener: function (e) {
+  closeableListener: function closeableListener(e) {
     e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
     if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
       });
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
     }
   },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
-};
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
 Triggers.Initializers.addOpenListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
   $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
-
-// Elements with [data-close] will close a plugin that supports it when clicked.
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
 // If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
 Triggers.Initializers.addCloseListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
   $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 Triggers.Initializers.addToggleListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
   $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
 Triggers.Initializers.addCloseableListener = function ($elem) {
   $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
   $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
 Triggers.Initializers.addToggleFocusListener = function ($elem) {
   $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
   $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+}; // More Global/complex listeners and triggers
+
 
-// More Global/complex listeners and triggers
 Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
+  resizeListener: function resizeListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a resize event
+    } //trigger all listening elements and signal a resize event
+
+
     $nodes.attr('data-events', "resize");
   },
-  scrollListener: function ($nodes) {
+  scrollListener: function scrollListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a scroll event
+    } //trigger all listening elements and signal a scroll event
+
+
     $nodes.attr('data-events', "scroll");
   },
-  closeMeListener: function (e, pluginId) {
+  closeMeListener: function closeMeListener(e, pluginId) {
     var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
-
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
     plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+
       _this.triggerHandler('close.zf.trigger', [_this]);
     });
-  }
+  } // Global, parses whole document.
+
+};
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
       plugNames = ['dropdown', 'tooltip', 'reveal'];
 
   if (pluginName) {
     if (typeof pluginName === 'string') {
       plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
     } else {
       console.error('Plugin names must be strings');
     }
   }
+
   if (yetiBoxes.length) {
     var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
+      return "closeme.zf.".concat(name);
     }).join(' ');
-
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
   }
 };
 
 function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
+  var timer,
       args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
     if (timer) {
       clearTimeout(timer);
     }
+
     timer = setTimeout(function () {
       listener.apply(null, args);
     }, debounce || 10); //default time to emit scroll event
@@ -950,14 +1135,16 @@ function debounceGlobalListener(debounce, trigger, listener) {
 }
 
 Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
   }
 };
 
 Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
   }
@@ -967,25 +1154,27 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
   if (!MutationObserver) {
     return false;
   }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
 
-    //trigger the event handler for the element depending on type
     switch (mutationRecordsList[0].type) {
       case "attributes":
         if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
+
         if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
+
         if (mutationRecordsList[0].attributeName === "style") {
           $target.closest("[data-mutate]").attr("data-events", "mutate");
           $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
         }
+
         break;
 
       case "childList":
@@ -1003,14 +1192,19 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
     //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
     for (var i = 0; i <= $nodes.length - 1; i++) {
       var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
   }
 };
 
 Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addOpenListener($document);
   Triggers.Initializers.addCloseListener($document);
   Triggers.Initializers.addToggleListener($document);
@@ -1019,7 +1213,7 @@ Triggers.Initializers.addSimpleListeners = function () {
 };
 
 Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addMutationEventsListener($document);
   Triggers.Initializers.addResizeListener();
   Triggers.Initializers.addScrollListener();
@@ -1027,25 +1221,17 @@ Triggers.Initializers.addGlobalListeners = function () {
 };
 
 Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
-
-    if (document.readyState === "complete") {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
       Triggers.Initializers.addSimpleListeners();
       Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
-      });
+      $.triggersInitialized = true;
     }
-
-    $.triggersInitialized = true;
-  }
+  });
 
   if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
     Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
   }
 };
@@ -1054,12 +1240,29 @@ Triggers.init = function ($, Foundation) {
 
 /***/ }),
 
-/***/ 93:
+/***/ 14:
+/*!*******************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.reveal.js ***!
+  \*******************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(27);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.reveal.js */"./js/entries/plugins/foundation.reveal.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.reveal.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.reveal.js.map b/dist/js/plugins/foundation.reveal.js.map
new file mode 100644 (file)
index 0000000..1439651
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.touch\"],\"amd\":\"./foundation.util.touch\",\"commonjs\":\"./foundation.util.touch\",\"commonjs2\":\"./foundation.util.touch\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.reveal.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.reveal.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Reveal","element","options","$element","$","extend","defaults","data","className","_init","Triggers","init","Keyboard","register","MediaQuery","id","attr","isActive","cached","mq","current","$anchor","length","fullScreen","hasClass","overlay","$overlay","_makeOverlay","detach","appendTo","addClass","_events","deepLink","window","location","hash","onLoadListener","onLoad","open","additionalOverlayClasses","width","outerWidth","height","outerHeight","left","top","hOffset","parseInt","vOffset","Math","min","css","margin","_this","on","bind","event","target","parents","close","apply","toggle","_updatePosition","closeOnClick","off","e","contains","document","_handleState","scrollTop","history","pushState","updateHistory","replaceState","$activeAnchor","activeElement","is","show","hide","multipleOpened","trigger","_disableScroll","animationIn","afterAnimation","focus","_addGlobalClasses","trapFocus","Motion","animateIn","focusableElements","findFocusable","showDelay","_addGlobalListeners","updateScrollbarClass","toggleClass","removeClass","closeOnEsc","handleKey","animationOut","animateOut","finishUp","hideDelay","_removeGlobalClasses","releaseFocus","_enableScroll","resetOnClose","html","urlWithoutHash","pathname","search","title","remove","Plugin","MutationObserver","prefixes","i","triggers","el","type","split","forEach","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","scrollListener","closeMeListener","pluginId","namespace","plugins","not","addClosemeListener","pluginName","yetiBoxes","plugNames","push","concat","console","error","listeners","map","name","join","debounceGlobalListener","debounce","listener","timer","args","Array","prototype","slice","call","arguments","clearTimeout","setTimeout","addResizeListener","addScrollListener","addMutationEventsListener","find","listeningElementsMutation","mutationRecordsList","$target","attributeName","pageYOffset","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","triggersInitialized","IHearYou"],"mappings":"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","file":"foundation.reveal.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"./foundation.util.touch\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.reveal\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.reveal\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 14);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;","import { Foundation } from './foundation.core';\n\nimport { Reveal } from '../../foundation.reveal';\nFoundation.plugin(Reveal, 'Reveal');\n\nexport { Foundation, Reveal };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\nimport { Touch } from './foundation.util.touch'\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nclass Reveal extends Plugin {\n  /**\n   * Creates a new instance of Reveal.\n   * @class\n   * @name Reveal\n   * @param {jQuery} element - jQuery object to use for the modal.\n   * @param {Object} options - optional parameters.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Reveal.defaults, this.$element.data(), options);\n    this.className = 'Reveal'; // ie9 back compat\n    this._init();\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    Keyboard.register('Reveal', {\n      'ESCAPE': 'close',\n    });\n  }\n\n  /**\n   * Initializes the modal by adding the overlay and close buttons, (if selected).\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    this.id = this.$element.attr('id');\n    this.isActive = false;\n    this.cached = {mq: MediaQuery.current};\n\n    this.$anchor = $(`[data-open=\"${this.id}\"]`).length ? $(`[data-open=\"${this.id}\"]`) : $(`[data-toggle=\"${this.id}\"]`);\n    this.$anchor.attr({\n      'aria-controls': this.id,\n      'aria-haspopup': true,\n      'tabindex': 0\n    });\n\n    if (this.options.fullScreen || this.$element.hasClass('full')) {\n      this.options.fullScreen = true;\n      this.options.overlay = false;\n    }\n    if (this.options.overlay && !this.$overlay) {\n      this.$overlay = this._makeOverlay(this.id);\n    }\n\n    this.$element.attr({\n        'role': 'dialog',\n        'aria-hidden': true,\n        'data-yeti-box': this.id,\n        'data-resize': this.id\n    });\n\n    if(this.$overlay) {\n      this.$element.detach().appendTo(this.$overlay);\n    } else {\n      this.$element.detach().appendTo($(this.options.appendTo));\n      this.$element.addClass('without-overlay');\n    }\n    this._events();\n    if (this.options.deepLink && window.location.hash === ( `#${this.id}`)) {\n      this.onLoadListener = onLoad($(window), () => this.open());\n    }\n  }\n\n  /**\n   * Creates an overlay div to display behind the modal.\n   * @private\n   */\n  _makeOverlay() {\n    var additionalOverlayClasses = '';\n\n    if (this.options.additionalOverlayClasses) {\n      additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;\n    }\n\n    return $('<div></div>')\n      .addClass('reveal-overlay' + additionalOverlayClasses)\n      .appendTo(this.options.appendTo);\n  }\n\n  /**\n   * Updates position of modal\n   * TODO:  Figure out if we actually need to cache these values or if it doesn't matter\n   * @private\n   */\n  _updatePosition() {\n    var width = this.$element.outerWidth();\n    var outerWidth = $(window).width();\n    var height = this.$element.outerHeight();\n    var outerHeight = $(window).height();\n    var left, top = null;\n    if (this.options.hOffset === 'auto') {\n      left = parseInt((outerWidth - width) / 2, 10);\n    } else {\n      left = parseInt(this.options.hOffset, 10);\n    }\n    if (this.options.vOffset === 'auto') {\n      if (height > outerHeight) {\n        top = parseInt(Math.min(100, outerHeight / 10), 10);\n      } else {\n        top = parseInt((outerHeight - height) / 4, 10);\n      }\n    } else if (this.options.vOffset !== null) {\n      top = parseInt(this.options.vOffset, 10);\n    }\n\n    if (top !== null) {\n      this.$element.css({top: top + 'px'});\n    }\n\n    // only worry about left if we don't have an overlay or we have a horizontal offset,\n    // otherwise we're perfectly in the middle\n    if (!this.$overlay || (this.options.hOffset !== 'auto')) {\n      this.$element.css({left: left + 'px'});\n      this.$element.css({margin: '0px'});\n    }\n\n  }\n\n  /**\n   * Adds event handlers for the modal.\n   * @private\n   */\n  _events() {\n    var _this = this;\n\n    this.$element.on({\n      'open.zf.trigger': this.open.bind(this),\n      'close.zf.trigger': (event, $element) => {\n        if ((event.target === _this.$element[0]) ||\n            ($(event.target).parents('[data-closable]')[0] === $element)) { // only close reveal when it's explicitly called\n          return this.close.apply(this);\n        }\n      },\n      'toggle.zf.trigger': this.toggle.bind(this),\n      'resizeme.zf.trigger': function() {\n        _this._updatePosition();\n      }\n    });\n\n    if (this.options.closeOnClick && this.options.overlay) {\n      this.$overlay.off('.zf.reveal').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) {\n              return;\n        }\n        _this.close();\n      });\n    }\n    if (this.options.deepLink) {\n      $(window).on(`hashchange.zf.reveal:${this.id}`, this._handleState.bind(this));\n    }\n  }\n\n  /**\n   * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.\n   * @private\n   */\n  _handleState(e) {\n    if(window.location.hash === ( '#' + this.id) && !this.isActive){ this.open(); }\n    else{ this.close(); }\n  }\n\n  /**\n  * Disables the scroll when Reveal is shown to prevent the background from shifting\n  * @param {number} scrollTop - Scroll to visually apply, window current scroll by default\n  */\n  _disableScroll(scrollTop) {\n    scrollTop = scrollTop || $(window).scrollTop();\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", -scrollTop);\n    }\n  }\n\n  /**\n  * Reenables the scroll when Reveal closes\n  * @param {number} scrollTop - Scroll to restore, html \"top\" property by default (as set by `_disableScroll`)\n  */\n  _enableScroll(scrollTop) {\n    scrollTop = scrollTop || parseInt($(\"html\").css(\"top\"));\n    if ($(document).height() > $(window).height()) {\n      $(\"html\")\n        .css(\"top\", \"\");\n      $(window).scrollTop(-scrollTop);\n    }\n  }\n\n\n  /**\n   * Opens the modal controlled by `this.$anchor`, and closes all others by default.\n   * @function\n   * @fires Reveal#closeme\n   * @fires Reveal#open\n   */\n  open() {\n    // either update or replace browser history\n    const hash = `#${this.id}`;\n    if (this.options.deepLink && window.location.hash !== hash) {\n\n      if (window.history.pushState) {\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', hash);\n        } else {\n          window.history.replaceState({}, '', hash);\n        }\n      } else {\n        window.location.hash = hash;\n      }\n    }\n\n    // Remember anchor that opened it to set focus back later, have general anchors as fallback\n    this.$activeAnchor = $(document.activeElement).is(this.$anchor) ? $(document.activeElement) : this.$anchor;\n\n    this.isActive = true;\n\n    // Make elements invisible, but remove display: none so we can get size and positioning\n    this.$element\n        .css({ 'visibility': 'hidden' })\n        .show()\n        .scrollTop(0);\n    if (this.options.overlay) {\n      this.$overlay.css({'visibility': 'hidden'}).show();\n    }\n\n    this._updatePosition();\n\n    this.$element\n      .hide()\n      .css({ 'visibility': '' });\n\n    if(this.$overlay) {\n      this.$overlay.css({'visibility': ''}).hide();\n      if(this.$element.hasClass('fast')) {\n        this.$overlay.addClass('fast');\n      } else if (this.$element.hasClass('slow')) {\n        this.$overlay.addClass('slow');\n      }\n    }\n\n\n    if (!this.options.multipleOpened) {\n      /**\n       * Fires immediately before the modal opens.\n       * Closes any other modals that are currently open\n       * @event Reveal#closeme\n       */\n      this.$element.trigger('closeme.zf.reveal', this.id);\n    }\n\n    this._disableScroll();\n\n    var _this = this;\n\n    // Motion UI method of reveal\n    if (this.options.animationIn) {\n      function afterAnimation(){\n        _this.$element\n          .attr({\n            'aria-hidden': false,\n            'tabindex': -1\n          })\n          .focus();\n        _this._addGlobalClasses();\n        Keyboard.trapFocus(_this.$element);\n      }\n      if (this.options.overlay) {\n        Motion.animateIn(this.$overlay, 'fade-in');\n      }\n      Motion.animateIn(this.$element, this.options.animationIn, () => {\n        if(this.$element) { // protect against object having been removed\n          this.focusableElements = Keyboard.findFocusable(this.$element);\n          afterAnimation();\n        }\n      });\n    }\n    // jQuery method of reveal\n    else {\n      if (this.options.overlay) {\n        this.$overlay.show(0);\n      }\n      this.$element.show(this.options.showDelay);\n    }\n\n    // handle accessibility\n    this.$element\n      .attr({\n        'aria-hidden': false,\n        'tabindex': -1\n      })\n      .focus();\n    Keyboard.trapFocus(this.$element);\n\n    this._addGlobalClasses();\n\n    this._addGlobalListeners();\n\n    /**\n     * Fires when the modal has successfully opened.\n     * @event Reveal#open\n     */\n    this.$element.trigger('open.zf.reveal');\n  }\n\n  /**\n   * Adds classes and listeners on document required by open modals.\n   *\n   * The following classes are added and updated:\n   * - `.is-reveal-open` - Prevents the scroll on document\n   * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the\n   *                       scroll was not disabled. This prevent a \"shift\" of the page content due\n   *                       the scrollbar disappearing when the modal opens.\n   *\n   * @private\n   */\n  _addGlobalClasses() {\n    const updateScrollbarClass = () => {\n      $('html').toggleClass('zf-has-scroll', !!($(document).height() > $(window).height()));\n    };\n\n    this.$element.on('resizeme.zf.trigger.revealScrollbarListener', () => updateScrollbarClass());\n    updateScrollbarClass();\n    $('html').addClass('is-reveal-open');\n  }\n\n  /**\n   * Removes classes and listeners on document that were required by open modals.\n   * @private\n   */\n  _removeGlobalClasses() {\n    this.$element.off('resizeme.zf.trigger.revealScrollbarListener');\n    $('html').removeClass('is-reveal-open');\n    $('html').removeClass('zf-has-scroll');\n  }\n\n  /**\n   * Adds extra event handlers for the body and window if necessary.\n   * @private\n   */\n  _addGlobalListeners() {\n    var _this = this;\n    if(!this.$element) { return; } // If we're in the middle of cleanup, don't freak out\n    this.focusableElements = Keyboard.findFocusable(this.$element);\n\n    if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {\n      $('body').on('click.zf.reveal', function(e) {\n        if (e.target === _this.$element[0] ||\n          $.contains(_this.$element[0], e.target) ||\n            !$.contains(document, e.target)) { return; }\n        _this.close();\n      });\n    }\n\n    if (this.options.closeOnEsc) {\n      $(window).on('keydown.zf.reveal', function(e) {\n        Keyboard.handleKey(e, 'Reveal', {\n          close: function() {\n            if (_this.options.closeOnEsc) {\n              _this.close();\n            }\n          }\n        });\n      });\n    }\n  }\n\n  /**\n   * Closes the modal.\n   * @function\n   * @fires Reveal#closed\n   */\n  close() {\n    if (!this.isActive || !this.$element.is(':visible')) {\n      return false;\n    }\n    var _this = this;\n\n    // Motion UI method of hiding\n    if (this.options.animationOut) {\n      if (this.options.overlay) {\n        Motion.animateOut(this.$overlay, 'fade-out');\n      }\n\n      Motion.animateOut(this.$element, this.options.animationOut, finishUp);\n    }\n    // jQuery method of hiding\n    else {\n      this.$element.hide(this.options.hideDelay);\n\n      if (this.options.overlay) {\n        this.$overlay.hide(0, finishUp);\n      }\n      else {\n        finishUp();\n      }\n    }\n\n    // Conditionals to remove extra event listeners added on open\n    if (this.options.closeOnEsc) {\n      $(window).off('keydown.zf.reveal');\n    }\n\n    if (!this.options.overlay && this.options.closeOnClick) {\n      $('body').off('click.zf.reveal');\n    }\n\n    this.$element.off('keydown.zf.reveal');\n\n    function finishUp() {\n\n      // Get the current top before the modal is closed and restore the scroll after.\n      // TODO: use component properties instead of HTML properties\n      // See https://github.com/zurb/foundation-sites/pull/10786\n      var scrollTop = parseInt($(\"html\").css(\"top\"));\n\n      if ($('.reveal:visible').length  === 0) {\n        _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n      }\n\n      Keyboard.releaseFocus(_this.$element);\n\n      _this.$element.attr('aria-hidden', true);\n\n      _this._enableScroll(scrollTop);\n\n      /**\n      * Fires when the modal is done closing.\n      * @event Reveal#closed\n      */\n      _this.$element.trigger('closed.zf.reveal');\n    }\n\n    /**\n    * Resets the modal content\n    * This prevents a running video to keep going in the background\n    */\n    if (this.options.resetOnClose) {\n      this.$element.html(this.$element.html());\n    }\n\n    this.isActive = false;\n    // If deepLink and we did not switched to an other modal...\n    if (_this.options.deepLink && window.location.hash === `#${this.id}`) {\n      // Remove the history hash\n      if (window.history.replaceState) {\n        const urlWithoutHash = window.location.pathname + window.location.search;\n        if (this.options.updateHistory) {\n          window.history.pushState({}, '', urlWithoutHash); // remove the hash\n        } else {\n          window.history.replaceState('', document.title, urlWithoutHash);\n        }\n      } else {\n        window.location.hash = '';\n      }\n    }\n\n    this.$activeAnchor.focus();\n  }\n\n  /**\n   * Toggles the open/closed state of a modal.\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.close();\n    } else {\n      this.open();\n    }\n  };\n\n  /**\n   * Destroys an instance of a modal.\n   * @function\n   */\n  _destroy() {\n    if (this.options.overlay) {\n      this.$element.appendTo($(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()\n      this.$overlay.hide().off().remove();\n    }\n    this.$element.hide().off();\n    this.$anchor.off('.zf');\n    $(window).off(`.zf.reveal:${this.id}`)\n    if (this.onLoadListener) $(window).off(this.onLoadListener);\n\n    if ($('.reveal:visible').length  === 0) {\n      this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n    }\n  };\n}\n\nReveal.defaults = {\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationIn: '',\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationOut: '',\n  /**\n   * Time, in ms, to delay the opening of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  showDelay: 0,\n  /**\n   * Time, in ms, to delay the closing of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hideDelay: 0,\n  /**\n   * Allows a click on the body/overlay to close the modal.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n  /**\n   * Allows the modal to close if the user presses the `ESCAPE` key.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnEsc: true,\n  /**\n   * If true, allows multiple modals to be displayed at once.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multipleOpened: false,\n  /**\n   * Distance, in pixels, the modal should push down from the top of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  vOffset: 'auto',\n  /**\n   * Distance, in pixels, the modal should push in from the side of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  hOffset: 'auto',\n  /**\n   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  fullScreen: false,\n  /**\n   * Allows the modal to generate an overlay div, which will cover the view when modal opens.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  overlay: true,\n  /**\n   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  resetOnClose: false,\n  /**\n   * Link the location hash to the modal.\n   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n  /**\n   * If `deepLink` is enabled, update the browser history with the open modal\n   * @option\n   * @default false\n   */\n  updateHistory: false,\n    /**\n   * Allows the modal to append to custom div.\n   * @option\n   * @type {string}\n   * @default \"body\"\n   */\n  appendTo: \"body\",\n  /**\n   * Allows adding additional class names to the reveal overlay.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  additionalOverlayClasses: ''\n};\n\nexport {Reveal};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index d8f1dfb6ebb322e2cb583f19aef28d1c1013be7e..25489de2cd8d206878d841ef8c33895402822fde 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(n){if(i[n])return i[n].exports;var o=i[n]={i:n,l:!1,exports:{}};return e[n].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var i={};t.m=e,t.c=i,t.i=function(e){return e},t.d=function(e,i,n){t.o(e,i)||Object.defineProperty(e,i,{configurable:!1,enumerable:!0,get:n})},t.n=function(e){var i=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(i,"a",i),i},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=93)}({0:function(e,t){e.exports=jQuery},1:function(e,t){e.exports={Foundation:window.Foundation}},2:function(e,t){e.exports={Plugin:window.Foundation.Plugin}},27:function(e,t,i){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var n=i(1),o=(i.n(n),i(57));n.Foundation.plugin(o.a,"Reveal")},4:function(e,t){e.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},5:function(e,t){e.exports={Keyboard:window.Foundation.Keyboard}},57:function(e,t,i){"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function o(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function s(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}function a(){return/iP(ad|hone|od).*OS/.test(window.navigator.userAgent)}function r(){return/Android/.test(window.navigator.userAgent)}function l(){return a()||r()}i.d(t,"a",function(){return m});var c=i(0),d=i.n(c),u=i(5),h=(i.n(u),i(6)),f=(i.n(h),i(4)),g=(i.n(f),i(2)),p=(i.n(g),i(7)),v=function(){function e(e,t){for(var i=0;i<t.length;i++){var n=t[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}return function(t,i,n){return i&&e(t.prototype,i),n&&e(t,n),t}}(),m=function(e){function t(){return n(this,t),o(this,(t.__proto__||Object.getPrototypeOf(t)).apply(this,arguments))}return s(t,e),v(t,[{key:"_setup",value:function(e,i){this.$element=e,this.options=d.a.extend({},t.defaults,this.$element.data(),i),this.className="Reveal",this._init(),p.a.init(d.a),u.Keyboard.register("Reveal",{ESCAPE:"close"})}},{key:"_init",value:function(){h.MediaQuery._init(),this.id=this.$element.attr("id"),this.isActive=!1,this.cached={mq:h.MediaQuery.current},this.isMobile=l(),this.$anchor=d()('[data-open="'+this.id+'"]').length?d()('[data-open="'+this.id+'"]'):d()('[data-toggle="'+this.id+'"]'),this.$anchor.attr({"aria-controls":this.id,"aria-haspopup":!0,tabindex:0}),(this.options.fullScreen||this.$element.hasClass("full"))&&(this.options.fullScreen=!0,this.options.overlay=!1),this.options.overlay&&!this.$overlay&&(this.$overlay=this._makeOverlay(this.id)),this.$element.attr({role:"dialog","aria-hidden":!0,"data-yeti-box":this.id,"data-resize":this.id}),this.$overlay?this.$element.detach().appendTo(this.$overlay):(this.$element.detach().appendTo(d()(this.options.appendTo)),this.$element.addClass("without-overlay")),this._events(),this.options.deepLink&&window.location.hash==="#"+this.id&&d()(window).one("load.zf.reveal",this.open.bind(this))}},{key:"_makeOverlay",value:function(){var e="";return this.options.additionalOverlayClasses&&(e=" "+this.options.additionalOverlayClasses),d()("<div></div>").addClass("reveal-overlay"+e).appendTo(this.options.appendTo)}},{key:"_updatePosition",value:function(){var e,t,i=this.$element.outerWidth(),n=d()(window).width(),o=this.$element.outerHeight(),s=d()(window).height();e="auto"===this.options.hOffset?parseInt((n-i)/2,10):parseInt(this.options.hOffset,10),t="auto"===this.options.vOffset?o>s?parseInt(Math.min(100,s/10),10):parseInt((s-o)/4,10):parseInt(this.options.vOffset,10),this.$element.css({top:t+"px"}),this.$overlay&&"auto"===this.options.hOffset||(this.$element.css({left:e+"px"}),this.$element.css({margin:"0px"}))}},{key:"_events",value:function(){var e=this,t=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":function(i,n){if(i.target===t.$element[0]||d()(i.target).parents("[data-closable]")[0]===n)return e.close.apply(e)},"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":function(){t._updatePosition()}}),this.options.closeOnClick&&this.options.overlay&&this.$overlay.off(".zf.reveal").on("click.zf.reveal",function(e){e.target!==t.$element[0]&&!d.a.contains(t.$element[0],e.target)&&d.a.contains(document,e.target)&&t.close()}),this.options.deepLink&&d()(window).on("popstate.zf.reveal:"+this.id,this._handleState.bind(this))}},{key:"_handleState",value:function(e){window.location.hash!=="#"+this.id||this.isActive?this.close():this.open()}},{key:"open",value:function(){function e(){n.isMobile?(n.originalScrollPos||(n.originalScrollPos=window.pageYOffset),d()("html, body").addClass("is-reveal-open")):d()("body").addClass("is-reveal-open")}var t=this;if(this.options.deepLink){var i="#"+this.id;window.history.pushState?this.options.updateHistory?window.history.pushState({},"",i):window.history.replaceState({},"",i):window.location.hash=i}this.isActive=!0,this.$element.css({visibility:"hidden"}).show().scrollTop(0),this.options.overlay&&this.$overlay.css({visibility:"hidden"}).show(),this._updatePosition(),this.$element.hide().css({visibility:""}),this.$overlay&&(this.$overlay.css({visibility:""}).hide(),this.$element.hasClass("fast")?this.$overlay.addClass("fast"):this.$element.hasClass("slow")&&this.$overlay.addClass("slow")),this.options.multipleOpened||this.$element.trigger("closeme.zf.reveal",this.id);var n=this;if(this.options.animationIn){var o=function(){n.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),e(),u.Keyboard.trapFocus(n.$element)};this.options.overlay&&f.Motion.animateIn(this.$overlay,"fade-in"),f.Motion.animateIn(this.$element,this.options.animationIn,function(){t.$element&&(t.focusableElements=u.Keyboard.findFocusable(t.$element),o())})}else this.options.overlay&&this.$overlay.show(0),this.$element.show(this.options.showDelay);this.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),u.Keyboard.trapFocus(this.$element),e(),this._extraHandlers(),this.$element.trigger("open.zf.reveal")}},{key:"_extraHandlers",value:function(){var e=this;this.$element&&(this.focusableElements=u.Keyboard.findFocusable(this.$element),this.options.overlay||!this.options.closeOnClick||this.options.fullScreen||d()("body").on("click.zf.reveal",function(t){t.target!==e.$element[0]&&!d.a.contains(e.$element[0],t.target)&&d.a.contains(document,t.target)&&e.close()}),this.options.closeOnEsc&&d()(window).on("keydown.zf.reveal",function(t){u.Keyboard.handleKey(t,"Reveal",{close:function(){e.options.closeOnEsc&&e.close()}})}))}},{key:"close",value:function(){function e(){t.isMobile?(0===d()(".reveal:visible").length&&d()("html, body").removeClass("is-reveal-open"),t.originalScrollPos&&(d()("body").scrollTop(t.originalScrollPos),t.originalScrollPos=null)):0===d()(".reveal:visible").length&&d()("body").removeClass("is-reveal-open"),u.Keyboard.releaseFocus(t.$element),t.$element.attr("aria-hidden",!0),t.$element.trigger("closed.zf.reveal")}if(!this.isActive||!this.$element.is(":visible"))return!1;var t=this;this.options.animationOut?(this.options.overlay&&f.Motion.animateOut(this.$overlay,"fade-out"),f.Motion.animateOut(this.$element,this.options.animationOut,e)):(this.$element.hide(this.options.hideDelay),this.options.overlay?this.$overlay.hide(0,e):e()),this.options.closeOnEsc&&d()(window).off("keydown.zf.reveal"),!this.options.overlay&&this.options.closeOnClick&&d()("body").off("click.zf.reveal"),this.$element.off("keydown.zf.reveal"),this.options.resetOnClose&&this.$element.html(this.$element.html()),this.isActive=!1,t.options.deepLink&&(window.history.replaceState?window.history.replaceState("",document.title,window.location.href.replace("#"+this.id,"")):window.location.hash=""),this.$anchor.focus()}},{key:"toggle",value:function(){this.isActive?this.close():this.open()}},{key:"_destroy",value:function(){this.options.overlay&&(this.$element.appendTo(d()(this.options.appendTo)),this.$overlay.hide().off().remove()),this.$element.hide().off(),this.$anchor.off(".zf"),d()(window).off(".zf.reveal:"+this.id)}}]),t}(g.Plugin);m.defaults={animationIn:"",animationOut:"",showDelay:0,hideDelay:0,closeOnClick:!0,closeOnEsc:!0,multipleOpened:!1,vOffset:"auto",hOffset:"auto",fullScreen:!1,btmOffsetPct:10,overlay:!0,resetOnClose:!1,deepLink:!1,updateHistory:!1,appendTo:"body",additionalOverlayClasses:""}},6:function(e,t){e.exports={MediaQuery:window.Foundation.MediaQuery}},7:function(e,t,i){"use strict";function n(e,t,i){var n=void 0,o=Array.prototype.slice.call(arguments,3);s()(window).off(t).on(t,function(t){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,o)},e||10)})}i.d(t,"a",function(){return c});var o=i(0),s=i.n(o),a=i(4),r=(i.n(a),function(){for(var e=["WebKit","Moz","O","Ms",""],t=0;t<e.length;t++)if(e[t]+"MutationObserver"in window)return window[e[t]+"MutationObserver"];return!1}()),l=function(e,t){e.data(t).split(" ").forEach(function(i){s()("#"+i)["close"===t?"trigger":"triggerHandler"](t+".zf.trigger",[e])})},c={Listeners:{Basic:{},Global:{}},Initializers:{}};c.Listeners.Basic={openListener:function(){l(s()(this),"open")},closeListener:function(){s()(this).data("close")?l(s()(this),"close"):s()(this).trigger("close.zf.trigger")},toggleListener:function(){s()(this).data("toggle")?l(s()(this),"toggle"):s()(this).trigger("toggle.zf.trigger")},closeableListener:function(e){e.stopPropagation();var t=s()(this).data("closable");""!==t?a.Motion.animateOut(s()(this),t,function(){s()(this).trigger("closed.zf")}):s()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var e=s()(this).data("toggle-focus");s()("#"+e).triggerHandler("toggle.zf.trigger",[s()(this)])}},c.Initializers.addOpenListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.openListener),e.on("click.zf.trigger","[data-open]",c.Listeners.Basic.openListener)},c.Initializers.addCloseListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.closeListener),e.on("click.zf.trigger","[data-close]",c.Listeners.Basic.closeListener)},c.Initializers.addToggleListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.toggleListener),e.on("click.zf.trigger","[data-toggle]",c.Listeners.Basic.toggleListener)},c.Initializers.addCloseableListener=function(e){e.off("close.zf.trigger",c.Listeners.Basic.closeableListener),e.on("close.zf.trigger","[data-closeable], [data-closable]",c.Listeners.Basic.closeableListener)},c.Initializers.addToggleFocusListener=function(e){e.off("focus.zf.trigger blur.zf.trigger",c.Listeners.Basic.toggleFocusListener),e.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",c.Listeners.Basic.toggleFocusListener)},c.Listeners.Global={resizeListener:function(e){r||e.each(function(){s()(this).triggerHandler("resizeme.zf.trigger")}),e.attr("data-events","resize")},scrollListener:function(e){r||e.each(function(){s()(this).triggerHandler("scrollme.zf.trigger")}),e.attr("data-events","scroll")},closeMeListener:function(e,t){var i=e.namespace.split(".")[0];s()("[data-"+i+"]").not('[data-yeti-box="'+t+'"]').each(function(){var e=s()(this);e.triggerHandler("close.zf.trigger",[e])})}},c.Initializers.addClosemeListener=function(e){var t=s()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(e&&("string"==typeof e?i.push(e):"object"==typeof e&&"string"==typeof e[0]?i.concat(e):console.error("Plugin names must be strings")),t.length){var n=i.map(function(e){return"closeme.zf."+e}).join(" ");s()(window).off(n).on(n,c.Listeners.Global.closeMeListener)}},c.Initializers.addResizeListener=function(e){var t=s()("[data-resize]");t.length&&n(e,"resize.zf.trigger",c.Listeners.Global.resizeListener,t)},c.Initializers.addScrollListener=function(e){var t=s()("[data-scroll]");t.length&&n(e,"scroll.zf.trigger",c.Listeners.Global.scrollListener,t)},c.Initializers.addMutationEventsListener=function(e){if(!r)return!1;var t=e.find("[data-resize], [data-scroll], [data-mutate]"),i=function(e){var t=s()(e[0].target);switch(e[0].type){case"attributes":"scroll"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("scrollme.zf.trigger",[t,window.pageYOffset]),"resize"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("resizeme.zf.trigger",[t]),"style"===e[0].attributeName&&(t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]));break;case"childList":t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]);break;default:return!1}};if(t.length)for(var n=0;n<=t.length-1;n++){var o=new r(i);o.observe(t[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},c.Initializers.addSimpleListeners=function(){var e=s()(document);c.Initializers.addOpenListener(e),c.Initializers.addCloseListener(e),c.Initializers.addToggleListener(e),c.Initializers.addCloseableListener(e),c.Initializers.addToggleFocusListener(e)},c.Initializers.addGlobalListeners=function(){var e=s()(document);c.Initializers.addMutationEventsListener(e),c.Initializers.addResizeListener(),c.Initializers.addScrollListener(),c.Initializers.addClosemeListener()},c.init=function(e,t){if(void 0===e.triggersInitialized){e(document);"complete"===document.readyState?(c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners()):e(window).on("load",function(){c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners()}),e.triggersInitialized=!0}t&&(t.Triggers=c,t.IHearYou=c.Initializers.addGlobalListeners)}},93:function(e,t,i){e.exports=i(27)}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("./foundation.util.keyboard"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("./foundation.util.touch"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.keyboard","./foundation.util.mediaQuery","./foundation.util.motion","./foundation.util.touch","jquery"],t):"object"==typeof exports?exports["foundation.reveal"]=t(require("./foundation.core"),require("./foundation.util.keyboard"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("./foundation.util.touch"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.reveal"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],e.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],e.__FOUNDATION_EXTERNAL__["foundation.util.motion"],e.__FOUNDATION_EXTERNAL__["foundation.util.touch"],e.jQuery))}(window,function(i,n,o,s,r,a){return function(i){var n={};function o(e){if(n[e])return n[e].exports;var t=n[e]={i:e,l:!1,exports:{}};return i[e].call(t.exports,t,t.exports,o),t.l=!0,t.exports}return o.m=i,o.c=n,o.d=function(e,t,i){o.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:i})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(t,e){if(1&e&&(t=o(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var i=Object.create(null);if(o.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var n in t)o.d(i,n,function(e){return t[e]}.bind(null,n));return i},o.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(t,"a",t),t},o.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},o.p="",o(o.s=14)}({"./foundation.core":function(e,t){e.exports=i},"./foundation.util.keyboard":function(e,t){e.exports=n},"./foundation.util.mediaQuery":function(e,t){e.exports=o},"./foundation.util.motion":function(e,t){e.exports=s},"./foundation.util.touch":function(e,t){e.exports=r},"./js/entries/plugins/foundation.reveal.js":function(e,t,i){"use strict";i.r(t);var n=i("./foundation.core");i.d(t,"Foundation",function(){return n.Foundation});var o=i("./js/foundation.reveal.js");i.d(t,"Reveal",function(){return o.Reveal}),n.Foundation.plugin(o.Reveal,"Reveal")},"./js/foundation.reveal.js":function(e,t,i){"use strict";i.r(t),i.d(t,"Reveal",function(){return g});var n=i("jquery"),r=i.n(n),s=i("./foundation.core"),a=i("./foundation.util.keyboard"),l=i("./foundation.util.mediaQuery"),c=i("./foundation.util.motion"),u=i("./js/foundation.util.triggers.js");i("./foundation.util.touch");function o(e){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}function d(e,t){for(var i=0;i<t.length;i++){var n=t[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}function f(e,t){return!t||"object"!==o(t)&&"function"!=typeof t?function(e){if(void 0!==e)return e;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(e):t}function h(e){return(h=Object.setPrototypeOf?Object.getPrototypeOf:function(e){return e.__proto__||Object.getPrototypeOf(e)})(e)}function p(e,t){return(p=Object.setPrototypeOf||function(e,t){return e.__proto__=t,e})(e,t)}var g=function(e){function i(){return function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,i),f(this,h(i).apply(this,arguments))}var t,n,o;return function(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function");e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,writable:!0,configurable:!0}}),t&&p(e,t)}(i,s["Plugin"]),t=i,(n=[{key:"_setup",value:function(e,t){this.$element=e,this.options=r.a.extend({},i.defaults,this.$element.data(),t),this.className="Reveal",this._init(),u.Triggers.init(r.a),a.Keyboard.register("Reveal",{ESCAPE:"close"})}},{key:"_init",value:function(){var e=this;l.MediaQuery._init(),this.id=this.$element.attr("id"),this.isActive=!1,this.cached={mq:l.MediaQuery.current},this.$anchor=r()('[data-open="'.concat(this.id,'"]')).length?r()('[data-open="'.concat(this.id,'"]')):r()('[data-toggle="'.concat(this.id,'"]')),this.$anchor.attr({"aria-controls":this.id,"aria-haspopup":!0,tabindex:0}),(this.options.fullScreen||this.$element.hasClass("full"))&&(this.options.fullScreen=!0,this.options.overlay=!1),this.options.overlay&&!this.$overlay&&(this.$overlay=this._makeOverlay(this.id)),this.$element.attr({role:"dialog","aria-hidden":!0,"data-yeti-box":this.id,"data-resize":this.id}),this.$overlay?this.$element.detach().appendTo(this.$overlay):(this.$element.detach().appendTo(r()(this.options.appendTo)),this.$element.addClass("without-overlay")),this._events(),this.options.deepLink&&window.location.hash==="#".concat(this.id)&&(this.onLoadListener=Object(s.onLoad)(r()(window),function(){return e.open()}))}},{key:"_makeOverlay",value:function(){var e="";return this.options.additionalOverlayClasses&&(e=" "+this.options.additionalOverlayClasses),r()("<div></div>").addClass("reveal-overlay"+e).appendTo(this.options.appendTo)}},{key:"_updatePosition",value:function(){var e,t=this.$element.outerWidth(),i=r()(window).width(),n=this.$element.outerHeight(),o=r()(window).height(),s=null;e="auto"===this.options.hOffset?parseInt((i-t)/2,10):parseInt(this.options.hOffset,10),"auto"===this.options.vOffset?s=o<n?parseInt(Math.min(100,o/10),10):parseInt((o-n)/4,10):null!==this.options.vOffset&&(s=parseInt(this.options.vOffset,10)),null!==s&&this.$element.css({top:s+"px"}),this.$overlay&&"auto"===this.options.hOffset||(this.$element.css({left:e+"px"}),this.$element.css({margin:"0px"}))}},{key:"_events",value:function(){var i=this,n=this;this.$element.on({"open.zf.trigger":this.open.bind(this),"close.zf.trigger":function(e,t){if(e.target===n.$element[0]||r()(e.target).parents("[data-closable]")[0]===t)return i.close.apply(i)},"toggle.zf.trigger":this.toggle.bind(this),"resizeme.zf.trigger":function(){n._updatePosition()}}),this.options.closeOnClick&&this.options.overlay&&this.$overlay.off(".zf.reveal").on("click.zf.reveal",function(e){e.target!==n.$element[0]&&!r.a.contains(n.$element[0],e.target)&&r.a.contains(document,e.target)&&n.close()}),this.options.deepLink&&r()(window).on("hashchange.zf.reveal:".concat(this.id),this._handleState.bind(this))}},{key:"_handleState",value:function(e){window.location.hash!=="#"+this.id||this.isActive?this.close():this.open()}},{key:"_disableScroll",value:function(e){e=e||r()(window).scrollTop(),r()(document).height()>r()(window).height()&&r()("html").css("top",-e)}},{key:"_enableScroll",value:function(e){e=e||parseInt(r()("html").css("top")),r()(document).height()>r()(window).height()&&(r()("html").css("top",""),r()(window).scrollTop(-e))}},{key:"open",value:function(){var e=this,t="#".concat(this.id);this.options.deepLink&&window.location.hash!==t&&(window.history.pushState?this.options.updateHistory?window.history.pushState({},"",t):window.history.replaceState({},"",t):window.location.hash=t),this.$activeAnchor=r()(document.activeElement).is(this.$anchor)?r()(document.activeElement):this.$anchor,this.isActive=!0,this.$element.css({visibility:"hidden"}).show().scrollTop(0),this.options.overlay&&this.$overlay.css({visibility:"hidden"}).show(),this._updatePosition(),this.$element.hide().css({visibility:""}),this.$overlay&&(this.$overlay.css({visibility:""}).hide(),this.$element.hasClass("fast")?this.$overlay.addClass("fast"):this.$element.hasClass("slow")&&this.$overlay.addClass("slow")),this.options.multipleOpened||this.$element.trigger("closeme.zf.reveal",this.id),this._disableScroll();var i=this;if(this.options.animationIn){this.options.overlay&&c.Motion.animateIn(this.$overlay,"fade-in"),c.Motion.animateIn(this.$element,this.options.animationIn,function(){e.$element&&(e.focusableElements=a.Keyboard.findFocusable(e.$element),i.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),i._addGlobalClasses(),a.Keyboard.trapFocus(i.$element))})}else this.options.overlay&&this.$overlay.show(0),this.$element.show(this.options.showDelay);this.$element.attr({"aria-hidden":!1,tabindex:-1}).focus(),a.Keyboard.trapFocus(this.$element),this._addGlobalClasses(),this._addGlobalListeners(),this.$element.trigger("open.zf.reveal")}},{key:"_addGlobalClasses",value:function(){var e=function(){r()("html").toggleClass("zf-has-scroll",!!(r()(document).height()>r()(window).height()))};this.$element.on("resizeme.zf.trigger.revealScrollbarListener",function(){return e()}),e(),r()("html").addClass("is-reveal-open")}},{key:"_removeGlobalClasses",value:function(){this.$element.off("resizeme.zf.trigger.revealScrollbarListener"),r()("html").removeClass("is-reveal-open"),r()("html").removeClass("zf-has-scroll")}},{key:"_addGlobalListeners",value:function(){var t=this;this.$element&&(this.focusableElements=a.Keyboard.findFocusable(this.$element),this.options.overlay||!this.options.closeOnClick||this.options.fullScreen||r()("body").on("click.zf.reveal",function(e){e.target!==t.$element[0]&&!r.a.contains(t.$element[0],e.target)&&r.a.contains(document,e.target)&&t.close()}),this.options.closeOnEsc&&r()(window).on("keydown.zf.reveal",function(e){a.Keyboard.handleKey(e,"Reveal",{close:function(){t.options.closeOnEsc&&t.close()}})}))}},{key:"close",value:function(){if(!this.isActive||!this.$element.is(":visible"))return!1;var t=this;function e(){var e=parseInt(r()("html").css("top"));0===r()(".reveal:visible").length&&t._removeGlobalClasses(),a.Keyboard.releaseFocus(t.$element),t.$element.attr("aria-hidden",!0),t._enableScroll(e),t.$element.trigger("closed.zf.reveal")}if(this.options.animationOut?(this.options.overlay&&c.Motion.animateOut(this.$overlay,"fade-out"),c.Motion.animateOut(this.$element,this.options.animationOut,e)):(this.$element.hide(this.options.hideDelay),this.options.overlay?this.$overlay.hide(0,e):e()),this.options.closeOnEsc&&r()(window).off("keydown.zf.reveal"),!this.options.overlay&&this.options.closeOnClick&&r()("body").off("click.zf.reveal"),this.$element.off("keydown.zf.reveal"),this.options.resetOnClose&&this.$element.html(this.$element.html()),this.isActive=!1,t.options.deepLink&&window.location.hash==="#".concat(this.id))if(window.history.replaceState){var i=window.location.pathname+window.location.search;this.options.updateHistory?window.history.pushState({},"",i):window.history.replaceState("",document.title,i)}else window.location.hash="";this.$activeAnchor.focus()}},{key:"toggle",value:function(){this.isActive?this.close():this.open()}},{key:"_destroy",value:function(){this.options.overlay&&(this.$element.appendTo(r()(this.options.appendTo)),this.$overlay.hide().off().remove()),this.$element.hide().off(),this.$anchor.off(".zf"),r()(window).off(".zf.reveal:".concat(this.id)),this.onLoadListener&&r()(window).off(this.onLoadListener),0===r()(".reveal:visible").length&&this._removeGlobalClasses()}}])&&d(t.prototype,n),o&&d(t,o),i}();g.defaults={animationIn:"",animationOut:"",showDelay:0,hideDelay:0,closeOnClick:!0,closeOnEsc:!0,multipleOpened:!1,vOffset:"auto",hOffset:"auto",fullScreen:!1,overlay:!0,resetOnClose:!1,deepLink:!1,updateHistory:!1,appendTo:"body",additionalOverlayClasses:""}},"./js/foundation.util.triggers.js":function(e,t,i){"use strict";i.r(t),i.d(t,"Triggers",function(){return u});var n=i("jquery"),s=i.n(n),o=i("./foundation.core"),r=i("./foundation.util.motion");function a(e){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}var l=function(){for(var e=["WebKit","Moz","O","Ms",""],t=0;t<e.length;t++)if("".concat(e[t],"MutationObserver")in window)return window["".concat(e[t],"MutationObserver")];return!1}(),c=function(t,i){t.data(i).split(" ").forEach(function(e){s()("#".concat(e))["close"===i?"trigger":"triggerHandler"]("".concat(i,".zf.trigger"),[t])})},u={Listeners:{Basic:{},Global:{}},Initializers:{}};function d(t,e,i){var n,o=Array.prototype.slice.call(arguments,3);s()(window).off(e).on(e,function(e){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,o)},t||10)})}u.Listeners.Basic={openListener:function(){c(s()(this),"open")},closeListener:function(){s()(this).data("close")?c(s()(this),"close"):s()(this).trigger("close.zf.trigger")},toggleListener:function(){s()(this).data("toggle")?c(s()(this),"toggle"):s()(this).trigger("toggle.zf.trigger")},closeableListener:function(e){e.stopPropagation();var t=s()(this).data("closable");""!==t?r.Motion.animateOut(s()(this),t,function(){s()(this).trigger("closed.zf")}):s()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var e=s()(this).data("toggle-focus");s()("#".concat(e)).triggerHandler("toggle.zf.trigger",[s()(this)])}},u.Initializers.addOpenListener=function(e){e.off("click.zf.trigger",u.Listeners.Basic.openListener),e.on("click.zf.trigger","[data-open]",u.Listeners.Basic.openListener)},u.Initializers.addCloseListener=function(e){e.off("click.zf.trigger",u.Listeners.Basic.closeListener),e.on("click.zf.trigger","[data-close]",u.Listeners.Basic.closeListener)},u.Initializers.addToggleListener=function(e){e.off("click.zf.trigger",u.Listeners.Basic.toggleListener),e.on("click.zf.trigger","[data-toggle]",u.Listeners.Basic.toggleListener)},u.Initializers.addCloseableListener=function(e){e.off("close.zf.trigger",u.Listeners.Basic.closeableListener),e.on("close.zf.trigger","[data-closeable], [data-closable]",u.Listeners.Basic.closeableListener)},u.Initializers.addToggleFocusListener=function(e){e.off("focus.zf.trigger blur.zf.trigger",u.Listeners.Basic.toggleFocusListener),e.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",u.Listeners.Basic.toggleFocusListener)},u.Listeners.Global={resizeListener:function(e){l||e.each(function(){s()(this).triggerHandler("resizeme.zf.trigger")}),e.attr("data-events","resize")},scrollListener:function(e){l||e.each(function(){s()(this).triggerHandler("scrollme.zf.trigger")}),e.attr("data-events","scroll")},closeMeListener:function(e,t){var i=e.namespace.split(".")[0];s()("[data-".concat(i,"]")).not('[data-yeti-box="'.concat(t,'"]')).each(function(){var e=s()(this);e.triggerHandler("close.zf.trigger",[e])})}},u.Initializers.addClosemeListener=function(e){var t=s()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(e&&("string"==typeof e?i.push(e):"object"===a(e)&&"string"==typeof e[0]?i=i.concat(e):console.error("Plugin names must be strings")),t.length){var n=i.map(function(e){return"closeme.zf.".concat(e)}).join(" ");s()(window).off(n).on(n,u.Listeners.Global.closeMeListener)}},u.Initializers.addResizeListener=function(e){var t=s()("[data-resize]");t.length&&d(e,"resize.zf.trigger",u.Listeners.Global.resizeListener,t)},u.Initializers.addScrollListener=function(e){var t=s()("[data-scroll]");t.length&&d(e,"scroll.zf.trigger",u.Listeners.Global.scrollListener,t)},u.Initializers.addMutationEventsListener=function(e){if(!l)return!1;var t=e.find("[data-resize], [data-scroll], [data-mutate]"),i=function(e){var t=s()(e[0].target);switch(e[0].type){case"attributes":"scroll"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("scrollme.zf.trigger",[t,window.pageYOffset]),"resize"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("resizeme.zf.trigger",[t]),"style"===e[0].attributeName&&(t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]));break;case"childList":t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]);break;default:return!1}};if(t.length)for(var n=0;n<=t.length-1;n++){new l(i).observe(t[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},u.Initializers.addSimpleListeners=function(){var e=s()(document);u.Initializers.addOpenListener(e),u.Initializers.addCloseListener(e),u.Initializers.addToggleListener(e),u.Initializers.addCloseableListener(e),u.Initializers.addToggleFocusListener(e)},u.Initializers.addGlobalListeners=function(){var e=s()(document);u.Initializers.addMutationEventsListener(e),u.Initializers.addResizeListener(),u.Initializers.addScrollListener(),u.Initializers.addClosemeListener()},u.init=function(e,t){Object(o.onLoad)(e(window),function(){!0!==e.triggersInitialized&&(u.Initializers.addSimpleListeners(),u.Initializers.addGlobalListeners(),e.triggersInitialized=!0)}),t&&(t.Triggers=u,t.IHearYou=u.Initializers.addGlobalListeners)}},14:function(e,t,i){e.exports=i("./js/entries/plugins/foundation.reveal.js")},jquery:function(e,t){e.exports=a}})});
+//# sourceMappingURL=foundation.reveal.min.js.map
diff --git a/dist/js/plugins/foundation.reveal.min.js.map b/dist/js/plugins/foundation.reveal.min.js.map
new file mode 100644 (file)
index 0000000..bbbe6ab
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.reveal.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE__foundation_util_touch__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.keyboard","./foundation.util.mediaQuery","./foundation.util.motion","./foundation.util.touch","./js/entries/plugins/foundation.reveal.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_reveal__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.reveal.js","Reveal","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","init","register","ESCAPE","_this2","id","attr","isActive","cached","mq","current","$anchor","concat","aria-controls","aria-haspopup","tabindex","fullScreen","hasClass","overlay","$overlay","_makeOverlay","role","aria-hidden","data-yeti-box","data-resize","detach","appendTo","addClass","_events","deepLink","location","hash","onLoadListener","open","additionalOverlayClasses","left","width","outerWidth","height","outerHeight","top","hOffset","parseInt","vOffset","Math","min","css","margin","_this3","_this","on","open.zf.trigger","close.zf.trigger","event","parents","close","toggle.zf.trigger","toggle","resizeme.zf.trigger","_updatePosition","closeOnClick","off","e","contains","document","_handleState","scrollTop","_this4","history","pushState","updateHistory","replaceState","$activeAnchor","activeElement","is","visibility","show","hide","multipleOpened","trigger","_disableScroll","animationIn","animateIn","focusableElements","findFocusable","focus","_addGlobalClasses","trapFocus","showDelay","_addGlobalListeners","updateScrollbarClass","toggleClass","removeClass","closeOnEsc","handleKey","finishUp","_removeGlobalClasses","releaseFocus","_enableScroll","animationOut","animateOut","hideDelay","resetOnClose","html","urlWithoutHash","pathname","search","title","remove","./js/foundation.util.triggers.js","Triggers","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","MutationObserver","prefixes","triggers","el","type","split","forEach","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","listener","timer","args","Array","slice","clearTimeout","setTimeout","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","scrollListener","closeMeListener","pluginId","namespace","not","addClosemeListener","pluginName","yetiBoxes","plugNames","push","console","error","listeners","map","join","addResizeListener","addScrollListener","addMutationEventsListener","find","listeningElementsMutation","mutationRecordsList","$target","attributeName","pageYOffset","closest","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","$","Foundation","triggersInitialized","IHearYou","14","jquery"],"mappings":"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","file":"foundation.reveal.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"./foundation.util.touch\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.reveal\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.reveal\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 14);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./foundation.util.touch\":\n/*!****************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.touch\"],\"amd\":\"./foundation.util.touch\",\"commonjs\":\"./foundation.util.touch\",\"commonjs2\":\"./foundation.util.touch\"} ***!\n  \\****************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.reveal.js\":\n/*!*************************************************!*\\\n  !*** ./js/entries/plugins/foundation.reveal.js ***!\n  \\*************************************************/\n/*! exports provided: Foundation, Reveal */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_reveal__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.reveal */ \"./js/foundation.reveal.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Reveal\", function() { return _foundation_reveal__WEBPACK_IMPORTED_MODULE_1__[\"Reveal\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_reveal__WEBPACK_IMPORTED_MODULE_1__[\"Reveal\"], 'Reveal');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.reveal.js\":\n/*!*********************************!*\\\n  !*** ./js/foundation.reveal.js ***!\n  \\*********************************/\n/*! exports provided: Reveal */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Reveal\", function() { return Reveal; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./foundation.util.touch */ \"./foundation.util.touch\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_6___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_touch__WEBPACK_IMPORTED_MODULE_6__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n\n/**\n * Reveal module.\n * @module foundation.reveal\n * @requires foundation.util.keyboard\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.motion if using animations\n */\n\nvar Reveal =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Reveal, _Plugin);\n\n  function Reveal() {\n    _classCallCheck(this, Reveal);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Reveal).apply(this, arguments));\n  }\n\n  _createClass(Reveal, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Reveal.\n     * @class\n     * @name Reveal\n     * @param {jQuery} element - jQuery object to use for the modal.\n     * @param {Object} options - optional parameters.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Reveal.defaults, this.$element.data(), options);\n      this.className = 'Reveal'; // ie9 back compat\n\n      this._init(); // Triggers init is idempotent, just need to make sure it is initialized\n\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('Reveal', {\n        'ESCAPE': 'close'\n      });\n    }\n    /**\n     * Initializes the modal by adding the overlay and close buttons, (if selected).\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var _this2 = this;\n\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"]._init();\n\n      this.id = this.$element.attr('id');\n      this.isActive = false;\n      this.cached = {\n        mq: _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_3__[\"MediaQuery\"].current\n      };\n      this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open=\\\"\".concat(this.id, \"\\\"]\")).length ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open=\\\"\".concat(this.id, \"\\\"]\")) : jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-toggle=\\\"\".concat(this.id, \"\\\"]\"));\n      this.$anchor.attr({\n        'aria-controls': this.id,\n        'aria-haspopup': true,\n        'tabindex': 0\n      });\n\n      if (this.options.fullScreen || this.$element.hasClass('full')) {\n        this.options.fullScreen = true;\n        this.options.overlay = false;\n      }\n\n      if (this.options.overlay && !this.$overlay) {\n        this.$overlay = this._makeOverlay(this.id);\n      }\n\n      this.$element.attr({\n        'role': 'dialog',\n        'aria-hidden': true,\n        'data-yeti-box': this.id,\n        'data-resize': this.id\n      });\n\n      if (this.$overlay) {\n        this.$element.detach().appendTo(this.$overlay);\n      } else {\n        this.$element.detach().appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo));\n        this.$element.addClass('without-overlay');\n      }\n\n      this._events();\n\n      if (this.options.deepLink && window.location.hash === \"#\".concat(this.id)) {\n        this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n          return _this2.open();\n        });\n      }\n    }\n    /**\n     * Creates an overlay div to display behind the modal.\n     * @private\n     */\n\n  }, {\n    key: \"_makeOverlay\",\n    value: function _makeOverlay() {\n      var additionalOverlayClasses = '';\n\n      if (this.options.additionalOverlayClasses) {\n        additionalOverlayClasses = ' ' + this.options.additionalOverlayClasses;\n      }\n\n      return jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div></div>').addClass('reveal-overlay' + additionalOverlayClasses).appendTo(this.options.appendTo);\n    }\n    /**\n     * Updates position of modal\n     * TODO:  Figure out if we actually need to cache these values or if it doesn't matter\n     * @private\n     */\n\n  }, {\n    key: \"_updatePosition\",\n    value: function _updatePosition() {\n      var width = this.$element.outerWidth();\n      var outerWidth = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).width();\n      var height = this.$element.outerHeight();\n      var outerHeight = jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height();\n      var left,\n          top = null;\n\n      if (this.options.hOffset === 'auto') {\n        left = parseInt((outerWidth - width) / 2, 10);\n      } else {\n        left = parseInt(this.options.hOffset, 10);\n      }\n\n      if (this.options.vOffset === 'auto') {\n        if (height > outerHeight) {\n          top = parseInt(Math.min(100, outerHeight / 10), 10);\n        } else {\n          top = parseInt((outerHeight - height) / 4, 10);\n        }\n      } else if (this.options.vOffset !== null) {\n        top = parseInt(this.options.vOffset, 10);\n      }\n\n      if (top !== null) {\n        this.$element.css({\n          top: top + 'px'\n        });\n      } // only worry about left if we don't have an overlay or we have a horizontal offset,\n      // otherwise we're perfectly in the middle\n\n\n      if (!this.$overlay || this.options.hOffset !== 'auto') {\n        this.$element.css({\n          left: left + 'px'\n        });\n        this.$element.css({\n          margin: '0px'\n        });\n      }\n    }\n    /**\n     * Adds event handlers for the modal.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this3 = this;\n\n      var _this = this;\n\n      this.$element.on({\n        'open.zf.trigger': this.open.bind(this),\n        'close.zf.trigger': function closeZfTrigger(event, $element) {\n          if (event.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default()(event.target).parents('[data-closable]')[0] === $element) {\n            // only close reveal when it's explicitly called\n            return _this3.close.apply(_this3);\n          }\n        },\n        'toggle.zf.trigger': this.toggle.bind(this),\n        'resizeme.zf.trigger': function resizemeZfTrigger() {\n          _this._updatePosition();\n        }\n      });\n\n      if (this.options.closeOnClick && this.options.overlay) {\n        this.$overlay.off('.zf.reveal').on('click.zf.reveal', function (e) {\n          if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) {\n            return;\n          }\n\n          _this.close();\n        });\n      }\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on(\"hashchange.zf.reveal:\".concat(this.id), this._handleState.bind(this));\n      }\n    }\n    /**\n     * Handles modal methods on back/forward button clicks or any other event that triggers hashchange.\n     * @private\n     */\n\n  }, {\n    key: \"_handleState\",\n    value: function _handleState(e) {\n      if (window.location.hash === '#' + this.id && !this.isActive) {\n        this.open();\n      } else {\n        this.close();\n      }\n    }\n    /**\n    * Disables the scroll when Reveal is shown to prevent the background from shifting\n    * @param {number} scrollTop - Scroll to visually apply, window current scroll by default\n    */\n\n  }, {\n    key: \"_disableScroll\",\n    value: function _disableScroll(scrollTop) {\n      scrollTop = scrollTop || jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop();\n\n      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"html\").css(\"top\", -scrollTop);\n      }\n    }\n    /**\n    * Reenables the scroll when Reveal closes\n    * @param {number} scrollTop - Scroll to restore, html \"top\" property by default (as set by `_disableScroll`)\n    */\n\n  }, {\n    key: \"_enableScroll\",\n    value: function _enableScroll(scrollTop) {\n      scrollTop = scrollTop || parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"html\").css(\"top\"));\n\n      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"html\").css(\"top\", \"\");\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop(-scrollTop);\n      }\n    }\n    /**\n     * Opens the modal controlled by `this.$anchor`, and closes all others by default.\n     * @function\n     * @fires Reveal#closeme\n     * @fires Reveal#open\n     */\n\n  }, {\n    key: \"open\",\n    value: function open() {\n      var _this4 = this;\n\n      // either update or replace browser history\n      var hash = \"#\".concat(this.id);\n\n      if (this.options.deepLink && window.location.hash !== hash) {\n        if (window.history.pushState) {\n          if (this.options.updateHistory) {\n            window.history.pushState({}, '', hash);\n          } else {\n            window.history.replaceState({}, '', hash);\n          }\n        } else {\n          window.location.hash = hash;\n        }\n      } // Remember anchor that opened it to set focus back later, have general anchors as fallback\n\n\n      this.$activeAnchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement).is(this.$anchor) ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(document.activeElement) : this.$anchor;\n      this.isActive = true; // Make elements invisible, but remove display: none so we can get size and positioning\n\n      this.$element.css({\n        'visibility': 'hidden'\n      }).show().scrollTop(0);\n\n      if (this.options.overlay) {\n        this.$overlay.css({\n          'visibility': 'hidden'\n        }).show();\n      }\n\n      this._updatePosition();\n\n      this.$element.hide().css({\n        'visibility': ''\n      });\n\n      if (this.$overlay) {\n        this.$overlay.css({\n          'visibility': ''\n        }).hide();\n\n        if (this.$element.hasClass('fast')) {\n          this.$overlay.addClass('fast');\n        } else if (this.$element.hasClass('slow')) {\n          this.$overlay.addClass('slow');\n        }\n      }\n\n      if (!this.options.multipleOpened) {\n        /**\n         * Fires immediately before the modal opens.\n         * Closes any other modals that are currently open\n         * @event Reveal#closeme\n         */\n        this.$element.trigger('closeme.zf.reveal', this.id);\n      }\n\n      this._disableScroll();\n\n      var _this = this; // Motion UI method of reveal\n\n\n      if (this.options.animationIn) {\n        var afterAnimation = function afterAnimation() {\n          _this.$element.attr({\n            'aria-hidden': false,\n            'tabindex': -1\n          }).focus();\n\n          _this._addGlobalClasses();\n\n          _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].trapFocus(_this.$element);\n        };\n\n        if (this.options.overlay) {\n          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__[\"Motion\"].animateIn(this.$overlay, 'fade-in');\n        }\n\n        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__[\"Motion\"].animateIn(this.$element, this.options.animationIn, function () {\n          if (_this4.$element) {\n            // protect against object having been removed\n            _this4.focusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].findFocusable(_this4.$element);\n            afterAnimation();\n          }\n        });\n      } // jQuery method of reveal\n      else {\n          if (this.options.overlay) {\n            this.$overlay.show(0);\n          }\n\n          this.$element.show(this.options.showDelay);\n        } // handle accessibility\n\n\n      this.$element.attr({\n        'aria-hidden': false,\n        'tabindex': -1\n      }).focus();\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].trapFocus(this.$element);\n\n      this._addGlobalClasses();\n\n      this._addGlobalListeners();\n      /**\n       * Fires when the modal has successfully opened.\n       * @event Reveal#open\n       */\n\n\n      this.$element.trigger('open.zf.reveal');\n    }\n    /**\n     * Adds classes and listeners on document required by open modals.\n     *\n     * The following classes are added and updated:\n     * - `.is-reveal-open` - Prevents the scroll on document\n     * - `.zf-has-scroll`  - Displays a disabled scrollbar on document if required like if the\n     *                       scroll was not disabled. This prevent a \"shift\" of the page content due\n     *                       the scrollbar disappearing when the modal opens.\n     *\n     * @private\n     */\n\n  }, {\n    key: \"_addGlobalClasses\",\n    value: function _addGlobalClasses() {\n      var updateScrollbarClass = function updateScrollbarClass() {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').toggleClass('zf-has-scroll', !!(jquery__WEBPACK_IMPORTED_MODULE_0___default()(document).height() > jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).height()));\n      };\n\n      this.$element.on('resizeme.zf.trigger.revealScrollbarListener', function () {\n        return updateScrollbarClass();\n      });\n      updateScrollbarClass();\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').addClass('is-reveal-open');\n    }\n    /**\n     * Removes classes and listeners on document that were required by open modals.\n     * @private\n     */\n\n  }, {\n    key: \"_removeGlobalClasses\",\n    value: function _removeGlobalClasses() {\n      this.$element.off('resizeme.zf.trigger.revealScrollbarListener');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('is-reveal-open');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html').removeClass('zf-has-scroll');\n    }\n    /**\n     * Adds extra event handlers for the body and window if necessary.\n     * @private\n     */\n\n  }, {\n    key: \"_addGlobalListeners\",\n    value: function _addGlobalListeners() {\n      var _this = this;\n\n      if (!this.$element) {\n        return;\n      } // If we're in the middle of cleanup, don't freak out\n\n\n      this.focusableElements = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].findFocusable(this.$element);\n\n      if (!this.options.overlay && this.options.closeOnClick && !this.options.fullScreen) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').on('click.zf.reveal', function (e) {\n          if (e.target === _this.$element[0] || jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(_this.$element[0], e.target) || !jquery__WEBPACK_IMPORTED_MODULE_0___default.a.contains(document, e.target)) {\n            return;\n          }\n\n          _this.close();\n        });\n      }\n\n      if (this.options.closeOnEsc) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('keydown.zf.reveal', function (e) {\n          _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'Reveal', {\n            close: function close() {\n              if (_this.options.closeOnEsc) {\n                _this.close();\n              }\n            }\n          });\n        });\n      }\n    }\n    /**\n     * Closes the modal.\n     * @function\n     * @fires Reveal#closed\n     */\n\n  }, {\n    key: \"close\",\n    value: function close() {\n      if (!this.isActive || !this.$element.is(':visible')) {\n        return false;\n      }\n\n      var _this = this; // Motion UI method of hiding\n\n\n      if (this.options.animationOut) {\n        if (this.options.overlay) {\n          _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__[\"Motion\"].animateOut(this.$overlay, 'fade-out');\n        }\n\n        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_4__[\"Motion\"].animateOut(this.$element, this.options.animationOut, finishUp);\n      } // jQuery method of hiding\n      else {\n          this.$element.hide(this.options.hideDelay);\n\n          if (this.options.overlay) {\n            this.$overlay.hide(0, finishUp);\n          } else {\n            finishUp();\n          }\n        } // Conditionals to remove extra event listeners added on open\n\n\n      if (this.options.closeOnEsc) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('keydown.zf.reveal');\n      }\n\n      if (!this.options.overlay && this.options.closeOnClick) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('body').off('click.zf.reveal');\n      }\n\n      this.$element.off('keydown.zf.reveal');\n\n      function finishUp() {\n        // Get the current top before the modal is closed and restore the scroll after.\n        // TODO: use component properties instead of HTML properties\n        // See https://github.com/zurb/foundation-sites/pull/10786\n        var scrollTop = parseInt(jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"html\").css(\"top\"));\n\n        if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) {\n          _this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n\n        }\n\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].releaseFocus(_this.$element);\n\n        _this.$element.attr('aria-hidden', true);\n\n        _this._enableScroll(scrollTop);\n        /**\n        * Fires when the modal is done closing.\n        * @event Reveal#closed\n        */\n\n\n        _this.$element.trigger('closed.zf.reveal');\n      }\n      /**\n      * Resets the modal content\n      * This prevents a running video to keep going in the background\n      */\n\n\n      if (this.options.resetOnClose) {\n        this.$element.html(this.$element.html());\n      }\n\n      this.isActive = false; // If deepLink and we did not switched to an other modal...\n\n      if (_this.options.deepLink && window.location.hash === \"#\".concat(this.id)) {\n        // Remove the history hash\n        if (window.history.replaceState) {\n          var urlWithoutHash = window.location.pathname + window.location.search;\n\n          if (this.options.updateHistory) {\n            window.history.pushState({}, '', urlWithoutHash); // remove the hash\n          } else {\n            window.history.replaceState('', document.title, urlWithoutHash);\n          }\n        } else {\n          window.location.hash = '';\n        }\n      }\n\n      this.$activeAnchor.focus();\n    }\n    /**\n     * Toggles the open/closed state of a modal.\n     * @function\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle() {\n      if (this.isActive) {\n        this.close();\n      } else {\n        this.open();\n      }\n    }\n  }, {\n    key: \"_destroy\",\n\n    /**\n     * Destroys an instance of a modal.\n     * @function\n     */\n    value: function _destroy() {\n      if (this.options.overlay) {\n        this.$element.appendTo(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.appendTo)); // move $element outside of $overlay to prevent error unregisterPlugin()\n\n        this.$overlay.hide().off().remove();\n      }\n\n      this.$element.hide().off();\n      this.$anchor.off('.zf');\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(\".zf.reveal:\".concat(this.id));\n      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n\n      if (jquery__WEBPACK_IMPORTED_MODULE_0___default()('.reveal:visible').length === 0) {\n        this._removeGlobalClasses(); // also remove .is-reveal-open from the html element when there is no opened reveal\n\n      }\n    }\n  }]);\n\n  return Reveal;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n\nReveal.defaults = {\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationIn: '',\n\n  /**\n   * Motion-UI class to use for animated elements. If none used, defaults to simple show/hide.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  animationOut: '',\n\n  /**\n   * Time, in ms, to delay the opening of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  showDelay: 0,\n\n  /**\n   * Time, in ms, to delay the closing of a modal after a click if no animation used.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hideDelay: 0,\n\n  /**\n   * Allows a click on the body/overlay to close the modal.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnClick: true,\n\n  /**\n   * Allows the modal to close if the user presses the `ESCAPE` key.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  closeOnEsc: true,\n\n  /**\n   * If true, allows multiple modals to be displayed at once.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  multipleOpened: false,\n\n  /**\n   * Distance, in pixels, the modal should push down from the top of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  vOffset: 'auto',\n\n  /**\n   * Distance, in pixels, the modal should push in from the side of the screen.\n   * @option\n   * @type {number|string}\n   * @default auto\n   */\n  hOffset: 'auto',\n\n  /**\n   * Allows the modal to be fullscreen, completely blocking out the rest of the view. JS checks for this as well.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  fullScreen: false,\n\n  /**\n   * Allows the modal to generate an overlay div, which will cover the view when modal opens.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  overlay: true,\n\n  /**\n   * Allows the modal to remove and reinject markup on close. Should be true if using video elements w/o using provider's api, otherwise, videos will continue to play in the background.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  resetOnClose: false,\n\n  /**\n   * Link the location hash to the modal.\n   * Set the location hash when the modal is opened/closed, and open/close the modal when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open modal\n   * @option\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n  * Allows the modal to append to custom div.\n  * @option\n  * @type {string}\n  * @default \"body\"\n  */\n  appendTo: \"body\",\n\n  /**\n   * Allows adding additional class names to the reveal overlay.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  additionalOverlayClasses: ''\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 14:\n/*!*******************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.reveal.js ***!\n  \\*******************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.reveal.js */\"./js/entries/plugins/foundation.reveal.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.reveal.js.map"]}
\ No newline at end of file
index d6872fdb260634b9b902e6ae86cf94a9baddb86a..cb33a0f7f507f60d56dc6d8d17b189a63b056b25 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("./foundation.util.motion"), require("./foundation.util.touch"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.keyboard", "./foundation.util.motion", "./foundation.util.touch", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.slider"] = factory(require("./foundation.core"), require("./foundation.util.keyboard"), require("./foundation.util.motion"), require("./foundation.util.touch"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.slider"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.touch"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 94);
+/******/       return __webpack_require__(__webpack_require__.s = 15);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
 /***/ }),
 
-/***/ 12:
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Touch: window.Foundation.Touch};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.util.touch":
+/*!****************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.touch"],"amd":"./foundation.util.touch","commonjs":"./foundation.util.touch","commonjs2":"./foundation.util.touch"} ***!
+  \****************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;
 
 /***/ }),
 
-/***/ 28:
+/***/ "./js/entries/plugins/foundation.slider.js":
+/*!*************************************************!*\
+  !*** ./js/entries/plugins/foundation.slider.js ***!
+  \*************************************************/
+/*! exports provided: Foundation, Slider */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_slider__ = __webpack_require__(58);
-
-
-
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_slider__["a" /* Slider */], 'Slider');
-
-/***/ }),
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-/***/ 3:
-/***/ (function(module, exports) {
+/* harmony import */ var _foundation_slider__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.slider */ "./js/foundation.slider.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Slider", function() { return _foundation_slider__WEBPACK_IMPORTED_MODULE_1__["Slider"]; });
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
-/***/ }),
 
-/***/ 4:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_slider__WEBPACK_IMPORTED_MODULE_1__["Slider"], 'Slider');
 
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
 
 /***/ }),
 
-/***/ 5:
-/***/ (function(module, exports) {
-
-module.exports = {Keyboard: window.Foundation.Keyboard};
-
-/***/ }),
-
-/***/ 58:
+/***/ "./js/foundation.slider.js":
+/*!*********************************!*\
+  !*** ./js/foundation.slider.js ***!
+  \*********************************/
+/*! exports provided: Slider */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Slider; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_touch__ = __webpack_require__(12);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_5__foundation_util_touch___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_5__foundation_util_touch__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_6__foundation_util_triggers__ = __webpack_require__(7);
-
-
-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; }; }();
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Slider", function() { return Slider; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__);
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.touch */ "./foundation.util.touch");
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_touch__WEBPACK_IMPORTED_MODULE_4__);
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(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 _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -179,17 +220,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.touch
  */
 
-var Slider = function (_Plugin) {
+var Slider =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Slider, _Plugin);
 
   function Slider() {
     _classCallCheck(this, Slider);
 
-    return _possibleConstructorReturn(this, (Slider.__proto__ || Object.getPrototypeOf(Slider)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Slider).apply(this, arguments));
   }
 
   _createClass(Slider, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of a slider control.
@@ -200,16 +243,16 @@ var Slider = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Slider.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Slider.defaults, this.$element.data(), options);
       this.className = 'Slider'; // ie9 back compat
-
       // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.
-      __WEBPACK_IMPORTED_MODULE_5__foundation_util_touch__["Touch"].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
-      __WEBPACK_IMPORTED_MODULE_6__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+
+      _foundation_util_touch__WEBPACK_IMPORTED_MODULE_4__["Touch"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
       this._init();
 
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('Slider', {
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].register('Slider', {
         'ltr': {
           'ARROW_RIGHT': 'increase',
           'ARROW_UP': 'increase',
@@ -230,7 +273,6 @@ var Slider = function (_Plugin) {
         }
       });
     }
-
     /**
      * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).
      * @function
@@ -238,23 +280,24 @@ var Slider = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
       this.inputs = this.$element.find('input');
       this.handles = this.$element.find('[data-slider-handle]');
-
       this.$handle = this.handles.eq(0);
-      this.$input = this.inputs.length ? this.inputs.eq(0) : __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + this.$handle.attr('aria-controls'));
+      this.$input = this.inputs.length ? this.inputs.eq(0) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(this.$handle.attr('aria-controls')));
       this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);
 
       var isDbl = false,
           _this = this;
+
       if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {
         this.options.disabled = true;
         this.$element.addClass(this.options.disabledClass);
       }
+
       if (!this.inputs.length) {
-        this.inputs = __WEBPACK_IMPORTED_MODULE_0_jquery___default()().add(this.$input);
+        this.inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default()().add(this.$input);
         this.options.binding = true;
       }
 
@@ -263,37 +306,37 @@ var Slider = function (_Plugin) {
       if (this.handles[1]) {
         this.options.doubleSided = true;
         this.$handle2 = this.handles.eq(1);
-        this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + this.$handle2.attr('aria-controls'));
+        this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(this.$handle2.attr('aria-controls')));
 
         if (!this.inputs[1]) {
           this.inputs = this.inputs.add(this.$input2);
         }
-        isDbl = true;
 
-        // this.$handle.triggerHandler('click.zf.slider');
+        isDbl = true; // this.$handle.triggerHandler('click.zf.slider');
+
         this._setInitAttr(1);
-      }
+      } // Set handle positions
+
 
-      // Set handle positions
       this.setHandles();
 
       this._events();
     }
   }, {
-    key: 'setHandles',
+    key: "setHandles",
     value: function setHandles() {
-      var _this3 = this;
+      var _this2 = this;
 
       if (this.handles[1]) {
         this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, function () {
-          _this3._setHandlePos(_this3.$handle2, _this3.inputs.eq(1).val(), true);
+          _this2._setHandlePos(_this2.$handle2, _this2.inputs.eq(1).val(), true);
         });
       } else {
         this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);
       }
     }
   }, {
-    key: '_reflow',
+    key: "_reflow",
     value: function _reflow() {
       this.setHandles();
     }
@@ -304,7 +347,7 @@ var Slider = function (_Plugin) {
     */
 
   }, {
-    key: '_pctOfBar',
+    key: "_pctOfBar",
     value: function _pctOfBar(value) {
       var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start);
 
@@ -312,6 +355,7 @@ var Slider = function (_Plugin) {
         case "pow":
           pctOfBar = this._logTransform(pctOfBar);
           break;
+
         case "log":
           pctOfBar = this._powTransform(pctOfBar);
           break;
@@ -319,7 +363,6 @@ var Slider = function (_Plugin) {
 
       return pctOfBar.toFixed(2);
     }
-
     /**
     * @function
     * @private
@@ -327,21 +370,21 @@ var Slider = function (_Plugin) {
     */
 
   }, {
-    key: '_value',
+    key: "_value",
     value: function _value(pctOfBar) {
       switch (this.options.positionValueFunction) {
         case "pow":
           pctOfBar = this._powTransform(pctOfBar);
           break;
+
         case "log":
           pctOfBar = this._logTransform(pctOfBar);
           break;
       }
-      var value = (this.options.end - this.options.start) * pctOfBar + this.options.start;
 
+      var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);
       return value;
     }
-
     /**
     * @function
     * @private
@@ -349,11 +392,10 @@ var Slider = function (_Plugin) {
     */
 
   }, {
-    key: '_logTransform',
+    key: "_logTransform",
     value: function _logTransform(value) {
       return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1);
     }
-
     /**
     * @function
     * @private
@@ -361,11 +403,10 @@ var Slider = function (_Plugin) {
     */
 
   }, {
-    key: '_powTransform',
+    key: "_powTransform",
     value: function _powTransform(value) {
       return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1);
     }
-
     /**
      * Sets the position of the selected handle and fill bar.
      * @function
@@ -378,26 +419,26 @@ var Slider = function (_Plugin) {
      */
 
   }, {
-    key: '_setHandlePos',
+    key: "_setHandlePos",
     value: function _setHandlePos($hndl, location, noInvert, cb) {
       // don't move if the slider has been disabled since its initialization
       if (this.$element.hasClass(this.options.disabledClass)) {
         return;
-      }
-      //might need to alter that slightly for bars that will have odd number selections.
-      location = parseFloat(location); //on input change events, convert string to number...grumble.
+      } //might need to alter that slightly for bars that will have odd number selections.
 
+
+      location = parseFloat(location); //on input change events, convert string to number...grumble.
       // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max
+
       if (location < this.options.start) {
         location = this.options.start;
       } else if (location > this.options.end) {
         location = this.options.end;
       }
 
-      var isDbl = this.options.doubleSided;
-
-      //this is for single-handled vertical sliders, it adjusts the value to account for the slider being "upside-down"
+      var isDbl = this.options.doubleSided; //this is for single-handled vertical sliders, it adjusts the value to account for the slider being "upside-down"
       //for click and drag events, it's weird due to the scale(-1, 1) css property
+
       if (this.options.vertical && !noInvert) {
         location = this.options.end - location;
       }
@@ -419,51 +460,49 @@ var Slider = function (_Plugin) {
           lOrT = vert ? 'top' : 'left',
           handleDim = $hndl[0].getBoundingClientRect()[hOrW],
           elemDim = this.$element[0].getBoundingClientRect()[hOrW],
-
-      //percentage of bar min/max value based on click or drag point
+          //percentage of bar min/max value based on click or drag point
       pctOfBar = this._pctOfBar(location),
-
-      //number of actual pixels to shift the handle, based on the percentage obtained above
+          //number of actual pixels to shift the handle, based on the percentage obtained above
       pxToMove = (elemDim - handleDim) * pctOfBar,
+          //percentage of bar to shift the handle
+      movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value
+
+
+      location = parseFloat(location.toFixed(this.options.decimal)); // declare empty object for css adjustments, only used with 2 handled-sliders
 
-      //percentage of bar to shift the handle
-      movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);
-      //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value
-      location = parseFloat(location.toFixed(this.options.decimal));
-      // declare empty object for css adjustments, only used with 2 handled-sliders
       var css = {};
 
-      this._setValues($hndl, location);
+      this._setValues($hndl, location); // TODO update to calculate based on values set to respective inputs??
+
 
-      // TODO update to calculate based on values set to respective inputs??
       if (isDbl) {
         var isLeftHndl = this.handles.index($hndl) === 0,
-
-        //empty variable, will be used for min-height/width for fill bar
+            //empty variable, will be used for min-height/width for fill bar
         dim,
+            //percentage w/h of the handle compared to the slider bar
+        handlePct = ~~(percent(handleDim, elemDim) * 100); //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar
 
-        //percentage w/h of the handle compared to the slider bar
-        handlePct = ~~(percent(handleDim, elemDim) * 100);
-        //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar
         if (isLeftHndl) {
           //left or top percentage value to apply to the fill bar.
-          css[lOrT] = movement + '%';
-          //calculate the new min-height/width for the fill bar.
-          dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;
-          //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider
+          css[lOrT] = "".concat(movement, "%"); //calculate the new min-height/width for the fill bar.
+
+          dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider
           //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.
+
           if (cb && typeof cb === 'function') {
             cb();
           } //this is only needed for the initialization of 2 handled sliders
+
         } else {
           //just caching the value of the left/bottom handle's left/top property
-          var handlePos = parseFloat(this.$handle[0].style[lOrT]);
-          //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0
+          var handlePos = parseFloat(this.$handle[0].style[lOrT]); //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0
           //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself
+
           dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct;
-        }
-        // assign the min-height/width to our css object
-        css['min-' + hOrW] = dim + '%';
+        } // assign the min-height/width to our css object
+
+
+        css["min-".concat(hOrW)] = "".concat(dim, "%");
       }
 
       this.$element.one('finished.zf.animate', function () {
@@ -472,40 +511,37 @@ var Slider = function (_Plugin) {
          * @event Slider#moved
          */
         _this.$element.trigger('moved.zf.slider', [$hndl]);
-      });
+      }); //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.
 
-      //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.
       var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime;
-
-      __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_motion__["Move"])(moveTime, $hndl, function () {
+      Object(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Move"])(moveTime, $hndl, function () {
         // adjusting the left/top property of the handle, based on the percentage calculated above
         // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,
         // fall back to next best guess.
         if (isNaN(movement)) {
-          $hndl.css(lOrT, pctOfBar * 100 + '%');
+          $hndl.css(lOrT, "".concat(pctOfBar * 100, "%"));
         } else {
-          $hndl.css(lOrT, movement + '%');
+          $hndl.css(lOrT, "".concat(movement, "%"));
         }
 
         if (!_this.options.doubleSided) {
           //if single-handled, a simple method to expand the fill bar
-          _this.$fill.css(hOrW, pctOfBar * 100 + '%');
+          _this.$fill.css(hOrW, "".concat(pctOfBar * 100, "%"));
         } else {
           //otherwise, use the css object we created above
           _this.$fill.css(css);
         }
       });
-
       /**
        * Fires when the value has not been change for a given time.
        * @event Slider#changed
        */
+
       clearTimeout(_this.timeout);
       _this.timeout = setTimeout(function () {
         _this.$element.trigger('changed.zf.slider', [$hndl]);
       }, _this.options.changedDelay);
     }
-
     /**
      * Sets the initial attribute for the slider element.
      * @function
@@ -514,10 +550,10 @@ var Slider = function (_Plugin) {
      */
 
   }, {
-    key: '_setInitAttr',
+    key: "_setInitAttr",
     value: function _setInitAttr(idx) {
       var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd;
-      var id = this.inputs.eq(idx).attr('id') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["GetYoDigits"])(6, 'slider');
+      var id = this.inputs.eq(idx).attr('id') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["GetYoDigits"])(6, 'slider');
       this.inputs.eq(idx).attr({
         'id': id,
         'max': this.options.end,
@@ -535,7 +571,6 @@ var Slider = function (_Plugin) {
         'tabindex': 0
       });
     }
-
     /**
      * Sets the input and `aria-valuenow` values for the slider element.
      * @function
@@ -545,13 +580,12 @@ var Slider = function (_Plugin) {
      */
 
   }, {
-    key: '_setValues',
+    key: "_setValues",
     value: function _setValues($handle, val) {
       var idx = this.options.doubleSided ? this.handles.index($handle) : 0;
       this.inputs.eq(idx).val(val);
       $handle.attr('aria-valuenow', val);
     }
-
     /**
      * Handles events on the slider element.
      * Calculates the new location of the current handle.
@@ -565,12 +599,14 @@ var Slider = function (_Plugin) {
      */
 
   }, {
-    key: '_handleEvent',
+    key: "_handleEvent",
     value: function _handleEvent(e, $handle, val) {
       var value, hasVal;
+
       if (!val) {
         //click or drag events
         e.preventDefault();
+
         var _this = this,
             vertical = this.options.vertical,
             param = vertical ? 'height' : 'width',
@@ -578,17 +614,18 @@ var Slider = function (_Plugin) {
             eventOffset = vertical ? e.pageY : e.pageX,
             halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,
             barDim = this.$element[0].getBoundingClientRect()[param],
-            windowScroll = vertical ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).scrollTop() : __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).scrollLeft();
+            windowScroll = vertical ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop() : jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollLeft();
 
-        var elemOffset = this.$element.offset()[direction];
-
-        // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...
+        var elemOffset = this.$element.offset()[direction]; // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...
         // best way to guess this is simulated is if clientY == pageY
+
         if (e.clientY === e.pageY) {
           eventOffset = eventOffset + windowScroll;
         }
+
         var eventFromBar = eventOffset - elemOffset;
         var barXY;
+
         if (eventFromBar < 0) {
           barXY = 0;
         } else if (eventFromBar > barDim) {
@@ -596,17 +633,16 @@ var Slider = function (_Plugin) {
         } else {
           barXY = eventFromBar;
         }
-        var offsetPct = percent(barXY, barDim);
 
-        value = this._value(offsetPct);
+        var offsetPct = percent(barXY, barDim);
+        value = this._value(offsetPct); // turn everything around for RTL, yay math!
 
-        // turn everything around for RTL, yay math!
-        if (__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_3__foundation_util_core__["rtl"])() && !this.options.vertical) {
+        if (Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["rtl"])() && !this.options.vertical) {
           value = this.options.end - value;
         }
 
-        value = _this._adjustValue(null, value);
-        //boolean flag for the setHandlePos fn, specifically for vertical sliders
+        value = _this._adjustValue(null, value); //boolean flag for the setHandlePos fn, specifically for vertical sliders
+
         hasVal = false;
 
         if (!$handle) {
@@ -623,7 +659,6 @@ var Slider = function (_Plugin) {
 
       this._setHandlePos($handle, value, hasVal);
     }
-
     /**
      * Adjustes value for handle in regard to step value. returns adjusted value
      * @function
@@ -633,7 +668,7 @@ var Slider = function (_Plugin) {
      */
 
   }, {
-    key: '_adjustValue',
+    key: "_adjustValue",
     value: function _adjustValue($handle, value) {
       var val,
           step = this.options.step,
@@ -641,21 +676,29 @@ var Slider = function (_Plugin) {
           left,
           prev_val,
           next_val;
+
       if (!!$handle) {
         val = parseFloat($handle.attr('aria-valuenow'));
       } else {
         val = value;
       }
-      left = val % step;
+
+      if (val >= 0) {
+        left = val % step;
+      } else {
+        left = step + val % step;
+      }
+
       prev_val = val - left;
       next_val = prev_val + step;
+
       if (left === 0) {
         return val;
       }
+
       val = val >= prev_val + div ? next_val : prev_val;
       return val;
     }
-
     /**
      * Adds event listeners to the slider elements.
      * @function
@@ -663,14 +706,14 @@ var Slider = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       this._eventsForHandle(this.$handle);
+
       if (this.handles[1]) {
         this._eventsForHandle(this.$handle2);
       }
     }
-
     /**
      * Adds event listeners a particular handle
      * @function
@@ -679,16 +722,25 @@ var Slider = function (_Plugin) {
      */
 
   }, {
-    key: '_eventsForHandle',
+    key: "_eventsForHandle",
     value: function _eventsForHandle($handle) {
       var _this = this,
           curHandle,
           timer;
 
-      this.inputs.off('change.zf.slider').on('change.zf.slider', function (e) {
-        var idx = _this.inputs.index(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
-        _this._handleEvent(e, _this.handles.eq(idx), __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).val());
+      var handleChangeEvent = function handleChangeEvent(e) {
+        var idx = _this.inputs.index(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
+
+        _this._handleEvent(e, _this.handles.eq(idx), jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val());
+      }; // IE only triggers the change event when the input loses focus which strictly follows the HTML specification
+      // listen for the enter key and trigger a change
+      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events
+
+
+      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {
+        if (e.keyCode == 13) handleChangeEvent.call(this, e);
       });
+      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);
 
       if (this.options.clickSelect) {
         this.$element.off('click.zf.slider').on('click.zf.slider', function (e) {
@@ -696,7 +748,7 @@ var Slider = function (_Plugin) {
             return false;
           }
 
-          if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.target).is('[data-slider-handle]')) {
+          if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is('[data-slider-handle]')) {
             if (_this.options.doubleSided) {
               _this._handleEvent(e);
             } else {
@@ -708,63 +760,67 @@ var Slider = function (_Plugin) {
 
       if (this.options.draggable) {
         this.handles.addTouch();
-
-        var $body = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('body');
+        var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');
         $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) {
           $handle.addClass('is-dragging');
+
           _this.$fill.addClass('is-dragging'); //
-          _this.$element.data('dragging', true);
 
-          curHandle = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(e.currentTarget);
 
+          _this.$element.data('dragging', true);
+
+          curHandle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget);
           $body.on('mousemove.zf.slider', function (e) {
             e.preventDefault();
+
             _this._handleEvent(e, curHandle);
           }).on('mouseup.zf.slider', function (e) {
             _this._handleEvent(e, curHandle);
 
             $handle.removeClass('is-dragging');
+
             _this.$fill.removeClass('is-dragging');
+
             _this.$element.data('dragging', false);
 
             $body.off('mousemove.zf.slider mouseup.zf.slider');
           });
-        })
-        // prevent events triggered by touch
+        }) // prevent events triggered by touch
         .on('selectstart.zf.slider touchmove.zf.slider', function (e) {
           e.preventDefault();
         });
       }
 
       $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) {
-        var _$handle = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var _$handle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,
             oldValue = parseFloat(_this.inputs.eq(idx).val()),
-            newValue;
+            newValue; // handle keyboard event with keyboard util
+
 
-        // handle keyboard event with keyboard util
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'Slider', {
-          decrease: function () {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"].handleKey(e, 'Slider', {
+          decrease: function decrease() {
             newValue = oldValue - _this.options.step;
           },
-          increase: function () {
+          increase: function increase() {
             newValue = oldValue + _this.options.step;
           },
-          decrease_fast: function () {
+          decrease_fast: function decrease_fast() {
             newValue = oldValue - _this.options.step * 10;
           },
-          increase_fast: function () {
+          increase_fast: function increase_fast() {
             newValue = oldValue + _this.options.step * 10;
           },
-          min: function () {
+          min: function min() {
             newValue = _this.options.start;
           },
-          max: function () {
+          max: function max() {
             newValue = _this.options.end;
           },
-          handled: function () {
+          handled: function handled() {
             // only set handle pos when event was handled specially
             e.preventDefault();
+
             _this._setHandlePos(_$handle, newValue, true);
           }
         });
@@ -774,24 +830,22 @@ var Slider = function (_Plugin) {
         }*/
       });
     }
-
     /**
      * Destroys the slider plugin.
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.handles.off('.zf.slider');
       this.inputs.off('.zf.slider');
       this.$element.off('.zf.slider');
-
       clearTimeout(this.timeout);
     }
   }]);
 
   return Slider;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__["Plugin"]);
 
 Slider.defaults = {
   /**
@@ -801,6 +855,7 @@ Slider.defaults = {
    * @default 0
    */
   start: 0,
+
   /**
    * Maximum value for the slider scale.
    * @option
@@ -808,6 +863,7 @@ Slider.defaults = {
    * @default 100
    */
   end: 100,
+
   /**
    * Minimum value change per change event.
    * @option
@@ -815,6 +871,7 @@ Slider.defaults = {
    * @default 1
    */
   step: 1,
+
   /**
    * Value at which the handle/input *(left handle/first input)* should be set to on initialization.
    * @option
@@ -822,6 +879,7 @@ Slider.defaults = {
    * @default 0
    */
   initialStart: 0,
+
   /**
    * Value at which the right handle/second input should be set to on initialization.
    * @option
@@ -829,6 +887,7 @@ Slider.defaults = {
    * @default 100
    */
   initialEnd: 100,
+
   /**
    * Allows the input to be located outside the container and visible. Set to by the JS
    * @option
@@ -836,6 +895,7 @@ Slider.defaults = {
    * @default false
    */
   binding: false,
+
   /**
    * Allows the user to click/tap on the slider bar to select a value.
    * @option
@@ -843,6 +903,7 @@ Slider.defaults = {
    * @default true
    */
   clickSelect: true,
+
   /**
    * Set to true and use the `vertical` class to change alignment to vertical.
    * @option
@@ -850,6 +911,7 @@ Slider.defaults = {
    * @default false
    */
   vertical: false,
+
   /**
    * Allows the user to drag the slider handle(s) to select a value.
    * @option
@@ -857,6 +919,7 @@ Slider.defaults = {
    * @default true
    */
   draggable: true,
+
   /**
    * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.
    * @option
@@ -864,6 +927,7 @@ Slider.defaults = {
    * @default false
    */
   disabled: false,
+
   /**
    * Allows the use of two handles. Double checked by the JS. Changes some logic handling.
    * @option
@@ -871,10 +935,12 @@ Slider.defaults = {
    * @default false
    */
   doubleSided: false,
+
   /**
    * Potential future feature.
    */
   // steps: 100,
+
   /**
    * Number of decimal places the plugin should go to for floating point precision.
    * @option
@@ -882,17 +948,21 @@ Slider.defaults = {
    * @default 2
    */
   decimal: 2,
+
   /**
    * Time delay for dragged elements.
    */
   // dragDelay: 0,
+
   /**
    * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.
    * @option
    * @type {number}
    * @default 200
    */
-  moveTime: 200, //update this if changing the transition time in the sass
+  moveTime: 200,
+  //update this if changing the transition time in the sass
+
   /**
    * Class applied to disabled sliders.
    * @option
@@ -900,6 +970,7 @@ Slider.defaults = {
    * @default 'disabled'
    */
   disabledClass: 'disabled',
+
   /**
    * Will invert the default layout for a vertical<span data-tooltip title="who would do this???"> </span>slider.
    * @option
@@ -907,6 +978,7 @@ Slider.defaults = {
    * @default false
    */
   invertVertical: false,
+
   /**
    * Milliseconds before the `changed.zf-slider` event is triggered after value change.
    * @option
@@ -914,6 +986,7 @@ Slider.defaults = {
    * @default 500
    */
   changedDelay: 500,
+
   /**
   * Basevalue for non-linear sliders
   * @option
@@ -921,6 +994,7 @@ Slider.defaults = {
   * @default 5
   */
   nonLinearBase: 5,
+
   /**
   * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.
   * @option
@@ -933,9 +1007,11 @@ Slider.defaults = {
 function percent(frac, num) {
   return frac / num;
 }
+
 function absPosition($handle, dir, clickPos, param) {
   return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos);
 }
+
 function baseLog(base, value) {
   return Math.log(value) / Math.log(base);
 }
@@ -944,15 +1020,25 @@ function baseLog(base, value) {
 
 /***/ }),
 
-/***/ 7:
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
@@ -960,17 +1046,19 @@ function baseLog(base, value) {
 
 var MutationObserver = function () {
   var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
   for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
     }
   }
+
   return false;
 }();
 
-var triggers = function (el, type) {
+var triggers = function triggers(el, type) {
   el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
   });
 };
 
@@ -981,138 +1069,142 @@ var Triggers = {
   },
   Initializers: {}
 };
-
 Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
   },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
     }
   },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
     }
   },
-  closeableListener: function (e) {
+  closeableListener: function closeableListener(e) {
     e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
     if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
       });
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
     }
   },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
-};
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
 Triggers.Initializers.addOpenListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
   $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
-
-// Elements with [data-close] will close a plugin that supports it when clicked.
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
 // If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
 Triggers.Initializers.addCloseListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
   $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 Triggers.Initializers.addToggleListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
   $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
 Triggers.Initializers.addCloseableListener = function ($elem) {
   $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
   $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
 Triggers.Initializers.addToggleFocusListener = function ($elem) {
   $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
   $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+}; // More Global/complex listeners and triggers
+
 
-// More Global/complex listeners and triggers
 Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
+  resizeListener: function resizeListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a resize event
+    } //trigger all listening elements and signal a resize event
+
+
     $nodes.attr('data-events', "resize");
   },
-  scrollListener: function ($nodes) {
+  scrollListener: function scrollListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a scroll event
+    } //trigger all listening elements and signal a scroll event
+
+
     $nodes.attr('data-events', "scroll");
   },
-  closeMeListener: function (e, pluginId) {
+  closeMeListener: function closeMeListener(e, pluginId) {
     var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
-
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
     plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+
       _this.triggerHandler('close.zf.trigger', [_this]);
     });
-  }
+  } // Global, parses whole document.
+
+};
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
       plugNames = ['dropdown', 'tooltip', 'reveal'];
 
   if (pluginName) {
     if (typeof pluginName === 'string') {
       plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
     } else {
       console.error('Plugin names must be strings');
     }
   }
+
   if (yetiBoxes.length) {
     var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
+      return "closeme.zf.".concat(name);
     }).join(' ');
-
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
   }
 };
 
 function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
+  var timer,
       args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
     if (timer) {
       clearTimeout(timer);
     }
+
     timer = setTimeout(function () {
       listener.apply(null, args);
     }, debounce || 10); //default time to emit scroll event
@@ -1120,14 +1212,16 @@ function debounceGlobalListener(debounce, trigger, listener) {
 }
 
 Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
   }
 };
 
 Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
   }
@@ -1137,25 +1231,27 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
   if (!MutationObserver) {
     return false;
   }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
 
-    //trigger the event handler for the element depending on type
     switch (mutationRecordsList[0].type) {
       case "attributes":
         if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
+
         if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
+
         if (mutationRecordsList[0].attributeName === "style") {
           $target.closest("[data-mutate]").attr("data-events", "mutate");
           $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
         }
+
         break;
 
       case "childList":
@@ -1173,14 +1269,19 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
     //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
     for (var i = 0; i <= $nodes.length - 1; i++) {
       var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
   }
 };
 
 Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addOpenListener($document);
   Triggers.Initializers.addCloseListener($document);
   Triggers.Initializers.addToggleListener($document);
@@ -1189,7 +1290,7 @@ Triggers.Initializers.addSimpleListeners = function () {
 };
 
 Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addMutationEventsListener($document);
   Triggers.Initializers.addResizeListener();
   Triggers.Initializers.addScrollListener();
@@ -1197,25 +1298,17 @@ Triggers.Initializers.addGlobalListeners = function () {
 };
 
 Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
-
-    if (document.readyState === "complete") {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
       Triggers.Initializers.addSimpleListeners();
       Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
-      });
+      $.triggersInitialized = true;
     }
-
-    $.triggersInitialized = true;
-  }
+  });
 
   if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
     Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
   }
 };
@@ -1224,12 +1317,29 @@ Triggers.init = function ($, Foundation) {
 
 /***/ }),
 
-/***/ 94:
+/***/ 15:
+/*!*******************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.slider.js ***!
+  \*******************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(28);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.slider.js */"./js/entries/plugins/foundation.slider.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.slider.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.slider.js.map b/dist/js/plugins/foundation.slider.js.map
new file mode 100644 (file)
index 0000000..8616d33
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.touch\"],\"amd\":\"./foundation.util.touch\",\"commonjs\":\"./foundation.util.touch\",\"commonjs2\":\"./foundation.util.touch\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.slider.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.slider.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Slider","element","options","$element","$","extend","defaults","data","className","Touch","init","Triggers","_init","Keyboard","register","inputs","find","handles","$handle","eq","$input","length","attr","$fill","css","vertical","isDbl","_this","disabled","hasClass","disabledClass","addClass","add","binding","_setInitAttr","doubleSided","$handle2","$input2","setHandles","_events","_setHandlePos","val","value","pctOfBar","percent","start","end","positionValueFunction","_logTransform","_powTransform","toFixed","parseFloat","baseLog","nonLinearBase","Math","pow","$hndl","location","noInvert","cb","index","h2Val","step","h1Val","vert","hOrW","lOrT","handleDim","getBoundingClientRect","elemDim","_pctOfBar","pxToMove","movement","decimal","_setValues","isLeftHndl","dim","handlePct","style","handlePos","isNaN","initialStart","one","trigger","moveTime","Move","clearTimeout","timeout","setTimeout","changedDelay","idx","initVal","initialEnd","id","GetYoDigits","e","hasVal","preventDefault","param","direction","eventOffset","pageY","pageX","halfOfHandle","barDim","windowScroll","window","scrollTop","scrollLeft","elemOffset","offset","clientY","eventFromBar","barXY","offsetPct","_value","Rtl","_adjustValue","firstHndlPos","absPosition","secndHndlPos","div","left","prev_val","next_val","_eventsForHandle","curHandle","timer","handleChangeEvent","_handleEvent","off","on","keyCode","call","clickSelect","target","is","draggable","addTouch","$body","currentTarget","removeClass","_$handle","oldValue","newValue","handleKey","decrease","increase","decrease_fast","increase_fast","min","max","handled","Plugin","invertVertical","frac","num","dir","clickPos","abs","position","base","log","MutationObserver","prefixes","i","triggers","el","type","split","forEach","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","Motion","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","scrollListener","closeMeListener","pluginId","namespace","plugins","not","addClosemeListener","pluginName","yetiBoxes","plugNames","push","concat","console","error","listeners","map","name","join","debounceGlobalListener","debounce","listener","args","Array","prototype","slice","arguments","apply","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","$target","attributeName","pageYOffset","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","document","addGlobalListeners","onLoad","triggersInitialized","IHearYou"],"mappings":"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","file":"foundation.slider.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"./foundation.util.motion\", \"./foundation.util.touch\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.slider\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.slider\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 15);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;","import { Foundation } from './foundation.core';\n\nimport { Slider } from '../../foundation.slider';\nFoundation.plugin(Slider, 'Slider');\n\nexport { Foundation, Slider };\n","'use strict';\n\nimport $ from 'jquery';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { Move } from './foundation.util.motion';\nimport { GetYoDigits, rtl as Rtl } from './foundation.core.utils';\n\nimport { Plugin } from './foundation.core.plugin';\n\nimport { Touch } from './foundation.util.touch';\n\nimport { Triggers } from './foundation.util.triggers';\n/**\n * Slider module.\n * @module foundation.slider\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n */\n\nclass Slider extends Plugin {\n  /**\n   * Creates a new instance of a slider control.\n   * @class\n   * @name Slider\n   * @param {jQuery} element - jQuery object to make into a slider control.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Slider.defaults, this.$element.data(), options);\n    this.className = 'Slider'; // ie9 back compat\n\n  // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.\n    Touch.init($);\n    Triggers.init($);\n\n    this._init();\n\n    Keyboard.register('Slider', {\n      'ltr': {\n        'ARROW_RIGHT': 'increase',\n        'ARROW_UP': 'increase',\n        'ARROW_DOWN': 'decrease',\n        'ARROW_LEFT': 'decrease',\n        'SHIFT_ARROW_RIGHT': 'increase_fast',\n        'SHIFT_ARROW_UP': 'increase_fast',\n        'SHIFT_ARROW_DOWN': 'decrease_fast',\n        'SHIFT_ARROW_LEFT': 'decrease_fast',\n        'HOME': 'min',\n        'END': 'max'\n      },\n      'rtl': {\n        'ARROW_LEFT': 'increase',\n        'ARROW_RIGHT': 'decrease',\n        'SHIFT_ARROW_LEFT': 'increase_fast',\n        'SHIFT_ARROW_RIGHT': 'decrease_fast'\n      }\n    });\n  }\n\n  /**\n   * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).\n   * @function\n   * @private\n   */\n  _init() {\n    this.inputs = this.$element.find('input');\n    this.handles = this.$element.find('[data-slider-handle]');\n\n    this.$handle = this.handles.eq(0);\n    this.$input = this.inputs.length ? this.inputs.eq(0) : $(`#${this.$handle.attr('aria-controls')}`);\n    this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);\n\n    var isDbl = false,\n        _this = this;\n    if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {\n      this.options.disabled = true;\n      this.$element.addClass(this.options.disabledClass);\n    }\n    if (!this.inputs.length) {\n      this.inputs = $().add(this.$input);\n      this.options.binding = true;\n    }\n\n    this._setInitAttr(0);\n\n    if (this.handles[1]) {\n      this.options.doubleSided = true;\n      this.$handle2 = this.handles.eq(1);\n      this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : $(`#${this.$handle2.attr('aria-controls')}`);\n\n      if (!this.inputs[1]) {\n        this.inputs = this.inputs.add(this.$input2);\n      }\n      isDbl = true;\n\n      // this.$handle.triggerHandler('click.zf.slider');\n      this._setInitAttr(1);\n    }\n\n    // Set handle positions\n    this.setHandles();\n\n    this._events();\n  }\n\n  setHandles() {\n    if(this.handles[1]) {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, () => {\n        this._setHandlePos(this.$handle2, this.inputs.eq(1).val(), true);\n      });\n    } else {\n      this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);\n    }\n  }\n\n  _reflow() {\n    this.setHandles();\n  }\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)\n  */\n  _pctOfBar(value) {\n    var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start)\n\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    }\n\n    return pctOfBar.toFixed(2)\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value\n  */\n  _value(pctOfBar) {\n    switch(this.options.positionValueFunction) {\n    case \"pow\":\n      pctOfBar = this._powTransform(pctOfBar);\n      break;\n    case \"log\":\n      pctOfBar = this._logTransform(pctOfBar);\n      break;\n    }\n    var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);\n\n    return value\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function\n  */\n  _logTransform(value) {\n    return baseLog(this.options.nonLinearBase, ((value*(this.options.nonLinearBase-1))+1))\n  }\n\n  /**\n  * @function\n  * @private\n  * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function\n  */\n  _powTransform(value) {\n    return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1)\n  }\n\n  /**\n   * Sets the position of the selected handle and fill bar.\n   * @function\n   * @private\n   * @param {jQuery} $hndl - the selected handle to move.\n   * @param {Number} location - floating point between the start and end values of the slider bar.\n   * @param {Function} cb - callback function to fire on completion.\n   * @fires Slider#moved\n   * @fires Slider#changed\n   */\n  _setHandlePos($hndl, location, noInvert, cb) {\n    // don't move if the slider has been disabled since its initialization\n    if (this.$element.hasClass(this.options.disabledClass)) {\n      return;\n    }\n    //might need to alter that slightly for bars that will have odd number selections.\n    location = parseFloat(location);//on input change events, convert string to number...grumble.\n\n    // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max\n    if (location < this.options.start) { location = this.options.start; }\n    else if (location > this.options.end) { location = this.options.end; }\n\n    var isDbl = this.options.doubleSided;\n\n    //this is for single-handled vertical sliders, it adjusts the value to account for the slider being \"upside-down\"\n    //for click and drag events, it's weird due to the scale(-1, 1) css property\n    if (this.options.vertical && !noInvert) {\n      location = this.options.end - location;\n    }\n\n    if (isDbl) { //this block is to prevent 2 handles from crossing eachother. Could/should be improved.\n      if (this.handles.index($hndl) === 0) {\n        var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));\n        location = location >= h2Val ? h2Val - this.options.step : location;\n      } else {\n        var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));\n        location = location <= h1Val ? h1Val + this.options.step : location;\n      }\n    }\n\n    var _this = this,\n        vert = this.options.vertical,\n        hOrW = vert ? 'height' : 'width',\n        lOrT = vert ? 'top' : 'left',\n        handleDim = $hndl[0].getBoundingClientRect()[hOrW],\n        elemDim = this.$element[0].getBoundingClientRect()[hOrW],\n        //percentage of bar min/max value based on click or drag point\n        pctOfBar = this._pctOfBar(location),\n        //number of actual pixels to shift the handle, based on the percentage obtained above\n        pxToMove = (elemDim - handleDim) * pctOfBar,\n        //percentage of bar to shift the handle\n        movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal);\n        //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value\n        location = parseFloat(location.toFixed(this.options.decimal));\n        // declare empty object for css adjustments, only used with 2 handled-sliders\n    var css = {};\n\n    this._setValues($hndl, location);\n\n    // TODO update to calculate based on values set to respective inputs??\n    if (isDbl) {\n      var isLeftHndl = this.handles.index($hndl) === 0,\n          //empty variable, will be used for min-height/width for fill bar\n          dim,\n          //percentage w/h of the handle compared to the slider bar\n          handlePct =  ~~(percent(handleDim, elemDim) * 100);\n      //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar\n      if (isLeftHndl) {\n        //left or top percentage value to apply to the fill bar.\n        css[lOrT] = `${movement}%`;\n        //calculate the new min-height/width for the fill bar.\n        dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct;\n        //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider\n        //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.\n        if (cb && typeof cb === 'function') { cb(); }//this is only needed for the initialization of 2 handled sliders\n      } else {\n        //just caching the value of the left/bottom handle's left/top property\n        var handlePos = parseFloat(this.$handle[0].style[lOrT]);\n        //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0\n        //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself\n        dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start)/((this.options.end-this.options.start)/100) : handlePos) + handlePct;\n      }\n      // assign the min-height/width to our css object\n      css[`min-${hOrW}`] = `${dim}%`;\n    }\n\n    this.$element.one('finished.zf.animate', function() {\n                    /**\n                     * Fires when the handle is done moving.\n                     * @event Slider#moved\n                     */\n                    _this.$element.trigger('moved.zf.slider', [$hndl]);\n                });\n\n    //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.\n    var moveTime = this.$element.data('dragging') ? 1000/60 : this.options.moveTime;\n\n    Move(moveTime, $hndl, function() {\n      // adjusting the left/top property of the handle, based on the percentage calculated above\n      // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,\n      // fall back to next best guess.\n      if (isNaN(movement)) {\n        $hndl.css(lOrT, `${pctOfBar * 100}%`);\n      }\n      else {\n        $hndl.css(lOrT, `${movement}%`);\n      }\n\n      if (!_this.options.doubleSided) {\n        //if single-handled, a simple method to expand the fill bar\n        _this.$fill.css(hOrW, `${pctOfBar * 100}%`);\n      } else {\n        //otherwise, use the css object we created above\n        _this.$fill.css(css);\n      }\n    });\n\n\n    /**\n     * Fires when the value has not been change for a given time.\n     * @event Slider#changed\n     */\n    clearTimeout(_this.timeout);\n    _this.timeout = setTimeout(function(){\n      _this.$element.trigger('changed.zf.slider', [$hndl]);\n    }, _this.options.changedDelay);\n  }\n\n  /**\n   * Sets the initial attribute for the slider element.\n   * @function\n   * @private\n   * @param {Number} idx - index of the current handle/input to use.\n   */\n  _setInitAttr(idx) {\n    var initVal = (idx === 0 ? this.options.initialStart : this.options.initialEnd)\n    var id = this.inputs.eq(idx).attr('id') || GetYoDigits(6, 'slider');\n    this.inputs.eq(idx).attr({\n      'id': id,\n      'max': this.options.end,\n      'min': this.options.start,\n      'step': this.options.step\n    });\n    this.inputs.eq(idx).val(initVal);\n    this.handles.eq(idx).attr({\n      'role': 'slider',\n      'aria-controls': id,\n      'aria-valuemax': this.options.end,\n      'aria-valuemin': this.options.start,\n      'aria-valuenow': initVal,\n      'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',\n      'tabindex': 0\n    });\n  }\n\n  /**\n   * Sets the input and `aria-valuenow` values for the slider element.\n   * @function\n   * @private\n   * @param {jQuery} $handle - the currently selected handle.\n   * @param {Number} val - floating point of the new value.\n   */\n  _setValues($handle, val) {\n    var idx = this.options.doubleSided ? this.handles.index($handle) : 0;\n    this.inputs.eq(idx).val(val);\n    $handle.attr('aria-valuenow', val);\n  }\n\n  /**\n   * Handles events on the slider element.\n   * Calculates the new location of the current handle.\n   * If there are two handles and the bar was clicked, it determines which handle to move.\n   * @function\n   * @private\n   * @param {Object} e - the `event` object passed from the listener.\n   * @param {jQuery} $handle - the current handle to calculate for, if selected.\n   * @param {Number} val - floating point number for the new value of the slider.\n   * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.\n   */\n  _handleEvent(e, $handle, val) {\n    var value, hasVal;\n    if (!val) {//click or drag events\n      e.preventDefault();\n      var _this = this,\n          vertical = this.options.vertical,\n          param = vertical ? 'height' : 'width',\n          direction = vertical ? 'top' : 'left',\n          eventOffset = vertical ? e.pageY : e.pageX,\n          halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,\n          barDim = this.$element[0].getBoundingClientRect()[param],\n          windowScroll = vertical ? $(window).scrollTop() : $(window).scrollLeft();\n\n\n      var elemOffset = this.$element.offset()[direction];\n\n      // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...\n      // best way to guess this is simulated is if clientY == pageY\n      if (e.clientY === e.pageY) { eventOffset = eventOffset + windowScroll; }\n      var eventFromBar = eventOffset - elemOffset;\n      var barXY;\n      if (eventFromBar < 0) {\n        barXY = 0;\n      } else if (eventFromBar > barDim) {\n        barXY = barDim;\n      } else {\n        barXY = eventFromBar;\n      }\n      var offsetPct = percent(barXY, barDim);\n\n      value = this._value(offsetPct);\n\n      // turn everything around for RTL, yay math!\n      if (Rtl() && !this.options.vertical) {value = this.options.end - value;}\n\n      value = _this._adjustValue(null, value);\n      //boolean flag for the setHandlePos fn, specifically for vertical sliders\n      hasVal = false;\n\n      if (!$handle) {//figure out which handle it is, pass it to the next function.\n        var firstHndlPos = absPosition(this.$handle, direction, barXY, param),\n            secndHndlPos = absPosition(this.$handle2, direction, barXY, param);\n            $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;\n      }\n\n    } else {//change event on input\n      value = this._adjustValue(null, val);\n      hasVal = true;\n    }\n\n    this._setHandlePos($handle, value, hasVal);\n  }\n\n  /**\n   * Adjustes value for handle in regard to step value. returns adjusted value\n   * @function\n   * @private\n   * @param {jQuery} $handle - the selected handle.\n   * @param {Number} value - value to adjust. used if $handle is falsy\n   */\n  _adjustValue($handle, value) {\n    var val,\n      step = this.options.step,\n      div = parseFloat(step/2),\n      left, prev_val, next_val;\n    if (!!$handle) {\n      val = parseFloat($handle.attr('aria-valuenow'));\n    }\n    else {\n      val = value;\n    }\n    if (val >= 0) {\n      left = val % step;\n    } else {\n      left = step + (val % step);\n    }\n    prev_val = val - left;\n    next_val = prev_val + step;\n    if (left === 0) {\n      return val;\n    }\n    val = val >= prev_val + div ? next_val : prev_val;\n    return val;\n  }\n\n  /**\n   * Adds event listeners to the slider elements.\n   * @function\n   * @private\n   */\n  _events() {\n    this._eventsForHandle(this.$handle);\n    if(this.handles[1]) {\n      this._eventsForHandle(this.$handle2);\n    }\n  }\n\n\n  /**\n   * Adds event listeners a particular handle\n   * @function\n   * @private\n   * @param {jQuery} $handle - the current handle to apply listeners to.\n   */\n  _eventsForHandle($handle) {\n    var _this = this,\n        curHandle,\n        timer;\n\n      const handleChangeEvent = function(e) {\n        const idx = _this.inputs.index($(this));\n        _this._handleEvent(e, _this.handles.eq(idx), $(this).val());\n      };\n\n      // IE only triggers the change event when the input loses focus which strictly follows the HTML specification\n      // listen for the enter key and trigger a change\n      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events\n      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {\n        if(e.keyCode == 13) handleChangeEvent.call(this, e);\n      });\n\n      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);\n\n      if (this.options.clickSelect) {\n        this.$element.off('click.zf.slider').on('click.zf.slider', function(e) {\n          if (_this.$element.data('dragging')) { return false; }\n\n          if (!$(e.target).is('[data-slider-handle]')) {\n            if (_this.options.doubleSided) {\n              _this._handleEvent(e);\n            } else {\n              _this._handleEvent(e, _this.$handle);\n            }\n          }\n        });\n      }\n\n    if (this.options.draggable) {\n      this.handles.addTouch();\n\n      var $body = $('body');\n      $handle\n        .off('mousedown.zf.slider')\n        .on('mousedown.zf.slider', function(e) {\n          $handle.addClass('is-dragging');\n          _this.$fill.addClass('is-dragging');//\n          _this.$element.data('dragging', true);\n\n          curHandle = $(e.currentTarget);\n\n          $body.on('mousemove.zf.slider', function(e) {\n            e.preventDefault();\n            _this._handleEvent(e, curHandle);\n\n          }).on('mouseup.zf.slider', function(e) {\n            _this._handleEvent(e, curHandle);\n\n            $handle.removeClass('is-dragging');\n            _this.$fill.removeClass('is-dragging');\n            _this.$element.data('dragging', false);\n\n            $body.off('mousemove.zf.slider mouseup.zf.slider');\n          });\n      })\n      // prevent events triggered by touch\n      .on('selectstart.zf.slider touchmove.zf.slider', function(e) {\n        e.preventDefault();\n      });\n    }\n\n    $handle.off('keydown.zf.slider').on('keydown.zf.slider', function(e) {\n      var _$handle = $(this),\n          idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,\n          oldValue = parseFloat(_this.inputs.eq(idx).val()),\n          newValue;\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Slider', {\n        decrease: function() {\n          newValue = oldValue - _this.options.step;\n        },\n        increase: function() {\n          newValue = oldValue + _this.options.step;\n        },\n        decrease_fast: function() {\n          newValue = oldValue - _this.options.step * 10;\n        },\n        increase_fast: function() {\n          newValue = oldValue + _this.options.step * 10;\n        },\n        min: function() {\n          newValue = _this.options.start;\n        },\n        max: function() {\n          newValue = _this.options.end;\n        },\n        handled: function() { // only set handle pos when event was handled specially\n          e.preventDefault();\n          _this._setHandlePos(_$handle, newValue, true);\n        }\n      });\n      /*if (newValue) { // if pressed key has special function, update value\n        e.preventDefault();\n        _this._setHandlePos(_$handle, newValue);\n      }*/\n    });\n  }\n\n  /**\n   * Destroys the slider plugin.\n   */\n  _destroy() {\n    this.handles.off('.zf.slider');\n    this.inputs.off('.zf.slider');\n    this.$element.off('.zf.slider');\n\n    clearTimeout(this.timeout);\n  }\n}\n\nSlider.defaults = {\n  /**\n   * Minimum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  start: 0,\n  /**\n   * Maximum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  end: 100,\n  /**\n   * Minimum value change per change event.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  step: 1,\n  /**\n   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  initialStart: 0,\n  /**\n   * Value at which the right handle/second input should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  initialEnd: 100,\n  /**\n   * Allows the input to be located outside the container and visible. Set to by the JS\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  binding: false,\n  /**\n   * Allows the user to click/tap on the slider bar to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickSelect: true,\n  /**\n   * Set to true and use the `vertical` class to change alignment to vertical.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  vertical: false,\n  /**\n   * Allows the user to drag the slider handle(s) to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  draggable: true,\n  /**\n   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disabled: false,\n  /**\n   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  doubleSided: false,\n  /**\n   * Potential future feature.\n   */\n  // steps: 100,\n  /**\n   * Number of decimal places the plugin should go to for floating point precision.\n   * @option\n   * @type {number}\n   * @default 2\n   */\n  decimal: 2,\n  /**\n   * Time delay for dragged elements.\n   */\n  // dragDelay: 0,\n  /**\n   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  moveTime: 200,//update this if changing the transition time in the sass\n  /**\n   * Class applied to disabled sliders.\n   * @option\n   * @type {string}\n   * @default 'disabled'\n   */\n  disabledClass: 'disabled',\n  /**\n   * Will invert the default layout for a vertical<span data-tooltip title=\"who would do this???\"> </span>slider.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  invertVertical: false,\n  /**\n   * Milliseconds before the `changed.zf-slider` event is triggered after value change.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  changedDelay: 500,\n  /**\n  * Basevalue for non-linear sliders\n  * @option\n  * @type {number}\n  * @default 5\n  */\n  nonLinearBase: 5,\n  /**\n  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.\n  * @option\n  * @type {string}\n  * @default 'linear'\n  */\n  positionValueFunction: 'linear',\n};\n\nfunction percent(frac, num) {\n  return (frac / num);\n}\nfunction absPosition($handle, dir, clickPos, param) {\n  return Math.abs(($handle.position()[dir] + ($handle[param]() / 2)) - clickPos);\n}\nfunction baseLog(base, value) {\n  return Math.log(value)/Math.log(base)\n}\n\nexport {Slider};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index fd780905bcf240b200247a7d083d4cbc921f55b9..3ea3d10172a1d4e1723f69365ac6568f9fd6547d 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(n){if(i[n])return i[n].exports;var s=i[n]={i:n,l:!1,exports:{}};return t[n].call(s.exports,s,s.exports,e),s.l=!0,s.exports}var i={};e.m=t,e.c=i,e.i=function(t){return t},e.d=function(t,i,n){e.o(t,i)||Object.defineProperty(t,i,{configurable:!1,enumerable:!0,get:n})},e.n=function(t){var i=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(i,"a",i),i},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=94)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},12:function(t,e){t.exports={Touch:window.Foundation.Touch}},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},28:function(t,e,i){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var n=i(1),s=(i.n(n),i(58));n.Foundation.plugin(s.a,"Slider")},3:function(t,e){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},4:function(t,e){t.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},5:function(t,e){t.exports={Keyboard:window.Foundation.Keyboard}},58:function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function a(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function o(t,e){return t/e}function r(t,e,i,n){return Math.abs(t.position()[e]+t[n]()/2-i)}function l(t,e){return Math.log(e)/Math.log(t)}i.d(e,"a",function(){return z});var d=i(0),u=i.n(d),c=i(5),f=(i.n(c),i(4)),h=(i.n(f),i(3)),g=(i.n(h),i(2)),p=(i.n(g),i(12)),v=(i.n(p),i(7)),m=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),z=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return a(e,t),m(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=u.a.extend({},e.defaults,this.$element.data(),i),this.className="Slider",p.Touch.init(u.a),v.a.init(u.a),this._init(),c.Keyboard.register("Slider",{ltr:{ARROW_RIGHT:"increase",ARROW_UP:"increase",ARROW_DOWN:"decrease",ARROW_LEFT:"decrease",SHIFT_ARROW_RIGHT:"increase_fast",SHIFT_ARROW_UP:"increase_fast",SHIFT_ARROW_DOWN:"decrease_fast",SHIFT_ARROW_LEFT:"decrease_fast",HOME:"min",END:"max"},rtl:{ARROW_LEFT:"increase",ARROW_RIGHT:"decrease",SHIFT_ARROW_LEFT:"increase_fast",SHIFT_ARROW_RIGHT:"decrease_fast"}})}},{key:"_init",value:function(){this.inputs=this.$element.find("input"),this.handles=this.$element.find("[data-slider-handle]"),this.$handle=this.handles.eq(0),this.$input=this.inputs.length?this.inputs.eq(0):u()("#"+this.$handle.attr("aria-controls")),this.$fill=this.$element.find("[data-slider-fill]").css(this.options.vertical?"height":"width",0);(this.options.disabled||this.$element.hasClass(this.options.disabledClass))&&(this.options.disabled=!0,this.$element.addClass(this.options.disabledClass)),this.inputs.length||(this.inputs=u()().add(this.$input),this.options.binding=!0),this._setInitAttr(0),this.handles[1]&&(this.options.doubleSided=!0,this.$handle2=this.handles.eq(1),this.$input2=this.inputs.length>1?this.inputs.eq(1):u()("#"+this.$handle2.attr("aria-controls")),this.inputs[1]||(this.inputs=this.inputs.add(this.$input2)),!0,this._setInitAttr(1)),this.setHandles(),this._events()}},{key:"setHandles",value:function(){var t=this;this.handles[1]?this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0,function(){t._setHandlePos(t.$handle2,t.inputs.eq(1).val(),!0)}):this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0)}},{key:"_reflow",value:function(){this.setHandles()}},{key:"_pctOfBar",value:function(t){var e=o(t-this.options.start,this.options.end-this.options.start);switch(this.options.positionValueFunction){case"pow":e=this._logTransform(e);break;case"log":e=this._powTransform(e)}return e.toFixed(2)}},{key:"_value",value:function(t){switch(this.options.positionValueFunction){case"pow":t=this._powTransform(t);break;case"log":t=this._logTransform(t)}return(this.options.end-this.options.start)*t+this.options.start}},{key:"_logTransform",value:function(t){return l(this.options.nonLinearBase,t*(this.options.nonLinearBase-1)+1)}},{key:"_powTransform",value:function(t){return(Math.pow(this.options.nonLinearBase,t)-1)/(this.options.nonLinearBase-1)}},{key:"_setHandlePos",value:function(t,e,n,s){if(!this.$element.hasClass(this.options.disabledClass)){e=parseFloat(e),e<this.options.start?e=this.options.start:e>this.options.end&&(e=this.options.end);var a=this.options.doubleSided;if(this.options.vertical&&!n&&(e=this.options.end-e),a)if(0===this.handles.index(t)){var r=parseFloat(this.$handle2.attr("aria-valuenow"));e=e>=r?r-this.options.step:e}else{var l=parseFloat(this.$handle.attr("aria-valuenow"));e=e<=l?l+this.options.step:e}var d=this,u=this.options.vertical,c=u?"height":"width",h=u?"top":"left",g=t[0].getBoundingClientRect()[c],p=this.$element[0].getBoundingClientRect()[c],v=this._pctOfBar(e),m=(p-g)*v,z=(100*o(m,p)).toFixed(this.options.decimal);e=parseFloat(e.toFixed(this.options.decimal));var b={};if(this._setValues(t,e),a){var _,L=0===this.handles.index(t),w=~~(100*o(g,p));if(L)b[h]=z+"%",_=parseFloat(this.$handle2[0].style[h])-z+w,s&&"function"==typeof s&&s();else{var y=parseFloat(this.$handle[0].style[h]);_=z-(isNaN(y)?(this.options.initialStart-this.options.start)/((this.options.end-this.options.start)/100):y)+w}b["min-"+c]=_+"%"}this.$element.one("finished.zf.animate",function(){d.$element.trigger("moved.zf.slider",[t])});var $=this.$element.data("dragging")?1e3/60:this.options.moveTime;i.i(f.Move)($,t,function(){isNaN(z)?t.css(h,100*v+"%"):t.css(h,z+"%"),d.options.doubleSided?d.$fill.css(b):d.$fill.css(c,100*v+"%")}),clearTimeout(d.timeout),d.timeout=setTimeout(function(){d.$element.trigger("changed.zf.slider",[t])},d.options.changedDelay)}}},{key:"_setInitAttr",value:function(t){var e=0===t?this.options.initialStart:this.options.initialEnd,n=this.inputs.eq(t).attr("id")||i.i(h.GetYoDigits)(6,"slider");this.inputs.eq(t).attr({id:n,max:this.options.end,min:this.options.start,step:this.options.step}),this.inputs.eq(t).val(e),this.handles.eq(t).attr({role:"slider","aria-controls":n,"aria-valuemax":this.options.end,"aria-valuemin":this.options.start,"aria-valuenow":e,"aria-orientation":this.options.vertical?"vertical":"horizontal",tabindex:0})}},{key:"_setValues",value:function(t,e){var i=this.options.doubleSided?this.handles.index(t):0;this.inputs.eq(i).val(e),t.attr("aria-valuenow",e)}},{key:"_handleEvent",value:function(t,e,n){var s,a;if(n)s=this._adjustValue(null,n),a=!0;else{t.preventDefault();var l=this,d=this.options.vertical,c=d?"height":"width",f=d?"top":"left",g=d?t.pageY:t.pageX,p=(this.$handle[0].getBoundingClientRect()[c],this.$element[0].getBoundingClientRect()[c]),v=d?u()(window).scrollTop():u()(window).scrollLeft(),m=this.$element.offset()[f];t.clientY===t.pageY&&(g+=v);var z,b=g-m;z=b<0?0:b>p?p:b;var _=o(z,p);if(s=this._value(_),i.i(h.rtl)()&&!this.options.vertical&&(s=this.options.end-s),s=l._adjustValue(null,s),a=!1,!e){e=r(this.$handle,f,z,c)<=r(this.$handle2,f,z,c)?this.$handle:this.$handle2}}this._setHandlePos(e,s,a)}},{key:"_adjustValue",value:function(t,e){var i,n,s,a,o=this.options.step,r=parseFloat(o/2);return i=t?parseFloat(t.attr("aria-valuenow")):e,n=i%o,s=i-n,a=s+o,0===n?i:i=i>=s+r?a:s}},{key:"_events",value:function(){this._eventsForHandle(this.$handle),this.handles[1]&&this._eventsForHandle(this.$handle2)}},{key:"_eventsForHandle",value:function(t){var e,i=this;if(this.inputs.off("change.zf.slider").on("change.zf.slider",function(t){var e=i.inputs.index(u()(this));i._handleEvent(t,i.handles.eq(e),u()(this).val())}),this.options.clickSelect&&this.$element.off("click.zf.slider").on("click.zf.slider",function(t){if(i.$element.data("dragging"))return!1;u()(t.target).is("[data-slider-handle]")||(i.options.doubleSided?i._handleEvent(t):i._handleEvent(t,i.$handle))}),this.options.draggable){this.handles.addTouch();var n=u()("body");t.off("mousedown.zf.slider").on("mousedown.zf.slider",function(s){t.addClass("is-dragging"),i.$fill.addClass("is-dragging"),i.$element.data("dragging",!0),e=u()(s.currentTarget),n.on("mousemove.zf.slider",function(t){t.preventDefault(),i._handleEvent(t,e)}).on("mouseup.zf.slider",function(s){i._handleEvent(s,e),t.removeClass("is-dragging"),i.$fill.removeClass("is-dragging"),i.$element.data("dragging",!1),n.off("mousemove.zf.slider mouseup.zf.slider")})}).on("selectstart.zf.slider touchmove.zf.slider",function(t){t.preventDefault()})}t.off("keydown.zf.slider").on("keydown.zf.slider",function(t){var e,n=u()(this),s=i.options.doubleSided?i.handles.index(n):0,a=parseFloat(i.inputs.eq(s).val());c.Keyboard.handleKey(t,"Slider",{decrease:function(){e=a-i.options.step},increase:function(){e=a+i.options.step},decrease_fast:function(){e=a-10*i.options.step},increase_fast:function(){e=a+10*i.options.step},min:function(){e=i.options.start},max:function(){e=i.options.end},handled:function(){t.preventDefault(),i._setHandlePos(n,e,!0)}})})}},{key:"_destroy",value:function(){this.handles.off(".zf.slider"),this.inputs.off(".zf.slider"),this.$element.off(".zf.slider"),clearTimeout(this.timeout)}}]),e}(g.Plugin);z.defaults={start:0,end:100,step:1,initialStart:0,initialEnd:100,binding:!1,clickSelect:!0,vertical:!1,draggable:!0,disabled:!1,doubleSided:!1,decimal:2,moveTime:200,disabledClass:"disabled",invertVertical:!1,changedDelay:500,nonLinearBase:5,positionValueFunction:"linear"}},7:function(t,e,i){"use strict";function n(t,e,i){var n=void 0,s=Array.prototype.slice.call(arguments,3);a()(window).off(e).on(e,function(e){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,s)},t||10)})}i.d(e,"a",function(){return d});var s=i(0),a=i.n(s),o=i(4),r=(i.n(o),function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if(t[e]+"MutationObserver"in window)return window[t[e]+"MutationObserver"];return!1}()),l=function(t,e){t.data(e).split(" ").forEach(function(i){a()("#"+i)["close"===e?"trigger":"triggerHandler"](e+".zf.trigger",[t])})},d={Listeners:{Basic:{},Global:{}},Initializers:{}};d.Listeners.Basic={openListener:function(){l(a()(this),"open")},closeListener:function(){a()(this).data("close")?l(a()(this),"close"):a()(this).trigger("close.zf.trigger")},toggleListener:function(){a()(this).data("toggle")?l(a()(this),"toggle"):a()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=a()(this).data("closable");""!==e?o.Motion.animateOut(a()(this),e,function(){a()(this).trigger("closed.zf")}):a()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=a()(this).data("toggle-focus");a()("#"+t).triggerHandler("toggle.zf.trigger",[a()(this)])}},d.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",d.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",d.Listeners.Basic.openListener)},d.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",d.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",d.Listeners.Basic.closeListener)},d.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",d.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",d.Listeners.Basic.toggleListener)},d.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",d.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",d.Listeners.Basic.closeableListener)},d.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",d.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",d.Listeners.Basic.toggleFocusListener)},d.Listeners.Global={resizeListener:function(t){r||t.each(function(){a()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){r||t.each(function(){a()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];a()("[data-"+i+"]").not('[data-yeti-box="'+e+'"]').each(function(){var t=a()(this);t.triggerHandler("close.zf.trigger",[t])})}},d.Initializers.addClosemeListener=function(t){var e=a()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"==typeof t&&"string"==typeof t[0]?i.concat(t):console.error("Plugin names must be strings")),e.length){var n=i.map(function(t){return"closeme.zf."+t}).join(" ");a()(window).off(n).on(n,d.Listeners.Global.closeMeListener)}},d.Initializers.addResizeListener=function(t){var e=a()("[data-resize]");e.length&&n(t,"resize.zf.trigger",d.Listeners.Global.resizeListener,e)},d.Initializers.addScrollListener=function(t){var e=a()("[data-scroll]");e.length&&n(t,"scroll.zf.trigger",d.Listeners.Global.scrollListener,e)},d.Initializers.addMutationEventsListener=function(t){if(!r)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=a()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var n=0;n<=e.length-1;n++){var s=new r(i);s.observe(e[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},d.Initializers.addSimpleListeners=function(){var t=a()(document);d.Initializers.addOpenListener(t),d.Initializers.addCloseListener(t),d.Initializers.addToggleListener(t),d.Initializers.addCloseableListener(t),d.Initializers.addToggleFocusListener(t)},d.Initializers.addGlobalListeners=function(){var t=a()(document);d.Initializers.addMutationEventsListener(t),d.Initializers.addResizeListener(),d.Initializers.addScrollListener(),d.Initializers.addClosemeListener()},d.init=function(t,e){if(void 0===t.triggersInitialized){t(document);"complete"===document.readyState?(d.Initializers.addSimpleListeners(),d.Initializers.addGlobalListeners()):t(window).on("load",function(){d.Initializers.addSimpleListeners(),d.Initializers.addGlobalListeners()}),t.triggersInitialized=!0}e&&(e.Triggers=d,e.IHearYou=d.Initializers.addGlobalListeners)}},94:function(t,e,i){t.exports=i(28)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("./foundation.util.keyboard"),require("./foundation.util.motion"),require("./foundation.util.touch"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.keyboard","./foundation.util.motion","./foundation.util.touch","jquery"],e):"object"==typeof exports?exports["foundation.slider"]=e(require("./foundation.core"),require("./foundation.util.keyboard"),require("./foundation.util.motion"),require("./foundation.util.touch"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.slider"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],t.__FOUNDATION_EXTERNAL__["foundation.util.motion"],t.__FOUNDATION_EXTERNAL__["foundation.util.touch"],t.jQuery))}(window,function(i,n,s,o,r){return function(i){var n={};function s(t){if(n[t])return n[t].exports;var e=n[t]={i:t,l:!1,exports:{}};return i[t].call(e.exports,e,e.exports,s),e.l=!0,e.exports}return s.m=i,s.c=n,s.d=function(t,e,i){s.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:i})},s.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},s.t=function(e,t){if(1&t&&(e=s(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var i=Object.create(null);if(s.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)s.d(i,n,function(t){return e[t]}.bind(null,n));return i},s.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return s.d(e,"a",e),e},s.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},s.p="",s(s.s=15)}({"./foundation.core":function(t,e){t.exports=i},"./foundation.util.keyboard":function(t,e){t.exports=n},"./foundation.util.motion":function(t,e){t.exports=s},"./foundation.util.touch":function(t,e){t.exports=o},"./js/entries/plugins/foundation.slider.js":function(t,e,i){"use strict";i.r(e);var n=i("./foundation.core");i.d(e,"Foundation",function(){return n.Foundation});var s=i("./js/foundation.slider.js");i.d(e,"Slider",function(){return s.Slider}),n.Foundation.plugin(s.Slider,"Slider")},"./js/foundation.slider.js":function(t,e,i){"use strict";i.r(e),i.d(e,"Slider",function(){return f});var n=i("jquery"),g=i.n(n),r=i("./foundation.util.keyboard"),z=i("./foundation.util.motion"),v=i("./foundation.core"),o=i("./foundation.util.touch"),a=i("./js/foundation.util.triggers.js");function s(t){return(s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function l(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}function u(t,e){return!e||"object"!==s(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function c(t,e){return(c=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var f=function(t){function i(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),u(this,d(i).apply(this,arguments))}var e,n,s;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&c(t,e)}(i,v["Plugin"]),e=i,(n=[{key:"_setup",value:function(t,e){this.$element=t,this.options=g.a.extend({},i.defaults,this.$element.data(),e),this.className="Slider",o.Touch.init(g.a),a.Triggers.init(g.a),this._init(),r.Keyboard.register("Slider",{ltr:{ARROW_RIGHT:"increase",ARROW_UP:"increase",ARROW_DOWN:"decrease",ARROW_LEFT:"decrease",SHIFT_ARROW_RIGHT:"increase_fast",SHIFT_ARROW_UP:"increase_fast",SHIFT_ARROW_DOWN:"decrease_fast",SHIFT_ARROW_LEFT:"decrease_fast",HOME:"min",END:"max"},rtl:{ARROW_LEFT:"increase",ARROW_RIGHT:"decrease",SHIFT_ARROW_LEFT:"increase_fast",SHIFT_ARROW_RIGHT:"decrease_fast"}})}},{key:"_init",value:function(){this.inputs=this.$element.find("input"),this.handles=this.$element.find("[data-slider-handle]"),this.$handle=this.handles.eq(0),this.$input=this.inputs.length?this.inputs.eq(0):g()("#".concat(this.$handle.attr("aria-controls"))),this.$fill=this.$element.find("[data-slider-fill]").css(this.options.vertical?"height":"width",0);(this.options.disabled||this.$element.hasClass(this.options.disabledClass))&&(this.options.disabled=!0,this.$element.addClass(this.options.disabledClass)),this.inputs.length||(this.inputs=g()().add(this.$input),this.options.binding=!0),this._setInitAttr(0),this.handles[1]&&(this.options.doubleSided=!0,this.$handle2=this.handles.eq(1),this.$input2=1<this.inputs.length?this.inputs.eq(1):g()("#".concat(this.$handle2.attr("aria-controls"))),this.inputs[1]||(this.inputs=this.inputs.add(this.$input2)),!0,this._setInitAttr(1)),this.setHandles(),this._events()}},{key:"setHandles",value:function(){var t=this;this.handles[1]?this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0,function(){t._setHandlePos(t.$handle2,t.inputs.eq(1).val(),!0)}):this._setHandlePos(this.$handle,this.inputs.eq(0).val(),!0)}},{key:"_reflow",value:function(){this.setHandles()}},{key:"_pctOfBar",value:function(t){var e=L(t-this.options.start,this.options.end-this.options.start);switch(this.options.positionValueFunction){case"pow":e=this._logTransform(e);break;case"log":e=this._powTransform(e)}return e.toFixed(2)}},{key:"_value",value:function(t){switch(this.options.positionValueFunction){case"pow":t=this._powTransform(t);break;case"log":t=this._logTransform(t)}return(this.options.end-this.options.start)*t+parseFloat(this.options.start)}},{key:"_logTransform",value:function(t){return e=this.options.nonLinearBase,i=t*(this.options.nonLinearBase-1)+1,Math.log(i)/Math.log(e);var e,i}},{key:"_powTransform",value:function(t){return(Math.pow(this.options.nonLinearBase,t)-1)/(this.options.nonLinearBase-1)}},{key:"_setHandlePos",value:function(t,e,i,n){if(!this.$element.hasClass(this.options.disabledClass)){(e=parseFloat(e))<this.options.start?e=this.options.start:e>this.options.end&&(e=this.options.end);var s=this.options.doubleSided;if(this.options.vertical&&!i&&(e=this.options.end-e),s)if(0===this.handles.index(t)){var o=parseFloat(this.$handle2.attr("aria-valuenow"));e=o<=e?o-this.options.step:e}else{var r=parseFloat(this.$handle.attr("aria-valuenow"));e=e<=r?r+this.options.step:e}var a=this,l=this.options.vertical,u=l?"height":"width",d=l?"top":"left",c=t[0].getBoundingClientRect()[u],f=this.$element[0].getBoundingClientRect()[u],h=this._pctOfBar(e),p=(100*L((f-c)*h,f)).toFixed(this.options.decimal);e=parseFloat(e.toFixed(this.options.decimal));var g={};if(this._setValues(t,e),s){var v,m=0===this.handles.index(t),b=~~(100*L(c,f));if(m)g[d]="".concat(p,"%"),v=parseFloat(this.$handle2[0].style[d])-p+b,n&&"function"==typeof n&&n();else{var _=parseFloat(this.$handle[0].style[d]);v=p-(isNaN(_)?(this.options.initialStart-this.options.start)/((this.options.end-this.options.start)/100):_)+b}g["min-".concat(u)]="".concat(v,"%")}this.$element.one("finished.zf.animate",function(){a.$element.trigger("moved.zf.slider",[t])});var y=this.$element.data("dragging")?1e3/60:this.options.moveTime;Object(z.Move)(y,t,function(){isNaN(p)?t.css(d,"".concat(100*h,"%")):t.css(d,"".concat(p,"%")),a.options.doubleSided?a.$fill.css(g):a.$fill.css(u,"".concat(100*h,"%"))}),clearTimeout(a.timeout),a.timeout=setTimeout(function(){a.$element.trigger("changed.zf.slider",[t])},a.options.changedDelay)}}},{key:"_setInitAttr",value:function(t){var e=0===t?this.options.initialStart:this.options.initialEnd,i=this.inputs.eq(t).attr("id")||Object(v.GetYoDigits)(6,"slider");this.inputs.eq(t).attr({id:i,max:this.options.end,min:this.options.start,step:this.options.step}),this.inputs.eq(t).val(e),this.handles.eq(t).attr({role:"slider","aria-controls":i,"aria-valuemax":this.options.end,"aria-valuemin":this.options.start,"aria-valuenow":e,"aria-orientation":this.options.vertical?"vertical":"horizontal",tabindex:0})}},{key:"_setValues",value:function(t,e){var i=this.options.doubleSided?this.handles.index(t):0;this.inputs.eq(i).val(e),t.attr("aria-valuenow",e)}},{key:"_handleEvent",value:function(t,e,i){var n,s;if(i)n=this._adjustValue(null,i),s=!0;else{t.preventDefault();var o=this.options.vertical,r=o?"height":"width",a=o?"top":"left",l=o?t.pageY:t.pageX,u=(this.$handle[0].getBoundingClientRect()[r],this.$element[0].getBoundingClientRect()[r]),d=o?g()(window).scrollTop():g()(window).scrollLeft(),c=this.$element.offset()[a];t.clientY===t.pageY&&(l+=d);var f,h=l-c,p=L(f=h<0?0:u<h?u:h,u);if(n=this._value(p),Object(v.rtl)()&&!this.options.vertical&&(n=this.options.end-n),n=this._adjustValue(null,n),s=!1,!e)e=m(this.$handle,a,f,r)<=m(this.$handle2,a,f,r)?this.$handle:this.$handle2}this._setHandlePos(e,n,s)}},{key:"_adjustValue",value:function(t,e){var i,n,s,o=this.options.step,r=parseFloat(o/2);return 0===(n=0<=(i=t?parseFloat(t.attr("aria-valuenow")):e)?i%o:o+i%o)?i:i=(s=i-n)+r<=i?s+o:s}},{key:"_events",value:function(){this._eventsForHandle(this.$handle),this.handles[1]&&this._eventsForHandle(this.$handle2)}},{key:"_eventsForHandle",value:function(e){var i,o=this,n=function(t){var e=o.inputs.index(g()(this));o._handleEvent(t,o.handles.eq(e),g()(this).val())};if(this.inputs.off("keyup.zf.slider").on("keyup.zf.slider",function(t){13==t.keyCode&&n.call(this,t)}),this.inputs.off("change.zf.slider").on("change.zf.slider",n),this.options.clickSelect&&this.$element.off("click.zf.slider").on("click.zf.slider",function(t){if(o.$element.data("dragging"))return!1;g()(t.target).is("[data-slider-handle]")||(o.options.doubleSided?o._handleEvent(t):o._handleEvent(t,o.$handle))}),this.options.draggable){this.handles.addTouch();var s=g()("body");e.off("mousedown.zf.slider").on("mousedown.zf.slider",function(t){e.addClass("is-dragging"),o.$fill.addClass("is-dragging"),o.$element.data("dragging",!0),i=g()(t.currentTarget),s.on("mousemove.zf.slider",function(t){t.preventDefault(),o._handleEvent(t,i)}).on("mouseup.zf.slider",function(t){o._handleEvent(t,i),e.removeClass("is-dragging"),o.$fill.removeClass("is-dragging"),o.$element.data("dragging",!1),s.off("mousemove.zf.slider mouseup.zf.slider")})}).on("selectstart.zf.slider touchmove.zf.slider",function(t){t.preventDefault()})}e.off("keydown.zf.slider").on("keydown.zf.slider",function(t){var e,i=g()(this),n=o.options.doubleSided?o.handles.index(i):0,s=parseFloat(o.inputs.eq(n).val());r.Keyboard.handleKey(t,"Slider",{decrease:function(){e=s-o.options.step},increase:function(){e=s+o.options.step},decrease_fast:function(){e=s-10*o.options.step},increase_fast:function(){e=s+10*o.options.step},min:function(){e=o.options.start},max:function(){e=o.options.end},handled:function(){t.preventDefault(),o._setHandlePos(i,e,!0)}})})}},{key:"_destroy",value:function(){this.handles.off(".zf.slider"),this.inputs.off(".zf.slider"),this.$element.off(".zf.slider"),clearTimeout(this.timeout)}}])&&l(e.prototype,n),s&&l(e,s),i}();function L(t,e){return t/e}function m(t,e,i,n){return Math.abs(t.position()[e]+t[n]()/2-i)}f.defaults={start:0,end:100,step:1,initialStart:0,initialEnd:100,binding:!1,clickSelect:!0,vertical:!1,draggable:!0,disabled:!1,doubleSided:!1,decimal:2,moveTime:200,disabledClass:"disabled",invertVertical:!1,changedDelay:500,nonLinearBase:5,positionValueFunction:"linear"}},"./js/foundation.util.triggers.js":function(t,e,i){"use strict";i.r(e),i.d(e,"Triggers",function(){return d});var n=i("jquery"),o=i.n(n),s=i("./foundation.core"),r=i("./foundation.util.motion");function a(t){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var l=function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if("".concat(t[e],"MutationObserver")in window)return window["".concat(t[e],"MutationObserver")];return!1}(),u=function(e,i){e.data(i).split(" ").forEach(function(t){o()("#".concat(t))["close"===i?"trigger":"triggerHandler"]("".concat(i,".zf.trigger"),[e])})},d={Listeners:{Basic:{},Global:{}},Initializers:{}};function c(e,t,i){var n,s=Array.prototype.slice.call(arguments,3);o()(window).off(t).on(t,function(t){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,s)},e||10)})}d.Listeners.Basic={openListener:function(){u(o()(this),"open")},closeListener:function(){o()(this).data("close")?u(o()(this),"close"):o()(this).trigger("close.zf.trigger")},toggleListener:function(){o()(this).data("toggle")?u(o()(this),"toggle"):o()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=o()(this).data("closable");""!==e?r.Motion.animateOut(o()(this),e,function(){o()(this).trigger("closed.zf")}):o()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=o()(this).data("toggle-focus");o()("#".concat(t)).triggerHandler("toggle.zf.trigger",[o()(this)])}},d.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",d.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",d.Listeners.Basic.openListener)},d.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",d.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",d.Listeners.Basic.closeListener)},d.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",d.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",d.Listeners.Basic.toggleListener)},d.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",d.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",d.Listeners.Basic.closeableListener)},d.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",d.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",d.Listeners.Basic.toggleFocusListener)},d.Listeners.Global={resizeListener:function(t){l||t.each(function(){o()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){l||t.each(function(){o()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];o()("[data-".concat(i,"]")).not('[data-yeti-box="'.concat(e,'"]')).each(function(){var t=o()(this);t.triggerHandler("close.zf.trigger",[t])})}},d.Initializers.addClosemeListener=function(t){var e=o()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"===a(t)&&"string"==typeof t[0]?i=i.concat(t):console.error("Plugin names must be strings")),e.length){var n=i.map(function(t){return"closeme.zf.".concat(t)}).join(" ");o()(window).off(n).on(n,d.Listeners.Global.closeMeListener)}},d.Initializers.addResizeListener=function(t){var e=o()("[data-resize]");e.length&&c(t,"resize.zf.trigger",d.Listeners.Global.resizeListener,e)},d.Initializers.addScrollListener=function(t){var e=o()("[data-scroll]");e.length&&c(t,"scroll.zf.trigger",d.Listeners.Global.scrollListener,e)},d.Initializers.addMutationEventsListener=function(t){if(!l)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=o()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var n=0;n<=e.length-1;n++){new l(i).observe(e[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},d.Initializers.addSimpleListeners=function(){var t=o()(document);d.Initializers.addOpenListener(t),d.Initializers.addCloseListener(t),d.Initializers.addToggleListener(t),d.Initializers.addCloseableListener(t),d.Initializers.addToggleFocusListener(t)},d.Initializers.addGlobalListeners=function(){var t=o()(document);d.Initializers.addMutationEventsListener(t),d.Initializers.addResizeListener(),d.Initializers.addScrollListener(),d.Initializers.addClosemeListener()},d.init=function(t,e){Object(s.onLoad)(t(window),function(){!0!==t.triggersInitialized&&(d.Initializers.addSimpleListeners(),d.Initializers.addGlobalListeners(),t.triggersInitialized=!0)}),e&&(e.Triggers=d,e.IHearYou=d.Initializers.addGlobalListeners)}},15:function(t,e,i){t.exports=i("./js/entries/plugins/foundation.slider.js")},jquery:function(t,e){t.exports=r}})});
+//# sourceMappingURL=foundation.slider.min.js.map
diff --git a/dist/js/plugins/foundation.slider.min.js.map b/dist/js/plugins/foundation.slider.min.js.map
new file mode 100644 (file)
index 0000000..604a1a8
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.slider.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE__foundation_util_touch__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.keyboard","./foundation.util.motion","./foundation.util.touch","./js/entries/plugins/foundation.slider.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_slider__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.slider.js","Slider","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__","_foundation_util_touch__WEBPACK_IMPORTED_MODULE_4__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","init","_init","register","ltr","ARROW_RIGHT","ARROW_UP","ARROW_DOWN","ARROW_LEFT","SHIFT_ARROW_RIGHT","SHIFT_ARROW_UP","SHIFT_ARROW_DOWN","SHIFT_ARROW_LEFT","HOME","END","rtl","inputs","find","handles","$handle","eq","$input","concat","attr","$fill","css","vertical","disabled","hasClass","disabledClass","addClass","add","binding","_setInitAttr","doubleSided","$handle2","$input2","setHandles","_events","_this2","_setHandlePos","val","pctOfBar","percent","start","end","positionValueFunction","_logTransform","_powTransform","toFixed","parseFloat","base","nonLinearBase","Math","log","pow","$hndl","location","noInvert","cb","isDbl","index","h2Val","step","h1Val","_this","vert","hOrW","lOrT","handleDim","getBoundingClientRect","elemDim","_pctOfBar","movement","decimal","_setValues","dim","isLeftHndl","handlePct","style","handlePos","isNaN","initialStart","one","trigger","moveTime","clearTimeout","timeout","setTimeout","changedDelay","idx","initVal","initialEnd","id","max","min","role","aria-controls","aria-valuemax","aria-valuemin","aria-valuenow","aria-orientation","tabindex","e","hasVal","_adjustValue","preventDefault","param","direction","eventOffset","pageY","pageX","barDim","windowScroll","scrollTop","scrollLeft","elemOffset","offset","clientY","barXY","eventFromBar","offsetPct","_value","absPosition","left","prev_val","div","_eventsForHandle","curHandle","handleChangeEvent","_handleEvent","off","on","keyCode","clickSelect","is","draggable","addTouch","$body","currentTarget","removeClass","newValue","_$handle","oldValue","handleKey","decrease","increase","decrease_fast","increase_fast","handled","frac","num","dir","clickPos","abs","position","invertVertical","./js/foundation.util.triggers.js","Triggers","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","MutationObserver","prefixes","triggers","el","type","split","forEach","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","listener","timer","args","Array","slice","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","scrollListener","closeMeListener","pluginId","namespace","not","addClosemeListener","pluginName","yetiBoxes","plugNames","push","console","error","listeners","map","join","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","$target","attributeName","pageYOffset","closest","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","document","addGlobalListeners","$","Foundation","triggersInitialized","IHearYou","15","jquery"],"mappings":"CAAA,SAA2CA,EAAMC,GAC1B,iBAAZC,SAA0C,iBAAXC,OACxCA,OAAOD,QAAUD,EAAQG,QAAQ,qBAAsBA,QAAQ,8BAA+BA,QAAQ,4BAA6BA,QAAQ,2BAA4BA,QAAQ,WACtJ,mBAAXC,QAAyBA,OAAOC,IAC9CD,OAAO,CAAC,oBAAqB,6BAA8B,2BAA4B,0BAA2B,UAAWJ,GACnG,iBAAZC,QACdA,QAAQ,qBAAuBD,EAAQG,QAAQ,qBAAsBA,QAAQ,8BAA+BA,QAAQ,4BAA6BA,QAAQ,2BAA4BA,QAAQ,YAE7LJ,EAA8B,wBAAIA,EAA8B,yBAAK,GAAIA,EAA8B,wBAAE,qBAAuBC,EAAQD,EAA8B,wBAAE,mBAAoBA,EAA8B,wBAAE,4BAA6BA,EAA8B,wBAAE,0BAA2BA,EAA8B,wBAAE,yBAA0BA,EAAa,SAR7X,CASGO,OAAQ,SAASC,EAA8CC,EAAuDC,EAAqDC,EAAoDC,GAClO,OAAgB,SAAUC,GAEhB,IAAIC,EAAmB,GAGvB,SAASC,EAAoBC,GAG5B,GAAGF,EAAiBE,GACnB,OAAOF,EAAiBE,GAAUd,QAGnC,IAAIC,EAASW,EAAiBE,GAAY,CACzCC,EAAGD,EACHE,GAAG,EACHhB,QAAS,IAUV,OANAW,EAAQG,GAAUG,KAAKhB,EAAOD,QAASC,EAAQA,EAAOD,QAASa,GAG/DZ,EAAOe,GAAI,EAGJf,EAAOD,QA0Df,OArDAa,EAAoBK,EAAIP,EAGxBE,EAAoBM,EAAIP,EAGxBC,EAAoBO,EAAI,SAASpB,EAASqB,EAAMC,GAC3CT,EAAoBU,EAAEvB,EAASqB,IAClCG,OAAOC,eAAezB,EAASqB,EAAM,CAAEK,YAAY,EAAMC,IAAKL,KAKhET,EAAoBe,EAAI,SAAS5B,GACX,oBAAX6B,QAA0BA,OAAOC,aAC1CN,OAAOC,eAAezB,EAAS6B,OAAOC,YAAa,CAAEC,MAAO,WAE7DP,OAAOC,eAAezB,EAAS,aAAc,CAAE+B,OAAO,KAQvDlB,EAAoBmB,EAAI,SAASD,EAAOE,GAEvC,GADU,EAAPA,IAAUF,EAAQlB,EAAoBkB,IAC/B,EAAPE,EAAU,OAAOF,EACpB,GAAW,EAAPE,GAA8B,iBAAVF,GAAsBA,GAASA,EAAMG,WAAY,OAAOH,EAChF,IAAII,EAAKX,OAAOY,OAAO,MAGvB,GAFAvB,EAAoBe,EAAEO,GACtBX,OAAOC,eAAeU,EAAI,UAAW,CAAET,YAAY,EAAMK,MAAOA,IACtD,EAAPE,GAA4B,iBAATF,EAAmB,IAAI,IAAIM,KAAON,EAAOlB,EAAoBO,EAAEe,EAAIE,EAAK,SAASA,GAAO,OAAON,EAAMM,IAAQC,KAAK,KAAMD,IAC9I,OAAOF,GAIRtB,EAAoB0B,EAAI,SAAStC,GAChC,IAAIqB,EAASrB,GAAUA,EAAOiC,WAC7B,WAAwB,OAAOjC,EAAgB,SAC/C,WAA8B,OAAOA,GAEtC,OADAY,EAAoBO,EAAEE,EAAQ,IAAKA,GAC5BA,GAIRT,EAAoBU,EAAI,SAASiB,EAAQC,GAAY,OAAOjB,OAAOkB,UAAUC,eAAe1B,KAAKuB,EAAQC,IAGzG5B,EAAoB+B,EAAI,GAIjB/B,EAAoBA,EAAoBgC,EAAI,IAnF7C,CAsFN,CAEJC,oBAKA,SAAU7C,EAAQD,GAExBC,EAAOD,QAAUM,GAIXyC,6BAKA,SAAU9C,EAAQD,GAExBC,EAAOD,QAAUO,GAIXyC,2BAKA,SAAU/C,EAAQD,GAExBC,EAAOD,QAAUQ,GAIXyC,0BAKA,SAAUhD,EAAQD,GAExBC,EAAOD,QAAUS,GAIXyC,4CAKA,SAAUjD,EAAQkD,EAAqBtC,GAE7C,aACAA,EAAoBe,EAAEuB,GACD,IAAIC,EAAgDvC,EAA6C,qBAExFA,EAAoBO,EAAE+B,EAAqB,aAAc,WAAa,OAAOC,EAA0D,aAEhJ,IAAIC,EAAkDxC,EAAmD,6BAChGA,EAAoBO,EAAE+B,EAAqB,SAAU,WAAa,OAAOE,EAAwD,SAI/JD,EAA0D,WAAEE,OAAOD,EAAwD,OAAG,WAKxHE,4BAKA,SAAUtD,EAAQkD,EAAqBtC,GAE7C,aACAA,EAAoBe,EAAEuB,GACStC,EAAoBO,EAAE+B,EAAqB,SAAU,WAAa,OAAOK,IACnF,IAAIC,EAAsC5C,EAAkC,UACxE6C,EAA2D7C,EAAoB0B,EAAEkB,GACjFE,EAAyD9C,EAAsD,8BAE/G+C,EAAuD/C,EAAoD,4BAE3GgD,EAAsDhD,EAAmD,qBAEzGiD,EAAsDjD,EAAmD,2BAEzGkD,EAAyDlD,EAAsD,oCAGxI,SAASmD,EAAQC,GAAwT,OAAtOD,EAArD,mBAAXnC,QAAoD,iBAApBA,OAAOqC,SAAmC,SAAiBD,GAAO,cAAcA,GAA2B,SAAiBA,GAAO,OAAOA,GAAyB,mBAAXpC,QAAyBoC,EAAIE,cAAgBtC,QAAUoC,IAAQpC,OAAOa,UAAY,gBAAkBuB,IAAyBA,GAIxV,SAASG,EAAkBC,EAAQC,GAAS,IAAK,IAAIvD,EAAI,EAAGA,EAAIuD,EAAMC,OAAQxD,IAAK,CAAE,IAAIyD,EAAaF,EAAMvD,GAAIyD,EAAW9C,WAAa8C,EAAW9C,aAAc,EAAO8C,EAAWC,cAAe,EAAU,UAAWD,IAAYA,EAAWE,UAAW,GAAMlD,OAAOC,eAAe4C,EAAQG,EAAWnC,IAAKmC,IAI7S,SAASG,EAA2BC,EAAM3D,GAAQ,OAAIA,GAA2B,WAAlB+C,EAAQ/C,IAAsC,mBAATA,EAEpG,SAAgC2D,GAAQ,QAAa,IAATA,EAA4G,OAAOA,EAAhG,MAAM,IAAIC,eAAe,6DAF0DC,CAAuBF,GAAtC3D,EAInI,SAAS8D,EAAgBxD,GAAwJ,OAAnJwD,EAAkBvD,OAAOwD,eAAiBxD,OAAOyD,eAAiB,SAAyB1D,GAAK,OAAOA,EAAE2D,WAAa1D,OAAOyD,eAAe1D,KAA8BA,GAIxM,SAAS4D,EAAgB5D,EAAGqB,GAA+G,OAA1GuC,EAAkB3D,OAAOwD,gBAAkB,SAAyBzD,EAAGqB,GAAsB,OAAjBrB,EAAE2D,UAAYtC,EAAUrB,IAA6BA,EAAGqB,GAkBrK,IAAIY,EAEJ,SAAU4B,GAGR,SAAS5B,IAGP,OAxCJ,SAAyB6B,EAAUC,GAAe,KAAMD,aAAoBC,GAAgB,MAAM,IAAIC,UAAU,qCAsC5GC,CAAgBC,KAAMjC,GAEfmB,EAA2Bc,KAAMV,EAAgBvB,GAAQkC,MAAMD,KAAME,YApChF,IAAsBL,EAAaM,EAAYC,EA4oB7C,OApoBF,SAAmBC,EAAUC,GAAc,GAA0B,mBAAfA,GAA4C,OAAfA,EAAuB,MAAM,IAAIR,UAAU,sDAAyDO,EAASpD,UAAYlB,OAAOY,OAAO2D,GAAcA,EAAWrD,UAAW,CAAEyB,YAAa,CAAEpC,MAAO+D,EAAUpB,UAAU,EAAMD,cAAc,KAAesB,GAAYZ,EAAgBW,EAAUC,GAuBjXC,CAAUxC,EA8mBVK,EAAoD,WA7oBhCyB,EAuCP9B,GAvCoBoC,EAuCZ,CAAC,CACpBvD,IAAK,SASLN,MAAO,SAAgBkE,EAASC,GAC9BT,KAAKU,SAAWF,EAChBR,KAAKS,QAAUxC,EAA4C0C,EAAEC,OAAO,GAAI7C,EAAO8C,SAAUb,KAAKU,SAASI,OAAQL,GAC/GT,KAAKe,UAAY,SAGjB1C,EAA2D,MAAE2C,KAAK/C,EAA4C0C,GAC9GrC,EAAiE,SAAE0C,KAAK/C,EAA4C0C,GAEpHX,KAAKiB,QAEL/C,EAAiE,SAAEgD,SAAS,SAAU,CACpFC,IAAO,CACLC,YAAe,WACfC,SAAY,WACZC,WAAc,WACdC,WAAc,WACdC,kBAAqB,gBACrBC,eAAkB,gBAClBC,iBAAoB,gBACpBC,iBAAoB,gBACpBC,KAAQ,MACRC,IAAO,OAETC,IAAO,CACLP,WAAc,WACdH,YAAe,WACfO,iBAAoB,gBACpBH,kBAAqB,qBAU1B,CACD5E,IAAK,QACLN,MAAO,WACL0D,KAAK+B,OAAS/B,KAAKU,SAASsB,KAAK,SACjChC,KAAKiC,QAAUjC,KAAKU,SAASsB,KAAK,wBAClChC,KAAKkC,QAAUlC,KAAKiC,QAAQE,GAAG,GAC/BnC,KAAKoC,OAASpC,KAAK+B,OAAOjD,OAASkB,KAAK+B,OAAOI,GAAG,GAAKlE,GAAAA,CAA8C,IAAIoE,OAAOrC,KAAKkC,QAAQI,KAAK,mBAClItC,KAAKuC,MAAQvC,KAAKU,SAASsB,KAAK,sBAAsBQ,IAAIxC,KAAKS,QAAQgC,SAAW,SAAW,QAAS,IAKlGzC,KAAKS,QAAQiC,UAAY1C,KAAKU,SAASiC,SAAS3C,KAAKS,QAAQmC,kBAC/D5C,KAAKS,QAAQiC,UAAW,EACxB1C,KAAKU,SAASmC,SAAS7C,KAAKS,QAAQmC,gBAGjC5C,KAAK+B,OAAOjD,SACfkB,KAAK+B,OAAS9D,GAAAA,GAAgD6E,IAAI9C,KAAKoC,QACvEpC,KAAKS,QAAQsC,SAAU,GAGzB/C,KAAKgD,aAAa,GAEdhD,KAAKiC,QAAQ,KACfjC,KAAKS,QAAQwC,aAAc,EAC3BjD,KAAKkD,SAAWlD,KAAKiC,QAAQE,GAAG,GAChCnC,KAAKmD,QAA+B,EAArBnD,KAAK+B,OAAOjD,OAAakB,KAAK+B,OAAOI,GAAG,GAAKlE,GAAAA,CAA8C,IAAIoE,OAAOrC,KAAKkD,SAASZ,KAAK,mBAEnItC,KAAK+B,OAAO,KACf/B,KAAK+B,OAAS/B,KAAK+B,OAAOe,IAAI9C,KAAKmD,WAG7B,EAERnD,KAAKgD,aAAa,IAIpBhD,KAAKoD,aAELpD,KAAKqD,YAEN,CACDzG,IAAK,aACLN,MAAO,WACL,IAAIgH,EAAStD,KAETA,KAAKiC,QAAQ,GACfjC,KAAKuD,cAAcvD,KAAKkC,QAASlC,KAAK+B,OAAOI,GAAG,GAAGqB,OAAO,EAAM,WAC9DF,EAAOC,cAAcD,EAAOJ,SAAUI,EAAOvB,OAAOI,GAAG,GAAGqB,OAAO,KAGnExD,KAAKuD,cAAcvD,KAAKkC,QAASlC,KAAK+B,OAAOI,GAAG,GAAGqB,OAAO,KAG7D,CACD5G,IAAK,UACLN,MAAO,WACL0D,KAAKoD,eAQN,CACDxG,IAAK,YACLN,MAAO,SAAmBA,GACxB,IAAImH,EAAWC,EAAQpH,EAAQ0D,KAAKS,QAAQkD,MAAO3D,KAAKS,QAAQmD,IAAM5D,KAAKS,QAAQkD,OAEnF,OAAQ3D,KAAKS,QAAQoD,uBACnB,IAAK,MACHJ,EAAWzD,KAAK8D,cAAcL,GAC9B,MAEF,IAAK,MACHA,EAAWzD,KAAK+D,cAAcN,GAIlC,OAAOA,EAASO,QAAQ,KAQzB,CACDpH,IAAK,SACLN,MAAO,SAAgBmH,GACrB,OAAQzD,KAAKS,QAAQoD,uBACnB,IAAK,MACHJ,EAAWzD,KAAK+D,cAAcN,GAC9B,MAEF,IAAK,MACHA,EAAWzD,KAAK8D,cAAcL,GAKlC,OADazD,KAAKS,QAAQmD,IAAM5D,KAAKS,QAAQkD,OAASF,EAAWQ,WAAWjE,KAAKS,QAAQkD,SAS1F,CACD/G,IAAK,gBACLN,MAAO,SAAuBA,GAC5B,OA0mBW4H,EA1mBIlE,KAAKS,QAAQ0D,cA0mBX7H,EA1mB0BA,GAAS0D,KAAKS,QAAQ0D,cAAgB,GAAK,EA2mBnFC,KAAKC,IAAI/H,GAAS8H,KAAKC,IAAIH,GADpC,IAAiBA,EAAM5H,IAlmBlB,CACDM,IAAK,gBACLN,MAAO,SAAuBA,GAC5B,OAAQ8H,KAAKE,IAAItE,KAAKS,QAAQ0D,cAAe7H,GAAS,IAAM0D,KAAKS,QAAQ0D,cAAgB,KAa1F,CACDvH,IAAK,gBACLN,MAAO,SAAuBiI,EAAOC,EAAUC,EAAUC,GAEvD,IAAI1E,KAAKU,SAASiC,SAAS3C,KAAKS,QAAQmC,eAAxC,EAKA4B,EAAWP,WAAWO,IAGPxE,KAAKS,QAAQkD,MAC1Ba,EAAWxE,KAAKS,QAAQkD,MACfa,EAAWxE,KAAKS,QAAQmD,MACjCY,EAAWxE,KAAKS,QAAQmD,KAG1B,IAAIe,EAAQ3E,KAAKS,QAAQwC,YAOzB,GAJIjD,KAAKS,QAAQgC,WAAagC,IAC5BD,EAAWxE,KAAKS,QAAQmD,IAAMY,GAG5BG,EAEF,GAAkC,IAA9B3E,KAAKiC,QAAQ2C,MAAML,GAAc,CACnC,IAAIM,EAAQZ,WAAWjE,KAAKkD,SAASZ,KAAK,kBAC1CkC,EAAuBK,GAAZL,EAAoBK,EAAQ7E,KAAKS,QAAQqE,KAAON,MACtD,CACL,IAAIO,EAAQd,WAAWjE,KAAKkC,QAAQI,KAAK,kBACzCkC,EAAWA,GAAYO,EAAQA,EAAQ/E,KAAKS,QAAQqE,KAAON,EAI/D,IAAIQ,EAAQhF,KACRiF,EAAOjF,KAAKS,QAAQgC,SACpByC,EAAOD,EAAO,SAAW,QACzBE,EAAOF,EAAO,MAAQ,OACtBG,EAAYb,EAAM,GAAGc,wBAAwBH,GAC7CI,EAAUtF,KAAKU,SAAS,GAAG2E,wBAAwBH,GAEvDzB,EAAWzD,KAAKuF,UAAUf,GAI1BgB,GAAyC,IAA7B9B,GAFA4B,EAAUF,GAAa3B,EAEL6B,IAAgBtB,QAAQhE,KAAKS,QAAQgF,SAGnEjB,EAAWP,WAAWO,EAASR,QAAQhE,KAAKS,QAAQgF,UAEpD,IAAIjD,EAAM,GAKV,GAHAxC,KAAK0F,WAAWnB,EAAOC,GAGnBG,EAAO,CACT,IAEAgB,EAFIC,EAA2C,IAA9B5F,KAAKiC,QAAQ2C,MAAML,GAIpCsB,KAA6C,IAA9BnC,EAAQ0B,EAAWE,IAElC,GAAIM,EAEFpD,EAAI2C,GAAQ,GAAG9C,OAAOmD,EAAU,KAEhCG,EAAM1B,WAAWjE,KAAKkD,SAAS,GAAG4C,MAAMX,IAASK,EAAWK,EAGxDnB,GAAoB,mBAAPA,GACfA,QAGG,CAEL,IAAIqB,EAAY9B,WAAWjE,KAAKkC,QAAQ,GAAG4D,MAAMX,IAGjDQ,EAAMH,GAAYQ,MAAMD,IAAc/F,KAAKS,QAAQwF,aAAejG,KAAKS,QAAQkD,SAAW3D,KAAKS,QAAQmD,IAAM5D,KAAKS,QAAQkD,OAAS,KAAOoC,GAAaF,EAIzJrD,EAAI,OAAOH,OAAO6C,IAAS,GAAG7C,OAAOsD,EAAK,KAG5C3F,KAAKU,SAASwF,IAAI,sBAAuB,WAKvClB,EAAMtE,SAASyF,QAAQ,kBAAmB,CAAC5B,MAG7C,IAAI6B,EAAWpG,KAAKU,SAASI,KAAK,YAAc,IAAO,GAAKd,KAAKS,QAAQ2F,SACzErK,OAAOoC,EAA2D,KAAlEpC,CAAqEqK,EAAU7B,EAAO,WAIhFyB,MAAMR,GACRjB,EAAM/B,IAAI2C,EAAM,GAAG9C,OAAkB,IAAXoB,EAAgB,MAE1Cc,EAAM/B,IAAI2C,EAAM,GAAG9C,OAAOmD,EAAU,MAGjCR,EAAMvE,QAAQwC,YAKjB+B,EAAMzC,MAAMC,IAAIA,GAHhBwC,EAAMzC,MAAMC,IAAI0C,EAAM,GAAG7C,OAAkB,IAAXoB,EAAgB,QAWpD4C,aAAarB,EAAMsB,SACnBtB,EAAMsB,QAAUC,WAAW,WACzBvB,EAAMtE,SAASyF,QAAQ,oBAAqB,CAAC5B,KAC5CS,EAAMvE,QAAQ+F,iBASlB,CACD5J,IAAK,eACLN,MAAO,SAAsBmK,GAC3B,IAAIC,EAAkB,IAARD,EAAYzG,KAAKS,QAAQwF,aAAejG,KAAKS,QAAQkG,WAC/DC,EAAK5G,KAAK+B,OAAOI,GAAGsE,GAAKnE,KAAK,OAASvG,OAAOqC,EAAiE,YAAxErC,CAA2E,EAAG,UACzHiE,KAAK+B,OAAOI,GAAGsE,GAAKnE,KAAK,CACvBsE,GAAMA,EACNC,IAAO7G,KAAKS,QAAQmD,IACpBkD,IAAO9G,KAAKS,QAAQkD,MACpBmB,KAAQ9E,KAAKS,QAAQqE,OAEvB9E,KAAK+B,OAAOI,GAAGsE,GAAKjD,IAAIkD,GACxB1G,KAAKiC,QAAQE,GAAGsE,GAAKnE,KAAK,CACxByE,KAAQ,SACRC,gBAAiBJ,EACjBK,gBAAiBjH,KAAKS,QAAQmD,IAC9BsD,gBAAiBlH,KAAKS,QAAQkD,MAC9BwD,gBAAiBT,EACjBU,mBAAoBpH,KAAKS,QAAQgC,SAAW,WAAa,aACzD4E,SAAY,MAWf,CACDzK,IAAK,aACLN,MAAO,SAAoB4F,EAASsB,GAClC,IAAIiD,EAAMzG,KAAKS,QAAQwC,YAAcjD,KAAKiC,QAAQ2C,MAAM1C,GAAW,EACnElC,KAAK+B,OAAOI,GAAGsE,GAAKjD,IAAIA,GACxBtB,EAAQI,KAAK,gBAAiBkB,KAc/B,CACD5G,IAAK,eACLN,MAAO,SAAsBgL,EAAGpF,EAASsB,GACvC,IAAIlH,EAAOiL,EAEX,GAAK/D,EAkDHlH,EAAQ0D,KAAKwH,aAAa,KAAMhE,GAChC+D,GAAS,MAnDD,CAERD,EAAEG,iBAEF,IACIhF,EAAWzC,KAAKS,QAAQgC,SACxBiF,EAAQjF,EAAW,SAAW,QAC9BkF,EAAYlF,EAAW,MAAQ,OAC/BmF,EAAcnF,EAAW6E,EAAEO,MAAQP,EAAEQ,MAErCC,GADe/H,KAAKkC,QAAQ,GAAGmD,wBAAwBqC,GAC9C1H,KAAKU,SAAS,GAAG2E,wBAAwBqC,IAClDM,EAAevF,EAAWxE,GAAAA,CAA8CrD,QAAQqN,YAAchK,GAAAA,CAA8CrD,QAAQsN,aAEpJC,EAAanI,KAAKU,SAAS0H,SAAST,GAGpCL,EAAEe,UAAYf,EAAEO,QAClBD,GAA4BI,GAG9B,IACIM,EADAC,EAAeX,EAAcO,EAW7BK,EAAY9E,EAPd4E,EADEC,EAAe,EACT,EACgBR,EAAfQ,EACDR,EAEAQ,EAGqBR,GAW/B,GAVAzL,EAAQ0D,KAAKyI,OAAOD,GAEhBzM,OAAOqC,EAAyD,IAAhErC,KAAyEiE,KAAKS,QAAQgC,WACxFnG,EAAQ0D,KAAKS,QAAQmD,IAAMtH,GAG7BA,EAlCY0D,KAkCEwH,aAAa,KAAMlL,GAEjCiL,GAAS,GAEJrF,EAIHA,EAFmBwG,EAAY1I,KAAKkC,QAASyF,EAAWW,EAAOZ,IAC5CgB,EAAY1I,KAAKkD,SAAUyE,EAAWW,EAAOZ,GACvB1H,KAAKkC,QAAUlC,KAAKkD,SAQjElD,KAAKuD,cAAcrB,EAAS5F,EAAOiL,KAUpC,CACD3K,IAAK,eACLN,MAAO,SAAsB4F,EAAS5F,GACpC,IAAIkH,EAGAmF,EACAC,EAHA9D,EAAO9E,KAAKS,QAAQqE,KACpB+D,EAAM5E,WAAWa,EAAO,GAoB5B,OAAa,KARX6D,EADS,IALTnF,EADItB,EACE+B,WAAW/B,EAAQI,KAAK,kBAExBhG,GAICkH,EAAMsB,EAENA,EAAOtB,EAAMsB,GAObtB,EAGTA,GAPAoF,EAAWpF,EAAMmF,GAOOE,GAAlBrF,EANKoF,EAAW9D,EAMmB8D,IAS1C,CACDhM,IAAK,UACLN,MAAO,WACL0D,KAAK8I,iBAAiB9I,KAAKkC,SAEvBlC,KAAKiC,QAAQ,IACfjC,KAAK8I,iBAAiB9I,KAAKkD,YAU9B,CACDtG,IAAK,mBACLN,MAAO,SAA0B4F,GAC/B,IACI6G,EADA/D,EAAQhF,KAIRgJ,EAAoB,SAA2B1B,GACjD,IAAIb,EAAMzB,EAAMjD,OAAO6C,MAAM3G,GAAAA,CAA8C+B,OAE3EgF,EAAMiE,aAAa3B,EAAGtC,EAAM/C,QAAQE,GAAGsE,GAAMxI,GAAAA,CAA8C+B,MAAMwD,QA2BnG,GArBAxD,KAAK+B,OAAOmH,IAAI,mBAAmBC,GAAG,kBAAmB,SAAU7B,GAChD,IAAbA,EAAE8B,SAAeJ,EAAkBxN,KAAKwE,KAAMsH,KAEpDtH,KAAK+B,OAAOmH,IAAI,oBAAoBC,GAAG,mBAAoBH,GAEvDhJ,KAAKS,QAAQ4I,aACfrJ,KAAKU,SAASwI,IAAI,mBAAmBC,GAAG,kBAAmB,SAAU7B,GACnE,GAAItC,EAAMtE,SAASI,KAAK,YACtB,OAAO,EAGJ7C,GAAAA,CAA8CqJ,EAAE1I,QAAQ0K,GAAG,0BAC1DtE,EAAMvE,QAAQwC,YAChB+B,EAAMiE,aAAa3B,GAEnBtC,EAAMiE,aAAa3B,EAAGtC,EAAM9C,YAMhClC,KAAKS,QAAQ8I,UAAW,CAC1BvJ,KAAKiC,QAAQuH,WACb,IAAIC,EAAQxL,GAAAA,CAA8C,QAC1DiE,EAAQgH,IAAI,uBAAuBC,GAAG,sBAAuB,SAAU7B,GACrEpF,EAAQW,SAAS,eAEjBmC,EAAMzC,MAAMM,SAAS,eAGrBmC,EAAMtE,SAASI,KAAK,YAAY,GAEhCiI,EAAY9K,GAAAA,CAA8CqJ,EAAEoC,eAC5DD,EAAMN,GAAG,sBAAuB,SAAU7B,GACxCA,EAAEG,iBAEFzC,EAAMiE,aAAa3B,EAAGyB,KACrBI,GAAG,oBAAqB,SAAU7B,GACnCtC,EAAMiE,aAAa3B,EAAGyB,GAEtB7G,EAAQyH,YAAY,eAEpB3E,EAAMzC,MAAMoH,YAAY,eAExB3E,EAAMtE,SAASI,KAAK,YAAY,GAEhC2I,EAAMP,IAAI,6CAGbC,GAAG,4CAA6C,SAAU7B,GACzDA,EAAEG,mBAINvF,EAAQgH,IAAI,qBAAqBC,GAAG,oBAAqB,SAAU7B,GACjE,IAGIsC,EAHAC,EAAW5L,GAAAA,CAA8C+B,MACzDyG,EAAMzB,EAAMvE,QAAQwC,YAAc+B,EAAM/C,QAAQ2C,MAAMiF,GAAY,EAClEC,EAAW7F,WAAWe,EAAMjD,OAAOI,GAAGsE,GAAKjD,OAI/CtF,EAAiE,SAAE6L,UAAUzC,EAAG,SAAU,CACxF0C,SAAU,WACRJ,EAAWE,EAAW9E,EAAMvE,QAAQqE,MAEtCmF,SAAU,WACRL,EAAWE,EAAW9E,EAAMvE,QAAQqE,MAEtCoF,cAAe,WACbN,EAAWE,EAAgC,GAArB9E,EAAMvE,QAAQqE,MAEtCqF,cAAe,WACbP,EAAWE,EAAgC,GAArB9E,EAAMvE,QAAQqE,MAEtCgC,IAAK,WACH8C,EAAW5E,EAAMvE,QAAQkD,OAE3BkD,IAAK,WACH+C,EAAW5E,EAAMvE,QAAQmD,KAE3BwG,QAAS,WAEP9C,EAAEG,iBAEFzC,EAAMzB,cAAcsG,EAAUD,GAAU,UAa/C,CACDhN,IAAK,WACLN,MAAO,WACL0D,KAAKiC,QAAQiH,IAAI,cACjBlJ,KAAK+B,OAAOmH,IAAI,cAChBlJ,KAAKU,SAASwI,IAAI,cAClB7C,aAAarG,KAAKsG,cAxoBsD3H,EAAkBkB,EAAY5C,UAAWkD,GAAiBC,GAAazB,EAAkBkB,EAAaO,GA4oB3KrC,EA9mBT,GA8wBA,SAAS2F,EAAQ2G,EAAMC,GACrB,OAAOD,EAAOC,EAGhB,SAAS5B,EAAYxG,EAASqI,EAAKC,EAAU9C,GAC3C,OAAOtD,KAAKqG,IAAIvI,EAAQwI,WAAWH,GAAOrI,EAAQwF,KAAW,EAAI8C,GAlKnEzM,EAAO8C,SAAW,CAOhB8C,MAAO,EAQPC,IAAK,IAQLkB,KAAM,EAQNmB,aAAc,EAQdU,WAAY,IAQZ5D,SAAS,EAQTsG,aAAa,EAQb5G,UAAU,EAQV8G,WAAW,EAQX7G,UAAU,EAQVO,aAAa,EAabwC,QAAS,EAaTW,SAAU,IASVxD,cAAe,WAQf+H,gBAAgB,EAQhBnE,aAAc,IAQdrC,cAAe,EAQfN,sBAAuB,WAmBnB+G,mCAKA,SAAUpQ,EAAQkD,EAAqBtC,GAE7C,aACAA,EAAoBe,EAAEuB,GACStC,EAAoBO,EAAE+B,EAAqB,WAAY,WAAa,OAAOmN,IACrF,IAAI7M,EAAsC5C,EAAkC,UACxE6C,EAA2D7C,EAAoB0B,EAAEkB,GACjF8M,EAAsD1P,EAAmD,qBAEzG+C,EAAuD/C,EAAoD,4BAIpI,SAASmD,EAAQC,GAAwT,OAAtOD,EAArD,mBAAXnC,QAAoD,iBAApBA,OAAOqC,SAAmC,SAAiBD,GAAO,cAAcA,GAA2B,SAAiBA,GAAO,OAAOA,GAAyB,mBAAXpC,QAAyBoC,EAAIE,cAAgBtC,QAAUoC,IAAQpC,OAAOa,UAAY,gBAAkBuB,IAAyBA,GAMxV,IAAIuM,EAAmB,WAGrB,IAFA,IAAIC,EAAW,CAAC,SAAU,MAAO,IAAK,KAAM,IAEnC1P,EAAI,EAAGA,EAAI0P,EAASlM,OAAQxD,IACnC,GAAI,GAAG+G,OAAO2I,EAAS1P,GAAI,sBAAuBV,OAChD,OAAOA,OAAO,GAAGyH,OAAO2I,EAAS1P,GAAI,qBAIzC,OAAO,EATc,GAYnB2P,EAAW,SAAkBC,EAAIC,GACnCD,EAAGpK,KAAKqK,GAAMC,MAAM,KAAKC,QAAQ,SAAUzE,GACzC3I,GAAAA,CAA8C,IAAIoE,OAAOuE,IAAc,UAATuE,EAAmB,UAAY,kBAAkB,GAAG9I,OAAO8I,EAAM,eAAgB,CAACD,OAIhJL,EAAW,CACbS,UAAW,CACTC,MAAO,GACPC,OAAQ,IAEVC,aAAc,IAkIhB,SAASC,EAAuBC,EAAUxF,EAASyF,GACjD,IAAIC,EACAC,EAAOC,MAAM9O,UAAU+O,MAAMxQ,KAAK0E,UAAW,GACjDjC,GAAAA,CAA8CrD,QAAQsO,IAAI/C,GAASgD,GAAGhD,EAAS,SAAUmB,GACnFuE,GACFxF,aAAawF,GAGfA,EAAQtF,WAAW,WACjBqF,EAAS3L,MAAM,KAAM6L,IACpBH,GAAY,MA1InBd,EAASS,UAAUC,MAAQ,CACzBU,aAAc,WACZhB,EAAShN,GAAAA,CAA8C+B,MAAO,SAEhEkM,cAAe,WACJjO,GAAAA,CAA8C+B,MAAMc,KAAK,SAGhEmK,EAAShN,GAAAA,CAA8C+B,MAAO,SAE9D/B,GAAAA,CAA8C+B,MAAMmG,QAAQ,qBAGhEgG,eAAgB,WACLlO,GAAAA,CAA8C+B,MAAMc,KAAK,UAGhEmK,EAAShN,GAAAA,CAA8C+B,MAAO,UAE9D/B,GAAAA,CAA8C+B,MAAMmG,QAAQ,sBAGhEiG,kBAAmB,SAA2B9E,GAC5CA,EAAE+E,kBACF,IAAIC,EAAYrO,GAAAA,CAA8C+B,MAAMc,KAAK,YAEvD,KAAdwL,EACFnO,EAA6D,OAAEoO,WAAWtO,GAAAA,CAA8C+B,MAAOsM,EAAW,WACxIrO,GAAAA,CAA8C+B,MAAMmG,QAAQ,eAG9DlI,GAAAA,CAA8C+B,MAAMwM,UAAUrG,QAAQ,cAG1EsG,oBAAqB,WACnB,IAAI7F,EAAK3I,GAAAA,CAA8C+B,MAAMc,KAAK,gBAClE7C,GAAAA,CAA8C,IAAIoE,OAAOuE,IAAK8F,eAAe,oBAAqB,CAACzO,GAAAA,CAA8C+B,UAIrJ6K,EAASY,aAAakB,gBAAkB,SAAUC,GAChDA,EAAM1D,IAAI,mBAAoB2B,EAASS,UAAUC,MAAMU,cACvDW,EAAMzD,GAAG,mBAAoB,cAAe0B,EAASS,UAAUC,MAAMU,eAKvEpB,EAASY,aAAaoB,iBAAmB,SAAUD,GACjDA,EAAM1D,IAAI,mBAAoB2B,EAASS,UAAUC,MAAMW,eACvDU,EAAMzD,GAAG,mBAAoB,eAAgB0B,EAASS,UAAUC,MAAMW,gBAIxErB,EAASY,aAAaqB,kBAAoB,SAAUF,GAClDA,EAAM1D,IAAI,mBAAoB2B,EAASS,UAAUC,MAAMY,gBACvDS,EAAMzD,GAAG,mBAAoB,gBAAiB0B,EAASS,UAAUC,MAAMY,iBAIzEtB,EAASY,aAAasB,qBAAuB,SAAUH,GACrDA,EAAM1D,IAAI,mBAAoB2B,EAASS,UAAUC,MAAMa,mBACvDQ,EAAMzD,GAAG,mBAAoB,oCAAqC0B,EAASS,UAAUC,MAAMa,oBAI7FvB,EAASY,aAAauB,uBAAyB,SAAUJ,GACvDA,EAAM1D,IAAI,mCAAoC2B,EAASS,UAAUC,MAAMkB,qBACvEG,EAAMzD,GAAG,mCAAoC,sBAAuB0B,EAASS,UAAUC,MAAMkB,sBAI/F5B,EAASS,UAAUE,OAAS,CAC1ByB,eAAgB,SAAwBC,GACjCnC,GAEHmC,EAAOC,KAAK,WACVlP,GAAAA,CAA8C+B,MAAM0M,eAAe,yBAKvEQ,EAAO5K,KAAK,cAAe,WAE7B8K,eAAgB,SAAwBF,GACjCnC,GAEHmC,EAAOC,KAAK,WACVlP,GAAAA,CAA8C+B,MAAM0M,eAAe,yBAKvEQ,EAAO5K,KAAK,cAAe,WAE7B+K,gBAAiB,SAAyB/F,EAAGgG,GAC3C,IAAIzP,EAASyJ,EAAEiG,UAAUnC,MAAM,KAAK,GACtBnN,GAAAA,CAA8C,SAASoE,OAAOxE,EAAQ,MAAM2P,IAAI,mBAAoBnL,OAAOiL,EAAU,OAC3HH,KAAK,WACX,IAAInI,EAAQ/G,GAAAA,CAA8C+B,MAE1DgF,EAAM0H,eAAe,mBAAoB,CAAC1H,QAMhD6F,EAASY,aAAagC,mBAAqB,SAAUC,GACnD,IAAIC,EAAY1P,GAAAA,CAA8C,mBAC1D2P,EAAY,CAAC,WAAY,UAAW,UAYxC,GAVIF,IACwB,iBAAfA,EACTE,EAAUC,KAAKH,GACkB,WAAxBnP,EAAQmP,IAAqD,iBAAlBA,EAAW,GAC/DE,EAAYA,EAAUvL,OAAOqL,GAE7BI,QAAQC,MAAM,iCAIdJ,EAAU7O,OAAQ,CACpB,IAAIkP,EAAYJ,EAAUK,IAAI,SAAUrS,GACtC,MAAO,cAAcyG,OAAOzG,KAC3BsS,KAAK,KACRjQ,GAAAA,CAA8CrD,QAAQsO,IAAI8E,GAAW7E,GAAG6E,EAAWnD,EAASS,UAAUE,OAAO6B,mBAkBjHxC,EAASY,aAAa0C,kBAAoB,SAAUxC,GAClD,IAAIuB,EAASjP,GAAAA,CAA8C,iBAEvDiP,EAAOpO,QACT4M,EAAuBC,EAAU,oBAAqBd,EAASS,UAAUE,OAAOyB,eAAgBC,IAIpGrC,EAASY,aAAa2C,kBAAoB,SAAUzC,GAClD,IAAIuB,EAASjP,GAAAA,CAA8C,iBAEvDiP,EAAOpO,QACT4M,EAAuBC,EAAU,oBAAqBd,EAASS,UAAUE,OAAO4B,eAAgBF,IAIpGrC,EAASY,aAAa4C,0BAA4B,SAAUzB,GAC1D,IAAK7B,EACH,OAAO,EAGT,IAAImC,EAASN,EAAM5K,KAAK,+CAEpBsM,EAA4B,SAAmCC,GACjE,IAAIC,EAAUvQ,GAAAA,CAA8CsQ,EAAoB,GAAG3P,QAEnF,OAAQ2P,EAAoB,GAAGpD,MAC7B,IAAK,aACiC,WAAhCqD,EAAQlM,KAAK,gBAAwE,gBAAzCiM,EAAoB,GAAGE,eACrED,EAAQ9B,eAAe,sBAAuB,CAAC8B,EAAS5T,OAAO8T,cAG7B,WAAhCF,EAAQlM,KAAK,gBAAwE,gBAAzCiM,EAAoB,GAAGE,eACrED,EAAQ9B,eAAe,sBAAuB,CAAC8B,IAGJ,UAAzCD,EAAoB,GAAGE,gBACzBD,EAAQG,QAAQ,iBAAiBrM,KAAK,cAAe,UACrDkM,EAAQG,QAAQ,iBAAiBjC,eAAe,sBAAuB,CAAC8B,EAAQG,QAAQ,oBAG1F,MAEF,IAAK,YACHH,EAAQG,QAAQ,iBAAiBrM,KAAK,cAAe,UACrDkM,EAAQG,QAAQ,iBAAiBjC,eAAe,sBAAuB,CAAC8B,EAAQG,QAAQ,mBACxF,MAEF,QACE,OAAO,IAKb,GAAIzB,EAAOpO,OAET,IAAK,IAAIxD,EAAI,EAAGA,GAAK4R,EAAOpO,OAAS,EAAGxD,IAAK,CACrB,IAAIyP,EAAiBuD,GAC3BM,QAAQ1B,EAAO5R,GAAI,CACjCuT,YAAY,EACZC,WAAW,EACXC,eAAe,EACfC,SAAS,EACTC,gBAAiB,CAAC,cAAe,aAMzCpE,EAASY,aAAayD,mBAAqB,WACzC,IAAIC,EAAYlR,GAAAA,CAA8CmR,UAC9DvE,EAASY,aAAakB,gBAAgBwC,GACtCtE,EAASY,aAAaoB,iBAAiBsC,GACvCtE,EAASY,aAAaqB,kBAAkBqC,GACxCtE,EAASY,aAAasB,qBAAqBoC,GAC3CtE,EAASY,aAAauB,uBAAuBmC,IAG/CtE,EAASY,aAAa4D,mBAAqB,WACzC,IAAIF,EAAYlR,GAAAA,CAA8CmR,UAC9DvE,EAASY,aAAa4C,0BAA0Bc,GAChDtE,EAASY,aAAa0C,oBACtBtD,EAASY,aAAa2C,oBACtBvD,EAASY,aAAagC,sBAGxB5C,EAAS7J,KAAO,SAAUsO,EAAGC,GAC3BxT,OAAO+O,EAA4D,OAAnE/O,CAAsEuT,EAAE1U,QAAS,YACjD,IAA1B0U,EAAEE,sBACJ3E,EAASY,aAAayD,qBACtBrE,EAASY,aAAa4D,qBACtBC,EAAEE,qBAAsB,KAIxBD,IACFA,EAAW1E,SAAWA,EAEtB0E,EAAWE,SAAW5E,EAASY,aAAa4D,sBAQ1CK,GAKA,SAAUlV,EAAQD,EAASa,GAEjCZ,EAAOD,QAAUa,EAAwH,8CAKnIuU,OAKA,SAAUnV,EAAQD,GAExBC,EAAOD,QAAUU","file":"foundation.slider.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.keyboard\", \"./foundation.util.motion\", \"./foundation.util.touch\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.slider\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.keyboard\"), require(\"./foundation.util.motion\"), require(\"./foundation.util.touch\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.slider\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 15);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./foundation.util.touch\":\n/*!****************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.touch\"],\"amd\":\"./foundation.util.touch\",\"commonjs\":\"./foundation.util.touch\",\"commonjs2\":\"./foundation.util.touch\"} ***!\n  \\****************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_touch__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.slider.js\":\n/*!*************************************************!*\\\n  !*** ./js/entries/plugins/foundation.slider.js ***!\n  \\*************************************************/\n/*! exports provided: Foundation, Slider */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_slider__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.slider */ \"./js/foundation.slider.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Slider\", function() { return _foundation_slider__WEBPACK_IMPORTED_MODULE_1__[\"Slider\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_slider__WEBPACK_IMPORTED_MODULE_1__[\"Slider\"], 'Slider');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.slider.js\":\n/*!*********************************!*\\\n  !*** ./js/foundation.slider.js ***!\n  \\*********************************/\n/*! exports provided: Slider */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Slider\", function() { return Slider; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__);\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.util.touch */ \"./foundation.util.touch\");\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_4___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_touch__WEBPACK_IMPORTED_MODULE_4__);\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n\n\n/**\n * Slider module.\n * @module foundation.slider\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n * @requires foundation.util.keyboard\n * @requires foundation.util.touch\n */\n\nvar Slider =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Slider, _Plugin);\n\n  function Slider() {\n    _classCallCheck(this, Slider);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Slider).apply(this, arguments));\n  }\n\n  _createClass(Slider, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a slider control.\n     * @class\n     * @name Slider\n     * @param {jQuery} element - jQuery object to make into a slider control.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Slider.defaults, this.$element.data(), options);\n      this.className = 'Slider'; // ie9 back compat\n      // Touch and Triggers inits are idempotent, we just need to make sure it's initialied.\n\n      _foundation_util_touch__WEBPACK_IMPORTED_MODULE_4__[\"Touch\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_5__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].register('Slider', {\n        'ltr': {\n          'ARROW_RIGHT': 'increase',\n          'ARROW_UP': 'increase',\n          'ARROW_DOWN': 'decrease',\n          'ARROW_LEFT': 'decrease',\n          'SHIFT_ARROW_RIGHT': 'increase_fast',\n          'SHIFT_ARROW_UP': 'increase_fast',\n          'SHIFT_ARROW_DOWN': 'decrease_fast',\n          'SHIFT_ARROW_LEFT': 'decrease_fast',\n          'HOME': 'min',\n          'END': 'max'\n        },\n        'rtl': {\n          'ARROW_LEFT': 'increase',\n          'ARROW_RIGHT': 'decrease',\n          'SHIFT_ARROW_LEFT': 'increase_fast',\n          'SHIFT_ARROW_RIGHT': 'decrease_fast'\n        }\n      });\n    }\n    /**\n     * Initilizes the plugin by reading/setting attributes, creating collections and setting the initial position of the handle(s).\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      this.inputs = this.$element.find('input');\n      this.handles = this.$element.find('[data-slider-handle]');\n      this.$handle = this.handles.eq(0);\n      this.$input = this.inputs.length ? this.inputs.eq(0) : jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(this.$handle.attr('aria-controls')));\n      this.$fill = this.$element.find('[data-slider-fill]').css(this.options.vertical ? 'height' : 'width', 0);\n\n      var isDbl = false,\n          _this = this;\n\n      if (this.options.disabled || this.$element.hasClass(this.options.disabledClass)) {\n        this.options.disabled = true;\n        this.$element.addClass(this.options.disabledClass);\n      }\n\n      if (!this.inputs.length) {\n        this.inputs = jquery__WEBPACK_IMPORTED_MODULE_0___default()().add(this.$input);\n        this.options.binding = true;\n      }\n\n      this._setInitAttr(0);\n\n      if (this.handles[1]) {\n        this.options.doubleSided = true;\n        this.$handle2 = this.handles.eq(1);\n        this.$input2 = this.inputs.length > 1 ? this.inputs.eq(1) : jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(this.$handle2.attr('aria-controls')));\n\n        if (!this.inputs[1]) {\n          this.inputs = this.inputs.add(this.$input2);\n        }\n\n        isDbl = true; // this.$handle.triggerHandler('click.zf.slider');\n\n        this._setInitAttr(1);\n      } // Set handle positions\n\n\n      this.setHandles();\n\n      this._events();\n    }\n  }, {\n    key: \"setHandles\",\n    value: function setHandles() {\n      var _this2 = this;\n\n      if (this.handles[1]) {\n        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true, function () {\n          _this2._setHandlePos(_this2.$handle2, _this2.inputs.eq(1).val(), true);\n        });\n      } else {\n        this._setHandlePos(this.$handle, this.inputs.eq(0).val(), true);\n      }\n    }\n  }, {\n    key: \"_reflow\",\n    value: function _reflow() {\n      this.setHandles();\n    }\n    /**\n    * @function\n    * @private\n    * @param {Number} value - floating point (the value) to be transformed using to a relative position on the slider (the inverse of _value)\n    */\n\n  }, {\n    key: \"_pctOfBar\",\n    value: function _pctOfBar(value) {\n      var pctOfBar = percent(value - this.options.start, this.options.end - this.options.start);\n\n      switch (this.options.positionValueFunction) {\n        case \"pow\":\n          pctOfBar = this._logTransform(pctOfBar);\n          break;\n\n        case \"log\":\n          pctOfBar = this._powTransform(pctOfBar);\n          break;\n      }\n\n      return pctOfBar.toFixed(2);\n    }\n    /**\n    * @function\n    * @private\n    * @param {Number} pctOfBar - floating point, the relative position of the slider (typically between 0-1) to be transformed to a value\n    */\n\n  }, {\n    key: \"_value\",\n    value: function _value(pctOfBar) {\n      switch (this.options.positionValueFunction) {\n        case \"pow\":\n          pctOfBar = this._powTransform(pctOfBar);\n          break;\n\n        case \"log\":\n          pctOfBar = this._logTransform(pctOfBar);\n          break;\n      }\n\n      var value = (this.options.end - this.options.start) * pctOfBar + parseFloat(this.options.start);\n      return value;\n    }\n    /**\n    * @function\n    * @private\n    * @param {Number} value - floating point (typically between 0-1) to be transformed using the log function\n    */\n\n  }, {\n    key: \"_logTransform\",\n    value: function _logTransform(value) {\n      return baseLog(this.options.nonLinearBase, value * (this.options.nonLinearBase - 1) + 1);\n    }\n    /**\n    * @function\n    * @private\n    * @param {Number} value - floating point (typically between 0-1) to be transformed using the power function\n    */\n\n  }, {\n    key: \"_powTransform\",\n    value: function _powTransform(value) {\n      return (Math.pow(this.options.nonLinearBase, value) - 1) / (this.options.nonLinearBase - 1);\n    }\n    /**\n     * Sets the position of the selected handle and fill bar.\n     * @function\n     * @private\n     * @param {jQuery} $hndl - the selected handle to move.\n     * @param {Number} location - floating point between the start and end values of the slider bar.\n     * @param {Function} cb - callback function to fire on completion.\n     * @fires Slider#moved\n     * @fires Slider#changed\n     */\n\n  }, {\n    key: \"_setHandlePos\",\n    value: function _setHandlePos($hndl, location, noInvert, cb) {\n      // don't move if the slider has been disabled since its initialization\n      if (this.$element.hasClass(this.options.disabledClass)) {\n        return;\n      } //might need to alter that slightly for bars that will have odd number selections.\n\n\n      location = parseFloat(location); //on input change events, convert string to number...grumble.\n      // prevent slider from running out of bounds, if value exceeds the limits set through options, override the value to min/max\n\n      if (location < this.options.start) {\n        location = this.options.start;\n      } else if (location > this.options.end) {\n        location = this.options.end;\n      }\n\n      var isDbl = this.options.doubleSided; //this is for single-handled vertical sliders, it adjusts the value to account for the slider being \"upside-down\"\n      //for click and drag events, it's weird due to the scale(-1, 1) css property\n\n      if (this.options.vertical && !noInvert) {\n        location = this.options.end - location;\n      }\n\n      if (isDbl) {\n        //this block is to prevent 2 handles from crossing eachother. Could/should be improved.\n        if (this.handles.index($hndl) === 0) {\n          var h2Val = parseFloat(this.$handle2.attr('aria-valuenow'));\n          location = location >= h2Val ? h2Val - this.options.step : location;\n        } else {\n          var h1Val = parseFloat(this.$handle.attr('aria-valuenow'));\n          location = location <= h1Val ? h1Val + this.options.step : location;\n        }\n      }\n\n      var _this = this,\n          vert = this.options.vertical,\n          hOrW = vert ? 'height' : 'width',\n          lOrT = vert ? 'top' : 'left',\n          handleDim = $hndl[0].getBoundingClientRect()[hOrW],\n          elemDim = this.$element[0].getBoundingClientRect()[hOrW],\n          //percentage of bar min/max value based on click or drag point\n      pctOfBar = this._pctOfBar(location),\n          //number of actual pixels to shift the handle, based on the percentage obtained above\n      pxToMove = (elemDim - handleDim) * pctOfBar,\n          //percentage of bar to shift the handle\n      movement = (percent(pxToMove, elemDim) * 100).toFixed(this.options.decimal); //fixing the decimal value for the location number, is passed to other methods as a fixed floating-point value\n\n\n      location = parseFloat(location.toFixed(this.options.decimal)); // declare empty object for css adjustments, only used with 2 handled-sliders\n\n      var css = {};\n\n      this._setValues($hndl, location); // TODO update to calculate based on values set to respective inputs??\n\n\n      if (isDbl) {\n        var isLeftHndl = this.handles.index($hndl) === 0,\n            //empty variable, will be used for min-height/width for fill bar\n        dim,\n            //percentage w/h of the handle compared to the slider bar\n        handlePct = ~~(percent(handleDim, elemDim) * 100); //if left handle, the math is slightly different than if it's the right handle, and the left/top property needs to be changed for the fill bar\n\n        if (isLeftHndl) {\n          //left or top percentage value to apply to the fill bar.\n          css[lOrT] = \"\".concat(movement, \"%\"); //calculate the new min-height/width for the fill bar.\n\n          dim = parseFloat(this.$handle2[0].style[lOrT]) - movement + handlePct; //this callback is necessary to prevent errors and allow the proper placement and initialization of a 2-handled slider\n          //plus, it means we don't care if 'dim' isNaN on init, it won't be in the future.\n\n          if (cb && typeof cb === 'function') {\n            cb();\n          } //this is only needed for the initialization of 2 handled sliders\n\n        } else {\n          //just caching the value of the left/bottom handle's left/top property\n          var handlePos = parseFloat(this.$handle[0].style[lOrT]); //calculate the new min-height/width for the fill bar. Use isNaN to prevent false positives for numbers <= 0\n          //based on the percentage of movement of the handle being manipulated, less the opposing handle's left/top position, plus the percentage w/h of the handle itself\n\n          dim = movement - (isNaN(handlePos) ? (this.options.initialStart - this.options.start) / ((this.options.end - this.options.start) / 100) : handlePos) + handlePct;\n        } // assign the min-height/width to our css object\n\n\n        css[\"min-\".concat(hOrW)] = \"\".concat(dim, \"%\");\n      }\n\n      this.$element.one('finished.zf.animate', function () {\n        /**\n         * Fires when the handle is done moving.\n         * @event Slider#moved\n         */\n        _this.$element.trigger('moved.zf.slider', [$hndl]);\n      }); //because we don't know exactly how the handle will be moved, check the amount of time it should take to move.\n\n      var moveTime = this.$element.data('dragging') ? 1000 / 60 : this.options.moveTime;\n      Object(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Move\"])(moveTime, $hndl, function () {\n        // adjusting the left/top property of the handle, based on the percentage calculated above\n        // if movement isNaN, that is because the slider is hidden and we cannot determine handle width,\n        // fall back to next best guess.\n        if (isNaN(movement)) {\n          $hndl.css(lOrT, \"\".concat(pctOfBar * 100, \"%\"));\n        } else {\n          $hndl.css(lOrT, \"\".concat(movement, \"%\"));\n        }\n\n        if (!_this.options.doubleSided) {\n          //if single-handled, a simple method to expand the fill bar\n          _this.$fill.css(hOrW, \"\".concat(pctOfBar * 100, \"%\"));\n        } else {\n          //otherwise, use the css object we created above\n          _this.$fill.css(css);\n        }\n      });\n      /**\n       * Fires when the value has not been change for a given time.\n       * @event Slider#changed\n       */\n\n      clearTimeout(_this.timeout);\n      _this.timeout = setTimeout(function () {\n        _this.$element.trigger('changed.zf.slider', [$hndl]);\n      }, _this.options.changedDelay);\n    }\n    /**\n     * Sets the initial attribute for the slider element.\n     * @function\n     * @private\n     * @param {Number} idx - index of the current handle/input to use.\n     */\n\n  }, {\n    key: \"_setInitAttr\",\n    value: function _setInitAttr(idx) {\n      var initVal = idx === 0 ? this.options.initialStart : this.options.initialEnd;\n      var id = this.inputs.eq(idx).attr('id') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"GetYoDigits\"])(6, 'slider');\n      this.inputs.eq(idx).attr({\n        'id': id,\n        'max': this.options.end,\n        'min': this.options.start,\n        'step': this.options.step\n      });\n      this.inputs.eq(idx).val(initVal);\n      this.handles.eq(idx).attr({\n        'role': 'slider',\n        'aria-controls': id,\n        'aria-valuemax': this.options.end,\n        'aria-valuemin': this.options.start,\n        'aria-valuenow': initVal,\n        'aria-orientation': this.options.vertical ? 'vertical' : 'horizontal',\n        'tabindex': 0\n      });\n    }\n    /**\n     * Sets the input and `aria-valuenow` values for the slider element.\n     * @function\n     * @private\n     * @param {jQuery} $handle - the currently selected handle.\n     * @param {Number} val - floating point of the new value.\n     */\n\n  }, {\n    key: \"_setValues\",\n    value: function _setValues($handle, val) {\n      var idx = this.options.doubleSided ? this.handles.index($handle) : 0;\n      this.inputs.eq(idx).val(val);\n      $handle.attr('aria-valuenow', val);\n    }\n    /**\n     * Handles events on the slider element.\n     * Calculates the new location of the current handle.\n     * If there are two handles and the bar was clicked, it determines which handle to move.\n     * @function\n     * @private\n     * @param {Object} e - the `event` object passed from the listener.\n     * @param {jQuery} $handle - the current handle to calculate for, if selected.\n     * @param {Number} val - floating point number for the new value of the slider.\n     * TODO clean this up, there's a lot of repeated code between this and the _setHandlePos fn.\n     */\n\n  }, {\n    key: \"_handleEvent\",\n    value: function _handleEvent(e, $handle, val) {\n      var value, hasVal;\n\n      if (!val) {\n        //click or drag events\n        e.preventDefault();\n\n        var _this = this,\n            vertical = this.options.vertical,\n            param = vertical ? 'height' : 'width',\n            direction = vertical ? 'top' : 'left',\n            eventOffset = vertical ? e.pageY : e.pageX,\n            halfOfHandle = this.$handle[0].getBoundingClientRect()[param] / 2,\n            barDim = this.$element[0].getBoundingClientRect()[param],\n            windowScroll = vertical ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollTop() : jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).scrollLeft();\n\n        var elemOffset = this.$element.offset()[direction]; // touch events emulated by the touch util give position relative to screen, add window.scroll to event coordinates...\n        // best way to guess this is simulated is if clientY == pageY\n\n        if (e.clientY === e.pageY) {\n          eventOffset = eventOffset + windowScroll;\n        }\n\n        var eventFromBar = eventOffset - elemOffset;\n        var barXY;\n\n        if (eventFromBar < 0) {\n          barXY = 0;\n        } else if (eventFromBar > barDim) {\n          barXY = barDim;\n        } else {\n          barXY = eventFromBar;\n        }\n\n        var offsetPct = percent(barXY, barDim);\n        value = this._value(offsetPct); // turn everything around for RTL, yay math!\n\n        if (Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"rtl\"])() && !this.options.vertical) {\n          value = this.options.end - value;\n        }\n\n        value = _this._adjustValue(null, value); //boolean flag for the setHandlePos fn, specifically for vertical sliders\n\n        hasVal = false;\n\n        if (!$handle) {\n          //figure out which handle it is, pass it to the next function.\n          var firstHndlPos = absPosition(this.$handle, direction, barXY, param),\n              secndHndlPos = absPosition(this.$handle2, direction, barXY, param);\n          $handle = firstHndlPos <= secndHndlPos ? this.$handle : this.$handle2;\n        }\n      } else {\n        //change event on input\n        value = this._adjustValue(null, val);\n        hasVal = true;\n      }\n\n      this._setHandlePos($handle, value, hasVal);\n    }\n    /**\n     * Adjustes value for handle in regard to step value. returns adjusted value\n     * @function\n     * @private\n     * @param {jQuery} $handle - the selected handle.\n     * @param {Number} value - value to adjust. used if $handle is falsy\n     */\n\n  }, {\n    key: \"_adjustValue\",\n    value: function _adjustValue($handle, value) {\n      var val,\n          step = this.options.step,\n          div = parseFloat(step / 2),\n          left,\n          prev_val,\n          next_val;\n\n      if (!!$handle) {\n        val = parseFloat($handle.attr('aria-valuenow'));\n      } else {\n        val = value;\n      }\n\n      if (val >= 0) {\n        left = val % step;\n      } else {\n        left = step + val % step;\n      }\n\n      prev_val = val - left;\n      next_val = prev_val + step;\n\n      if (left === 0) {\n        return val;\n      }\n\n      val = val >= prev_val + div ? next_val : prev_val;\n      return val;\n    }\n    /**\n     * Adds event listeners to the slider elements.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this._eventsForHandle(this.$handle);\n\n      if (this.handles[1]) {\n        this._eventsForHandle(this.$handle2);\n      }\n    }\n    /**\n     * Adds event listeners a particular handle\n     * @function\n     * @private\n     * @param {jQuery} $handle - the current handle to apply listeners to.\n     */\n\n  }, {\n    key: \"_eventsForHandle\",\n    value: function _eventsForHandle($handle) {\n      var _this = this,\n          curHandle,\n          timer;\n\n      var handleChangeEvent = function handleChangeEvent(e) {\n        var idx = _this.inputs.index(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n\n        _this._handleEvent(e, _this.handles.eq(idx), jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).val());\n      }; // IE only triggers the change event when the input loses focus which strictly follows the HTML specification\n      // listen for the enter key and trigger a change\n      // @see https://html.spec.whatwg.org/multipage/input.html#common-input-element-events\n\n\n      this.inputs.off('keyup.zf.slider').on('keyup.zf.slider', function (e) {\n        if (e.keyCode == 13) handleChangeEvent.call(this, e);\n      });\n      this.inputs.off('change.zf.slider').on('change.zf.slider', handleChangeEvent);\n\n      if (this.options.clickSelect) {\n        this.$element.off('click.zf.slider').on('click.zf.slider', function (e) {\n          if (_this.$element.data('dragging')) {\n            return false;\n          }\n\n          if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.target).is('[data-slider-handle]')) {\n            if (_this.options.doubleSided) {\n              _this._handleEvent(e);\n            } else {\n              _this._handleEvent(e, _this.$handle);\n            }\n          }\n        });\n      }\n\n      if (this.options.draggable) {\n        this.handles.addTouch();\n        var $body = jquery__WEBPACK_IMPORTED_MODULE_0___default()('body');\n        $handle.off('mousedown.zf.slider').on('mousedown.zf.slider', function (e) {\n          $handle.addClass('is-dragging');\n\n          _this.$fill.addClass('is-dragging'); //\n\n\n          _this.$element.data('dragging', true);\n\n          curHandle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget);\n          $body.on('mousemove.zf.slider', function (e) {\n            e.preventDefault();\n\n            _this._handleEvent(e, curHandle);\n          }).on('mouseup.zf.slider', function (e) {\n            _this._handleEvent(e, curHandle);\n\n            $handle.removeClass('is-dragging');\n\n            _this.$fill.removeClass('is-dragging');\n\n            _this.$element.data('dragging', false);\n\n            $body.off('mousemove.zf.slider mouseup.zf.slider');\n          });\n        }) // prevent events triggered by touch\n        .on('selectstart.zf.slider touchmove.zf.slider', function (e) {\n          e.preventDefault();\n        });\n      }\n\n      $handle.off('keydown.zf.slider').on('keydown.zf.slider', function (e) {\n        var _$handle = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            idx = _this.options.doubleSided ? _this.handles.index(_$handle) : 0,\n            oldValue = parseFloat(_this.inputs.eq(idx).val()),\n            newValue; // handle keyboard event with keyboard util\n\n\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"].handleKey(e, 'Slider', {\n          decrease: function decrease() {\n            newValue = oldValue - _this.options.step;\n          },\n          increase: function increase() {\n            newValue = oldValue + _this.options.step;\n          },\n          decrease_fast: function decrease_fast() {\n            newValue = oldValue - _this.options.step * 10;\n          },\n          increase_fast: function increase_fast() {\n            newValue = oldValue + _this.options.step * 10;\n          },\n          min: function min() {\n            newValue = _this.options.start;\n          },\n          max: function max() {\n            newValue = _this.options.end;\n          },\n          handled: function handled() {\n            // only set handle pos when event was handled specially\n            e.preventDefault();\n\n            _this._setHandlePos(_$handle, newValue, true);\n          }\n        });\n        /*if (newValue) { // if pressed key has special function, update value\n          e.preventDefault();\n          _this._setHandlePos(_$handle, newValue);\n        }*/\n      });\n    }\n    /**\n     * Destroys the slider plugin.\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.handles.off('.zf.slider');\n      this.inputs.off('.zf.slider');\n      this.$element.off('.zf.slider');\n      clearTimeout(this.timeout);\n    }\n  }]);\n\n  return Slider;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_3__[\"Plugin\"]);\n\nSlider.defaults = {\n  /**\n   * Minimum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  start: 0,\n\n  /**\n   * Maximum value for the slider scale.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  end: 100,\n\n  /**\n   * Minimum value change per change event.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  step: 1,\n\n  /**\n   * Value at which the handle/input *(left handle/first input)* should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  initialStart: 0,\n\n  /**\n   * Value at which the right handle/second input should be set to on initialization.\n   * @option\n   * @type {number}\n   * @default 100\n   */\n  initialEnd: 100,\n\n  /**\n   * Allows the input to be located outside the container and visible. Set to by the JS\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  binding: false,\n\n  /**\n   * Allows the user to click/tap on the slider bar to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickSelect: true,\n\n  /**\n   * Set to true and use the `vertical` class to change alignment to vertical.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  vertical: false,\n\n  /**\n   * Allows the user to drag the slider handle(s) to select a value.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  draggable: true,\n\n  /**\n   * Disables the slider and prevents event listeners from being applied. Double checked by JS with `disabledClass`.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disabled: false,\n\n  /**\n   * Allows the use of two handles. Double checked by the JS. Changes some logic handling.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  doubleSided: false,\n\n  /**\n   * Potential future feature.\n   */\n  // steps: 100,\n\n  /**\n   * Number of decimal places the plugin should go to for floating point precision.\n   * @option\n   * @type {number}\n   * @default 2\n   */\n  decimal: 2,\n\n  /**\n   * Time delay for dragged elements.\n   */\n  // dragDelay: 0,\n\n  /**\n   * Time, in ms, to animate the movement of a slider handle if user clicks/taps on the bar. Needs to be manually set if updating the transition time in the Sass settings.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  moveTime: 200,\n  //update this if changing the transition time in the sass\n\n  /**\n   * Class applied to disabled sliders.\n   * @option\n   * @type {string}\n   * @default 'disabled'\n   */\n  disabledClass: 'disabled',\n\n  /**\n   * Will invert the default layout for a vertical<span data-tooltip title=\"who would do this???\"> </span>slider.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  invertVertical: false,\n\n  /**\n   * Milliseconds before the `changed.zf-slider` event is triggered after value change.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  changedDelay: 500,\n\n  /**\n  * Basevalue for non-linear sliders\n  * @option\n  * @type {number}\n  * @default 5\n  */\n  nonLinearBase: 5,\n\n  /**\n  * Basevalue for non-linear sliders, possible values are: `'linear'`, `'pow'` & `'log'`. Pow and Log use the nonLinearBase setting.\n  * @option\n  * @type {string}\n  * @default 'linear'\n  */\n  positionValueFunction: 'linear'\n};\n\nfunction percent(frac, num) {\n  return frac / num;\n}\n\nfunction absPosition($handle, dir, clickPos, param) {\n  return Math.abs($handle.position()[dir] + $handle[param]() / 2 - clickPos);\n}\n\nfunction baseLog(base, value) {\n  return Math.log(value) / Math.log(base);\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 15:\n/*!*******************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.slider.js ***!\n  \\*******************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.slider.js */\"./js/entries/plugins/foundation.slider.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.slider.js.map"]}
\ No newline at end of file
index e45bc7f47fa19710109534022e8b87fca8763c17..cef3eabab810e4011cbf0d9b535c82342a330f96 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.smoothScroll"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.smoothScroll"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 95);
+/******/       return __webpack_require__(__webpack_require__.s = 16);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
-/***/ (function(module, exports) {
-
-module.exports = {Foundation: window.Foundation};
-
-/***/ }),
-
-/***/ 2:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 29:
+/***/ "./js/entries/plugins/foundation.smoothScroll.js":
+/*!*******************************************************!*\
+  !*** ./js/entries/plugins/foundation.smoothScroll.js ***!
+  \*******************************************************/
+/*! exports provided: Foundation, SmoothScroll */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_smoothScroll__ = __webpack_require__(59);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.smoothScroll */ "./js/foundation.smoothScroll.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "SmoothScroll", function() { return _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_1__["SmoothScroll"]; });
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_smoothScroll__["a" /* SmoothScroll */], 'SmoothScroll');
 
-/***/ }),
 
-/***/ 3:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_1__["SmoothScroll"], 'SmoothScroll');
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
 
 /***/ }),
 
-/***/ 59:
+/***/ "./js/foundation.smoothScroll.js":
+/*!***************************************!*\
+  !*** ./js/foundation.smoothScroll.js ***!
+  \***************************************/
+/*! exports provided: SmoothScroll */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return SmoothScroll; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "SmoothScroll", function() { return SmoothScroll; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-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 _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -141,163 +170,190 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @module foundation.smooth-scroll
  */
 
-var SmoothScroll = function (_Plugin) {
-    _inherits(SmoothScroll, _Plugin);
+var SmoothScroll =
+/*#__PURE__*/
+function (_Plugin) {
+  _inherits(SmoothScroll, _Plugin);
 
-    function SmoothScroll() {
-        _classCallCheck(this, SmoothScroll);
+  function SmoothScroll() {
+    _classCallCheck(this, SmoothScroll);
 
-        return _possibleConstructorReturn(this, (SmoothScroll.__proto__ || Object.getPrototypeOf(SmoothScroll)).apply(this, arguments));
-    }
-
-    _createClass(SmoothScroll, [{
-        key: '_setup',
-
-        /**
-         * Creates a new instance of SmoothScroll.
-         * @class
-         * @name SmoothScroll
-         * @fires SmoothScroll#init
-         * @param {Object} element - jQuery object to add the trigger to.
-         * @param {Object} options - Overrides to the default plugin settings.
-         */
-        value: function _setup(element, options) {
-            this.$element = element;
-            this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, SmoothScroll.defaults, this.$element.data(), options);
-            this.className = 'SmoothScroll'; // ie9 back compat
-
-            this._init();
-        }
-
-        /**
-         * Initialize the SmoothScroll plugin
-         * @private
-         */
-
-    }, {
-        key: '_init',
-        value: function _init() {
-            var id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["GetYoDigits"])(6, 'smooth-scroll');
-            var _this = this;
-            this.$element.attr({
-                'id': id
-            });
-
-            this._events();
-        }
+    return _possibleConstructorReturn(this, _getPrototypeOf(SmoothScroll).apply(this, arguments));
+  }
 
-        /**
-         * Initializes events for SmoothScroll.
-         * @private
-         */
+  _createClass(SmoothScroll, [{
+    key: "_setup",
 
-    }, {
-        key: '_events',
-        value: function _events() {
-            var _this = this;
+    /**
+     * Creates a new instance of SmoothScroll.
+     * @class
+     * @name SmoothScroll
+     * @fires SmoothScroll#init
+     * @param {Object} element - jQuery object to add the trigger to.
+     * @param {Object} options - Overrides to the default plugin settings.
+     */
+    value: function _setup(element, options) {
+      this.$element = element;
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, SmoothScroll.defaults, this.$element.data(), options);
+      this.className = 'SmoothScroll'; // ie9 back compat
 
-            // click handler function.
-            var handleLinkClick = function (e) {
-                // exit function if the event source isn't coming from an anchor with href attribute starts with '#'
-                if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is('a[href^="#"]')) {
-                    return false;
-                }
+      this._init();
+    }
+    /**
+     * Initialize the SmoothScroll plugin
+     * @private
+     */
 
-                var arrival = this.getAttribute('href');
+  }, {
+    key: "_init",
+    value: function _init() {
+      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'smooth-scroll');
+      this.$element.attr({
+        id: id
+      });
 
-                _this._inTransition = true;
+      this._events();
+    }
+    /**
+     * Initializes events for SmoothScroll.
+     * @private
+     */
 
-                SmoothScroll.scrollToLoc(arrival, _this.options, function () {
-                    _this._inTransition = false;
-                });
+  }, {
+    key: "_events",
+    value: function _events() {
+      this._linkClickListener = this._handleLinkClick.bind(this);
+      this.$element.on('click.zf.smoothScroll', this._linkClickListener);
+      this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
+    }
+    /**
+     * Handle the given event to smoothly scroll to the anchor pointed by the event target.
+     * @param {*} e - event
+     * @function
+     * @private
+     */
 
-                e.preventDefault();
-            };
+  }, {
+    key: "_handleLinkClick",
+    value: function _handleLinkClick(e) {
+      var _this = this;
+
+      // Follow the link if it does not point to an anchor.
+      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget).is('a[href^="#"]')) return;
+      var arrival = e.currentTarget.getAttribute('href');
+      this._inTransition = true;
+      SmoothScroll.scrollToLoc(arrival, this.options, function () {
+        _this._inTransition = false;
+      });
+      e.preventDefault();
+    }
+  }, {
+    key: "_destroy",
 
-            this.$element.on('click.zf.smoothScroll', handleLinkClick);
-            this.$element.on('click.zf.smoothScroll', 'a[href^="#"]', handleLinkClick);
-        }
+    /**
+     * Destroys the SmoothScroll instance.
+     * @function
+     */
+    value: function _destroy() {
+      this.$element.off('click.zf.smoothScroll', this._linkClickListener);
+      this.$element.off('click.zf.smoothScroll', 'a[href^="#"]', this._linkClickListener);
+    }
+  }], [{
+    key: "scrollToLoc",
 
-        /**
-         * Function to scroll to a given location on the page.
-         * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'
-         * @param {Object} options - The options to use.
-         * @param {Function} callback - The callback function.
-         * @static
-         * @function
-         */
-
-    }], [{
-        key: 'scrollToLoc',
-        value: function scrollToLoc(loc) {
-            var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults;
-            var callback = arguments[2];
-
-            // Do nothing if target does not exist to prevent errors
-            if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(loc).length) {
-                return false;
-            }
-
-            var scrollPos = Math.round(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(loc).offset().top - options.threshold / 2 - options.offset);
-
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').stop(true).animate({ scrollTop: scrollPos }, options.animationDuration, options.animationEasing, function () {
-                if (callback && typeof callback == "function") {
-                    callback();
-                }
-            });
+    /**
+     * Function to scroll to a given location on the page.
+     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'
+     * @param {Object} options - The options to use.
+     * @param {Function} callback - The callback function.
+     * @static
+     * @function
+     */
+    value: function scrollToLoc(loc) {
+      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults;
+      var callback = arguments.length > 2 ? arguments[2] : undefined;
+      var $loc = jquery__WEBPACK_IMPORTED_MODULE_0___default()(loc); // Do nothing if target does not exist to prevent errors
+
+      if (!$loc.length) return false;
+      var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({
+        scrollTop: scrollPos
+      }, options.animationDuration, options.animationEasing, function () {
+        if (typeof callback === 'function') {
+          callback();
         }
-    }]);
-
-    return SmoothScroll;
-}(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__["Plugin"]);
+      });
+    }
+  }]);
 
+  return SmoothScroll;
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 /**
  * Default settings for plugin.
  */
 
 
 SmoothScroll.defaults = {
-    /**
-     * Amount of time, in ms, the animated scrolling should take between locations.
-     * @option
-     * @type {number}
-     * @default 500
-     */
-    animationDuration: 500,
-    /**
-     * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
-     * @option
-     * @type {string}
-     * @default 'linear'
-     * @see {@link https://api.jquery.com/animate|Jquery animate}
-     */
-    animationEasing: 'linear',
-    /**
-     * Number of pixels to use as a marker for location changes.
-     * @option
-     * @type {number}
-     * @default 50
-     */
-    threshold: 50,
-    /**
-     * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
-     * @option
-     * @type {number}
-     * @default 0
-     */
-    offset: 0
+  /**
+   * Amount of time, in ms, the animated scrolling should take between locations.
+   * @option
+   * @type {number}
+   * @default 500
+   */
+  animationDuration: 500,
+
+  /**
+   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.
+   * @option
+   * @type {string}
+   * @default 'linear'
+   * @see {@link https://api.jquery.com/animate|Jquery animate}
+   */
+  animationEasing: 'linear',
+
+  /**
+   * Number of pixels to use as a marker for location changes.
+   * @option
+   * @type {number}
+   * @default 50
+   */
+  threshold: 50,
+
+  /**
+   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.
+   * @option
+   * @type {number}
+   * @default 0
+   */
+  offset: 0
 };
 
 
-
 /***/ }),
 
-/***/ 95:
+/***/ 16:
+/*!*************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.smoothScroll.js ***!
+  \*************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(29);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.smoothScroll.js */"./js/entries/plugins/foundation.smoothScroll.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.smoothScroll.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.smoothScroll.js.map b/dist/js/plugins/foundation.smoothScroll.js.map
new file mode 100644 (file)
index 0000000..4fa3a31
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.smoothScroll.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.smoothScroll.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","SmoothScroll","element","options","$element","$","extend","defaults","data","className","_init","id","GetYoDigits","attr","_events","_linkClickListener","_handleLinkClick","bind","on","e","currentTarget","is","arrival","getAttribute","_inTransition","scrollToLoc","preventDefault","off","loc","callback","$loc","length","scrollPos","Math","round","offset","top","threshold","stop","animate","scrollTop","animationDuration","animationEasing","Plugin"],"mappings":"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","file":"foundation.smoothScroll.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.smoothScroll\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.smoothScroll\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 16);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\n\nimport { SmoothScroll } from '../../foundation.smoothScroll';\nFoundation.plugin(SmoothScroll, 'SmoothScroll');\n\nexport { Foundation, SmoothScroll };\n","import $ from 'jquery';\nimport { GetYoDigits } from './foundation.core.utils';\nimport { Plugin } from './foundation.core.plugin';\n\n/**\n * SmoothScroll module.\n * @module foundation.smooth-scroll\n */\nclass SmoothScroll extends Plugin {\n  /**\n   * Creates a new instance of SmoothScroll.\n   * @class\n   * @name SmoothScroll\n   * @fires SmoothScroll#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n    _setup(element, options) {\n        this.$element = element;\n        this.options = $.extend({}, SmoothScroll.defaults, this.$element.data(), options);\n        this.className = 'SmoothScroll'; // ie9 back compat\n\n        this._init();\n    }\n\n    /**\n     * Initialize the SmoothScroll plugin\n     * @private\n     */\n    _init() {\n        const id = this.$element[0].id || GetYoDigits(6, 'smooth-scroll');\n        this.$element.attr({ id });\n\n        this._events();\n    }\n\n    /**\n     * Initializes events for SmoothScroll.\n     * @private\n     */\n    _events() {\n        this._linkClickListener = this._handleLinkClick.bind(this);\n        this.$element.on('click.zf.smoothScroll', this._linkClickListener);\n        this.$element.on('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n\n    /**\n     * Handle the given event to smoothly scroll to the anchor pointed by the event target.\n     * @param {*} e - event\n     * @function\n     * @private\n     */\n    _handleLinkClick(e) {\n        // Follow the link if it does not point to an anchor.\n        if (!$(e.currentTarget).is('a[href^=\"#\"]')) return;\n\n        const arrival = e.currentTarget.getAttribute('href');\n\n        this._inTransition = true;\n\n        SmoothScroll.scrollToLoc(arrival, this.options, () => {\n            this._inTransition = false;\n        });\n\n        e.preventDefault();\n    };\n\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'\n     * @param {Object} options - The options to use.\n     * @param {Function} callback - The callback function.\n     * @static\n     * @function\n     */\n    static scrollToLoc(loc, options = SmoothScroll.defaults, callback) {\n        const $loc = $(loc);\n\n        // Do nothing if target does not exist to prevent errors\n        if (!$loc.length) return false;\n\n        var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);\n\n        $('html, body').stop(true).animate(\n            { scrollTop: scrollPos },\n            options.animationDuration,\n            options.animationEasing,\n            () => {\n                if (typeof callback === 'function'){\n                    callback();\n                }\n            }\n        );\n    }\n\n    /**\n     * Destroys the SmoothScroll instance.\n     * @function\n     */\n    _destroy() {\n        this.$element.off('click.zf.smoothScroll', this._linkClickListener)\n        this.$element.off('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n}\n\n/**\n * Default settings for plugin.\n */\nSmoothScroll.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n}\n\nexport {SmoothScroll}\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 606e013c6fd418c908e9ccb35a9f15471a04cbbd..c14438ca69cbebd924170803c9d5b5bd47f45bc8 100644 (file)
@@ -1 +1,2 @@
-!function(t){function n(o){if(e[o])return e[o].exports;var i=e[o]={i:o,l:!1,exports:{}};return t[o].call(i.exports,i,i.exports,n),i.l=!0,i.exports}var e={};n.m=t,n.c=e,n.i=function(t){return t},n.d=function(t,e,o){n.o(t,e)||Object.defineProperty(t,e,{configurable:!1,enumerable:!0,get:o})},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,n){return Object.prototype.hasOwnProperty.call(t,n)},n.p="",n(n.s=95)}({0:function(t,n){t.exports=jQuery},1:function(t,n){t.exports={Foundation:window.Foundation}},2:function(t,n){t.exports={Plugin:window.Foundation.Plugin}},29:function(t,n,e){"use strict";Object.defineProperty(n,"__esModule",{value:!0});var o=e(1),i=(e.n(o),e(59));o.Foundation.plugin(i.a,"SmoothScroll")},3:function(t,n){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},59:function(t,n,e){"use strict";function o(t,n){if(!(t instanceof n))throw new TypeError("Cannot call a class as a function")}function i(t,n){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!n||"object"!=typeof n&&"function"!=typeof n?t:n}function r(t,n){if("function"!=typeof n&&null!==n)throw new TypeError("Super expression must either be null or a function, not "+typeof n);t.prototype=Object.create(n&&n.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),n&&(Object.setPrototypeOf?Object.setPrototypeOf(t,n):t.__proto__=n)}e.d(n,"a",function(){return f});var u=e(0),a=e.n(u),s=e(3),l=(e.n(s),e(2)),c=(e.n(l),function(){function t(t,n){for(var e=0;e<n.length;e++){var o=n[e];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}return function(n,e,o){return e&&t(n.prototype,e),o&&t(n,o),n}}()),f=function(t){function n(){return o(this,n),i(this,(n.__proto__||Object.getPrototypeOf(n)).apply(this,arguments))}return r(n,t),c(n,[{key:"_setup",value:function(t,e){this.$element=t,this.options=a.a.extend({},n.defaults,this.$element.data(),e),this.className="SmoothScroll",this._init()}},{key:"_init",value:function(){var t=this.$element[0].id||e.i(s.GetYoDigits)(6,"smooth-scroll");this.$element.attr({id:t}),this._events()}},{key:"_events",value:function(){var t=this,e=function(e){if(!a()(this).is('a[href^="#"]'))return!1;var o=this.getAttribute("href");t._inTransition=!0,n.scrollToLoc(o,t.options,function(){t._inTransition=!1}),e.preventDefault()};this.$element.on("click.zf.smoothScroll",e),this.$element.on("click.zf.smoothScroll",'a[href^="#"]',e)}}],[{key:"scrollToLoc",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:n.defaults,o=arguments[2];if(!a()(t).length)return!1;var i=Math.round(a()(t).offset().top-e.threshold/2-e.offset);a()("html, body").stop(!0).animate({scrollTop:i},e.animationDuration,e.animationEasing,function(){o&&"function"==typeof o&&o()})}}]),n}(l.Plugin);f.defaults={animationDuration:500,animationEasing:"linear",threshold:50,offset:0}},95:function(t,n,e){t.exports=e(29)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],e):"object"==typeof exports?exports["foundation.smoothScroll"]=e(require("./foundation.core"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.smoothScroll"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.jQuery))}(window,function(o,n){return function(o){var n={};function r(t){if(n[t])return n[t].exports;var e=n[t]={i:t,l:!1,exports:{}};return o[t].call(e.exports,e,e.exports,r),e.l=!0,e.exports}return r.m=o,r.c=n,r.d=function(t,e,o){r.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:o})},r.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var o=Object.create(null);if(r.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)r.d(o,n,function(t){return e[t]}.bind(null,n));return o},r.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return r.d(e,"a",e),e},r.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},r.p="",r(r.s=16)}({"./foundation.core":function(t,e){t.exports=o},"./js/entries/plugins/foundation.smoothScroll.js":function(t,e,o){"use strict";o.r(e);var n=o("./foundation.core");o.d(e,"Foundation",function(){return n.Foundation});var r=o("./js/foundation.smoothScroll.js");o.d(e,"SmoothScroll",function(){return r.SmoothScroll}),n.Foundation.plugin(r.SmoothScroll,"SmoothScroll")},"./js/foundation.smoothScroll.js":function(t,e,o){"use strict";o.r(e),o.d(e,"SmoothScroll",function(){return a});var n=o("jquery"),u=o.n(n),r=o("./foundation.core");function i(t){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function l(t,e){for(var o=0;o<e.length;o++){var n=e[o];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}function c(t,e){return!e||"object"!==i(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function s(t,e){return(s=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var a=function(t){function i(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),c(this,f(i).apply(this,arguments))}var e,o,n;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&s(t,e)}(i,r["Plugin"]),e=i,n=[{key:"scrollToLoc",value:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:i.defaults,o=2<arguments.length?arguments[2]:void 0,n=u()(t);if(!n.length)return!1;var r=Math.round(n.offset().top-e.threshold/2-e.offset);u()("html, body").stop(!0).animate({scrollTop:r},e.animationDuration,e.animationEasing,function(){"function"==typeof o&&o()})}}],(o=[{key:"_setup",value:function(t,e){this.$element=t,this.options=u.a.extend({},i.defaults,this.$element.data(),e),this.className="SmoothScroll",this._init()}},{key:"_init",value:function(){var t=this.$element[0].id||Object(r.GetYoDigits)(6,"smooth-scroll");this.$element.attr({id:t}),this._events()}},{key:"_events",value:function(){this._linkClickListener=this._handleLinkClick.bind(this),this.$element.on("click.zf.smoothScroll",this._linkClickListener),this.$element.on("click.zf.smoothScroll",'a[href^="#"]',this._linkClickListener)}},{key:"_handleLinkClick",value:function(t){var e=this;if(u()(t.currentTarget).is('a[href^="#"]')){var o=t.currentTarget.getAttribute("href");this._inTransition=!0,i.scrollToLoc(o,this.options,function(){e._inTransition=!1}),t.preventDefault()}}},{key:"_destroy",value:function(){this.$element.off("click.zf.smoothScroll",this._linkClickListener),this.$element.off("click.zf.smoothScroll",'a[href^="#"]',this._linkClickListener)}}])&&l(e.prototype,o),n&&l(e,n),i}();a.defaults={animationDuration:500,animationEasing:"linear",threshold:50,offset:0}},16:function(t,e,o){t.exports=o("./js/entries/plugins/foundation.smoothScroll.js")},jquery:function(t,e){t.exports=n}})});
+//# sourceMappingURL=foundation.smoothScroll.min.js.map
diff --git a/dist/js/plugins/foundation.smoothScroll.min.js.map b/dist/js/plugins/foundation.smoothScroll.min.js.map
new file mode 100644 (file)
index 0000000..fc15d1d
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.smoothScroll.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.smoothScroll.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.smoothScroll.js","SmoothScroll","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","loc","options","undefined","defaults","callback","$loc","scrollPos","Math","round","offset","top","threshold","stop","animate","scrollTop","animationDuration","animationEasing","element","$element","a","extend","data","className","_init","id","attr","_events","_linkClickListener","_handleLinkClick","on","e","_this","currentTarget","is","arrival","getAttribute","_inTransition","scrollToLoc","preventDefault","off","16","jquery"],"mappings":"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","file":"foundation.smoothScroll.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.smoothScroll\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.smoothScroll\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 16);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.smoothScroll.js\":\n/*!*******************************************************!*\\\n  !*** ./js/entries/plugins/foundation.smoothScroll.js ***!\n  \\*******************************************************/\n/*! exports provided: Foundation, SmoothScroll */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.smoothScroll */ \"./js/foundation.smoothScroll.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"SmoothScroll\", function() { return _foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_1__[\"SmoothScroll\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_smoothScroll__WEBPACK_IMPORTED_MODULE_1__[\"SmoothScroll\"], 'SmoothScroll');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.smoothScroll.js\":\n/*!***************************************!*\\\n  !*** ./js/foundation.smoothScroll.js ***!\n  \\***************************************/\n/*! exports provided: SmoothScroll */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"SmoothScroll\", function() { return SmoothScroll; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n/**\n * SmoothScroll module.\n * @module foundation.smooth-scroll\n */\n\nvar SmoothScroll =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(SmoothScroll, _Plugin);\n\n  function SmoothScroll() {\n    _classCallCheck(this, SmoothScroll);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(SmoothScroll).apply(this, arguments));\n  }\n\n  _createClass(SmoothScroll, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of SmoothScroll.\n     * @class\n     * @name SmoothScroll\n     * @fires SmoothScroll#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, SmoothScroll.defaults, this.$element.data(), options);\n      this.className = 'SmoothScroll'; // ie9 back compat\n\n      this._init();\n    }\n    /**\n     * Initialize the SmoothScroll plugin\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'smooth-scroll');\n      this.$element.attr({\n        id: id\n      });\n\n      this._events();\n    }\n    /**\n     * Initializes events for SmoothScroll.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this._linkClickListener = this._handleLinkClick.bind(this);\n      this.$element.on('click.zf.smoothScroll', this._linkClickListener);\n      this.$element.on('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n    /**\n     * Handle the given event to smoothly scroll to the anchor pointed by the event target.\n     * @param {*} e - event\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_handleLinkClick\",\n    value: function _handleLinkClick(e) {\n      var _this = this;\n\n      // Follow the link if it does not point to an anchor.\n      if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(e.currentTarget).is('a[href^=\"#\"]')) return;\n      var arrival = e.currentTarget.getAttribute('href');\n      this._inTransition = true;\n      SmoothScroll.scrollToLoc(arrival, this.options, function () {\n        _this._inTransition = false;\n      });\n      e.preventDefault();\n    }\n  }, {\n    key: \"_destroy\",\n\n    /**\n     * Destroys the SmoothScroll instance.\n     * @function\n     */\n    value: function _destroy() {\n      this.$element.off('click.zf.smoothScroll', this._linkClickListener);\n      this.$element.off('click.zf.smoothScroll', 'a[href^=\"#\"]', this._linkClickListener);\n    }\n  }], [{\n    key: \"scrollToLoc\",\n\n    /**\n     * Function to scroll to a given location on the page.\n     * @param {String} loc - A properly formatted jQuery id selector. Example: '#foo'\n     * @param {Object} options - The options to use.\n     * @param {Function} callback - The callback function.\n     * @static\n     * @function\n     */\n    value: function scrollToLoc(loc) {\n      var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : SmoothScroll.defaults;\n      var callback = arguments.length > 2 ? arguments[2] : undefined;\n      var $loc = jquery__WEBPACK_IMPORTED_MODULE_0___default()(loc); // Do nothing if target does not exist to prevent errors\n\n      if (!$loc.length) return false;\n      var scrollPos = Math.round($loc.offset().top - options.threshold / 2 - options.offset);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').stop(true).animate({\n        scrollTop: scrollPos\n      }, options.animationDuration, options.animationEasing, function () {\n        if (typeof callback === 'function') {\n          callback();\n        }\n      });\n    }\n  }]);\n\n  return SmoothScroll;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n/**\n * Default settings for plugin.\n */\n\n\nSmoothScroll.defaults = {\n  /**\n   * Amount of time, in ms, the animated scrolling should take between locations.\n   * @option\n   * @type {number}\n   * @default 500\n   */\n  animationDuration: 500,\n\n  /**\n   * Animation style to use when scrolling between locations. Can be `'swing'` or `'linear'`.\n   * @option\n   * @type {string}\n   * @default 'linear'\n   * @see {@link https://api.jquery.com/animate|Jquery animate}\n   */\n  animationEasing: 'linear',\n\n  /**\n   * Number of pixels to use as a marker for location changes.\n   * @option\n   * @type {number}\n   * @default 50\n   */\n  threshold: 50,\n\n  /**\n   * Number of pixels to offset the scroll of the page on item click if using a sticky nav bar.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  offset: 0\n};\n\n\n/***/ }),\n\n/***/ 16:\n/*!*************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.smoothScroll.js ***!\n  \\*************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.smoothScroll.js */\"./js/entries/plugins/foundation.smoothScroll.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.smoothScroll.js.map"]}
\ No newline at end of file
index 9082ef415fad0fe243ca995cd24cf3216a90be1b..d9d8d34f5f6cc1a25636464353592e86c3c88633 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.mediaQuery", "./foundation.util.motion", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.sticky"] = factory(require("./foundation.core"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.sticky"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 96);
+/******/       return __webpack_require__(__webpack_require__.s = 17);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 2:
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Plugin: window.Foundation.Plugin};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
 
 /***/ }),
 
-/***/ 3:
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
 /***/ }),
 
-/***/ 30:
+/***/ "./js/entries/plugins/foundation.sticky.js":
+/*!*************************************************!*\
+  !*** ./js/entries/plugins/foundation.sticky.js ***!
+  \*************************************************/
+/*! exports provided: Foundation, Sticky */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_sticky__ = __webpack_require__(60);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_sticky__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.sticky */ "./js/foundation.sticky.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Sticky", function() { return _foundation_sticky__WEBPACK_IMPORTED_MODULE_1__["Sticky"]; });
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_sticky__["a" /* Sticky */], 'Sticky');
 
-/***/ }),
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_sticky__WEBPACK_IMPORTED_MODULE_1__["Sticky"], 'Sticky');
 
-/***/ 4:
-/***/ (function(module, exports) {
-
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
 
 /***/ }),
 
-/***/ 6:
-/***/ (function(module, exports) {
-
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
-
-/***/ }),
-
-/***/ 60:
+/***/ "./js/foundation.sticky.js":
+/*!*********************************!*\
+  !*** ./js/foundation.sticky.js ***!
+  \*********************************/
+/*! exports provided: Sticky */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Sticky; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_util_triggers__ = __webpack_require__(7);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Sticky", function() { return Sticky; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return 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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -162,17 +201,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.mediaQuery
  */
 
-var Sticky = function (_Plugin) {
+var Sticky =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Sticky, _Plugin);
 
   function Sticky() {
     _classCallCheck(this, Sticky);
 
-    return _possibleConstructorReturn(this, (Sticky.__proto__ || Object.getPrototypeOf(Sticky)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments));
   }
 
   _createClass(Sticky, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of a sticky thing.
@@ -183,15 +224,14 @@ var Sticky = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Sticky.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Sticky.defaults, this.$element.data(), options);
       this.className = 'Sticky'; // ie9 back compat
-
       // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_4__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
       this._init();
     }
-
     /**
      * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes
      * @function
@@ -199,12 +239,12 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"]._init();
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"]._init();
 
       var $parent = this.$element.parent('[data-sticky-container]'),
-          id = this.$element[0].id || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["GetYoDigits"])(6, 'sticky'),
+          id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'sticky'),
           _this = this;
 
       if ($parent.length) {
@@ -214,38 +254,49 @@ var Sticky = function (_Plugin) {
         this.$element.wrap(this.options.container);
         this.$container = this.$element.parent();
       }
+
       this.$container.addClass(this.options.containerClass);
+      this.$element.addClass(this.options.stickyClass).attr({
+        'data-resize': id,
+        'data-mutate': id
+      });
 
-      this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });
       if (this.options.anchor !== '') {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + _this.options.anchor).attr({ 'data-mutate': id });
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor).attr({
+          'data-mutate': id
+        });
       }
 
       this.scrollCount = this.options.checkEvery;
       this.isStuck = false;
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).one('load.zf.sticky', function () {
+      this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
         //We calculate the container height to have correct values for anchor points offset calculation.
         _this.containerHeight = _this.$element.css("display") == "none" ? 0 : _this.$element[0].getBoundingClientRect().height;
+
         _this.$container.css('height', _this.containerHeight);
+
         _this.elemHeight = _this.containerHeight;
+
         if (_this.options.anchor !== '') {
-          _this.$anchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + _this.options.anchor);
+          _this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor);
         } else {
           _this._parsePoints();
         }
 
         _this._setSizes(function () {
           var scroll = window.pageYOffset;
-          _this._calc(false, scroll);
-          //Unstick the element will ensure that proper classes are set.
+
+          _this._calc(false, scroll); //Unstick the element will ensure that proper classes are set.
+
+
           if (!_this.isStuck) {
             _this._removeSticky(scroll >= _this.topPoint ? false : true);
           }
         });
+
         _this._events(id.split('-').reverse().join('-'));
       });
     }
-
     /**
      * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.
      * @function
@@ -253,32 +304,34 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_parsePoints',
+    key: "_parsePoints",
     value: function _parsePoints() {
       var top = this.options.topAnchor == "" ? 1 : this.options.topAnchor,
           btm = this.options.btmAnchor == "" ? document.documentElement.scrollHeight : this.options.btmAnchor,
           pts = [top, btm],
           breaks = {};
+
       for (var i = 0, len = pts.length; i < len && pts[i]; i++) {
         var pt;
+
         if (typeof pts[i] === 'number') {
           pt = pts[i];
         } else {
           var place = pts[i].split(':'),
-              anchor = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + place[0]);
-
+              anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(place[0]));
           pt = anchor.offset().top;
+
           if (place[1] && place[1].toLowerCase() === 'bottom') {
             pt += anchor[0].getBoundingClientRect().height;
           }
         }
+
         breaks[i] = pt;
       }
 
       this.points = breaks;
       return;
     }
-
     /**
      * Adds event handlers for the scrolling element.
      * @private
@@ -286,23 +339,27 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events(id) {
       var _this = this,
-          scrollListener = this.scrollListener = 'scroll.zf.' + id;
+          scrollListener = this.scrollListener = "scroll.zf.".concat(id);
+
       if (this.isOn) {
         return;
       }
+
       if (this.canStick) {
         this.isOn = true;
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(scrollListener).on(scrollListener, function (e) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener).on(scrollListener, function (e) {
           if (_this.scrollCount === 0) {
             _this.scrollCount = _this.options.checkEvery;
+
             _this._setSizes(function () {
               _this._calc(false, window.pageYOffset);
             });
           } else {
             _this.scrollCount--;
+
             _this._calc(false, window.pageYOffset);
           }
         });
@@ -311,7 +368,6 @@ var Sticky = function (_Plugin) {
       this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) {
         _this._eventsHandler(id);
       });
-
       this.$element.on('mutateme.zf.trigger', function (e, el) {
         _this._eventsHandler(id);
       });
@@ -322,7 +378,6 @@ var Sticky = function (_Plugin) {
         });
       }
     }
-
     /**
      * Handler for events.
      * @private
@@ -330,13 +385,14 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_eventsHandler',
+    key: "_eventsHandler",
     value: function _eventsHandler(id) {
       var _this = this,
-          scrollListener = this.scrollListener = 'scroll.zf.' + id;
+          scrollListener = this.scrollListener = "scroll.zf.".concat(id);
 
       _this._setSizes(function () {
         _this._calc(false);
+
         if (_this.canStick) {
           if (!_this.isOn) {
             _this._events(id);
@@ -346,7 +402,6 @@ var Sticky = function (_Plugin) {
         }
       });
     }
-
     /**
      * Removes event handlers for scroll and change events on anchor.
      * @fires Sticky#pause
@@ -354,19 +409,18 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_pauseListeners',
+    key: "_pauseListeners",
     value: function _pauseListeners(scrollListener) {
       this.isOn = false;
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(scrollListener);
-
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener);
       /**
        * Fires when the plugin is paused due to resize event shrinking the view.
        * @event Sticky#pause
        * @private
        */
+
       this.$element.trigger('pause.zf.sticky');
     }
-
     /**
      * Called on every `scroll` event and on `_init`
      * fires functions based on booleans and cached values
@@ -375,7 +429,7 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_calc',
+    key: "_calc",
     value: function _calc(checkSizes, scroll) {
       if (checkSizes) {
         this._setSizes();
@@ -385,6 +439,7 @@ var Sticky = function (_Plugin) {
         if (this.isStuck) {
           this._removeSticky(true);
         }
+
         return false;
       }
 
@@ -408,7 +463,6 @@ var Sticky = function (_Plugin) {
         }
       }
     }
-
     /**
      * Causes the $element to become stuck.
      * Adds `position: fixed;`, and helper classes.
@@ -418,7 +472,7 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_setSticky',
+    key: "_setSticky",
     value: function _setSticky() {
       var _this = this,
           stickTo = this.options.stickTo,
@@ -426,22 +480,21 @@ var Sticky = function (_Plugin) {
           notStuckTo = stickTo === 'top' ? 'bottom' : 'top',
           css = {};
 
-      css[mrgn] = this.options[mrgn] + 'em';
+      css[mrgn] = "".concat(this.options[mrgn], "em");
       css[stickTo] = 0;
       css[notStuckTo] = 'auto';
       this.isStuck = true;
-      this.$element.removeClass('is-anchored is-at-' + notStuckTo).addClass('is-stuck is-at-' + stickTo).css(css)
+      this.$element.removeClass("is-anchored is-at-".concat(notStuckTo)).addClass("is-stuck is-at-".concat(stickTo)).css(css)
       /**
        * Fires when the $element has become `position: fixed;`
        * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`
        * @event Sticky#stuckto
        */
-      .trigger('sticky.zf.stuckto:' + stickTo);
+      .trigger("sticky.zf.stuckto:".concat(stickTo));
       this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd", function () {
         _this._setSizes();
       });
     }
-
     /**
      * Causes the $element to become unstuck.
      * Removes `position: fixed;`, and helper classes.
@@ -452,7 +505,7 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_removeSticky',
+    key: "_removeSticky",
     value: function _removeSticky(isTop) {
       var stickTo = this.options.stickTo,
           stickToTop = stickTo === 'top',
@@ -461,10 +514,9 @@ var Sticky = function (_Plugin) {
           mrgn = stickToTop ? 'marginTop' : 'marginBottom',
           notStuckTo = stickToTop ? 'bottom' : 'top',
           topOrBottom = isTop ? 'top' : 'bottom';
-
       css[mrgn] = 0;
-
       css['bottom'] = 'auto';
+
       if (isTop) {
         css['top'] = 0;
       } else {
@@ -472,15 +524,14 @@ var Sticky = function (_Plugin) {
       }
 
       this.isStuck = false;
-      this.$element.removeClass('is-stuck is-at-' + stickTo).addClass('is-anchored is-at-' + topOrBottom).css(css)
+      this.$element.removeClass("is-stuck is-at-".concat(stickTo)).addClass("is-anchored is-at-".concat(topOrBottom)).css(css)
       /**
        * Fires when the $element has become anchored.
        * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`
        * @event Sticky#unstuckfrom
        */
-      .trigger('sticky.zf.unstuckfrom:' + topOrBottom);
+      .trigger("sticky.zf.unstuckfrom:".concat(topOrBottom));
     }
-
     /**
      * Sets the $element and $container sizes for plugin.
      * Calls `_setBreakPoints`.
@@ -489,14 +540,16 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_setSizes',
+    key: "_setSizes",
     value: function _setSizes(cb) {
-      this.canStick = __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"].is(this.options.stickyOn);
+      this.canStick = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"].is(this.options.stickyOn);
+
       if (!this.canStick) {
         if (cb && typeof cb === 'function') {
           cb();
         }
       }
+
       var _this = this,
           newElemWidth = this.$container[0].getBoundingClientRect().width,
           comp = window.getComputedStyle(this.$container[0]),
@@ -510,13 +563,14 @@ var Sticky = function (_Plugin) {
       }
 
       this.$element.css({
-        'max-width': newElemWidth - pdngl - pdngr + 'px'
+        'max-width': "".concat(newElemWidth - pdngl - pdngr, "px")
       });
-
       var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;
+
       if (this.$element.css("display") == "none") {
         newContainerHeight = 0;
       }
+
       this.containerHeight = newContainerHeight;
       this.$container.css({
         height: newContainerHeight
@@ -536,7 +590,6 @@ var Sticky = function (_Plugin) {
         }
       });
     }
-
     /**
      * Sets the upper and lower breakpoints for the element to become sticky/unsticky.
      * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.
@@ -545,7 +598,7 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_setBreakPoints',
+    key: "_setBreakPoints",
     value: function _setBreakPoints(elemHeight, cb) {
       if (!this.canStick) {
         if (cb && typeof cb === 'function') {
@@ -554,12 +607,12 @@ var Sticky = function (_Plugin) {
           return false;
         }
       }
+
       var mTop = emCalc(this.options.marginTop),
           mBtm = emCalc(this.options.marginBottom),
           topPoint = this.points ? this.points[0] : this.$anchor.offset().top,
           bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,
-
-      // topPoint = this.$anchor.offset().top || this.points[0],
+          // topPoint = this.$anchor.offset().top || this.points[0],
       // bottomPoint = topPoint + this.anchorHeight || this.points[1],
       winHeight = window.innerHeight;
 
@@ -569,8 +622,7 @@ var Sticky = function (_Plugin) {
       } else if (this.options.stickTo === 'bottom') {
         topPoint -= winHeight - (elemHeight + mBtm);
         bottomPoint -= winHeight - mBtm;
-      } else {
-        //this would be the stickTo: both option... tricky
+      } else {//this would be the stickTo: both option... tricky
       }
 
       this.topPoint = topPoint;
@@ -580,7 +632,6 @@ var Sticky = function (_Plugin) {
         cb();
       }
     }
-
     /**
      * Destroys the current sticky element.
      * Resets the element to the top position first.
@@ -589,20 +640,23 @@ var Sticky = function (_Plugin) {
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this._removeSticky(true);
 
-      this.$element.removeClass(this.options.stickyClass + ' is-anchored is-at-top').css({
+      this.$element.removeClass("".concat(this.options.stickyClass, " is-anchored is-at-top")).css({
         height: '',
         top: '',
         bottom: '',
         'max-width': ''
       }).off('resizeme.zf.trigger').off('mutateme.zf.trigger');
+
       if (this.$anchor && this.$anchor.length) {
         this.$anchor.off('change.zf.sticky');
       }
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(this.scrollListener);
+
+      if (this.scrollListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.scrollListener);
+      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
 
       if (this.wasWrapped) {
         this.$element.unwrap();
@@ -615,7 +669,7 @@ var Sticky = function (_Plugin) {
   }]);
 
   return Sticky;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 
 Sticky.defaults = {
   /**
@@ -625,6 +679,7 @@ Sticky.defaults = {
    * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'
    */
   container: '<div data-sticky-container></div>',
+
   /**
    * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.
    * @option
@@ -632,6 +687,7 @@ Sticky.defaults = {
    * @default 'top'
    */
   stickTo: 'top',
+
   /**
    * If anchored to a single element, the id of that element.
    * @option
@@ -639,6 +695,7 @@ Sticky.defaults = {
    * @default ''
    */
   anchor: '',
+
   /**
    * If using more than one element as anchor points, the id of the top anchor.
    * @option
@@ -646,6 +703,7 @@ Sticky.defaults = {
    * @default ''
    */
   topAnchor: '',
+
   /**
    * If using more than one element as anchor points, the id of the bottom anchor.
    * @option
@@ -653,6 +711,7 @@ Sticky.defaults = {
    * @default ''
    */
   btmAnchor: '',
+
   /**
    * Margin, in `em`'s to apply to the top of the element when it becomes sticky.
    * @option
@@ -660,6 +719,7 @@ Sticky.defaults = {
    * @default 1
    */
   marginTop: 1,
+
   /**
    * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.
    * @option
@@ -667,6 +727,7 @@ Sticky.defaults = {
    * @default 1
    */
   marginBottom: 1,
+
   /**
    * Breakpoint string that is the minimum screen size an element should become sticky.
    * @option
@@ -674,6 +735,7 @@ Sticky.defaults = {
    * @default 'medium'
    */
   stickyOn: 'medium',
+
   /**
    * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.
    * @option
@@ -681,6 +743,7 @@ Sticky.defaults = {
    * @default 'sticky'
    */
   stickyClass: 'sticky',
+
   /**
    * Class applied to sticky container. Foundation defaults to `sticky-container`.
    * @option
@@ -688,6 +751,7 @@ Sticky.defaults = {
    * @default 'sticky-container'
    */
   containerClass: 'sticky-container',
+
   /**
    * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.
    * @option
@@ -696,11 +760,11 @@ Sticky.defaults = {
    */
   checkEvery: -1
 };
-
 /**
  * Helper function to calculate em values
  * @param Number {em} - number of em's to calculate into pixels
  */
+
 function emCalc(em) {
   return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;
 }
@@ -709,15 +773,25 @@ function emCalc(em) {
 
 /***/ }),
 
-/***/ 7:
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
@@ -725,17 +799,19 @@ function emCalc(em) {
 
 var MutationObserver = function () {
   var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
   for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
     }
   }
+
   return false;
 }();
 
-var triggers = function (el, type) {
+var triggers = function triggers(el, type) {
   el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
   });
 };
 
@@ -746,138 +822,142 @@ var Triggers = {
   },
   Initializers: {}
 };
-
 Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
   },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
     }
   },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
     }
   },
-  closeableListener: function (e) {
+  closeableListener: function closeableListener(e) {
     e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
     if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
       });
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
     }
   },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
-};
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
 Triggers.Initializers.addOpenListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
   $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
-
-// Elements with [data-close] will close a plugin that supports it when clicked.
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
 // If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
 Triggers.Initializers.addCloseListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
   $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 Triggers.Initializers.addToggleListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
   $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
 Triggers.Initializers.addCloseableListener = function ($elem) {
   $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
   $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
 Triggers.Initializers.addToggleFocusListener = function ($elem) {
   $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
   $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+}; // More Global/complex listeners and triggers
+
 
-// More Global/complex listeners and triggers
 Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
+  resizeListener: function resizeListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a resize event
+    } //trigger all listening elements and signal a resize event
+
+
     $nodes.attr('data-events', "resize");
   },
-  scrollListener: function ($nodes) {
+  scrollListener: function scrollListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a scroll event
+    } //trigger all listening elements and signal a scroll event
+
+
     $nodes.attr('data-events', "scroll");
   },
-  closeMeListener: function (e, pluginId) {
+  closeMeListener: function closeMeListener(e, pluginId) {
     var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
-
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
     plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+
       _this.triggerHandler('close.zf.trigger', [_this]);
     });
-  }
+  } // Global, parses whole document.
+
+};
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
       plugNames = ['dropdown', 'tooltip', 'reveal'];
 
   if (pluginName) {
     if (typeof pluginName === 'string') {
       plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
     } else {
       console.error('Plugin names must be strings');
     }
   }
+
   if (yetiBoxes.length) {
     var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
+      return "closeme.zf.".concat(name);
     }).join(' ');
-
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
   }
 };
 
 function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
+  var timer,
       args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
     if (timer) {
       clearTimeout(timer);
     }
+
     timer = setTimeout(function () {
       listener.apply(null, args);
     }, debounce || 10); //default time to emit scroll event
@@ -885,14 +965,16 @@ function debounceGlobalListener(debounce, trigger, listener) {
 }
 
 Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
   }
 };
 
 Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
   }
@@ -902,25 +984,27 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
   if (!MutationObserver) {
     return false;
   }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
 
-    //trigger the event handler for the element depending on type
     switch (mutationRecordsList[0].type) {
       case "attributes":
         if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
+
         if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
+
         if (mutationRecordsList[0].attributeName === "style") {
           $target.closest("[data-mutate]").attr("data-events", "mutate");
           $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
         }
+
         break;
 
       case "childList":
@@ -938,14 +1022,19 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
     //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
     for (var i = 0; i <= $nodes.length - 1; i++) {
       var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
   }
 };
 
 Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addOpenListener($document);
   Triggers.Initializers.addCloseListener($document);
   Triggers.Initializers.addToggleListener($document);
@@ -954,7 +1043,7 @@ Triggers.Initializers.addSimpleListeners = function () {
 };
 
 Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addMutationEventsListener($document);
   Triggers.Initializers.addResizeListener();
   Triggers.Initializers.addScrollListener();
@@ -962,25 +1051,17 @@ Triggers.Initializers.addGlobalListeners = function () {
 };
 
 Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
-
-    if (document.readyState === "complete") {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
       Triggers.Initializers.addSimpleListeners();
       Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
-      });
+      $.triggersInitialized = true;
     }
-
-    $.triggersInitialized = true;
-  }
+  });
 
   if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
     Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
   }
 };
@@ -989,12 +1070,29 @@ Triggers.init = function ($, Foundation) {
 
 /***/ }),
 
-/***/ 96:
+/***/ 17:
+/*!*******************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.sticky.js ***!
+  \*******************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(30);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.sticky.js */"./js/entries/plugins/foundation.sticky.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.sticky.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.sticky.js.map b/dist/js/plugins/foundation.sticky.js.map
new file mode 100644 (file)
index 0000000..51d54f4
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.sticky.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.sticky.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Sticky","element","options","$element","$","extend","defaults","data","className","Triggers","init","_init","MediaQuery","$parent","parent","id","GetYoDigits","_this","length","$container","wasWrapped","wrap","container","addClass","containerClass","stickyClass","attr","anchor","scrollCount","checkEvery","isStuck","onLoadListener","onLoad","window","containerHeight","css","getBoundingClientRect","height","elemHeight","$anchor","_parsePoints","_setSizes","scroll","pageYOffset","_calc","_removeSticky","topPoint","_events","split","reverse","join","top","topAnchor","btm","btmAnchor","document","documentElement","scrollHeight","pts","breaks","i","len","pt","place","offset","toLowerCase","points","scrollListener","isOn","canStick","off","on","e","el","_eventsHandler","_pauseListeners","trigger","checkSizes","bottomPoint","_setSticky","stickTo","mrgn","notStuckTo","removeClass","isTop","stickToTop","anchorPt","anchorHeight","topOrBottom","cb","is","stickyOn","newElemWidth","width","comp","getComputedStyle","pdngl","parseInt","pdngr","newContainerHeight","hasClass","_setBreakPoints","mTop","emCalc","marginTop","mBtm","marginBottom","winHeight","innerHeight","bottom","unwrap","Plugin","em","body","fontSize","MutationObserver","prefixes","triggers","type","forEach","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","Motion","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","closeMeListener","pluginId","namespace","plugins","not","addClosemeListener","pluginName","yetiBoxes","plugNames","push","concat","console","error","listeners","map","name","debounceGlobalListener","debounce","listener","timer","args","Array","prototype","slice","call","arguments","clearTimeout","setTimeout","apply","addResizeListener","addScrollListener","addMutationEventsListener","find","listeningElementsMutation","mutationRecordsList","$target","target","attributeName","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","triggersInitialized","IHearYou"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yEAAyE;AACzE,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;AClFA,8D;;;;;;;;;;;ACAA,yE;;;;;;;;;;;ACAA,qE;;;;;;;;;;;;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AACAA,2DAAU,CAACC,MAAX,CAAkBC,yDAAlB,EAA0B,QAA1B;;;;;;;;;;;;;ACHA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAa;;;;;;;;;;;;;;;;;;;;AAEb;AACA;AACA;AACA;AACA;AAEA;;;;;;;IAOMA,M;;;;;;;;;;;;;;AACJ;;;;;;;2BAOOC,O,EAASC,O,EAAS;AACvB,WAAKC,QAAL,GAAgBF,OAAhB;AACA,WAAKC,OAAL,GAAeE,6CAAC,CAACC,MAAF,CAAS,EAAT,EAAaL,MAAM,CAACM,QAApB,EAA8B,KAAKH,QAAL,CAAcI,IAAd,EAA9B,EAAoDL,OAApD,CAAf;AACA,WAAKM,SAAL,GAAiB,QAAjB,CAHuB,CAGI;AAE3B;;AACAC,wEAAQ,CAACC,IAAT,CAAcN,6CAAd;;AAEA,WAAKO,KAAL;AACD;AAED;;;;;;;;4BAKQ;AACNC,4EAAU,CAACD,KAAX;;AAEA,UAAIE,OAAO,GAAG,KAAKV,QAAL,CAAcW,MAAd,CAAqB,yBAArB,CAAd;AAAA,UACIC,EAAE,GAAG,KAAKZ,QAAL,CAAc,CAAd,EAAiBY,EAAjB,IAAuBC,0EAAW,CAAC,CAAD,EAAI,QAAJ,CAD3C;AAAA,UAEIC,KAAK,GAAG,IAFZ;;AAIA,UAAGJ,OAAO,CAACK,MAAX,EAAkB;AAChB,aAAKC,UAAL,GAAkBN,OAAlB;AACD,OAFD,MAEO;AACL,aAAKO,UAAL,GAAkB,IAAlB;AACA,aAAKjB,QAAL,CAAckB,IAAd,CAAmB,KAAKnB,OAAL,CAAaoB,SAAhC;AACA,aAAKH,UAAL,GAAkB,KAAKhB,QAAL,CAAcW,MAAd,EAAlB;AACD;;AACD,WAAKK,UAAL,CAAgBI,QAAhB,CAAyB,KAAKrB,OAAL,CAAasB,cAAtC;AAEA,WAAKrB,QAAL,CAAcoB,QAAd,CAAuB,KAAKrB,OAAL,CAAauB,WAApC,EAAiDC,IAAjD,CAAsD;AAAE,uBAAeX,EAAjB;AAAqB,uBAAeA;AAApC,OAAtD;;AACA,UAAI,KAAKb,OAAL,CAAayB,MAAb,KAAwB,EAA5B,EAAgC;AAC5BvB,qDAAC,CAAC,MAAMa,KAAK,CAACf,OAAN,CAAcyB,MAArB,CAAD,CAA8BD,IAA9B,CAAmC;AAAE,yBAAeX;AAAjB,SAAnC;AACH;;AAED,WAAKa,WAAL,GAAmB,KAAK1B,OAAL,CAAa2B,UAAhC;AACA,WAAKC,OAAL,GAAe,KAAf;AACA,WAAKC,cAAL,GAAsBC,qEAAM,CAAC5B,6CAAC,CAAC6B,MAAD,CAAF,EAAY,YAAY;AAClD;AACAhB,aAAK,CAACiB,eAAN,GAAwBjB,KAAK,CAACd,QAAN,CAAegC,GAAf,CAAmB,SAAnB,KAAiC,MAAjC,GAA0C,CAA1C,GAA8ClB,KAAK,CAACd,QAAN,CAAe,CAAf,EAAkBiC,qBAAlB,GAA0CC,MAAhH;;AACApB,aAAK,CAACE,UAAN,CAAiBgB,GAAjB,CAAqB,QAArB,EAA+BlB,KAAK,CAACiB,eAArC;;AACAjB,aAAK,CAACqB,UAAN,GAAmBrB,KAAK,CAACiB,eAAzB;;AACA,YAAIjB,KAAK,CAACf,OAAN,CAAcyB,MAAd,KAAyB,EAA7B,EAAiC;AAC/BV,eAAK,CAACsB,OAAN,GAAgBnC,6CAAC,CAAC,MAAMa,KAAK,CAACf,OAAN,CAAcyB,MAArB,CAAjB;AACD,SAFD,MAEO;AACLV,eAAK,CAACuB,YAAN;AACD;;AAEDvB,aAAK,CAACwB,SAAN,CAAgB,YAAY;AAC1B,cAAIC,MAAM,GAAGT,MAAM,CAACU,WAApB;;AACA1B,eAAK,CAAC2B,KAAN,CAAY,KAAZ,EAAmBF,MAAnB,EAF0B,CAG1B;;;AACA,cAAI,CAACzB,KAAK,CAACa,OAAX,EAAoB;AAClBb,iBAAK,CAAC4B,aAAN,CAAqBH,MAAM,IAAIzB,KAAK,CAAC6B,QAAjB,GAA6B,KAA7B,GAAqC,IAAzD;AACD;AACF,SAPD;;AAQA7B,aAAK,CAAC8B,OAAN,CAAchC,EAAE,CAACiC,KAAH,CAAS,GAAT,EAAcC,OAAd,GAAwBC,IAAxB,CAA6B,GAA7B,CAAd;AACD,OApB2B,CAA5B;AAqBD;AAED;;;;;;;;mCAKe;AACb,UAAIC,GAAG,GAAG,KAAKjD,OAAL,CAAakD,SAAb,IAA0B,EAA1B,GAA+B,CAA/B,GAAmC,KAAKlD,OAAL,CAAakD,SAA1D;AAAA,UACIC,GAAG,GAAG,KAAKnD,OAAL,CAAaoD,SAAb,IAAyB,EAAzB,GAA8BC,QAAQ,CAACC,eAAT,CAAyBC,YAAvD,GAAsE,KAAKvD,OAAL,CAAaoD,SAD7F;AAAA,UAEII,GAAG,GAAG,CAACP,GAAD,EAAME,GAAN,CAFV;AAAA,UAGIM,MAAM,GAAG,EAHb;;AAIA,WAAK,IAAIC,CAAC,GAAG,CAAR,EAAWC,GAAG,GAAGH,GAAG,CAACxC,MAA1B,EAAkC0C,CAAC,GAAGC,GAAJ,IAAWH,GAAG,CAACE,CAAD,CAAhD,EAAqDA,CAAC,EAAtD,EAA0D;AACxD,YAAIE,EAAJ;;AACA,YAAI,OAAOJ,GAAG,CAACE,CAAD,CAAV,KAAkB,QAAtB,EAAgC;AAC9BE,YAAE,GAAGJ,GAAG,CAACE,CAAD,CAAR;AACD,SAFD,MAEO;AACL,cAAIG,KAAK,GAAGL,GAAG,CAACE,CAAD,CAAH,CAAOZ,KAAP,CAAa,GAAb,CAAZ;AAAA,cACIrB,MAAM,GAAGvB,6CAAC,YAAK2D,KAAK,CAAC,CAAD,CAAV,EADd;AAGAD,YAAE,GAAGnC,MAAM,CAACqC,MAAP,GAAgBb,GAArB;;AACA,cAAIY,KAAK,CAAC,CAAD,CAAL,IAAYA,KAAK,CAAC,CAAD,CAAL,CAASE,WAAT,OAA2B,QAA3C,EAAqD;AACnDH,cAAE,IAAInC,MAAM,CAAC,CAAD,CAAN,CAAUS,qBAAV,GAAkCC,MAAxC;AACD;AACF;;AACDsB,cAAM,CAACC,CAAD,CAAN,GAAYE,EAAZ;AACD;;AAGD,WAAKI,MAAL,GAAcP,MAAd;AACA;AACD;AAED;;;;;;;;4BAKQ5C,E,EAAI;AACV,UAAIE,KAAK,GAAG,IAAZ;AAAA,UACIkD,cAAc,GAAG,KAAKA,cAAL,uBAAmCpD,EAAnC,CADrB;;AAEA,UAAI,KAAKqD,IAAT,EAAe;AAAE;AAAS;;AAC1B,UAAI,KAAKC,QAAT,EAAmB;AACjB,aAAKD,IAAL,GAAY,IAAZ;AACAhE,qDAAC,CAAC6B,MAAD,CAAD,CAAUqC,GAAV,CAAcH,cAAd,EACUI,EADV,CACaJ,cADb,EAC6B,UAASK,CAAT,EAAY;AAC9B,cAAIvD,KAAK,CAACW,WAAN,KAAsB,CAA1B,EAA6B;AAC3BX,iBAAK,CAACW,WAAN,GAAoBX,KAAK,CAACf,OAAN,CAAc2B,UAAlC;;AACAZ,iBAAK,CAACwB,SAAN,CAAgB,YAAW;AACzBxB,mBAAK,CAAC2B,KAAN,CAAY,KAAZ,EAAmBX,MAAM,CAACU,WAA1B;AACD,aAFD;AAGD,WALD,MAKO;AACL1B,iBAAK,CAACW,WAAN;;AACAX,iBAAK,CAAC2B,KAAN,CAAY,KAAZ,EAAmBX,MAAM,CAACU,WAA1B;AACD;AACH,SAXT;AAYD;;AAED,WAAKxC,QAAL,CAAcmE,GAAd,CAAkB,qBAAlB,EACcC,EADd,CACiB,qBADjB,EACwC,UAASC,CAAT,EAAYC,EAAZ,EAAgB;AACxCxD,aAAK,CAACyD,cAAN,CAAqB3D,EAArB;AACf,OAHD;AAKA,WAAKZ,QAAL,CAAcoE,EAAd,CAAiB,qBAAjB,EAAwC,UAAUC,CAAV,EAAaC,EAAb,EAAiB;AACrDxD,aAAK,CAACyD,cAAN,CAAqB3D,EAArB;AACH,OAFD;;AAIA,UAAG,KAAKwB,OAAR,EAAiB;AACf,aAAKA,OAAL,CAAagC,EAAb,CAAgB,qBAAhB,EAAuC,UAAUC,CAAV,EAAaC,EAAb,EAAiB;AACpDxD,eAAK,CAACyD,cAAN,CAAqB3D,EAArB;AACH,SAFD;AAGD;AACF;AAED;;;;;;;;mCAKeA,E,EAAI;AACd,UAAIE,KAAK,GAAG,IAAZ;AAAA,UACCkD,cAAc,GAAG,KAAKA,cAAL,uBAAmCpD,EAAnC,CADlB;;AAGAE,WAAK,CAACwB,SAAN,CAAgB,YAAW;AAC3BxB,aAAK,CAAC2B,KAAN,CAAY,KAAZ;;AACA,YAAI3B,KAAK,CAACoD,QAAV,EAAoB;AAClB,cAAI,CAACpD,KAAK,CAACmD,IAAX,EAAiB;AACfnD,iBAAK,CAAC8B,OAAN,CAAchC,EAAd;AACD;AACF,SAJD,MAIO,IAAIE,KAAK,CAACmD,IAAV,EAAgB;AACrBnD,eAAK,CAAC0D,eAAN,CAAsBR,cAAtB;AACD;AACF,OATC;AAUJ;AAED;;;;;;;;oCAKgBA,c,EAAgB;AAC9B,WAAKC,IAAL,GAAY,KAAZ;AACAhE,mDAAC,CAAC6B,MAAD,CAAD,CAAUqC,GAAV,CAAcH,cAAd;AAEA;;;;;;AAKC,WAAKhE,QAAL,CAAcyE,OAAd,CAAsB,iBAAtB;AACF;AAED;;;;;;;;;0BAMMC,U,EAAYnC,M,EAAQ;AACxB,UAAImC,UAAJ,EAAgB;AAAE,aAAKpC,SAAL;AAAmB;;AAErC,UAAI,CAAC,KAAK4B,QAAV,EAAoB;AAClB,YAAI,KAAKvC,OAAT,EAAkB;AAChB,eAAKe,aAAL,CAAmB,IAAnB;AACD;;AACD,eAAO,KAAP;AACD;;AAED,UAAI,CAACH,MAAL,EAAa;AAAEA,cAAM,GAAGT,MAAM,CAACU,WAAhB;AAA8B;;AAE7C,UAAID,MAAM,IAAI,KAAKI,QAAnB,EAA6B;AAC3B,YAAIJ,MAAM,IAAI,KAAKoC,WAAnB,EAAgC;AAC9B,cAAI,CAAC,KAAKhD,OAAV,EAAmB;AACjB,iBAAKiD,UAAL;AACD;AACF,SAJD,MAIO;AACL,cAAI,KAAKjD,OAAT,EAAkB;AAChB,iBAAKe,aAAL,CAAmB,KAAnB;AACD;AACF;AACF,OAVD,MAUO;AACL,YAAI,KAAKf,OAAT,EAAkB;AAChB,eAAKe,aAAL,CAAmB,IAAnB;AACD;AACF;AACF;AAED;;;;;;;;;;iCAOa;AACX,UAAI5B,KAAK,GAAG,IAAZ;AAAA,UACI+D,OAAO,GAAG,KAAK9E,OAAL,CAAa8E,OAD3B;AAAA,UAEIC,IAAI,GAAGD,OAAO,KAAK,KAAZ,GAAoB,WAApB,GAAkC,cAF7C;AAAA,UAGIE,UAAU,GAAGF,OAAO,KAAK,KAAZ,GAAoB,QAApB,GAA+B,KAHhD;AAAA,UAII7C,GAAG,GAAG,EAJV;;AAMAA,SAAG,CAAC8C,IAAD,CAAH,aAAe,KAAK/E,OAAL,CAAa+E,IAAb,CAAf;AACA9C,SAAG,CAAC6C,OAAD,CAAH,GAAe,CAAf;AACA7C,SAAG,CAAC+C,UAAD,CAAH,GAAkB,MAAlB;AACA,WAAKpD,OAAL,GAAe,IAAf;AACA,WAAK3B,QAAL,CAAcgF,WAAd,6BAA+CD,UAA/C,GACc3D,QADd,0BACyCyD,OADzC,GAEc7C,GAFd,CAEkBA,GAFlB;AAGa;;;;;AAHb,OAQcyC,OARd,6BAQ2CI,OAR3C;AASA,WAAK7E,QAAL,CAAcoE,EAAd,CAAiB,iFAAjB,EAAoG,YAAW;AAC7GtD,aAAK,CAACwB,SAAN;AACD,OAFD;AAGD;AAED;;;;;;;;;;;kCAQc2C,K,EAAO;AACnB,UAAIJ,OAAO,GAAG,KAAK9E,OAAL,CAAa8E,OAA3B;AAAA,UACIK,UAAU,GAAGL,OAAO,KAAK,KAD7B;AAAA,UAEI7C,GAAG,GAAG,EAFV;AAAA,UAGImD,QAAQ,GAAG,CAAC,KAAKpB,MAAL,GAAc,KAAKA,MAAL,CAAY,CAAZ,IAAiB,KAAKA,MAAL,CAAY,CAAZ,CAA/B,GAAgD,KAAKqB,YAAtD,IAAsE,KAAKjD,UAH1F;AAAA,UAII2C,IAAI,GAAGI,UAAU,GAAG,WAAH,GAAiB,cAJtC;AAAA,UAKIH,UAAU,GAAGG,UAAU,GAAG,QAAH,GAAc,KALzC;AAAA,UAMIG,WAAW,GAAGJ,KAAK,GAAG,KAAH,GAAW,QANlC;AAQAjD,SAAG,CAAC8C,IAAD,CAAH,GAAY,CAAZ;AAEA9C,SAAG,CAAC,QAAD,CAAH,GAAgB,MAAhB;;AACA,UAAGiD,KAAH,EAAU;AACRjD,WAAG,CAAC,KAAD,CAAH,GAAa,CAAb;AACD,OAFD,MAEO;AACLA,WAAG,CAAC,KAAD,CAAH,GAAamD,QAAb;AACD;;AAED,WAAKxD,OAAL,GAAe,KAAf;AACA,WAAK3B,QAAL,CAAcgF,WAAd,0BAA4CH,OAA5C,GACczD,QADd,6BAC4CiE,WAD5C,GAEcrD,GAFd,CAEkBA,GAFlB;AAGa;;;;;AAHb,OAQcyC,OARd,iCAQ+CY,WAR/C;AASD;AAED;;;;;;;;;8BAMUC,E,EAAI;AACZ,WAAKpB,QAAL,GAAgBzD,sEAAU,CAAC8E,EAAX,CAAc,KAAKxF,OAAL,CAAayF,QAA3B,CAAhB;;AACA,UAAI,CAAC,KAAKtB,QAAV,EAAoB;AAClB,YAAIoB,EAAE,IAAI,OAAOA,EAAP,KAAc,UAAxB,EAAoC;AAAEA,YAAE;AAAK;AAC9C;;AACD,UAAIxE,KAAK,GAAG,IAAZ;AAAA,UACI2E,YAAY,GAAG,KAAKzE,UAAL,CAAgB,CAAhB,EAAmBiB,qBAAnB,GAA2CyD,KAD9D;AAAA,UAEIC,IAAI,GAAG7D,MAAM,CAAC8D,gBAAP,CAAwB,KAAK5E,UAAL,CAAgB,CAAhB,CAAxB,CAFX;AAAA,UAGI6E,KAAK,GAAGC,QAAQ,CAACH,IAAI,CAAC,cAAD,CAAL,EAAuB,EAAvB,CAHpB;AAAA,UAIII,KAAK,GAAGD,QAAQ,CAACH,IAAI,CAAC,eAAD,CAAL,EAAwB,EAAxB,CAJpB;;AAMA,UAAI,KAAKvD,OAAL,IAAgB,KAAKA,OAAL,CAAarB,MAAjC,EAAyC;AACvC,aAAKqE,YAAL,GAAoB,KAAKhD,OAAL,CAAa,CAAb,EAAgBH,qBAAhB,GAAwCC,MAA5D;AACD,OAFD,MAEO;AACL,aAAKG,YAAL;AACD;;AAED,WAAKrC,QAAL,CAAcgC,GAAd,CAAkB;AAChB,+BAAgByD,YAAY,GAAGI,KAAf,GAAuBE,KAAvC;AADgB,OAAlB;AAIA,UAAIC,kBAAkB,GAAG,KAAKhG,QAAL,CAAc,CAAd,EAAiBiC,qBAAjB,GAAyCC,MAAzC,IAAmD,KAAKH,eAAjF;;AACA,UAAI,KAAK/B,QAAL,CAAcgC,GAAd,CAAkB,SAAlB,KAAgC,MAApC,EAA4C;AAC1CgE,0BAAkB,GAAG,CAArB;AACD;;AACD,WAAKjE,eAAL,GAAuBiE,kBAAvB;AACA,WAAKhF,UAAL,CAAgBgB,GAAhB,CAAoB;AAClBE,cAAM,EAAE8D;AADU,OAApB;AAGA,WAAK7D,UAAL,GAAkB6D,kBAAlB;;AAEA,UAAI,CAAC,KAAKrE,OAAV,EAAmB;AACjB,YAAI,KAAK3B,QAAL,CAAciG,QAAd,CAAuB,cAAvB,CAAJ,EAA4C;AAC1C,cAAId,QAAQ,GAAG,CAAC,KAAKpB,MAAL,GAAc,KAAKA,MAAL,CAAY,CAAZ,IAAiB,KAAK/C,UAAL,CAAgB6C,MAAhB,GAAyBb,GAAxD,GAA8D,KAAKoC,YAApE,IAAoF,KAAKjD,UAAxG;AACA,eAAKnC,QAAL,CAAcgC,GAAd,CAAkB,KAAlB,EAAyBmD,QAAzB;AACD;AACF;;AAED,WAAKe,eAAL,CAAqBF,kBAArB,EAAyC,YAAW;AAClD,YAAIV,EAAE,IAAI,OAAOA,EAAP,KAAc,UAAxB,EAAoC;AAAEA,YAAE;AAAK;AAC9C,OAFD;AAGD;AAED;;;;;;;;;oCAMgBnD,U,EAAYmD,E,EAAI;AAC9B,UAAI,CAAC,KAAKpB,QAAV,EAAoB;AAClB,YAAIoB,EAAE,IAAI,OAAOA,EAAP,KAAc,UAAxB,EAAoC;AAAEA,YAAE;AAAK,SAA7C,MACK;AAAE,iBAAO,KAAP;AAAe;AACvB;;AACD,UAAIa,IAAI,GAAGC,MAAM,CAAC,KAAKrG,OAAL,CAAasG,SAAd,CAAjB;AAAA,UACIC,IAAI,GAAGF,MAAM,CAAC,KAAKrG,OAAL,CAAawG,YAAd,CADjB;AAAA,UAEI5D,QAAQ,GAAG,KAAKoB,MAAL,GAAc,KAAKA,MAAL,CAAY,CAAZ,CAAd,GAA+B,KAAK3B,OAAL,CAAayB,MAAb,GAAsBb,GAFpE;AAAA,UAGI2B,WAAW,GAAG,KAAKZ,MAAL,GAAc,KAAKA,MAAL,CAAY,CAAZ,CAAd,GAA+BpB,QAAQ,GAAG,KAAKyC,YAHjE;AAAA,UAII;AACA;AACAoB,eAAS,GAAG1E,MAAM,CAAC2E,WANvB;;AAQA,UAAI,KAAK1G,OAAL,CAAa8E,OAAb,KAAyB,KAA7B,EAAoC;AAClClC,gBAAQ,IAAIwD,IAAZ;AACAxB,mBAAW,IAAKxC,UAAU,GAAGgE,IAA7B;AACD,OAHD,MAGO,IAAI,KAAKpG,OAAL,CAAa8E,OAAb,KAAyB,QAA7B,EAAuC;AAC5ClC,gBAAQ,IAAK6D,SAAS,IAAIrE,UAAU,GAAGmE,IAAjB,CAAtB;AACA3B,mBAAW,IAAK6B,SAAS,GAAGF,IAA5B;AACD,OAHM,MAGA,CACL;AACD;;AAED,WAAK3D,QAAL,GAAgBA,QAAhB;AACA,WAAKgC,WAAL,GAAmBA,WAAnB;;AAEA,UAAIW,EAAE,IAAI,OAAOA,EAAP,KAAc,UAAxB,EAAoC;AAAEA,UAAE;AAAK;AAC9C;AAED;;;;;;;;;+BAMW;AACT,WAAK5C,aAAL,CAAmB,IAAnB;;AAEA,WAAK1C,QAAL,CAAcgF,WAAd,WAA6B,KAAKjF,OAAL,CAAauB,WAA1C,6BACcU,GADd,CACkB;AACHE,cAAM,EAAE,EADL;AAEHc,WAAG,EAAE,EAFF;AAGH0D,cAAM,EAAE,EAHL;AAIH,qBAAa;AAJV,OADlB,EAOcvC,GAPd,CAOkB,qBAPlB,EAQcA,GARd,CAQkB,qBARlB;;AASA,UAAI,KAAK/B,OAAL,IAAgB,KAAKA,OAAL,CAAarB,MAAjC,EAAyC;AACvC,aAAKqB,OAAL,CAAa+B,GAAb,CAAiB,kBAAjB;AACD;;AACD,UAAI,KAAKH,cAAT,EAAyB/D,6CAAC,CAAC6B,MAAD,CAAD,CAAUqC,GAAV,CAAc,KAAKH,cAAnB;AACzB,UAAI,KAAKpC,cAAT,EAAyB3B,6CAAC,CAAC6B,MAAD,CAAD,CAAUqC,GAAV,CAAc,KAAKvC,cAAnB;;AAEzB,UAAI,KAAKX,UAAT,EAAqB;AACnB,aAAKjB,QAAL,CAAc2G,MAAd;AACD,OAFD,MAEO;AACL,aAAK3F,UAAL,CAAgBgE,WAAhB,CAA4B,KAAKjF,OAAL,CAAasB,cAAzC,EACgBW,GADhB,CACoB;AACHE,gBAAM,EAAE;AADL,SADpB;AAID;AACF;;;;EAjZkB0E,6D;;AAoZrB/G,MAAM,CAACM,QAAP,GAAkB;AAChB;;;;;;AAMAgB,WAAS,EAAE,mCAPK;;AAQhB;;;;;;AAMA0D,SAAO,EAAE,KAdO;;AAehB;;;;;;AAMArD,QAAM,EAAE,EArBQ;;AAsBhB;;;;;;AAMAyB,WAAS,EAAE,EA5BK;;AA6BhB;;;;;;AAMAE,WAAS,EAAE,EAnCK;;AAoChB;;;;;;AAMAkD,WAAS,EAAE,CA1CK;;AA2ChB;;;;;;AAMAE,cAAY,EAAE,CAjDE;;AAkDhB;;;;;;AAMAf,UAAQ,EAAE,QAxDM;;AAyDhB;;;;;;AAMAlE,aAAW,EAAE,QA/DG;;AAgEhB;;;;;;AAMAD,gBAAc,EAAE,kBAtEA;;AAuEhB;;;;;;AAMAK,YAAU,EAAE,CAAC;AA7EG,CAAlB;AAgFA;;;;;AAIA,SAAS0E,MAAT,CAAgBS,EAAhB,EAAoB;AAClB,SAAOf,QAAQ,CAAChE,MAAM,CAAC8D,gBAAP,CAAwBxC,QAAQ,CAAC0D,IAAjC,EAAuC,IAAvC,EAA6CC,QAA9C,EAAwD,EAAxD,CAAR,GAAsEF,EAA7E;AACD;;;;;;;;;;;;;;ACzfD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAa;;;;AAEb;AACA;AACA;;AAEA,IAAMG,gBAAgB,GAAI,YAAY;AACpC,MAAIC,QAAQ,GAAG,CAAC,QAAD,EAAW,KAAX,EAAkB,GAAlB,EAAuB,IAAvB,EAA6B,EAA7B,CAAf;;AACA,OAAK,IAAIxD,CAAC,GAAC,CAAX,EAAcA,CAAC,GAAGwD,QAAQ,CAAClG,MAA3B,EAAmC0C,CAAC,EAApC,EAAwC;AACtC,QAAI,UAAGwD,QAAQ,CAACxD,CAAD,CAAX,yBAAoC3B,MAAxC,EAAgD;AAC9C,aAAOA,MAAM,WAAImF,QAAQ,CAACxD,CAAD,CAAZ,sBAAb;AACD;AACF;;AACD,SAAO,KAAP;AACD,CARyB,EAA1B;;AAUA,IAAMyD,QAAQ,GAAG,SAAXA,QAAW,CAAC5C,EAAD,EAAK6C,IAAL,EAAc;AAC7B7C,IAAE,CAAClE,IAAH,CAAQ+G,IAAR,EAActE,KAAd,CAAoB,GAApB,EAAyBuE,OAAzB,CAAiC,UAAAxG,EAAE,EAAI;AACrCX,iDAAC,YAAKW,EAAL,EAAD,CAAauG,IAAI,KAAK,OAAT,GAAmB,SAAnB,GAA+B,gBAA5C,YAAiEA,IAAjE,kBAAoF,CAAC7C,EAAD,CAApF;AACD,GAFD;AAGD,CAJD;;AAMA,IAAIhE,QAAQ,GAAG;AACb+G,WAAS,EAAE;AACTC,SAAK,EAAE,EADE;AAETC,UAAM,EAAE;AAFC,GADE;AAKbC,cAAY,EAAE;AALD,CAAf;AAQAlH,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,GAA4B;AAC1BG,cAAY,EAAE,wBAAW;AACvBP,YAAQ,CAACjH,6CAAC,CAAC,IAAD,CAAF,EAAU,MAAV,CAAR;AACD,GAHyB;AAI1ByH,eAAa,EAAE,yBAAW;AACxB,QAAI9G,EAAE,GAAGX,6CAAC,CAAC,IAAD,CAAD,CAAQG,IAAR,CAAa,OAAb,CAAT;;AACA,QAAIQ,EAAJ,EAAQ;AACNsG,cAAQ,CAACjH,6CAAC,CAAC,IAAD,CAAF,EAAU,OAAV,CAAR;AACD,KAFD,MAGK;AACHA,mDAAC,CAAC,IAAD,CAAD,CAAQwE,OAAR,CAAgB,kBAAhB;AACD;AACF,GAZyB;AAa1BkD,gBAAc,EAAE,0BAAW;AACzB,QAAI/G,EAAE,GAAGX,6CAAC,CAAC,IAAD,CAAD,CAAQG,IAAR,CAAa,QAAb,CAAT;;AACA,QAAIQ,EAAJ,EAAQ;AACNsG,cAAQ,CAACjH,6CAAC,CAAC,IAAD,CAAF,EAAU,QAAV,CAAR;AACD,KAFD,MAEO;AACLA,mDAAC,CAAC,IAAD,CAAD,CAAQwE,OAAR,CAAgB,mBAAhB;AACD;AACF,GApByB;AAqB1BmD,mBAAiB,EAAE,2BAASvD,CAAT,EAAY;AAC7BA,KAAC,CAACwD,eAAF;AACA,QAAIC,SAAS,GAAG7H,6CAAC,CAAC,IAAD,CAAD,CAAQG,IAAR,CAAa,UAAb,CAAhB;;AAEA,QAAG0H,SAAS,KAAK,EAAjB,EAAoB;AAClBC,oEAAM,CAACC,UAAP,CAAkB/H,6CAAC,CAAC,IAAD,CAAnB,EAA2B6H,SAA3B,EAAsC,YAAW;AAC/C7H,qDAAC,CAAC,IAAD,CAAD,CAAQwE,OAAR,CAAgB,WAAhB;AACD,OAFD;AAGD,KAJD,MAIK;AACHxE,mDAAC,CAAC,IAAD,CAAD,CAAQgI,OAAR,GAAkBxD,OAAlB,CAA0B,WAA1B;AACD;AACF,GAhCyB;AAiC1ByD,qBAAmB,EAAE,+BAAW;AAC9B,QAAItH,EAAE,GAAGX,6CAAC,CAAC,IAAD,CAAD,CAAQG,IAAR,CAAa,cAAb,CAAT;AACAH,iDAAC,YAAKW,EAAL,EAAD,CAAYuH,cAAZ,CAA2B,mBAA3B,EAAgD,CAAClI,6CAAC,CAAC,IAAD,CAAF,CAAhD;AACD;AApCyB,CAA5B,C,CAuCA;;AACAK,QAAQ,CAACkH,YAAT,CAAsBY,eAAtB,GAAwC,UAACC,KAAD,EAAW;AACjDA,OAAK,CAAClE,GAAN,CAAU,kBAAV,EAA8B7D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBG,YAAvD;AACAY,OAAK,CAACjE,EAAN,CAAS,kBAAT,EAA6B,aAA7B,EAA4C9D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBG,YAArE;AACD,CAHD,C,CAKA;AACA;;;AACAnH,QAAQ,CAACkH,YAAT,CAAsBc,gBAAtB,GAAyC,UAACD,KAAD,EAAW;AAClDA,OAAK,CAAClE,GAAN,CAAU,kBAAV,EAA8B7D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBI,aAAvD;AACAW,OAAK,CAACjE,EAAN,CAAS,kBAAT,EAA6B,cAA7B,EAA6C9D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBI,aAAtE;AACD,CAHD,C,CAKA;;;AACApH,QAAQ,CAACkH,YAAT,CAAsBe,iBAAtB,GAA0C,UAACF,KAAD,EAAW;AACnDA,OAAK,CAAClE,GAAN,CAAU,kBAAV,EAA8B7D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBK,cAAvD;AACAU,OAAK,CAACjE,EAAN,CAAS,kBAAT,EAA6B,eAA7B,EAA8C9D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBK,cAAvE;AACD,CAHD,C,CAKA;;;AACArH,QAAQ,CAACkH,YAAT,CAAsBgB,oBAAtB,GAA6C,UAACH,KAAD,EAAW;AACtDA,OAAK,CAAClE,GAAN,CAAU,kBAAV,EAA8B7D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBM,iBAAvD;AACAS,OAAK,CAACjE,EAAN,CAAS,kBAAT,EAA6B,mCAA7B,EAAkE9D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBM,iBAA3F;AACD,CAHD,C,CAKA;;;AACAtH,QAAQ,CAACkH,YAAT,CAAsBiB,sBAAtB,GAA+C,UAACJ,KAAD,EAAW;AACxDA,OAAK,CAAClE,GAAN,CAAU,kCAAV,EAA8C7D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBY,mBAAvE;AACAG,OAAK,CAACjE,EAAN,CAAS,kCAAT,EAA6C,qBAA7C,EAAoE9D,QAAQ,CAAC+G,SAAT,CAAmBC,KAAnB,CAAyBY,mBAA7F;AACD,CAHD,C,CAOA;;;AACA5H,QAAQ,CAAC+G,SAAT,CAAmBE,MAAnB,GAA6B;AAC3BmB,gBAAc,EAAE,wBAASC,MAAT,EAAiB;AAC/B,QAAG,CAAC3B,gBAAJ,EAAqB;AAAC;AACpB2B,YAAM,CAACC,IAAP,CAAY,YAAU;AACpB3I,qDAAC,CAAC,IAAD,CAAD,CAAQkI,cAAR,CAAuB,qBAAvB;AACD,OAFD;AAGD,KAL8B,CAM/B;;;AACAQ,UAAM,CAACpH,IAAP,CAAY,aAAZ,EAA2B,QAA3B;AACD,GAT0B;AAU3ByC,gBAAc,EAAE,wBAAS2E,MAAT,EAAiB;AAC/B,QAAG,CAAC3B,gBAAJ,EAAqB;AAAC;AACpB2B,YAAM,CAACC,IAAP,CAAY,YAAU;AACpB3I,qDAAC,CAAC,IAAD,CAAD,CAAQkI,cAAR,CAAuB,qBAAvB;AACD,OAFD;AAGD,KAL8B,CAM/B;;;AACAQ,UAAM,CAACpH,IAAP,CAAY,aAAZ,EAA2B,QAA3B;AACD,GAlB0B;AAmB3BsH,iBAAe,EAAE,yBAASxE,CAAT,EAAYyE,QAAZ,EAAqB;AACpC,QAAIlJ,MAAM,GAAGyE,CAAC,CAAC0E,SAAF,CAAYlG,KAAZ,CAAkB,GAAlB,EAAuB,CAAvB,CAAb;AACA,QAAImG,OAAO,GAAG/I,6CAAC,iBAAUL,MAAV,OAAD,CAAsBqJ,GAAtB,4BAA6CH,QAA7C,SAAd;AAEAE,WAAO,CAACJ,IAAR,CAAa,YAAU;AACrB,UAAI9H,KAAK,GAAGb,6CAAC,CAAC,IAAD,CAAb;;AACAa,WAAK,CAACqH,cAAN,CAAqB,kBAArB,EAAyC,CAACrH,KAAD,CAAzC;AACD,KAHD;AAID,GA3B0B,CA8B7B;;AA9B6B,CAA7B;;AA+BAR,QAAQ,CAACkH,YAAT,CAAsB0B,kBAAtB,GAA2C,UAASC,UAAT,EAAqB;AAC9D,MAAIC,SAAS,GAAGnJ,6CAAC,CAAC,iBAAD,CAAjB;AAAA,MACIoJ,SAAS,GAAG,CAAC,UAAD,EAAa,SAAb,EAAwB,QAAxB,CADhB;;AAGA,MAAGF,UAAH,EAAc;AACZ,QAAG,OAAOA,UAAP,KAAsB,QAAzB,EAAkC;AAChCE,eAAS,CAACC,IAAV,CAAeH,UAAf;AACD,KAFD,MAEM,IAAG,QAAOA,UAAP,MAAsB,QAAtB,IAAkC,OAAOA,UAAU,CAAC,CAAD,CAAjB,KAAyB,QAA9D,EAAuE;AAC3EE,eAAS,GAAGA,SAAS,CAACE,MAAV,CAAiBJ,UAAjB,CAAZ;AACD,KAFK,MAED;AACHK,aAAO,CAACC,KAAR,CAAc,8BAAd;AACD;AACF;;AACD,MAAGL,SAAS,CAACrI,MAAb,EAAoB;AAClB,QAAI2I,SAAS,GAAGL,SAAS,CAACM,GAAV,CAAc,UAACC,IAAD,EAAU;AACtC,kCAAqBA,IAArB;AACD,KAFe,EAEb7G,IAFa,CAER,GAFQ,CAAhB;AAIA9C,iDAAC,CAAC6B,MAAD,CAAD,CAAUqC,GAAV,CAAcuF,SAAd,EAAyBtF,EAAzB,CAA4BsF,SAA5B,EAAuCpJ,QAAQ,CAAC+G,SAAT,CAAmBE,MAAnB,CAA0BsB,eAAjE;AACD;AACF,CApBD;;AAsBA,SAASgB,sBAAT,CAAgCC,QAAhC,EAA0CrF,OAA1C,EAAmDsF,QAAnD,EAA6D;AAC3D,MAAIC,KAAJ;AAAA,MAAWC,IAAI,GAAGC,KAAK,CAACC,SAAN,CAAgBC,KAAhB,CAAsBC,IAAtB,CAA2BC,SAA3B,EAAsC,CAAtC,CAAlB;AACArK,+CAAC,CAAC6B,MAAD,CAAD,CAAUqC,GAAV,CAAcM,OAAd,EAAuBL,EAAvB,CAA0BK,OAA1B,EAAmC,UAASJ,CAAT,EAAY;AAC7C,QAAI2F,KAAJ,EAAW;AAAEO,kBAAY,CAACP,KAAD,CAAZ;AAAsB;;AACnCA,SAAK,GAAGQ,UAAU,CAAC,YAAU;AAC3BT,cAAQ,CAACU,KAAT,CAAe,IAAf,EAAqBR,IAArB;AACD,KAFiB,EAEfH,QAAQ,IAAI,EAFG,CAAlB,CAF6C,CAI1B;AACpB,GALD;AAMD;;AAEDxJ,QAAQ,CAACkH,YAAT,CAAsBkD,iBAAtB,GAA0C,UAASZ,QAAT,EAAkB;AAC1D,MAAInB,MAAM,GAAG1I,6CAAC,CAAC,eAAD,CAAd;;AACA,MAAG0I,MAAM,CAAC5H,MAAV,EAAiB;AACf8I,0BAAsB,CAACC,QAAD,EAAW,mBAAX,EAAgCxJ,QAAQ,CAAC+G,SAAT,CAAmBE,MAAnB,CAA0BmB,cAA1D,EAA0EC,MAA1E,CAAtB;AACD;AACF,CALD;;AAOArI,QAAQ,CAACkH,YAAT,CAAsBmD,iBAAtB,GAA0C,UAASb,QAAT,EAAkB;AAC1D,MAAInB,MAAM,GAAG1I,6CAAC,CAAC,eAAD,CAAd;;AACA,MAAG0I,MAAM,CAAC5H,MAAV,EAAiB;AACf8I,0BAAsB,CAACC,QAAD,EAAW,mBAAX,EAAgCxJ,QAAQ,CAAC+G,SAAT,CAAmBE,MAAnB,CAA0BvD,cAA1D,EAA0E2E,MAA1E,CAAtB;AACD;AACF,CALD;;AAOArI,QAAQ,CAACkH,YAAT,CAAsBoD,yBAAtB,GAAkD,UAASvC,KAAT,EAAgB;AAChE,MAAG,CAACrB,gBAAJ,EAAqB;AAAE,WAAO,KAAP;AAAe;;AACtC,MAAI2B,MAAM,GAAGN,KAAK,CAACwC,IAAN,CAAW,6CAAX,CAAb,CAFgE,CAIhE;;AACA,MAAIC,yBAAyB,GAAG,SAA5BA,yBAA4B,CAAUC,mBAAV,EAA+B;AAC7D,QAAIC,OAAO,GAAG/K,6CAAC,CAAC8K,mBAAmB,CAAC,CAAD,CAAnB,CAAuBE,MAAxB,CAAf,CAD6D,CAG7D;;AACA,YAAQF,mBAAmB,CAAC,CAAD,CAAnB,CAAuB5D,IAA/B;AACE,WAAK,YAAL;AACE,YAAI6D,OAAO,CAACzJ,IAAR,CAAa,aAAb,MAAgC,QAAhC,IAA4CwJ,mBAAmB,CAAC,CAAD,CAAnB,CAAuBG,aAAvB,KAAyC,aAAzF,EAAwG;AACtGF,iBAAO,CAAC7C,cAAR,CAAuB,qBAAvB,EAA8C,CAAC6C,OAAD,EAAUlJ,MAAM,CAACU,WAAjB,CAA9C;AACD;;AACD,YAAIwI,OAAO,CAACzJ,IAAR,CAAa,aAAb,MAAgC,QAAhC,IAA4CwJ,mBAAmB,CAAC,CAAD,CAAnB,CAAuBG,aAAvB,KAAyC,aAAzF,EAAwG;AACtGF,iBAAO,CAAC7C,cAAR,CAAuB,qBAAvB,EAA8C,CAAC6C,OAAD,CAA9C;AACA;;AACF,YAAID,mBAAmB,CAAC,CAAD,CAAnB,CAAuBG,aAAvB,KAAyC,OAA7C,EAAsD;AACpDF,iBAAO,CAACG,OAAR,CAAgB,eAAhB,EAAiC5J,IAAjC,CAAsC,aAAtC,EAAoD,QAApD;AACAyJ,iBAAO,CAACG,OAAR,CAAgB,eAAhB,EAAiChD,cAAjC,CAAgD,qBAAhD,EAAuE,CAAC6C,OAAO,CAACG,OAAR,CAAgB,eAAhB,CAAD,CAAvE;AACD;;AACD;;AAEF,WAAK,WAAL;AACEH,eAAO,CAACG,OAAR,CAAgB,eAAhB,EAAiC5J,IAAjC,CAAsC,aAAtC,EAAoD,QAApD;AACAyJ,eAAO,CAACG,OAAR,CAAgB,eAAhB,EAAiChD,cAAjC,CAAgD,qBAAhD,EAAuE,CAAC6C,OAAO,CAACG,OAAR,CAAgB,eAAhB,CAAD,CAAvE;AACA;;AAEF;AACE,eAAO,KAAP;AACF;AArBF;AAuBD,GA3BD;;AA6BA,MAAIxC,MAAM,CAAC5H,MAAX,EAAmB;AACjB;AACA,SAAK,IAAI0C,CAAC,GAAG,CAAb,EAAgBA,CAAC,IAAIkF,MAAM,CAAC5H,MAAP,GAAgB,CAArC,EAAwC0C,CAAC,EAAzC,EAA6C;AAC3C,UAAI2H,eAAe,GAAG,IAAIpE,gBAAJ,CAAqB8D,yBAArB,CAAtB;AACAM,qBAAe,CAACC,OAAhB,CAAwB1C,MAAM,CAAClF,CAAD,CAA9B,EAAmC;AAAE6H,kBAAU,EAAE,IAAd;AAAoBC,iBAAS,EAAE,IAA/B;AAAqCC,qBAAa,EAAE,KAApD;AAA2DC,eAAO,EAAE,IAApE;AAA0EC,uBAAe,EAAE,CAAC,aAAD,EAAgB,OAAhB;AAA3F,OAAnC;AACD;AACF;AACF,CAzCD;;AA2CApL,QAAQ,CAACkH,YAAT,CAAsBmE,kBAAtB,GAA2C,YAAW;AACpD,MAAIC,SAAS,GAAG3L,6CAAC,CAACmD,QAAD,CAAjB;AAEA9C,UAAQ,CAACkH,YAAT,CAAsBY,eAAtB,CAAsCwD,SAAtC;AACAtL,UAAQ,CAACkH,YAAT,CAAsBc,gBAAtB,CAAuCsD,SAAvC;AACAtL,UAAQ,CAACkH,YAAT,CAAsBe,iBAAtB,CAAwCqD,SAAxC;AACAtL,UAAQ,CAACkH,YAAT,CAAsBgB,oBAAtB,CAA2CoD,SAA3C;AACAtL,UAAQ,CAACkH,YAAT,CAAsBiB,sBAAtB,CAA6CmD,SAA7C;AAED,CATD;;AAWAtL,QAAQ,CAACkH,YAAT,CAAsBqE,kBAAtB,GAA2C,YAAW;AACpD,MAAID,SAAS,GAAG3L,6CAAC,CAACmD,QAAD,CAAjB;AACA9C,UAAQ,CAACkH,YAAT,CAAsBoD,yBAAtB,CAAgDgB,SAAhD;AACAtL,UAAQ,CAACkH,YAAT,CAAsBkD,iBAAtB;AACApK,UAAQ,CAACkH,YAAT,CAAsBmD,iBAAtB;AACArK,UAAQ,CAACkH,YAAT,CAAsB0B,kBAAtB;AACD,CAND;;AASA5I,QAAQ,CAACC,IAAT,GAAgB,UAAUN,CAAV,EAAaN,UAAb,EAAyB;AACvCkC,uEAAM,CAAC5B,CAAC,CAAC6B,MAAD,CAAF,EAAY,YAAY;AAC5B,QAAI7B,CAAC,CAAC6L,mBAAF,KAA0B,IAA9B,EAAoC;AAClCxL,cAAQ,CAACkH,YAAT,CAAsBmE,kBAAtB;AACArL,cAAQ,CAACkH,YAAT,CAAsBqE,kBAAtB;AACA5L,OAAC,CAAC6L,mBAAF,GAAwB,IAAxB;AACD;AACF,GANK,CAAN;;AAQA,MAAGnM,UAAH,EAAe;AACbA,cAAU,CAACW,QAAX,GAAsBA,QAAtB,CADa,CAEb;;AACAX,cAAU,CAACoM,QAAX,GAAsBzL,QAAQ,CAACkH,YAAT,CAAsBqE,kBAA5C;AACD;AACF,CAdD;;;;;;;;;;;;;;;;;;;;;;;;;ACnPA,oD","file":"foundation.sticky.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.sticky\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.sticky\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 17);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","import { Foundation } from './foundation.core';\n\nimport { Sticky } from '../../foundation.sticky';\nFoundation.plugin(Sticky, 'Sticky');\n\nexport { Foundation, Sticky };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad, GetYoDigits } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Plugin } from './foundation.core.plugin';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nclass Sticky extends Plugin {\n  /**\n   * Creates a new instance of a sticky thing.\n   * @class\n   * @name Sticky\n   * @param {jQuery} element - jQuery object to make sticky.\n   * @param {Object} options - options object passed when creating the element programmatically.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Sticky.defaults, this.$element.data(), options);\n    this.className = 'Sticky'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes\n   * @function\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n\n    var $parent = this.$element.parent('[data-sticky-container]'),\n        id = this.$element[0].id || GetYoDigits(6, 'sticky'),\n        _this = this;\n\n    if($parent.length){\n      this.$container = $parent;\n    } else {\n      this.wasWrapped = true;\n      this.$element.wrap(this.options.container);\n      this.$container = this.$element.parent();\n    }\n    this.$container.addClass(this.options.containerClass);\n\n    this.$element.addClass(this.options.stickyClass).attr({ 'data-resize': id, 'data-mutate': id });\n    if (this.options.anchor !== '') {\n        $('#' + _this.options.anchor).attr({ 'data-mutate': id });\n    }\n\n    this.scrollCount = this.options.checkEvery;\n    this.isStuck = false;\n    this.onLoadListener = onLoad($(window), function () {\n      //We calculate the container height to have correct values for anchor points offset calculation.\n      _this.containerHeight = _this.$element.css(\"display\") == \"none\" ? 0 : _this.$element[0].getBoundingClientRect().height;\n      _this.$container.css('height', _this.containerHeight);\n      _this.elemHeight = _this.containerHeight;\n      if (_this.options.anchor !== '') {\n        _this.$anchor = $('#' + _this.options.anchor);\n      } else {\n        _this._parsePoints();\n      }\n\n      _this._setSizes(function () {\n        var scroll = window.pageYOffset;\n        _this._calc(false, scroll);\n        //Unstick the element will ensure that proper classes are set.\n        if (!_this.isStuck) {\n          _this._removeSticky((scroll >= _this.topPoint) ? false : true);\n        }\n      });\n      _this._events(id.split('-').reverse().join('-'));\n    });\n  }\n\n  /**\n   * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.\n   * @function\n   * @private\n   */\n  _parsePoints() {\n    var top = this.options.topAnchor == \"\" ? 1 : this.options.topAnchor,\n        btm = this.options.btmAnchor== \"\" ? document.documentElement.scrollHeight : this.options.btmAnchor,\n        pts = [top, btm],\n        breaks = {};\n    for (var i = 0, len = pts.length; i < len && pts[i]; i++) {\n      var pt;\n      if (typeof pts[i] === 'number') {\n        pt = pts[i];\n      } else {\n        var place = pts[i].split(':'),\n            anchor = $(`#${place[0]}`);\n\n        pt = anchor.offset().top;\n        if (place[1] && place[1].toLowerCase() === 'bottom') {\n          pt += anchor[0].getBoundingClientRect().height;\n        }\n      }\n      breaks[i] = pt;\n    }\n\n\n    this.points = breaks;\n    return;\n  }\n\n  /**\n   * Adds event handlers for the scrolling element.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _events(id) {\n    var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n    if (this.isOn) { return; }\n    if (this.canStick) {\n      this.isOn = true;\n      $(window).off(scrollListener)\n               .on(scrollListener, function(e) {\n                 if (_this.scrollCount === 0) {\n                   _this.scrollCount = _this.options.checkEvery;\n                   _this._setSizes(function() {\n                     _this._calc(false, window.pageYOffset);\n                   });\n                 } else {\n                   _this.scrollCount--;\n                   _this._calc(false, window.pageYOffset);\n                 }\n              });\n    }\n\n    this.$element.off('resizeme.zf.trigger')\n                 .on('resizeme.zf.trigger', function(e, el) {\n                    _this._eventsHandler(id);\n    });\n\n    this.$element.on('mutateme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n    });\n\n    if(this.$anchor) {\n      this.$anchor.on('mutateme.zf.trigger', function (e, el) {\n          _this._eventsHandler(id);\n      });\n    }\n  }\n\n  /**\n   * Handler for events.\n   * @private\n   * @param {String} id - pseudo-random id for unique scroll event listener.\n   */\n  _eventsHandler(id) {\n       var _this = this,\n        scrollListener = this.scrollListener = `scroll.zf.${id}`;\n\n       _this._setSizes(function() {\n       _this._calc(false);\n       if (_this.canStick) {\n         if (!_this.isOn) {\n           _this._events(id);\n         }\n       } else if (_this.isOn) {\n         _this._pauseListeners(scrollListener);\n       }\n     });\n  }\n\n  /**\n   * Removes event handlers for scroll and change events on anchor.\n   * @fires Sticky#pause\n   * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`\n   */\n  _pauseListeners(scrollListener) {\n    this.isOn = false;\n    $(window).off(scrollListener);\n\n    /**\n     * Fires when the plugin is paused due to resize event shrinking the view.\n     * @event Sticky#pause\n     * @private\n     */\n     this.$element.trigger('pause.zf.sticky');\n  }\n\n  /**\n   * Called on every `scroll` event and on `_init`\n   * fires functions based on booleans and cached values\n   * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.\n   * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.\n   */\n  _calc(checkSizes, scroll) {\n    if (checkSizes) { this._setSizes(); }\n\n    if (!this.canStick) {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n      return false;\n    }\n\n    if (!scroll) { scroll = window.pageYOffset; }\n\n    if (scroll >= this.topPoint) {\n      if (scroll <= this.bottomPoint) {\n        if (!this.isStuck) {\n          this._setSticky();\n        }\n      } else {\n        if (this.isStuck) {\n          this._removeSticky(false);\n        }\n      }\n    } else {\n      if (this.isStuck) {\n        this._removeSticky(true);\n      }\n    }\n  }\n\n  /**\n   * Causes the $element to become stuck.\n   * Adds `position: fixed;`, and helper classes.\n   * @fires Sticky#stuckto\n   * @function\n   * @private\n   */\n  _setSticky() {\n    var _this = this,\n        stickTo = this.options.stickTo,\n        mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickTo === 'top' ? 'bottom' : 'top',\n        css = {};\n\n    css[mrgn] = `${this.options[mrgn]}em`;\n    css[stickTo] = 0;\n    css[notStuckTo] = 'auto';\n    this.isStuck = true;\n    this.$element.removeClass(`is-anchored is-at-${notStuckTo}`)\n                 .addClass(`is-stuck is-at-${stickTo}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become `position: fixed;`\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`\n                  * @event Sticky#stuckto\n                  */\n                 .trigger(`sticky.zf.stuckto:${stickTo}`);\n    this.$element.on(\"transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd\", function() {\n      _this._setSizes();\n    });\n  }\n\n  /**\n   * Causes the $element to become unstuck.\n   * Removes `position: fixed;`, and helper classes.\n   * Adds other helper classes.\n   * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.\n   * @fires Sticky#unstuckfrom\n   * @private\n   */\n  _removeSticky(isTop) {\n    var stickTo = this.options.stickTo,\n        stickToTop = stickTo === 'top',\n        css = {},\n        anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,\n        mrgn = stickToTop ? 'marginTop' : 'marginBottom',\n        notStuckTo = stickToTop ? 'bottom' : 'top',\n        topOrBottom = isTop ? 'top' : 'bottom';\n\n    css[mrgn] = 0;\n\n    css['bottom'] = 'auto';\n    if(isTop) {\n      css['top'] = 0;\n    } else {\n      css['top'] = anchorPt;\n    }\n\n    this.isStuck = false;\n    this.$element.removeClass(`is-stuck is-at-${stickTo}`)\n                 .addClass(`is-anchored is-at-${topOrBottom}`)\n                 .css(css)\n                 /**\n                  * Fires when the $element has become anchored.\n                  * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`\n                  * @event Sticky#unstuckfrom\n                  */\n                 .trigger(`sticky.zf.unstuckfrom:${topOrBottom}`);\n  }\n\n  /**\n   * Sets the $element and $container sizes for plugin.\n   * Calls `_setBreakPoints`.\n   * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.\n   * @private\n   */\n  _setSizes(cb) {\n    this.canStick = MediaQuery.is(this.options.stickyOn);\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n    }\n    var _this = this,\n        newElemWidth = this.$container[0].getBoundingClientRect().width,\n        comp = window.getComputedStyle(this.$container[0]),\n        pdngl = parseInt(comp['padding-left'], 10),\n        pdngr = parseInt(comp['padding-right'], 10);\n\n    if (this.$anchor && this.$anchor.length) {\n      this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;\n    } else {\n      this._parsePoints();\n    }\n\n    this.$element.css({\n      'max-width': `${newElemWidth - pdngl - pdngr}px`\n    });\n\n    var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;\n    if (this.$element.css(\"display\") == \"none\") {\n      newContainerHeight = 0;\n    }\n    this.containerHeight = newContainerHeight;\n    this.$container.css({\n      height: newContainerHeight\n    });\n    this.elemHeight = newContainerHeight;\n\n    if (!this.isStuck) {\n      if (this.$element.hasClass('is-at-bottom')) {\n        var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;\n        this.$element.css('top', anchorPt);\n      }\n    }\n\n    this._setBreakPoints(newContainerHeight, function() {\n      if (cb && typeof cb === 'function') { cb(); }\n    });\n  }\n\n  /**\n   * Sets the upper and lower breakpoints for the element to become sticky/unsticky.\n   * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.\n   * @param {Function} cb - optional callback function to be called on completion.\n   * @private\n   */\n  _setBreakPoints(elemHeight, cb) {\n    if (!this.canStick) {\n      if (cb && typeof cb === 'function') { cb(); }\n      else { return false; }\n    }\n    var mTop = emCalc(this.options.marginTop),\n        mBtm = emCalc(this.options.marginBottom),\n        topPoint = this.points ? this.points[0] : this.$anchor.offset().top,\n        bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,\n        // topPoint = this.$anchor.offset().top || this.points[0],\n        // bottomPoint = topPoint + this.anchorHeight || this.points[1],\n        winHeight = window.innerHeight;\n\n    if (this.options.stickTo === 'top') {\n      topPoint -= mTop;\n      bottomPoint -= (elemHeight + mTop);\n    } else if (this.options.stickTo === 'bottom') {\n      topPoint -= (winHeight - (elemHeight + mBtm));\n      bottomPoint -= (winHeight - mBtm);\n    } else {\n      //this would be the stickTo: both option... tricky\n    }\n\n    this.topPoint = topPoint;\n    this.bottomPoint = bottomPoint;\n\n    if (cb && typeof cb === 'function') { cb(); }\n  }\n\n  /**\n   * Destroys the current sticky element.\n   * Resets the element to the top position first.\n   * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.\n   * @function\n   */\n  _destroy() {\n    this._removeSticky(true);\n\n    this.$element.removeClass(`${this.options.stickyClass} is-anchored is-at-top`)\n                 .css({\n                   height: '',\n                   top: '',\n                   bottom: '',\n                   'max-width': ''\n                 })\n                 .off('resizeme.zf.trigger')\n                 .off('mutateme.zf.trigger');\n    if (this.$anchor && this.$anchor.length) {\n      this.$anchor.off('change.zf.sticky');\n    }\n    if (this.scrollListener) $(window).off(this.scrollListener)\n    if (this.onLoadListener) $(window).off(this.onLoadListener)\n\n    if (this.wasWrapped) {\n      this.$element.unwrap();\n    } else {\n      this.$container.removeClass(this.options.containerClass)\n                     .css({\n                       height: ''\n                     });\n    }\n  }\n}\n\nSticky.defaults = {\n  /**\n   * Customizable container template. Add your own classes for styling and sizing.\n   * @option\n   * @type {string}\n   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'\n   */\n  container: '<div data-sticky-container></div>',\n  /**\n   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default 'top'\n   */\n  stickTo: 'top',\n  /**\n   * If anchored to a single element, the id of that element.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  anchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the top anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  topAnchor: '',\n  /**\n   * If using more than one element as anchor points, the id of the bottom anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  btmAnchor: '',\n  /**\n   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginTop: 1,\n  /**\n   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginBottom: 1,\n  /**\n   * Breakpoint string that is the minimum screen size an element should become sticky.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  stickyOn: 'medium',\n  /**\n   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.\n   * @option\n   * @type {string}\n   * @default 'sticky'\n   */\n  stickyClass: 'sticky',\n  /**\n   * Class applied to sticky container. Foundation defaults to `sticky-container`.\n   * @option\n   * @type {string}\n   * @default 'sticky-container'\n   */\n  containerClass: 'sticky-container',\n  /**\n   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.\n   * @option\n   * @type {number}\n   * @default -1\n   */\n  checkEvery: -1\n};\n\n/**\n * Helper function to calculate em values\n * @param Number {em} - number of em's to calculate into pixels\n */\nfunction emCalc(em) {\n  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;\n}\n\nexport {Sticky};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 3c5c8d63ba71cc5a9880a3e001eb79a8b76024fe..c87a46435f91d48aee6e9f24a1978be92bbc4705 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(n){if(i[n])return i[n].exports;var s=i[n]={i:n,l:!1,exports:{}};return t[n].call(s.exports,s,s.exports,e),s.l=!0,s.exports}var i={};e.m=t,e.c=i,e.i=function(t){return t},e.d=function(t,i,n){e.o(t,i)||Object.defineProperty(t,i,{configurable:!1,enumerable:!0,get:n})},e.n=function(t){var i=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(i,"a",i),i},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=96)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},3:function(t,e){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},30:function(t,e,i){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var n=i(1),s=(i.n(n),i(60));n.Foundation.plugin(s.a,"Sticky")},4:function(t,e){t.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},6:function(t,e){t.exports={MediaQuery:window.Foundation.MediaQuery}},60:function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function s(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function o(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function r(t){return parseInt(window.getComputedStyle(document.body,null).fontSize,10)*t}i.d(e,"a",function(){return g});var a=i(0),c=i.n(a),l=i(3),u=(i.n(l),i(6)),f=(i.n(u),i(2)),h=(i.n(f),i(7)),d=function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}(),g=function(t){function e(){return n(this,e),s(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return o(e,t),d(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=c.a.extend({},e.defaults,this.$element.data(),i),this.className="Sticky",h.a.init(c.a),this._init()}},{key:"_init",value:function(){u.MediaQuery._init();var t=this.$element.parent("[data-sticky-container]"),e=this.$element[0].id||i.i(l.GetYoDigits)(6,"sticky"),n=this;t.length?this.$container=t:(this.wasWrapped=!0,this.$element.wrap(this.options.container),this.$container=this.$element.parent()),this.$container.addClass(this.options.containerClass),this.$element.addClass(this.options.stickyClass).attr({"data-resize":e,"data-mutate":e}),""!==this.options.anchor&&c()("#"+n.options.anchor).attr({"data-mutate":e}),this.scrollCount=this.options.checkEvery,this.isStuck=!1,c()(window).one("load.zf.sticky",function(){n.containerHeight="none"==n.$element.css("display")?0:n.$element[0].getBoundingClientRect().height,n.$container.css("height",n.containerHeight),n.elemHeight=n.containerHeight,""!==n.options.anchor?n.$anchor=c()("#"+n.options.anchor):n._parsePoints(),n._setSizes(function(){var t=window.pageYOffset;n._calc(!1,t),n.isStuck||n._removeSticky(!(t>=n.topPoint))}),n._events(e.split("-").reverse().join("-"))})}},{key:"_parsePoints",value:function(){for(var t=""==this.options.topAnchor?1:this.options.topAnchor,e=""==this.options.btmAnchor?document.documentElement.scrollHeight:this.options.btmAnchor,i=[t,e],n={},s=0,o=i.length;s<o&&i[s];s++){var r;if("number"==typeof i[s])r=i[s];else{var a=i[s].split(":"),l=c()("#"+a[0]);r=l.offset().top,a[1]&&"bottom"===a[1].toLowerCase()&&(r+=l[0].getBoundingClientRect().height)}n[s]=r}this.points=n}},{key:"_events",value:function(t){var e=this,i=this.scrollListener="scroll.zf."+t;this.isOn||(this.canStick&&(this.isOn=!0,c()(window).off(i).on(i,function(t){0===e.scrollCount?(e.scrollCount=e.options.checkEvery,e._setSizes(function(){e._calc(!1,window.pageYOffset)})):(e.scrollCount--,e._calc(!1,window.pageYOffset))})),this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(i,n){e._eventsHandler(t)}),this.$element.on("mutateme.zf.trigger",function(i,n){e._eventsHandler(t)}),this.$anchor&&this.$anchor.on("mutateme.zf.trigger",function(i,n){e._eventsHandler(t)}))}},{key:"_eventsHandler",value:function(t){var e=this,i=this.scrollListener="scroll.zf."+t;e._setSizes(function(){e._calc(!1),e.canStick?e.isOn||e._events(t):e.isOn&&e._pauseListeners(i)})}},{key:"_pauseListeners",value:function(t){this.isOn=!1,c()(window).off(t),this.$element.trigger("pause.zf.sticky")}},{key:"_calc",value:function(t,e){if(t&&this._setSizes(),!this.canStick)return this.isStuck&&this._removeSticky(!0),!1;e||(e=window.pageYOffset),e>=this.topPoint?e<=this.bottomPoint?this.isStuck||this._setSticky():this.isStuck&&this._removeSticky(!1):this.isStuck&&this._removeSticky(!0)}},{key:"_setSticky",value:function(){var t=this,e=this.options.stickTo,i="top"===e?"marginTop":"marginBottom",n="top"===e?"bottom":"top",s={};s[i]=this.options[i]+"em",s[e]=0,s[n]="auto",this.isStuck=!0,this.$element.removeClass("is-anchored is-at-"+n).addClass("is-stuck is-at-"+e).css(s).trigger("sticky.zf.stuckto:"+e),this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd",function(){t._setSizes()})}},{key:"_removeSticky",value:function(t){var e=this.options.stickTo,i="top"===e,n={},s=(this.points?this.points[1]-this.points[0]:this.anchorHeight)-this.elemHeight,o=i?"marginTop":"marginBottom",r=t?"top":"bottom";n[o]=0,n.bottom="auto",n.top=t?0:s,this.isStuck=!1,this.$element.removeClass("is-stuck is-at-"+e).addClass("is-anchored is-at-"+r).css(n).trigger("sticky.zf.unstuckfrom:"+r)}},{key:"_setSizes",value:function(t){this.canStick=u.MediaQuery.is(this.options.stickyOn),this.canStick||t&&"function"==typeof t&&t();var e=this.$container[0].getBoundingClientRect().width,i=window.getComputedStyle(this.$container[0]),n=parseInt(i["padding-left"],10),s=parseInt(i["padding-right"],10);this.$anchor&&this.$anchor.length?this.anchorHeight=this.$anchor[0].getBoundingClientRect().height:this._parsePoints(),this.$element.css({"max-width":e-n-s+"px"});var o=this.$element[0].getBoundingClientRect().height||this.containerHeight;if("none"==this.$element.css("display")&&(o=0),this.containerHeight=o,this.$container.css({height:o}),this.elemHeight=o,!this.isStuck&&this.$element.hasClass("is-at-bottom")){var r=(this.points?this.points[1]-this.$container.offset().top:this.anchorHeight)-this.elemHeight;this.$element.css("top",r)}this._setBreakPoints(o,function(){t&&"function"==typeof t&&t()})}},{key:"_setBreakPoints",value:function(t,e){if(!this.canStick){if(!e||"function"!=typeof e)return!1;e()}var i=r(this.options.marginTop),n=r(this.options.marginBottom),s=this.points?this.points[0]:this.$anchor.offset().top,o=this.points?this.points[1]:s+this.anchorHeight,a=window.innerHeight;"top"===this.options.stickTo?(s-=i,o-=t+i):"bottom"===this.options.stickTo&&(s-=a-(t+n),o-=a-n),this.topPoint=s,this.bottomPoint=o,e&&"function"==typeof e&&e()}},{key:"_destroy",value:function(){this._removeSticky(!0),this.$element.removeClass(this.options.stickyClass+" is-anchored is-at-top").css({height:"",top:"",bottom:"","max-width":""}).off("resizeme.zf.trigger").off("mutateme.zf.trigger"),this.$anchor&&this.$anchor.length&&this.$anchor.off("change.zf.sticky"),c()(window).off(this.scrollListener),this.wasWrapped?this.$element.unwrap():this.$container.removeClass(this.options.containerClass).css({height:""})}}]),e}(f.Plugin);g.defaults={container:"<div data-sticky-container></div>",stickTo:"top",anchor:"",topAnchor:"",btmAnchor:"",marginTop:1,marginBottom:1,stickyOn:"medium",stickyClass:"sticky",containerClass:"sticky-container",checkEvery:-1}},7:function(t,e,i){"use strict";function n(t,e,i){var n=void 0,s=Array.prototype.slice.call(arguments,3);o()(window).off(e).on(e,function(e){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,s)},t||10)})}i.d(e,"a",function(){return l});var s=i(0),o=i.n(s),r=i(4),a=(i.n(r),function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if(t[e]+"MutationObserver"in window)return window[t[e]+"MutationObserver"];return!1}()),c=function(t,e){t.data(e).split(" ").forEach(function(i){o()("#"+i)["close"===e?"trigger":"triggerHandler"](e+".zf.trigger",[t])})},l={Listeners:{Basic:{},Global:{}},Initializers:{}};l.Listeners.Basic={openListener:function(){c(o()(this),"open")},closeListener:function(){o()(this).data("close")?c(o()(this),"close"):o()(this).trigger("close.zf.trigger")},toggleListener:function(){o()(this).data("toggle")?c(o()(this),"toggle"):o()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=o()(this).data("closable");""!==e?r.Motion.animateOut(o()(this),e,function(){o()(this).trigger("closed.zf")}):o()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=o()(this).data("toggle-focus");o()("#"+t).triggerHandler("toggle.zf.trigger",[o()(this)])}},l.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",l.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",l.Listeners.Basic.openListener)},l.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",l.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",l.Listeners.Basic.closeListener)},l.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",l.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",l.Listeners.Basic.toggleListener)},l.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",l.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",l.Listeners.Basic.closeableListener)},l.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",l.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",l.Listeners.Basic.toggleFocusListener)},l.Listeners.Global={resizeListener:function(t){a||t.each(function(){o()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){a||t.each(function(){o()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];o()("[data-"+i+"]").not('[data-yeti-box="'+e+'"]').each(function(){var t=o()(this);t.triggerHandler("close.zf.trigger",[t])})}},l.Initializers.addClosemeListener=function(t){var e=o()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"==typeof t&&"string"==typeof t[0]?i.concat(t):console.error("Plugin names must be strings")),e.length){var n=i.map(function(t){return"closeme.zf."+t}).join(" ");o()(window).off(n).on(n,l.Listeners.Global.closeMeListener)}},l.Initializers.addResizeListener=function(t){var e=o()("[data-resize]");e.length&&n(t,"resize.zf.trigger",l.Listeners.Global.resizeListener,e)},l.Initializers.addScrollListener=function(t){var e=o()("[data-scroll]");e.length&&n(t,"scroll.zf.trigger",l.Listeners.Global.scrollListener,e)},l.Initializers.addMutationEventsListener=function(t){if(!a)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=o()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var n=0;n<=e.length-1;n++){var s=new a(i);s.observe(e[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},l.Initializers.addSimpleListeners=function(){var t=o()(document);l.Initializers.addOpenListener(t),l.Initializers.addCloseListener(t),l.Initializers.addToggleListener(t),l.Initializers.addCloseableListener(t),l.Initializers.addToggleFocusListener(t)},l.Initializers.addGlobalListeners=function(){var t=o()(document);l.Initializers.addMutationEventsListener(t),l.Initializers.addResizeListener(),l.Initializers.addScrollListener(),l.Initializers.addClosemeListener()},l.init=function(t,e){if(void 0===t.triggersInitialized){t(document);"complete"===document.readyState?(l.Initializers.addSimpleListeners(),l.Initializers.addGlobalListeners()):t(window).on("load",function(){l.Initializers.addSimpleListeners(),l.Initializers.addGlobalListeners()}),t.triggersInitialized=!0}e&&(e.Triggers=l,e.IHearYou=l.Initializers.addGlobalListeners)}},96:function(t,e,i){t.exports=i(30)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.mediaQuery","./foundation.util.motion","jquery"],e):"object"==typeof exports?exports["foundation.sticky"]=e(require("./foundation.core"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.sticky"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],t.__FOUNDATION_EXTERNAL__["foundation.util.motion"],t.jQuery))}(window,function(i,n,o,s){return function(i){var n={};function o(t){if(n[t])return n[t].exports;var e=n[t]={i:t,l:!1,exports:{}};return i[t].call(e.exports,e,e.exports,o),e.l=!0,e.exports}return o.m=i,o.c=n,o.d=function(t,e,i){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:i})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var i=Object.create(null);if(o.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var n in e)o.d(i,n,function(t){return e[t]}.bind(null,n));return i},o.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return o.d(e,"a",e),e},o.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},o.p="",o(o.s=17)}({"./foundation.core":function(t,e){t.exports=i},"./foundation.util.mediaQuery":function(t,e){t.exports=n},"./foundation.util.motion":function(t,e){t.exports=o},"./js/entries/plugins/foundation.sticky.js":function(t,e,i){"use strict";i.r(e);var n=i("./foundation.core");i.d(e,"Foundation",function(){return n.Foundation});var o=i("./js/foundation.sticky.js");i.d(e,"Sticky",function(){return o.Sticky}),n.Foundation.plugin(o.Sticky,"Sticky")},"./js/foundation.sticky.js":function(t,e,i){"use strict";i.r(e),i.d(e,"Sticky",function(){return h});var n=i("jquery"),a=i.n(n),s=i("./foundation.core"),c=i("./foundation.util.mediaQuery"),r=i("./js/foundation.util.triggers.js");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}function l(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function d(t,e){return(d=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var h=function(t){function i(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),l(this,f(i).apply(this,arguments))}var e,n,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&d(t,e)}(i,s["Plugin"]),e=i,(n=[{key:"_setup",value:function(t,e){this.$element=t,this.options=a.a.extend({},i.defaults,this.$element.data(),e),this.className="Sticky",r.Triggers.init(a.a),this._init()}},{key:"_init",value:function(){c.MediaQuery._init();var t=this.$element.parent("[data-sticky-container]"),e=this.$element[0].id||Object(s.GetYoDigits)(6,"sticky"),i=this;t.length?this.$container=t:(this.wasWrapped=!0,this.$element.wrap(this.options.container),this.$container=this.$element.parent()),this.$container.addClass(this.options.containerClass),this.$element.addClass(this.options.stickyClass).attr({"data-resize":e,"data-mutate":e}),""!==this.options.anchor&&a()("#"+i.options.anchor).attr({"data-mutate":e}),this.scrollCount=this.options.checkEvery,this.isStuck=!1,this.onLoadListener=Object(s.onLoad)(a()(window),function(){i.containerHeight="none"==i.$element.css("display")?0:i.$element[0].getBoundingClientRect().height,i.$container.css("height",i.containerHeight),i.elemHeight=i.containerHeight,""!==i.options.anchor?i.$anchor=a()("#"+i.options.anchor):i._parsePoints(),i._setSizes(function(){var t=window.pageYOffset;i._calc(!1,t),i.isStuck||i._removeSticky(!(t>=i.topPoint))}),i._events(e.split("-").reverse().join("-"))})}},{key:"_parsePoints",value:function(){for(var t=[""==this.options.topAnchor?1:this.options.topAnchor,""==this.options.btmAnchor?document.documentElement.scrollHeight:this.options.btmAnchor],e={},i=0,n=t.length;i<n&&t[i];i++){var o;if("number"==typeof t[i])o=t[i];else{var s=t[i].split(":"),r=a()("#".concat(s[0]));o=r.offset().top,s[1]&&"bottom"===s[1].toLowerCase()&&(o+=r[0].getBoundingClientRect().height)}e[i]=o}this.points=e}},{key:"_events",value:function(i){var n=this,t=this.scrollListener="scroll.zf.".concat(i);this.isOn||(this.canStick&&(this.isOn=!0,a()(window).off(t).on(t,function(t){0===n.scrollCount?(n.scrollCount=n.options.checkEvery,n._setSizes(function(){n._calc(!1,window.pageYOffset)})):(n.scrollCount--,n._calc(!1,window.pageYOffset))})),this.$element.off("resizeme.zf.trigger").on("resizeme.zf.trigger",function(t,e){n._eventsHandler(i)}),this.$element.on("mutateme.zf.trigger",function(t,e){n._eventsHandler(i)}),this.$anchor&&this.$anchor.on("mutateme.zf.trigger",function(t,e){n._eventsHandler(i)}))}},{key:"_eventsHandler",value:function(t){var e=this,i=this.scrollListener="scroll.zf.".concat(t);e._setSizes(function(){e._calc(!1),e.canStick?e.isOn||e._events(t):e.isOn&&e._pauseListeners(i)})}},{key:"_pauseListeners",value:function(t){this.isOn=!1,a()(window).off(t),this.$element.trigger("pause.zf.sticky")}},{key:"_calc",value:function(t,e){if(t&&this._setSizes(),!this.canStick)return this.isStuck&&this._removeSticky(!0),!1;e||(e=window.pageYOffset),e>=this.topPoint?e<=this.bottomPoint?this.isStuck||this._setSticky():this.isStuck&&this._removeSticky(!1):this.isStuck&&this._removeSticky(!0)}},{key:"_setSticky",value:function(){var t=this,e=this.options.stickTo,i="top"===e?"marginTop":"marginBottom",n="top"===e?"bottom":"top",o={};o[i]="".concat(this.options[i],"em"),o[e]=0,o[n]="auto",this.isStuck=!0,this.$element.removeClass("is-anchored is-at-".concat(n)).addClass("is-stuck is-at-".concat(e)).css(o).trigger("sticky.zf.stuckto:".concat(e)),this.$element.on("transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd",function(){t._setSizes()})}},{key:"_removeSticky",value:function(t){var e=this.options.stickTo,i="top"===e,n={},o=(this.points?this.points[1]-this.points[0]:this.anchorHeight)-this.elemHeight,s=t?"top":"bottom";n[i?"marginTop":"marginBottom"]=0,n.bottom="auto",n.top=t?0:o,this.isStuck=!1,this.$element.removeClass("is-stuck is-at-".concat(e)).addClass("is-anchored is-at-".concat(s)).css(n).trigger("sticky.zf.unstuckfrom:".concat(s))}},{key:"_setSizes",value:function(t){this.canStick=c.MediaQuery.is(this.options.stickyOn),this.canStick||t&&"function"==typeof t&&t();var e=this.$container[0].getBoundingClientRect().width,i=window.getComputedStyle(this.$container[0]),n=parseInt(i["padding-left"],10),o=parseInt(i["padding-right"],10);this.$anchor&&this.$anchor.length?this.anchorHeight=this.$anchor[0].getBoundingClientRect().height:this._parsePoints(),this.$element.css({"max-width":"".concat(e-n-o,"px")});var s=this.$element[0].getBoundingClientRect().height||this.containerHeight;if("none"==this.$element.css("display")&&(s=0),this.containerHeight=s,this.$container.css({height:s}),this.elemHeight=s,!this.isStuck&&this.$element.hasClass("is-at-bottom")){var r=(this.points?this.points[1]-this.$container.offset().top:this.anchorHeight)-this.elemHeight;this.$element.css("top",r)}this._setBreakPoints(s,function(){t&&"function"==typeof t&&t()})}},{key:"_setBreakPoints",value:function(t,e){if(!this.canStick){if(!e||"function"!=typeof e)return!1;e()}var i=g(this.options.marginTop),n=g(this.options.marginBottom),o=this.points?this.points[0]:this.$anchor.offset().top,s=this.points?this.points[1]:o+this.anchorHeight,r=window.innerHeight;"top"===this.options.stickTo?(o-=i,s-=t+i):"bottom"===this.options.stickTo&&(o-=r-(t+n),s-=r-n),this.topPoint=o,this.bottomPoint=s,e&&"function"==typeof e&&e()}},{key:"_destroy",value:function(){this._removeSticky(!0),this.$element.removeClass("".concat(this.options.stickyClass," is-anchored is-at-top")).css({height:"",top:"",bottom:"","max-width":""}).off("resizeme.zf.trigger").off("mutateme.zf.trigger"),this.$anchor&&this.$anchor.length&&this.$anchor.off("change.zf.sticky"),this.scrollListener&&a()(window).off(this.scrollListener),this.onLoadListener&&a()(window).off(this.onLoadListener),this.wasWrapped?this.$element.unwrap():this.$container.removeClass(this.options.containerClass).css({height:""})}}])&&u(e.prototype,n),o&&u(e,o),i}();function g(t){return parseInt(window.getComputedStyle(document.body,null).fontSize,10)*t}h.defaults={container:"<div data-sticky-container></div>",stickTo:"top",anchor:"",topAnchor:"",btmAnchor:"",marginTop:1,marginBottom:1,stickyOn:"medium",stickyClass:"sticky",containerClass:"sticky-container",checkEvery:-1}},"./js/foundation.util.triggers.js":function(t,e,i){"use strict";i.r(e),i.d(e,"Triggers",function(){return l});var n=i("jquery"),s=i.n(n),o=i("./foundation.core"),r=i("./foundation.util.motion");function a(t){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var c=function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if("".concat(t[e],"MutationObserver")in window)return window["".concat(t[e],"MutationObserver")];return!1}(),u=function(e,i){e.data(i).split(" ").forEach(function(t){s()("#".concat(t))["close"===i?"trigger":"triggerHandler"]("".concat(i,".zf.trigger"),[e])})},l={Listeners:{Basic:{},Global:{}},Initializers:{}};function f(e,t,i){var n,o=Array.prototype.slice.call(arguments,3);s()(window).off(t).on(t,function(t){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,o)},e||10)})}l.Listeners.Basic={openListener:function(){u(s()(this),"open")},closeListener:function(){s()(this).data("close")?u(s()(this),"close"):s()(this).trigger("close.zf.trigger")},toggleListener:function(){s()(this).data("toggle")?u(s()(this),"toggle"):s()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=s()(this).data("closable");""!==e?r.Motion.animateOut(s()(this),e,function(){s()(this).trigger("closed.zf")}):s()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=s()(this).data("toggle-focus");s()("#".concat(t)).triggerHandler("toggle.zf.trigger",[s()(this)])}},l.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",l.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",l.Listeners.Basic.openListener)},l.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",l.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",l.Listeners.Basic.closeListener)},l.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",l.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",l.Listeners.Basic.toggleListener)},l.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",l.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",l.Listeners.Basic.closeableListener)},l.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",l.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",l.Listeners.Basic.toggleFocusListener)},l.Listeners.Global={resizeListener:function(t){c||t.each(function(){s()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){c||t.each(function(){s()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];s()("[data-".concat(i,"]")).not('[data-yeti-box="'.concat(e,'"]')).each(function(){var t=s()(this);t.triggerHandler("close.zf.trigger",[t])})}},l.Initializers.addClosemeListener=function(t){var e=s()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"===a(t)&&"string"==typeof t[0]?i=i.concat(t):console.error("Plugin names must be strings")),e.length){var n=i.map(function(t){return"closeme.zf.".concat(t)}).join(" ");s()(window).off(n).on(n,l.Listeners.Global.closeMeListener)}},l.Initializers.addResizeListener=function(t){var e=s()("[data-resize]");e.length&&f(t,"resize.zf.trigger",l.Listeners.Global.resizeListener,e)},l.Initializers.addScrollListener=function(t){var e=s()("[data-scroll]");e.length&&f(t,"scroll.zf.trigger",l.Listeners.Global.scrollListener,e)},l.Initializers.addMutationEventsListener=function(t){if(!c)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=s()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var n=0;n<=e.length-1;n++){new c(i).observe(e[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},l.Initializers.addSimpleListeners=function(){var t=s()(document);l.Initializers.addOpenListener(t),l.Initializers.addCloseListener(t),l.Initializers.addToggleListener(t),l.Initializers.addCloseableListener(t),l.Initializers.addToggleFocusListener(t)},l.Initializers.addGlobalListeners=function(){var t=s()(document);l.Initializers.addMutationEventsListener(t),l.Initializers.addResizeListener(),l.Initializers.addScrollListener(),l.Initializers.addClosemeListener()},l.init=function(t,e){Object(o.onLoad)(t(window),function(){!0!==t.triggersInitialized&&(l.Initializers.addSimpleListeners(),l.Initializers.addGlobalListeners(),t.triggersInitialized=!0)}),e&&(e.Triggers=l,e.IHearYou=l.Initializers.addGlobalListeners)}},17:function(t,e,i){t.exports=i("./js/entries/plugins/foundation.sticky.js")},jquery:function(t,e){t.exports=s}})});
+//# sourceMappingURL=foundation.sticky.min.js.map
diff --git a/dist/js/plugins/foundation.sticky.min.js.map b/dist/js/plugins/foundation.sticky.min.js.map
new file mode 100644 (file)
index 0000000..21c9aa5
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.sticky.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.mediaQuery","./foundation.util.motion","./js/entries/plugins/foundation.sticky.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_sticky__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.sticky.js","Sticky","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","init","_init","$parent","parent","id","_this","$container","wasWrapped","wrap","container","addClass","containerClass","stickyClass","attr","data-resize","data-mutate","anchor","scrollCount","checkEvery","isStuck","onLoadListener","containerHeight","css","getBoundingClientRect","height","elemHeight","$anchor","_parsePoints","_setSizes","scroll","pageYOffset","_calc","_removeSticky","topPoint","_events","split","reverse","join","pts","topAnchor","btmAnchor","document","documentElement","scrollHeight","breaks","len","pt","place","concat","offset","top","toLowerCase","points","scrollListener","isOn","canStick","off","on","e","el","_eventsHandler","_pauseListeners","trigger","checkSizes","bottomPoint","_setSticky","stickTo","mrgn","notStuckTo","removeClass","isTop","stickToTop","anchorPt","anchorHeight","topOrBottom","cb","is","stickyOn","newElemWidth","width","comp","getComputedStyle","pdngl","parseInt","pdngr","max-width","newContainerHeight","hasClass","_setBreakPoints","mTop","emCalc","marginTop","mBtm","marginBottom","winHeight","innerHeight","bottom","unwrap","em","body","fontSize","./js/foundation.util.triggers.js","Triggers","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","MutationObserver","prefixes","triggers","type","forEach","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","listener","timer","args","Array","slice","clearTimeout","setTimeout","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","closeMeListener","pluginId","namespace","not","addClosemeListener","pluginName","yetiBoxes","plugNames","push","console","error","listeners","map","addResizeListener","addScrollListener","addMutationEventsListener","find","listeningElementsMutation","mutationRecordsList","$target","attributeName","closest","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","$","Foundation","triggersInitialized","IHearYou","17","jquery"],"mappings":"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","file":"foundation.sticky.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.sticky\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.sticky\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 17);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.sticky.js\":\n/*!*************************************************!*\\\n  !*** ./js/entries/plugins/foundation.sticky.js ***!\n  \\*************************************************/\n/*! exports provided: Foundation, Sticky */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_sticky__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.sticky */ \"./js/foundation.sticky.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Sticky\", function() { return _foundation_sticky__WEBPACK_IMPORTED_MODULE_1__[\"Sticky\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_sticky__WEBPACK_IMPORTED_MODULE_1__[\"Sticky\"], 'Sticky');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.sticky.js\":\n/*!*********************************!*\\\n  !*** ./js/foundation.sticky.js ***!\n  \\*********************************/\n/*! exports provided: Sticky */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Sticky\", function() { return Sticky; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Sticky module.\n * @module foundation.sticky\n * @requires foundation.util.triggers\n * @requires foundation.util.mediaQuery\n */\n\nvar Sticky =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Sticky, _Plugin);\n\n  function Sticky() {\n    _classCallCheck(this, Sticky);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Sticky).apply(this, arguments));\n  }\n\n  _createClass(Sticky, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a sticky thing.\n     * @class\n     * @name Sticky\n     * @param {jQuery} element - jQuery object to make sticky.\n     * @param {Object} options - options object passed when creating the element programmatically.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Sticky.defaults, this.$element.data(), options);\n      this.className = 'Sticky'; // ie9 back compat\n      // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n    }\n    /**\n     * Initializes the sticky element by adding classes, getting/setting dimensions, breakpoints and attributes\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"]._init();\n\n      var $parent = this.$element.parent('[data-sticky-container]'),\n          id = this.$element[0].id || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'sticky'),\n          _this = this;\n\n      if ($parent.length) {\n        this.$container = $parent;\n      } else {\n        this.wasWrapped = true;\n        this.$element.wrap(this.options.container);\n        this.$container = this.$element.parent();\n      }\n\n      this.$container.addClass(this.options.containerClass);\n      this.$element.addClass(this.options.stickyClass).attr({\n        'data-resize': id,\n        'data-mutate': id\n      });\n\n      if (this.options.anchor !== '') {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor).attr({\n          'data-mutate': id\n        });\n      }\n\n      this.scrollCount = this.options.checkEvery;\n      this.isStuck = false;\n      this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n        //We calculate the container height to have correct values for anchor points offset calculation.\n        _this.containerHeight = _this.$element.css(\"display\") == \"none\" ? 0 : _this.$element[0].getBoundingClientRect().height;\n\n        _this.$container.css('height', _this.containerHeight);\n\n        _this.elemHeight = _this.containerHeight;\n\n        if (_this.options.anchor !== '') {\n          _this.$anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()('#' + _this.options.anchor);\n        } else {\n          _this._parsePoints();\n        }\n\n        _this._setSizes(function () {\n          var scroll = window.pageYOffset;\n\n          _this._calc(false, scroll); //Unstick the element will ensure that proper classes are set.\n\n\n          if (!_this.isStuck) {\n            _this._removeSticky(scroll >= _this.topPoint ? false : true);\n          }\n        });\n\n        _this._events(id.split('-').reverse().join('-'));\n      });\n    }\n    /**\n     * If using multiple elements as anchors, calculates the top and bottom pixel values the sticky thing should stick and unstick on.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_parsePoints\",\n    value: function _parsePoints() {\n      var top = this.options.topAnchor == \"\" ? 1 : this.options.topAnchor,\n          btm = this.options.btmAnchor == \"\" ? document.documentElement.scrollHeight : this.options.btmAnchor,\n          pts = [top, btm],\n          breaks = {};\n\n      for (var i = 0, len = pts.length; i < len && pts[i]; i++) {\n        var pt;\n\n        if (typeof pts[i] === 'number') {\n          pt = pts[i];\n        } else {\n          var place = pts[i].split(':'),\n              anchor = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(place[0]));\n          pt = anchor.offset().top;\n\n          if (place[1] && place[1].toLowerCase() === 'bottom') {\n            pt += anchor[0].getBoundingClientRect().height;\n          }\n        }\n\n        breaks[i] = pt;\n      }\n\n      this.points = breaks;\n      return;\n    }\n    /**\n     * Adds event handlers for the scrolling element.\n     * @private\n     * @param {String} id - pseudo-random id for unique scroll event listener.\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events(id) {\n      var _this = this,\n          scrollListener = this.scrollListener = \"scroll.zf.\".concat(id);\n\n      if (this.isOn) {\n        return;\n      }\n\n      if (this.canStick) {\n        this.isOn = true;\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener).on(scrollListener, function (e) {\n          if (_this.scrollCount === 0) {\n            _this.scrollCount = _this.options.checkEvery;\n\n            _this._setSizes(function () {\n              _this._calc(false, window.pageYOffset);\n            });\n          } else {\n            _this.scrollCount--;\n\n            _this._calc(false, window.pageYOffset);\n          }\n        });\n      }\n\n      this.$element.off('resizeme.zf.trigger').on('resizeme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n      });\n      this.$element.on('mutateme.zf.trigger', function (e, el) {\n        _this._eventsHandler(id);\n      });\n\n      if (this.$anchor) {\n        this.$anchor.on('mutateme.zf.trigger', function (e, el) {\n          _this._eventsHandler(id);\n        });\n      }\n    }\n    /**\n     * Handler for events.\n     * @private\n     * @param {String} id - pseudo-random id for unique scroll event listener.\n     */\n\n  }, {\n    key: \"_eventsHandler\",\n    value: function _eventsHandler(id) {\n      var _this = this,\n          scrollListener = this.scrollListener = \"scroll.zf.\".concat(id);\n\n      _this._setSizes(function () {\n        _this._calc(false);\n\n        if (_this.canStick) {\n          if (!_this.isOn) {\n            _this._events(id);\n          }\n        } else if (_this.isOn) {\n          _this._pauseListeners(scrollListener);\n        }\n      });\n    }\n    /**\n     * Removes event handlers for scroll and change events on anchor.\n     * @fires Sticky#pause\n     * @param {String} scrollListener - unique, namespaced scroll listener attached to `window`\n     */\n\n  }, {\n    key: \"_pauseListeners\",\n    value: function _pauseListeners(scrollListener) {\n      this.isOn = false;\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(scrollListener);\n      /**\n       * Fires when the plugin is paused due to resize event shrinking the view.\n       * @event Sticky#pause\n       * @private\n       */\n\n      this.$element.trigger('pause.zf.sticky');\n    }\n    /**\n     * Called on every `scroll` event and on `_init`\n     * fires functions based on booleans and cached values\n     * @param {Boolean} checkSizes - true if plugin should recalculate sizes and breakpoints.\n     * @param {Number} scroll - current scroll position passed from scroll event cb function. If not passed, defaults to `window.pageYOffset`.\n     */\n\n  }, {\n    key: \"_calc\",\n    value: function _calc(checkSizes, scroll) {\n      if (checkSizes) {\n        this._setSizes();\n      }\n\n      if (!this.canStick) {\n        if (this.isStuck) {\n          this._removeSticky(true);\n        }\n\n        return false;\n      }\n\n      if (!scroll) {\n        scroll = window.pageYOffset;\n      }\n\n      if (scroll >= this.topPoint) {\n        if (scroll <= this.bottomPoint) {\n          if (!this.isStuck) {\n            this._setSticky();\n          }\n        } else {\n          if (this.isStuck) {\n            this._removeSticky(false);\n          }\n        }\n      } else {\n        if (this.isStuck) {\n          this._removeSticky(true);\n        }\n      }\n    }\n    /**\n     * Causes the $element to become stuck.\n     * Adds `position: fixed;`, and helper classes.\n     * @fires Sticky#stuckto\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_setSticky\",\n    value: function _setSticky() {\n      var _this = this,\n          stickTo = this.options.stickTo,\n          mrgn = stickTo === 'top' ? 'marginTop' : 'marginBottom',\n          notStuckTo = stickTo === 'top' ? 'bottom' : 'top',\n          css = {};\n\n      css[mrgn] = \"\".concat(this.options[mrgn], \"em\");\n      css[stickTo] = 0;\n      css[notStuckTo] = 'auto';\n      this.isStuck = true;\n      this.$element.removeClass(\"is-anchored is-at-\".concat(notStuckTo)).addClass(\"is-stuck is-at-\".concat(stickTo)).css(css)\n      /**\n       * Fires when the $element has become `position: fixed;`\n       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.stuckto:top`\n       * @event Sticky#stuckto\n       */\n      .trigger(\"sticky.zf.stuckto:\".concat(stickTo));\n      this.$element.on(\"transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd\", function () {\n        _this._setSizes();\n      });\n    }\n    /**\n     * Causes the $element to become unstuck.\n     * Removes `position: fixed;`, and helper classes.\n     * Adds other helper classes.\n     * @param {Boolean} isTop - tells the function if the $element should anchor to the top or bottom of its $anchor element.\n     * @fires Sticky#unstuckfrom\n     * @private\n     */\n\n  }, {\n    key: \"_removeSticky\",\n    value: function _removeSticky(isTop) {\n      var stickTo = this.options.stickTo,\n          stickToTop = stickTo === 'top',\n          css = {},\n          anchorPt = (this.points ? this.points[1] - this.points[0] : this.anchorHeight) - this.elemHeight,\n          mrgn = stickToTop ? 'marginTop' : 'marginBottom',\n          notStuckTo = stickToTop ? 'bottom' : 'top',\n          topOrBottom = isTop ? 'top' : 'bottom';\n      css[mrgn] = 0;\n      css['bottom'] = 'auto';\n\n      if (isTop) {\n        css['top'] = 0;\n      } else {\n        css['top'] = anchorPt;\n      }\n\n      this.isStuck = false;\n      this.$element.removeClass(\"is-stuck is-at-\".concat(stickTo)).addClass(\"is-anchored is-at-\".concat(topOrBottom)).css(css)\n      /**\n       * Fires when the $element has become anchored.\n       * Namespaced to `top` or `bottom`, e.g. `sticky.zf.unstuckfrom:bottom`\n       * @event Sticky#unstuckfrom\n       */\n      .trigger(\"sticky.zf.unstuckfrom:\".concat(topOrBottom));\n    }\n    /**\n     * Sets the $element and $container sizes for plugin.\n     * Calls `_setBreakPoints`.\n     * @param {Function} cb - optional callback function to fire on completion of `_setBreakPoints`.\n     * @private\n     */\n\n  }, {\n    key: \"_setSizes\",\n    value: function _setSizes(cb) {\n      this.canStick = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"].is(this.options.stickyOn);\n\n      if (!this.canStick) {\n        if (cb && typeof cb === 'function') {\n          cb();\n        }\n      }\n\n      var _this = this,\n          newElemWidth = this.$container[0].getBoundingClientRect().width,\n          comp = window.getComputedStyle(this.$container[0]),\n          pdngl = parseInt(comp['padding-left'], 10),\n          pdngr = parseInt(comp['padding-right'], 10);\n\n      if (this.$anchor && this.$anchor.length) {\n        this.anchorHeight = this.$anchor[0].getBoundingClientRect().height;\n      } else {\n        this._parsePoints();\n      }\n\n      this.$element.css({\n        'max-width': \"\".concat(newElemWidth - pdngl - pdngr, \"px\")\n      });\n      var newContainerHeight = this.$element[0].getBoundingClientRect().height || this.containerHeight;\n\n      if (this.$element.css(\"display\") == \"none\") {\n        newContainerHeight = 0;\n      }\n\n      this.containerHeight = newContainerHeight;\n      this.$container.css({\n        height: newContainerHeight\n      });\n      this.elemHeight = newContainerHeight;\n\n      if (!this.isStuck) {\n        if (this.$element.hasClass('is-at-bottom')) {\n          var anchorPt = (this.points ? this.points[1] - this.$container.offset().top : this.anchorHeight) - this.elemHeight;\n          this.$element.css('top', anchorPt);\n        }\n      }\n\n      this._setBreakPoints(newContainerHeight, function () {\n        if (cb && typeof cb === 'function') {\n          cb();\n        }\n      });\n    }\n    /**\n     * Sets the upper and lower breakpoints for the element to become sticky/unsticky.\n     * @param {Number} elemHeight - px value for sticky.$element height, calculated by `_setSizes`.\n     * @param {Function} cb - optional callback function to be called on completion.\n     * @private\n     */\n\n  }, {\n    key: \"_setBreakPoints\",\n    value: function _setBreakPoints(elemHeight, cb) {\n      if (!this.canStick) {\n        if (cb && typeof cb === 'function') {\n          cb();\n        } else {\n          return false;\n        }\n      }\n\n      var mTop = emCalc(this.options.marginTop),\n          mBtm = emCalc(this.options.marginBottom),\n          topPoint = this.points ? this.points[0] : this.$anchor.offset().top,\n          bottomPoint = this.points ? this.points[1] : topPoint + this.anchorHeight,\n          // topPoint = this.$anchor.offset().top || this.points[0],\n      // bottomPoint = topPoint + this.anchorHeight || this.points[1],\n      winHeight = window.innerHeight;\n\n      if (this.options.stickTo === 'top') {\n        topPoint -= mTop;\n        bottomPoint -= elemHeight + mTop;\n      } else if (this.options.stickTo === 'bottom') {\n        topPoint -= winHeight - (elemHeight + mBtm);\n        bottomPoint -= winHeight - mBtm;\n      } else {//this would be the stickTo: both option... tricky\n      }\n\n      this.topPoint = topPoint;\n      this.bottomPoint = bottomPoint;\n\n      if (cb && typeof cb === 'function') {\n        cb();\n      }\n    }\n    /**\n     * Destroys the current sticky element.\n     * Resets the element to the top position first.\n     * Removes event listeners, JS-added css properties and classes, and unwraps the $element if the JS added the $container.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this._removeSticky(true);\n\n      this.$element.removeClass(\"\".concat(this.options.stickyClass, \" is-anchored is-at-top\")).css({\n        height: '',\n        top: '',\n        bottom: '',\n        'max-width': ''\n      }).off('resizeme.zf.trigger').off('mutateme.zf.trigger');\n\n      if (this.$anchor && this.$anchor.length) {\n        this.$anchor.off('change.zf.sticky');\n      }\n\n      if (this.scrollListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.scrollListener);\n      if (this.onLoadListener) jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n\n      if (this.wasWrapped) {\n        this.$element.unwrap();\n      } else {\n        this.$container.removeClass(this.options.containerClass).css({\n          height: ''\n        });\n      }\n    }\n  }]);\n\n  return Sticky;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n\nSticky.defaults = {\n  /**\n   * Customizable container template. Add your own classes for styling and sizing.\n   * @option\n   * @type {string}\n   * @default '&lt;div data-sticky-container&gt;&lt;/div&gt;'\n   */\n  container: '<div data-sticky-container></div>',\n\n  /**\n   * Location in the view the element sticks to. Can be `'top'` or `'bottom'`.\n   * @option\n   * @type {string}\n   * @default 'top'\n   */\n  stickTo: 'top',\n\n  /**\n   * If anchored to a single element, the id of that element.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  anchor: '',\n\n  /**\n   * If using more than one element as anchor points, the id of the top anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  topAnchor: '',\n\n  /**\n   * If using more than one element as anchor points, the id of the bottom anchor.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  btmAnchor: '',\n\n  /**\n   * Margin, in `em`'s to apply to the top of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginTop: 1,\n\n  /**\n   * Margin, in `em`'s to apply to the bottom of the element when it becomes sticky.\n   * @option\n   * @type {number}\n   * @default 1\n   */\n  marginBottom: 1,\n\n  /**\n   * Breakpoint string that is the minimum screen size an element should become sticky.\n   * @option\n   * @type {string}\n   * @default 'medium'\n   */\n  stickyOn: 'medium',\n\n  /**\n   * Class applied to sticky element, and removed on destruction. Foundation defaults to `sticky`.\n   * @option\n   * @type {string}\n   * @default 'sticky'\n   */\n  stickyClass: 'sticky',\n\n  /**\n   * Class applied to sticky container. Foundation defaults to `sticky-container`.\n   * @option\n   * @type {string}\n   * @default 'sticky-container'\n   */\n  containerClass: 'sticky-container',\n\n  /**\n   * Number of scroll events between the plugin's recalculating sticky points. Setting it to `0` will cause it to recalc every scroll event, setting it to `-1` will prevent recalc on scroll.\n   * @option\n   * @type {number}\n   * @default -1\n   */\n  checkEvery: -1\n};\n/**\n * Helper function to calculate em values\n * @param Number {em} - number of em's to calculate into pixels\n */\n\nfunction emCalc(em) {\n  return parseInt(window.getComputedStyle(document.body, null).fontSize, 10) * em;\n}\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 17:\n/*!*******************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.sticky.js ***!\n  \\*******************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.sticky.js */\"./js/entries/plugins/foundation.sticky.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.sticky.js.map"]}
\ No newline at end of file
index e9943e18550f622d304fdc146058217c1f71cc75..702f43d862284f6b6bc5712d3d8eb62caefc942f 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.imageLoader"), require("./foundation.util.keyboard"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.imageLoader", "./foundation.util.keyboard", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.tabs"] = factory(require("./foundation.core"), require("./foundation.util.imageLoader"), require("./foundation.util.keyboard"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.tabs"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.imageLoader"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 97);
+/******/       return __webpack_require__(__webpack_require__.s = 18);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.imageLoader":
+/*!****************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.imageLoader"],"amd":"./foundation.util.imageLoader","commonjs":"./foundation.util.imageLoader","commonjs2":"./foundation.util.imageLoader"} ***!
+  \****************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;
 
 /***/ }),
 
-/***/ 10:
+/***/ "./foundation.util.keyboard":
+/*!****************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.keyboard"],"amd":"./foundation.util.keyboard","commonjs":"./foundation.util.keyboard","commonjs2":"./foundation.util.keyboard"} ***!
+  \****************************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {onImagesLoaded: window.Foundation.onImagesLoaded};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;
 
 /***/ }),
 
-/***/ 2:
-/***/ (function(module, exports) {
-
-module.exports = {Plugin: window.Foundation.Plugin};
-
-/***/ }),
-
-/***/ 31:
+/***/ "./js/entries/plugins/foundation.tabs.js":
+/*!***********************************************!*\
+  !*** ./js/entries/plugins/foundation.tabs.js ***!
+  \***********************************************/
+/*! exports provided: Foundation, Tabs */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_tabs__ = __webpack_require__(61);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.tabs */ "./js/foundation.tabs.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Tabs", function() { return _foundation_tabs__WEBPACK_IMPORTED_MODULE_1__["Tabs"]; });
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_tabs__["a" /* Tabs */], 'Tabs');
 
-/***/ }),
 
-/***/ 5:
-/***/ (function(module, exports) {
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_tabs__WEBPACK_IMPORTED_MODULE_1__["Tabs"], 'Tabs');
 
-module.exports = {Keyboard: window.Foundation.Keyboard};
 
 /***/ }),
 
-/***/ 61:
+/***/ "./js/foundation.tabs.js":
+/*!*******************************!*\
+  !*** ./js/foundation.tabs.js ***!
+  \*******************************/
+/*! exports provided: Tabs */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Tabs; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(5);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__ = __webpack_require__(10);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Tabs", function() { return Tabs; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ "./foundation.util.keyboard");
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.imageLoader */ "./foundation.util.imageLoader");
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
+
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
-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; }
 
 
 
@@ -152,17 +202,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.imageLoader if tabs contain images
  */
 
-var Tabs = function (_Plugin) {
+var Tabs =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Tabs, _Plugin);
 
   function Tabs() {
     _classCallCheck(this, Tabs);
 
-    return _possibleConstructorReturn(this, (Tabs.__proto__ || Object.getPrototypeOf(Tabs)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments));
   }
 
   _createClass(Tabs, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of tabs.
@@ -174,48 +226,50 @@ var Tabs = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Tabs.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tabs.defaults, this.$element.data(), options);
       this.className = 'Tabs'; // ie9 back compat
 
       this._init();
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].register('Tabs', {
+
+      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].register('Tabs', {
         'ENTER': 'open',
         'SPACE': 'open',
         'ARROW_RIGHT': 'next',
         'ARROW_UP': 'previous',
         'ARROW_DOWN': 'next',
-        'ARROW_LEFT': 'previous'
-        // 'TAB': 'next',
+        'ARROW_LEFT': 'previous' // 'TAB': 'next',
         // 'SHIFT_TAB': 'previous'
+
       });
     }
-
     /**
      * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      var _this3 = this;
+      var _this2 = this;
 
       var _this = this;
 
-      this.$element.attr({ 'role': 'tablist' });
-      this.$tabTitles = this.$element.find('.' + this.options.linkClass);
-      this.$tabContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-tabs-content="' + this.$element[0].id + '"]');
-
+      this._isInitializing = true;
+      this.$element.attr({
+        'role': 'tablist'
+      });
+      this.$tabTitles = this.$element.find(".".concat(this.options.linkClass));
+      this.$tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-tabs-content=\"".concat(this.$element[0].id, "\"]"));
       this.$tabTitles.each(function () {
-        var $elem = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             $link = $elem.find('a'),
-            isActive = $elem.hasClass('' + _this.options.linkActiveClass),
+            isActive = $elem.hasClass("".concat(_this.options.linkActiveClass)),
             hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),
-            linkId = $link[0].id ? $link[0].id : hash + '-label',
-            $tabContent = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + hash);
-
-        $elem.attr({ 'role': 'presentation' });
-
+            linkId = $link[0].id ? $link[0].id : "".concat(hash, "-label"),
+            $tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(hash));
+        $elem.attr({
+          'role': 'presentation'
+        });
         $link.attr({
           'role': 'tab',
           'aria-controls': hash,
@@ -223,126 +277,151 @@ var Tabs = function (_Plugin) {
           'id': linkId,
           'tabindex': isActive ? '0' : '-1'
         });
-
         $tabContent.attr({
           'role': 'tabpanel',
           'aria-labelledby': linkId
-        });
+        }); // Save up the initial hash to return to it later when going back in history
+
+        if (isActive) {
+          _this._initialAnchor = "#".concat(hash);
+        }
 
         if (!isActive) {
           $tabContent.attr('aria-hidden', 'true');
         }
 
         if (isActive && _this.options.autoFocus) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).load(function () {
-            __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, function () {
+          _this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({
+              scrollTop: $elem.offset().top
+            }, _this.options.deepLinkSmudgeDelay, function () {
               $link.focus();
             });
           });
         }
       });
+
       if (this.options.matchHeight) {
         var $images = this.$tabContent.find('img');
 
         if ($images.length) {
-          __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_imageLoader__["onImagesLoaded"])($images, this._setHeight.bind(this));
+          Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__["onImagesLoaded"])($images, this._setHeight.bind(this));
         } else {
           this._setHeight();
         }
-      }
+      } // Current context-bound function to open tabs on page load or history hashchange
+
 
-      //current context-bound function to open tabs on page load or history popstate
       this._checkDeepLink = function () {
         var anchor = window.location.hash;
-        //need a hash and a relevant anchor in this tabset
-        if (anchor.length) {
-          var $link = _this3.$element.find('[href$="' + anchor + '"]');
-          if ($link.length) {
-            _this3.selectTab(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(anchor), true);
-
-            //roll up a little to show the titles
-            if (_this3.options.deepLinkSmudge) {
-              var offset = _this3.$element.offset();
-              __WEBPACK_IMPORTED_MODULE_0_jquery___default()('html, body').animate({ scrollTop: offset.top }, _this3.options.deepLinkSmudgeDelay);
-            }
 
-            /**
-              * Fires when the zplugin has deeplinked at pageload
-              * @event Tabs#deeplink
-              */
-            _this3.$element.trigger('deeplink.zf.tabs', [$link, __WEBPACK_IMPORTED_MODULE_0_jquery___default()(anchor)]);
+        if (!anchor.length) {
+          // If we are still initializing and there is no anchor, then there is nothing to do
+          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor
+
+          if (_this2._initialAnchor) anchor = _this2._initialAnchor;
+        }
+
+        var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor);
+
+        var $link = anchor && _this2.$element.find('[href$="' + anchor + '"]'); // Whether the anchor element that has been found is part of this element
+
+
+        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, select it
+
+        if ($anchor && $anchor.length && $link && $link.length) {
+          _this2.selectTab($anchor, true);
+        } // Otherwise, collapse everything
+        else {
+            _this2._collapse();
           }
+
+        if (isOwnAnchor) {
+          // Roll up a little to show the titles
+          if (_this2.options.deepLinkSmudge) {
+            var offset = _this2.$element.offset();
+
+            jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({
+              scrollTop: offset.top
+            }, _this2.options.deepLinkSmudgeDelay);
+          }
+          /**
+           * Fires when the plugin has deeplinked at pageload
+           * @event Tabs#deeplink
+           */
+
+
+          _this2.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);
         }
-      };
+      }; //use browser to open a tab, if it exists in this tabset
+
 
-      //use browser to open a tab, if it exists in this tabset
       if (this.options.deepLink) {
         this._checkDeepLink();
       }
 
       this._events();
-    }
 
+      this._isInitializing = false;
+    }
     /**
      * Adds event handlers for items within the tabs.
      * @private
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       this._addKeyHandler();
+
       this._addClickHandler();
+
       this._setHeightMqHandler = null;
 
       if (this.options.matchHeight) {
         this._setHeightMqHandler = this._setHeight.bind(this);
-
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('changed.zf.mediaquery', this._setHeightMqHandler);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._setHeightMqHandler);
       }
 
       if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).on('popstate', this._checkDeepLink);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink);
       }
     }
-
     /**
      * Adds click handlers for items within the tabs.
      * @private
      */
 
   }, {
-    key: '_addClickHandler',
+    key: "_addClickHandler",
     value: function _addClickHandler() {
       var _this = this;
 
-      this.$element.off('click.zf.tabs').on('click.zf.tabs', '.' + this.options.linkClass, function (e) {
+      this.$element.off('click.zf.tabs').on('click.zf.tabs', ".".concat(this.options.linkClass), function (e) {
         e.preventDefault();
         e.stopPropagation();
-        _this._handleTabChange(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this));
+
+        _this._handleTabChange(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));
       });
     }
-
     /**
      * Adds keyboard event handlers for items within the tabs.
      * @private
      */
 
   }, {
-    key: '_addKeyHandler',
+    key: "_addKeyHandler",
     value: function _addKeyHandler() {
       var _this = this;
 
       this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) {
         if (e.which === 9) return;
-
-        var $element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
             $elements = $element.parent('ul').children('li'),
             $prevElement,
             $nextElement;
-
         $elements.each(function (i) {
-          if (__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is($element)) {
+          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {
             if (_this.options.wrapOnKeys) {
               $prevElement = i === 0 ? $elements.last() : $elements.eq(i - 1);
               $nextElement = i === $elements.length - 1 ? $elements.first() : $elements.eq(i + 1);
@@ -350,32 +429,34 @@ var Tabs = function (_Plugin) {
               $prevElement = $elements.eq(Math.max(0, i - 1));
               $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));
             }
+
             return;
           }
-        });
+        }); // handle keyboard event with keyboard util
 
-        // handle keyboard event with keyboard util
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["Keyboard"].handleKey(e, 'Tabs', {
-          open: function () {
+        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__["Keyboard"].handleKey(e, 'Tabs', {
+          open: function open() {
             $element.find('[role="tab"]').focus();
+
             _this._handleTabChange($element);
           },
-          previous: function () {
+          previous: function previous() {
             $prevElement.find('[role="tab"]').focus();
+
             _this._handleTabChange($prevElement);
           },
-          next: function () {
+          next: function next() {
             $nextElement.find('[role="tab"]').focus();
+
             _this._handleTabChange($nextElement);
           },
-          handled: function () {
+          handled: function handled() {
             e.stopPropagation();
             e.preventDefault();
           }
         });
       });
     }
-
     /**
      * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.
      * @param {jQuery} $target - Tab to open.
@@ -385,97 +466,104 @@ var Tabs = function (_Plugin) {
      */
 
   }, {
-    key: '_handleTabChange',
+    key: "_handleTabChange",
     value: function _handleTabChange($target, historyHandled) {
-
-      /**
-       * Check for active class on target. Collapse if exists.
-       */
-      if ($target.hasClass('' + this.options.linkActiveClass)) {
+      // With `activeCollapse`, if the target is the active Tab, collapse it.
+      if ($target.hasClass("".concat(this.options.linkActiveClass))) {
         if (this.options.activeCollapse) {
-          this._collapseTab($target);
-
-          /**
-           * Fires when the zplugin has successfully collapsed tabs.
-           * @event Tabs#collapse
-           */
-          this.$element.trigger('collapse.zf.tabs', [$target]);
+          this._collapse();
         }
+
         return;
       }
 
-      var $oldTab = this.$element.find('.' + this.options.linkClass + '.' + this.options.linkActiveClass),
+      var $oldTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass)),
           $tabLink = $target.find('[role="tab"]'),
-          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),
-          $targetContent = this.$tabContent.find('#' + hash);
+          target = $tabLink.attr('data-tabs-target'),
+          anchor = target && target.length ? "#".concat(target) : $tabLink[0].hash,
+          $targetContent = this.$tabContent.find(anchor); //close old tab
 
-      //close old tab
-      this._collapseTab($oldTab);
+      this._collapseTab($oldTab); //open new tab
 
-      //open new tab
-      this._openTab($target);
 
-      //either replace or update browser history
-      if (this.options.deepLink && !historyHandled) {
-        var anchor = $target.find('a').attr('href');
+      this._openTab($target); //either replace or update browser history
+
 
+      if (this.options.deepLink && !historyHandled) {
         if (this.options.updateHistory) {
           history.pushState({}, '', anchor);
         } else {
           history.replaceState({}, '', anchor);
         }
       }
-
       /**
        * Fires when the plugin has successfully changed tabs.
        * @event Tabs#change
        */
-      this.$element.trigger('change.zf.tabs', [$target, $targetContent]);
 
-      //fire to children a mutation event
+
+      this.$element.trigger('change.zf.tabs', [$target, $targetContent]); //fire to children a mutation event
+
       $targetContent.find("[data-mutate]").trigger("mutateme.zf.trigger");
     }
-
     /**
      * Opens the tab `$targetContent` defined by `$target`.
-     * @param {jQuery} $target - Tab to Open.
+     * @param {jQuery} $target - Tab to open.
      * @function
      */
 
   }, {
-    key: '_openTab',
+    key: "_openTab",
     value: function _openTab($target) {
       var $tabLink = $target.find('[role="tab"]'),
           hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),
-          $targetContent = this.$tabContent.find('#' + hash);
-
-      $target.addClass('' + this.options.linkActiveClass);
-
+          $targetContent = this.$tabContent.find("#".concat(hash));
+      $target.addClass("".concat(this.options.linkActiveClass));
       $tabLink.attr({
         'aria-selected': 'true',
         'tabindex': '0'
       });
-
-      $targetContent.addClass('' + this.options.panelActiveClass).removeAttr('aria-hidden');
+      $targetContent.addClass("".concat(this.options.panelActiveClass)).removeAttr('aria-hidden');
     }
-
     /**
      * Collapses `$targetContent` defined by `$target`.
-     * @param {jQuery} $target - Tab to Open.
+     * @param {jQuery} $target - Tab to collapse.
      * @function
      */
 
   }, {
-    key: '_collapseTab',
+    key: "_collapseTab",
     value: function _collapseTab($target) {
-      var $target_anchor = $target.removeClass('' + this.options.linkActiveClass).find('[role="tab"]').attr({
+      var $target_anchor = $target.removeClass("".concat(this.options.linkActiveClass)).find('[role="tab"]').attr({
         'aria-selected': 'false',
         'tabindex': -1
       });
-
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + $target_anchor.attr('aria-controls')).removeClass('' + this.options.panelActiveClass).attr({ 'aria-hidden': 'true' });
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat($target_anchor.attr('aria-controls'))).removeClass("".concat(this.options.panelActiveClass)).attr({
+        'aria-hidden': 'true'
+      });
     }
+    /**
+     * Collapses the active Tab.
+     * @fires Tabs#collapse
+     * @function
+     */
+
+  }, {
+    key: "_collapse",
+    value: function _collapse() {
+      var $activeTab = this.$element.find(".".concat(this.options.linkClass, ".").concat(this.options.linkActiveClass));
+
+      if ($activeTab.length) {
+        this._collapseTab($activeTab);
+        /**
+        * Fires when the plugin has successfully collapsed tabs.
+        * @event Tabs#collapse
+        */
+
 
+        this.$element.trigger('collapse.zf.tabs', [$activeTab]);
+      }
+    }
     /**
      * Public method for selecting a content pane to display.
      * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.
@@ -484,26 +572,26 @@ var Tabs = function (_Plugin) {
      */
 
   }, {
-    key: 'selectTab',
+    key: "selectTab",
     value: function selectTab(elem, historyHandled) {
       var idStr;
 
-      if (typeof elem === 'object') {
+      if (_typeof(elem) === 'object') {
         idStr = elem[0].id;
       } else {
         idStr = elem;
       }
 
       if (idStr.indexOf('#') < 0) {
-        idStr = '#' + idStr;
+        idStr = "#".concat(idStr);
       }
 
-      var $target = this.$tabTitles.find('[href$="' + idStr + '"]').parent('.' + this.options.linkClass);
+      var $target = this.$tabTitles.has("[href$=\"".concat(idStr, "\"]"));
 
       this._handleTabChange($target, historyHandled);
     }
   }, {
-    key: '_setHeight',
+    key: "_setHeight",
 
     /**
      * Sets the height of each panel to the height of the tallest panel.
@@ -517,13 +605,16 @@ var Tabs = function (_Plugin) {
       var max = 0,
           _this = this; // Lock down the `this` value for the root tabs object
 
-      this.$tabContent.find('.' + this.options.panelClass).css('height', '').each(function () {
 
-        var panel = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
-            isActive = panel.hasClass('' + _this.options.panelActiveClass); // get the options from the parent instead of trying to get them from the child
+      this.$tabContent.find(".".concat(this.options.panelClass)).css('height', '').each(function () {
+        var panel = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
+            isActive = panel.hasClass("".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child
 
         if (!isActive) {
-          panel.css({ 'visibility': 'hidden', 'display': 'block' });
+          panel.css({
+            'visibility': 'hidden',
+            'display': 'block'
+          });
         }
 
         var temp = this.getBoundingClientRect().height;
@@ -536,37 +627,41 @@ var Tabs = function (_Plugin) {
         }
 
         max = temp > max ? temp : max;
-      }).css('height', max + 'px');
+      }).css('height', "".concat(max, "px"));
     }
-
     /**
-     * Destroys an instance of an tabs.
+     * Destroys an instance of tabs.
      * @fires Tabs#destroyed
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
-      this.$element.find('.' + this.options.linkClass).off('.zf.tabs').hide().end().find('.' + this.options.panelClass).hide();
+      this.$element.find(".".concat(this.options.linkClass)).off('.zf.tabs').hide().end().find(".".concat(this.options.panelClass)).hide();
 
       if (this.options.matchHeight) {
         if (this._setHeightMqHandler != null) {
-          __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('changed.zf.mediaquery', this._setHeightMqHandler);
+          jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._setHeightMqHandler);
         }
       }
 
       if (this.options.deepLink) {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('popstate', this._checkDeepLink);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink);
+      }
+
+      if (this.onLoadListener) {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);
       }
     }
   }]);
 
   return Tabs;
-}(__WEBPACK_IMPORTED_MODULE_3__foundation_plugin__["Plugin"]);
+}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 
 Tabs.defaults = {
   /**
-   * Allows the window to scroll to content of pane specified by hash anchor
+   * Link the location hash to the active pane.
+   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.
    * @option
    * @type {boolean}
    * @default false
@@ -574,7 +669,7 @@ Tabs.defaults = {
   deepLink: false,
 
   /**
-   * Adjust the deep link scroll to make sure the top of the tab panel is visible
+   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible
    * @option
    * @type {boolean}
    * @default false
@@ -582,7 +677,7 @@ Tabs.defaults = {
   deepLinkSmudge: false,
 
   /**
-   * Animation time (ms) for the deep link adjustment
+   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment
    * @option
    * @type {number}
    * @default 300
@@ -590,7 +685,7 @@ Tabs.defaults = {
   deepLinkSmudgeDelay: 300,
 
   /**
-   * Update the browser history with the open tab
+   * If `deepLink` is enabled, update the browser history with the open tab
    * @option
    * @type {boolean}
    * @default false
@@ -598,7 +693,7 @@ Tabs.defaults = {
   updateHistory: false,
 
   /**
-   * Allows the window to scroll to content of active pane on load if set to true.
+   * Allows the window to scroll to content of active pane on load.
    * Not recommended if more than one tab panel per page.
    * @option
    * @type {boolean}
@@ -664,15 +759,31 @@ Tabs.defaults = {
 };
 
 
-
 /***/ }),
 
-/***/ 97:
+/***/ 18:
+/*!*****************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.tabs.js ***!
+  \*****************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(31);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.tabs.js */"./js/entries/plugins/foundation.tabs.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.tabs.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.tabs.js.map b/dist/js/plugins/foundation.tabs.js.map
new file mode 100644 (file)
index 0000000..22a2ca9
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.imageLoader\"],\"amd\":\"./foundation.util.imageLoader\",\"commonjs\":\"./foundation.util.imageLoader\",\"commonjs2\":\"./foundation.util.imageLoader\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.tabs.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.tabs.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Tabs","element","options","$element","$","extend","defaults","data","className","_init","Keyboard","register","_this","_isInitializing","attr","$tabTitles","find","linkClass","$tabContent","id","each","$elem","$link","isActive","hasClass","linkActiveClass","hash","slice","linkId","_initialAnchor","autoFocus","onLoadListener","onLoad","window","animate","scrollTop","offset","top","deepLinkSmudgeDelay","focus","matchHeight","$images","length","onImagesLoaded","_setHeight","bind","_checkDeepLink","anchor","location","$anchor","isOwnAnchor","selectTab","_collapse","deepLinkSmudge","trigger","deepLink","_events","_addKeyHandler","_addClickHandler","_setHeightMqHandler","on","off","e","preventDefault","stopPropagation","_handleTabChange","which","$elements","parent","children","$prevElement","$nextElement","i","is","wrapOnKeys","last","eq","first","Math","max","min","handleKey","open","previous","next","handled","$target","historyHandled","activeCollapse","$oldTab","$tabLink","target","$targetContent","_collapseTab","_openTab","updateHistory","history","pushState","replaceState","addClass","panelActiveClass","removeAttr","$target_anchor","removeClass","$activeTab","elem","idStr","indexOf","has","panelClass","css","panel","temp","getBoundingClientRect","height","hide","end","Plugin"],"mappings":"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","file":"foundation.tabs.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.keyboard\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.imageLoader\", \"./foundation.util.keyboard\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.tabs\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.keyboard\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.tabs\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.imageLoader\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 18);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;","import { Foundation } from './foundation.core';\n\nimport { Tabs } from '../../foundation.tabs';\nFoundation.plugin(Tabs, 'Tabs');\n\nexport { Foundation, Tabs };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Keyboard } from './foundation.util.keyboard';\nimport { onImagesLoaded } from './foundation.util.imageLoader';\nimport { Plugin } from './foundation.core.plugin';\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.imageLoader if tabs contain images\n */\n\nclass Tabs extends Plugin {\n  /**\n   * Creates a new instance of tabs.\n   * @class\n   * @name Tabs\n   * @fires Tabs#init\n   * @param {jQuery} element - jQuery object to make into tabs.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tabs.defaults, this.$element.data(), options);\n    this.className = 'Tabs'; // ie9 back compat\n\n    this._init();\n    Keyboard.register('Tabs', {\n      'ENTER': 'open',\n      'SPACE': 'open',\n      'ARROW_RIGHT': 'next',\n      'ARROW_UP': 'previous',\n      'ARROW_DOWN': 'next',\n      'ARROW_LEFT': 'previous'\n      // 'TAB': 'next',\n      // 'SHIFT_TAB': 'previous'\n    });\n  }\n\n  /**\n   * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.\n   * @private\n   */\n  _init() {\n    var _this = this;\n    this._isInitializing = true;\n\n    this.$element.attr({'role': 'tablist'});\n    this.$tabTitles = this.$element.find(`.${this.options.linkClass}`);\n    this.$tabContent = $(`[data-tabs-content=\"${this.$element[0].id}\"]`);\n\n    this.$tabTitles.each(function(){\n      var $elem = $(this),\n          $link = $elem.find('a'),\n          isActive = $elem.hasClass(`${_this.options.linkActiveClass}`),\n          hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),\n          linkId = $link[0].id ? $link[0].id : `${hash}-label`,\n          $tabContent = $(`#${hash}`);\n\n      $elem.attr({'role': 'presentation'});\n\n      $link.attr({\n        'role': 'tab',\n        'aria-controls': hash,\n        'aria-selected': isActive,\n        'id': linkId,\n        'tabindex': isActive ? '0' : '-1'\n      });\n\n      $tabContent.attr({\n        'role': 'tabpanel',\n        'aria-labelledby': linkId\n      });\n\n      // Save up the initial hash to return to it later when going back in history\n      if (isActive) {\n        _this._initialAnchor = `#${hash}`;\n      }\n\n      if(!isActive) {\n        $tabContent.attr('aria-hidden', 'true');\n      }\n\n      if(isActive && _this.options.autoFocus){\n        _this.onLoadListener = onLoad($(window), function() {\n          $('html, body').animate({ scrollTop: $elem.offset().top }, _this.options.deepLinkSmudgeDelay, () => {\n            $link.focus();\n          });\n        });\n      }\n    });\n\n    if(this.options.matchHeight) {\n      var $images = this.$tabContent.find('img');\n\n      if ($images.length) {\n        onImagesLoaded($images, this._setHeight.bind(this));\n      } else {\n        this._setHeight();\n      }\n    }\n\n     // Current context-bound function to open tabs on page load or history hashchange\n    this._checkDeepLink = () => {\n      var anchor = window.location.hash;\n\n      if (!anchor.length) {\n        // If we are still initializing and there is no anchor, then there is nothing to do\n        if (this._isInitializing) return;\n        // Otherwise, move to the initial anchor\n        if (this._initialAnchor) anchor = this._initialAnchor;\n      }\n\n      var $anchor = anchor && $(anchor);\n      var $link = anchor && this.$element.find('[href$=\"'+anchor+'\"]');\n      // Whether the anchor element that has been found is part of this element\n      var isOwnAnchor = !!($anchor.length && $link.length);\n\n      // If there is an anchor for the hash, select it\n      if ($anchor && $anchor.length && $link && $link.length) {\n        this.selectTab($anchor, true);\n      }\n      // Otherwise, collapse everything\n      else {\n        this._collapse();\n      }\n\n      if (isOwnAnchor) {\n        // Roll up a little to show the titles\n        if (this.options.deepLinkSmudge) {\n          var offset = this.$element.offset();\n          $('html, body').animate({ scrollTop: offset.top }, this.options.deepLinkSmudgeDelay);\n        }\n\n        /**\n         * Fires when the plugin has deeplinked at pageload\n         * @event Tabs#deeplink\n         */\n        this.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);\n      }\n    }\n\n    //use browser to open a tab, if it exists in this tabset\n    if (this.options.deepLink) {\n      this._checkDeepLink();\n    }\n\n    this._events();\n\n    this._isInitializing = false;\n  }\n\n  /**\n   * Adds event handlers for items within the tabs.\n   * @private\n   */\n  _events() {\n    this._addKeyHandler();\n    this._addClickHandler();\n    this._setHeightMqHandler = null;\n\n    if (this.options.matchHeight) {\n      this._setHeightMqHandler = this._setHeight.bind(this);\n\n      $(window).on('changed.zf.mediaquery', this._setHeightMqHandler);\n    }\n\n    if(this.options.deepLink) {\n      $(window).on('hashchange', this._checkDeepLink);\n    }\n  }\n\n  /**\n   * Adds click handlers for items within the tabs.\n   * @private\n   */\n  _addClickHandler() {\n    var _this = this;\n\n    this.$element\n      .off('click.zf.tabs')\n      .on('click.zf.tabs', `.${this.options.linkClass}`, function(e){\n        e.preventDefault();\n        e.stopPropagation();\n        _this._handleTabChange($(this));\n      });\n  }\n\n  /**\n   * Adds keyboard event handlers for items within the tabs.\n   * @private\n   */\n  _addKeyHandler() {\n    var _this = this;\n\n    this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function(e){\n      if (e.which === 9) return;\n\n\n      var $element = $(this),\n        $elements = $element.parent('ul').children('li'),\n        $prevElement,\n        $nextElement;\n\n      $elements.each(function(i) {\n        if ($(this).is($element)) {\n          if (_this.options.wrapOnKeys) {\n            $prevElement = i === 0 ? $elements.last() : $elements.eq(i-1);\n            $nextElement = i === $elements.length -1 ? $elements.first() : $elements.eq(i+1);\n          } else {\n            $prevElement = $elements.eq(Math.max(0, i-1));\n            $nextElement = $elements.eq(Math.min(i+1, $elements.length-1));\n          }\n          return;\n        }\n      });\n\n      // handle keyboard event with keyboard util\n      Keyboard.handleKey(e, 'Tabs', {\n        open: function() {\n          $element.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($element);\n        },\n        previous: function() {\n          $prevElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($prevElement);\n        },\n        next: function() {\n          $nextElement.find('[role=\"tab\"]').focus();\n          _this._handleTabChange($nextElement);\n        },\n        handled: function() {\n          e.stopPropagation();\n          e.preventDefault();\n        }\n      });\n    });\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.\n   * @param {jQuery} $target - Tab to open.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @fires Tabs#change\n   * @function\n   */\n  _handleTabChange($target, historyHandled) {\n\n    // With `activeCollapse`, if the target is the active Tab, collapse it.\n    if ($target.hasClass(`${this.options.linkActiveClass}`)) {\n        if(this.options.activeCollapse) {\n            this._collapse();\n        }\n        return;\n    }\n\n    var $oldTab = this.$element.\n          find(`.${this.options.linkClass}.${this.options.linkActiveClass}`),\n          $tabLink = $target.find('[role=\"tab\"]'),\n          target = $tabLink.attr('data-tabs-target'),\n          anchor = target && target.length ? `#${target}` : $tabLink[0].hash,\n          $targetContent = this.$tabContent.find(anchor);\n\n    //close old tab\n    this._collapseTab($oldTab);\n\n    //open new tab\n    this._openTab($target);\n\n    //either replace or update browser history\n    if (this.options.deepLink && !historyHandled) {\n      if (this.options.updateHistory) {\n        history.pushState({}, '', anchor);\n      } else {\n        history.replaceState({}, '', anchor);\n      }\n    }\n\n    /**\n     * Fires when the plugin has successfully changed tabs.\n     * @event Tabs#change\n     */\n    this.$element.trigger('change.zf.tabs', [$target, $targetContent]);\n\n    //fire to children a mutation event\n    $targetContent.find(\"[data-mutate]\").trigger(\"mutateme.zf.trigger\");\n  }\n\n  /**\n   * Opens the tab `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to open.\n   * @function\n   */\n  _openTab($target) {\n      var $tabLink = $target.find('[role=\"tab\"]'),\n          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),\n          $targetContent = this.$tabContent.find(`#${hash}`);\n\n      $target.addClass(`${this.options.linkActiveClass}`);\n\n      $tabLink.attr({\n        'aria-selected': 'true',\n        'tabindex': '0'\n      });\n\n      $targetContent\n        .addClass(`${this.options.panelActiveClass}`).removeAttr('aria-hidden');\n  }\n\n  /**\n   * Collapses `$targetContent` defined by `$target`.\n   * @param {jQuery} $target - Tab to collapse.\n   * @function\n   */\n  _collapseTab($target) {\n    var $target_anchor = $target\n      .removeClass(`${this.options.linkActiveClass}`)\n      .find('[role=\"tab\"]')\n      .attr({\n        'aria-selected': 'false',\n        'tabindex': -1\n      });\n\n    $(`#${$target_anchor.attr('aria-controls')}`)\n      .removeClass(`${this.options.panelActiveClass}`)\n      .attr({ 'aria-hidden': 'true' })\n  }\n\n  /**\n   * Collapses the active Tab.\n   * @fires Tabs#collapse\n   * @function\n   */\n  _collapse() {\n    var $activeTab = this.$element.find(`.${this.options.linkClass}.${this.options.linkActiveClass}`);\n\n    if ($activeTab.length) {\n      this._collapseTab($activeTab);\n\n      /**\n      * Fires when the plugin has successfully collapsed tabs.\n      * @event Tabs#collapse\n      */\n      this.$element.trigger('collapse.zf.tabs', [$activeTab]);\n    }\n  }\n\n  /**\n   * Public method for selecting a content pane to display.\n   * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.\n   * @param {boolean} historyHandled - browser has already handled a history update\n   * @function\n   */\n  selectTab(elem, historyHandled) {\n    var idStr;\n\n    if (typeof elem === 'object') {\n      idStr = elem[0].id;\n    } else {\n      idStr = elem;\n    }\n\n    if (idStr.indexOf('#') < 0) {\n      idStr = `#${idStr}`;\n    }\n\n    var $target = this.$tabTitles.has(`[href$=\"${idStr}\"]`);\n\n    this._handleTabChange($target, historyHandled);\n  };\n\n  /**\n   * Sets the height of each panel to the height of the tallest panel.\n   * If enabled in options, gets called on media query change.\n   * If loading content via external source, can be called directly or with _reflow.\n   * If enabled with `data-match-height=\"true\"`, tabs sets to equal height\n   * @function\n   * @private\n   */\n  _setHeight() {\n    var max = 0,\n        _this = this; // Lock down the `this` value for the root tabs object\n\n    this.$tabContent\n      .find(`.${this.options.panelClass}`)\n      .css('height', '')\n      .each(function() {\n\n        var panel = $(this),\n            isActive = panel.hasClass(`${_this.options.panelActiveClass}`); // get the options from the parent instead of trying to get them from the child\n\n        if (!isActive) {\n          panel.css({'visibility': 'hidden', 'display': 'block'});\n        }\n\n        var temp = this.getBoundingClientRect().height;\n\n        if (!isActive) {\n          panel.css({\n            'visibility': '',\n            'display': ''\n          });\n        }\n\n        max = temp > max ? temp : max;\n      })\n      .css('height', `${max}px`);\n  }\n\n  /**\n   * Destroys an instance of tabs.\n   * @fires Tabs#destroyed\n   */\n  _destroy() {\n    this.$element\n      .find(`.${this.options.linkClass}`)\n      .off('.zf.tabs').hide().end()\n      .find(`.${this.options.panelClass}`)\n      .hide();\n\n    if (this.options.matchHeight) {\n      if (this._setHeightMqHandler != null) {\n         $(window).off('changed.zf.mediaquery', this._setHeightMqHandler);\n      }\n    }\n\n    if (this.options.deepLink) {\n      $(window).off('hashchange', this._checkDeepLink);\n    }\n\n    if (this.onLoadListener) {\n      $(window).off(this.onLoadListener);\n    }\n  }\n}\n\nTabs.defaults = {\n  /**\n   * Link the location hash to the active pane.\n   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open tab\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n   * Allows the window to scroll to content of active pane on load.\n   * Not recommended if more than one tab panel per page.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows keyboard input to 'wrap' around the tab links.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  wrapOnKeys: true,\n\n  /**\n   * Allows the tab content panes to match heights if set to true.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  matchHeight: false,\n\n  /**\n   * Allows active tabs to collapse when clicked.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  activeCollapse: false,\n\n  /**\n   * Class applied to `li`'s in tab link list.\n   * @option\n   * @type {string}\n   * @default 'tabs-title'\n   */\n  linkClass: 'tabs-title',\n\n  /**\n   * Class applied to the active `li` in tab link list.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  linkActiveClass: 'is-active',\n\n  /**\n   * Class applied to the content containers.\n   * @option\n   * @type {string}\n   * @default 'tabs-panel'\n   */\n  panelClass: 'tabs-panel',\n\n  /**\n   * Class applied to the active content container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  panelActiveClass: 'is-active'\n};\n\nexport {Tabs};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 5d2a60fac45389d00a503a4d5fc8e945d2206a26..d2319cc70d67d9906a18420c78c767af37f0c771 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(n){if(i[n])return i[n].exports;var a=i[n]={i:n,l:!1,exports:{}};return t[n].call(a.exports,a,a.exports,e),a.l=!0,a.exports}var i={};e.m=t,e.c=i,e.i=function(t){return t},e.d=function(t,i,n){e.o(t,i)||Object.defineProperty(t,i,{configurable:!1,enumerable:!0,get:n})},e.n=function(t){var i=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(i,"a",i),i},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=97)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},10:function(t,e){t.exports={onImagesLoaded:window.Foundation.onImagesLoaded}},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},31:function(t,e,i){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var n=i(1),a=(i.n(n),i(61));n.Foundation.plugin(a.a,"Tabs")},5:function(t,e){t.exports={Keyboard:window.Foundation.Keyboard}},61:function(t,e,i){"use strict";function n(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function a(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function s(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return u});var o=i(0),r=i.n(o),l=i(5),h=(i.n(l),i(10)),d=(i.n(h),i(2)),c=(i.n(d),function(){function t(t,e){for(var i=0;i<e.length;i++){var n=e[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(t,n.key,n)}}return function(e,i,n){return i&&t(e.prototype,i),n&&t(e,n),e}}()),u=function(t){function e(){return n(this,e),a(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return s(e,t),c(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=r.a.extend({},e.defaults,this.$element.data(),i),this.className="Tabs",this._init(),l.Keyboard.register("Tabs",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"previous",ARROW_DOWN:"next",ARROW_LEFT:"previous"})}},{key:"_init",value:function(){var t=this,e=this;if(this.$element.attr({role:"tablist"}),this.$tabTitles=this.$element.find("."+this.options.linkClass),this.$tabContent=r()('[data-tabs-content="'+this.$element[0].id+'"]'),this.$tabTitles.each(function(){var t=r()(this),i=t.find("a"),n=t.hasClass(""+e.options.linkActiveClass),a=i.attr("data-tabs-target")||i[0].hash.slice(1),s=i[0].id?i[0].id:a+"-label",o=r()("#"+a);t.attr({role:"presentation"}),i.attr({role:"tab","aria-controls":a,"aria-selected":n,id:s,tabindex:n?"0":"-1"}),o.attr({role:"tabpanel","aria-labelledby":s}),n||o.attr("aria-hidden","true"),n&&e.options.autoFocus&&r()(window).load(function(){r()("html, body").animate({scrollTop:t.offset().top},e.options.deepLinkSmudgeDelay,function(){i.focus()})})}),this.options.matchHeight){var n=this.$tabContent.find("img");n.length?i.i(h.onImagesLoaded)(n,this._setHeight.bind(this)):this._setHeight()}this._checkDeepLink=function(){var e=window.location.hash;if(e.length){var i=t.$element.find('[href$="'+e+'"]');if(i.length){if(t.selectTab(r()(e),!0),t.options.deepLinkSmudge){var n=t.$element.offset();r()("html, body").animate({scrollTop:n.top},t.options.deepLinkSmudgeDelay)}t.$element.trigger("deeplink.zf.tabs",[i,r()(e)])}}},this.options.deepLink&&this._checkDeepLink(),this._events()}},{key:"_events",value:function(){this._addKeyHandler(),this._addClickHandler(),this._setHeightMqHandler=null,this.options.matchHeight&&(this._setHeightMqHandler=this._setHeight.bind(this),r()(window).on("changed.zf.mediaquery",this._setHeightMqHandler)),this.options.deepLink&&r()(window).on("popstate",this._checkDeepLink)}},{key:"_addClickHandler",value:function(){var t=this;this.$element.off("click.zf.tabs").on("click.zf.tabs","."+this.options.linkClass,function(e){e.preventDefault(),e.stopPropagation(),t._handleTabChange(r()(this))})}},{key:"_addKeyHandler",value:function(){var t=this;this.$tabTitles.off("keydown.zf.tabs").on("keydown.zf.tabs",function(e){if(9!==e.which){var i,n,a=r()(this),s=a.parent("ul").children("li");s.each(function(e){if(r()(this).is(a))return void(t.options.wrapOnKeys?(i=0===e?s.last():s.eq(e-1),n=e===s.length-1?s.first():s.eq(e+1)):(i=s.eq(Math.max(0,e-1)),n=s.eq(Math.min(e+1,s.length-1))))}),l.Keyboard.handleKey(e,"Tabs",{open:function(){a.find('[role="tab"]').focus(),t._handleTabChange(a)},previous:function(){i.find('[role="tab"]').focus(),t._handleTabChange(i)},next:function(){n.find('[role="tab"]').focus(),t._handleTabChange(n)},handled:function(){e.stopPropagation(),e.preventDefault()}})}})}},{key:"_handleTabChange",value:function(t,e){if(t.hasClass(""+this.options.linkActiveClass))return void(this.options.activeCollapse&&(this._collapseTab(t),this.$element.trigger("collapse.zf.tabs",[t])));var i=this.$element.find("."+this.options.linkClass+"."+this.options.linkActiveClass),n=t.find('[role="tab"]'),a=n.attr("data-tabs-target")||n[0].hash.slice(1),s=this.$tabContent.find("#"+a);if(this._collapseTab(i),this._openTab(t),this.options.deepLink&&!e){var o=t.find("a").attr("href");this.options.updateHistory?history.pushState({},"",o):history.replaceState({},"",o)}this.$element.trigger("change.zf.tabs",[t,s]),s.find("[data-mutate]").trigger("mutateme.zf.trigger")}},{key:"_openTab",value:function(t){var e=t.find('[role="tab"]'),i=e.attr("data-tabs-target")||e[0].hash.slice(1),n=this.$tabContent.find("#"+i);t.addClass(""+this.options.linkActiveClass),e.attr({"aria-selected":"true",tabindex:"0"}),n.addClass(""+this.options.panelActiveClass).removeAttr("aria-hidden")}},{key:"_collapseTab",value:function(t){var e=t.removeClass(""+this.options.linkActiveClass).find('[role="tab"]').attr({"aria-selected":"false",tabindex:-1});r()("#"+e.attr("aria-controls")).removeClass(""+this.options.panelActiveClass).attr({"aria-hidden":"true"})}},{key:"selectTab",value:function(t,e){var i;i="object"==typeof t?t[0].id:t,i.indexOf("#")<0&&(i="#"+i);var n=this.$tabTitles.find('[href$="'+i+'"]').parent("."+this.options.linkClass);this._handleTabChange(n,e)}},{key:"_setHeight",value:function(){var t=0,e=this;this.$tabContent.find("."+this.options.panelClass).css("height","").each(function(){var i=r()(this),n=i.hasClass(""+e.options.panelActiveClass);n||i.css({visibility:"hidden",display:"block"});var a=this.getBoundingClientRect().height;n||i.css({visibility:"",display:""}),t=a>t?a:t}).css("height",t+"px")}},{key:"_destroy",value:function(){this.$element.find("."+this.options.linkClass).off(".zf.tabs").hide().end().find("."+this.options.panelClass).hide(),this.options.matchHeight&&null!=this._setHeightMqHandler&&r()(window).off("changed.zf.mediaquery",this._setHeightMqHandler),this.options.deepLink&&r()(window).off("popstate",this._checkDeepLink)}}]),e}(d.Plugin);u.defaults={deepLink:!1,deepLinkSmudge:!1,deepLinkSmudgeDelay:300,updateHistory:!1,autoFocus:!1,wrapOnKeys:!0,matchHeight:!1,activeCollapse:!1,linkClass:"tabs-title",linkActiveClass:"is-active",panelClass:"tabs-panel",panelActiveClass:"is-active"}},97:function(t,e,i){t.exports=i(31)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("./foundation.util.imageLoader"),require("./foundation.util.keyboard"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.imageLoader","./foundation.util.keyboard","jquery"],e):"object"==typeof exports?exports["foundation.tabs"]=e(require("./foundation.core"),require("./foundation.util.imageLoader"),require("./foundation.util.keyboard"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.tabs"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.util.imageLoader"],t.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"],t.jQuery))}(window,function(n,i,o,a){return function(n){var i={};function o(t){if(i[t])return i[t].exports;var e=i[t]={i:t,l:!1,exports:{}};return n[t].call(e.exports,e,e.exports,o),e.l=!0,e.exports}return o.m=n,o.c=i,o.d=function(t,e,n){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(o.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)o.d(n,i,function(t){return e[t]}.bind(null,i));return n},o.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return o.d(e,"a",e),e},o.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},o.p="",o(o.s=18)}({"./foundation.core":function(t,e){t.exports=n},"./foundation.util.imageLoader":function(t,e){t.exports=i},"./foundation.util.keyboard":function(t,e){t.exports=o},"./js/entries/plugins/foundation.tabs.js":function(t,e,n){"use strict";n.r(e);var i=n("./foundation.core");n.d(e,"Foundation",function(){return i.Foundation});var o=n("./js/foundation.tabs.js");n.d(e,"Tabs",function(){return o.Tabs}),i.Foundation.plugin(o.Tabs,"Tabs")},"./js/foundation.tabs.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Tabs",function(){return o});var i=n("jquery"),r=n.n(i),l=n("./foundation.core"),s=n("./foundation.util.keyboard"),c=n("./foundation.util.imageLoader");function a(t){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function d(t,e){return!e||"object"!==a(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function h(t,e){return(h=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var o=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),d(this,f(n).apply(this,arguments))}var e,i,o;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&h(t,e)}(n,l["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=r.a.extend({},n.defaults,this.$element.data(),e),this.className="Tabs",this._init(),s.Keyboard.register("Tabs",{ENTER:"open",SPACE:"open",ARROW_RIGHT:"next",ARROW_UP:"previous",ARROW_DOWN:"next",ARROW_LEFT:"previous"})}},{key:"_init",value:function(){var a=this,s=this;if(this._isInitializing=!0,this.$element.attr({role:"tablist"}),this.$tabTitles=this.$element.find(".".concat(this.options.linkClass)),this.$tabContent=r()('[data-tabs-content="'.concat(this.$element[0].id,'"]')),this.$tabTitles.each(function(){var t=r()(this),e=t.find("a"),n=t.hasClass("".concat(s.options.linkActiveClass)),i=e.attr("data-tabs-target")||e[0].hash.slice(1),o=e[0].id?e[0].id:"".concat(i,"-label"),a=r()("#".concat(i));t.attr({role:"presentation"}),e.attr({role:"tab","aria-controls":i,"aria-selected":n,id:o,tabindex:n?"0":"-1"}),a.attr({role:"tabpanel","aria-labelledby":o}),n&&(s._initialAnchor="#".concat(i)),n||a.attr("aria-hidden","true"),n&&s.options.autoFocus&&(s.onLoadListener=Object(l.onLoad)(r()(window),function(){r()("html, body").animate({scrollTop:t.offset().top},s.options.deepLinkSmudgeDelay,function(){e.focus()})}))}),this.options.matchHeight){var t=this.$tabContent.find("img");t.length?Object(c.onImagesLoaded)(t,this._setHeight.bind(this)):this._setHeight()}this._checkDeepLink=function(){var t=window.location.hash;if(!t.length){if(a._isInitializing)return;a._initialAnchor&&(t=a._initialAnchor)}var e=t&&r()(t),n=t&&a.$element.find('[href$="'+t+'"]'),i=!(!e.length||!n.length);if(e&&e.length&&n&&n.length?a.selectTab(e,!0):a._collapse(),i){if(a.options.deepLinkSmudge){var o=a.$element.offset();r()("html, body").animate({scrollTop:o.top},a.options.deepLinkSmudgeDelay)}a.$element.trigger("deeplink.zf.tabs",[n,e])}},this.options.deepLink&&this._checkDeepLink(),this._events(),this._isInitializing=!1}},{key:"_events",value:function(){this._addKeyHandler(),this._addClickHandler(),this._setHeightMqHandler=null,this.options.matchHeight&&(this._setHeightMqHandler=this._setHeight.bind(this),r()(window).on("changed.zf.mediaquery",this._setHeightMqHandler)),this.options.deepLink&&r()(window).on("hashchange",this._checkDeepLink)}},{key:"_addClickHandler",value:function(){var e=this;this.$element.off("click.zf.tabs").on("click.zf.tabs",".".concat(this.options.linkClass),function(t){t.preventDefault(),t.stopPropagation(),e._handleTabChange(r()(this))})}},{key:"_addKeyHandler",value:function(){var a=this;this.$tabTitles.off("keydown.zf.tabs").on("keydown.zf.tabs",function(t){if(9!==t.which){var e,n,i=r()(this),o=i.parent("ul").children("li");o.each(function(t){r()(this).is(i)&&(n=a.options.wrapOnKeys?(e=0===t?o.last():o.eq(t-1),t===o.length-1?o.first():o.eq(t+1)):(e=o.eq(Math.max(0,t-1)),o.eq(Math.min(t+1,o.length-1))))}),s.Keyboard.handleKey(t,"Tabs",{open:function(){i.find('[role="tab"]').focus(),a._handleTabChange(i)},previous:function(){e.find('[role="tab"]').focus(),a._handleTabChange(e)},next:function(){n.find('[role="tab"]').focus(),a._handleTabChange(n)},handled:function(){t.stopPropagation(),t.preventDefault()}})}})}},{key:"_handleTabChange",value:function(t,e){if(t.hasClass("".concat(this.options.linkActiveClass)))this.options.activeCollapse&&this._collapse();else{var n=this.$element.find(".".concat(this.options.linkClass,".").concat(this.options.linkActiveClass)),i=t.find('[role="tab"]'),o=i.attr("data-tabs-target"),a=o&&o.length?"#".concat(o):i[0].hash,s=this.$tabContent.find(a);this._collapseTab(n),this._openTab(t),this.options.deepLink&&!e&&(this.options.updateHistory?history.pushState({},"",a):history.replaceState({},"",a)),this.$element.trigger("change.zf.tabs",[t,s]),s.find("[data-mutate]").trigger("mutateme.zf.trigger")}}},{key:"_openTab",value:function(t){var e=t.find('[role="tab"]'),n=e.attr("data-tabs-target")||e[0].hash.slice(1),i=this.$tabContent.find("#".concat(n));t.addClass("".concat(this.options.linkActiveClass)),e.attr({"aria-selected":"true",tabindex:"0"}),i.addClass("".concat(this.options.panelActiveClass)).removeAttr("aria-hidden")}},{key:"_collapseTab",value:function(t){var e=t.removeClass("".concat(this.options.linkActiveClass)).find('[role="tab"]').attr({"aria-selected":"false",tabindex:-1});r()("#".concat(e.attr("aria-controls"))).removeClass("".concat(this.options.panelActiveClass)).attr({"aria-hidden":"true"})}},{key:"_collapse",value:function(){var t=this.$element.find(".".concat(this.options.linkClass,".").concat(this.options.linkActiveClass));t.length&&(this._collapseTab(t),this.$element.trigger("collapse.zf.tabs",[t]))}},{key:"selectTab",value:function(t,e){var n;(n="object"===a(t)?t[0].id:t).indexOf("#")<0&&(n="#".concat(n));var i=this.$tabTitles.has('[href$="'.concat(n,'"]'));this._handleTabChange(i,e)}},{key:"_setHeight",value:function(){var i=0,o=this;this.$tabContent.find(".".concat(this.options.panelClass)).css("height","").each(function(){var t=r()(this),e=t.hasClass("".concat(o.options.panelActiveClass));e||t.css({visibility:"hidden",display:"block"});var n=this.getBoundingClientRect().height;e||t.css({visibility:"",display:""}),i=i<n?n:i}).css("height","".concat(i,"px"))}},{key:"_destroy",value:function(){this.$element.find(".".concat(this.options.linkClass)).off(".zf.tabs").hide().end().find(".".concat(this.options.panelClass)).hide(),this.options.matchHeight&&null!=this._setHeightMqHandler&&r()(window).off("changed.zf.mediaquery",this._setHeightMqHandler),this.options.deepLink&&r()(window).off("hashchange",this._checkDeepLink),this.onLoadListener&&r()(window).off(this.onLoadListener)}}])&&u(e.prototype,i),o&&u(e,o),n}();o.defaults={deepLink:!1,deepLinkSmudge:!1,deepLinkSmudgeDelay:300,updateHistory:!1,autoFocus:!1,wrapOnKeys:!0,matchHeight:!1,activeCollapse:!1,linkClass:"tabs-title",linkActiveClass:"is-active",panelClass:"tabs-panel",panelActiveClass:"is-active"}},18:function(t,e,n){t.exports=n("./js/entries/plugins/foundation.tabs.js")},jquery:function(t,e){t.exports=a}})});
+//# sourceMappingURL=foundation.tabs.min.js.map
diff --git a/dist/js/plugins/foundation.tabs.min.js.map b/dist/js/plugins/foundation.tabs.min.js.map
new file mode 100644 (file)
index 0000000..58ebecc
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.tabs.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__","__WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.imageLoader","./foundation.util.keyboard","./js/entries/plugins/foundation.tabs.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_tabs__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.tabs.js","Tabs","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","_init","register","ENTER","SPACE","ARROW_RIGHT","ARROW_UP","ARROW_DOWN","ARROW_LEFT","_this2","_this","_isInitializing","attr","role","$tabTitles","find","concat","linkClass","$tabContent","id","each","$elem","$link","isActive","hasClass","linkActiveClass","hash","slice","linkId","aria-controls","aria-selected","tabindex","aria-labelledby","_initialAnchor","autoFocus","onLoadListener","animate","scrollTop","offset","top","deepLinkSmudgeDelay","focus","matchHeight","$images","_setHeight","_checkDeepLink","anchor","location","$anchor","isOwnAnchor","selectTab","_collapse","deepLinkSmudge","trigger","deepLink","_events","_addKeyHandler","_addClickHandler","_setHeightMqHandler","on","off","e","preventDefault","stopPropagation","_handleTabChange","which","$prevElement","$nextElement","$elements","parent","children","is","wrapOnKeys","last","eq","first","Math","max","min","handleKey","open","previous","next","handled","$target","historyHandled","activeCollapse","$oldTab","$tabLink","$targetContent","_collapseTab","_openTab","updateHistory","history","pushState","replaceState","addClass","panelActiveClass","removeAttr","$target_anchor","removeClass","aria-hidden","$activeTab","elem","idStr","indexOf","has","panelClass","css","panel","visibility","display","temp","getBoundingClientRect","height","hide","end","18","jquery"],"mappings":"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","file":"foundation.tabs.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.keyboard\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.imageLoader\", \"./foundation.util.keyboard\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.tabs\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.imageLoader\"), require(\"./foundation.util.keyboard\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.tabs\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.imageLoader\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__, __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 18);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.imageLoader\":\n/*!****************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.imageLoader\"],\"amd\":\"./foundation.util.imageLoader\",\"commonjs\":\"./foundation.util.imageLoader\",\"commonjs2\":\"./foundation.util.imageLoader\"} ***!\n  \\****************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_imageLoader__;\n\n/***/ }),\n\n/***/ \"./foundation.util.keyboard\":\n/*!****************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.keyboard\"],\"amd\":\"./foundation.util.keyboard\",\"commonjs\":\"./foundation.util.keyboard\",\"commonjs2\":\"./foundation.util.keyboard\"} ***!\n  \\****************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_keyboard__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.tabs.js\":\n/*!***********************************************!*\\\n  !*** ./js/entries/plugins/foundation.tabs.js ***!\n  \\***********************************************/\n/*! exports provided: Foundation, Tabs */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_tabs__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.tabs */ \"./js/foundation.tabs.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Tabs\", function() { return _foundation_tabs__WEBPACK_IMPORTED_MODULE_1__[\"Tabs\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_tabs__WEBPACK_IMPORTED_MODULE_1__[\"Tabs\"], 'Tabs');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.tabs.js\":\n/*!*******************************!*\\\n  !*** ./js/foundation.tabs.js ***!\n  \\*******************************/\n/*! exports provided: Tabs */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Tabs\", function() { return Tabs; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.keyboard */ \"./foundation.util.keyboard\");\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.imageLoader */ \"./foundation.util.imageLoader\");\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Tabs module.\n * @module foundation.tabs\n * @requires foundation.util.keyboard\n * @requires foundation.util.imageLoader if tabs contain images\n */\n\nvar Tabs =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Tabs, _Plugin);\n\n  function Tabs() {\n    _classCallCheck(this, Tabs);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Tabs).apply(this, arguments));\n  }\n\n  _createClass(Tabs, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of tabs.\n     * @class\n     * @name Tabs\n     * @fires Tabs#init\n     * @param {jQuery} element - jQuery object to make into tabs.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tabs.defaults, this.$element.data(), options);\n      this.className = 'Tabs'; // ie9 back compat\n\n      this._init();\n\n      _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].register('Tabs', {\n        'ENTER': 'open',\n        'SPACE': 'open',\n        'ARROW_RIGHT': 'next',\n        'ARROW_UP': 'previous',\n        'ARROW_DOWN': 'next',\n        'ARROW_LEFT': 'previous' // 'TAB': 'next',\n        // 'SHIFT_TAB': 'previous'\n\n      });\n    }\n    /**\n     * Initializes the tabs by showing and focusing (if autoFocus=true) the preset active tab.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var _this2 = this;\n\n      var _this = this;\n\n      this._isInitializing = true;\n      this.$element.attr({\n        'role': 'tablist'\n      });\n      this.$tabTitles = this.$element.find(\".\".concat(this.options.linkClass));\n      this.$tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-tabs-content=\\\"\".concat(this.$element[0].id, \"\\\"]\"));\n      this.$tabTitles.each(function () {\n        var $elem = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $link = $elem.find('a'),\n            isActive = $elem.hasClass(\"\".concat(_this.options.linkActiveClass)),\n            hash = $link.attr('data-tabs-target') || $link[0].hash.slice(1),\n            linkId = $link[0].id ? $link[0].id : \"\".concat(hash, \"-label\"),\n            $tabContent = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(hash));\n        $elem.attr({\n          'role': 'presentation'\n        });\n        $link.attr({\n          'role': 'tab',\n          'aria-controls': hash,\n          'aria-selected': isActive,\n          'id': linkId,\n          'tabindex': isActive ? '0' : '-1'\n        });\n        $tabContent.attr({\n          'role': 'tabpanel',\n          'aria-labelledby': linkId\n        }); // Save up the initial hash to return to it later when going back in history\n\n        if (isActive) {\n          _this._initialAnchor = \"#\".concat(hash);\n        }\n\n        if (!isActive) {\n          $tabContent.attr('aria-hidden', 'true');\n        }\n\n        if (isActive && _this.options.autoFocus) {\n          _this.onLoadListener = Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])(jquery__WEBPACK_IMPORTED_MODULE_0___default()(window), function () {\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({\n              scrollTop: $elem.offset().top\n            }, _this.options.deepLinkSmudgeDelay, function () {\n              $link.focus();\n            });\n          });\n        }\n      });\n\n      if (this.options.matchHeight) {\n        var $images = this.$tabContent.find('img');\n\n        if ($images.length) {\n          Object(_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_3__[\"onImagesLoaded\"])($images, this._setHeight.bind(this));\n        } else {\n          this._setHeight();\n        }\n      } // Current context-bound function to open tabs on page load or history hashchange\n\n\n      this._checkDeepLink = function () {\n        var anchor = window.location.hash;\n\n        if (!anchor.length) {\n          // If we are still initializing and there is no anchor, then there is nothing to do\n          if (_this2._isInitializing) return; // Otherwise, move to the initial anchor\n\n          if (_this2._initialAnchor) anchor = _this2._initialAnchor;\n        }\n\n        var $anchor = anchor && jquery__WEBPACK_IMPORTED_MODULE_0___default()(anchor);\n\n        var $link = anchor && _this2.$element.find('[href$=\"' + anchor + '\"]'); // Whether the anchor element that has been found is part of this element\n\n\n        var isOwnAnchor = !!($anchor.length && $link.length); // If there is an anchor for the hash, select it\n\n        if ($anchor && $anchor.length && $link && $link.length) {\n          _this2.selectTab($anchor, true);\n        } // Otherwise, collapse everything\n        else {\n            _this2._collapse();\n          }\n\n        if (isOwnAnchor) {\n          // Roll up a little to show the titles\n          if (_this2.options.deepLinkSmudge) {\n            var offset = _this2.$element.offset();\n\n            jquery__WEBPACK_IMPORTED_MODULE_0___default()('html, body').animate({\n              scrollTop: offset.top\n            }, _this2.options.deepLinkSmudgeDelay);\n          }\n          /**\n           * Fires when the plugin has deeplinked at pageload\n           * @event Tabs#deeplink\n           */\n\n\n          _this2.$element.trigger('deeplink.zf.tabs', [$link, $anchor]);\n        }\n      }; //use browser to open a tab, if it exists in this tabset\n\n\n      if (this.options.deepLink) {\n        this._checkDeepLink();\n      }\n\n      this._events();\n\n      this._isInitializing = false;\n    }\n    /**\n     * Adds event handlers for items within the tabs.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this._addKeyHandler();\n\n      this._addClickHandler();\n\n      this._setHeightMqHandler = null;\n\n      if (this.options.matchHeight) {\n        this._setHeightMqHandler = this._setHeight.bind(this);\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('changed.zf.mediaquery', this._setHeightMqHandler);\n      }\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).on('hashchange', this._checkDeepLink);\n      }\n    }\n    /**\n     * Adds click handlers for items within the tabs.\n     * @private\n     */\n\n  }, {\n    key: \"_addClickHandler\",\n    value: function _addClickHandler() {\n      var _this = this;\n\n      this.$element.off('click.zf.tabs').on('click.zf.tabs', \".\".concat(this.options.linkClass), function (e) {\n        e.preventDefault();\n        e.stopPropagation();\n\n        _this._handleTabChange(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this));\n      });\n    }\n    /**\n     * Adds keyboard event handlers for items within the tabs.\n     * @private\n     */\n\n  }, {\n    key: \"_addKeyHandler\",\n    value: function _addKeyHandler() {\n      var _this = this;\n\n      this.$tabTitles.off('keydown.zf.tabs').on('keydown.zf.tabs', function (e) {\n        if (e.which === 9) return;\n        var $element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            $elements = $element.parent('ul').children('li'),\n            $prevElement,\n            $nextElement;\n        $elements.each(function (i) {\n          if (jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is($element)) {\n            if (_this.options.wrapOnKeys) {\n              $prevElement = i === 0 ? $elements.last() : $elements.eq(i - 1);\n              $nextElement = i === $elements.length - 1 ? $elements.first() : $elements.eq(i + 1);\n            } else {\n              $prevElement = $elements.eq(Math.max(0, i - 1));\n              $nextElement = $elements.eq(Math.min(i + 1, $elements.length - 1));\n            }\n\n            return;\n          }\n        }); // handle keyboard event with keyboard util\n\n        _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_2__[\"Keyboard\"].handleKey(e, 'Tabs', {\n          open: function open() {\n            $element.find('[role=\"tab\"]').focus();\n\n            _this._handleTabChange($element);\n          },\n          previous: function previous() {\n            $prevElement.find('[role=\"tab\"]').focus();\n\n            _this._handleTabChange($prevElement);\n          },\n          next: function next() {\n            $nextElement.find('[role=\"tab\"]').focus();\n\n            _this._handleTabChange($nextElement);\n          },\n          handled: function handled() {\n            e.stopPropagation();\n            e.preventDefault();\n          }\n        });\n      });\n    }\n    /**\n     * Opens the tab `$targetContent` defined by `$target`. Collapses active tab.\n     * @param {jQuery} $target - Tab to open.\n     * @param {boolean} historyHandled - browser has already handled a history update\n     * @fires Tabs#change\n     * @function\n     */\n\n  }, {\n    key: \"_handleTabChange\",\n    value: function _handleTabChange($target, historyHandled) {\n      // With `activeCollapse`, if the target is the active Tab, collapse it.\n      if ($target.hasClass(\"\".concat(this.options.linkActiveClass))) {\n        if (this.options.activeCollapse) {\n          this._collapse();\n        }\n\n        return;\n      }\n\n      var $oldTab = this.$element.find(\".\".concat(this.options.linkClass, \".\").concat(this.options.linkActiveClass)),\n          $tabLink = $target.find('[role=\"tab\"]'),\n          target = $tabLink.attr('data-tabs-target'),\n          anchor = target && target.length ? \"#\".concat(target) : $tabLink[0].hash,\n          $targetContent = this.$tabContent.find(anchor); //close old tab\n\n      this._collapseTab($oldTab); //open new tab\n\n\n      this._openTab($target); //either replace or update browser history\n\n\n      if (this.options.deepLink && !historyHandled) {\n        if (this.options.updateHistory) {\n          history.pushState({}, '', anchor);\n        } else {\n          history.replaceState({}, '', anchor);\n        }\n      }\n      /**\n       * Fires when the plugin has successfully changed tabs.\n       * @event Tabs#change\n       */\n\n\n      this.$element.trigger('change.zf.tabs', [$target, $targetContent]); //fire to children a mutation event\n\n      $targetContent.find(\"[data-mutate]\").trigger(\"mutateme.zf.trigger\");\n    }\n    /**\n     * Opens the tab `$targetContent` defined by `$target`.\n     * @param {jQuery} $target - Tab to open.\n     * @function\n     */\n\n  }, {\n    key: \"_openTab\",\n    value: function _openTab($target) {\n      var $tabLink = $target.find('[role=\"tab\"]'),\n          hash = $tabLink.attr('data-tabs-target') || $tabLink[0].hash.slice(1),\n          $targetContent = this.$tabContent.find(\"#\".concat(hash));\n      $target.addClass(\"\".concat(this.options.linkActiveClass));\n      $tabLink.attr({\n        'aria-selected': 'true',\n        'tabindex': '0'\n      });\n      $targetContent.addClass(\"\".concat(this.options.panelActiveClass)).removeAttr('aria-hidden');\n    }\n    /**\n     * Collapses `$targetContent` defined by `$target`.\n     * @param {jQuery} $target - Tab to collapse.\n     * @function\n     */\n\n  }, {\n    key: \"_collapseTab\",\n    value: function _collapseTab($target) {\n      var $target_anchor = $target.removeClass(\"\".concat(this.options.linkActiveClass)).find('[role=\"tab\"]').attr({\n        'aria-selected': 'false',\n        'tabindex': -1\n      });\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat($target_anchor.attr('aria-controls'))).removeClass(\"\".concat(this.options.panelActiveClass)).attr({\n        'aria-hidden': 'true'\n      });\n    }\n    /**\n     * Collapses the active Tab.\n     * @fires Tabs#collapse\n     * @function\n     */\n\n  }, {\n    key: \"_collapse\",\n    value: function _collapse() {\n      var $activeTab = this.$element.find(\".\".concat(this.options.linkClass, \".\").concat(this.options.linkActiveClass));\n\n      if ($activeTab.length) {\n        this._collapseTab($activeTab);\n        /**\n        * Fires when the plugin has successfully collapsed tabs.\n        * @event Tabs#collapse\n        */\n\n\n        this.$element.trigger('collapse.zf.tabs', [$activeTab]);\n      }\n    }\n    /**\n     * Public method for selecting a content pane to display.\n     * @param {jQuery | String} elem - jQuery object or string of the id of the pane to display.\n     * @param {boolean} historyHandled - browser has already handled a history update\n     * @function\n     */\n\n  }, {\n    key: \"selectTab\",\n    value: function selectTab(elem, historyHandled) {\n      var idStr;\n\n      if (_typeof(elem) === 'object') {\n        idStr = elem[0].id;\n      } else {\n        idStr = elem;\n      }\n\n      if (idStr.indexOf('#') < 0) {\n        idStr = \"#\".concat(idStr);\n      }\n\n      var $target = this.$tabTitles.has(\"[href$=\\\"\".concat(idStr, \"\\\"]\"));\n\n      this._handleTabChange($target, historyHandled);\n    }\n  }, {\n    key: \"_setHeight\",\n\n    /**\n     * Sets the height of each panel to the height of the tallest panel.\n     * If enabled in options, gets called on media query change.\n     * If loading content via external source, can be called directly or with _reflow.\n     * If enabled with `data-match-height=\"true\"`, tabs sets to equal height\n     * @function\n     * @private\n     */\n    value: function _setHeight() {\n      var max = 0,\n          _this = this; // Lock down the `this` value for the root tabs object\n\n\n      this.$tabContent.find(\".\".concat(this.options.panelClass)).css('height', '').each(function () {\n        var panel = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n            isActive = panel.hasClass(\"\".concat(_this.options.panelActiveClass)); // get the options from the parent instead of trying to get them from the child\n\n        if (!isActive) {\n          panel.css({\n            'visibility': 'hidden',\n            'display': 'block'\n          });\n        }\n\n        var temp = this.getBoundingClientRect().height;\n\n        if (!isActive) {\n          panel.css({\n            'visibility': '',\n            'display': ''\n          });\n        }\n\n        max = temp > max ? temp : max;\n      }).css('height', \"\".concat(max, \"px\"));\n    }\n    /**\n     * Destroys an instance of tabs.\n     * @fires Tabs#destroyed\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.find(\".\".concat(this.options.linkClass)).off('.zf.tabs').hide().end().find(\".\".concat(this.options.panelClass)).hide();\n\n      if (this.options.matchHeight) {\n        if (this._setHeightMqHandler != null) {\n          jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('changed.zf.mediaquery', this._setHeightMqHandler);\n        }\n      }\n\n      if (this.options.deepLink) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('hashchange', this._checkDeepLink);\n      }\n\n      if (this.onLoadListener) {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(this.onLoadListener);\n      }\n    }\n  }]);\n\n  return Tabs;\n}(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n\nTabs.defaults = {\n  /**\n   * Link the location hash to the active pane.\n   * Set the location hash when the active pane changes, and open the corresponding pane when the location changes.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLink: false,\n\n  /**\n   * If `deepLink` is enabled, adjust the deep link scroll to make sure the top of the tab panel is visible\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  deepLinkSmudge: false,\n\n  /**\n   * If `deepLinkSmudge` is enabled, animation time (ms) for the deep link adjustment\n   * @option\n   * @type {number}\n   * @default 300\n   */\n  deepLinkSmudgeDelay: 300,\n\n  /**\n   * If `deepLink` is enabled, update the browser history with the open tab\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  updateHistory: false,\n\n  /**\n   * Allows the window to scroll to content of active pane on load.\n   * Not recommended if more than one tab panel per page.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  autoFocus: false,\n\n  /**\n   * Allows keyboard input to 'wrap' around the tab links.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  wrapOnKeys: true,\n\n  /**\n   * Allows the tab content panes to match heights if set to true.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  matchHeight: false,\n\n  /**\n   * Allows active tabs to collapse when clicked.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  activeCollapse: false,\n\n  /**\n   * Class applied to `li`'s in tab link list.\n   * @option\n   * @type {string}\n   * @default 'tabs-title'\n   */\n  linkClass: 'tabs-title',\n\n  /**\n   * Class applied to the active `li` in tab link list.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  linkActiveClass: 'is-active',\n\n  /**\n   * Class applied to the content containers.\n   * @option\n   * @type {string}\n   * @default 'tabs-panel'\n   */\n  panelClass: 'tabs-panel',\n\n  /**\n   * Class applied to the active content container.\n   * @option\n   * @type {string}\n   * @default 'is-active'\n   */\n  panelActiveClass: 'is-active'\n};\n\n\n/***/ }),\n\n/***/ 18:\n/*!*****************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.tabs.js ***!\n  \\*****************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.tabs.js */\"./js/entries/plugins/foundation.tabs.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.tabs.js.map"]}
\ No newline at end of file
index 7085d8569702142433bec73538ddbdee6f7df6d2..f3c5f5e156392738c51cbf032363c35ee09c0ce2 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.motion"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.motion", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.toggler"] = factory(require("./foundation.core"), require("./foundation.util.motion"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.toggler"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 98);
+/******/       return __webpack_require__(__webpack_require__.s = 19);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
 /***/ }),
 
-/***/ 2:
-/***/ (function(module, exports) {
-
-module.exports = {Plugin: window.Foundation.Plugin};
-
-/***/ }),
-
-/***/ 32:
+/***/ "./js/entries/plugins/foundation.toggler.js":
+/*!**************************************************!*\
+  !*** ./js/entries/plugins/foundation.toggler.js ***!
+  \**************************************************/
+/*! exports provided: Foundation, Toggler */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_toggler__ = __webpack_require__(62);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_toggler__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.toggler */ "./js/foundation.toggler.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Toggler", function() { return _foundation_toggler__WEBPACK_IMPORTED_MODULE_1__["Toggler"]; });
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_toggler__["a" /* Toggler */], 'Toggler');
 
-/***/ }),
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_toggler__WEBPACK_IMPORTED_MODULE_1__["Toggler"], 'Toggler');
 
-/***/ 4:
-/***/ (function(module, exports) {
-
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
 
 /***/ }),
 
-/***/ 62:
+/***/ "./js/foundation.toggler.js":
+/*!**********************************!*\
+  !*** ./js/foundation.toggler.js ***!
+  \**********************************/
+/*! exports provided: Toggler */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Toggler; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_triggers__ = __webpack_require__(7);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Toggler", function() { return Toggler; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ "./foundation.core");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-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 _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
+
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -145,17 +190,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.triggers
  */
 
-var Toggler = function (_Plugin) {
+var Toggler =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Toggler, _Plugin);
 
   function Toggler() {
     _classCallCheck(this, Toggler);
 
-    return _possibleConstructorReturn(this, (Toggler.__proto__ || Object.getPrototypeOf(Toggler)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Toggler).apply(this, arguments));
   }
 
   _createClass(Toggler, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of Toggler.
@@ -167,17 +214,17 @@ var Toggler = function (_Plugin) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Toggler.defaults, element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Toggler.defaults, element.data(), options);
       this.className = '';
       this.className = 'Toggler'; // ie9 back compat
-
       // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_3__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
       this._init();
+
       this._events();
     }
-
     /**
      * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.
      * @function
@@ -185,30 +232,34 @@ var Toggler = function (_Plugin) {
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      var input;
-      // Parse animation classes if they were set
+      var input; // Parse animation classes if they were set
+
       if (this.options.animate) {
         input = this.options.animate.split(' ');
-
         this.animationIn = input[0];
         this.animationOut = input[1] || null;
-      }
-      // Otherwise, parse toggle class
+      } // Otherwise, parse toggle class
       else {
-          input = this.$element.data('toggler');
-          // Allow for a . at the beginning of the string
+          input = this.$element.data('toggler'); // Allow for a . at the beginning of the string
+
           this.className = input[0] === '.' ? input.slice(1) : input;
-        }
+        } // Add ARIA attributes to triggers:
 
-      // Add ARIA attributes to triggers
-      var id = this.$element[0].id;
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-open="' + id + '"], [data-close="' + id + '"], [data-toggle="' + id + '"]').attr('aria-controls', id);
-      // If the target is hidden, add aria-hidden
-      this.$element.attr('aria-expanded', this.$element.is(':hidden') ? false : true);
-    }
 
+      var id = this.$element[0].id,
+          $triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open~=\"".concat(id, "\"], [data-close~=\"").concat(id, "\"], [data-toggle~=\"").concat(id, "\"]")); // - aria-expanded: according to the element visibility.
+
+      $triggers.attr('aria-expanded', !this.$element.is(':hidden')); // - aria-controls: adding the element id to it if not already in it.
+
+      $triggers.each(function (index, trigger) {
+        var $trigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()(trigger);
+        var controls = $trigger.attr('aria-controls') || '';
+        var containsId = new RegExp("\\b".concat(Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["RegExpEscape"])(id), "\\b")).test(controls);
+        if (!containsId) $trigger.attr('aria-controls', controls ? "".concat(controls, " ").concat(id) : id);
+      });
+    }
     /**
      * Initializes events for the toggle trigger.
      * @function
@@ -216,11 +267,10 @@ var Toggler = function (_Plugin) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));
     }
-
     /**
      * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was "on" or "off".
      * @function
@@ -229,16 +279,16 @@ var Toggler = function (_Plugin) {
      */
 
   }, {
-    key: 'toggle',
+    key: "toggle",
     value: function toggle() {
       this[this.options.animate ? '_toggleAnimate' : '_toggleClass']();
     }
   }, {
-    key: '_toggleClass',
+    key: "_toggleClass",
     value: function _toggleClass() {
       this.$element.toggleClass(this.className);
-
       var isOn = this.$element.hasClass(this.className);
+
       if (isOn) {
         /**
          * Fires if the target element has the class after a toggle.
@@ -254,47 +304,52 @@ var Toggler = function (_Plugin) {
       }
 
       this._updateARIA(isOn);
+
       this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');
     }
   }, {
-    key: '_toggleAnimate',
+    key: "_toggleAnimate",
     value: function _toggleAnimate() {
       var _this = this;
 
       if (this.$element.is(':hidden')) {
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateIn(this.$element, this.animationIn, function () {
+        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__["Motion"].animateIn(this.$element, this.animationIn, function () {
           _this._updateARIA(true);
+
           this.trigger('on.zf.toggler');
           this.find('[data-mutate]').trigger('mutateme.zf.trigger');
         });
       } else {
-        __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(this.$element, this.animationOut, function () {
+        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__["Motion"].animateOut(this.$element, this.animationOut, function () {
           _this._updateARIA(false);
+
           this.trigger('off.zf.toggler');
           this.find('[data-mutate]').trigger('mutateme.zf.trigger');
         });
       }
     }
   }, {
-    key: '_updateARIA',
+    key: "_updateARIA",
     value: function _updateARIA(isOn) {
-      this.$element.attr('aria-expanded', isOn ? true : false);
+      var id = this.$element[0].id;
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-open=\"".concat(id, "\"], [data-close=\"").concat(id, "\"], [data-toggle=\"").concat(id, "\"]")).attr({
+        'aria-expanded': isOn ? true : false
+      });
     }
-
     /**
      * Destroys the instance of Toggler on the element.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
       this.$element.off('.zf.toggler');
     }
   }]);
 
   return Toggler;
-}(__WEBPACK_IMPORTED_MODULE_2__foundation_plugin__["Plugin"]);
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__["Plugin"]);
 
 Toggler.defaults = {
   /**
@@ -307,18 +362,27 @@ Toggler.defaults = {
 };
 
 
-
 /***/ }),
 
-/***/ 7:
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
@@ -326,17 +390,19 @@ Toggler.defaults = {
 
 var MutationObserver = function () {
   var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
   for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
     }
   }
+
   return false;
 }();
 
-var triggers = function (el, type) {
+var triggers = function triggers(el, type) {
   el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
   });
 };
 
@@ -347,138 +413,142 @@ var Triggers = {
   },
   Initializers: {}
 };
-
 Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
   },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
     }
   },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
     }
   },
-  closeableListener: function (e) {
+  closeableListener: function closeableListener(e) {
     e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
     if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
       });
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
     }
   },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
-};
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
 Triggers.Initializers.addOpenListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
   $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
-
-// Elements with [data-close] will close a plugin that supports it when clicked.
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
 // If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
 Triggers.Initializers.addCloseListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
   $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 Triggers.Initializers.addToggleListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
   $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
 Triggers.Initializers.addCloseableListener = function ($elem) {
   $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
   $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
 Triggers.Initializers.addToggleFocusListener = function ($elem) {
   $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
   $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+}; // More Global/complex listeners and triggers
+
 
-// More Global/complex listeners and triggers
 Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
+  resizeListener: function resizeListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a resize event
+    } //trigger all listening elements and signal a resize event
+
+
     $nodes.attr('data-events', "resize");
   },
-  scrollListener: function ($nodes) {
+  scrollListener: function scrollListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a scroll event
+    } //trigger all listening elements and signal a scroll event
+
+
     $nodes.attr('data-events', "scroll");
   },
-  closeMeListener: function (e, pluginId) {
+  closeMeListener: function closeMeListener(e, pluginId) {
     var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
-
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
     plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+
       _this.triggerHandler('close.zf.trigger', [_this]);
     });
-  }
+  } // Global, parses whole document.
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
+};
+
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
       plugNames = ['dropdown', 'tooltip', 'reveal'];
 
   if (pluginName) {
     if (typeof pluginName === 'string') {
       plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
     } else {
       console.error('Plugin names must be strings');
     }
   }
+
   if (yetiBoxes.length) {
     var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
+      return "closeme.zf.".concat(name);
     }).join(' ');
-
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
   }
 };
 
 function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
+  var timer,
       args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
     if (timer) {
       clearTimeout(timer);
     }
+
     timer = setTimeout(function () {
       listener.apply(null, args);
     }, debounce || 10); //default time to emit scroll event
@@ -486,14 +556,16 @@ function debounceGlobalListener(debounce, trigger, listener) {
 }
 
 Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
   }
 };
 
 Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
   }
@@ -503,25 +575,27 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
   if (!MutationObserver) {
     return false;
   }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
 
-    //trigger the event handler for the element depending on type
     switch (mutationRecordsList[0].type) {
       case "attributes":
         if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
+
         if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
+
         if (mutationRecordsList[0].attributeName === "style") {
           $target.closest("[data-mutate]").attr("data-events", "mutate");
           $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
         }
+
         break;
 
       case "childList":
@@ -539,14 +613,19 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
     //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
     for (var i = 0; i <= $nodes.length - 1; i++) {
       var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
   }
 };
 
 Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addOpenListener($document);
   Triggers.Initializers.addCloseListener($document);
   Triggers.Initializers.addToggleListener($document);
@@ -555,7 +634,7 @@ Triggers.Initializers.addSimpleListeners = function () {
 };
 
 Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addMutationEventsListener($document);
   Triggers.Initializers.addResizeListener();
   Triggers.Initializers.addScrollListener();
@@ -563,25 +642,17 @@ Triggers.Initializers.addGlobalListeners = function () {
 };
 
 Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
-
-    if (document.readyState === "complete") {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
       Triggers.Initializers.addSimpleListeners();
       Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
-      });
+      $.triggersInitialized = true;
     }
-
-    $.triggersInitialized = true;
-  }
+  });
 
   if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
     Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
   }
 };
@@ -590,12 +661,29 @@ Triggers.init = function ($, Foundation) {
 
 /***/ }),
 
-/***/ 98:
+/***/ 19:
+/*!********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.toggler.js ***!
+  \********************************************************/
+/*! no static exports found */
 /***/ (function(module, exports, __webpack_require__) {
 
-module.exports = __webpack_require__(32);
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.toggler.js */"./js/entries/plugins/foundation.toggler.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.toggler.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.toggler.js.map b/dist/js/plugins/foundation.toggler.js.map
new file mode 100644 (file)
index 0000000..a7ea1e8
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.toggler.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.toggler.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Toggler","element","options","$element","$","extend","defaults","data","className","Triggers","init","_init","_events","input","animate","split","animationIn","animationOut","slice","id","$triggers","attr","is","each","index","trigger","$trigger","controls","containsId","RegExp","RegExpEscape","test","off","on","toggle","bind","toggleClass","isOn","hasClass","_updateARIA","find","_this","Motion","animateIn","animateOut","Plugin","MutationObserver","prefixes","i","length","window","triggers","el","type","forEach","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","e","stopPropagation","animation","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","scrollListener","closeMeListener","pluginId","namespace","plugins","not","addClosemeListener","pluginName","yetiBoxes","plugNames","push","concat","console","error","listeners","map","name","join","debounceGlobalListener","debounce","listener","timer","args","Array","prototype","call","arguments","clearTimeout","setTimeout","apply","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","$target","target","attributeName","pageYOffset","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","document","addGlobalListeners","onLoad","triggersInitialized","IHearYou"],"mappings":"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","file":"foundation.toggler.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.toggler\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.toggler\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 19);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","import { Foundation } from './foundation.core';\n\nimport { Toggler } from '../../foundation.toggler';\nFoundation.plugin(Toggler, 'Toggler');\n\nexport { Foundation, Toggler };\n","'use strict';\n\nimport $ from 'jquery';\nimport { Motion } from './foundation.util.motion';\nimport { Plugin } from './foundation.core.plugin';\nimport { RegExpEscape } from './foundation.core.utils';\nimport { Triggers } from './foundation.util.triggers';\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nclass Toggler extends Plugin {\n  /**\n   * Creates a new instance of Toggler.\n   * @class\n   * @name Toggler\n   * @fires Toggler#init\n   * @param {Object} element - jQuery object to add the trigger to.\n   * @param {Object} options - Overrides to the default plugin settings.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Toggler.defaults, element.data(), options);\n    this.className = '';\n    this.className = 'Toggler'; // ie9 back compat\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n    this._events();\n  }\n\n  /**\n   * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.\n   * @function\n   * @private\n   */\n  _init() {\n    var input;\n    // Parse animation classes if they were set\n    if (this.options.animate) {\n      input = this.options.animate.split(' ');\n\n      this.animationIn = input[0];\n      this.animationOut = input[1] || null;\n    }\n    // Otherwise, parse toggle class\n    else {\n      input = this.$element.data('toggler');\n      // Allow for a . at the beginning of the string\n      this.className = input[0] === '.' ? input.slice(1) : input;\n    }\n\n    // Add ARIA attributes to triggers:\n    var id = this.$element[0].id,\n      $triggers = $(`[data-open~=\"${id}\"], [data-close~=\"${id}\"], [data-toggle~=\"${id}\"]`);\n\n    // - aria-expanded: according to the element visibility.\n    $triggers.attr('aria-expanded', !this.$element.is(':hidden'));\n    // - aria-controls: adding the element id to it if not already in it.\n    $triggers.each((index, trigger) => {\n      const $trigger = $(trigger);\n      const controls = $trigger.attr('aria-controls') || '';\n\n      const containsId = new RegExp(`\\\\b${RegExpEscape(id)}\\\\b`).test(controls);\n      if (!containsId) $trigger.attr('aria-controls', controls ? `${controls} ${id}` : id);\n    });\n  }\n\n  /**\n   * Initializes events for the toggle trigger.\n   * @function\n   * @private\n   */\n  _events() {\n    this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));\n  }\n\n  /**\n   * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was \"on\" or \"off\".\n   * @function\n   * @fires Toggler#on\n   * @fires Toggler#off\n   */\n  toggle() {\n    this[ this.options.animate ? '_toggleAnimate' : '_toggleClass']();\n  }\n\n  _toggleClass() {\n    this.$element.toggleClass(this.className);\n\n    var isOn = this.$element.hasClass(this.className);\n    if (isOn) {\n      /**\n       * Fires if the target element has the class after a toggle.\n       * @event Toggler#on\n       */\n      this.$element.trigger('on.zf.toggler');\n    }\n    else {\n      /**\n       * Fires if the target element does not have the class after a toggle.\n       * @event Toggler#off\n       */\n      this.$element.trigger('off.zf.toggler');\n    }\n\n    this._updateARIA(isOn);\n    this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');\n  }\n\n  _toggleAnimate() {\n    var _this = this;\n\n    if (this.$element.is(':hidden')) {\n      Motion.animateIn(this.$element, this.animationIn, function() {\n        _this._updateARIA(true);\n        this.trigger('on.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n    else {\n      Motion.animateOut(this.$element, this.animationOut, function() {\n        _this._updateARIA(false);\n        this.trigger('off.zf.toggler');\n        this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n      });\n    }\n  }\n\n  _updateARIA(isOn) {\n    var id = this.$element[0].id;\n    $(`[data-open=\"${id}\"], [data-close=\"${id}\"], [data-toggle=\"${id}\"]`)\n      .attr({\n        'aria-expanded': isOn ? true : false\n      });\n  }\n\n  /**\n   * Destroys the instance of Toggler on the element.\n   * @function\n   */\n  _destroy() {\n    this.$element.off('.zf.toggler');\n  }\n}\n\nToggler.defaults = {\n  /**\n   * Tells the plugin if the element should animated when toggled.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\nexport {Toggler};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index e8bfe72ccaa9b09a6e3abddbcd4394d1ca17b9d0..e34807eccf9db47506cee2198a1d87fb7711dd03 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(n){if(i[n])return i[n].exports;var r=i[n]={i:n,l:!1,exports:{}};return e[n].call(r.exports,r,r.exports,t),r.l=!0,r.exports}var i={};t.m=e,t.c=i,t.i=function(e){return e},t.d=function(e,i,n){t.o(e,i)||Object.defineProperty(e,i,{configurable:!1,enumerable:!0,get:n})},t.n=function(e){var i=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(i,"a",i),i},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=98)}({0:function(e,t){e.exports=jQuery},1:function(e,t){e.exports={Foundation:window.Foundation}},2:function(e,t){e.exports={Plugin:window.Foundation.Plugin}},32:function(e,t,i){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var n=i(1),r=(i.n(n),i(62));n.Foundation.plugin(r.a,"Toggler")},4:function(e,t){e.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},62:function(e,t,i){"use strict";function n(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function r(e,t){if(!e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!t||"object"!=typeof t&&"function"!=typeof t?e:t}function a(e,t){if("function"!=typeof t&&null!==t)throw new TypeError("Super expression must either be null or a function, not "+typeof t);e.prototype=Object.create(t&&t.prototype,{constructor:{value:e,enumerable:!1,writable:!0,configurable:!0}}),t&&(Object.setPrototypeOf?Object.setPrototypeOf(e,t):e.__proto__=t)}i.d(t,"a",function(){return f});var s=i(0),o=i.n(s),l=i(4),c=(i.n(l),i(2)),g=(i.n(c),i(7)),u=function(){function e(e,t){for(var i=0;i<t.length;i++){var n=t[i];n.enumerable=n.enumerable||!1,n.configurable=!0,"value"in n&&(n.writable=!0),Object.defineProperty(e,n.key,n)}}return function(t,i,n){return i&&e(t.prototype,i),n&&e(t,n),t}}(),f=function(e){function t(){return n(this,t),r(this,(t.__proto__||Object.getPrototypeOf(t)).apply(this,arguments))}return a(t,e),u(t,[{key:"_setup",value:function(e,i){this.$element=e,this.options=o.a.extend({},t.defaults,e.data(),i),this.className="",this.className="Toggler",g.a.init(o.a),this._init(),this._events()}},{key:"_init",value:function(){var e;this.options.animate?(e=this.options.animate.split(" "),this.animationIn=e[0],this.animationOut=e[1]||null):(e=this.$element.data("toggler"),this.className="."===e[0]?e.slice(1):e);var t=this.$element[0].id;o()('[data-open="'+t+'"], [data-close="'+t+'"], [data-toggle="'+t+'"]').attr("aria-controls",t),this.$element.attr("aria-expanded",!this.$element.is(":hidden"))}},{key:"_events",value:function(){this.$element.off("toggle.zf.trigger").on("toggle.zf.trigger",this.toggle.bind(this))}},{key:"toggle",value:function(){this[this.options.animate?"_toggleAnimate":"_toggleClass"]()}},{key:"_toggleClass",value:function(){this.$element.toggleClass(this.className);var e=this.$element.hasClass(this.className);e?this.$element.trigger("on.zf.toggler"):this.$element.trigger("off.zf.toggler"),this._updateARIA(e),this.$element.find("[data-mutate]").trigger("mutateme.zf.trigger")}},{key:"_toggleAnimate",value:function(){var e=this;this.$element.is(":hidden")?l.Motion.animateIn(this.$element,this.animationIn,function(){e._updateARIA(!0),this.trigger("on.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")}):l.Motion.animateOut(this.$element,this.animationOut,function(){e._updateARIA(!1),this.trigger("off.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")})}},{key:"_updateARIA",value:function(e){this.$element.attr("aria-expanded",!!e)}},{key:"_destroy",value:function(){this.$element.off(".zf.toggler")}}]),t}(c.Plugin);f.defaults={animate:!1}},7:function(e,t,i){"use strict";function n(e,t,i){var n=void 0,r=Array.prototype.slice.call(arguments,3);a()(window).off(t).on(t,function(t){n&&clearTimeout(n),n=setTimeout(function(){i.apply(null,r)},e||10)})}i.d(t,"a",function(){return c});var r=i(0),a=i.n(r),s=i(4),o=(i.n(s),function(){for(var e=["WebKit","Moz","O","Ms",""],t=0;t<e.length;t++)if(e[t]+"MutationObserver"in window)return window[e[t]+"MutationObserver"];return!1}()),l=function(e,t){e.data(t).split(" ").forEach(function(i){a()("#"+i)["close"===t?"trigger":"triggerHandler"](t+".zf.trigger",[e])})},c={Listeners:{Basic:{},Global:{}},Initializers:{}};c.Listeners.Basic={openListener:function(){l(a()(this),"open")},closeListener:function(){a()(this).data("close")?l(a()(this),"close"):a()(this).trigger("close.zf.trigger")},toggleListener:function(){a()(this).data("toggle")?l(a()(this),"toggle"):a()(this).trigger("toggle.zf.trigger")},closeableListener:function(e){e.stopPropagation();var t=a()(this).data("closable");""!==t?s.Motion.animateOut(a()(this),t,function(){a()(this).trigger("closed.zf")}):a()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var e=a()(this).data("toggle-focus");a()("#"+e).triggerHandler("toggle.zf.trigger",[a()(this)])}},c.Initializers.addOpenListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.openListener),e.on("click.zf.trigger","[data-open]",c.Listeners.Basic.openListener)},c.Initializers.addCloseListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.closeListener),e.on("click.zf.trigger","[data-close]",c.Listeners.Basic.closeListener)},c.Initializers.addToggleListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.toggleListener),e.on("click.zf.trigger","[data-toggle]",c.Listeners.Basic.toggleListener)},c.Initializers.addCloseableListener=function(e){e.off("close.zf.trigger",c.Listeners.Basic.closeableListener),e.on("close.zf.trigger","[data-closeable], [data-closable]",c.Listeners.Basic.closeableListener)},c.Initializers.addToggleFocusListener=function(e){e.off("focus.zf.trigger blur.zf.trigger",c.Listeners.Basic.toggleFocusListener),e.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",c.Listeners.Basic.toggleFocusListener)},c.Listeners.Global={resizeListener:function(e){o||e.each(function(){a()(this).triggerHandler("resizeme.zf.trigger")}),e.attr("data-events","resize")},scrollListener:function(e){o||e.each(function(){a()(this).triggerHandler("scrollme.zf.trigger")}),e.attr("data-events","scroll")},closeMeListener:function(e,t){var i=e.namespace.split(".")[0];a()("[data-"+i+"]").not('[data-yeti-box="'+t+'"]').each(function(){var e=a()(this);e.triggerHandler("close.zf.trigger",[e])})}},c.Initializers.addClosemeListener=function(e){var t=a()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(e&&("string"==typeof e?i.push(e):"object"==typeof e&&"string"==typeof e[0]?i.concat(e):console.error("Plugin names must be strings")),t.length){var n=i.map(function(e){return"closeme.zf."+e}).join(" ");a()(window).off(n).on(n,c.Listeners.Global.closeMeListener)}},c.Initializers.addResizeListener=function(e){var t=a()("[data-resize]");t.length&&n(e,"resize.zf.trigger",c.Listeners.Global.resizeListener,t)},c.Initializers.addScrollListener=function(e){var t=a()("[data-scroll]");t.length&&n(e,"scroll.zf.trigger",c.Listeners.Global.scrollListener,t)},c.Initializers.addMutationEventsListener=function(e){if(!o)return!1;var t=e.find("[data-resize], [data-scroll], [data-mutate]"),i=function(e){var t=a()(e[0].target);switch(e[0].type){case"attributes":"scroll"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("scrollme.zf.trigger",[t,window.pageYOffset]),"resize"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("resizeme.zf.trigger",[t]),"style"===e[0].attributeName&&(t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]));break;case"childList":t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]);break;default:return!1}};if(t.length)for(var n=0;n<=t.length-1;n++){var r=new o(i);r.observe(t[n],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},c.Initializers.addSimpleListeners=function(){var e=a()(document);c.Initializers.addOpenListener(e),c.Initializers.addCloseListener(e),c.Initializers.addToggleListener(e),c.Initializers.addCloseableListener(e),c.Initializers.addToggleFocusListener(e)},c.Initializers.addGlobalListeners=function(){var e=a()(document);c.Initializers.addMutationEventsListener(e),c.Initializers.addResizeListener(),c.Initializers.addScrollListener(),c.Initializers.addClosemeListener()},c.init=function(e,t){if(void 0===e.triggersInitialized){e(document);"complete"===document.readyState?(c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners()):e(window).on("load",function(){c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners()}),e.triggersInitialized=!0}t&&(t.Triggers=c,t.IHearYou=c.Initializers.addGlobalListeners)}},98:function(e,t,i){e.exports=i(32)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("./foundation.util.motion"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.motion","jquery"],e):"object"==typeof exports?exports["foundation.toggler"]=e(require("./foundation.core"),require("./foundation.util.motion"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.toggler"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.util.motion"],t.jQuery))}(window,function(n,i,r){return function(n){var i={};function r(t){if(i[t])return i[t].exports;var e=i[t]={i:t,l:!1,exports:{}};return n[t].call(e.exports,e,e.exports,r),e.l=!0,e.exports}return r.m=n,r.c=i,r.d=function(t,e,n){r.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},r.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},r.t=function(e,t){if(1&t&&(e=r(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(r.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)r.d(n,i,function(t){return e[t]}.bind(null,i));return n},r.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return r.d(e,"a",e),e},r.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},r.p="",r(r.s=19)}({"./foundation.core":function(t,e){t.exports=n},"./foundation.util.motion":function(t,e){t.exports=i},"./js/entries/plugins/foundation.toggler.js":function(t,e,n){"use strict";n.r(e);var i=n("./foundation.core");n.d(e,"Foundation",function(){return i.Foundation});var r=n("./js/foundation.toggler.js");n.d(e,"Toggler",function(){return r.Toggler}),i.Foundation.plugin(r.Toggler,"Toggler")},"./js/foundation.toggler.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Toggler",function(){return d});var i=n("jquery"),o=n.n(i),a=n("./foundation.util.motion"),s=n("./foundation.core"),l=n("./js/foundation.util.triggers.js");function r(t){return(r="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function u(t,e){for(var n=0;n<e.length;n++){var i=e[n];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}function c(t,e){return!e||"object"!==r(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function f(t){return(f=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function g(t,e){return(g=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var d=function(t){function n(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,n),c(this,f(n).apply(this,arguments))}var e,i,r;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&g(t,e)}(n,s["Plugin"]),e=n,(i=[{key:"_setup",value:function(t,e){this.$element=t,this.options=o.a.extend({},n.defaults,t.data(),e),this.className="",this.className="Toggler",l.Triggers.init(o.a),this._init(),this._events()}},{key:"_init",value:function(){var t;this.options.animate?(t=this.options.animate.split(" "),this.animationIn=t[0],this.animationOut=t[1]||null):(t=this.$element.data("toggler"),this.className="."===t[0]?t.slice(1):t);var r=this.$element[0].id,e=o()('[data-open~="'.concat(r,'"], [data-close~="').concat(r,'"], [data-toggle~="').concat(r,'"]'));e.attr("aria-expanded",!this.$element.is(":hidden")),e.each(function(t,e){var n=o()(e),i=n.attr("aria-controls")||"";new RegExp("\\b".concat(Object(s.RegExpEscape)(r),"\\b")).test(i)||n.attr("aria-controls",i?"".concat(i," ").concat(r):r)})}},{key:"_events",value:function(){this.$element.off("toggle.zf.trigger").on("toggle.zf.trigger",this.toggle.bind(this))}},{key:"toggle",value:function(){this[this.options.animate?"_toggleAnimate":"_toggleClass"]()}},{key:"_toggleClass",value:function(){this.$element.toggleClass(this.className);var t=this.$element.hasClass(this.className);t?this.$element.trigger("on.zf.toggler"):this.$element.trigger("off.zf.toggler"),this._updateARIA(t),this.$element.find("[data-mutate]").trigger("mutateme.zf.trigger")}},{key:"_toggleAnimate",value:function(){var t=this;this.$element.is(":hidden")?a.Motion.animateIn(this.$element,this.animationIn,function(){t._updateARIA(!0),this.trigger("on.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")}):a.Motion.animateOut(this.$element,this.animationOut,function(){t._updateARIA(!1),this.trigger("off.zf.toggler"),this.find("[data-mutate]").trigger("mutateme.zf.trigger")})}},{key:"_updateARIA",value:function(t){var e=this.$element[0].id;o()('[data-open="'.concat(e,'"], [data-close="').concat(e,'"], [data-toggle="').concat(e,'"]')).attr({"aria-expanded":!!t})}},{key:"_destroy",value:function(){this.$element.off(".zf.toggler")}}])&&u(e.prototype,i),r&&u(e,r),n}();d.defaults={animate:!1}},"./js/foundation.util.triggers.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Triggers",function(){return c});var i=n("jquery"),o=n.n(i),r=n("./foundation.core"),a=n("./foundation.util.motion");function s(t){return(s="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var l=function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if("".concat(t[e],"MutationObserver")in window)return window["".concat(t[e],"MutationObserver")];return!1}(),u=function(e,n){e.data(n).split(" ").forEach(function(t){o()("#".concat(t))["close"===n?"trigger":"triggerHandler"]("".concat(n,".zf.trigger"),[e])})},c={Listeners:{Basic:{},Global:{}},Initializers:{}};function f(e,t,n){var i,r=Array.prototype.slice.call(arguments,3);o()(window).off(t).on(t,function(t){i&&clearTimeout(i),i=setTimeout(function(){n.apply(null,r)},e||10)})}c.Listeners.Basic={openListener:function(){u(o()(this),"open")},closeListener:function(){o()(this).data("close")?u(o()(this),"close"):o()(this).trigger("close.zf.trigger")},toggleListener:function(){o()(this).data("toggle")?u(o()(this),"toggle"):o()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=o()(this).data("closable");""!==e?a.Motion.animateOut(o()(this),e,function(){o()(this).trigger("closed.zf")}):o()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=o()(this).data("toggle-focus");o()("#".concat(t)).triggerHandler("toggle.zf.trigger",[o()(this)])}},c.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",c.Listeners.Basic.openListener)},c.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",c.Listeners.Basic.closeListener)},c.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",c.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",c.Listeners.Basic.toggleListener)},c.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",c.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",c.Listeners.Basic.closeableListener)},c.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",c.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",c.Listeners.Basic.toggleFocusListener)},c.Listeners.Global={resizeListener:function(t){l||t.each(function(){o()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){l||t.each(function(){o()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var n=t.namespace.split(".")[0];o()("[data-".concat(n,"]")).not('[data-yeti-box="'.concat(e,'"]')).each(function(){var t=o()(this);t.triggerHandler("close.zf.trigger",[t])})}},c.Initializers.addClosemeListener=function(t){var e=o()("[data-yeti-box]"),n=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?n.push(t):"object"===s(t)&&"string"==typeof t[0]?n=n.concat(t):console.error("Plugin names must be strings")),e.length){var i=n.map(function(t){return"closeme.zf.".concat(t)}).join(" ");o()(window).off(i).on(i,c.Listeners.Global.closeMeListener)}},c.Initializers.addResizeListener=function(t){var e=o()("[data-resize]");e.length&&f(t,"resize.zf.trigger",c.Listeners.Global.resizeListener,e)},c.Initializers.addScrollListener=function(t){var e=o()("[data-scroll]");e.length&&f(t,"scroll.zf.trigger",c.Listeners.Global.scrollListener,e)},c.Initializers.addMutationEventsListener=function(t){if(!l)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),n=function(t){var e=o()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var i=0;i<=e.length-1;i++){new l(n).observe(e[i],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},c.Initializers.addSimpleListeners=function(){var t=o()(document);c.Initializers.addOpenListener(t),c.Initializers.addCloseListener(t),c.Initializers.addToggleListener(t),c.Initializers.addCloseableListener(t),c.Initializers.addToggleFocusListener(t)},c.Initializers.addGlobalListeners=function(){var t=o()(document);c.Initializers.addMutationEventsListener(t),c.Initializers.addResizeListener(),c.Initializers.addScrollListener(),c.Initializers.addClosemeListener()},c.init=function(t,e){Object(r.onLoad)(t(window),function(){!0!==t.triggersInitialized&&(c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners(),t.triggersInitialized=!0)}),e&&(e.Triggers=c,e.IHearYou=c.Initializers.addGlobalListeners)}},19:function(t,e,n){t.exports=n("./js/entries/plugins/foundation.toggler.js")},jquery:function(t,e){t.exports=r}})});
+//# sourceMappingURL=foundation.toggler.min.js.map
diff --git a/dist/js/plugins/foundation.toggler.min.js.map b/dist/js/plugins/foundation.toggler.min.js.map
new file mode 100644 (file)
index 0000000..946e251
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.toggler.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.motion","./js/entries/plugins/foundation.toggler.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_toggler__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.toggler.js","Toggler","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","element","options","$element","a","extend","defaults","data","className","init","_init","_events","input","animate","split","animationIn","animationOut","slice","id","$triggers","concat","attr","is","each","index","trigger","$trigger","controls","RegExp","test","off","on","toggle","toggleClass","isOn","hasClass","_updateARIA","find","_this","animateIn","animateOut","aria-expanded","./js/foundation.util.triggers.js","Triggers","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","MutationObserver","prefixes","triggers","el","type","forEach","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","listener","timer","args","Array","e","clearTimeout","setTimeout","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","scrollListener","closeMeListener","pluginId","namespace","not","addClosemeListener","pluginName","yetiBoxes","plugNames","push","console","error","listeners","map","join","addResizeListener","addScrollListener","addMutationEventsListener","listeningElementsMutation","mutationRecordsList","$target","attributeName","pageYOffset","closest","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","document","addGlobalListeners","$","Foundation","triggersInitialized","IHearYou","19","jquery"],"mappings":"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","file":"foundation.toggler.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.toggler\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.toggler\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 19);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.toggler.js\":\n/*!**************************************************!*\\\n  !*** ./js/entries/plugins/foundation.toggler.js ***!\n  \\**************************************************/\n/*! exports provided: Foundation, Toggler */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_toggler__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.toggler */ \"./js/foundation.toggler.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Toggler\", function() { return _foundation_toggler__WEBPACK_IMPORTED_MODULE_1__[\"Toggler\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_toggler__WEBPACK_IMPORTED_MODULE_1__[\"Toggler\"], 'Toggler');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.toggler.js\":\n/*!**********************************!*\\\n  !*** ./js/foundation.toggler.js ***!\n  \\**********************************/\n/*! exports provided: Toggler */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Toggler\", function() { return Toggler; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Toggler module.\n * @module foundation.toggler\n * @requires foundation.util.motion\n * @requires foundation.util.triggers\n */\n\nvar Toggler =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Toggler, _Plugin);\n\n  function Toggler() {\n    _classCallCheck(this, Toggler);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Toggler).apply(this, arguments));\n  }\n\n  _createClass(Toggler, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of Toggler.\n     * @class\n     * @name Toggler\n     * @fires Toggler#init\n     * @param {Object} element - jQuery object to add the trigger to.\n     * @param {Object} options - Overrides to the default plugin settings.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Toggler.defaults, element.data(), options);\n      this.className = '';\n      this.className = 'Toggler'; // ie9 back compat\n      // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n\n      this._events();\n    }\n    /**\n     * Initializes the Toggler plugin by parsing the toggle class from data-toggler, or animation classes from data-animate.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      var input; // Parse animation classes if they were set\n\n      if (this.options.animate) {\n        input = this.options.animate.split(' ');\n        this.animationIn = input[0];\n        this.animationOut = input[1] || null;\n      } // Otherwise, parse toggle class\n      else {\n          input = this.$element.data('toggler'); // Allow for a . at the beginning of the string\n\n          this.className = input[0] === '.' ? input.slice(1) : input;\n        } // Add ARIA attributes to triggers:\n\n\n      var id = this.$element[0].id,\n          $triggers = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open~=\\\"\".concat(id, \"\\\"], [data-close~=\\\"\").concat(id, \"\\\"], [data-toggle~=\\\"\").concat(id, \"\\\"]\")); // - aria-expanded: according to the element visibility.\n\n      $triggers.attr('aria-expanded', !this.$element.is(':hidden')); // - aria-controls: adding the element id to it if not already in it.\n\n      $triggers.each(function (index, trigger) {\n        var $trigger = jquery__WEBPACK_IMPORTED_MODULE_0___default()(trigger);\n        var controls = $trigger.attr('aria-controls') || '';\n        var containsId = new RegExp(\"\\\\b\".concat(Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"RegExpEscape\"])(id), \"\\\\b\")).test(controls);\n        if (!containsId) $trigger.attr('aria-controls', controls ? \"\".concat(controls, \" \").concat(id) : id);\n      });\n    }\n    /**\n     * Initializes events for the toggle trigger.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      this.$element.off('toggle.zf.trigger').on('toggle.zf.trigger', this.toggle.bind(this));\n    }\n    /**\n     * Toggles the target class on the target element. An event is fired from the original trigger depending on if the resultant state was \"on\" or \"off\".\n     * @function\n     * @fires Toggler#on\n     * @fires Toggler#off\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle() {\n      this[this.options.animate ? '_toggleAnimate' : '_toggleClass']();\n    }\n  }, {\n    key: \"_toggleClass\",\n    value: function _toggleClass() {\n      this.$element.toggleClass(this.className);\n      var isOn = this.$element.hasClass(this.className);\n\n      if (isOn) {\n        /**\n         * Fires if the target element has the class after a toggle.\n         * @event Toggler#on\n         */\n        this.$element.trigger('on.zf.toggler');\n      } else {\n        /**\n         * Fires if the target element does not have the class after a toggle.\n         * @event Toggler#off\n         */\n        this.$element.trigger('off.zf.toggler');\n      }\n\n      this._updateARIA(isOn);\n\n      this.$element.find('[data-mutate]').trigger('mutateme.zf.trigger');\n    }\n  }, {\n    key: \"_toggleAnimate\",\n    value: function _toggleAnimate() {\n      var _this = this;\n\n      if (this.$element.is(':hidden')) {\n        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__[\"Motion\"].animateIn(this.$element, this.animationIn, function () {\n          _this._updateARIA(true);\n\n          this.trigger('on.zf.toggler');\n          this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        });\n      } else {\n        _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__[\"Motion\"].animateOut(this.$element, this.animationOut, function () {\n          _this._updateARIA(false);\n\n          this.trigger('off.zf.toggler');\n          this.find('[data-mutate]').trigger('mutateme.zf.trigger');\n        });\n      }\n    }\n  }, {\n    key: \"_updateARIA\",\n    value: function _updateARIA(isOn) {\n      var id = this.$element[0].id;\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-open=\\\"\".concat(id, \"\\\"], [data-close=\\\"\").concat(id, \"\\\"], [data-toggle=\\\"\").concat(id, \"\\\"]\")).attr({\n        'aria-expanded': isOn ? true : false\n      });\n    }\n    /**\n     * Destroys the instance of Toggler on the element.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.off('.zf.toggler');\n    }\n  }]);\n\n  return Toggler;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_2__[\"Plugin\"]);\n\nToggler.defaults = {\n  /**\n   * Tells the plugin if the element should animated when toggled.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  animate: false\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 19:\n/*!********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.toggler.js ***!\n  \\********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.toggler.js */\"./js/entries/plugins/foundation.toggler.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.toggler.js.map"]}
\ No newline at end of file
index 0a4500c6d7bba7e66a1cb5462c555b9ecf2a2d8a..dc82141344b45f13b52b85eb0393437ffaa66ff0 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.box"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.box", "./foundation.util.mediaQuery", "./foundation.util.motion", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.tooltip"] = factory(require("./foundation.core"), require("./foundation.util.box"), require("./foundation.util.mediaQuery"), require("./foundation.util.motion"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.tooltip"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.box"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 99);
+/******/       return __webpack_require__(__webpack_require__.s = 20);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
+/***/ "./foundation.util.box":
+/*!********************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.box"],"amd":"./foundation.util.box","commonjs":"./foundation.util.box","commonjs2":"./foundation.util.box"} ***!
+  \********************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;
+
+/***/ }),
+
+/***/ "./foundation.util.mediaQuery":
+/*!************************************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.mediaQuery"],"amd":"./foundation.util.mediaQuery","commonjs":"./foundation.util.mediaQuery","commonjs2":"./foundation.util.mediaQuery"} ***!
+  \************************************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;
+
+/***/ }),
+
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
+
+/***/ }),
+
+/***/ "./js/entries/plugins/foundation.tooltip.js":
+/*!**************************************************!*\
+  !*** ./js/entries/plugins/foundation.tooltip.js ***!
+  \**************************************************/
+/*! exports provided: Foundation, Tooltip */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
+
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
+
+/* harmony import */ var _foundation_tooltip__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.tooltip */ "./js/foundation.tooltip.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Tooltip", function() { return _foundation_tooltip__WEBPACK_IMPORTED_MODULE_1__["Tooltip"]; });
+
+
+
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].plugin(_foundation_tooltip__WEBPACK_IMPORTED_MODULE_1__["Tooltip"], 'Tooltip');
+
 
 /***/ }),
 
-/***/ 11:
+/***/ "./js/foundation.positionable.js":
+/*!***************************************!*\
+  !*** ./js/foundation.positionable.js ***!
+  \***************************************/
+/*! exports provided: Positionable */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Positionable; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__ = __webpack_require__(8);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_util_box___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_plugin__ = __webpack_require__(2);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_plugin___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_plugin__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Positionable", function() { return Positionable; });
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.util.box */ "./foundation.util.box");
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ "./foundation.core");
+/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__);
 
 
-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 _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-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 _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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
+function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
+
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
+
+function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
-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 _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -110,7 +203,6 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
 var POSITIONS = ['left', 'right', 'top', 'bottom'];
 var VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];
 var HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];
-
 var ALIGNMENTS = {
   'left': VERTICAL_ALIGNMENTS,
   'right': VERTICAL_ALIGNMENTS,
@@ -120,6 +212,7 @@ var ALIGNMENTS = {
 
 function nextItem(item, array) {
   var currentIdx = array.indexOf(item);
+
   if (currentIdx === array.length - 1) {
     return array[0];
   } else {
@@ -127,17 +220,19 @@ function nextItem(item, array) {
   }
 }
 
-var Positionable = function (_Plugin) {
+var Positionable =
+/*#__PURE__*/
+function (_Plugin) {
   _inherits(Positionable, _Plugin);
 
   function Positionable() {
     _classCallCheck(this, Positionable);
 
-    return _possibleConstructorReturn(this, (Positionable.__proto__ || Object.getPrototypeOf(Positionable)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments));
   }
 
   _createClass(Positionable, [{
-    key: '_init',
+    key: "_init",
 
     /**
      * Abstract class encapsulating the tether-like explicit positioning logic
@@ -148,30 +243,31 @@ var Positionable = function (_Plugin) {
      * generated) by explicitly declaring them.
      *
      **/
-
     value: function _init() {
       this.triedPositions = {};
       this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;
       this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;
+      this.originalPosition = this.position;
+      this.originalAlignment = this.alignment;
     }
   }, {
-    key: '_getDefaultPosition',
+    key: "_getDefaultPosition",
     value: function _getDefaultPosition() {
       return 'bottom';
     }
   }, {
-    key: '_getDefaultAlignment',
+    key: "_getDefaultAlignment",
     value: function _getDefaultAlignment() {
       switch (this.position) {
         case 'bottom':
         case 'top':
-          return __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_2__foundation_util_core__["rtl"])() ? 'right' : 'left';
+          return Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["rtl"])() ? 'right' : 'left';
+
         case 'left':
         case 'right':
           return 'bottom';
       }
     }
-
     /**
      * Adjusts the positionable possible positions by iterating through alignments
      * and positions.
@@ -180,7 +276,7 @@ var Positionable = function (_Plugin) {
      */
 
   }, {
-    key: '_reposition',
+    key: "_reposition",
     value: function _reposition() {
       if (this._alignmentsExhausted(this.position)) {
         this.position = nextItem(this.position, POSITIONS);
@@ -189,7 +285,6 @@ var Positionable = function (_Plugin) {
         this._realign();
       }
     }
-
     /**
      * Adjusts the dropdown pane possible positions by iterating through alignments
      * on the current position.
@@ -198,33 +293,34 @@ var Positionable = function (_Plugin) {
      */
 
   }, {
-    key: '_realign',
+    key: "_realign",
     value: function _realign() {
       this._addTriedPosition(this.position, this.alignment);
+
       this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);
     }
   }, {
-    key: '_addTriedPosition',
+    key: "_addTriedPosition",
     value: function _addTriedPosition(position, alignment) {
       this.triedPositions[position] = this.triedPositions[position] || [];
       this.triedPositions[position].push(alignment);
     }
   }, {
-    key: '_positionsExhausted',
+    key: "_positionsExhausted",
     value: function _positionsExhausted() {
       var isExhausted = true;
+
       for (var i = 0; i < POSITIONS.length; i++) {
         isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);
       }
+
       return isExhausted;
     }
   }, {
-    key: '_alignmentsExhausted',
+    key: "_alignmentsExhausted",
     value: function _alignmentsExhausted(position) {
       return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;
-    }
-
-    // When we're trying to center, we don't want to apply offset that's going to
+    } // When we're trying to center, we don't want to apply offset that's going to
     // take us just off center, so wrap around to return 0 for the appropriate
     // offset in those alignments.  TODO: Figure out if we want to make this
     // configurable behavior... it feels more intuitive, especially for tooltips, but
@@ -232,57 +328,73 @@ var Positionable = function (_Plugin) {
     // slightly off.
 
   }, {
-    key: '_getVOffset',
+    key: "_getVOffset",
     value: function _getVOffset() {
       return this.options.vOffset;
     }
   }, {
-    key: '_getHOffset',
+    key: "_getHOffset",
     value: function _getHOffset() {
       return this.options.hOffset;
     }
   }, {
-    key: '_setPosition',
+    key: "_setPosition",
     value: function _setPosition($anchor, $element, $parent) {
       if ($anchor.attr('aria-expanded') === 'false') {
         return false;
       }
-      var $eleDims = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetDimensions($element),
-          $anchorDims = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetDimensions($anchor);
 
-      $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+      var $eleDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetDimensions($element),
+          $anchorDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetDimensions($anchor);
+
+      if (!this.options.allowOverlap) {
+        // restore original position & alignment before checking overlap
+        this.position = this.originalPosition;
+        this.alignment = this.originalAlignment;
+      }
+
+      $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
 
       if (!this.options.allowOverlap) {
         var overlaps = {};
-        var minOverlap = 100000000;
-        // default coordinates to how we start, in case we can't figure out better
-        var minCoordinates = { position: this.position, alignment: this.alignment };
+        var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better
+
+        var minCoordinates = {
+          position: this.position,
+          alignment: this.alignment
+        };
+
         while (!this._positionsExhausted()) {
-          var overlap = __WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
+          var overlap = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);
+
           if (overlap === 0) {
             return;
           }
 
           if (overlap < minOverlap) {
             minOverlap = overlap;
-            minCoordinates = { position: this.position, alignment: this.alignment };
+            minCoordinates = {
+              position: this.position,
+              alignment: this.alignment
+            };
           }
 
           this._reposition();
 
-          $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
-        }
-        // If we get through the entire loop, there was no non-overlapping
+          $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+        } // If we get through the entire loop, there was no non-overlapping
         // position available. Pick the version with least overlap.
+
+
         this.position = minCoordinates.position;
         this.alignment = minCoordinates.alignment;
-        $element.offset(__WEBPACK_IMPORTED_MODULE_0__foundation_util_box__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
+        $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__["Box"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));
       }
     }
   }]);
 
   return Positionable;
-}(__WEBPACK_IMPORTED_MODULE_1__foundation_plugin__["Plugin"]);
+}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__["Plugin"]);
 
 Positionable.defaults = {
   /**
@@ -292,6 +404,7 @@ Positionable.defaults = {
    * @default 'auto'
    */
   position: 'auto',
+
   /**
    * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.
    * @option
@@ -299,6 +412,7 @@ Positionable.defaults = {
    * @default 'auto'
    */
   alignment: 'auto',
+
   /**
    * Allow overlap of container/window. If false, dropdown positionable first
    * try to position as defined by data-position and data-alignment, but
@@ -308,6 +422,7 @@ Positionable.defaults = {
    * @default false
    */
   allowOverlap: false,
+
   /**
    * Allow overlap of only the bottom of the container. This is the most common
    * behavior for dropdowns, allowing the dropdown to extend the bottom of the
@@ -317,6 +432,7 @@ Positionable.defaults = {
    * @default true
    */
   allowBottomOverlap: true,
+
   /**
    * Number of pixels the positionable should be separated vertically from anchor
    * @option
@@ -324,6 +440,7 @@ Positionable.defaults = {
    * @default 0
    */
   vOffset: 0,
+
   /**
    * Number of pixels the positionable should be separated horizontally from anchor
    * @option
@@ -334,78 +451,49 @@ Positionable.defaults = {
 };
 
 
-
 /***/ }),
 
-/***/ 2:
-/***/ (function(module, exports) {
-
-module.exports = {Plugin: window.Foundation.Plugin};
-
-/***/ }),
-
-/***/ 3:
-/***/ (function(module, exports) {
-
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
-
-/***/ }),
-
-/***/ 33:
+/***/ "./js/foundation.tooltip.js":
+/*!**********************************!*\
+  !*** ./js/foundation.tooltip.js ***!
+  \**********************************/
+/*! exports provided: Tooltip */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_tooltip__ = __webpack_require__(63);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Tooltip", function() { return Tooltip; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ "./foundation.util.mediaQuery");
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.triggers */ "./js/foundation.util.triggers.js");
+/* harmony import */ var _foundation_positionable__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.positionable */ "./js/foundation.positionable.js");
 
 
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].plugin(__WEBPACK_IMPORTED_MODULE_1__foundation_tooltip__["a" /* Tooltip */], 'Tooltip');
-
-/***/ }),
-
-/***/ 4:
-/***/ (function(module, exports) {
-
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
-
-/***/ }),
-
-/***/ 6:
-/***/ (function(module, exports) {
-
-module.exports = {MediaQuery: window.Foundation.MediaQuery};
-
-/***/ }),
-
-/***/ 63:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
 
-"use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Tooltip; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__ = __webpack_require__(6);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__foundation_util_triggers__ = __webpack_require__(7);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_4__foundation_positionable__ = __webpack_require__(11);
+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); } }
 
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
 
-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 (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
 
-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); } };
+function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
 
-function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
+function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); }
 
-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 _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }
 
-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 _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
 
+function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }
 
+function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
 
 
 
@@ -420,17 +508,19 @@ function _inherits(subClass, superClass) { if (typeof superClass !== "function"
  * @requires foundation.util.triggers
  */
 
-var Tooltip = function (_Positionable) {
+var Tooltip =
+/*#__PURE__*/
+function (_Positionable) {
   _inherits(Tooltip, _Positionable);
 
   function Tooltip() {
     _classCallCheck(this, Tooltip);
 
-    return _possibleConstructorReturn(this, (Tooltip.__proto__ || Object.getPrototypeOf(Tooltip)).apply(this, arguments));
+    return _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments));
   }
 
   _createClass(Tooltip, [{
-    key: '_setup',
+    key: "_setup",
 
     /**
      * Creates a new instance of a Tooltip.
@@ -442,31 +532,29 @@ var Tooltip = function (_Positionable) {
      */
     value: function _setup(element, options) {
       this.$element = element;
-      this.options = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, Tooltip.defaults, this.$element.data(), options);
+      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tooltip.defaults, this.$element.data(), options);
       this.className = 'Tooltip'; // ie9 back compat
 
       this.isActive = false;
-      this.isClick = false;
+      this.isClick = false; // Triggers init is idempotent, just need to make sure it is initialized
 
-      // Triggers init is idempotent, just need to make sure it is initialized
-      __WEBPACK_IMPORTED_MODULE_3__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
+      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
 
       this._init();
     }
-
     /**
      * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.
      * @private
      */
 
   }, {
-    key: '_init',
+    key: "_init",
     value: function _init() {
-      __WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"]._init();
-      var elemId = this.$element.attr('aria-describedby') || __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["GetYoDigits"])(6, 'tooltip');
+      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"]._init();
 
+      var elemId = this.$element.attr('aria-describedby') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["GetYoDigits"])(6, 'tooltip');
       this.options.tipText = this.options.tipText || this.$element.attr('title');
-      this.template = this.options.template ? __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this.options.template) : this._buildTemplate(elemId);
+      this.template = this.options.template ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.template) : this._buildTemplate(elemId);
 
       if (this.options.allowHtml) {
         this.template.appendTo(document.body).html(this.options.tipText).hide();
@@ -482,23 +570,24 @@ var Tooltip = function (_Positionable) {
         'data-resize': elemId
       }).addClass(this.options.triggerClass);
 
-      _get(Tooltip.prototype.__proto__ || Object.getPrototypeOf(Tooltip.prototype), '_init', this).call(this);
+      _get(_getPrototypeOf(Tooltip.prototype), "_init", this).call(this);
+
       this._events();
     }
   }, {
-    key: '_getDefaultPosition',
+    key: "_getDefaultPosition",
     value: function _getDefaultPosition() {
       // handle legacy classnames
       var position = this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);
       return position ? position[0] : 'top';
     }
   }, {
-    key: '_getDefaultAlignment',
+    key: "_getDefaultAlignment",
     value: function _getDefaultAlignment() {
       return 'center';
     }
   }, {
-    key: '_getHOffset',
+    key: "_getHOffset",
     value: function _getHOffset() {
       if (this.position === 'left' || this.position === 'right') {
         return this.options.hOffset + this.options.tooltipWidth;
@@ -507,7 +596,7 @@ var Tooltip = function (_Positionable) {
       }
     }
   }, {
-    key: '_getVOffset',
+    key: "_getVOffset",
     value: function _getVOffset() {
       if (this.position === 'top' || this.position === 'bottom') {
         return this.options.vOffset + this.options.tooltipHeight;
@@ -515,17 +604,16 @@ var Tooltip = function (_Positionable) {
         return this.options.vOffset;
       }
     }
-
     /**
      * builds the tooltip element, adds attributes, and returns the template.
      * @private
      */
 
   }, {
-    key: '_buildTemplate',
+    key: "_buildTemplate",
     value: function _buildTemplate(id) {
-      var templateClasses = (this.options.tooltipClass + ' ' + this.options.positionClass + ' ' + this.options.templateClasses).trim();
-      var $template = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<div></div>').addClass(templateClasses).attr({
+      var templateClasses = "".concat(this.options.tooltipClass, " ").concat(this.options.templateClasses).trim();
+      var $template = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div></div>').addClass(templateClasses).attr({
         'role': 'tooltip',
         'aria-hidden': true,
         'data-is-active': false,
@@ -534,7 +622,6 @@ var Tooltip = function (_Positionable) {
       });
       return $template;
     }
-
     /**
      * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.
      * if the tooltip is larger than the screen width, default to full width - any user selected margin
@@ -542,11 +629,10 @@ var Tooltip = function (_Positionable) {
      */
 
   }, {
-    key: '_setPosition',
+    key: "_setPosition",
     value: function _setPosition() {
-      _get(Tooltip.prototype.__proto__ || Object.getPrototypeOf(Tooltip.prototype), '_setPosition', this).call(this, this.$element, this.template);
+      _get(_getPrototypeOf(Tooltip.prototype), "_setPosition", this).call(this, this.$element, this.template);
     }
-
     /**
      * reveals the tooltip, and fires an event to close any other open tooltips on the page
      * @fires Tooltip#closeme
@@ -555,41 +641,42 @@ var Tooltip = function (_Positionable) {
      */
 
   }, {
-    key: 'show',
+    key: "show",
     value: function show() {
-      if (this.options.showOn !== 'all' && !__WEBPACK_IMPORTED_MODULE_2__foundation_util_mediaQuery__["MediaQuery"].is(this.options.showOn)) {
+      if (this.options.showOn !== 'all' && !_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__["MediaQuery"].is(this.options.showOn)) {
         // console.error('The screen is too small to display this tooltip');
         return false;
       }
 
       var _this = this;
+
       this.template.css('visibility', 'hidden').show();
+
       this._setPosition();
+
       this.template.removeClass('top bottom left right').addClass(this.position);
       this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);
-
       /**
        * Fires to close all other open tooltips on the page
        * @event Closeme#tooltip
        */
-      this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));
 
+      this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));
       this.template.attr({
         'data-is-active': true,
         'aria-hidden': false
       });
-      _this.isActive = true;
-      // console.log(this.template);
-      this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {
-        //maybe do stuff?
+      _this.isActive = true; // console.log(this.template);
+
+      this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {//maybe do stuff?
       });
       /**
        * Fires when the tooltip is shown
        * @event Tooltip#show
        */
+
       this.$element.trigger('show.zf.tooltip');
     }
-
     /**
      * Hides the current tooltip, and resets the positioning class if it was changed due to collision
      * @fires Tooltip#hide
@@ -597,10 +684,11 @@ var Tooltip = function (_Positionable) {
      */
 
   }, {
-    key: 'hide',
+    key: "hide",
     value: function hide() {
       // console.log('hiding', this.$element.data('yeti-box'));
       var _this = this;
+
       this.template.stop().attr({
         'aria-hidden': true,
         'data-is-active': false
@@ -612,9 +700,9 @@ var Tooltip = function (_Positionable) {
        * fires when the tooltip is hidden
        * @event Tooltip#hide
        */
+
       this.$element.trigger('hide.zf.tooltip');
     }
-
     /**
      * adds event listeners for the tooltip and its anchor
      * TODO combine some of the listeners like focus and mouseenter, etc.
@@ -622,36 +710,38 @@ var Tooltip = function (_Positionable) {
      */
 
   }, {
-    key: '_events',
+    key: "_events",
     value: function _events() {
       var _this = this;
+
       var $template = this.template;
       var isFocus = false;
 
       if (!this.options.disableHover) {
-
         this.$element.on('mouseenter.zf.tooltip', function (e) {
           if (!_this.isActive) {
             _this.timeout = setTimeout(function () {
               _this.show();
             }, _this.options.hoverDelay);
           }
-        }).on('mouseleave.zf.tooltip', function (e) {
+        }).on('mouseleave.zf.tooltip', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["ignoreMousedisappear"])(function (e) {
           clearTimeout(_this.timeout);
+
           if (!isFocus || _this.isClick && !_this.options.clickOpen) {
             _this.hide();
           }
-        });
+        }));
       }
 
       if (this.options.clickOpen) {
         this.$element.on('mousedown.zf.tooltip', function (e) {
           e.stopImmediatePropagation();
-          if (_this.isClick) {
-            //_this.hide();
+
+          if (_this.isClick) {//_this.hide();
             // _this.isClick = false;
           } else {
             _this.isClick = true;
+
             if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {
               _this.show();
             }
@@ -675,15 +765,16 @@ var Tooltip = function (_Positionable) {
         // 'close.zf.trigger': this.hide.bind(this)
         'close.zf.trigger': this.hide.bind(this)
       });
-
       this.$element.on('focus.zf.tooltip', function (e) {
         isFocus = true;
+
         if (_this.isClick) {
           // If we're not showing open on clicks, we need to pretend a click-launched focus isn't
           // a real focus, otherwise on hover and come back we get bad behavior
           if (!_this.options.clickOpen) {
             isFocus = false;
           }
+
           return false;
         } else {
           _this.show();
@@ -691,6 +782,7 @@ var Tooltip = function (_Positionable) {
       }).on('focusout.zf.tooltip', function (e) {
         isFocus = false;
         _this.isClick = false;
+
         _this.hide();
       }).on('resizeme.zf.trigger', function () {
         if (_this.isActive) {
@@ -698,14 +790,13 @@ var Tooltip = function (_Positionable) {
         }
       });
     }
-
     /**
      * adds a toggle method, in addition to the static show() & hide() functions
      * @function
      */
 
   }, {
-    key: 'toggle',
+    key: "toggle",
     value: function toggle() {
       if (this.isActive) {
         this.hide();
@@ -713,26 +804,25 @@ var Tooltip = function (_Positionable) {
         this.show();
       }
     }
-
     /**
      * Destroys an instance of tooltip, removes template element from the view.
      * @function
      */
 
   }, {
-    key: '_destroy',
+    key: "_destroy",
     value: function _destroy() {
-      this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass('has-tip top right left').removeAttr('aria-describedby aria-haspopup data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');
-
+      this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass(this.options.triggerClass).removeClass('top right left bottom').removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');
       this.template.remove();
     }
   }]);
 
   return Tooltip;
-}(__WEBPACK_IMPORTED_MODULE_4__foundation_positionable__["a" /* Positionable */]);
+}(_foundation_positionable__WEBPACK_IMPORTED_MODULE_4__["Positionable"]);
 
 Tooltip.defaults = {
   disableForTouch: false,
+
   /**
    * Time, in ms, before a tooltip should open on hover.
    * @option
@@ -740,6 +830,7 @@ Tooltip.defaults = {
    * @default 200
    */
   hoverDelay: 200,
+
   /**
    * Time, in ms, a tooltip should take to fade into view.
    * @option
@@ -747,6 +838,7 @@ Tooltip.defaults = {
    * @default 150
    */
   fadeInDuration: 150,
+
   /**
    * Time, in ms, a tooltip should take to fade out of view.
    * @option
@@ -754,6 +846,7 @@ Tooltip.defaults = {
    * @default 150
    */
   fadeOutDuration: 150,
+
   /**
    * Disables hover events from opening the tooltip if set to true
    * @option
@@ -761,6 +854,7 @@ Tooltip.defaults = {
    * @default false
    */
   disableHover: false,
+
   /**
    * Optional addtional classes to apply to the tooltip template on init.
    * @option
@@ -768,6 +862,7 @@ Tooltip.defaults = {
    * @default ''
    */
   templateClasses: '',
+
   /**
    * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.
    * @option
@@ -775,6 +870,7 @@ Tooltip.defaults = {
    * @default 'tooltip'
    */
   tooltipClass: 'tooltip',
+
   /**
    * Class applied to the tooltip anchor element.
    * @option
@@ -782,6 +878,7 @@ Tooltip.defaults = {
    * @default 'has-tip'
    */
   triggerClass: 'has-tip',
+
   /**
    * Minimum breakpoint size at which to open the tooltip.
    * @option
@@ -789,6 +886,7 @@ Tooltip.defaults = {
    * @default 'small'
    */
   showOn: 'small',
+
   /**
    * Custom template to be used to generate markup for tooltip.
    * @option
@@ -796,6 +894,7 @@ Tooltip.defaults = {
    * @default ''
    */
   template: '',
+
   /**
    * Text displayed in the tooltip template on open.
    * @option
@@ -804,6 +903,7 @@ Tooltip.defaults = {
    */
   tipText: '',
   touchCloseText: 'Tap to close.',
+
   /**
    * Allows the tooltip to remain open if triggered with a click or touch event.
    * @option
@@ -811,13 +911,7 @@ Tooltip.defaults = {
    * @default true
    */
   clickOpen: true,
-  /**
-   * DEPRECATED Additional positioning classes, set by the JS
-   * @option
-   * @type {string}
-   * @default ''
-   */
-  positionClass: '',
+
   /**
    * Position of tooltip. Can be left, right, bottom, top, or auto.
    * @option
@@ -825,6 +919,7 @@ Tooltip.defaults = {
    * @default 'auto'
    */
   position: 'auto',
+
   /**
    * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.
    * @option
@@ -832,6 +927,7 @@ Tooltip.defaults = {
    * @default 'auto'
    */
   alignment: 'auto',
+
   /**
    * Allow overlap of container/window. If false, tooltip will first try to
    * position as defined by data-position and data-alignment, but reposition if
@@ -840,6 +936,7 @@ Tooltip.defaults = {
    * @default false
    */
   allowOverlap: false,
+
   /**
    * Allow overlap of only the bottom of the container. This is the most common
    * behavior for dropdowns, allowing the dropdown to extend the bottom of the
@@ -850,6 +947,7 @@ Tooltip.defaults = {
    * @default false
    */
   allowBottomOverlap: false,
+
   /**
    * Distance, in pixels, the template should push away from the anchor on the Y axis.
    * @option
@@ -857,6 +955,7 @@ Tooltip.defaults = {
    * @default 0
    */
   vOffset: 0,
+
   /**
    * Distance, in pixels, the template should push away from the anchor on the X axis
    * @option
@@ -864,6 +963,7 @@ Tooltip.defaults = {
    * @default 0
    */
   hOffset: 0,
+
   /**
    * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip
    * @option
@@ -871,6 +971,7 @@ Tooltip.defaults = {
    * @default 14
    */
   tooltipHeight: 14,
+
   /**
    * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip
    * @option
@@ -878,6 +979,7 @@ Tooltip.defaults = {
    * @default 12
    */
   tooltipWidth: 12,
+
   /**
   * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,
   * allowing HTML may open yourself up to XSS attacks.
@@ -887,7 +989,6 @@ Tooltip.defaults = {
   */
   allowHtml: false
 };
-
 /**
  * TODO utilize resize event trigger
  */
@@ -896,15 +997,25 @@ Tooltip.defaults = {
 
 /***/ }),
 
-/***/ 7:
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
@@ -912,17 +1023,19 @@ Tooltip.defaults = {
 
 var MutationObserver = function () {
   var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
   for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
     }
   }
+
   return false;
 }();
 
-var triggers = function (el, type) {
+var triggers = function triggers(el, type) {
   el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
   });
 };
 
@@ -933,138 +1046,142 @@ var Triggers = {
   },
   Initializers: {}
 };
-
 Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
   },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
     }
   },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
     }
   },
-  closeableListener: function (e) {
+  closeableListener: function closeableListener(e) {
     e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
     if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
       });
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
     }
   },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
-};
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
 Triggers.Initializers.addOpenListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
   $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
-
-// Elements with [data-close] will close a plugin that supports it when clicked.
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
 // If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
 Triggers.Initializers.addCloseListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
   $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 Triggers.Initializers.addToggleListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
   $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
 Triggers.Initializers.addCloseableListener = function ($elem) {
   $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
   $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
 Triggers.Initializers.addToggleFocusListener = function ($elem) {
   $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
   $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+}; // More Global/complex listeners and triggers
+
 
-// More Global/complex listeners and triggers
 Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
+  resizeListener: function resizeListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a resize event
+    } //trigger all listening elements and signal a resize event
+
+
     $nodes.attr('data-events', "resize");
   },
-  scrollListener: function ($nodes) {
+  scrollListener: function scrollListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a scroll event
+    } //trigger all listening elements and signal a scroll event
+
+
     $nodes.attr('data-events', "scroll");
   },
-  closeMeListener: function (e, pluginId) {
+  closeMeListener: function closeMeListener(e, pluginId) {
     var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
-
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
     plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+
       _this.triggerHandler('close.zf.trigger', [_this]);
     });
-  }
+  } // Global, parses whole document.
+
+};
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
       plugNames = ['dropdown', 'tooltip', 'reveal'];
 
   if (pluginName) {
     if (typeof pluginName === 'string') {
       plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
     } else {
       console.error('Plugin names must be strings');
     }
   }
+
   if (yetiBoxes.length) {
     var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
+      return "closeme.zf.".concat(name);
     }).join(' ');
-
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
   }
 };
 
 function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
+  var timer,
       args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
     if (timer) {
       clearTimeout(timer);
     }
+
     timer = setTimeout(function () {
       listener.apply(null, args);
     }, debounce || 10); //default time to emit scroll event
@@ -1072,14 +1189,16 @@ function debounceGlobalListener(debounce, trigger, listener) {
 }
 
 Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
   }
 };
 
 Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
   }
@@ -1089,25 +1208,27 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
   if (!MutationObserver) {
     return false;
   }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
 
-    //trigger the event handler for the element depending on type
     switch (mutationRecordsList[0].type) {
       case "attributes":
         if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
+
         if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
+
         if (mutationRecordsList[0].attributeName === "style") {
           $target.closest("[data-mutate]").attr("data-events", "mutate");
           $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
         }
+
         break;
 
       case "childList":
@@ -1125,14 +1246,19 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
     //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
     for (var i = 0; i <= $nodes.length - 1; i++) {
       var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
   }
 };
 
 Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addOpenListener($document);
   Triggers.Initializers.addCloseListener($document);
   Triggers.Initializers.addToggleListener($document);
@@ -1141,7 +1267,7 @@ Triggers.Initializers.addSimpleListeners = function () {
 };
 
 Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addMutationEventsListener($document);
   Triggers.Initializers.addResizeListener();
   Triggers.Initializers.addScrollListener();
@@ -1149,25 +1275,17 @@ Triggers.Initializers.addGlobalListeners = function () {
 };
 
 Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
-
-    if (document.readyState === "complete") {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
       Triggers.Initializers.addSimpleListeners();
       Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
-      });
+      $.triggersInitialized = true;
     }
-
-    $.triggersInitialized = true;
-  }
+  });
 
   if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
     Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
   }
 };
@@ -1176,19 +1294,29 @@ Triggers.init = function ($, Foundation) {
 
 /***/ }),
 
-/***/ 8:
-/***/ (function(module, exports) {
+/***/ 20:
+/*!********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.tooltip.js ***!
+  \********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
 
-module.exports = {Box: window.Foundation.Box};
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.tooltip.js */"./js/entries/plugins/foundation.tooltip.js");
 
-/***/ }),
 
-/***/ 99:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ }),
 
-module.exports = __webpack_require__(33);
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
 
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.tooltip.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.tooltip.js.map b/dist/js/plugins/foundation.tooltip.js.map
new file mode 100644 (file)
index 0000000..f875c08
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.box\"],\"amd\":\"./foundation.util.box\",\"commonjs\":\"./foundation.util.box\",\"commonjs2\":\"./foundation.util.box\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.tooltip.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.positionable.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.tooltip.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","plugin","Tooltip","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","nextItem","item","array","currentIdx","indexOf","length","Positionable","triedPositions","position","options","_getDefaultPosition","alignment","_getDefaultAlignment","originalPosition","originalAlignment","Rtl","_alignmentsExhausted","_realign","_addTriedPosition","push","isExhausted","i","vOffset","hOffset","$anchor","$element","$parent","attr","$eleDims","Box","GetDimensions","$anchorDims","allowOverlap","offset","GetExplicitOffsets","_getVOffset","_getHOffset","overlaps","minOverlap","minCoordinates","_positionsExhausted","overlap","OverlapArea","allowBottomOverlap","_reposition","Plugin","defaults","element","$","extend","data","className","isActive","isClick","Triggers","init","_init","MediaQuery","elemId","GetYoDigits","tipText","template","_buildTemplate","allowHtml","appendTo","document","body","html","hide","text","addClass","triggerClass","_events","match","tooltipWidth","tooltipHeight","id","templateClasses","tooltipClass","trim","$template","showOn","is","_this","css","show","_setPosition","removeClass","trigger","stop","fadeIn","fadeInDuration","fadeOut","fadeOutDuration","isFocus","disableHover","on","e","timeout","setTimeout","hoverDelay","ignoreMousedisappear","clearTimeout","clickOpen","stopImmediatePropagation","disableForTouch","bind","off","removeAttr","remove","touchCloseText","MutationObserver","prefixes","window","triggers","el","type","split","forEach","Listeners","Basic","Global","Initializers","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","Motion","animateOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","scrollListener","closeMeListener","pluginId","namespace","plugins","not","addClosemeListener","pluginName","yetiBoxes","plugNames","concat","console","error","listeners","map","name","join","debounceGlobalListener","debounce","listener","timer","args","Array","prototype","slice","call","arguments","apply","addResizeListener","addScrollListener","addMutationEventsListener","find","listeningElementsMutation","mutationRecordsList","$target","target","attributeName","pageYOffset","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","onLoad","triggersInitialized","IHearYou"],"mappings":"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","file":"foundation.tooltip.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.box\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.tooltip\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.tooltip\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 20);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","import { Foundation } from './foundation.core';\n\nimport { Tooltip } from '../../foundation.tooltip';\nFoundation.plugin(Tooltip, 'Tooltip');\n\nexport { Foundation, Tooltip };\n","'use strict';\n\nimport { Box } from './foundation.util.box';\nimport { Plugin } from './foundation.core.plugin';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst POSITIONS = ['left', 'right', 'top', 'bottom'];\nconst VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nconst HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\n\nconst ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n}\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n  if(currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\n\nclass Positionable extends Plugin {\n  /**\n   * Abstract class encapsulating the tether-like explicit positioning logic\n   * including repositioning based on overlap.\n   * Expects classes to define defaults for vOffset, hOffset, position,\n   * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n   * extending the defaults, or (for now recommended due to the way docs are\n   * generated) by explicitly declaring them.\n   *\n   **/\n\n  _init() {\n    this.triedPositions = {};\n    this.position  = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n    this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n    this.originalPosition = this.position;\n    this.originalAlignment = this.alignment;\n  }\n\n  _getDefaultPosition () {\n    return 'bottom';\n  }\n\n  _getDefaultAlignment() {\n    switch(this.position) {\n      case 'bottom':\n      case 'top':\n        return Rtl() ? 'right' : 'left';\n      case 'left':\n      case 'right':\n        return 'bottom';\n    }\n  }\n\n  /**\n   * Adjusts the positionable possible positions by iterating through alignments\n   * and positions.\n   * @function\n   * @private\n   */\n  _reposition() {\n    if(this._alignmentsExhausted(this.position)) {\n      this.position = nextItem(this.position, POSITIONS);\n      this.alignment = ALIGNMENTS[this.position][0];\n    } else {\n      this._realign();\n    }\n  }\n\n  /**\n   * Adjusts the dropdown pane possible positions by iterating through alignments\n   * on the current position.\n   * @function\n   * @private\n   */\n  _realign() {\n    this._addTriedPosition(this.position, this.alignment)\n    this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position])\n  }\n\n  _addTriedPosition(position, alignment) {\n    this.triedPositions[position] = this.triedPositions[position] || []\n    this.triedPositions[position].push(alignment);\n  }\n\n  _positionsExhausted() {\n    var isExhausted = true;\n    for(var i = 0; i < POSITIONS.length; i++) {\n      isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n    }\n    return isExhausted;\n  }\n\n  _alignmentsExhausted(position) {\n    return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n  }\n\n\n  // When we're trying to center, we don't want to apply offset that's going to\n  // take us just off center, so wrap around to return 0 for the appropriate\n  // offset in those alignments.  TODO: Figure out if we want to make this\n  // configurable behavior... it feels more intuitive, especially for tooltips, but\n  // it's possible someone might actually want to start from center and then nudge\n  // slightly off.\n  _getVOffset() {\n    return this.options.vOffset;\n  }\n\n  _getHOffset() {\n    return this.options.hOffset;\n  }\n\n\n  _setPosition($anchor, $element, $parent) {\n    if($anchor.attr('aria-expanded') === 'false'){ return false; }\n    var $eleDims = Box.GetDimensions($element),\n        $anchorDims = Box.GetDimensions($anchor);\n\n\n    if (!this.options.allowOverlap) {\n      // restore original position & alignment before checking overlap\n      this.position = this.originalPosition;\n      this.alignment = this.originalAlignment;\n    }\n\n    $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n    if(!this.options.allowOverlap) {\n      var overlaps = {};\n      var minOverlap = 100000000;\n      // default coordinates to how we start, in case we can't figure out better\n      var minCoordinates = {position: this.position, alignment: this.alignment};\n      while(!this._positionsExhausted()) {\n        let overlap = Box.OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n        if(overlap === 0) {\n          return;\n        }\n\n        if(overlap < minOverlap) {\n          minOverlap = overlap;\n          minCoordinates = {position: this.position, alignment: this.alignment};\n        }\n\n        this._reposition();\n\n        $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n      // If we get through the entire loop, there was no non-overlapping\n      // position available. Pick the version with least overlap.\n      this.position = minCoordinates.position;\n      this.alignment = minCoordinates.alignment;\n      $element.offset(Box.GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n    }\n  }\n\n}\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n}\n\nexport {Positionable};\n","'use strict';\n\nimport $ from 'jquery';\n\nimport { GetYoDigits, ignoreMousedisappear } from './foundation.core.utils';\nimport { MediaQuery } from './foundation.util.mediaQuery';\nimport { Triggers } from './foundation.util.triggers';\nimport { Positionable } from './foundation.positionable';\n\n/**\n * Tooltip module.\n * @module foundation.tooltip\n * @requires foundation.util.box\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nclass Tooltip extends Positionable {\n  /**\n   * Creates a new instance of a Tooltip.\n   * @class\n   * @name Tooltip\n   * @fires Tooltip#init\n   * @param {jQuery} element - jQuery object to attach a tooltip to.\n   * @param {Object} options - object to extend the default configuration.\n   */\n  _setup(element, options) {\n    this.$element = element;\n    this.options = $.extend({}, Tooltip.defaults, this.$element.data(), options);\n    this.className = 'Tooltip'; // ie9 back compat\n\n    this.isActive = false;\n    this.isClick = false;\n\n    // Triggers init is idempotent, just need to make sure it is initialized\n    Triggers.init($);\n\n    this._init();\n  }\n\n  /**\n   * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.\n   * @private\n   */\n  _init() {\n    MediaQuery._init();\n    var elemId = this.$element.attr('aria-describedby') || GetYoDigits(6, 'tooltip');\n\n    this.options.tipText = this.options.tipText || this.$element.attr('title');\n    this.template = this.options.template ? $(this.options.template) : this._buildTemplate(elemId);\n\n    if (this.options.allowHtml) {\n      this.template.appendTo(document.body)\n        .html(this.options.tipText)\n        .hide();\n    } else {\n      this.template.appendTo(document.body)\n        .text(this.options.tipText)\n        .hide();\n    }\n\n    this.$element.attr({\n      'title': '',\n      'aria-describedby': elemId,\n      'data-yeti-box': elemId,\n      'data-toggle': elemId,\n      'data-resize': elemId\n    }).addClass(this.options.triggerClass);\n\n    super._init();\n    this._events();\n  }\n\n  _getDefaultPosition() {\n    // handle legacy classnames\n    var position = this.$element[0].className.match(/\\b(top|left|right|bottom)\\b/g);\n    return position ? position[0] : 'top';\n  }\n\n  _getDefaultAlignment() {\n    return 'center';\n  }\n\n  _getHOffset() {\n    if(this.position === 'left' || this.position === 'right') {\n      return this.options.hOffset + this.options.tooltipWidth;\n    } else {\n      return this.options.hOffset\n    }\n  }\n\n  _getVOffset() {\n    if(this.position === 'top' || this.position === 'bottom') {\n      return this.options.vOffset + this.options.tooltipHeight;\n    } else {\n      return this.options.vOffset\n    }\n  }\n\n  /**\n   * builds the tooltip element, adds attributes, and returns the template.\n   * @private\n   */\n  _buildTemplate(id) {\n    var templateClasses = (`${this.options.tooltipClass} ${this.options.templateClasses}`).trim();\n    var $template =  $('<div></div>').addClass(templateClasses).attr({\n      'role': 'tooltip',\n      'aria-hidden': true,\n      'data-is-active': false,\n      'data-is-focus': false,\n      'id': id\n    });\n    return $template;\n  }\n\n  /**\n   * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.\n   * if the tooltip is larger than the screen width, default to full width - any user selected margin\n   * @private\n   */\n  _setPosition() {\n    super._setPosition(this.$element, this.template);\n  }\n\n  /**\n   * reveals the tooltip, and fires an event to close any other open tooltips on the page\n   * @fires Tooltip#closeme\n   * @fires Tooltip#show\n   * @function\n   */\n  show() {\n    if (this.options.showOn !== 'all' && !MediaQuery.is(this.options.showOn)) {\n      // console.error('The screen is too small to display this tooltip');\n      return false;\n    }\n\n    var _this = this;\n    this.template.css('visibility', 'hidden').show();\n    this._setPosition();\n    this.template.removeClass('top bottom left right').addClass(this.position)\n    this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);\n\n    /**\n     * Fires to close all other open tooltips on the page\n     * @event Closeme#tooltip\n     */\n    this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));\n\n\n    this.template.attr({\n      'data-is-active': true,\n      'aria-hidden': false\n    });\n    _this.isActive = true;\n    // console.log(this.template);\n    this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function() {\n      //maybe do stuff?\n    });\n    /**\n     * Fires when the tooltip is shown\n     * @event Tooltip#show\n     */\n    this.$element.trigger('show.zf.tooltip');\n  }\n\n  /**\n   * Hides the current tooltip, and resets the positioning class if it was changed due to collision\n   * @fires Tooltip#hide\n   * @function\n   */\n  hide() {\n    // console.log('hiding', this.$element.data('yeti-box'));\n    var _this = this;\n    this.template.stop().attr({\n      'aria-hidden': true,\n      'data-is-active': false\n    }).fadeOut(this.options.fadeOutDuration, function() {\n      _this.isActive = false;\n      _this.isClick = false;\n    });\n    /**\n     * fires when the tooltip is hidden\n     * @event Tooltip#hide\n     */\n    this.$element.trigger('hide.zf.tooltip');\n  }\n\n  /**\n   * adds event listeners for the tooltip and its anchor\n   * TODO combine some of the listeners like focus and mouseenter, etc.\n   * @private\n   */\n  _events() {\n    var _this = this;\n    var $template = this.template;\n    var isFocus = false;\n\n    if (!this.options.disableHover) {\n\n      this.$element\n      .on('mouseenter.zf.tooltip', function(e) {\n        if (!_this.isActive) {\n          _this.timeout = setTimeout(function() {\n            _this.show();\n          }, _this.options.hoverDelay);\n        }\n      })\n      .on('mouseleave.zf.tooltip', ignoreMousedisappear(function(e) {\n        clearTimeout(_this.timeout);\n        if (!isFocus || (_this.isClick && !_this.options.clickOpen)) {\n          _this.hide();\n        }\n      }));\n    }\n\n    if (this.options.clickOpen) {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        if (_this.isClick) {\n          //_this.hide();\n          // _this.isClick = false;\n        } else {\n          _this.isClick = true;\n          if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {\n            _this.show();\n          }\n        }\n      });\n    } else {\n      this.$element.on('mousedown.zf.tooltip', function(e) {\n        e.stopImmediatePropagation();\n        _this.isClick = true;\n      });\n    }\n\n    if (!this.options.disableForTouch) {\n      this.$element\n      .on('tap.zf.tooltip touchend.zf.tooltip', function(e) {\n        _this.isActive ? _this.hide() : _this.show();\n      });\n    }\n\n    this.$element.on({\n      // 'toggle.zf.trigger': this.toggle.bind(this),\n      // 'close.zf.trigger': this.hide.bind(this)\n      'close.zf.trigger': this.hide.bind(this)\n    });\n\n    this.$element\n      .on('focus.zf.tooltip', function(e) {\n        isFocus = true;\n        if (_this.isClick) {\n          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't\n          // a real focus, otherwise on hover and come back we get bad behavior\n          if(!_this.options.clickOpen) { isFocus = false; }\n          return false;\n        } else {\n          _this.show();\n        }\n      })\n\n      .on('focusout.zf.tooltip', function(e) {\n        isFocus = false;\n        _this.isClick = false;\n        _this.hide();\n      })\n\n      .on('resizeme.zf.trigger', function() {\n        if (_this.isActive) {\n          _this._setPosition();\n        }\n      });\n  }\n\n  /**\n   * adds a toggle method, in addition to the static show() & hide() functions\n   * @function\n   */\n  toggle() {\n    if (this.isActive) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n\n  /**\n   * Destroys an instance of tooltip, removes template element from the view.\n   * @function\n   */\n  _destroy() {\n    this.$element.attr('title', this.template.text())\n                 .off('.zf.trigger .zf.tooltip')\n                 .removeClass(this.options.triggerClass)\n                 .removeClass('top right left bottom')\n                 .removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n\n    this.template.remove();\n  }\n}\n\nTooltip.defaults = {\n  disableForTouch: false,\n  /**\n   * Time, in ms, before a tooltip should open on hover.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  hoverDelay: 200,\n  /**\n   * Time, in ms, a tooltip should take to fade into view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeInDuration: 150,\n  /**\n   * Time, in ms, a tooltip should take to fade out of view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeOutDuration: 150,\n  /**\n   * Disables hover events from opening the tooltip if set to true\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n  /**\n   * Optional addtional classes to apply to the tooltip template on init.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  templateClasses: '',\n  /**\n   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.\n   * @option\n   * @type {string}\n   * @default 'tooltip'\n   */\n  tooltipClass: 'tooltip',\n  /**\n   * Class applied to the tooltip anchor element.\n   * @option\n   * @type {string}\n   * @default 'has-tip'\n   */\n  triggerClass: 'has-tip',\n  /**\n   * Minimum breakpoint size at which to open the tooltip.\n   * @option\n   * @type {string}\n   * @default 'small'\n   */\n  showOn: 'small',\n  /**\n   * Custom template to be used to generate markup for tooltip.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  template: '',\n  /**\n   * Text displayed in the tooltip template on open.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  tipText: '',\n  touchCloseText: 'Tap to close.',\n  /**\n   * Allows the tooltip to remain open if triggered with a click or touch event.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickOpen: true,\n  /**\n   * Position of tooltip. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n  /**\n   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n  /**\n   * Allow overlap of container/window. If false, tooltip will first try to\n   * position as defined by data-position and data-alignment, but reposition if\n   * it would cause an overflow.  @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * Less common for tooltips.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowBottomOverlap: false,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the Y axis.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the X axis\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip\n   * @option\n   * @type {number}\n   * @default 14\n   */\n  tooltipHeight: 14,\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip\n   * @option\n   * @type {number}\n   * @default 12\n   */\n  tooltipWidth: 12,\n    /**\n   * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,\n   * allowing HTML may open yourself up to XSS attacks.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowHtml: false\n};\n\n/**\n * TODO utilize resize event trigger\n */\n\nexport {Tooltip};\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 4a66b968f2c439a7f0b1eed91a096782a973b62a..8ac86ffcbfae4a34322c4b89a86eed9cd15797ea 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(o){if(i[o])return i[o].exports;var n=i[o]={i:o,l:!1,exports:{}};return t[o].call(n.exports,n,n.exports,e),n.l=!0,n.exports}var i={};e.m=t,e.c=i,e.i=function(t){return t},e.d=function(t,i,o){e.o(t,i)||Object.defineProperty(t,i,{configurable:!1,enumerable:!0,get:o})},e.n=function(t){var i=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(i,"a",i),i},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=99)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},11:function(t,e,i){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function n(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function s(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}function r(t,e){var i=e.indexOf(t);return i===e.length-1?e[0]:e[i+1]}i.d(e,"a",function(){return g});var a=i(8),l=(i.n(a),i(2)),u=(i.n(l),i(3)),f=(i.n(u),function(){function t(t,e){for(var i=0;i<e.length;i++){var o=e[i];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}return function(e,i,o){return i&&t(e.prototype,i),o&&t(e,o),e}}()),c=["left","right","top","bottom"],p=["top","bottom","center"],d=["left","right","center"],h={left:p,right:p,top:d,bottom:d},g=function(t){function e(){return o(this,e),n(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return s(e,t),f(e,[{key:"_init",value:function(){this.triedPositions={},this.position="auto"===this.options.position?this._getDefaultPosition():this.options.position,this.alignment="auto"===this.options.alignment?this._getDefaultAlignment():this.options.alignment}},{key:"_getDefaultPosition",value:function(){return"bottom"}},{key:"_getDefaultAlignment",value:function(){switch(this.position){case"bottom":case"top":return i.i(u.rtl)()?"right":"left";case"left":case"right":return"bottom"}}},{key:"_reposition",value:function(){this._alignmentsExhausted(this.position)?(this.position=r(this.position,c),this.alignment=h[this.position][0]):this._realign()}},{key:"_realign",value:function(){this._addTriedPosition(this.position,this.alignment),this.alignment=r(this.alignment,h[this.position])}},{key:"_addTriedPosition",value:function(t,e){this.triedPositions[t]=this.triedPositions[t]||[],this.triedPositions[t].push(e)}},{key:"_positionsExhausted",value:function(){for(var t=!0,e=0;e<c.length;e++)t=t&&this._alignmentsExhausted(c[e]);return t}},{key:"_alignmentsExhausted",value:function(t){return this.triedPositions[t]&&this.triedPositions[t].length==h[t].length}},{key:"_getVOffset",value:function(){return this.options.vOffset}},{key:"_getHOffset",value:function(){return this.options.hOffset}},{key:"_setPosition",value:function(t,e,i){if("false"===t.attr("aria-expanded"))return!1;a.Box.GetDimensions(e),a.Box.GetDimensions(t);if(e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset())),!this.options.allowOverlap){for(var o=1e8,n={position:this.position,alignment:this.alignment};!this._positionsExhausted();){var s=a.Box.OverlapArea(e,i,!1,!1,this.options.allowBottomOverlap);if(0===s)return;s<o&&(o=s,n={position:this.position,alignment:this.alignment}),this._reposition(),e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}this.position=n.position,this.alignment=n.alignment,e.offset(a.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}}}]),e}(l.Plugin);g.defaults={position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,vOffset:0,hOffset:0}},2:function(t,e){t.exports={Plugin:window.Foundation.Plugin}},3:function(t,e){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},33:function(t,e,i){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var o=i(1),n=(i.n(o),i(63));o.Foundation.plugin(n.a,"Tooltip")},4:function(t,e){t.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},6:function(t,e){t.exports={MediaQuery:window.Foundation.MediaQuery}},63:function(t,e,i){"use strict";function o(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}function n(t,e){if(!t)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return!e||"object"!=typeof e&&"function"!=typeof e?t:e}function s(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function, not "+typeof e);t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,enumerable:!1,writable:!0,configurable:!0}}),e&&(Object.setPrototypeOf?Object.setPrototypeOf(t,e):t.__proto__=e)}i.d(e,"a",function(){return h});var r=i(0),a=i.n(r),l=i(3),u=(i.n(l),i(6)),f=(i.n(u),i(7)),c=i(11),p=function(){function t(t,e){for(var i=0;i<e.length;i++){var o=e[i];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}return function(e,i,o){return i&&t(e.prototype,i),o&&t(e,o),e}}(),d=function t(e,i,o){null===e&&(e=Function.prototype);var n=Object.getOwnPropertyDescriptor(e,i);if(void 0===n){var s=Object.getPrototypeOf(e);return null===s?void 0:t(s,i,o)}if("value"in n)return n.value;var r=n.get;if(void 0!==r)return r.call(o)},h=function(t){function e(){return o(this,e),n(this,(e.__proto__||Object.getPrototypeOf(e)).apply(this,arguments))}return s(e,t),p(e,[{key:"_setup",value:function(t,i){this.$element=t,this.options=a.a.extend({},e.defaults,this.$element.data(),i),this.className="Tooltip",this.isActive=!1,this.isClick=!1,f.a.init(a.a),this._init()}},{key:"_init",value:function(){u.MediaQuery._init();var t=this.$element.attr("aria-describedby")||i.i(l.GetYoDigits)(6,"tooltip");this.options.tipText=this.options.tipText||this.$element.attr("title"),this.template=this.options.template?a()(this.options.template):this._buildTemplate(t),this.options.allowHtml?this.template.appendTo(document.body).html(this.options.tipText).hide():this.template.appendTo(document.body).text(this.options.tipText).hide(),this.$element.attr({title:"","aria-describedby":t,"data-yeti-box":t,"data-toggle":t,"data-resize":t}).addClass(this.options.triggerClass),d(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_init",this).call(this),this._events()}},{key:"_getDefaultPosition",value:function(){var t=this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);return t?t[0]:"top"}},{key:"_getDefaultAlignment",value:function(){return"center"}},{key:"_getHOffset",value:function(){return"left"===this.position||"right"===this.position?this.options.hOffset+this.options.tooltipWidth:this.options.hOffset}},{key:"_getVOffset",value:function(){return"top"===this.position||"bottom"===this.position?this.options.vOffset+this.options.tooltipHeight:this.options.vOffset}},{key:"_buildTemplate",value:function(t){var e=(this.options.tooltipClass+" "+this.options.positionClass+" "+this.options.templateClasses).trim();return a()("<div></div>").addClass(e).attr({role:"tooltip","aria-hidden":!0,"data-is-active":!1,"data-is-focus":!1,id:t})}},{key:"_setPosition",value:function(){d(e.prototype.__proto__||Object.getPrototypeOf(e.prototype),"_setPosition",this).call(this,this.$element,this.template)}},{key:"show",value:function(){if("all"!==this.options.showOn&&!u.MediaQuery.is(this.options.showOn))return!1;var t=this;this.template.css("visibility","hidden").show(),this._setPosition(),this.template.removeClass("top bottom left right").addClass(this.position),this.template.removeClass("align-top align-bottom align-left align-right align-center").addClass("align-"+this.alignment),this.$element.trigger("closeme.zf.tooltip",this.template.attr("id")),this.template.attr({"data-is-active":!0,"aria-hidden":!1}),t.isActive=!0,this.template.stop().hide().css("visibility","").fadeIn(this.options.fadeInDuration,function(){}),this.$element.trigger("show.zf.tooltip")}},{key:"hide",value:function(){var t=this;this.template.stop().attr({"aria-hidden":!0,"data-is-active":!1}).fadeOut(this.options.fadeOutDuration,function(){t.isActive=!1,t.isClick=!1}),this.$element.trigger("hide.zf.tooltip")}},{key:"_events",value:function(){var t=this,e=(this.template,!1);this.options.disableHover||this.$element.on("mouseenter.zf.tooltip",function(e){t.isActive||(t.timeout=setTimeout(function(){t.show()},t.options.hoverDelay))}).on("mouseleave.zf.tooltip",function(i){clearTimeout(t.timeout),(!e||t.isClick&&!t.options.clickOpen)&&t.hide()}),this.options.clickOpen?this.$element.on("mousedown.zf.tooltip",function(e){e.stopImmediatePropagation(),t.isClick||(t.isClick=!0,!t.options.disableHover&&t.$element.attr("tabindex")||t.isActive||t.show())}):this.$element.on("mousedown.zf.tooltip",function(e){e.stopImmediatePropagation(),t.isClick=!0}),this.options.disableForTouch||this.$element.on("tap.zf.tooltip touchend.zf.tooltip",function(e){t.isActive?t.hide():t.show()}),this.$element.on({"close.zf.trigger":this.hide.bind(this)}),this.$element.on("focus.zf.tooltip",function(i){if(e=!0,t.isClick)return t.options.clickOpen||(e=!1),!1;t.show()}).on("focusout.zf.tooltip",function(i){e=!1,t.isClick=!1,t.hide()}).on("resizeme.zf.trigger",function(){t.isActive&&t._setPosition()})}},{key:"toggle",value:function(){this.isActive?this.hide():this.show()}},{key:"_destroy",value:function(){this.$element.attr("title",this.template.text()).off(".zf.trigger .zf.tooltip").removeClass("has-tip top right left").removeAttr("aria-describedby aria-haspopup data-disable-hover data-resize data-toggle data-tooltip data-yeti-box"),this.template.remove()}}]),e}(c.a);h.defaults={disableForTouch:!1,hoverDelay:200,fadeInDuration:150,fadeOutDuration:150,disableHover:!1,templateClasses:"",tooltipClass:"tooltip",triggerClass:"has-tip",showOn:"small",template:"",tipText:"",touchCloseText:"Tap to close.",clickOpen:!0,positionClass:"",position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!1,vOffset:0,hOffset:0,tooltipHeight:14,tooltipWidth:12,allowHtml:!1}},7:function(t,e,i){"use strict";function o(t,e,i){var o=void 0,n=Array.prototype.slice.call(arguments,3);s()(window).off(e).on(e,function(e){o&&clearTimeout(o),o=setTimeout(function(){i.apply(null,n)},t||10)})}i.d(e,"a",function(){return u});var n=i(0),s=i.n(n),r=i(4),a=(i.n(r),function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if(t[e]+"MutationObserver"in window)return window[t[e]+"MutationObserver"];return!1}()),l=function(t,e){t.data(e).split(" ").forEach(function(i){s()("#"+i)["close"===e?"trigger":"triggerHandler"](e+".zf.trigger",[t])})},u={Listeners:{Basic:{},Global:{}},Initializers:{}};u.Listeners.Basic={openListener:function(){l(s()(this),"open")},closeListener:function(){s()(this).data("close")?l(s()(this),"close"):s()(this).trigger("close.zf.trigger")},toggleListener:function(){s()(this).data("toggle")?l(s()(this),"toggle"):s()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=s()(this).data("closable");""!==e?r.Motion.animateOut(s()(this),e,function(){s()(this).trigger("closed.zf")}):s()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=s()(this).data("toggle-focus");s()("#"+t).triggerHandler("toggle.zf.trigger",[s()(this)])}},u.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",u.Listeners.Basic.openListener)},u.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",u.Listeners.Basic.closeListener)},u.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",u.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",u.Listeners.Basic.toggleListener)},u.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",u.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",u.Listeners.Basic.closeableListener)},u.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",u.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",u.Listeners.Basic.toggleFocusListener)},u.Listeners.Global={resizeListener:function(t){a||t.each(function(){s()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){a||t.each(function(){s()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];s()("[data-"+i+"]").not('[data-yeti-box="'+e+'"]').each(function(){var t=s()(this);t.triggerHandler("close.zf.trigger",[t])})}},u.Initializers.addClosemeListener=function(t){var e=s()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"==typeof t&&"string"==typeof t[0]?i.concat(t):console.error("Plugin names must be strings")),e.length){var o=i.map(function(t){return"closeme.zf."+t}).join(" ");s()(window).off(o).on(o,u.Listeners.Global.closeMeListener)}},u.Initializers.addResizeListener=function(t){var e=s()("[data-resize]");e.length&&o(t,"resize.zf.trigger",u.Listeners.Global.resizeListener,e)},u.Initializers.addScrollListener=function(t){var e=s()("[data-scroll]");e.length&&o(t,"scroll.zf.trigger",u.Listeners.Global.scrollListener,e)},u.Initializers.addMutationEventsListener=function(t){if(!a)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=s()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var o=0;o<=e.length-1;o++){var n=new a(i);n.observe(e[o],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},u.Initializers.addSimpleListeners=function(){var t=s()(document);u.Initializers.addOpenListener(t),u.Initializers.addCloseListener(t),u.Initializers.addToggleListener(t),u.Initializers.addCloseableListener(t),u.Initializers.addToggleFocusListener(t)},u.Initializers.addGlobalListeners=function(){var t=s()(document);u.Initializers.addMutationEventsListener(t),u.Initializers.addResizeListener(),u.Initializers.addScrollListener(),u.Initializers.addClosemeListener()},u.init=function(t,e){if(void 0===t.triggersInitialized){t(document);"complete"===document.readyState?(u.Initializers.addSimpleListeners(),u.Initializers.addGlobalListeners()):t(window).on("load",function(){u.Initializers.addSimpleListeners(),u.Initializers.addGlobalListeners()}),t.triggersInitialized=!0}e&&(e.Triggers=u,e.IHearYou=u.Initializers.addGlobalListeners)}},8:function(t,e){t.exports={Box:window.Foundation.Box}},99:function(t,e,i){t.exports=i(33)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("./foundation.util.box"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.box","./foundation.util.mediaQuery","./foundation.util.motion","jquery"],e):"object"==typeof exports?exports["foundation.tooltip"]=e(require("./foundation.core"),require("./foundation.util.box"),require("./foundation.util.mediaQuery"),require("./foundation.util.motion"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.tooltip"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.__FOUNDATION_EXTERNAL__["foundation.util.box"],t.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"],t.__FOUNDATION_EXTERNAL__["foundation.util.motion"],t.jQuery))}(window,function(i,o,n,s,r){return function(i){var o={};function n(t){if(o[t])return o[t].exports;var e=o[t]={i:t,l:!1,exports:{}};return i[t].call(e.exports,e,e.exports,n),e.l=!0,e.exports}return n.m=i,n.c=o,n.d=function(t,e,i){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:i})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var i=Object.create(null);if(n.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var o in e)n.d(i,o,function(t){return e[t]}.bind(null,o));return i},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=20)}({"./foundation.core":function(t,e){t.exports=i},"./foundation.util.box":function(t,e){t.exports=o},"./foundation.util.mediaQuery":function(t,e){t.exports=n},"./foundation.util.motion":function(t,e){t.exports=s},"./js/entries/plugins/foundation.tooltip.js":function(t,e,i){"use strict";i.r(e);var o=i("./foundation.core");i.d(e,"Foundation",function(){return o.Foundation});var n=i("./js/foundation.tooltip.js");i.d(e,"Tooltip",function(){return n.Tooltip}),o.Foundation.plugin(n.Tooltip,"Tooltip")},"./js/foundation.positionable.js":function(t,e,i){"use strict";i.r(e),i.d(e,"Positionable",function(){return h});var r=i("./foundation.util.box"),s=i("./foundation.core");function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function a(t,e){for(var i=0;i<e.length;i++){var o=e[i];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}function l(t,e){return!e||"object"!==o(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function u(t){return(u=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function f(t,e){return(f=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var c=["left","right","top","bottom"],n=["top","bottom","center"],p=["left","right","center"],d={left:n,right:n,top:p,bottom:p};function g(t,e){var i=e.indexOf(t);return i===e.length-1?e[0]:e[i+1]}var h=function(t){function e(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,e),l(this,u(e).apply(this,arguments))}var i,o,n;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&f(t,e)}(e,s["Plugin"]),i=e,(o=[{key:"_init",value:function(){this.triedPositions={},this.position="auto"===this.options.position?this._getDefaultPosition():this.options.position,this.alignment="auto"===this.options.alignment?this._getDefaultAlignment():this.options.alignment,this.originalPosition=this.position,this.originalAlignment=this.alignment}},{key:"_getDefaultPosition",value:function(){return"bottom"}},{key:"_getDefaultAlignment",value:function(){switch(this.position){case"bottom":case"top":return Object(s.rtl)()?"right":"left";case"left":case"right":return"bottom"}}},{key:"_reposition",value:function(){this._alignmentsExhausted(this.position)?(this.position=g(this.position,c),this.alignment=d[this.position][0]):this._realign()}},{key:"_realign",value:function(){this._addTriedPosition(this.position,this.alignment),this.alignment=g(this.alignment,d[this.position])}},{key:"_addTriedPosition",value:function(t,e){this.triedPositions[t]=this.triedPositions[t]||[],this.triedPositions[t].push(e)}},{key:"_positionsExhausted",value:function(){for(var t=!0,e=0;e<c.length;e++)t=t&&this._alignmentsExhausted(c[e]);return t}},{key:"_alignmentsExhausted",value:function(t){return this.triedPositions[t]&&this.triedPositions[t].length==d[t].length}},{key:"_getVOffset",value:function(){return this.options.vOffset}},{key:"_getHOffset",value:function(){return this.options.hOffset}},{key:"_setPosition",value:function(t,e,i){if("false"===t.attr("aria-expanded"))return!1;r.Box.GetDimensions(e),r.Box.GetDimensions(t);if(this.options.allowOverlap||(this.position=this.originalPosition,this.alignment=this.originalAlignment),e.offset(r.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset())),!this.options.allowOverlap){for(var o=1e8,n={position:this.position,alignment:this.alignment};!this._positionsExhausted();){var s=r.Box.OverlapArea(e,i,!1,!1,this.options.allowBottomOverlap);if(0===s)return;s<o&&(o=s,n={position:this.position,alignment:this.alignment}),this._reposition(),e.offset(r.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}this.position=n.position,this.alignment=n.alignment,e.offset(r.Box.GetExplicitOffsets(e,t,this.position,this.alignment,this._getVOffset(),this._getHOffset()))}}}])&&a(i.prototype,o),n&&a(i,n),e}();h.defaults={position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!0,vOffset:0,hOffset:0}},"./js/foundation.tooltip.js":function(t,e,i){"use strict";i.r(e),i.d(e,"Tooltip",function(){return h});var o=i("jquery"),s=i.n(o),r=i("./foundation.core"),a=i("./foundation.util.mediaQuery"),l=i("./js/foundation.util.triggers.js"),u=i("./js/foundation.positionable.js");function n(t){return(n="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function f(t,e){for(var i=0;i<e.length;i++){var o=e[i];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(t,o.key,o)}}function c(t,e){return!e||"object"!==n(e)&&"function"!=typeof e?function(t){if(void 0!==t)return t;throw new ReferenceError("this hasn't been initialised - super() hasn't been called")}(t):e}function p(t,e,i){return(p="undefined"!=typeof Reflect&&Reflect.get?Reflect.get:function(t,e,i){var o=function(t,e){for(;!Object.prototype.hasOwnProperty.call(t,e)&&null!==(t=d(t)););return t}(t,e);if(o){var n=Object.getOwnPropertyDescriptor(o,e);return n.get?n.get.call(i):n.value}})(t,e,i||t)}function d(t){return(d=Object.setPrototypeOf?Object.getPrototypeOf:function(t){return t.__proto__||Object.getPrototypeOf(t)})(t)}function g(t,e){return(g=Object.setPrototypeOf||function(t,e){return t.__proto__=e,t})(t,e)}var h=function(t){function i(){return function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}(this,i),c(this,d(i).apply(this,arguments))}var e,o,n;return function(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),e&&g(t,e)}(i,u["Positionable"]),e=i,(o=[{key:"_setup",value:function(t,e){this.$element=t,this.options=s.a.extend({},i.defaults,this.$element.data(),e),this.className="Tooltip",this.isActive=!1,this.isClick=!1,l.Triggers.init(s.a),this._init()}},{key:"_init",value:function(){a.MediaQuery._init();var t=this.$element.attr("aria-describedby")||Object(r.GetYoDigits)(6,"tooltip");this.options.tipText=this.options.tipText||this.$element.attr("title"),this.template=this.options.template?s()(this.options.template):this._buildTemplate(t),this.options.allowHtml?this.template.appendTo(document.body).html(this.options.tipText).hide():this.template.appendTo(document.body).text(this.options.tipText).hide(),this.$element.attr({title:"","aria-describedby":t,"data-yeti-box":t,"data-toggle":t,"data-resize":t}).addClass(this.options.triggerClass),p(d(i.prototype),"_init",this).call(this),this._events()}},{key:"_getDefaultPosition",value:function(){var t=this.$element[0].className.match(/\b(top|left|right|bottom)\b/g);return t?t[0]:"top"}},{key:"_getDefaultAlignment",value:function(){return"center"}},{key:"_getHOffset",value:function(){return"left"===this.position||"right"===this.position?this.options.hOffset+this.options.tooltipWidth:this.options.hOffset}},{key:"_getVOffset",value:function(){return"top"===this.position||"bottom"===this.position?this.options.vOffset+this.options.tooltipHeight:this.options.vOffset}},{key:"_buildTemplate",value:function(t){var e="".concat(this.options.tooltipClass," ").concat(this.options.templateClasses).trim();return s()("<div></div>").addClass(e).attr({role:"tooltip","aria-hidden":!0,"data-is-active":!1,"data-is-focus":!1,id:t})}},{key:"_setPosition",value:function(){p(d(i.prototype),"_setPosition",this).call(this,this.$element,this.template)}},{key:"show",value:function(){if("all"!==this.options.showOn&&!a.MediaQuery.is(this.options.showOn))return!1;this.template.css("visibility","hidden").show(),this._setPosition(),this.template.removeClass("top bottom left right").addClass(this.position),this.template.removeClass("align-top align-bottom align-left align-right align-center").addClass("align-"+this.alignment),this.$element.trigger("closeme.zf.tooltip",this.template.attr("id")),this.template.attr({"data-is-active":!0,"aria-hidden":!1}),this.isActive=!0,this.template.stop().hide().css("visibility","").fadeIn(this.options.fadeInDuration,function(){}),this.$element.trigger("show.zf.tooltip")}},{key:"hide",value:function(){var t=this;this.template.stop().attr({"aria-hidden":!0,"data-is-active":!1}).fadeOut(this.options.fadeOutDuration,function(){t.isActive=!1,t.isClick=!1}),this.$element.trigger("hide.zf.tooltip")}},{key:"_events",value:function(){var e=this,i=(this.template,!1);this.options.disableHover||this.$element.on("mouseenter.zf.tooltip",function(t){e.isActive||(e.timeout=setTimeout(function(){e.show()},e.options.hoverDelay))}).on("mouseleave.zf.tooltip",Object(r.ignoreMousedisappear)(function(t){clearTimeout(e.timeout),(!i||e.isClick&&!e.options.clickOpen)&&e.hide()})),this.options.clickOpen?this.$element.on("mousedown.zf.tooltip",function(t){t.stopImmediatePropagation(),e.isClick||(e.isClick=!0,!e.options.disableHover&&e.$element.attr("tabindex")||e.isActive||e.show())}):this.$element.on("mousedown.zf.tooltip",function(t){t.stopImmediatePropagation(),e.isClick=!0}),this.options.disableForTouch||this.$element.on("tap.zf.tooltip touchend.zf.tooltip",function(t){e.isActive?e.hide():e.show()}),this.$element.on({"close.zf.trigger":this.hide.bind(this)}),this.$element.on("focus.zf.tooltip",function(t){if(i=!0,e.isClick)return e.options.clickOpen||(i=!1),!1;e.show()}).on("focusout.zf.tooltip",function(t){i=!1,e.isClick=!1,e.hide()}).on("resizeme.zf.trigger",function(){e.isActive&&e._setPosition()})}},{key:"toggle",value:function(){this.isActive?this.hide():this.show()}},{key:"_destroy",value:function(){this.$element.attr("title",this.template.text()).off(".zf.trigger .zf.tooltip").removeClass(this.options.triggerClass).removeClass("top right left bottom").removeAttr("aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box"),this.template.remove()}}])&&f(e.prototype,o),n&&f(e,n),i}();h.defaults={disableForTouch:!1,hoverDelay:200,fadeInDuration:150,fadeOutDuration:150,disableHover:!1,templateClasses:"",tooltipClass:"tooltip",triggerClass:"has-tip",showOn:"small",template:"",tipText:"",touchCloseText:"Tap to close.",clickOpen:!0,position:"auto",alignment:"auto",allowOverlap:!1,allowBottomOverlap:!1,vOffset:0,hOffset:0,tooltipHeight:14,tooltipWidth:12,allowHtml:!1}},"./js/foundation.util.triggers.js":function(t,e,i){"use strict";i.r(e),i.d(e,"Triggers",function(){return f});var o=i("jquery"),s=i.n(o),n=i("./foundation.core"),r=i("./foundation.util.motion");function a(t){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}var l=function(){for(var t=["WebKit","Moz","O","Ms",""],e=0;e<t.length;e++)if("".concat(t[e],"MutationObserver")in window)return window["".concat(t[e],"MutationObserver")];return!1}(),u=function(e,i){e.data(i).split(" ").forEach(function(t){s()("#".concat(t))["close"===i?"trigger":"triggerHandler"]("".concat(i,".zf.trigger"),[e])})},f={Listeners:{Basic:{},Global:{}},Initializers:{}};function c(e,t,i){var o,n=Array.prototype.slice.call(arguments,3);s()(window).off(t).on(t,function(t){o&&clearTimeout(o),o=setTimeout(function(){i.apply(null,n)},e||10)})}f.Listeners.Basic={openListener:function(){u(s()(this),"open")},closeListener:function(){s()(this).data("close")?u(s()(this),"close"):s()(this).trigger("close.zf.trigger")},toggleListener:function(){s()(this).data("toggle")?u(s()(this),"toggle"):s()(this).trigger("toggle.zf.trigger")},closeableListener:function(t){t.stopPropagation();var e=s()(this).data("closable");""!==e?r.Motion.animateOut(s()(this),e,function(){s()(this).trigger("closed.zf")}):s()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var t=s()(this).data("toggle-focus");s()("#".concat(t)).triggerHandler("toggle.zf.trigger",[s()(this)])}},f.Initializers.addOpenListener=function(t){t.off("click.zf.trigger",f.Listeners.Basic.openListener),t.on("click.zf.trigger","[data-open]",f.Listeners.Basic.openListener)},f.Initializers.addCloseListener=function(t){t.off("click.zf.trigger",f.Listeners.Basic.closeListener),t.on("click.zf.trigger","[data-close]",f.Listeners.Basic.closeListener)},f.Initializers.addToggleListener=function(t){t.off("click.zf.trigger",f.Listeners.Basic.toggleListener),t.on("click.zf.trigger","[data-toggle]",f.Listeners.Basic.toggleListener)},f.Initializers.addCloseableListener=function(t){t.off("close.zf.trigger",f.Listeners.Basic.closeableListener),t.on("close.zf.trigger","[data-closeable], [data-closable]",f.Listeners.Basic.closeableListener)},f.Initializers.addToggleFocusListener=function(t){t.off("focus.zf.trigger blur.zf.trigger",f.Listeners.Basic.toggleFocusListener),t.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",f.Listeners.Basic.toggleFocusListener)},f.Listeners.Global={resizeListener:function(t){l||t.each(function(){s()(this).triggerHandler("resizeme.zf.trigger")}),t.attr("data-events","resize")},scrollListener:function(t){l||t.each(function(){s()(this).triggerHandler("scrollme.zf.trigger")}),t.attr("data-events","scroll")},closeMeListener:function(t,e){var i=t.namespace.split(".")[0];s()("[data-".concat(i,"]")).not('[data-yeti-box="'.concat(e,'"]')).each(function(){var t=s()(this);t.triggerHandler("close.zf.trigger",[t])})}},f.Initializers.addClosemeListener=function(t){var e=s()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(t&&("string"==typeof t?i.push(t):"object"===a(t)&&"string"==typeof t[0]?i=i.concat(t):console.error("Plugin names must be strings")),e.length){var o=i.map(function(t){return"closeme.zf.".concat(t)}).join(" ");s()(window).off(o).on(o,f.Listeners.Global.closeMeListener)}},f.Initializers.addResizeListener=function(t){var e=s()("[data-resize]");e.length&&c(t,"resize.zf.trigger",f.Listeners.Global.resizeListener,e)},f.Initializers.addScrollListener=function(t){var e=s()("[data-scroll]");e.length&&c(t,"scroll.zf.trigger",f.Listeners.Global.scrollListener,e)},f.Initializers.addMutationEventsListener=function(t){if(!l)return!1;var e=t.find("[data-resize], [data-scroll], [data-mutate]"),i=function(t){var e=s()(t[0].target);switch(t[0].type){case"attributes":"scroll"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("scrollme.zf.trigger",[e,window.pageYOffset]),"resize"===e.attr("data-events")&&"data-events"===t[0].attributeName&&e.triggerHandler("resizeme.zf.trigger",[e]),"style"===t[0].attributeName&&(e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]));break;case"childList":e.closest("[data-mutate]").attr("data-events","mutate"),e.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[e.closest("[data-mutate]")]);break;default:return!1}};if(e.length)for(var o=0;o<=e.length-1;o++){new l(i).observe(e[o],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},f.Initializers.addSimpleListeners=function(){var t=s()(document);f.Initializers.addOpenListener(t),f.Initializers.addCloseListener(t),f.Initializers.addToggleListener(t),f.Initializers.addCloseableListener(t),f.Initializers.addToggleFocusListener(t)},f.Initializers.addGlobalListeners=function(){var t=s()(document);f.Initializers.addMutationEventsListener(t),f.Initializers.addResizeListener(),f.Initializers.addScrollListener(),f.Initializers.addClosemeListener()},f.init=function(t,e){Object(n.onLoad)(t(window),function(){!0!==t.triggersInitialized&&(f.Initializers.addSimpleListeners(),f.Initializers.addGlobalListeners(),t.triggersInitialized=!0)}),e&&(e.Triggers=f,e.IHearYou=f.Initializers.addGlobalListeners)}},20:function(t,e,i){t.exports=i("./js/entries/plugins/foundation.tooltip.js")},jquery:function(t,e){t.exports=r}})});
+//# sourceMappingURL=foundation.tooltip.min.js.map
diff --git a/dist/js/plugins/foundation.tooltip.min.js.map b/dist/js/plugins/foundation.tooltip.min.js.map
new file mode 100644 (file)
index 0000000..859772e
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.tooltip.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_box__","__WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.box","./foundation.util.mediaQuery","./foundation.util.motion","./js/entries/plugins/foundation.tooltip.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_tooltip__WEBPACK_IMPORTED_MODULE_1__","plugin","./js/foundation.positionable.js","Positionable","_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__","_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__","_typeof","obj","iterator","constructor","_defineProperties","target","props","length","descriptor","configurable","writable","_possibleConstructorReturn","self","ReferenceError","_assertThisInitialized","_getPrototypeOf","setPrototypeOf","getPrototypeOf","__proto__","_setPrototypeOf","POSITIONS","VERTICAL_ALIGNMENTS","HORIZONTAL_ALIGNMENTS","ALIGNMENTS","left","right","top","bottom","nextItem","item","array","currentIdx","indexOf","_Plugin","instance","Constructor","TypeError","_classCallCheck","this","apply","arguments","protoProps","staticProps","subClass","superClass","_inherits","triedPositions","position","options","_getDefaultPosition","alignment","_getDefaultAlignment","originalPosition","originalAlignment","_alignmentsExhausted","_realign","_addTriedPosition","push","isExhausted","vOffset","hOffset","$anchor","$element","$parent","attr","GetDimensions","allowOverlap","offset","GetExplicitOffsets","_getVOffset","_getHOffset","minOverlap","minCoordinates","_positionsExhausted","overlap","OverlapArea","allowBottomOverlap","_reposition","defaults","./js/foundation.tooltip.js","Tooltip","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__","_foundation_positionable__WEBPACK_IMPORTED_MODULE_4__","_get","receiver","Reflect","base","_superPropBase","desc","getOwnPropertyDescriptor","_Positionable","element","a","extend","data","className","isActive","isClick","init","_init","elemId","tipText","template","_buildTemplate","allowHtml","appendTo","document","body","html","hide","text","title","aria-describedby","data-yeti-box","data-toggle","data-resize","addClass","triggerClass","_events","match","tooltipWidth","tooltipHeight","id","templateClasses","concat","tooltipClass","trim","role","aria-hidden","data-is-active","data-is-focus","showOn","is","css","show","_setPosition","removeClass","trigger","stop","fadeIn","fadeInDuration","_this","fadeOut","fadeOutDuration","isFocus","disableHover","on","e","timeout","setTimeout","hoverDelay","clearTimeout","clickOpen","stopImmediatePropagation","disableForTouch","close.zf.trigger","off","removeAttr","remove","touchCloseText","./js/foundation.util.triggers.js","Triggers","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","MutationObserver","prefixes","triggers","el","type","split","forEach","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","listener","timer","args","Array","slice","openListener","closeListener","toggleListener","closeableListener","stopPropagation","animation","animateOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","scrollListener","closeMeListener","pluginId","namespace","not","addClosemeListener","pluginName","yetiBoxes","plugNames","console","error","listeners","map","join","addResizeListener","addScrollListener","addMutationEventsListener","find","listeningElementsMutation","mutationRecordsList","$target","attributeName","pageYOffset","closest","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","addGlobalListeners","$","Foundation","triggersInitialized","IHearYou","20","jquery"],"mappings":"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","file":"foundation.tooltip.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.box\", \"./foundation.util.mediaQuery\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.tooltip\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.box\"), require(\"./foundation.util.mediaQuery\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.tooltip\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_box__, __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 20);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.box\":\n/*!********************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.box\"],\"amd\":\"./foundation.util.box\",\"commonjs\":\"./foundation.util.box\",\"commonjs2\":\"./foundation.util.box\"} ***!\n  \\********************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_box__;\n\n/***/ }),\n\n/***/ \"./foundation.util.mediaQuery\":\n/*!************************************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.mediaQuery\"],\"amd\":\"./foundation.util.mediaQuery\",\"commonjs\":\"./foundation.util.mediaQuery\",\"commonjs2\":\"./foundation.util.mediaQuery\"} ***!\n  \\************************************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_mediaQuery__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.tooltip.js\":\n/*!**************************************************!*\\\n  !*** ./js/entries/plugins/foundation.tooltip.js ***!\n  \\**************************************************/\n/*! exports provided: Foundation, Tooltip */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_tooltip__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.tooltip */ \"./js/foundation.tooltip.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Tooltip\", function() { return _foundation_tooltip__WEBPACK_IMPORTED_MODULE_1__[\"Tooltip\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].plugin(_foundation_tooltip__WEBPACK_IMPORTED_MODULE_1__[\"Tooltip\"], 'Tooltip');\n\n\n/***/ }),\n\n/***/ \"./js/foundation.positionable.js\":\n/*!***************************************!*\\\n  !*** ./js/foundation.positionable.js ***!\n  \\***************************************/\n/*! exports provided: Positionable */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Positionable\", function() { return Positionable; });\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.util.box */ \"./foundation.util.box\");\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.plugin */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\nvar POSITIONS = ['left', 'right', 'top', 'bottom'];\nvar VERTICAL_ALIGNMENTS = ['top', 'bottom', 'center'];\nvar HORIZONTAL_ALIGNMENTS = ['left', 'right', 'center'];\nvar ALIGNMENTS = {\n  'left': VERTICAL_ALIGNMENTS,\n  'right': VERTICAL_ALIGNMENTS,\n  'top': HORIZONTAL_ALIGNMENTS,\n  'bottom': HORIZONTAL_ALIGNMENTS\n};\n\nfunction nextItem(item, array) {\n  var currentIdx = array.indexOf(item);\n\n  if (currentIdx === array.length - 1) {\n    return array[0];\n  } else {\n    return array[currentIdx + 1];\n  }\n}\n\nvar Positionable =\n/*#__PURE__*/\nfunction (_Plugin) {\n  _inherits(Positionable, _Plugin);\n\n  function Positionable() {\n    _classCallCheck(this, Positionable);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Positionable).apply(this, arguments));\n  }\n\n  _createClass(Positionable, [{\n    key: \"_init\",\n\n    /**\n     * Abstract class encapsulating the tether-like explicit positioning logic\n     * including repositioning based on overlap.\n     * Expects classes to define defaults for vOffset, hOffset, position,\n     * alignment, allowOverlap, and allowBottomOverlap. They can do this by\n     * extending the defaults, or (for now recommended due to the way docs are\n     * generated) by explicitly declaring them.\n     *\n     **/\n    value: function _init() {\n      this.triedPositions = {};\n      this.position = this.options.position === 'auto' ? this._getDefaultPosition() : this.options.position;\n      this.alignment = this.options.alignment === 'auto' ? this._getDefaultAlignment() : this.options.alignment;\n      this.originalPosition = this.position;\n      this.originalAlignment = this.alignment;\n    }\n  }, {\n    key: \"_getDefaultPosition\",\n    value: function _getDefaultPosition() {\n      return 'bottom';\n    }\n  }, {\n    key: \"_getDefaultAlignment\",\n    value: function _getDefaultAlignment() {\n      switch (this.position) {\n        case 'bottom':\n        case 'top':\n          return Object(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"rtl\"])() ? 'right' : 'left';\n\n        case 'left':\n        case 'right':\n          return 'bottom';\n      }\n    }\n    /**\n     * Adjusts the positionable possible positions by iterating through alignments\n     * and positions.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_reposition\",\n    value: function _reposition() {\n      if (this._alignmentsExhausted(this.position)) {\n        this.position = nextItem(this.position, POSITIONS);\n        this.alignment = ALIGNMENTS[this.position][0];\n      } else {\n        this._realign();\n      }\n    }\n    /**\n     * Adjusts the dropdown pane possible positions by iterating through alignments\n     * on the current position.\n     * @function\n     * @private\n     */\n\n  }, {\n    key: \"_realign\",\n    value: function _realign() {\n      this._addTriedPosition(this.position, this.alignment);\n\n      this.alignment = nextItem(this.alignment, ALIGNMENTS[this.position]);\n    }\n  }, {\n    key: \"_addTriedPosition\",\n    value: function _addTriedPosition(position, alignment) {\n      this.triedPositions[position] = this.triedPositions[position] || [];\n      this.triedPositions[position].push(alignment);\n    }\n  }, {\n    key: \"_positionsExhausted\",\n    value: function _positionsExhausted() {\n      var isExhausted = true;\n\n      for (var i = 0; i < POSITIONS.length; i++) {\n        isExhausted = isExhausted && this._alignmentsExhausted(POSITIONS[i]);\n      }\n\n      return isExhausted;\n    }\n  }, {\n    key: \"_alignmentsExhausted\",\n    value: function _alignmentsExhausted(position) {\n      return this.triedPositions[position] && this.triedPositions[position].length == ALIGNMENTS[position].length;\n    } // When we're trying to center, we don't want to apply offset that's going to\n    // take us just off center, so wrap around to return 0 for the appropriate\n    // offset in those alignments.  TODO: Figure out if we want to make this\n    // configurable behavior... it feels more intuitive, especially for tooltips, but\n    // it's possible someone might actually want to start from center and then nudge\n    // slightly off.\n\n  }, {\n    key: \"_getVOffset\",\n    value: function _getVOffset() {\n      return this.options.vOffset;\n    }\n  }, {\n    key: \"_getHOffset\",\n    value: function _getHOffset() {\n      return this.options.hOffset;\n    }\n  }, {\n    key: \"_setPosition\",\n    value: function _setPosition($anchor, $element, $parent) {\n      if ($anchor.attr('aria-expanded') === 'false') {\n        return false;\n      }\n\n      var $eleDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetDimensions($element),\n          $anchorDims = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetDimensions($anchor);\n\n      if (!this.options.allowOverlap) {\n        // restore original position & alignment before checking overlap\n        this.position = this.originalPosition;\n        this.alignment = this.originalAlignment;\n      }\n\n      $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n\n      if (!this.options.allowOverlap) {\n        var overlaps = {};\n        var minOverlap = 100000000; // default coordinates to how we start, in case we can't figure out better\n\n        var minCoordinates = {\n          position: this.position,\n          alignment: this.alignment\n        };\n\n        while (!this._positionsExhausted()) {\n          var overlap = _foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].OverlapArea($element, $parent, false, false, this.options.allowBottomOverlap);\n\n          if (overlap === 0) {\n            return;\n          }\n\n          if (overlap < minOverlap) {\n            minOverlap = overlap;\n            minCoordinates = {\n              position: this.position,\n              alignment: this.alignment\n            };\n          }\n\n          this._reposition();\n\n          $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n        } // If we get through the entire loop, there was no non-overlapping\n        // position available. Pick the version with least overlap.\n\n\n        this.position = minCoordinates.position;\n        this.alignment = minCoordinates.alignment;\n        $element.offset(_foundation_util_box__WEBPACK_IMPORTED_MODULE_0__[\"Box\"].GetExplicitOffsets($element, $anchor, this.position, this.alignment, this._getVOffset(), this._getHOffset()));\n      }\n    }\n  }]);\n\n  return Positionable;\n}(_foundation_core_plugin__WEBPACK_IMPORTED_MODULE_1__[\"Plugin\"]);\n\nPositionable.defaults = {\n  /**\n   * Position of positionable relative to anchor. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n\n  /**\n   * Alignment of positionable relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow overlap of container/window. If false, dropdown positionable first\n   * try to position as defined by data-position and data-alignment, but\n   * reposition if it would cause an overflow.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  allowBottomOverlap: true,\n\n  /**\n   * Number of pixels the positionable should be separated vertically from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n\n  /**\n   * Number of pixels the positionable should be separated horizontally from anchor\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0\n};\n\n\n/***/ }),\n\n/***/ \"./js/foundation.tooltip.js\":\n/*!**********************************!*\\\n  !*** ./js/foundation.tooltip.js ***!\n  \\**********************************/\n/*! exports provided: Tooltip */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Tooltip\", function() { return Tooltip; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.mediaQuery */ \"./foundation.util.mediaQuery\");\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n/* harmony import */ var _foundation_positionable__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./foundation.positionable */ \"./js/foundation.positionable.js\");\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\nfunction _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === \"object\" || typeof call === \"function\")) { return call; } return _assertThisInitialized(self); }\n\nfunction _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError(\"this hasn't been initialised - super() hasn't been called\"); } return self; }\n\nfunction _get(target, property, receiver) { if (typeof Reflect !== \"undefined\" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); }\n\nfunction _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; }\n\nfunction _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }\n\nfunction _inherits(subClass, superClass) { if (typeof superClass !== \"function\" && superClass !== null) { throw new TypeError(\"Super expression must either be null or a function\"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); }\n\nfunction _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }\n\n\n\n\n\n\n/**\n * Tooltip module.\n * @module foundation.tooltip\n * @requires foundation.util.box\n * @requires foundation.util.mediaQuery\n * @requires foundation.util.triggers\n */\n\nvar Tooltip =\n/*#__PURE__*/\nfunction (_Positionable) {\n  _inherits(Tooltip, _Positionable);\n\n  function Tooltip() {\n    _classCallCheck(this, Tooltip);\n\n    return _possibleConstructorReturn(this, _getPrototypeOf(Tooltip).apply(this, arguments));\n  }\n\n  _createClass(Tooltip, [{\n    key: \"_setup\",\n\n    /**\n     * Creates a new instance of a Tooltip.\n     * @class\n     * @name Tooltip\n     * @fires Tooltip#init\n     * @param {jQuery} element - jQuery object to attach a tooltip to.\n     * @param {Object} options - object to extend the default configuration.\n     */\n    value: function _setup(element, options) {\n      this.$element = element;\n      this.options = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, Tooltip.defaults, this.$element.data(), options);\n      this.className = 'Tooltip'; // ie9 back compat\n\n      this.isActive = false;\n      this.isClick = false; // Triggers init is idempotent, just need to make sure it is initialized\n\n      _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_3__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\n\n      this._init();\n    }\n    /**\n     * Initializes the tooltip by setting the creating the tip element, adding it's text, setting private variables and setting attributes on the anchor.\n     * @private\n     */\n\n  }, {\n    key: \"_init\",\n    value: function _init() {\n      _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"]._init();\n\n      var elemId = this.$element.attr('aria-describedby') || Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"GetYoDigits\"])(6, 'tooltip');\n      this.options.tipText = this.options.tipText || this.$element.attr('title');\n      this.template = this.options.template ? jquery__WEBPACK_IMPORTED_MODULE_0___default()(this.options.template) : this._buildTemplate(elemId);\n\n      if (this.options.allowHtml) {\n        this.template.appendTo(document.body).html(this.options.tipText).hide();\n      } else {\n        this.template.appendTo(document.body).text(this.options.tipText).hide();\n      }\n\n      this.$element.attr({\n        'title': '',\n        'aria-describedby': elemId,\n        'data-yeti-box': elemId,\n        'data-toggle': elemId,\n        'data-resize': elemId\n      }).addClass(this.options.triggerClass);\n\n      _get(_getPrototypeOf(Tooltip.prototype), \"_init\", this).call(this);\n\n      this._events();\n    }\n  }, {\n    key: \"_getDefaultPosition\",\n    value: function _getDefaultPosition() {\n      // handle legacy classnames\n      var position = this.$element[0].className.match(/\\b(top|left|right|bottom)\\b/g);\n      return position ? position[0] : 'top';\n    }\n  }, {\n    key: \"_getDefaultAlignment\",\n    value: function _getDefaultAlignment() {\n      return 'center';\n    }\n  }, {\n    key: \"_getHOffset\",\n    value: function _getHOffset() {\n      if (this.position === 'left' || this.position === 'right') {\n        return this.options.hOffset + this.options.tooltipWidth;\n      } else {\n        return this.options.hOffset;\n      }\n    }\n  }, {\n    key: \"_getVOffset\",\n    value: function _getVOffset() {\n      if (this.position === 'top' || this.position === 'bottom') {\n        return this.options.vOffset + this.options.tooltipHeight;\n      } else {\n        return this.options.vOffset;\n      }\n    }\n    /**\n     * builds the tooltip element, adds attributes, and returns the template.\n     * @private\n     */\n\n  }, {\n    key: \"_buildTemplate\",\n    value: function _buildTemplate(id) {\n      var templateClasses = \"\".concat(this.options.tooltipClass, \" \").concat(this.options.templateClasses).trim();\n      var $template = jquery__WEBPACK_IMPORTED_MODULE_0___default()('<div></div>').addClass(templateClasses).attr({\n        'role': 'tooltip',\n        'aria-hidden': true,\n        'data-is-active': false,\n        'data-is-focus': false,\n        'id': id\n      });\n      return $template;\n    }\n    /**\n     * sets the position class of an element and recursively calls itself until there are no more possible positions to attempt, or the tooltip element is no longer colliding.\n     * if the tooltip is larger than the screen width, default to full width - any user selected margin\n     * @private\n     */\n\n  }, {\n    key: \"_setPosition\",\n    value: function _setPosition() {\n      _get(_getPrototypeOf(Tooltip.prototype), \"_setPosition\", this).call(this, this.$element, this.template);\n    }\n    /**\n     * reveals the tooltip, and fires an event to close any other open tooltips on the page\n     * @fires Tooltip#closeme\n     * @fires Tooltip#show\n     * @function\n     */\n\n  }, {\n    key: \"show\",\n    value: function show() {\n      if (this.options.showOn !== 'all' && !_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_2__[\"MediaQuery\"].is(this.options.showOn)) {\n        // console.error('The screen is too small to display this tooltip');\n        return false;\n      }\n\n      var _this = this;\n\n      this.template.css('visibility', 'hidden').show();\n\n      this._setPosition();\n\n      this.template.removeClass('top bottom left right').addClass(this.position);\n      this.template.removeClass('align-top align-bottom align-left align-right align-center').addClass('align-' + this.alignment);\n      /**\n       * Fires to close all other open tooltips on the page\n       * @event Closeme#tooltip\n       */\n\n      this.$element.trigger('closeme.zf.tooltip', this.template.attr('id'));\n      this.template.attr({\n        'data-is-active': true,\n        'aria-hidden': false\n      });\n      _this.isActive = true; // console.log(this.template);\n\n      this.template.stop().hide().css('visibility', '').fadeIn(this.options.fadeInDuration, function () {//maybe do stuff?\n      });\n      /**\n       * Fires when the tooltip is shown\n       * @event Tooltip#show\n       */\n\n      this.$element.trigger('show.zf.tooltip');\n    }\n    /**\n     * Hides the current tooltip, and resets the positioning class if it was changed due to collision\n     * @fires Tooltip#hide\n     * @function\n     */\n\n  }, {\n    key: \"hide\",\n    value: function hide() {\n      // console.log('hiding', this.$element.data('yeti-box'));\n      var _this = this;\n\n      this.template.stop().attr({\n        'aria-hidden': true,\n        'data-is-active': false\n      }).fadeOut(this.options.fadeOutDuration, function () {\n        _this.isActive = false;\n        _this.isClick = false;\n      });\n      /**\n       * fires when the tooltip is hidden\n       * @event Tooltip#hide\n       */\n\n      this.$element.trigger('hide.zf.tooltip');\n    }\n    /**\n     * adds event listeners for the tooltip and its anchor\n     * TODO combine some of the listeners like focus and mouseenter, etc.\n     * @private\n     */\n\n  }, {\n    key: \"_events\",\n    value: function _events() {\n      var _this = this;\n\n      var $template = this.template;\n      var isFocus = false;\n\n      if (!this.options.disableHover) {\n        this.$element.on('mouseenter.zf.tooltip', function (e) {\n          if (!_this.isActive) {\n            _this.timeout = setTimeout(function () {\n              _this.show();\n            }, _this.options.hoverDelay);\n          }\n        }).on('mouseleave.zf.tooltip', Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"ignoreMousedisappear\"])(function (e) {\n          clearTimeout(_this.timeout);\n\n          if (!isFocus || _this.isClick && !_this.options.clickOpen) {\n            _this.hide();\n          }\n        }));\n      }\n\n      if (this.options.clickOpen) {\n        this.$element.on('mousedown.zf.tooltip', function (e) {\n          e.stopImmediatePropagation();\n\n          if (_this.isClick) {//_this.hide();\n            // _this.isClick = false;\n          } else {\n            _this.isClick = true;\n\n            if ((_this.options.disableHover || !_this.$element.attr('tabindex')) && !_this.isActive) {\n              _this.show();\n            }\n          }\n        });\n      } else {\n        this.$element.on('mousedown.zf.tooltip', function (e) {\n          e.stopImmediatePropagation();\n          _this.isClick = true;\n        });\n      }\n\n      if (!this.options.disableForTouch) {\n        this.$element.on('tap.zf.tooltip touchend.zf.tooltip', function (e) {\n          _this.isActive ? _this.hide() : _this.show();\n        });\n      }\n\n      this.$element.on({\n        // 'toggle.zf.trigger': this.toggle.bind(this),\n        // 'close.zf.trigger': this.hide.bind(this)\n        'close.zf.trigger': this.hide.bind(this)\n      });\n      this.$element.on('focus.zf.tooltip', function (e) {\n        isFocus = true;\n\n        if (_this.isClick) {\n          // If we're not showing open on clicks, we need to pretend a click-launched focus isn't\n          // a real focus, otherwise on hover and come back we get bad behavior\n          if (!_this.options.clickOpen) {\n            isFocus = false;\n          }\n\n          return false;\n        } else {\n          _this.show();\n        }\n      }).on('focusout.zf.tooltip', function (e) {\n        isFocus = false;\n        _this.isClick = false;\n\n        _this.hide();\n      }).on('resizeme.zf.trigger', function () {\n        if (_this.isActive) {\n          _this._setPosition();\n        }\n      });\n    }\n    /**\n     * adds a toggle method, in addition to the static show() & hide() functions\n     * @function\n     */\n\n  }, {\n    key: \"toggle\",\n    value: function toggle() {\n      if (this.isActive) {\n        this.hide();\n      } else {\n        this.show();\n      }\n    }\n    /**\n     * Destroys an instance of tooltip, removes template element from the view.\n     * @function\n     */\n\n  }, {\n    key: \"_destroy\",\n    value: function _destroy() {\n      this.$element.attr('title', this.template.text()).off('.zf.trigger .zf.tooltip').removeClass(this.options.triggerClass).removeClass('top right left bottom').removeAttr('aria-describedby data-disable-hover data-resize data-toggle data-tooltip data-yeti-box');\n      this.template.remove();\n    }\n  }]);\n\n  return Tooltip;\n}(_foundation_positionable__WEBPACK_IMPORTED_MODULE_4__[\"Positionable\"]);\n\nTooltip.defaults = {\n  disableForTouch: false,\n\n  /**\n   * Time, in ms, before a tooltip should open on hover.\n   * @option\n   * @type {number}\n   * @default 200\n   */\n  hoverDelay: 200,\n\n  /**\n   * Time, in ms, a tooltip should take to fade into view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeInDuration: 150,\n\n  /**\n   * Time, in ms, a tooltip should take to fade out of view.\n   * @option\n   * @type {number}\n   * @default 150\n   */\n  fadeOutDuration: 150,\n\n  /**\n   * Disables hover events from opening the tooltip if set to true\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  disableHover: false,\n\n  /**\n   * Optional addtional classes to apply to the tooltip template on init.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  templateClasses: '',\n\n  /**\n   * Non-optional class added to tooltip templates. Foundation default is 'tooltip'.\n   * @option\n   * @type {string}\n   * @default 'tooltip'\n   */\n  tooltipClass: 'tooltip',\n\n  /**\n   * Class applied to the tooltip anchor element.\n   * @option\n   * @type {string}\n   * @default 'has-tip'\n   */\n  triggerClass: 'has-tip',\n\n  /**\n   * Minimum breakpoint size at which to open the tooltip.\n   * @option\n   * @type {string}\n   * @default 'small'\n   */\n  showOn: 'small',\n\n  /**\n   * Custom template to be used to generate markup for tooltip.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  template: '',\n\n  /**\n   * Text displayed in the tooltip template on open.\n   * @option\n   * @type {string}\n   * @default ''\n   */\n  tipText: '',\n  touchCloseText: 'Tap to close.',\n\n  /**\n   * Allows the tooltip to remain open if triggered with a click or touch event.\n   * @option\n   * @type {boolean}\n   * @default true\n   */\n  clickOpen: true,\n\n  /**\n   * Position of tooltip. Can be left, right, bottom, top, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  position: 'auto',\n\n  /**\n   * Alignment of tooltip relative to anchor. Can be left, right, bottom, top, center, or auto.\n   * @option\n   * @type {string}\n   * @default 'auto'\n   */\n  alignment: 'auto',\n\n  /**\n   * Allow overlap of container/window. If false, tooltip will first try to\n   * position as defined by data-position and data-alignment, but reposition if\n   * it would cause an overflow.  @option\n   * @type {boolean}\n   * @default false\n   */\n  allowOverlap: false,\n\n  /**\n   * Allow overlap of only the bottom of the container. This is the most common\n   * behavior for dropdowns, allowing the dropdown to extend the bottom of the\n   * screen but not otherwise influence or break out of the container.\n   * Less common for tooltips.\n   * @option\n   * @type {boolean}\n   * @default false\n   */\n  allowBottomOverlap: false,\n\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the Y axis.\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  vOffset: 0,\n\n  /**\n   * Distance, in pixels, the template should push away from the anchor on the X axis\n   * @option\n   * @type {number}\n   * @default 0\n   */\n  hOffset: 0,\n\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a vertical tooltip\n   * @option\n   * @type {number}\n   * @default 14\n   */\n  tooltipHeight: 14,\n\n  /**\n   * Distance, in pixels, the template spacing auto-adjust for a horizontal tooltip\n   * @option\n   * @type {number}\n   * @default 12\n   */\n  tooltipWidth: 12,\n\n  /**\n  * Allow HTML in tooltip. Warning: If you are loading user-generated content into tooltips,\n  * allowing HTML may open yourself up to XSS attacks.\n  * @option\n  * @type {boolean}\n  * @default false\n  */\n  allowHtml: false\n};\n/**\n * TODO utilize resize event trigger\n */\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 20:\n/*!********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.tooltip.js ***!\n  \\********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.tooltip.js */\"./js/entries/plugins/foundation.tooltip.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.tooltip.js.map"]}
\ No newline at end of file
index 5dbf175eaa4161923647ba61452fd7b27d94cdbc..b54f3122d8b68d278d3f75fd5ba3e56cde57d84e 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.box"] = factory(require("./foundation.core"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.box"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 100);
+/******/       return __webpack_require__(__webpack_require__.s = 21);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 100:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(34);
-
-
-/***/ }),
-
-/***/ 3:
-/***/ (function(module, exports) {
-
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
-
-/***/ }),
-
-/***/ 34:
+/***/ "./js/entries/plugins/foundation.util.box.js":
+/*!***************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.box.js ***!
+  \***************************************************/
+/*! exports provided: Foundation, Box */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_box__ = __webpack_require__(64);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
+
+/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.box */ "./js/foundation.util.box.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Box", function() { return _foundation_util_box__WEBPACK_IMPORTED_MODULE_1__["Box"]; });
 
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].Box = __WEBPACK_IMPORTED_MODULE_1__foundation_util_box__["a" /* Box */];
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].Box = _foundation_util_box__WEBPACK_IMPORTED_MODULE_1__["Box"];
+
 
 /***/ }),
 
-/***/ 64:
+/***/ "./js/foundation.util.box.js":
+/*!***********************************!*\
+  !*** ./js/foundation.util.box.js ***!
+  \***********************************/
+/*! exports provided: Box */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Box; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_util_core__);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Box", function() { return Box; });
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__);
 
 
 
@@ -122,7 +151,6 @@ var Box = {
   GetDimensions: GetDimensions,
   GetOffsets: GetOffsets,
   GetExplicitOffsets: GetExplicitOffsets
-
   /**
    * Compares the dimensions of an element to a container and determines collision events with container.
    * @function
@@ -133,19 +161,24 @@ var Box = {
    * @default if no parent object passed, detects collisions with `window`.
    * @returns {Boolean} - true if collision free, false if a collision in any direction.
    */
-};function ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {
-  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;
+
 };
 
+function ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {
+  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;
+}
+
+;
+
 function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {
   var eleDims = GetDimensions(element),
       topOver,
       bottomOver,
       leftOver,
       rightOver;
+
   if (parent) {
     var parDims = GetDimensions(parent);
-
     bottomOver = parDims.height + parDims.offset.top - (eleDims.offset.top + eleDims.height);
     topOver = eleDims.offset.top - parDims.offset.top;
     leftOver = eleDims.offset.left - parDims.offset.left;
@@ -165,14 +198,14 @@ function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {
   if (lrOnly) {
     return leftOver + rightOver;
   }
+
   if (tbOnly) {
     return topOver + bottomOver;
-  }
+  } // use sum of squares b/c we care about overlap area.
+
 
-  // use sum of squares b/c we care about overlap area.
   return Math.sqrt(topOver * topOver + bottomOver * bottomOver + leftOver * leftOver + rightOver * rightOver);
 }
-
 /**
  * Uses native methods to return an object of dimension values.
  * @function
@@ -180,6 +213,8 @@ function OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {
  * @returns {Object} - nested object of integer pixel values
  * TODO - if element is window, return only those values.
  */
+
+
 function GetDimensions(elem) {
   elem = elem.length ? elem[0] : elem;
 
@@ -192,7 +227,6 @@ function GetDimensions(elem) {
       winRect = document.body.getBoundingClientRect(),
       winY = window.pageYOffset,
       winX = window.pageXOffset;
-
   return {
     width: rect.width,
     height: rect.height,
@@ -218,7 +252,6 @@ function GetDimensions(elem) {
     }
   };
 }
-
 /**
  * Returns an object of top and left integer pixel values for dynamically rendered elements,
  * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where
@@ -233,76 +266,89 @@ function GetDimensions(elem) {
  * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.
  * TODO alter/rewrite to work with `em` values as well/instead of pixels
  */
+
+
 function GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {
   console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5");
+
   switch (position) {
     case 'top':
-      return __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__foundation_util_core__["rtl"])() ? GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);
+      return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__["rtl"])() ? GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);
+
     case 'bottom':
-      return __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__foundation_util_core__["rtl"])() ? GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+      return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__["rtl"])() ? GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
+
     case 'center top':
       return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);
+
     case 'center bottom':
       return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);
+
     case 'center left':
       return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);
+
     case 'center right':
       return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);
+
     case 'left bottom':
       return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);
+
     case 'right bottom':
       return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);
     // Backwards compatibility... this along with the reveal and reveal full
     // classes are the only ones that didn't reference anchor
+
     case 'center':
       return {
         left: $eleDims.windowDims.offset.left + $eleDims.windowDims.width / 2 - $eleDims.width / 2 + hOffset,
         top: $eleDims.windowDims.offset.top + $eleDims.windowDims.height / 2 - ($eleDims.height / 2 + vOffset)
       };
+
     case 'reveal':
       return {
         left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,
         top: $eleDims.windowDims.offset.top + vOffset
       };
+
     case 'reveal full':
       return {
         left: $eleDims.windowDims.offset.left,
         top: $eleDims.windowDims.offset.top
       };
       break;
+
     default:
       return {
-        left: __webpack_require__.i(__WEBPACK_IMPORTED_MODULE_0__foundation_util_core__["rtl"])() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset : $anchorDims.offset.left + hOffset,
+        left: Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__["rtl"])() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset : $anchorDims.offset.left + hOffset,
         top: $anchorDims.offset.top + $anchorDims.height + vOffset
       };
-
   }
 }
 
 function GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {
   var $eleDims = GetDimensions(element),
       $anchorDims = anchor ? GetDimensions(anchor) : null;
-
-  var topVal, leftVal;
-
-  // set position related attribute
+  var topVal, leftVal; // set position related attribute
 
   switch (position) {
     case 'top':
       topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);
       break;
+
     case 'bottom':
       topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;
       break;
+
     case 'left':
       leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);
       break;
+
     case 'right':
       leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;
       break;
-  }
+  } // set alignment related attribute
+
 
-  // set alignment related attribute
   switch (position) {
     case 'top':
     case 'bottom':
@@ -310,34 +356,59 @@ function GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffs
         case 'left':
           leftVal = $anchorDims.offset.left + hOffset;
           break;
+
         case 'right':
           leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;
           break;
+
         case 'center':
           leftVal = isOverflow ? hOffset : $anchorDims.offset.left + $anchorDims.width / 2 - $eleDims.width / 2 + hOffset;
           break;
       }
+
       break;
+
     case 'right':
     case 'left':
       switch (alignment) {
         case 'bottom':
           topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;
           break;
+
         case 'top':
           topVal = $anchorDims.offset.top + vOffset;
           break;
+
         case 'center':
           topVal = $anchorDims.offset.top + vOffset + $anchorDims.height / 2 - $eleDims.height / 2;
           break;
       }
+
       break;
   }
-  return { top: topVal, left: leftVal };
+
+  return {
+    top: topVal,
+    left: leftVal
+  };
 }
 
 
 
+/***/ }),
+
+/***/ 21:
+/*!*********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.box.js ***!
+  \*********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.box.js */"./js/entries/plugins/foundation.util.box.js");
+
+
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.box.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.box.js.map b/dist/js/plugins/foundation.util.box.js.map
new file mode 100644 (file)
index 0000000..d2b0fe6
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.box.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.box.js"],"names":["Foundation","Box","ImNotTouchingYou","OverlapArea","GetDimensions","GetOffsets","GetExplicitOffsets","element","parent","lrOnly","tbOnly","ignoreBottom","eleDims","topOver","bottomOver","leftOver","rightOver","parDims","height","offset","top","left","width","windowDims","Math","min","sqrt","elem","length","window","document","Error","rect","getBoundingClientRect","parRect","parentNode","winRect","body","winY","pageYOffset","winX","pageXOffset","parentDims","anchor","position","vOffset","hOffset","isOverflow","console","log","Rtl","$eleDims","$anchorDims","alignment","topVal","leftVal"],"mappings":"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","file":"foundation.util.box.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.box\"] = factory(require(\"./foundation.core\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 21);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\nimport { Box } from '../../foundation.util.box';\n\nFoundation.Box = Box;\n\nexport { Foundation, Box };\n","'use strict';\n\n\nimport { rtl as Rtl } from \"./foundation.core.utils\";\n\nvar Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  OverlapArea: OverlapArea,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets,\n  GetExplicitOffsets: GetExplicitOffsets\n}\n\n/**\n * Compares the dimensions of an element to a container and determines collision events with container.\n * @function\n * @param {jQuery} element - jQuery object to test for collisions.\n * @param {jQuery} parent - jQuery object to use as bounding container.\n * @param {Boolean} lrOnly - set to true to check left and right values only.\n * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n * @default if no parent object passed, detects collisions with `window`.\n * @returns {Boolean} - true if collision free, false if a collision in any direction.\n */\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n};\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  var eleDims = GetDimensions(element),\n  topOver, bottomOver, leftOver, rightOver;\n  if (parent) {\n    var parDims = GetDimensions(parent);\n\n    bottomOver = (parDims.height + parDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - parDims.offset.top;\n    leftOver   = eleDims.offset.left - parDims.offset.left;\n    rightOver  = (parDims.width + parDims.offset.left) - (eleDims.offset.left + eleDims.width);\n  }\n  else {\n    bottomOver = (eleDims.windowDims.height + eleDims.windowDims.offset.top) - (eleDims.offset.top + eleDims.height);\n    topOver    = eleDims.offset.top - eleDims.windowDims.offset.top;\n    leftOver   = eleDims.offset.left - eleDims.windowDims.offset.left;\n    rightOver  = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n  }\n\n  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n  topOver    = Math.min(topOver, 0);\n  leftOver   = Math.min(leftOver, 0);\n  rightOver  = Math.min(rightOver, 0);\n\n  if (lrOnly) {\n    return leftOver + rightOver;\n  }\n  if (tbOnly) {\n    return topOver + bottomOver;\n  }\n\n  // use sum of squares b/c we care about overlap area.\n  return Math.sqrt((topOver * topOver) + (bottomOver * bottomOver) + (leftOver * leftOver) + (rightOver * rightOver));\n}\n\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\nfunction GetDimensions(elem){\n  elem = elem.length ? elem[0] : elem;\n\n  if (elem === window || elem === document) {\n    throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n  }\n\n  var rect = elem.getBoundingClientRect(),\n      parRect = elem.parentNode.getBoundingClientRect(),\n      winRect = document.body.getBoundingClientRect(),\n      winY = window.pageYOffset,\n      winX = window.pageXOffset;\n\n  return {\n    width: rect.width,\n    height: rect.height,\n    offset: {\n      top: rect.top + winY,\n      left: rect.left + winX\n    },\n    parentDims: {\n      width: parRect.width,\n      height: parRect.height,\n      offset: {\n        top: parRect.top + winY,\n        left: parRect.left + winX\n      }\n    },\n    windowDims: {\n      width: winRect.width,\n      height: winRect.height,\n      offset: {\n        top: winY,\n        left: winX\n      }\n    }\n  }\n}\n\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\nfunction GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {\n  console.log(\"NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5\");\n  switch (position) {\n    case 'top':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);\n    case 'bottom':\n      return Rtl() ?\n        GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) :\n        GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    case 'center top':\n      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);\n    case 'center bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);\n    case 'center left':\n      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);\n    case 'center right':\n      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);\n    case 'left bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);\n    case 'right bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    // Backwards compatibility... this along with the reveal and reveal full\n    // classes are the only ones that didn't reference anchor\n    case 'center':\n      return {\n        left: ($eleDims.windowDims.offset.left + ($eleDims.windowDims.width / 2)) - ($eleDims.width / 2) + hOffset,\n        top: ($eleDims.windowDims.offset.top + ($eleDims.windowDims.height / 2)) - ($eleDims.height / 2 + vOffset)\n      }\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + vOffset\n      }\n    case 'reveal full':\n      return {\n        left: $eleDims.windowDims.offset.left,\n        top: $eleDims.windowDims.offset.top\n      }\n      break;\n    default:\n      return {\n        left: (Rtl() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset: $anchorDims.offset.left + hOffset),\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      }\n\n  }\n\n}\n\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n\n      var topVal, leftVal;\n\n  // set position related attribute\n\n  switch (position) {\n    case 'top':\n      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n      break;\n    case 'bottom':\n      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n      break;\n    case 'left':\n      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n      break;\n    case 'right':\n      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n      break;\n  }\n\n\n  // set alignment related attribute\n  switch (position) {\n    case 'top':\n    case 'bottom':\n      switch (alignment) {\n        case 'left':\n          leftVal = $anchorDims.offset.left + hOffset;\n          break;\n        case 'right':\n          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n          break;\n        case 'center':\n          leftVal = isOverflow ? hOffset : (($anchorDims.offset.left + ($anchorDims.width / 2)) - ($eleDims.width / 2)) + hOffset;\n          break;\n      }\n      break;\n    case 'right':\n    case 'left':\n      switch (alignment) {\n        case 'bottom':\n          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n          break;\n        case 'top':\n          topVal = $anchorDims.offset.top + vOffset\n          break;\n        case 'center':\n          topVal = ($anchorDims.offset.top + vOffset + ($anchorDims.height / 2)) - ($eleDims.height / 2)\n          break;\n      }\n      break;\n  }\n  return {top: topVal, left: leftVal};\n}\n\nexport {Box};\n"],"sourceRoot":""}
\ No newline at end of file
index 1aa9874e594212fa295f542a37eb54993182a65c..9e8c3c7d48a6068f1658d497be374ee9333ab20f 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(i){if(o[i])return o[i].exports;var n=o[i]={i:i,l:!1,exports:{}};return t[i].call(n.exports,n,n.exports,e),n.l=!0,n.exports}var o={};e.m=t,e.c=o,e.i=function(t){return t},e.d=function(t,o,i){e.o(t,o)||Object.defineProperty(t,o,{configurable:!1,enumerable:!0,get:i})},e.n=function(t){var o=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(o,"a",o),o},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=100)}({1:function(t,e){t.exports={Foundation:window.Foundation}},100:function(t,e,o){t.exports=o(34)},3:function(t,e){t.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},34:function(t,e,o){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var i=o(1),n=(o.n(i),o(64));i.Foundation.Box=n.a},64:function(t,e,o){"use strict";function i(t,e,o,i,f){return 0===n(t,e,o,i,f)}function n(t,e,o,i,n){var s,r,h,a,c=f(t);if(e){var l=f(e);r=l.height+l.offset.top-(c.offset.top+c.height),s=c.offset.top-l.offset.top,h=c.offset.left-l.offset.left,a=l.width+l.offset.left-(c.offset.left+c.width)}else r=c.windowDims.height+c.windowDims.offset.top-(c.offset.top+c.height),s=c.offset.top-c.windowDims.offset.top,h=c.offset.left-c.windowDims.offset.left,a=c.windowDims.width-(c.offset.left+c.width);return r=n?0:Math.min(r,0),s=Math.min(s,0),h=Math.min(h,0),a=Math.min(a,0),o?h+a:i?s+r:Math.sqrt(s*s+r*r+h*h+a*a)}function f(t){if((t=t.length?t[0]:t)===window||t===document)throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");var e=t.getBoundingClientRect(),o=t.parentNode.getBoundingClientRect(),i=document.body.getBoundingClientRect(),n=window.pageYOffset,f=window.pageXOffset;return{width:e.width,height:e.height,offset:{top:e.top+n,left:e.left+f},parentDims:{width:o.width,height:o.height,offset:{top:o.top+n,left:o.left+f}},windowDims:{width:i.width,height:i.height,offset:{top:n,left:f}}}}function s(t,e,i,n,f,s){switch(console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5"),i){case"top":return o.i(h.rtl)()?r(t,e,"top","left",n,f,s):r(t,e,"top","right",n,f,s);case"bottom":return o.i(h.rtl)()?r(t,e,"bottom","left",n,f,s):r(t,e,"bottom","right",n,f,s);case"center top":return r(t,e,"top","center",n,f,s);case"center bottom":return r(t,e,"bottom","center",n,f,s);case"center left":return r(t,e,"left","center",n,f,s);case"center right":return r(t,e,"right","center",n,f,s);case"left bottom":return r(t,e,"bottom","left",n,f,s);case"right bottom":return r(t,e,"bottom","right",n,f,s);case"center":return{left:$eleDims.windowDims.offset.left+$eleDims.windowDims.width/2-$eleDims.width/2+f,top:$eleDims.windowDims.offset.top+$eleDims.windowDims.height/2-($eleDims.height/2+n)};case"reveal":return{left:($eleDims.windowDims.width-$eleDims.width)/2+f,top:$eleDims.windowDims.offset.top+n};case"reveal full":return{left:$eleDims.windowDims.offset.left,top:$eleDims.windowDims.offset.top};default:return{left:o.i(h.rtl)()?$anchorDims.offset.left-$eleDims.width+$anchorDims.width-f:$anchorDims.offset.left+f,top:$anchorDims.offset.top+$anchorDims.height+n}}}function r(t,e,o,i,n,s,r){var h,a,c=f(t),l=e?f(e):null;switch(o){case"top":h=l.offset.top-(c.height+n);break;case"bottom":h=l.offset.top+l.height+n;break;case"left":a=l.offset.left-(c.width+s);break;case"right":a=l.offset.left+l.width+s}switch(o){case"top":case"bottom":switch(i){case"left":a=l.offset.left+s;break;case"right":a=l.offset.left-c.width+l.width-s;break;case"center":a=r?s:l.offset.left+l.width/2-c.width/2+s}break;case"right":case"left":switch(i){case"bottom":h=l.offset.top-n+l.height-c.height;break;case"top":h=l.offset.top+n;break;case"center":h=l.offset.top+n+l.height/2-c.height/2}}return{top:h,left:a}}o.d(e,"a",function(){return a});var h=o(3),a=(o.n(h),{ImNotTouchingYou:i,OverlapArea:n,GetDimensions:f,GetOffsets:s,GetExplicitOffsets:r})}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core")):"function"==typeof define&&define.amd?define(["./foundation.core"],e):"object"==typeof exports?exports["foundation.util.box"]=e(require("./foundation.core")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.util.box"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"]))}(window,function(o){return function(o){var i={};function n(t){if(i[t])return i[t].exports;var e=i[t]={i:t,l:!1,exports:{}};return o[t].call(e.exports,e,e.exports,n),e.l=!0,e.exports}return n.m=o,n.c=i,n.d=function(t,e,o){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:o})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(e,t){if(1&t&&(e=n(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var o=Object.create(null);if(n.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var i in e)n.d(o,i,function(t){return e[t]}.bind(null,i));return o},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=21)}({"./foundation.core":function(t,e){t.exports=o},"./js/entries/plugins/foundation.util.box.js":function(t,e,o){"use strict";o.r(e);var i=o("./foundation.core");o.d(e,"Foundation",function(){return i.Foundation});var n=o("./js/foundation.util.box.js");o.d(e,"Box",function(){return n.Box}),i.Foundation.Box=n.Box},"./js/foundation.util.box.js":function(t,e,o){"use strict";o.r(e),o.d(e,"Box",function(){return i});var r=o("./foundation.core"),i={ImNotTouchingYou:function(t,e,o,i,n){return 0===f(t,e,o,i,n)},OverlapArea:f,GetDimensions:l,GetOffsets:function(t,e,o,i,n,f){switch(console.log("NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5"),o){case"top":return Object(r.rtl)()?s(t,e,"top","left",i,n,f):s(t,e,"top","right",i,n,f);case"bottom":return Object(r.rtl)()?s(t,e,"bottom","left",i,n,f):s(t,e,"bottom","right",i,n,f);case"center top":return s(t,e,"top","center",i,n,f);case"center bottom":return s(t,e,"bottom","center",i,n,f);case"center left":return s(t,e,"left","center",i,n,f);case"center right":return s(t,e,"right","center",i,n,f);case"left bottom":return s(t,e,"bottom","left",i,n,f);case"right bottom":return s(t,e,"bottom","right",i,n,f);case"center":return{left:$eleDims.windowDims.offset.left+$eleDims.windowDims.width/2-$eleDims.width/2+n,top:$eleDims.windowDims.offset.top+$eleDims.windowDims.height/2-($eleDims.height/2+i)};case"reveal":return{left:($eleDims.windowDims.width-$eleDims.width)/2+n,top:$eleDims.windowDims.offset.top+i};case"reveal full":return{left:$eleDims.windowDims.offset.left,top:$eleDims.windowDims.offset.top};default:return{left:Object(r.rtl)()?$anchorDims.offset.left-$eleDims.width+$anchorDims.width-n:$anchorDims.offset.left+n,top:$anchorDims.offset.top+$anchorDims.height+i}}},GetExplicitOffsets:s};function f(t,e,o,i,n){var f,r,s,u,c=l(t);if(e){var a=l(e);r=a.height+a.offset.top-(c.offset.top+c.height),f=c.offset.top-a.offset.top,s=c.offset.left-a.offset.left,u=a.width+a.offset.left-(c.offset.left+c.width)}else r=c.windowDims.height+c.windowDims.offset.top-(c.offset.top+c.height),f=c.offset.top-c.windowDims.offset.top,s=c.offset.left-c.windowDims.offset.left,u=c.windowDims.width-(c.offset.left+c.width);return r=n?0:Math.min(r,0),f=Math.min(f,0),s=Math.min(s,0),u=Math.min(u,0),o?s+u:i?f+r:Math.sqrt(f*f+r*r+s*s+u*u)}function l(t){if((t=t.length?t[0]:t)===window||t===document)throw new Error("I'm sorry, Dave. I'm afraid I can't do that.");var e=t.getBoundingClientRect(),o=t.parentNode.getBoundingClientRect(),i=document.body.getBoundingClientRect(),n=window.pageYOffset,f=window.pageXOffset;return{width:e.width,height:e.height,offset:{top:e.top+n,left:e.left+f},parentDims:{width:o.width,height:o.height,offset:{top:o.top+n,left:o.left+f}},windowDims:{width:i.width,height:i.height,offset:{top:n,left:f}}}}function s(t,e,o,i,n,f,r){var s,u,c=l(t),a=e?l(e):null;switch(o){case"top":s=a.offset.top-(c.height+n);break;case"bottom":s=a.offset.top+a.height+n;break;case"left":u=a.offset.left-(c.width+f);break;case"right":u=a.offset.left+a.width+f}switch(o){case"top":case"bottom":switch(i){case"left":u=a.offset.left+f;break;case"right":u=a.offset.left-c.width+a.width-f;break;case"center":u=r?f:a.offset.left+a.width/2-c.width/2+f}break;case"right":case"left":switch(i){case"bottom":s=a.offset.top-n+a.height-c.height;break;case"top":s=a.offset.top+n;break;case"center":s=a.offset.top+n+a.height/2-c.height/2}}return{top:s,left:u}}},21:function(t,e,o){t.exports=o("./js/entries/plugins/foundation.util.box.js")}})});
+//# sourceMappingURL=foundation.util.box.min.js.map
diff --git a/dist/js/plugins/foundation.util.box.min.js.map b/dist/js/plugins/foundation.util.box.min.js.map
new file mode 100644 (file)
index 0000000..7a7abca
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.box.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.util.box.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_util_box__WEBPACK_IMPORTED_MODULE_1__","Box","./js/foundation.util.box.js","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__","ImNotTouchingYou","element","parent","lrOnly","tbOnly","ignoreBottom","OverlapArea","GetDimensions","GetOffsets","anchor","position","vOffset","hOffset","isOverflow","console","log","GetExplicitOffsets","left","$eleDims","windowDims","offset","width","top","height","$anchorDims","topOver","bottomOver","leftOver","rightOver","eleDims","parDims","Math","min","sqrt","elem","length","document","Error","rect","getBoundingClientRect","parRect","parentNode","winRect","body","winY","pageYOffset","winX","pageXOffset","parentDims","alignment","topVal","leftVal","21"],"mappings":"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","file":"foundation.util.box.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.box\"] = factory(require(\"./foundation.core\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.box\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 21);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.box.js\":\n/*!***************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.box.js ***!\n  \\***************************************************/\n/*! exports provided: Foundation, Box */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_util_box__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.box */ \"./js/foundation.util.box.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Box\", function() { return _foundation_util_box__WEBPACK_IMPORTED_MODULE_1__[\"Box\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].Box = _foundation_util_box__WEBPACK_IMPORTED_MODULE_1__[\"Box\"];\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.box.js\":\n/*!***********************************!*\\\n  !*** ./js/foundation.util.box.js ***!\n  \\***********************************/\n/*! exports provided: Box */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Box\", function() { return Box; });\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\nvar Box = {\n  ImNotTouchingYou: ImNotTouchingYou,\n  OverlapArea: OverlapArea,\n  GetDimensions: GetDimensions,\n  GetOffsets: GetOffsets,\n  GetExplicitOffsets: GetExplicitOffsets\n  /**\n   * Compares the dimensions of an element to a container and determines collision events with container.\n   * @function\n   * @param {jQuery} element - jQuery object to test for collisions.\n   * @param {jQuery} parent - jQuery object to use as bounding container.\n   * @param {Boolean} lrOnly - set to true to check left and right values only.\n   * @param {Boolean} tbOnly - set to true to check top and bottom values only.\n   * @default if no parent object passed, detects collisions with `window`.\n   * @returns {Boolean} - true if collision free, false if a collision in any direction.\n   */\n\n};\n\nfunction ImNotTouchingYou(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  return OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) === 0;\n}\n\n;\n\nfunction OverlapArea(element, parent, lrOnly, tbOnly, ignoreBottom) {\n  var eleDims = GetDimensions(element),\n      topOver,\n      bottomOver,\n      leftOver,\n      rightOver;\n\n  if (parent) {\n    var parDims = GetDimensions(parent);\n    bottomOver = parDims.height + parDims.offset.top - (eleDims.offset.top + eleDims.height);\n    topOver = eleDims.offset.top - parDims.offset.top;\n    leftOver = eleDims.offset.left - parDims.offset.left;\n    rightOver = parDims.width + parDims.offset.left - (eleDims.offset.left + eleDims.width);\n  } else {\n    bottomOver = eleDims.windowDims.height + eleDims.windowDims.offset.top - (eleDims.offset.top + eleDims.height);\n    topOver = eleDims.offset.top - eleDims.windowDims.offset.top;\n    leftOver = eleDims.offset.left - eleDims.windowDims.offset.left;\n    rightOver = eleDims.windowDims.width - (eleDims.offset.left + eleDims.width);\n  }\n\n  bottomOver = ignoreBottom ? 0 : Math.min(bottomOver, 0);\n  topOver = Math.min(topOver, 0);\n  leftOver = Math.min(leftOver, 0);\n  rightOver = Math.min(rightOver, 0);\n\n  if (lrOnly) {\n    return leftOver + rightOver;\n  }\n\n  if (tbOnly) {\n    return topOver + bottomOver;\n  } // use sum of squares b/c we care about overlap area.\n\n\n  return Math.sqrt(topOver * topOver + bottomOver * bottomOver + leftOver * leftOver + rightOver * rightOver);\n}\n/**\n * Uses native methods to return an object of dimension values.\n * @function\n * @param {jQuery || HTML} element - jQuery object or DOM element for which to get the dimensions. Can be any element other that document or window.\n * @returns {Object} - nested object of integer pixel values\n * TODO - if element is window, return only those values.\n */\n\n\nfunction GetDimensions(elem) {\n  elem = elem.length ? elem[0] : elem;\n\n  if (elem === window || elem === document) {\n    throw new Error(\"I'm sorry, Dave. I'm afraid I can't do that.\");\n  }\n\n  var rect = elem.getBoundingClientRect(),\n      parRect = elem.parentNode.getBoundingClientRect(),\n      winRect = document.body.getBoundingClientRect(),\n      winY = window.pageYOffset,\n      winX = window.pageXOffset;\n  return {\n    width: rect.width,\n    height: rect.height,\n    offset: {\n      top: rect.top + winY,\n      left: rect.left + winX\n    },\n    parentDims: {\n      width: parRect.width,\n      height: parRect.height,\n      offset: {\n        top: parRect.top + winY,\n        left: parRect.left + winX\n      }\n    },\n    windowDims: {\n      width: winRect.width,\n      height: winRect.height,\n      offset: {\n        top: winY,\n        left: winX\n      }\n    }\n  };\n}\n/**\n * Returns an object of top and left integer pixel values for dynamically rendered elements,\n * such as: Tooltip, Reveal, and Dropdown. Maintained for backwards compatibility, and where\n * you don't know alignment, but generally from\n * 6.4 forward you should use GetExplicitOffsets, as GetOffsets conflates position and alignment.\n * @function\n * @param {jQuery} element - jQuery object for the element being positioned.\n * @param {jQuery} anchor - jQuery object for the element's anchor point.\n * @param {String} position - a string relating to the desired position of the element, relative to it's anchor\n * @param {Number} vOffset - integer pixel value of desired vertical separation between anchor and element.\n * @param {Number} hOffset - integer pixel value of desired horizontal separation between anchor and element.\n * @param {Boolean} isOverflow - if a collision event is detected, sets to true to default the element to full width - any desired offset.\n * TODO alter/rewrite to work with `em` values as well/instead of pixels\n */\n\n\nfunction GetOffsets(element, anchor, position, vOffset, hOffset, isOverflow) {\n  console.log(\"NOTE: GetOffsets is deprecated in favor of GetExplicitOffsets and will be removed in 6.5\");\n\n  switch (position) {\n    case 'top':\n      return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__[\"rtl\"])() ? GetExplicitOffsets(element, anchor, 'top', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'top', 'right', vOffset, hOffset, isOverflow);\n\n    case 'bottom':\n      return Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__[\"rtl\"])() ? GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow) : GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n\n    case 'center top':\n      return GetExplicitOffsets(element, anchor, 'top', 'center', vOffset, hOffset, isOverflow);\n\n    case 'center bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'center', vOffset, hOffset, isOverflow);\n\n    case 'center left':\n      return GetExplicitOffsets(element, anchor, 'left', 'center', vOffset, hOffset, isOverflow);\n\n    case 'center right':\n      return GetExplicitOffsets(element, anchor, 'right', 'center', vOffset, hOffset, isOverflow);\n\n    case 'left bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'left', vOffset, hOffset, isOverflow);\n\n    case 'right bottom':\n      return GetExplicitOffsets(element, anchor, 'bottom', 'right', vOffset, hOffset, isOverflow);\n    // Backwards compatibility... this along with the reveal and reveal full\n    // classes are the only ones that didn't reference anchor\n\n    case 'center':\n      return {\n        left: $eleDims.windowDims.offset.left + $eleDims.windowDims.width / 2 - $eleDims.width / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + $eleDims.windowDims.height / 2 - ($eleDims.height / 2 + vOffset)\n      };\n\n    case 'reveal':\n      return {\n        left: ($eleDims.windowDims.width - $eleDims.width) / 2 + hOffset,\n        top: $eleDims.windowDims.offset.top + vOffset\n      };\n\n    case 'reveal full':\n      return {\n        left: $eleDims.windowDims.offset.left,\n        top: $eleDims.windowDims.offset.top\n      };\n      break;\n\n    default:\n      return {\n        left: Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_0__[\"rtl\"])() ? $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset : $anchorDims.offset.left + hOffset,\n        top: $anchorDims.offset.top + $anchorDims.height + vOffset\n      };\n  }\n}\n\nfunction GetExplicitOffsets(element, anchor, position, alignment, vOffset, hOffset, isOverflow) {\n  var $eleDims = GetDimensions(element),\n      $anchorDims = anchor ? GetDimensions(anchor) : null;\n  var topVal, leftVal; // set position related attribute\n\n  switch (position) {\n    case 'top':\n      topVal = $anchorDims.offset.top - ($eleDims.height + vOffset);\n      break;\n\n    case 'bottom':\n      topVal = $anchorDims.offset.top + $anchorDims.height + vOffset;\n      break;\n\n    case 'left':\n      leftVal = $anchorDims.offset.left - ($eleDims.width + hOffset);\n      break;\n\n    case 'right':\n      leftVal = $anchorDims.offset.left + $anchorDims.width + hOffset;\n      break;\n  } // set alignment related attribute\n\n\n  switch (position) {\n    case 'top':\n    case 'bottom':\n      switch (alignment) {\n        case 'left':\n          leftVal = $anchorDims.offset.left + hOffset;\n          break;\n\n        case 'right':\n          leftVal = $anchorDims.offset.left - $eleDims.width + $anchorDims.width - hOffset;\n          break;\n\n        case 'center':\n          leftVal = isOverflow ? hOffset : $anchorDims.offset.left + $anchorDims.width / 2 - $eleDims.width / 2 + hOffset;\n          break;\n      }\n\n      break;\n\n    case 'right':\n    case 'left':\n      switch (alignment) {\n        case 'bottom':\n          topVal = $anchorDims.offset.top - vOffset + $anchorDims.height - $eleDims.height;\n          break;\n\n        case 'top':\n          topVal = $anchorDims.offset.top + vOffset;\n          break;\n\n        case 'center':\n          topVal = $anchorDims.offset.top + vOffset + $anchorDims.height / 2 - $eleDims.height / 2;\n          break;\n      }\n\n      break;\n  }\n\n  return {\n    top: topVal,\n    left: leftVal\n  };\n}\n\n\n\n/***/ }),\n\n/***/ 21:\n/*!*********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.box.js ***!\n  \\*********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.box.js */\"./js/entries/plugins/foundation.util.box.js\");\n\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.box.js.map"]}
\ No newline at end of file
index 19480c36a24de75c299b2a7f296b275e64a831f3..52c7652412f4099ca5036dd8a74937af5c5d90a9 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.imageLoader"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.imageLoader"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 101);
+/******/       return __webpack_require__(__webpack_require__.s = 22);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
-/***/ (function(module, exports) {
-
-module.exports = {Foundation: window.Foundation};
-
-/***/ }),
-
-/***/ 101:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(35);
-
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 35:
+/***/ "./js/entries/plugins/foundation.util.imageLoader.js":
+/*!***********************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.imageLoader.js ***!
+  \***********************************************************/
+/*! exports provided: Foundation, onImagesLoaded */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_imageLoader__ = __webpack_require__(65);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
+
+/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.imageLoader */ "./js/foundation.util.imageLoader.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "onImagesLoaded", function() { return _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_1__["onImagesLoaded"]; });
 
 
 
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].onImagesLoaded = _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_1__["onImagesLoaded"];
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].onImagesLoaded = __WEBPACK_IMPORTED_MODULE_1__foundation_util_imageLoader__["a" /* onImagesLoaded */];
 
 /***/ }),
 
-/***/ 65:
+/***/ "./js/foundation.util.imageLoader.js":
+/*!*******************************************!*\
+  !*** ./js/foundation.util.imageLoader.js ***!
+  \*******************************************/
+/*! exports provided: onImagesLoaded */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return onImagesLoaded; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "onImagesLoaded", function() { return onImagesLoaded; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 
 
 
@@ -122,6 +150,7 @@ __WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].onImagesLoaded = __
  * @param {Object} images - Image(s) to check if loaded.
  * @param {Func} callback - Function to execute when image is fully loaded.
  */
+
 function onImagesLoaded(images, callback) {
   var self = this,
       unloaded = images.length;
@@ -132,24 +161,25 @@ function onImagesLoaded(images, callback) {
 
   images.each(function () {
     // Check if image is loaded
-    if (this.complete && this.naturalWidth !== undefined) {
+    if (this.complete && typeof this.naturalWidth !== 'undefined') {
       singleImageLoaded();
     } else {
       // If the above check failed, simulate loading on detached element.
-      var image = new Image();
-      // Still count image as loaded if it finalizes with an error.
+      var image = new Image(); // Still count image as loaded if it finalizes with an error.
+
       var events = "load.zf.images error.zf.images";
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(image).one(events, function me(event) {
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(image).one(events, function me(event) {
         // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).off(events, me);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off(events, me);
         singleImageLoaded();
       });
-      image.src = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).attr('src');
+      image.src = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('src');
     }
   });
 
   function singleImageLoaded() {
     unloaded--;
+
     if (unloaded === 0) {
       callback();
     }
@@ -158,6 +188,31 @@ function onImagesLoaded(images, callback) {
 
 
 
+/***/ }),
+
+/***/ 22:
+/*!*****************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.imageLoader.js ***!
+  \*****************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.imageLoader.js */"./js/entries/plugins/foundation.util.imageLoader.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
+
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.imageLoader.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.imageLoader.js.map b/dist/js/plugins/foundation.util.imageLoader.js.map
new file mode 100644 (file)
index 0000000..8900e8d
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.imageLoader.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.imageLoader.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","onImagesLoaded","images","callback","self","unloaded","length","each","complete","naturalWidth","singleImageLoaded","image","Image","events","$","one","me","event","off","src","attr"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yEAAyE;AACzE,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;AClFA,8D;;;;;;;;;;;;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AAEAA,2DAAU,CAACC,cAAX,GAA4BA,2EAA5B;;;;;;;;;;;;;ACJA;AAAA;AAAA;AAAA;AAAa;;AAEb;AAEA;;;;;;AAKA,SAASA,cAAT,CAAwBC,MAAxB,EAAgCC,QAAhC,EAAyC;AACvC,MAAIC,IAAI,GAAG,IAAX;AAAA,MACIC,QAAQ,GAAGH,MAAM,CAACI,MADtB;;AAGA,MAAID,QAAQ,KAAK,CAAjB,EAAoB;AAClBF,YAAQ;AACT;;AAEDD,QAAM,CAACK,IAAP,CAAY,YAAU;AACpB;AACA,QAAI,KAAKC,QAAL,IAAiB,OAAO,KAAKC,YAAZ,KAA6B,WAAlD,EAA+D;AAC7DC,uBAAiB;AAClB,KAFD,MAGK;AACH;AACA,UAAIC,KAAK,GAAG,IAAIC,KAAJ,EAAZ,CAFG,CAGH;;AACA,UAAIC,MAAM,GAAG,gCAAb;AACAC,mDAAC,CAACH,KAAD,CAAD,CAASI,GAAT,CAAaF,MAAb,EAAqB,SAASG,EAAT,CAAYC,KAAZ,EAAkB;AACrC;AACAH,qDAAC,CAAC,IAAD,CAAD,CAAQI,GAAR,CAAYL,MAAZ,EAAoBG,EAApB;AACAN,yBAAiB;AAClB,OAJD;AAKAC,WAAK,CAACQ,GAAN,GAAYL,6CAAC,CAAC,IAAD,CAAD,CAAQM,IAAR,CAAa,KAAb,CAAZ;AACD;AACF,GAjBD;;AAmBA,WAASV,iBAAT,GAA6B;AAC3BL,YAAQ;;AACR,QAAIA,QAAQ,KAAK,CAAjB,EAAoB;AAClBF,cAAQ;AACT;AACF;AACF;;;;;;;;;;;;;;;;;;;;;;;;;AC1CD,oD","file":"foundation.util.imageLoader.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.imageLoader\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.imageLoader\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 22);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\n\nimport { onImagesLoaded } from '../../foundation.util.imageLoader';\n\nFoundation.onImagesLoaded = onImagesLoaded;\n\nexport { Foundation, onImagesLoaded };\n","'use strict';\n\nimport $ from 'jquery';\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\nfunction onImagesLoaded(images, callback){\n  var self = this,\n      unloaded = images.length;\n\n  if (unloaded === 0) {\n    callback();\n  }\n\n  images.each(function(){\n    // Check if image is loaded\n    if (this.complete && typeof this.naturalWidth !== 'undefined') {\n      singleImageLoaded();\n    }\n    else {\n      // If the above check failed, simulate loading on detached element.\n      var image = new Image();\n      // Still count image as loaded if it finalizes with an error.\n      var events = \"load.zf.images error.zf.images\";\n      $(image).one(events, function me(event){\n        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n        $(this).off(events, me);\n        singleImageLoaded();\n      });\n      image.src = $(this).attr('src');\n    }\n  });\n\n  function singleImageLoaded() {\n    unloaded--;\n    if (unloaded === 0) {\n      callback();\n    }\n  }\n}\n\nexport { onImagesLoaded };\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 3707ac6fd1c3b92fdc9d118c72f4dcd6e2bdffc8..3ef07756de34aeda53283d0211f9754b878b7b40 100644 (file)
@@ -1 +1,2 @@
-!function(n){function t(o){if(e[o])return e[o].exports;var r=e[o]={i:o,l:!1,exports:{}};return n[o].call(r.exports,r,r.exports,t),r.l=!0,r.exports}var e={};t.m=n,t.c=e,t.i=function(n){return n},t.d=function(n,e,o){t.o(n,e)||Object.defineProperty(n,e,{configurable:!1,enumerable:!0,get:o})},t.n=function(n){var e=n&&n.__esModule?function(){return n.default}:function(){return n};return t.d(e,"a",e),e},t.o=function(n,t){return Object.prototype.hasOwnProperty.call(n,t)},t.p="",t(t.s=101)}({0:function(n,t){n.exports=jQuery},1:function(n,t){n.exports={Foundation:window.Foundation}},101:function(n,t,e){n.exports=e(35)},35:function(n,t,e){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var o=e(1),r=(e.n(o),e(65));o.Foundation.onImagesLoaded=r.a},65:function(n,t,e){"use strict";function o(n,t){function e(){0===--o&&t()}var o=n.length;0===o&&t(),n.each(function(){if(this.complete&&void 0!==this.naturalWidth)e();else{var n=new Image,t="load.zf.images error.zf.images";i()(n).one(t,function n(o){i()(this).off(t,n),e()}),n.src=i()(this).attr("src")}})}e.d(t,"a",function(){return o});var r=e(0),i=e.n(r)}});
\ No newline at end of file
+!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],n):"object"==typeof exports?exports["foundation.util.imageLoader"]=n(require("./foundation.core"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.util.imageLoader"]=n(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.jQuery))}(window,function(o,t){return function(o){var t={};function r(e){if(t[e])return t[e].exports;var n=t[e]={i:e,l:!1,exports:{}};return o[e].call(n.exports,n,n.exports,r),n.l=!0,n.exports}return r.m=o,r.c=t,r.d=function(e,n,o){r.o(e,n)||Object.defineProperty(e,n,{enumerable:!0,get:o})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(n,e){if(1&e&&(n=r(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var o=Object.create(null);if(r.r(o),Object.defineProperty(o,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var t in n)r.d(o,t,function(e){return n[e]}.bind(null,t));return o},r.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(n,"a",n),n},r.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},r.p="",r(r.s=22)}({"./foundation.core":function(e,n){e.exports=o},"./js/entries/plugins/foundation.util.imageLoader.js":function(e,n,o){"use strict";o.r(n);var t=o("./foundation.core");o.d(n,"Foundation",function(){return t.Foundation});var r=o("./js/foundation.util.imageLoader.js");o.d(n,"onImagesLoaded",function(){return r.onImagesLoaded}),t.Foundation.onImagesLoaded=r.onImagesLoaded},"./js/foundation.util.imageLoader.js":function(e,n,o){"use strict";o.r(n),o.d(n,"onImagesLoaded",function(){return u});var t=o("jquery"),r=o.n(t);function u(e,n){var o=e.length;function t(){0===--o&&n()}0===o&&n(),e.each(function(){if(this.complete&&void 0!==this.naturalWidth)t();else{var e=new Image,o="load.zf.images error.zf.images";r()(e).one(o,function e(n){r()(this).off(o,e),t()}),e.src=r()(this).attr("src")}})}},22:function(e,n,o){e.exports=o("./js/entries/plugins/foundation.util.imageLoader.js")},jquery:function(e,n){e.exports=t}})});
+//# sourceMappingURL=foundation.util.imageLoader.min.js.map
diff --git a/dist/js/plugins/foundation.util.imageLoader.min.js.map b/dist/js/plugins/foundation.util.imageLoader.min.js.map
new file mode 100644 (file)
index 0000000..b39d65c
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.imageLoader.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.util.imageLoader.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_1__","onImagesLoaded","./js/foundation.util.imageLoader.js","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","images","callback","unloaded","length","singleImageLoaded","each","this","complete","naturalWidth","image","Image","events","one","me","event","off","src","attr","22","jquery"],"mappings":"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","file":"foundation.util.imageLoader.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.imageLoader\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.imageLoader\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 22);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.imageLoader.js\":\n/*!***********************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.imageLoader.js ***!\n  \\***********************************************************/\n/*! exports provided: Foundation, onImagesLoaded */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.imageLoader */ \"./js/foundation.util.imageLoader.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"onImagesLoaded\", function() { return _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_1__[\"onImagesLoaded\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].onImagesLoaded = _foundation_util_imageLoader__WEBPACK_IMPORTED_MODULE_1__[\"onImagesLoaded\"];\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.imageLoader.js\":\n/*!*******************************************!*\\\n  !*** ./js/foundation.util.imageLoader.js ***!\n  \\*******************************************/\n/*! exports provided: onImagesLoaded */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"onImagesLoaded\", function() { return onImagesLoaded; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\n/**\n * Runs a callback function when images are fully loaded.\n * @param {Object} images - Image(s) to check if loaded.\n * @param {Func} callback - Function to execute when image is fully loaded.\n */\n\nfunction onImagesLoaded(images, callback) {\n  var self = this,\n      unloaded = images.length;\n\n  if (unloaded === 0) {\n    callback();\n  }\n\n  images.each(function () {\n    // Check if image is loaded\n    if (this.complete && typeof this.naturalWidth !== 'undefined') {\n      singleImageLoaded();\n    } else {\n      // If the above check failed, simulate loading on detached element.\n      var image = new Image(); // Still count image as loaded if it finalizes with an error.\n\n      var events = \"load.zf.images error.zf.images\";\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(image).one(events, function me(event) {\n        // Unbind the event listeners. We're using 'one' but only one of the two events will have fired.\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).off(events, me);\n        singleImageLoaded();\n      });\n      image.src = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('src');\n    }\n  });\n\n  function singleImageLoaded() {\n    unloaded--;\n\n    if (unloaded === 0) {\n      callback();\n    }\n  }\n}\n\n\n\n/***/ }),\n\n/***/ 22:\n/*!*****************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.imageLoader.js ***!\n  \\*****************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.imageLoader.js */\"./js/entries/plugins/foundation.util.imageLoader.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.imageLoader.js.map"]}
\ No newline at end of file
index c01e5a6e34dbfa6fb1f5aef5d157549345bfdad7..bb00c121fb2da211339c6046cf8a0e2830ec122d 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.keyboard"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.keyboard"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 102);
+/******/       return __webpack_require__(__webpack_require__.s = 23);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 102:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(36);
-
-
-/***/ }),
-
-/***/ 3:
-/***/ (function(module, exports) {
-
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
-
-/***/ }),
-
-/***/ 36:
+/***/ "./js/entries/plugins/foundation.util.keyboard.js":
+/*!********************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.keyboard.js ***!
+  \********************************************************/
+/*! exports provided: Foundation, Keyboard */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__ = __webpack_require__(66);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
+
+/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.keyboard */ "./js/foundation.util.keyboard.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Keyboard", function() { return _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"]; });
 
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].Keyboard = __WEBPACK_IMPORTED_MODULE_1__foundation_util_keyboard__["a" /* Keyboard */];
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].Keyboard = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__["Keyboard"];
+
 
 /***/ }),
 
-/***/ 66:
+/***/ "./js/foundation.util.keyboard.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.keyboard.js ***!
+  \****************************************/
+/*! exports provided: Keyboard */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Keyboard; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Keyboard", function() { return Keyboard; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
 /*******************************************
  *                                         *
  * This util was created by Marius Olbertz *
@@ -132,8 +155,6 @@ __WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].Keyboard = __WEBPAC
 
 
 
-
-
 var keyCodes = {
   9: 'TAB',
   13: 'ENTER',
@@ -146,35 +167,32 @@ var keyCodes = {
   39: 'ARROW_RIGHT',
   40: 'ARROW_DOWN'
 };
+var commands = {}; // Functions pulled out to be referenceable from internals
 
-var commands = {};
-
-// Functions pulled out to be referenceable from internals
 function findFocusable($element) {
   if (!$element) {
     return false;
   }
+
   return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function () {
-    if (!__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).is(':visible') || __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).attr('tabindex') < 0) {
+    if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':visible') || jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('tabindex') < 0) {
       return false;
     } //only have visible elements and those that have a tabindex greater or equal 0
+
+
     return true;
   });
 }
 
 function parseKey(event) {
-  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();
+  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase(); // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events
 
-  // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events
   key = key.replace(/\W+/, '');
+  if (event.shiftKey) key = "SHIFT_".concat(key);
+  if (event.ctrlKey) key = "CTRL_".concat(key);
+  if (event.altKey) key = "ALT_".concat(key); // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)
 
-  if (event.shiftKey) key = 'SHIFT_' + key;
-  if (event.ctrlKey) key = 'CTRL_' + key;
-  if (event.altKey) key = 'ALT_' + key;
-
-  // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)
   key = key.replace(/_$/, '');
-
   return key;
 }
 
@@ -195,13 +213,12 @@ var Keyboard = {
    * @param {String} component - Foundation component's name, e.g. Slider or Reveal
    * @param {Objects} functions - collection of functions that are to be executed
    */
-  handleKey: function (event, component, functions) {
+  handleKey: function handleKey(event, component, functions) {
     var commandList = commands[component],
         keyCode = this.parseKey(event),
         cmds,
         command,
         fn;
-
     if (!commandList) return console.warn('Component not defined!');
 
     if (typeof commandList.ltr === 'undefined') {
@@ -209,14 +226,16 @@ var Keyboard = {
       cmds = commandList; // use plain list
     } else {
       // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa
-      if (__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["rtl"])()) cmds = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, commandList.ltr, commandList.rtl);else cmds = __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.extend({}, commandList.rtl, commandList.ltr);
+      if (Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["rtl"])()) cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.ltr, commandList.rtl);else cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.rtl, commandList.ltr);
     }
-    command = cmds[keyCode];
 
+    command = cmds[keyCode];
     fn = functions[command];
+
     if (fn && typeof fn === 'function') {
       // execute function  if exists
       var returnValue = fn.apply();
+
       if (functions.handled || typeof functions.handled === 'function') {
         // execute function when event was handled
         functions.handled(returnValue);
@@ -229,13 +248,11 @@ var Keyboard = {
     }
   },
 
-
   /**
    * Finds all focusable elements within the given `$element`
    * @param {jQuery} $element - jQuery object to search within
    * @return {jQuery} $focusable - all focusable elements within `$element`
    */
-
   findFocusable: findFocusable,
 
   /**
@@ -243,23 +260,20 @@ var Keyboard = {
    * @param {Object} component - Foundation component, e.g. Slider or Reveal
    * @return String componentName
    */
-
-  register: function (componentName, cmds) {
+  register: function register(componentName, cmds) {
     commands[componentName] = cmds;
   },
-
-
   // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?
   //
+
   /**
    * Traps the focus in the given element.
    * @param  {jQuery} $element  jQuery object to trap the foucs into.
    */
-  trapFocus: function ($element) {
+  trapFocus: function trapFocus($element) {
     var $focusable = findFocusable($element),
         $firstFocusable = $focusable.eq(0),
         $lastFocusable = $focusable.eq(-1);
-
     $element.on('keydown.zf.trapfocus', function (event) {
       if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {
         event.preventDefault();
@@ -275,24 +289,52 @@ var Keyboard = {
    * Releases the trapped focus from the given element.
    * @param  {jQuery} $element  jQuery object to release the focus for.
    */
-  releaseFocus: function ($element) {
+  releaseFocus: function releaseFocus($element) {
     $element.off('keydown.zf.trapfocus');
   }
 };
-
 /*
  * Constants for easier comparing.
  * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE
  */
+
 function getKeyCodes(kcs) {
   var k = {};
+
   for (var kc in kcs) {
     k[kcs[kc]] = kcs[kc];
-  }return k;
+  }
+
+  return k;
 }
 
 
 
+/***/ }),
+
+/***/ 23:
+/*!**************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.keyboard.js ***!
+  \**************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.keyboard.js */"./js/entries/plugins/foundation.util.keyboard.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
+
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.keyboard.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.keyboard.js.map b/dist/js/plugins/foundation.util.keyboard.js.map
new file mode 100644 (file)
index 0000000..c3fb228
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.keyboard.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.keyboard.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","Keyboard","keyCodes","commands","findFocusable","$element","find","filter","$","is","attr","parseKey","event","key","which","keyCode","String","fromCharCode","toUpperCase","replace","shiftKey","ctrlKey","altKey","keys","getKeyCodes","handleKey","component","functions","commandList","cmds","command","fn","console","warn","ltr","Rtl","extend","rtl","returnValue","apply","handled","unhandled","register","componentName","trapFocus","$focusable","$firstFocusable","eq","$lastFocusable","on","target","preventDefault","focus","releaseFocus","off","kcs","k","kc"],"mappings":"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","file":"foundation.util.keyboard.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.keyboard\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 23);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\nimport { Keyboard } from '../../foundation.util.keyboard';\n\nFoundation.Keyboard = Keyboard;\n\nexport { Foundation, Keyboard };\n","/*******************************************\n *                                         *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n *                                         *\n ******************************************/\n\n'use strict';\n\nimport $ from 'jquery';\nimport { rtl as Rtl } from './foundation.core.utils';\n\nconst keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  35: 'END',\n  36: 'HOME',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n}\n\nvar commands = {}\n\n// Functions pulled out to be referenceable from internals\nfunction findFocusable($element) {\n  if(!$element) {return false; }\n  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function() {\n    if (!$(this).is(':visible') || $(this).attr('tabindex') < 0) { return false; } //only have visible elements and those that have a tabindex greater or equal 0\n    return true;\n  });\n}\n\nfunction parseKey(event) {\n  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase();\n\n  // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n  key = key.replace(/\\W+/, '');\n\n  if (event.shiftKey) key = `SHIFT_${key}`;\n  if (event.ctrlKey) key = `CTRL_${key}`;\n  if (event.altKey) key = `ALT_${key}`;\n\n  // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n  key = key.replace(/_$/, '');\n\n  return key;\n}\n\nvar Keyboard = {\n  keys: getKeyCodes(keyCodes),\n\n  /**\n   * Parses the (keyboard) event and returns a String that represents its key\n   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n   * @param {Event} event - the event generated by the event handler\n   * @return String key - String that represents the key pressed\n   */\n  parseKey: parseKey,\n\n  /**\n   * Handles the given (keyboard) event\n   * @param {Event} event - the event generated by the event handler\n   * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n   * @param {Objects} functions - collection of functions that are to be executed\n   */\n  handleKey(event, component, functions) {\n    var commandList = commands[component],\n      keyCode = this.parseKey(event),\n      cmds,\n      command,\n      fn;\n\n    if (!commandList) return console.warn('Component not defined!');\n\n    if (typeof commandList.ltr === 'undefined') { // this component does not differentiate between ltr and rtl\n        cmds = commandList; // use plain list\n    } else { // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n        if (Rtl()) cmds = $.extend({}, commandList.ltr, commandList.rtl);\n\n        else cmds = $.extend({}, commandList.rtl, commandList.ltr);\n    }\n    command = cmds[keyCode];\n\n    fn = functions[command];\n    if (fn && typeof fn === 'function') { // execute function  if exists\n      var returnValue = fn.apply();\n      if (functions.handled || typeof functions.handled === 'function') { // execute function when event was handled\n          functions.handled(returnValue);\n      }\n    } else {\n      if (functions.unhandled || typeof functions.unhandled === 'function') { // execute function when event was not handled\n          functions.unhandled();\n      }\n    }\n  },\n\n  /**\n   * Finds all focusable elements within the given `$element`\n   * @param {jQuery} $element - jQuery object to search within\n   * @return {jQuery} $focusable - all focusable elements within `$element`\n   */\n\n  findFocusable: findFocusable,\n\n  /**\n   * Returns the component name name\n   * @param {Object} component - Foundation component, e.g. Slider or Reveal\n   * @return String componentName\n   */\n\n  register(componentName, cmds) {\n    commands[componentName] = cmds;\n  },\n\n\n  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n  //\n  /**\n   * Traps the focus in the given element.\n   * @param  {jQuery} $element  jQuery object to trap the foucs into.\n   */\n  trapFocus($element) {\n    var $focusable = findFocusable($element),\n        $firstFocusable = $focusable.eq(0),\n        $lastFocusable = $focusable.eq(-1);\n\n    $element.on('keydown.zf.trapfocus', function(event) {\n      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      }\n      else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n        event.preventDefault();\n        $lastFocusable.focus();\n      }\n    });\n  },\n  /**\n   * Releases the trapped focus from the given element.\n   * @param  {jQuery} $element  jQuery object to release the focus for.\n   */\n  releaseFocus($element) {\n    $element.off('keydown.zf.trapfocus');\n  }\n}\n\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\nfunction getKeyCodes(kcs) {\n  var k = {};\n  for (var kc in kcs) k[kcs[kc]] = kcs[kc];\n  return k;\n}\n\nexport {Keyboard};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 4c7a603b2ce7d93abbdbe31cc9e72c593e746a4d..5c179267b0d1d36c134dd368f09d4492f4401622 100644 (file)
@@ -1 +1,2 @@
-!function(n){function t(o){if(e[o])return e[o].exports;var r=e[o]={i:o,l:!1,exports:{}};return n[o].call(r.exports,r,r.exports,t),r.l=!0,r.exports}var e={};t.m=n,t.c=e,t.i=function(n){return n},t.d=function(n,e,o){t.o(n,e)||Object.defineProperty(n,e,{configurable:!1,enumerable:!0,get:o})},t.n=function(n){var e=n&&n.__esModule?function(){return n.default}:function(){return n};return t.d(e,"a",e),e},t.o=function(n,t){return Object.prototype.hasOwnProperty.call(n,t)},t.p="",t(t.s=102)}({0:function(n,t){n.exports=jQuery},1:function(n,t){n.exports={Foundation:window.Foundation}},102:function(n,t,e){n.exports=e(36)},3:function(n,t){n.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},36:function(n,t,e){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var o=e(1),r=(e.n(o),e(66));o.Foundation.Keyboard=r.a},66:function(n,t,e){"use strict";function o(n){return!!n&&n.find("a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]").filter(function(){return!(!a()(this).is(":visible")||a()(this).attr("tabindex")<0)})}function r(n){var t=d[n.which||n.keyCode]||String.fromCharCode(n.which).toUpperCase();return t=t.replace(/\W+/,""),n.shiftKey&&(t="SHIFT_"+t),n.ctrlKey&&(t="CTRL_"+t),n.altKey&&(t="ALT_"+t),t=t.replace(/_$/,"")}e.d(t,"a",function(){return c});var i=e(0),a=e.n(i),u=e(3),d=(e.n(u),{9:"TAB",13:"ENTER",27:"ESCAPE",32:"SPACE",35:"END",36:"HOME",37:"ARROW_LEFT",38:"ARROW_UP",39:"ARROW_RIGHT",40:"ARROW_DOWN"}),f={},c={keys:function(n){var t={};for(var e in n)t[n[e]]=n[e];return t}(d),parseKey:r,handleKey:function(n,t,o){var r,i,d,c=f[t],s=this.parseKey(n);if(!c)return console.warn("Component not defined!");if(r=void 0===c.ltr?c:e.i(u.rtl)()?a.a.extend({},c.ltr,c.rtl):a.a.extend({},c.rtl,c.ltr),i=r[s],(d=o[i])&&"function"==typeof d){var l=d.apply();(o.handled||"function"==typeof o.handled)&&o.handled(l)}else(o.unhandled||"function"==typeof o.unhandled)&&o.unhandled()},findFocusable:o,register:function(n,t){f[n]=t},trapFocus:function(n){var t=o(n),e=t.eq(0),i=t.eq(-1);n.on("keydown.zf.trapfocus",function(n){n.target===i[0]&&"TAB"===r(n)?(n.preventDefault(),e.focus()):n.target===e[0]&&"SHIFT_TAB"===r(n)&&(n.preventDefault(),i.focus())})},releaseFocus:function(n){n.off("keydown.zf.trapfocus")}}}});
\ No newline at end of file
+!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],n):"object"==typeof exports?exports["foundation.util.keyboard"]=n(require("./foundation.core"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.util.keyboard"]=n(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.jQuery))}(window,function(t,o){return function(t){var o={};function r(e){if(o[e])return o[e].exports;var n=o[e]={i:e,l:!1,exports:{}};return t[e].call(n.exports,n,n.exports,r),n.l=!0,n.exports}return r.m=t,r.c=o,r.d=function(e,n,t){r.o(e,n)||Object.defineProperty(e,n,{enumerable:!0,get:t})},r.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},r.t=function(n,e){if(1&e&&(n=r(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var t=Object.create(null);if(r.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var o in n)r.d(t,o,function(e){return n[e]}.bind(null,o));return t},r.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return r.d(n,"a",n),n},r.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},r.p="",r(r.s=23)}({"./foundation.core":function(e,n){e.exports=t},"./js/entries/plugins/foundation.util.keyboard.js":function(e,n,t){"use strict";t.r(n);var o=t("./foundation.core");t.d(n,"Foundation",function(){return o.Foundation});var r=t("./js/foundation.util.keyboard.js");t.d(n,"Keyboard",function(){return r.Keyboard}),o.Foundation.Keyboard=r.Keyboard},"./js/foundation.util.keyboard.js":function(e,n,t){"use strict";t.r(n),t.d(n,"Keyboard",function(){return c});var o=t("jquery"),a=t.n(o),f=t("./foundation.core"),r={9:"TAB",13:"ENTER",27:"ESCAPE",32:"SPACE",35:"END",36:"HOME",37:"ARROW_LEFT",38:"ARROW_UP",39:"ARROW_RIGHT",40:"ARROW_DOWN"},d={};function u(e){return!!e&&e.find("a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]").filter(function(){return!(!a()(this).is(":visible")||a()(this).attr("tabindex")<0)})}function i(e){var n=r[e.which||e.keyCode]||String.fromCharCode(e.which).toUpperCase();return n=n.replace(/\W+/,""),e.shiftKey&&(n="SHIFT_".concat(n)),e.ctrlKey&&(n="CTRL_".concat(n)),e.altKey&&(n="ALT_".concat(n)),n=n.replace(/_$/,"")}var c={keys:function(e){var n={};for(var t in e)n[e[t]]=e[t];return n}(r),parseKey:i,handleKey:function(e,n,t){var o,r=d[n],u=this.parseKey(e);if(!r)return console.warn("Component not defined!");if((o=t[(void 0===r.ltr?r:Object(f.rtl)()?a.a.extend({},r.ltr,r.rtl):a.a.extend({},r.rtl,r.ltr))[u]])&&"function"==typeof o){var i=o.apply();(t.handled||"function"==typeof t.handled)&&t.handled(i)}else(t.unhandled||"function"==typeof t.unhandled)&&t.unhandled()},findFocusable:u,register:function(e,n){d[e]=n},trapFocus:function(e){var n=u(e),t=n.eq(0),o=n.eq(-1);e.on("keydown.zf.trapfocus",function(e){e.target===o[0]&&"TAB"===i(e)?(e.preventDefault(),t.focus()):e.target===t[0]&&"SHIFT_TAB"===i(e)&&(e.preventDefault(),o.focus())})},releaseFocus:function(e){e.off("keydown.zf.trapfocus")}}},23:function(e,n,t){e.exports=t("./js/entries/plugins/foundation.util.keyboard.js")},jquery:function(e,n){e.exports=o}})});
+//# sourceMappingURL=foundation.util.keyboard.min.js.map
diff --git a/dist/js/plugins/foundation.util.keyboard.min.js.map b/dist/js/plugins/foundation.util.keyboard.min.js.map
new file mode 100644 (file)
index 0000000..5165447
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.keyboard.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.util.keyboard.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__","Keyboard","./js/foundation.util.keyboard.js","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","keyCodes","9","13","27","32","35","36","37","38","39","40","commands","findFocusable","$element","find","filter","this","is","attr","parseKey","event","which","keyCode","String","fromCharCode","toUpperCase","replace","shiftKey","concat","ctrlKey","altKey","keys","kcs","k","kc","getKeyCodes","handleKey","component","functions","fn","commandList","console","warn","ltr","a","extend","rtl","returnValue","apply","handled","unhandled","register","componentName","cmds","trapFocus","$focusable","$firstFocusable","eq","$lastFocusable","on","target","preventDefault","focus","releaseFocus","off","23","jquery"],"mappings":"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","file":"foundation.util.keyboard.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.keyboard\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.keyboard\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 23);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.keyboard.js\":\n/*!********************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.keyboard.js ***!\n  \\********************************************************/\n/*! exports provided: Foundation, Keyboard */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.keyboard */ \"./js/foundation.util.keyboard.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Keyboard\", function() { return _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].Keyboard = _foundation_util_keyboard__WEBPACK_IMPORTED_MODULE_1__[\"Keyboard\"];\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.keyboard.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.keyboard.js ***!\n  \\****************************************/\n/*! exports provided: Keyboard */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Keyboard\", function() { return Keyboard; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/*******************************************\n *                                         *\n * This util was created by Marius Olbertz *\n * Please thank Marius on GitHub /owlbertz *\n * or the web http://www.mariusolbertz.de/ *\n *                                         *\n ******************************************/\n\n\n\n\nvar keyCodes = {\n  9: 'TAB',\n  13: 'ENTER',\n  27: 'ESCAPE',\n  32: 'SPACE',\n  35: 'END',\n  36: 'HOME',\n  37: 'ARROW_LEFT',\n  38: 'ARROW_UP',\n  39: 'ARROW_RIGHT',\n  40: 'ARROW_DOWN'\n};\nvar commands = {}; // Functions pulled out to be referenceable from internals\n\nfunction findFocusable($element) {\n  if (!$element) {\n    return false;\n  }\n\n  return $element.find('a[href], area[href], input:not([disabled]), select:not([disabled]), textarea:not([disabled]), button:not([disabled]), iframe, object, embed, *[tabindex], *[contenteditable]').filter(function () {\n    if (!jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).is(':visible') || jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).attr('tabindex') < 0) {\n      return false;\n    } //only have visible elements and those that have a tabindex greater or equal 0\n\n\n    return true;\n  });\n}\n\nfunction parseKey(event) {\n  var key = keyCodes[event.which || event.keyCode] || String.fromCharCode(event.which).toUpperCase(); // Remove un-printable characters, e.g. for `fromCharCode` calls for CTRL only events\n\n  key = key.replace(/\\W+/, '');\n  if (event.shiftKey) key = \"SHIFT_\".concat(key);\n  if (event.ctrlKey) key = \"CTRL_\".concat(key);\n  if (event.altKey) key = \"ALT_\".concat(key); // Remove trailing underscore, in case only modifiers were used (e.g. only `CTRL_ALT`)\n\n  key = key.replace(/_$/, '');\n  return key;\n}\n\nvar Keyboard = {\n  keys: getKeyCodes(keyCodes),\n\n  /**\n   * Parses the (keyboard) event and returns a String that represents its key\n   * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n   * @param {Event} event - the event generated by the event handler\n   * @return String key - String that represents the key pressed\n   */\n  parseKey: parseKey,\n\n  /**\n   * Handles the given (keyboard) event\n   * @param {Event} event - the event generated by the event handler\n   * @param {String} component - Foundation component's name, e.g. Slider or Reveal\n   * @param {Objects} functions - collection of functions that are to be executed\n   */\n  handleKey: function handleKey(event, component, functions) {\n    var commandList = commands[component],\n        keyCode = this.parseKey(event),\n        cmds,\n        command,\n        fn;\n    if (!commandList) return console.warn('Component not defined!');\n\n    if (typeof commandList.ltr === 'undefined') {\n      // this component does not differentiate between ltr and rtl\n      cmds = commandList; // use plain list\n    } else {\n      // merge ltr and rtl: if document is rtl, rtl overwrites ltr and vice versa\n      if (Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"rtl\"])()) cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.ltr, commandList.rtl);else cmds = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.extend({}, commandList.rtl, commandList.ltr);\n    }\n\n    command = cmds[keyCode];\n    fn = functions[command];\n\n    if (fn && typeof fn === 'function') {\n      // execute function  if exists\n      var returnValue = fn.apply();\n\n      if (functions.handled || typeof functions.handled === 'function') {\n        // execute function when event was handled\n        functions.handled(returnValue);\n      }\n    } else {\n      if (functions.unhandled || typeof functions.unhandled === 'function') {\n        // execute function when event was not handled\n        functions.unhandled();\n      }\n    }\n  },\n\n  /**\n   * Finds all focusable elements within the given `$element`\n   * @param {jQuery} $element - jQuery object to search within\n   * @return {jQuery} $focusable - all focusable elements within `$element`\n   */\n  findFocusable: findFocusable,\n\n  /**\n   * Returns the component name name\n   * @param {Object} component - Foundation component, e.g. Slider or Reveal\n   * @return String componentName\n   */\n  register: function register(componentName, cmds) {\n    commands[componentName] = cmds;\n  },\n  // TODO9438: These references to Keyboard need to not require global. Will 'this' work in this context?\n  //\n\n  /**\n   * Traps the focus in the given element.\n   * @param  {jQuery} $element  jQuery object to trap the foucs into.\n   */\n  trapFocus: function trapFocus($element) {\n    var $focusable = findFocusable($element),\n        $firstFocusable = $focusable.eq(0),\n        $lastFocusable = $focusable.eq(-1);\n    $element.on('keydown.zf.trapfocus', function (event) {\n      if (event.target === $lastFocusable[0] && parseKey(event) === 'TAB') {\n        event.preventDefault();\n        $firstFocusable.focus();\n      } else if (event.target === $firstFocusable[0] && parseKey(event) === 'SHIFT_TAB') {\n        event.preventDefault();\n        $lastFocusable.focus();\n      }\n    });\n  },\n\n  /**\n   * Releases the trapped focus from the given element.\n   * @param  {jQuery} $element  jQuery object to release the focus for.\n   */\n  releaseFocus: function releaseFocus($element) {\n    $element.off('keydown.zf.trapfocus');\n  }\n};\n/*\n * Constants for easier comparing.\n * Can be used like Foundation.parseKey(event) === Foundation.keys.SPACE\n */\n\nfunction getKeyCodes(kcs) {\n  var k = {};\n\n  for (var kc in kcs) {\n    k[kcs[kc]] = kcs[kc];\n  }\n\n  return k;\n}\n\n\n\n/***/ }),\n\n/***/ 23:\n/*!**************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.keyboard.js ***!\n  \\**************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.keyboard.js */\"./js/entries/plugins/foundation.util.keyboard.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.keyboard.js.map"]}
\ No newline at end of file
index 2d4789d53af2d32fad467fb5177b5889970fcb81..ce57c543853ddd14526d3d98f5d620b7cd54bd10 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.mediaQuery"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.mediaQuery"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 103);
+/******/       return __webpack_require__(__webpack_require__.s = 24);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 103:
-/***/ (function(module, exports, __webpack_require__) {
+/***/ "./js/entries/plugins/foundation.util.mediaQuery.js":
+/*!**********************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.mediaQuery.js ***!
+  \**********************************************************/
+/*! exports provided: Foundation, MediaQuery */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-module.exports = __webpack_require__(37);
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.mediaQuery */ "./js/foundation.util.mediaQuery.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "MediaQuery", function() { return _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"]; });
 
-/***/ }),
 
-/***/ 37:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__ = __webpack_require__(67);
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].MediaQuery = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__["MediaQuery"];
 
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].MediaQuery._init();
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].MediaQuery = __WEBPACK_IMPORTED_MODULE_1__foundation_util_mediaQuery__["a" /* MediaQuery */];
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].MediaQuery._init();
 
 /***/ }),
 
-/***/ 67:
+/***/ "./js/foundation.util.mediaQuery.js":
+/*!******************************************!*\
+  !*** ./js/foundation.util.mediaQuery.js ***!
+  \******************************************/
+/*! exports provided: MediaQuery */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return MediaQuery; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "MediaQuery", function() { return MediaQuery; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 
 
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
+ // Default set of media queries
 
-// Default set of media queries
 var defaultQueries = {
   'default': 'only screen',
   landscape: 'only screen and (orientation: landscape)',
   portrait: 'only screen and (orientation: portrait)',
   retina: 'only screen and (-webkit-min-device-pixel-ratio: 2),' + 'only screen and (min--moz-device-pixel-ratio: 2),' + 'only screen and (-o-min-device-pixel-ratio: 2/1),' + 'only screen and (min-device-pixel-ratio: 2),' + 'only screen and (min-resolution: 192dpi),' + 'only screen and (min-resolution: 2dppx)'
-};
+}; // matchMedia() polyfill - Test a CSS media type/query in JS.
+// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license
 
-// matchMedia() polyfill - Test a CSS media type/query in JS.
-// Authors & copyright (c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. Dual MIT/BSD license
-var matchMedia = window.matchMedia || function () {
-  'use strict';
+/* eslint-disable */
 
-  // For browsers that support matchMedium api such as IE 9 and webkit
+window.matchMedia || (window.matchMedia = function () {
+  "use strict"; // For browsers that support matchMedium api such as IE 9 and webkit
 
-  var styleMedia = window.styleMedia || window.media;
+  var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium
 
-  // For those that don't support matchMedium
   if (!styleMedia) {
     var style = document.createElement('style'),
         script = document.getElementsByTagName('script')[0],
         info = null;
-
     style.type = 'text/css';
     style.id = 'matchmediajs-test';
 
-    script && script.parentNode && script.parentNode.insertBefore(style, script);
+    if (!script) {
+      document.head.appendChild(style);
+    } else {
+      script.parentNode.insertBefore(style, script);
+    } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
 
-    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers
-    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;
 
+    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;
     styleMedia = {
-      matchMedium: function (media) {
-        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';
+      matchMedium: function matchMedium(media) {
+        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
 
-        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers
         if (style.styleSheet) {
           style.styleSheet.cssText = text;
         } else {
           style.textContent = text;
-        }
+        } // Test if media query is true or false
+
 
-        // Test if media query is true or false
         return info.width === '1px';
       }
     };
@@ -171,11 +203,11 @@ var matchMedia = window.matchMedia || function () {
       media: media || 'all'
     };
   };
-}();
+}());
+/* eslint-enable */
 
 var MediaQuery = {
   queries: [],
-
   current: '',
 
   /**
@@ -183,23 +215,23 @@ var MediaQuery = {
    * @function
    * @private
    */
-  _init: function () {
+  _init: function _init() {
     var self = this;
-    var $meta = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('meta.foundation-mq');
+    var $meta = jquery__WEBPACK_IMPORTED_MODULE_0___default()('meta.foundation-mq');
+
     if (!$meta.length) {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()('<meta class="foundation-mq">').appendTo(document.head);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()('<meta class="foundation-mq">').appendTo(document.head);
     }
 
-    var extractedStyles = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('.foundation-mq').css('font-family');
+    var extractedStyles = jquery__WEBPACK_IMPORTED_MODULE_0___default()('.foundation-mq').css('font-family');
     var namedQueries;
-
     namedQueries = parseStyleToObject(extractedStyles);
 
     for (var key in namedQueries) {
       if (namedQueries.hasOwnProperty(key)) {
         self.queries.push({
           name: key,
-          value: 'only screen and (min-width: ' + namedQueries[key] + ')'
+          value: "only screen and (min-width: ".concat(namedQueries[key], ")")
         });
       }
     }
@@ -209,48 +241,47 @@ var MediaQuery = {
     this._watcher();
   },
 
-
   /**
    * Checks if the screen is at least as wide as a breakpoint.
    * @function
    * @param {String} size - Name of the breakpoint to check.
    * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.
    */
-  atLeast: function (size) {
+  atLeast: function atLeast(size) {
     var query = this.get(size);
 
     if (query) {
-      return matchMedia(query).matches;
+      return window.matchMedia(query).matches;
     }
 
     return false;
   },
 
-
   /**
    * Checks if the screen matches to a breakpoint.
    * @function
    * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.
    * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.
    */
-  is: function (size) {
+  is: function is(size) {
     size = size.trim().split(' ');
+
     if (size.length > 1 && size[1] === 'only') {
       if (size[0] === this._getCurrentSize()) return true;
     } else {
       return this.atLeast(size[0]);
     }
+
     return false;
   },
 
-
   /**
    * Gets the media query of a breakpoint.
    * @function
    * @param {String} size - Name of the breakpoint to get.
    * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.
    */
-  get: function (size) {
+  get: function get(size) {
     for (var i in this.queries) {
       if (this.queries.hasOwnProperty(i)) {
         var query = this.queries[i];
@@ -261,56 +292,52 @@ var MediaQuery = {
     return null;
   },
 
-
   /**
    * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).
    * @function
    * @private
    * @returns {String} Name of the current breakpoint.
    */
-  _getCurrentSize: function () {
+  _getCurrentSize: function _getCurrentSize() {
     var matched;
 
     for (var i = 0; i < this.queries.length; i++) {
       var query = this.queries[i];
 
-      if (matchMedia(query.value).matches) {
+      if (window.matchMedia(query.value).matches) {
         matched = query;
       }
     }
 
-    if (typeof matched === 'object') {
+    if (_typeof(matched) === 'object') {
       return matched.name;
     } else {
       return matched;
     }
   },
 
-
   /**
    * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.
    * @function
    * @private
    */
-  _watcher: function () {
+  _watcher: function _watcher() {
     var _this = this;
 
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {
       var newSize = _this._getCurrentSize(),
           currentSize = _this.current;
 
       if (newSize !== currentSize) {
         // Change the current media query
-        _this.current = newSize;
+        _this.current = newSize; // Broadcast the media query change on the window
 
-        // Broadcast the media query change on the window
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);
       }
     });
   }
-};
+}; // Thank you: https://github.com/sindresorhus/query-string
 
-// Thank you: https://github.com/sindresorhus/query-string
 function parseStyleToObject(str) {
   var styleObject = {};
 
@@ -328,11 +355,10 @@ function parseStyleToObject(str) {
     var parts = param.replace(/\+/g, ' ').split('=');
     var key = parts[0];
     var val = parts[1];
-    key = decodeURIComponent(key);
-
-    // missing `=` should be `null`:
+    key = decodeURIComponent(key); // missing `=` should be `null`:
     // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters
-    val = val === undefined ? null : decodeURIComponent(val);
+
+    val = typeof val === 'undefined' ? null : decodeURIComponent(val);
 
     if (!ret.hasOwnProperty(key)) {
       ret[key] = val;
@@ -341,14 +367,39 @@ function parseStyleToObject(str) {
     } else {
       ret[key] = [ret[key], val];
     }
+
     return ret;
   }, {});
-
   return styleObject;
 }
 
 
 
+/***/ }),
+
+/***/ 24:
+/*!****************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.mediaQuery.js ***!
+  \****************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.mediaQuery.js */"./js/entries/plugins/foundation.util.mediaQuery.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
+
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.mediaQuery.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.mediaQuery.js.map b/dist/js/plugins/foundation.util.mediaQuery.js.map
new file mode 100644 (file)
index 0000000..4def6df
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.mediaQuery.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.mediaQuery.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","MediaQuery","_init","defaultQueries","landscape","portrait","retina","window","matchMedia","styleMedia","media","style","document","createElement","script","getElementsByTagName","info","type","id","head","appendChild","parentNode","insertBefore","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","matches","queries","current","self","$meta","$","length","appendTo","extractedStyles","css","namedQueries","parseStyleToObject","key","hasOwnProperty","push","name","value","_getCurrentSize","_watcher","atLeast","size","query","get","is","trim","split","i","matched","off","on","newSize","currentSize","trigger","str","styleObject","slice","reduce","ret","param","parts","replace","val","decodeURIComponent","Array","isArray"],"mappings":"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","file":"foundation.util.mediaQuery.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.mediaQuery\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 24);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\nimport { MediaQuery } from '../../foundation.util.mediaQuery';\n\nFoundation.MediaQuery = MediaQuery;\nFoundation.MediaQuery._init();\n\nexport { Foundation, MediaQuery };\n","'use strict';\n\nimport $ from 'jquery';\n\n// Default set of media queries\nconst defaultQueries = {\n  'default' : 'only screen',\n  landscape : 'only screen and (orientation: landscape)',\n  portrait : 'only screen and (orientation: portrait)',\n  retina : 'only screen and (-webkit-min-device-pixel-ratio: 2),' +\n    'only screen and (min--moz-device-pixel-ratio: 2),' +\n    'only screen and (-o-min-device-pixel-ratio: 2/1),' +\n    'only screen and (min-device-pixel-ratio: 2),' +\n    'only screen and (min-resolution: 192dpi),' +\n    'only screen and (min-resolution: 2dppx)'\n  };\n\n\n// matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n/* eslint-disable */\nwindow.matchMedia || (window.matchMedia = (function () {\n  \"use strict\";\n\n  // For browsers that support matchMedium api such as IE 9 and webkit\n  var styleMedia = (window.styleMedia || window.media);\n\n  // For those that don't support matchMedium\n  if (!styleMedia) {\n    var style   = document.createElement('style'),\n    script      = document.getElementsByTagName('script')[0],\n    info        = null;\n\n    style.type  = 'text/css';\n    style.id    = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    }\n\n    // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n    info = ('getComputedStyle' in window) && window.getComputedStyle(style, null) || style.currentStyle;\n\n    styleMedia = {\n      matchMedium: function (media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }';\n\n        // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        }\n\n        // Test if media query is true or false\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function(media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n})());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init() {\n    var self = this;\n    var $meta = $('meta.foundation-mq');\n    if(!$meta.length){\n      $('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = $('.foundation-mq').css('font-family');\n    var namedQueries;\n\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if(namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: `only screen and (min-width: ${namedQueries[key]})`\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is(size) {\n    size = size.trim().split(' ');\n    if(size.length > 1 && size[1] === 'only') {\n      if(size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get(size) {\n    for (var i in this.queries) {\n      if(this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (typeof matched === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher() {\n    $(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', () => {\n      var newSize = this._getCurrentSize(), currentSize = this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        this.current = newSize;\n\n        // Broadcast the media query change on the window\n        $(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n};\n\n\n\n// Thank you: https://github.com/sindresorhus/query-string\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function(ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key);\n\n    // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n    return ret;\n  }, {});\n\n  return styleObject;\n}\n\nexport {MediaQuery};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 40191736353b6c4b7588b7c39a2e9bc7d70a679b..1c3ef1fec3ae887ec313585576802d7204ccc204 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(r){if(n[r])return n[r].exports;var i=n[r]={i:r,l:!1,exports:{}};return e[r].call(i.exports,i,i.exports,t),i.l=!0,i.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,r){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=103)}({0:function(e,t){e.exports=jQuery},1:function(e,t){e.exports={Foundation:window.Foundation}},103:function(e,t,n){e.exports=n(37)},37:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=n(1),i=(n.n(r),n(67));r.Foundation.MediaQuery=i.a,r.Foundation.MediaQuery._init()},67:function(e,t,n){"use strict";function r(e){var t={};return"string"!=typeof e?t:(e=e.trim().slice(1,-1))?t=e.split("&").reduce(function(e,t){var n=t.replace(/\+/g," ").split("="),r=n[0],i=n[1];return r=decodeURIComponent(r),i=void 0===i?null:decodeURIComponent(i),e.hasOwnProperty(r)?Array.isArray(e[r])?e[r].push(i):e[r]=[e[r],i]:e[r]=i,e},{}):t}n.d(t,"a",function(){return a});var i=n(0),u=n.n(i),o=window.matchMedia||function(){var e=window.styleMedia||window.media;if(!e){var t=document.createElement("style"),n=document.getElementsByTagName("script")[0],r=null;t.type="text/css",t.id="matchmediajs-test",n&&n.parentNode&&n.parentNode.insertBefore(t,n),r="getComputedStyle"in window&&window.getComputedStyle(t,null)||t.currentStyle,e={matchMedium:function(e){var n="@media "+e+"{ #matchmediajs-test { width: 1px; } }";return t.styleSheet?t.styleSheet.cssText=n:t.textContent=n,"1px"===r.width}}}return function(t){return{matches:e.matchMedium(t||"all"),media:t||"all"}}}(),a={queries:[],current:"",_init:function(){var e=this;u()("meta.foundation-mq").length||u()('<meta class="foundation-mq">').appendTo(document.head);var t,n=u()(".foundation-mq").css("font-family");t=r(n);for(var i in t)t.hasOwnProperty(i)&&e.queries.push({name:i,value:"only screen and (min-width: "+t[i]+")"});this.current=this._getCurrentSize(),this._watcher()},atLeast:function(e){var t=this.get(e);return!!t&&o(t).matches},is:function(e){return e=e.trim().split(" "),e.length>1&&"only"===e[1]?e[0]===this._getCurrentSize():this.atLeast(e[0])},get:function(e){for(var t in this.queries)if(this.queries.hasOwnProperty(t)){var n=this.queries[t];if(e===n.name)return n.value}return null},_getCurrentSize:function(){for(var e,t=0;t<this.queries.length;t++){var n=this.queries[t];o(n.value).matches&&(e=n)}return"object"==typeof e?e.name:e},_watcher:function(){var e=this;u()(window).off("resize.zf.mediaquery").on("resize.zf.mediaquery",function(){var t=e._getCurrentSize(),n=e.current;t!==n&&(e.current=t,u()(window).trigger("changed.zf.mediaquery",[t,n]))})}}}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],t):"object"==typeof exports?exports["foundation.util.mediaQuery"]=t(require("./foundation.core"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.util.mediaQuery"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.jQuery))}(window,function(n,r){return function(n){var r={};function i(e){if(r[e])return r[e].exports;var t=r[e]={i:e,l:!1,exports:{}};return n[e].call(t.exports,t,t.exports,i),t.l=!0,t.exports}return i.m=n,i.c=r,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var r in t)i.d(n,r,function(e){return t[e]}.bind(null,r));return n},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="",i(i.s=24)}({"./foundation.core":function(e,t){e.exports=n},"./js/entries/plugins/foundation.util.mediaQuery.js":function(e,t,n){"use strict";n.r(t);var r=n("./foundation.core");n.d(t,"Foundation",function(){return r.Foundation});var i=n("./js/foundation.util.mediaQuery.js");n.d(t,"MediaQuery",function(){return i.MediaQuery}),r.Foundation.MediaQuery=i.MediaQuery,r.Foundation.MediaQuery._init()},"./js/foundation.util.mediaQuery.js":function(e,t,n){"use strict";n.r(t),n.d(t,"MediaQuery",function(){return u});var r=n("jquery"),o=n.n(r);function i(e){return(i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}window.matchMedia||(window.matchMedia=function(){var t=window.styleMedia||window.media;if(!t){var n,r=document.createElement("style"),e=document.getElementsByTagName("script")[0];r.type="text/css",r.id="matchmediajs-test",e?e.parentNode.insertBefore(r,e):document.head.appendChild(r),n="getComputedStyle"in window&&window.getComputedStyle(r,null)||r.currentStyle,t={matchMedium:function(e){var t="@media "+e+"{ #matchmediajs-test { width: 1px; } }";return r.styleSheet?r.styleSheet.cssText=t:r.textContent=t,"1px"===n.width}}}return function(e){return{matches:t.matchMedium(e||"all"),media:e||"all"}}}());var u={queries:[],current:"",_init:function(){o()("meta.foundation-mq").length||o()('<meta class="foundation-mq">').appendTo(document.head);var e,t,n,r=o()(".foundation-mq").css("font-family");for(var i in n={},e="string"==typeof(t=r)&&(t=t.trim().slice(1,-1))?n=t.split("&").reduce(function(e,t){var n=t.replace(/\+/g," ").split("="),r=n[0],i=n[1];return r=decodeURIComponent(r),i=void 0===i?null:decodeURIComponent(i),e.hasOwnProperty(r)?Array.isArray(e[r])?e[r].push(i):e[r]=[e[r],i]:e[r]=i,e},{}):n)e.hasOwnProperty(i)&&this.queries.push({name:i,value:"only screen and (min-width: ".concat(e[i],")")});this.current=this._getCurrentSize(),this._watcher()},atLeast:function(e){var t=this.get(e);return!!t&&window.matchMedia(t).matches},is:function(e){return 1<(e=e.trim().split(" ")).length&&"only"===e[1]?e[0]===this._getCurrentSize():this.atLeast(e[0])},get:function(e){for(var t in this.queries)if(this.queries.hasOwnProperty(t)){var n=this.queries[t];if(e===n.name)return n.value}return null},_getCurrentSize:function(){for(var e,t=0;t<this.queries.length;t++){var n=this.queries[t];window.matchMedia(n.value).matches&&(e=n)}return"object"===i(e)?e.name:e},_watcher:function(){var n=this;o()(window).off("resize.zf.mediaquery").on("resize.zf.mediaquery",function(){var e=n._getCurrentSize(),t=n.current;e!==t&&(n.current=e,o()(window).trigger("changed.zf.mediaquery",[e,t]))})}}},24:function(e,t,n){e.exports=n("./js/entries/plugins/foundation.util.mediaQuery.js")},jquery:function(e,t){e.exports=r}})});
+//# sourceMappingURL=foundation.util.mediaQuery.min.js.map
diff --git a/dist/js/plugins/foundation.util.mediaQuery.min.js.map b/dist/js/plugins/foundation.util.mediaQuery.min.js.map
new file mode 100644 (file)
index 0000000..d388595
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.mediaQuery.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.util.mediaQuery.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__","MediaQuery","_init","./js/foundation.util.mediaQuery.js","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_typeof","obj","iterator","constructor","matchMedia","styleMedia","media","info","style","document","createElement","script","getElementsByTagName","type","id","parentNode","insertBefore","head","appendChild","getComputedStyle","currentStyle","matchMedium","text","styleSheet","cssText","textContent","width","matches","queries","current","length","appendTo","namedQueries","str","styleObject","extractedStyles","css","trim","slice","split","reduce","ret","param","parts","replace","val","decodeURIComponent","Array","isArray","push","this","concat","_getCurrentSize","_watcher","atLeast","size","query","is","matched","_this","off","on","newSize","currentSize","trigger","24","jquery"],"mappings":"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","file":"foundation.util.mediaQuery.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.mediaQuery\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.mediaQuery\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 24);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.mediaQuery.js\":\n/*!**********************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.mediaQuery.js ***!\n  \\**********************************************************/\n/*! exports provided: Foundation, MediaQuery */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.mediaQuery */ \"./js/foundation.util.mediaQuery.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"MediaQuery\", function() { return _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].MediaQuery = _foundation_util_mediaQuery__WEBPACK_IMPORTED_MODULE_1__[\"MediaQuery\"];\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].MediaQuery._init();\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.mediaQuery.js\":\n/*!******************************************!*\\\n  !*** ./js/foundation.util.mediaQuery.js ***!\n  \\******************************************/\n/*! exports provided: MediaQuery */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"MediaQuery\", function() { return MediaQuery; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n // Default set of media queries\n\nvar defaultQueries = {\n  'default': 'only screen',\n  landscape: 'only screen and (orientation: landscape)',\n  portrait: 'only screen and (orientation: portrait)',\n  retina: 'only screen and (-webkit-min-device-pixel-ratio: 2),' + 'only screen and (min--moz-device-pixel-ratio: 2),' + 'only screen and (-o-min-device-pixel-ratio: 2/1),' + 'only screen and (min-device-pixel-ratio: 2),' + 'only screen and (min-resolution: 192dpi),' + 'only screen and (min-resolution: 2dppx)'\n}; // matchMedia() polyfill - Test a CSS media type/query in JS.\n// Authors & copyright(c) 2012: Scott Jehl, Paul Irish, Nicholas Zakas, David Knight. MIT license\n\n/* eslint-disable */\n\nwindow.matchMedia || (window.matchMedia = function () {\n  \"use strict\"; // For browsers that support matchMedium api such as IE 9 and webkit\n\n  var styleMedia = window.styleMedia || window.media; // For those that don't support matchMedium\n\n  if (!styleMedia) {\n    var style = document.createElement('style'),\n        script = document.getElementsByTagName('script')[0],\n        info = null;\n    style.type = 'text/css';\n    style.id = 'matchmediajs-test';\n\n    if (!script) {\n      document.head.appendChild(style);\n    } else {\n      script.parentNode.insertBefore(style, script);\n    } // 'style.currentStyle' is used by IE <= 8 and 'window.getComputedStyle' for all other browsers\n\n\n    info = 'getComputedStyle' in window && window.getComputedStyle(style, null) || style.currentStyle;\n    styleMedia = {\n      matchMedium: function matchMedium(media) {\n        var text = '@media ' + media + '{ #matchmediajs-test { width: 1px; } }'; // 'style.styleSheet' is used by IE <= 8 and 'style.textContent' for all other browsers\n\n        if (style.styleSheet) {\n          style.styleSheet.cssText = text;\n        } else {\n          style.textContent = text;\n        } // Test if media query is true or false\n\n\n        return info.width === '1px';\n      }\n    };\n  }\n\n  return function (media) {\n    return {\n      matches: styleMedia.matchMedium(media || 'all'),\n      media: media || 'all'\n    };\n  };\n}());\n/* eslint-enable */\n\nvar MediaQuery = {\n  queries: [],\n  current: '',\n\n  /**\n   * Initializes the media query helper, by extracting the breakpoint list from the CSS and activating the breakpoint watcher.\n   * @function\n   * @private\n   */\n  _init: function _init() {\n    var self = this;\n    var $meta = jquery__WEBPACK_IMPORTED_MODULE_0___default()('meta.foundation-mq');\n\n    if (!$meta.length) {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()('<meta class=\"foundation-mq\">').appendTo(document.head);\n    }\n\n    var extractedStyles = jquery__WEBPACK_IMPORTED_MODULE_0___default()('.foundation-mq').css('font-family');\n    var namedQueries;\n    namedQueries = parseStyleToObject(extractedStyles);\n\n    for (var key in namedQueries) {\n      if (namedQueries.hasOwnProperty(key)) {\n        self.queries.push({\n          name: key,\n          value: \"only screen and (min-width: \".concat(namedQueries[key], \")\")\n        });\n      }\n    }\n\n    this.current = this._getCurrentSize();\n\n    this._watcher();\n  },\n\n  /**\n   * Checks if the screen is at least as wide as a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it's smaller.\n   */\n  atLeast: function atLeast(size) {\n    var query = this.get(size);\n\n    if (query) {\n      return window.matchMedia(query).matches;\n    }\n\n    return false;\n  },\n\n  /**\n   * Checks if the screen matches to a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to check, either 'small only' or 'small'. Omitting 'only' falls back to using atLeast() method.\n   * @returns {Boolean} `true` if the breakpoint matches, `false` if it does not.\n   */\n  is: function is(size) {\n    size = size.trim().split(' ');\n\n    if (size.length > 1 && size[1] === 'only') {\n      if (size[0] === this._getCurrentSize()) return true;\n    } else {\n      return this.atLeast(size[0]);\n    }\n\n    return false;\n  },\n\n  /**\n   * Gets the media query of a breakpoint.\n   * @function\n   * @param {String} size - Name of the breakpoint to get.\n   * @returns {String|null} - The media query of the breakpoint, or `null` if the breakpoint doesn't exist.\n   */\n  get: function get(size) {\n    for (var i in this.queries) {\n      if (this.queries.hasOwnProperty(i)) {\n        var query = this.queries[i];\n        if (size === query.name) return query.value;\n      }\n    }\n\n    return null;\n  },\n\n  /**\n   * Gets the current breakpoint name by testing every breakpoint and returning the last one to match (the biggest one).\n   * @function\n   * @private\n   * @returns {String} Name of the current breakpoint.\n   */\n  _getCurrentSize: function _getCurrentSize() {\n    var matched;\n\n    for (var i = 0; i < this.queries.length; i++) {\n      var query = this.queries[i];\n\n      if (window.matchMedia(query.value).matches) {\n        matched = query;\n      }\n    }\n\n    if (_typeof(matched) === 'object') {\n      return matched.name;\n    } else {\n      return matched;\n    }\n  },\n\n  /**\n   * Activates the breakpoint watcher, which fires an event on the window whenever the breakpoint changes.\n   * @function\n   * @private\n   */\n  _watcher: function _watcher() {\n    var _this = this;\n\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off('resize.zf.mediaquery').on('resize.zf.mediaquery', function () {\n      var newSize = _this._getCurrentSize(),\n          currentSize = _this.current;\n\n      if (newSize !== currentSize) {\n        // Change the current media query\n        _this.current = newSize; // Broadcast the media query change on the window\n\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).trigger('changed.zf.mediaquery', [newSize, currentSize]);\n      }\n    });\n  }\n}; // Thank you: https://github.com/sindresorhus/query-string\n\nfunction parseStyleToObject(str) {\n  var styleObject = {};\n\n  if (typeof str !== 'string') {\n    return styleObject;\n  }\n\n  str = str.trim().slice(1, -1); // browsers re-quote string style values\n\n  if (!str) {\n    return styleObject;\n  }\n\n  styleObject = str.split('&').reduce(function (ret, param) {\n    var parts = param.replace(/\\+/g, ' ').split('=');\n    var key = parts[0];\n    var val = parts[1];\n    key = decodeURIComponent(key); // missing `=` should be `null`:\n    // http://w3.org/TR/2012/WD-url-20120524/#collect-url-parameters\n\n    val = typeof val === 'undefined' ? null : decodeURIComponent(val);\n\n    if (!ret.hasOwnProperty(key)) {\n      ret[key] = val;\n    } else if (Array.isArray(ret[key])) {\n      ret[key].push(val);\n    } else {\n      ret[key] = [ret[key], val];\n    }\n\n    return ret;\n  }, {});\n  return styleObject;\n}\n\n\n\n/***/ }),\n\n/***/ 24:\n/*!****************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.mediaQuery.js ***!\n  \\****************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.mediaQuery.js */\"./js/entries/plugins/foundation.util.mediaQuery.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.mediaQuery.js.map"]}
\ No newline at end of file
index 8e86cfd7d59ad58aefab29f7d6741416f04b4712..bb50c518003cd7e107f60cd9471e947327f65e7b 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.motion"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 104);
+/******/       return __webpack_require__(__webpack_require__.s = 25);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 1:
-/***/ (function(module, exports) {
-
-module.exports = {Foundation: window.Foundation};
-
-/***/ }),
-
-/***/ 104:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(38);
-
-
-/***/ }),
-
-/***/ 3:
-/***/ (function(module, exports) {
+/***/ "./js/entries/plugins/foundation.util.motion.js":
+/*!******************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.motion.js ***!
+  \******************************************************/
+/*! exports provided: Foundation, Motion, Move */
+/***/ (function(module, __webpack_exports__, __webpack_require__) {
 
-module.exports = {rtl: window.Foundation.rtl, GetYoDigits: window.Foundation.GetYoDigits, transitionend: window.Foundation.transitionend};
+"use strict";
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
-/***/ }),
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.motion */ "./js/foundation.util.motion.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Motion", function() { return _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__["Motion"]; });
 
-/***/ 38:
-/***/ (function(module, __webpack_exports__, __webpack_require__) {
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Move", function() { return _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__["Move"]; });
 
-"use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(68);
 
 
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].Motion = _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__["Motion"];
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].Move = _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__["Move"];
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].Motion = __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["a" /* Motion */];
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].Move = __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["b" /* Move */];
 
 /***/ }),
 
-/***/ 68:
+/***/ "./js/foundation.util.motion.js":
+/*!**************************************!*\
+  !*** ./js/foundation.util.motion.js ***!
+  \**************************************/
+/*! exports provided: Move, Motion */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return Move; });
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Motion; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core__ = __webpack_require__(3);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Move", function() { return Move; });
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Motion", function() { return Motion; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
 
 
 
@@ -135,13 +159,11 @@ __WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].Move = __WEBPACK_IM
 
 var initClasses = ['mui-enter', 'mui-leave'];
 var activeClasses = ['mui-enter-active', 'mui-leave-active'];
-
 var Motion = {
-  animateIn: function (element, animation, cb) {
+  animateIn: function animateIn(element, animation, cb) {
     animate(true, element, animation, cb);
   },
-
-  animateOut: function (element, animation, cb) {
+  animateOut: function animateOut(element, animation, cb) {
     animate(false, element, animation, cb);
   }
 };
@@ -149,8 +171,7 @@ var Motion = {
 function Move(duration, elem, fn) {
   var anim,
       prog,
-      start = null;
-  // console.log('called');
+      start = null; // console.log('called');
 
   if (duration === 0) {
     fn.apply(elem);
@@ -159,8 +180,8 @@ function Move(duration, elem, fn) {
   }
 
   function move(ts) {
-    if (!start) start = ts;
-    // console.log(start, ts);
+    if (!start) start = ts; // console.log(start, ts);
+
     prog = ts - start;
     fn.apply(elem);
 
@@ -171,9 +192,9 @@ function Move(duration, elem, fn) {
       elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);
     }
   }
+
   anim = window.requestAnimationFrame(move);
 }
-
 /**
  * Animates an element in or out using a CSS transition class.
  * @function
@@ -183,49 +204,68 @@ function Move(duration, elem, fn) {
  * @param {String} animation - CSS class to use.
  * @param {Function} cb - Callback to run when animation is finished.
  */
-function animate(isIn, element, animation, cb) {
-  element = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(element).eq(0);
 
-  if (!element.length) return;
 
+function animate(isIn, element, animation, cb) {
+  element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element).eq(0);
+  if (!element.length) return;
   var initClass = isIn ? initClasses[0] : initClasses[1];
-  var activeClass = isIn ? activeClasses[0] : activeClasses[1];
+  var activeClass = isIn ? activeClasses[0] : activeClasses[1]; // Set up the animation
 
-  // Set up the animation
   reset();
-
   element.addClass(animation).css('transition', 'none');
-
   requestAnimationFrame(function () {
     element.addClass(initClass);
     if (isIn) element.show();
-  });
+  }); // Start the animation
 
-  // Start the animation
   requestAnimationFrame(function () {
     element[0].offsetWidth;
     element.css('transition', '').addClass(activeClass);
-  });
+  }); // Clean up the animation when it finishes
 
-  // Clean up the animation when it finishes
-  element.one(__webpack_require__.i(__WEBPACK_IMPORTED_MODULE_1__foundation_util_core__["transitionend"])(element), finish);
+  element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["transitionend"])(element), finish); // Hides the element (for out animations), resets the element, and runs a callback
 
-  // Hides the element (for out animations), resets the element, and runs a callback
   function finish() {
     if (!isIn) element.hide();
     reset();
     if (cb) cb.apply(element);
-  }
+  } // Resets transitions and removes motion-specific classes
+
 
-  // Resets transitions and removes motion-specific classes
   function reset() {
     element[0].style.transitionDuration = 0;
-    element.removeClass(initClass + ' ' + activeClass + ' ' + animation);
+    element.removeClass("".concat(initClass, " ").concat(activeClass, " ").concat(animation));
   }
 }
 
 
 
+/***/ }),
+
+/***/ 25:
+/*!************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.motion.js ***!
+  \************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.motion.js */"./js/entries/plugins/foundation.util.motion.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
+
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.motion.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.motion.js.map b/dist/js/plugins/foundation.util.motion.js.map
new file mode 100644 (file)
index 0000000..75d72eb
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.motion.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.motion.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","Motion","Move","initClasses","activeClasses","animateIn","element","animation","cb","animate","animateOut","duration","elem","fn","anim","prog","start","apply","trigger","triggerHandler","move","ts","window","requestAnimationFrame","cancelAnimationFrame","isIn","$","eq","length","initClass","activeClass","reset","addClass","css","show","offsetWidth","one","transitionend","finish","hide","style","transitionDuration","removeClass"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yEAAyE;AACzE,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;AClFA,8D;;;;;;;;;;;;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AACA;AAEAA,2DAAU,CAACC,MAAX,GAAoBA,8DAApB;AACAD,2DAAU,CAACE,IAAX,GAAkBA,4DAAlB;;;;;;;;;;;;;ACJA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAa;;AAEb;AACA;AAEA;;;;;AAKA,IAAMC,WAAW,GAAK,CAAC,WAAD,EAAc,WAAd,CAAtB;AACA,IAAMC,aAAa,GAAG,CAAC,kBAAD,EAAqB,kBAArB,CAAtB;AAEA,IAAMH,MAAM,GAAG;AACbI,WAAS,EAAE,mBAASC,OAAT,EAAkBC,SAAlB,EAA6BC,EAA7B,EAAiC;AAC1CC,WAAO,CAAC,IAAD,EAAOH,OAAP,EAAgBC,SAAhB,EAA2BC,EAA3B,CAAP;AACD,GAHY;AAKbE,YAAU,EAAE,oBAASJ,OAAT,EAAkBC,SAAlB,EAA6BC,EAA7B,EAAiC;AAC3CC,WAAO,CAAC,KAAD,EAAQH,OAAR,EAAiBC,SAAjB,EAA4BC,EAA5B,CAAP;AACD;AAPY,CAAf;;AAUA,SAASN,IAAT,CAAcS,QAAd,EAAwBC,IAAxB,EAA8BC,EAA9B,EAAiC;AAC/B,MAAIC,IAAJ;AAAA,MAAUC,IAAV;AAAA,MAAgBC,KAAK,GAAG,IAAxB,CAD+B,CAE/B;;AAEA,MAAIL,QAAQ,KAAK,CAAjB,EAAoB;AAClBE,MAAE,CAACI,KAAH,CAASL,IAAT;AACAA,QAAI,CAACM,OAAL,CAAa,qBAAb,EAAoC,CAACN,IAAD,CAApC,EAA4CO,cAA5C,CAA2D,qBAA3D,EAAkF,CAACP,IAAD,CAAlF;AACA;AACD;;AAED,WAASQ,IAAT,CAAcC,EAAd,EAAiB;AACf,QAAG,CAACL,KAAJ,EAAWA,KAAK,GAAGK,EAAR,CADI,CAEf;;AACAN,QAAI,GAAGM,EAAE,GAAGL,KAAZ;AACAH,MAAE,CAACI,KAAH,CAASL,IAAT;;AAEA,QAAGG,IAAI,GAAGJ,QAAV,EAAmB;AAAEG,UAAI,GAAGQ,MAAM,CAACC,qBAAP,CAA6BH,IAA7B,EAAmCR,IAAnC,CAAP;AAAkD,KAAvE,MACI;AACFU,YAAM,CAACE,oBAAP,CAA4BV,IAA5B;AACAF,UAAI,CAACM,OAAL,CAAa,qBAAb,EAAoC,CAACN,IAAD,CAApC,EAA4CO,cAA5C,CAA2D,qBAA3D,EAAkF,CAACP,IAAD,CAAlF;AACD;AACF;;AACDE,MAAI,GAAGQ,MAAM,CAACC,qBAAP,CAA6BH,IAA7B,CAAP;AACD;AAED;;;;;;;;;;;AASA,SAASX,OAAT,CAAiBgB,IAAjB,EAAuBnB,OAAvB,EAAgCC,SAAhC,EAA2CC,EAA3C,EAA+C;AAC7CF,SAAO,GAAGoB,6CAAC,CAACpB,OAAD,CAAD,CAAWqB,EAAX,CAAc,CAAd,CAAV;AAEA,MAAI,CAACrB,OAAO,CAACsB,MAAb,EAAqB;AAErB,MAAIC,SAAS,GAAGJ,IAAI,GAAGtB,WAAW,CAAC,CAAD,CAAd,GAAoBA,WAAW,CAAC,CAAD,CAAnD;AACA,MAAI2B,WAAW,GAAGL,IAAI,GAAGrB,aAAa,CAAC,CAAD,CAAhB,GAAsBA,aAAa,CAAC,CAAD,CAAzD,CAN6C,CAQ7C;;AACA2B,OAAK;AAELzB,SAAO,CACJ0B,QADH,CACYzB,SADZ,EAEG0B,GAFH,CAEO,YAFP,EAEqB,MAFrB;AAIAV,uBAAqB,CAAC,YAAM;AAC1BjB,WAAO,CAAC0B,QAAR,CAAiBH,SAAjB;AACA,QAAIJ,IAAJ,EAAUnB,OAAO,CAAC4B,IAAR;AACX,GAHoB,CAArB,CAf6C,CAoB7C;;AACAX,uBAAqB,CAAC,YAAM;AAC1BjB,WAAO,CAAC,CAAD,CAAP,CAAW6B,WAAX;AACA7B,WAAO,CACJ2B,GADH,CACO,YADP,EACqB,EADrB,EAEGD,QAFH,CAEYF,WAFZ;AAGD,GALoB,CAArB,CArB6C,CA4B7C;;AACAxB,SAAO,CAAC8B,GAAR,CAAYC,4EAAa,CAAC/B,OAAD,CAAzB,EAAoCgC,MAApC,EA7B6C,CA+B7C;;AACA,WAASA,MAAT,GAAkB;AAChB,QAAI,CAACb,IAAL,EAAWnB,OAAO,CAACiC,IAAR;AACXR,SAAK;AACL,QAAIvB,EAAJ,EAAQA,EAAE,CAACS,KAAH,CAASX,OAAT;AACT,GApC4C,CAsC7C;;;AACA,WAASyB,KAAT,GAAiB;AACfzB,WAAO,CAAC,CAAD,CAAP,CAAWkC,KAAX,CAAiBC,kBAAjB,GAAsC,CAAtC;AACAnC,WAAO,CAACoC,WAAR,WAAuBb,SAAvB,cAAoCC,WAApC,cAAmDvB,SAAnD;AACD;AACF;;;;;;;;;;;;;;;;;;;;;;;;;ACpGD,oD","file":"foundation.util.motion.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.motion\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 25);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\nimport { Motion, Move } from '../../foundation.util.motion';\n\nFoundation.Motion = Motion;\nFoundation.Move = Move;\n\nexport { Foundation, Motion, Move };\n","'use strict';\n\nimport $ from 'jquery';\nimport { transitionend } from './foundation.core.utils';\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nconst initClasses   = ['mui-enter', 'mui-leave'];\nconst activeClasses = ['mui-enter-active', 'mui-leave-active'];\n\nconst Motion = {\n  animateIn: function(element, animation, cb) {\n    animate(true, element, animation, cb);\n  },\n\n  animateOut: function(element, animation, cb) {\n    animate(false, element, animation, cb);\n  }\n}\n\nfunction Move(duration, elem, fn){\n  var anim, prog, start = null;\n  // console.log('called');\n\n  if (duration === 0) {\n    fn.apply(elem);\n    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    return;\n  }\n\n  function move(ts){\n    if(!start) start = ts;\n    // console.log(start, ts);\n    prog = ts - start;\n    fn.apply(elem);\n\n    if(prog < duration){ anim = window.requestAnimationFrame(move, elem); }\n    else{\n      window.cancelAnimationFrame(anim);\n      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    }\n  }\n  anim = window.requestAnimationFrame(move);\n}\n\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\nfunction animate(isIn, element, animation, cb) {\n  element = $(element).eq(0);\n\n  if (!element.length) return;\n\n  var initClass = isIn ? initClasses[0] : initClasses[1];\n  var activeClass = isIn ? activeClasses[0] : activeClasses[1];\n\n  // Set up the animation\n  reset();\n\n  element\n    .addClass(animation)\n    .css('transition', 'none');\n\n  requestAnimationFrame(() => {\n    element.addClass(initClass);\n    if (isIn) element.show();\n  });\n\n  // Start the animation\n  requestAnimationFrame(() => {\n    element[0].offsetWidth;\n    element\n      .css('transition', '')\n      .addClass(activeClass);\n  });\n\n  // Clean up the animation when it finishes\n  element.one(transitionend(element), finish);\n\n  // Hides the element (for out animations), resets the element, and runs a callback\n  function finish() {\n    if (!isIn) element.hide();\n    reset();\n    if (cb) cb.apply(element);\n  }\n\n  // Resets transitions and removes motion-specific classes\n  function reset() {\n    element[0].style.transitionDuration = 0;\n    element.removeClass(`${initClass} ${activeClass} ${animation}`);\n  }\n}\n\nexport { Move, Motion };\n\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 3a85c34429996cd08b330ab60466305c65aab86f..990b7f01085c6f2c0fe03864d94ff88a8c7886a8 100644 (file)
@@ -1 +1,2 @@
-!function(n){function t(e){if(i[e])return i[e].exports;var o=i[e]={i:e,l:!1,exports:{}};return n[e].call(o.exports,o,o.exports,t),o.l=!0,o.exports}var i={};t.m=n,t.c=i,t.i=function(n){return n},t.d=function(n,i,e){t.o(n,i)||Object.defineProperty(n,i,{configurable:!1,enumerable:!0,get:e})},t.n=function(n){var i=n&&n.__esModule?function(){return n.default}:function(){return n};return t.d(i,"a",i),i},t.o=function(n,t){return Object.prototype.hasOwnProperty.call(n,t)},t.p="",t(t.s=104)}({0:function(n,t){n.exports=jQuery},1:function(n,t){n.exports={Foundation:window.Foundation}},104:function(n,t,i){n.exports=i(38)},3:function(n,t){n.exports={rtl:window.Foundation.rtl,GetYoDigits:window.Foundation.GetYoDigits,transitionend:window.Foundation.transitionend}},38:function(n,t,i){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var e=i(1),o=(i.n(e),i(68));e.Foundation.Motion=o.a,e.Foundation.Move=o.b},68:function(n,t,i){"use strict";function e(n,t,i){function e(u){a||(a=u),r=u-a,i.apply(t),r<n?o=window.requestAnimationFrame(e,t):(window.cancelAnimationFrame(o),t.trigger("finished.zf.animate",[t]).triggerHandler("finished.zf.animate",[t]))}var o,r,a=null;if(0===n)return i.apply(t),void t.trigger("finished.zf.animate",[t]).triggerHandler("finished.zf.animate",[t]);o=window.requestAnimationFrame(e)}function o(n,t,e,o){function r(){n||t.hide(),d(),o&&o.apply(t)}function d(){t[0].style.transitionDuration=0,t.removeClass(c+" "+l+" "+e)}if(t=a()(t).eq(0),t.length){var c=n?s[0]:s[1],l=n?f[0]:f[1];d(),t.addClass(e).css("transition","none"),requestAnimationFrame(function(){t.addClass(c),n&&t.show()}),requestAnimationFrame(function(){t[0].offsetWidth,t.css("transition","").addClass(l)}),t.one(i.i(u.transitionend)(t),r)}}i.d(t,"b",function(){return e}),i.d(t,"a",function(){return d});var r=i(0),a=i.n(r),u=i(3),s=(i.n(u),["mui-enter","mui-leave"]),f=["mui-enter-active","mui-leave-active"],d={animateIn:function(n,t,i){o(!0,n,t,i)},animateOut:function(n,t,i){o(!1,n,t,i)}}}});
\ No newline at end of file
+!function(n,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],t):"object"==typeof exports?exports["foundation.util.motion"]=t(require("./foundation.core"),require("jquery")):(n.__FOUNDATION_EXTERNAL__=n.__FOUNDATION_EXTERNAL__||{},n.__FOUNDATION_EXTERNAL__["foundation.util.motion"]=t(n.__FOUNDATION_EXTERNAL__["foundation.core"],n.jQuery))}(window,function(e,o){return function(e){var o={};function i(n){if(o[n])return o[n].exports;var t=o[n]={i:n,l:!1,exports:{}};return e[n].call(t.exports,t,t.exports,i),t.l=!0,t.exports}return i.m=e,i.c=o,i.d=function(n,t,e){i.o(n,t)||Object.defineProperty(n,t,{enumerable:!0,get:e})},i.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},i.t=function(t,n){if(1&n&&(t=i(t)),8&n)return t;if(4&n&&"object"==typeof t&&t&&t.__esModule)return t;var e=Object.create(null);if(i.r(e),Object.defineProperty(e,"default",{enumerable:!0,value:t}),2&n&&"string"!=typeof t)for(var o in t)i.d(e,o,function(n){return t[n]}.bind(null,o));return e},i.n=function(n){var t=n&&n.__esModule?function(){return n.default}:function(){return n};return i.d(t,"a",t),t},i.o=function(n,t){return Object.prototype.hasOwnProperty.call(n,t)},i.p="",i(i.s=25)}({"./foundation.core":function(n,t){n.exports=e},"./js/entries/plugins/foundation.util.motion.js":function(n,t,e){"use strict";e.r(t);var o=e("./foundation.core");e.d(t,"Foundation",function(){return o.Foundation});var i=e("./js/foundation.util.motion.js");e.d(t,"Motion",function(){return i.Motion}),e.d(t,"Move",function(){return i.Move}),o.Foundation.Motion=i.Motion,o.Foundation.Move=i.Move},"./js/foundation.util.motion.js":function(n,t,e){"use strict";e.r(t),e.d(t,"Move",function(){return r}),e.d(t,"Motion",function(){return i});var o=e("jquery"),a=e.n(o),f=e("./foundation.core"),c=["mui-enter","mui-leave"],d=["mui-enter-active","mui-leave-active"],i={animateIn:function(n,t,e){u(!0,n,t,e)},animateOut:function(n,t,e){u(!1,n,t,e)}};function r(e,o,i){var r,u,a=null;if(0===e)return i.apply(o),void o.trigger("finished.zf.animate",[o]).triggerHandler("finished.zf.animate",[o]);r=window.requestAnimationFrame(function n(t){a||(a=t),u=t-a,i.apply(o),u<e?r=window.requestAnimationFrame(n,o):(window.cancelAnimationFrame(r),o.trigger("finished.zf.animate",[o]).triggerHandler("finished.zf.animate",[o]))})}function u(n,t,e,o){if((t=a()(t).eq(0)).length){var i=n?c[0]:c[1],r=n?d[0]:d[1];u(),t.addClass(e).css("transition","none"),requestAnimationFrame(function(){t.addClass(i),n&&t.show()}),requestAnimationFrame(function(){t[0].offsetWidth,t.css("transition","").addClass(r)}),t.one(Object(f.transitionend)(t),function(){n||t.hide();u(),o&&o.apply(t)})}function u(){t[0].style.transitionDuration=0,t.removeClass("".concat(i," ").concat(r," ").concat(e))}}},25:function(n,t,e){n.exports=e("./js/entries/plugins/foundation.util.motion.js")},jquery:function(n,t){n.exports=o}})});
+//# sourceMappingURL=foundation.util.motion.min.js.map
diff --git a/dist/js/plugins/foundation.util.motion.min.js.map b/dist/js/plugins/foundation.util.motion.min.js.map
new file mode 100644 (file)
index 0000000..6b64f8d
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.motion.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.util.motion.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__","Motion","Move","./js/foundation.util.motion.js","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","initClasses","activeClasses","animateIn","element","animation","cb","animate","animateOut","duration","elem","fn","anim","prog","start","apply","trigger","triggerHandler","requestAnimationFrame","move","ts","cancelAnimationFrame","isIn","eq","length","initClass","activeClass","reset","addClass","css","show","offsetWidth","one","hide","style","transitionDuration","removeClass","concat","25","jquery"],"mappings":"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","file":"foundation.util.motion.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.motion\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 25);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.motion.js\":\n/*!******************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.motion.js ***!\n  \\******************************************************/\n/*! exports provided: Foundation, Motion, Move */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.motion */ \"./js/foundation.util.motion.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Motion\", function() { return _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__[\"Motion\"]; });\n\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Move\", function() { return _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__[\"Move\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].Motion = _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__[\"Motion\"];\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].Move = _foundation_util_motion__WEBPACK_IMPORTED_MODULE_1__[\"Move\"];\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.motion.js\":\n/*!**************************************!*\\\n  !*** ./js/foundation.util.motion.js ***!\n  \\**************************************/\n/*! exports provided: Move, Motion */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Move\", function() { return Move; });\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Motion\", function() { return Motion; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n\n\n\n\n/**\n * Motion module.\n * @module foundation.motion\n */\n\nvar initClasses = ['mui-enter', 'mui-leave'];\nvar activeClasses = ['mui-enter-active', 'mui-leave-active'];\nvar Motion = {\n  animateIn: function animateIn(element, animation, cb) {\n    animate(true, element, animation, cb);\n  },\n  animateOut: function animateOut(element, animation, cb) {\n    animate(false, element, animation, cb);\n  }\n};\n\nfunction Move(duration, elem, fn) {\n  var anim,\n      prog,\n      start = null; // console.log('called');\n\n  if (duration === 0) {\n    fn.apply(elem);\n    elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    return;\n  }\n\n  function move(ts) {\n    if (!start) start = ts; // console.log(start, ts);\n\n    prog = ts - start;\n    fn.apply(elem);\n\n    if (prog < duration) {\n      anim = window.requestAnimationFrame(move, elem);\n    } else {\n      window.cancelAnimationFrame(anim);\n      elem.trigger('finished.zf.animate', [elem]).triggerHandler('finished.zf.animate', [elem]);\n    }\n  }\n\n  anim = window.requestAnimationFrame(move);\n}\n/**\n * Animates an element in or out using a CSS transition class.\n * @function\n * @private\n * @param {Boolean} isIn - Defines if the animation is in or out.\n * @param {Object} element - jQuery or HTML object to animate.\n * @param {String} animation - CSS class to use.\n * @param {Function} cb - Callback to run when animation is finished.\n */\n\n\nfunction animate(isIn, element, animation, cb) {\n  element = jquery__WEBPACK_IMPORTED_MODULE_0___default()(element).eq(0);\n  if (!element.length) return;\n  var initClass = isIn ? initClasses[0] : initClasses[1];\n  var activeClass = isIn ? activeClasses[0] : activeClasses[1]; // Set up the animation\n\n  reset();\n  element.addClass(animation).css('transition', 'none');\n  requestAnimationFrame(function () {\n    element.addClass(initClass);\n    if (isIn) element.show();\n  }); // Start the animation\n\n  requestAnimationFrame(function () {\n    element[0].offsetWidth;\n    element.css('transition', '').addClass(activeClass);\n  }); // Clean up the animation when it finishes\n\n  element.one(Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"transitionend\"])(element), finish); // Hides the element (for out animations), resets the element, and runs a callback\n\n  function finish() {\n    if (!isIn) element.hide();\n    reset();\n    if (cb) cb.apply(element);\n  } // Resets transitions and removes motion-specific classes\n\n\n  function reset() {\n    element[0].style.transitionDuration = 0;\n    element.removeClass(\"\".concat(initClass, \" \").concat(activeClass, \" \").concat(animation));\n  }\n}\n\n\n\n/***/ }),\n\n/***/ 25:\n/*!************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.motion.js ***!\n  \\************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.motion.js */\"./js/entries/plugins/foundation.util.motion.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.motion.js.map"]}
\ No newline at end of file
index a706cdf3cfc04d5aa848f36f5c535054f035354b..e99ff87a0c17f7c6bc03cd5601ad4773de3716f4 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.nest"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.nest"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 105);
+/******/       return __webpack_require__(__webpack_require__.s = 26);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
-
-/***/ }),
-
-/***/ 105:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(39);
-
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 39:
+/***/ "./js/entries/plugins/foundation.util.nest.js":
+/*!****************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.nest.js ***!
+  \****************************************************/
+/*! exports provided: Foundation, Nest */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_nest__ = __webpack_require__(69);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
 
+/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.nest */ "./js/foundation.util.nest.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Nest", function() { return _foundation_util_nest__WEBPACK_IMPORTED_MODULE_1__["Nest"]; });
 
 
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].Nest = __WEBPACK_IMPORTED_MODULE_1__foundation_util_nest__["a" /* Nest */];
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].Nest = _foundation_util_nest__WEBPACK_IMPORTED_MODULE_1__["Nest"];
+
 
 /***/ }),
 
-/***/ 69:
+/***/ "./js/foundation.util.nest.js":
+/*!************************************!*\
+  !*** ./js/foundation.util.nest.js ***!
+  \************************************/
+/*! exports provided: Nest */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Nest; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Nest", function() { return Nest; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 
 
 
 var Nest = {
-  Feather: function (menu) {
+  Feather: function Feather(menu) {
     var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zf';
-
     menu.attr('role', 'menubar');
-
-    var items = menu.find('li').attr({ 'role': 'menuitem' }),
-        subMenuClass = 'is-' + type + '-submenu',
-        subItemClass = subMenuClass + '-item',
-        hasSubClass = 'is-' + type + '-submenu-parent',
+    var items = menu.find('li').attr({
+      'role': 'menuitem'
+    }),
+        subMenuClass = "is-".concat(type, "-submenu"),
+        subItemClass = "".concat(subMenuClass, "-item"),
+        hasSubClass = "is-".concat(type, "-submenu-parent"),
         applyAria = type !== 'accordion'; // Accordions handle their own ARIA attriutes.
 
     items.each(function () {
-      var $item = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this),
+      var $item = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),
           $sub = $item.children('ul');
 
       if ($sub.length) {
         $item.addClass(hasSubClass);
-        $sub.addClass('submenu ' + subMenuClass).attr({ 'data-submenu': '' });
+
         if (applyAria) {
           $item.attr({
             'aria-haspopup': true,
             'aria-label': $item.children('a:first').text()
-          });
-          // Note:  Drilldowns behave differently in how they hide, and so need
+          }); // Note:  Drilldowns behave differently in how they hide, and so need
           // additional attributes.  We should look if this possibly over-generalized
           // utility (Nest) is appropriate when we rework menus in 6.4
+
           if (type === 'drilldown') {
-            $item.attr({ 'aria-expanded': false });
+            $item.attr({
+              'aria-expanded': false
+            });
           }
         }
-        $sub.addClass('submenu ' + subMenuClass).attr({
+
+        $sub.addClass("submenu ".concat(subMenuClass)).attr({
           'data-submenu': '',
-          'role': 'menu'
+          'role': 'menubar'
         });
+
         if (type === 'drilldown') {
-          $sub.attr({ 'aria-hidden': true });
+          $sub.attr({
+            'aria-hidden': true
+          });
         }
       }
 
       if ($item.parent('[data-submenu]').length) {
-        $item.addClass('is-submenu-item ' + subItemClass);
+        $item.addClass("is-submenu-item ".concat(subItemClass));
       }
     });
-
     return;
   },
-  Burn: function (menu, type) {
+  Burn: function Burn(menu, type) {
     var //items = menu.find('li'),
-    subMenuClass = 'is-' + type + '-submenu',
-        subItemClass = subMenuClass + '-item',
-        hasSubClass = 'is-' + type + '-submenu-parent';
-
-    menu.find('>li, .menu, .menu > li').removeClass(subMenuClass + ' ' + subItemClass + ' ' + hasSubClass + ' is-submenu-item submenu is-active').removeAttr('data-submenu').css('display', '');
+    subMenuClass = "is-".concat(type, "-submenu"),
+        subItemClass = "".concat(subMenuClass, "-item"),
+        hasSubClass = "is-".concat(type, "-submenu-parent");
+    menu.find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li').removeClass("".concat(subMenuClass, " ").concat(subItemClass, " ").concat(hasSubClass, " is-submenu-item submenu is-active")).removeAttr('data-submenu').css('display', '');
   }
 };
 
 
+/***/ }),
+
+/***/ 26:
+/*!**********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.nest.js ***!
+  \**********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.nest.js */"./js/entries/plugins/foundation.util.nest.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
 
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.nest.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.nest.js.map b/dist/js/plugins/foundation.util.nest.js.map
new file mode 100644 (file)
index 0000000..e7cb669
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.nest.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.nest.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","Nest","Feather","menu","type","attr","items","find","subMenuClass","subItemClass","hasSubClass","applyAria","each","$item","$","$sub","children","length","addClass","text","parent","Burn","removeClass","removeAttr","css"],"mappings":"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","file":"foundation.util.nest.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.nest\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.nest\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 26);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\n\nimport { Nest } from '../../foundation.util.nest';\n\nFoundation.Nest = Nest;\n\nexport { Foundation, Nest };\n","'use strict';\n\nimport $ from 'jquery';\n\nconst Nest = {\n  Feather(menu, type = 'zf') {\n    menu.attr('role', 'menubar');\n\n    var items = menu.find('li').attr({'role': 'menuitem'}),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`,\n        applyAria = (type !== 'accordion'); // Accordions handle their own ARIA attriutes.\n\n    items.each(function() {\n      var $item = $(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item.addClass(hasSubClass);\n        if(applyAria) {\n          $item.attr({\n            'aria-haspopup': true,\n            'aria-label': $item.children('a:first').text()\n          });\n          // Note:  Drilldowns behave differently in how they hide, and so need\n          // additional attributes.  We should look if this possibly over-generalized\n          // utility (Nest) is appropriate when we rework menus in 6.4\n          if(type === 'drilldown') {\n            $item.attr({'aria-expanded': false});\n          }\n        }\n        $sub\n          .addClass(`submenu ${subMenuClass}`)\n          .attr({\n            'data-submenu': '',\n            'role': 'menubar'\n          });\n        if(type === 'drilldown') {\n          $sub.attr({'aria-hidden': true});\n        }\n      }\n\n      if ($item.parent('[data-submenu]').length) {\n        $item.addClass(`is-submenu-item ${subItemClass}`);\n      }\n    });\n\n    return;\n  },\n\n  Burn(menu, type) {\n    var //items = menu.find('li'),\n        subMenuClass = `is-${type}-submenu`,\n        subItemClass = `${subMenuClass}-item`,\n        hasSubClass = `is-${type}-submenu-parent`;\n\n    menu\n      .find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li')\n      .removeClass(`${subMenuClass} ${subItemClass} ${hasSubClass} is-submenu-item submenu is-active`)\n      .removeAttr('data-submenu').css('display', '');\n\n  }\n}\n\nexport {Nest};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 9763a441f1699233613fc7106112c5352b429b2e..945b5426680912934960518eda8a64279a56f7f8 100644 (file)
@@ -1 +1,2 @@
-!function(n){function e(r){if(t[r])return t[r].exports;var u=t[r]={i:r,l:!1,exports:{}};return n[r].call(u.exports,u,u.exports,e),u.l=!0,u.exports}var t={};e.m=n,e.c=t,e.i=function(n){return n},e.d=function(n,t,r){e.o(n,t)||Object.defineProperty(n,t,{configurable:!1,enumerable:!0,get:r})},e.n=function(n){var t=n&&n.__esModule?function(){return n.default}:function(){return n};return e.d(t,"a",t),t},e.o=function(n,e){return Object.prototype.hasOwnProperty.call(n,e)},e.p="",e(e.s=105)}({0:function(n,e){n.exports=jQuery},1:function(n,e){n.exports={Foundation:window.Foundation}},105:function(n,e,t){n.exports=t(39)},39:function(n,e,t){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var r=t(1),u=(t.n(r),t(69));r.Foundation.Nest=u.a},69:function(n,e,t){"use strict";t.d(e,"a",function(){return a});var r=t(0),u=t.n(r),a={Feather:function(n){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"zf";n.attr("role","menubar");var t=n.find("li").attr({role:"menuitem"}),r="is-"+e+"-submenu",a=r+"-item",i="is-"+e+"-submenu-parent",o="accordion"!==e;t.each(function(){var n=u()(this),t=n.children("ul");t.length&&(n.addClass(i),t.addClass("submenu "+r).attr({"data-submenu":""}),o&&(n.attr({"aria-haspopup":!0,"aria-label":n.children("a:first").text()}),"drilldown"===e&&n.attr({"aria-expanded":!1})),t.addClass("submenu "+r).attr({"data-submenu":"",role:"menu"}),"drilldown"===e&&t.attr({"aria-hidden":!0})),n.parent("[data-submenu]").length&&n.addClass("is-submenu-item "+a)})},Burn:function(n,e){var t="is-"+e+"-submenu",r=t+"-item",u="is-"+e+"-submenu-parent";n.find(">li, .menu, .menu > li").removeClass(t+" "+r+" "+u+" is-submenu-item submenu is-active").removeAttr("data-submenu").css("display","")}}}});
\ No newline at end of file
+!function(e,n){"object"==typeof exports&&"object"==typeof module?module.exports=n(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],n):"object"==typeof exports?exports["foundation.util.nest"]=n(require("./foundation.core"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.util.nest"]=n(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.jQuery))}(window,function(t,r){return function(t){var r={};function o(e){if(r[e])return r[e].exports;var n=r[e]={i:e,l:!1,exports:{}};return t[e].call(n.exports,n,n.exports,o),n.l=!0,n.exports}return o.m=t,o.c=r,o.d=function(e,n,t){o.o(e,n)||Object.defineProperty(e,n,{enumerable:!0,get:t})},o.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},o.t=function(n,e){if(1&e&&(n=o(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var t=Object.create(null);if(o.r(t),Object.defineProperty(t,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var r in n)o.d(t,r,function(e){return n[e]}.bind(null,r));return t},o.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return o.d(n,"a",n),n},o.o=function(e,n){return Object.prototype.hasOwnProperty.call(e,n)},o.p="",o(o.s=26)}({"./foundation.core":function(e,n){e.exports=t},"./js/entries/plugins/foundation.util.nest.js":function(e,n,t){"use strict";t.r(n);var r=t("./foundation.core");t.d(n,"Foundation",function(){return r.Foundation});var o=t("./js/foundation.util.nest.js");t.d(n,"Nest",function(){return o.Nest}),r.Foundation.Nest=o.Nest},"./js/foundation.util.nest.js":function(e,n,t){"use strict";t.r(n),t.d(n,"Nest",function(){return o});var r=t("jquery"),a=t.n(r),o={Feather:function(e){var t=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"zf";e.attr("role","menubar");var n=e.find("li").attr({role:"menuitem"}),r="is-".concat(t,"-submenu"),o="".concat(r,"-item"),u="is-".concat(t,"-submenu-parent"),i="accordion"!==t;n.each(function(){var e=a()(this),n=e.children("ul");n.length&&(e.addClass(u),i&&(e.attr({"aria-haspopup":!0,"aria-label":e.children("a:first").text()}),"drilldown"===t&&e.attr({"aria-expanded":!1})),n.addClass("submenu ".concat(r)).attr({"data-submenu":"",role:"menubar"}),"drilldown"===t&&n.attr({"aria-hidden":!0})),e.parent("[data-submenu]").length&&e.addClass("is-submenu-item ".concat(o))})},Burn:function(e,n){var t="is-".concat(n,"-submenu"),r="".concat(t,"-item"),o="is-".concat(n,"-submenu-parent");e.find(">li, > li > ul, .menu, .menu > li, [data-submenu] > li").removeClass("".concat(t," ").concat(r," ").concat(o," is-submenu-item submenu is-active")).removeAttr("data-submenu").css("display","")}}},26:function(e,n,t){e.exports=t("./js/entries/plugins/foundation.util.nest.js")},jquery:function(e,n){e.exports=r}})});
+//# sourceMappingURL=foundation.util.nest.min.js.map
diff --git a/dist/js/plugins/foundation.util.nest.min.js.map b/dist/js/plugins/foundation.util.nest.min.js.map
new file mode 100644 (file)
index 0000000..5e64a3d
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.nest.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.util.nest.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_util_nest__WEBPACK_IMPORTED_MODULE_1__","Nest","./js/foundation.util.nest.js","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","Feather","menu","type","arguments","length","undefined","attr","items","find","role","subMenuClass","concat","subItemClass","hasSubClass","applyAria","each","$item","this","$sub","children","addClass","aria-haspopup","aria-label","text","aria-expanded","data-submenu","aria-hidden","parent","Burn","removeClass","removeAttr","css","26","jquery"],"mappings":"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","file":"foundation.util.nest.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.nest\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.nest\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 26);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.nest.js\":\n/*!****************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.nest.js ***!\n  \\****************************************************/\n/*! exports provided: Foundation, Nest */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_util_nest__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.nest */ \"./js/foundation.util.nest.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Nest\", function() { return _foundation_util_nest__WEBPACK_IMPORTED_MODULE_1__[\"Nest\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].Nest = _foundation_util_nest__WEBPACK_IMPORTED_MODULE_1__[\"Nest\"];\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.nest.js\":\n/*!************************************!*\\\n  !*** ./js/foundation.util.nest.js ***!\n  \\************************************/\n/*! exports provided: Nest */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Nest\", function() { return Nest; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\nvar Nest = {\n  Feather: function Feather(menu) {\n    var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'zf';\n    menu.attr('role', 'menubar');\n    var items = menu.find('li').attr({\n      'role': 'menuitem'\n    }),\n        subMenuClass = \"is-\".concat(type, \"-submenu\"),\n        subItemClass = \"\".concat(subMenuClass, \"-item\"),\n        hasSubClass = \"is-\".concat(type, \"-submenu-parent\"),\n        applyAria = type !== 'accordion'; // Accordions handle their own ARIA attriutes.\n\n    items.each(function () {\n      var $item = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this),\n          $sub = $item.children('ul');\n\n      if ($sub.length) {\n        $item.addClass(hasSubClass);\n\n        if (applyAria) {\n          $item.attr({\n            'aria-haspopup': true,\n            'aria-label': $item.children('a:first').text()\n          }); // Note:  Drilldowns behave differently in how they hide, and so need\n          // additional attributes.  We should look if this possibly over-generalized\n          // utility (Nest) is appropriate when we rework menus in 6.4\n\n          if (type === 'drilldown') {\n            $item.attr({\n              'aria-expanded': false\n            });\n          }\n        }\n\n        $sub.addClass(\"submenu \".concat(subMenuClass)).attr({\n          'data-submenu': '',\n          'role': 'menubar'\n        });\n\n        if (type === 'drilldown') {\n          $sub.attr({\n            'aria-hidden': true\n          });\n        }\n      }\n\n      if ($item.parent('[data-submenu]').length) {\n        $item.addClass(\"is-submenu-item \".concat(subItemClass));\n      }\n    });\n    return;\n  },\n  Burn: function Burn(menu, type) {\n    var //items = menu.find('li'),\n    subMenuClass = \"is-\".concat(type, \"-submenu\"),\n        subItemClass = \"\".concat(subMenuClass, \"-item\"),\n        hasSubClass = \"is-\".concat(type, \"-submenu-parent\");\n    menu.find('>li, > li > ul, .menu, .menu > li, [data-submenu] > li').removeClass(\"\".concat(subMenuClass, \" \").concat(subItemClass, \" \").concat(hasSubClass, \" is-submenu-item submenu is-active\")).removeAttr('data-submenu').css('display', '');\n  }\n};\n\n\n/***/ }),\n\n/***/ 26:\n/*!**********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.nest.js ***!\n  \\**********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.nest.js */\"./js/entries/plugins/foundation.util.nest.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.nest.js.map"]}
\ No newline at end of file
index fc8c632960912a2e4d8cfd7a02c1db299d87f1f8..19813b487131c8737055b8f4d9f7eb1874d0877b 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.timer"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.timer"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 106);
+/******/       return __webpack_require__(__webpack_require__.s = 27);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
-/***/ (function(module, exports) {
-
-module.exports = {Foundation: window.Foundation};
-
-/***/ }),
-
-/***/ 106:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(40);
-
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 40:
+/***/ "./js/entries/plugins/foundation.util.timer.js":
+/*!*****************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.timer.js ***!
+  \*****************************************************/
+/*! exports provided: Foundation, Timer */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_timer__ = __webpack_require__(70);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
+
+/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.timer */ "./js/foundation.util.timer.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return _foundation_util_timer__WEBPACK_IMPORTED_MODULE_1__["Timer"]; });
 
 
 
+_foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"].Timer = _foundation_util_timer__WEBPACK_IMPORTED_MODULE_1__["Timer"];
 
-__WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"].Timer = __WEBPACK_IMPORTED_MODULE_1__foundation_util_timer__["a" /* Timer */];
 
 /***/ }),
 
-/***/ 70:
+/***/ "./js/foundation.util.timer.js":
+/*!*************************************!*\
+  !*** ./js/foundation.util.timer.js ***!
+  \*************************************/
+/*! exports provided: Timer */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Timer; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Timer", function() { return Timer; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 
 
 
@@ -135,8 +164,8 @@ function Timer(elem, options, cb) {
   };
 
   this.start = function () {
-    this.isPaused = false;
-    // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+    this.isPaused = false; // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+
     clearTimeout(timer);
     remain = remain <= 0 ? duration : remain;
     elem.data('paused', false);
@@ -144,27 +173,54 @@ function Timer(elem, options, cb) {
     timer = setTimeout(function () {
       if (options.infinite) {
         _this.restart(); //rerun the timer.
+
       }
+
       if (cb && typeof cb === 'function') {
         cb();
       }
     }, remain);
-    elem.trigger('timerstart.zf.' + nameSpace);
+    elem.trigger("timerstart.zf.".concat(nameSpace));
   };
 
   this.pause = function () {
-    this.isPaused = true;
-    //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+    this.isPaused = true; //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
+
     clearTimeout(timer);
     elem.data('paused', true);
     var end = Date.now();
     remain = remain - (end - start);
-    elem.trigger('timerpaused.zf.' + nameSpace);
+    elem.trigger("timerpaused.zf.".concat(nameSpace));
   };
 }
 
 
 
+/***/ }),
+
+/***/ 27:
+/*!***********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.timer.js ***!
+  \***********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.timer.js */"./js/entries/plugins/foundation.util.timer.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
+
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.timer.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.timer.js.map b/dist/js/plugins/foundation.util.timer.js.map
new file mode 100644 (file)
index 0000000..14b8943
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.timer.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.timer.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Foundation","Timer","elem","options","cb","_this","duration","nameSpace","Object","keys","data","remain","start","timer","isPaused","restart","clearTimeout","Date","now","setTimeout","infinite","trigger","pause","end"],"mappings":"AAAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,yEAAyE;AACzE,CAAC;AACD,O;ACVA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;;;AAGA;AACA;;AAEA;AACA;;AAEA;AACA;AACA;AACA,kDAA0C,gCAAgC;AAC1E;AACA;;AAEA;AACA;AACA;AACA,gEAAwD,kBAAkB;AAC1E;AACA,yDAAiD,cAAc;AAC/D;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,iDAAyC,iCAAiC;AAC1E,wHAAgH,mBAAmB,EAAE;AACrI;AACA;;AAEA;AACA;AACA;AACA,mCAA2B,0BAA0B,EAAE;AACvD,yCAAiC,eAAe;AAChD;AACA;AACA;;AAEA;AACA,8DAAsD,+DAA+D;;AAErH;AACA;;;AAGA;AACA;;;;;;;;;;;;AClFA,8D;;;;;;;;;;;;ACAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA;AAEAA,2DAAU,CAACC,KAAX,GAAmBA,4DAAnB;;;;;;;;;;;;;ACJA;AAAA;AAAA;AAAA;AAAa;;AAEb;;AAEA,SAASA,KAAT,CAAeC,IAAf,EAAqBC,OAArB,EAA8BC,EAA9B,EAAkC;AAChC,MAAIC,KAAK,GAAG,IAAZ;AAAA,MACIC,QAAQ,GAAGH,OAAO,CAACG,QADvB;AAAA,MACgC;AAC5BC,WAAS,GAAGC,MAAM,CAACC,IAAP,CAAYP,IAAI,CAACQ,IAAL,EAAZ,EAAyB,CAAzB,KAA+B,OAF/C;AAAA,MAGIC,MAAM,GAAG,CAAC,CAHd;AAAA,MAIIC,KAJJ;AAAA,MAKIC,KALJ;;AAOA,OAAKC,QAAL,GAAgB,KAAhB;;AAEA,OAAKC,OAAL,GAAe,YAAW;AACxBJ,UAAM,GAAG,CAAC,CAAV;AACAK,gBAAY,CAACH,KAAD,CAAZ;AACA,SAAKD,KAAL;AACD,GAJD;;AAMA,OAAKA,KAAL,GAAa,YAAW;AACtB,SAAKE,QAAL,GAAgB,KAAhB,CADsB,CAEtB;;AACAE,gBAAY,CAACH,KAAD,CAAZ;AACAF,UAAM,GAAGA,MAAM,IAAI,CAAV,GAAcL,QAAd,GAAyBK,MAAlC;AACAT,QAAI,CAACQ,IAAL,CAAU,QAAV,EAAoB,KAApB;AACAE,SAAK,GAAGK,IAAI,CAACC,GAAL,EAAR;AACAL,SAAK,GAAGM,UAAU,CAAC,YAAU;AAC3B,UAAGhB,OAAO,CAACiB,QAAX,EAAoB;AAClBf,aAAK,CAACU,OAAN,GADkB,CACF;;AACjB;;AACD,UAAIX,EAAE,IAAI,OAAOA,EAAP,KAAc,UAAxB,EAAoC;AAAEA,UAAE;AAAK;AAC9C,KALiB,EAKfO,MALe,CAAlB;AAMAT,QAAI,CAACmB,OAAL,yBAA8Bd,SAA9B;AACD,GAdD;;AAgBA,OAAKe,KAAL,GAAa,YAAW;AACtB,SAAKR,QAAL,GAAgB,IAAhB,CADsB,CAEtB;;AACAE,gBAAY,CAACH,KAAD,CAAZ;AACAX,QAAI,CAACQ,IAAL,CAAU,QAAV,EAAoB,IAApB;AACA,QAAIa,GAAG,GAAGN,IAAI,CAACC,GAAL,EAAV;AACAP,UAAM,GAAGA,MAAM,IAAIY,GAAG,GAAGX,KAAV,CAAf;AACAV,QAAI,CAACmB,OAAL,0BAA+Bd,SAA/B;AACD,GARD;AASD;;;;;;;;;;;;;;;;;;;;;;;;;AC7CD,oD","file":"foundation.util.timer.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.timer\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.timer\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 27);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import { Foundation } from './foundation.core';\n\nimport { Timer } from '../../foundation.util.timer';\n\nFoundation.Timer = Timer;\n\nexport { Foundation, Timer };\n","'use strict';\n\nimport $ from 'jquery';\n\nfunction Timer(elem, options, cb) {\n  var _this = this,\n      duration = options.duration,//options is an object for easily adding features later.\n      nameSpace = Object.keys(elem.data())[0] || 'timer',\n      remain = -1,\n      start,\n      timer;\n\n  this.isPaused = false;\n\n  this.restart = function() {\n    remain = -1;\n    clearTimeout(timer);\n    this.start();\n  }\n\n  this.start = function() {\n    this.isPaused = false;\n    // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    remain = remain <= 0 ? duration : remain;\n    elem.data('paused', false);\n    start = Date.now();\n    timer = setTimeout(function(){\n      if(options.infinite){\n        _this.restart();//rerun the timer.\n      }\n      if (cb && typeof cb === 'function') { cb(); }\n    }, remain);\n    elem.trigger(`timerstart.zf.${nameSpace}`);\n  }\n\n  this.pause = function() {\n    this.isPaused = true;\n    //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n    clearTimeout(timer);\n    elem.data('paused', true);\n    var end = Date.now();\n    remain = remain - (end - start);\n    elem.trigger(`timerpaused.zf.${nameSpace}`);\n  }\n}\n\nexport {Timer};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 873bd10d3be84b36222a05dccc9c6bb749592f0a..0ecbf8e17a8510b7e830aef6315f269c42def2d7 100644 (file)
@@ -1 +1,2 @@
-!function(t){function e(r){if(n[r])return n[r].exports;var i=n[r]={i:r,l:!1,exports:{}};return t[r].call(i.exports,i,i.exports,e),i.l=!0,i.exports}var n={};e.m=t,e.c=n,e.i=function(t){return t},e.d=function(t,n,r){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:r})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=106)}({0:function(t,e){t.exports=jQuery},1:function(t,e){t.exports={Foundation:window.Foundation}},106:function(t,e,n){t.exports=n(40)},40:function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0});var r=n(1),i=(n.n(r),n(70));r.Foundation.Timer=i.a},70:function(t,e,n){"use strict";function r(t,e,n){var r,i,o=this,u=e.duration,a=Object.keys(t.data())[0]||"timer",s=-1;this.isPaused=!1,this.restart=function(){s=-1,clearTimeout(i),this.start()},this.start=function(){this.isPaused=!1,clearTimeout(i),s=s<=0?u:s,t.data("paused",!1),r=Date.now(),i=setTimeout(function(){e.infinite&&o.restart(),n&&"function"==typeof n&&n()},s),t.trigger("timerstart.zf."+a)},this.pause=function(){this.isPaused=!0,clearTimeout(i),t.data("paused",!0);var e=Date.now();s-=e-r,t.trigger("timerpaused.zf."+a)}}n.d(e,"a",function(){return r});var i=n(0);n.n(i)}});
\ No newline at end of file
+!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],e):"object"==typeof exports?exports["foundation.util.timer"]=e(require("./foundation.core"),require("jquery")):(t.__FOUNDATION_EXTERNAL__=t.__FOUNDATION_EXTERNAL__||{},t.__FOUNDATION_EXTERNAL__["foundation.util.timer"]=e(t.__FOUNDATION_EXTERNAL__["foundation.core"],t.jQuery))}(window,function(n,r){return function(n){var r={};function o(t){if(r[t])return r[t].exports;var e=r[t]={i:t,l:!1,exports:{}};return n[t].call(e.exports,e,e.exports,o),e.l=!0,e.exports}return o.m=n,o.c=r,o.d=function(t,e,n){o.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:n})},o.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},o.t=function(e,t){if(1&t&&(e=o(e)),8&t)return e;if(4&t&&"object"==typeof e&&e&&e.__esModule)return e;var n=Object.create(null);if(o.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:e}),2&t&&"string"!=typeof e)for(var r in e)o.d(n,r,function(t){return e[t]}.bind(null,r));return n},o.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return o.d(e,"a",e),e},o.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},o.p="",o(o.s=27)}({"./foundation.core":function(t,e){t.exports=n},"./js/entries/plugins/foundation.util.timer.js":function(t,e,n){"use strict";n.r(e);var r=n("./foundation.core");n.d(e,"Foundation",function(){return r.Foundation});var o=n("./js/foundation.util.timer.js");n.d(e,"Timer",function(){return o.Timer}),r.Foundation.Timer=o.Timer},"./js/foundation.util.timer.js":function(t,e,n){"use strict";n.r(e),n.d(e,"Timer",function(){return r});n("jquery");function r(e,t,n){var r,o,i=this,u=t.duration,a=Object.keys(e.data())[0]||"timer",f=-1;this.isPaused=!1,this.restart=function(){f=-1,clearTimeout(o),this.start()},this.start=function(){this.isPaused=!1,clearTimeout(o),f=f<=0?u:f,e.data("paused",!1),r=Date.now(),o=setTimeout(function(){t.infinite&&i.restart(),n&&"function"==typeof n&&n()},f),e.trigger("timerstart.zf.".concat(a))},this.pause=function(){this.isPaused=!0,clearTimeout(o),e.data("paused",!0);var t=Date.now();f-=t-r,e.trigger("timerpaused.zf.".concat(a))}}},27:function(t,e,n){t.exports=n("./js/entries/plugins/foundation.util.timer.js")},jquery:function(t,e){t.exports=r}})});
+//# sourceMappingURL=foundation.util.timer.min.js.map
diff --git a/dist/js/plugins/foundation.util.timer.min.js.map b/dist/js/plugins/foundation.util.timer.min.js.map
new file mode 100644 (file)
index 0000000..d7a05b1
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.timer.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.util.timer.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","_foundation_util_timer__WEBPACK_IMPORTED_MODULE_1__","Timer","./js/foundation.util.timer.js","elem","options","cb","start","timer","_this","this","duration","nameSpace","keys","data","remain","isPaused","restart","clearTimeout","Date","now","setTimeout","infinite","trigger","concat","pause","end","27","jquery"],"mappings":"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","file":"foundation.util.timer.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.timer\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.timer\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 27);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.timer.js\":\n/*!*****************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.timer.js ***!\n  \\*****************************************************/\n/*! exports provided: Foundation, Timer */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var _foundation_util_timer__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.timer */ \"./js/foundation.util.timer.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Timer\", function() { return _foundation_util_timer__WEBPACK_IMPORTED_MODULE_1__[\"Timer\"]; });\n\n\n\n_foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"].Timer = _foundation_util_timer__WEBPACK_IMPORTED_MODULE_1__[\"Timer\"];\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.timer.js\":\n/*!*************************************!*\\\n  !*** ./js/foundation.util.timer.js ***!\n  \\*************************************/\n/*! exports provided: Timer */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Timer\", function() { return Timer; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n\n\n\n\nfunction Timer(elem, options, cb) {\n  var _this = this,\n      duration = options.duration,\n      //options is an object for easily adding features later.\n  nameSpace = Object.keys(elem.data())[0] || 'timer',\n      remain = -1,\n      start,\n      timer;\n\n  this.isPaused = false;\n\n  this.restart = function () {\n    remain = -1;\n    clearTimeout(timer);\n    this.start();\n  };\n\n  this.start = function () {\n    this.isPaused = false; // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n\n    clearTimeout(timer);\n    remain = remain <= 0 ? duration : remain;\n    elem.data('paused', false);\n    start = Date.now();\n    timer = setTimeout(function () {\n      if (options.infinite) {\n        _this.restart(); //rerun the timer.\n\n      }\n\n      if (cb && typeof cb === 'function') {\n        cb();\n      }\n    }, remain);\n    elem.trigger(\"timerstart.zf.\".concat(nameSpace));\n  };\n\n  this.pause = function () {\n    this.isPaused = true; //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.\n\n    clearTimeout(timer);\n    elem.data('paused', true);\n    var end = Date.now();\n    remain = remain - (end - start);\n    elem.trigger(\"timerpaused.zf.\".concat(nameSpace));\n  };\n}\n\n\n\n/***/ }),\n\n/***/ 27:\n/*!***********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.timer.js ***!\n  \\***********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.timer.js */\"./js/entries/plugins/foundation.util.timer.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.timer.js.map"]}
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.timerAndImageLoader.js b/dist/js/plugins/foundation.util.timerAndImageLoader.js
deleted file mode 100644 (file)
index 2706b13..0000000
+++ /dev/null
@@ -1,90 +0,0 @@
-'use strict';
-
-!function ($) {
-
-  function Timer(elem, options, cb) {
-    var _this = this,
-        duration = options.duration,
-        //options is an object for easily adding features later.
-    nameSpace = Object.keys(elem.data())[0] || 'timer',
-        remain = -1,
-        start,
-        timer;
-
-    this.isPaused = false;
-
-    this.restart = function () {
-      remain = -1;
-      clearTimeout(timer);
-      this.start();
-    };
-
-    this.start = function () {
-      this.isPaused = false;
-      // if(!elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
-      clearTimeout(timer);
-      remain = remain <= 0 ? duration : remain;
-      elem.data('paused', false);
-      start = Date.now();
-      timer = setTimeout(function () {
-        if (options.infinite) {
-          _this.restart(); //rerun the timer.
-        }
-        if (cb && typeof cb === 'function') {
-          cb();
-        }
-      }, remain);
-      elem.trigger('timerstart.zf.' + nameSpace);
-    };
-
-    this.pause = function () {
-      this.isPaused = true;
-      //if(elem.data('paused')){ return false; }//maybe implement this sanity check if used for other things.
-      clearTimeout(timer);
-      elem.data('paused', true);
-      var end = Date.now();
-      remain = remain - (end - start);
-      elem.trigger('timerpaused.zf.' + nameSpace);
-    };
-  }
-
-  /**
-   * Runs a callback function when images are fully loaded.
-   * @param {Object} images - Image(s) to check if loaded.
-   * @param {Func} callback - Function to execute when image is fully loaded.
-   */
-  function onImagesLoaded(images, callback) {
-    var self = this,
-        unloaded = images.length;
-
-    if (unloaded === 0) {
-      callback();
-    }
-
-    images.each(function () {
-      // Check if image is loaded
-      if (this.complete || this.readyState === 4 || this.readyState === 'complete') {
-        singleImageLoaded();
-      }
-      // Force load the image
-      else {
-          // fix for IE. See https://css-tricks.com/snippets/jquery/fixing-load-in-ie-for-cached-images/
-          var src = $(this).attr('src');
-          $(this).attr('src', src + (src.indexOf('?') >= 0 ? '&' : '?') + new Date().getTime());
-          $(this).one('load', function () {
-            singleImageLoaded();
-          });
-        }
-    });
-
-    function singleImageLoaded() {
-      unloaded--;
-      if (unloaded === 0) {
-        callback();
-      }
-    }
-  }
-
-  Foundation.Timer = Timer;
-  Foundation.onImagesLoaded = onImagesLoaded;
-}(jQuery);
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.timerAndImageLoader.min.js b/dist/js/plugins/foundation.util.timerAndImageLoader.min.js
deleted file mode 100644 (file)
index bde5447..0000000
+++ /dev/null
@@ -1 +0,0 @@
-"use strict";!function(t){function e(t,e,i){var a,s,n=this,r=e.duration,o=Object.keys(t.data())[0]||"timer",u=-1;this.isPaused=!1,this.restart=function(){u=-1,clearTimeout(s),this.start()},this.start=function(){this.isPaused=!1,clearTimeout(s),u=u<=0?r:u,t.data("paused",!1),a=Date.now(),s=setTimeout(function(){e.infinite&&n.restart(),i&&"function"==typeof i&&i()},u),t.trigger("timerstart.zf."+o)},this.pause=function(){this.isPaused=!0,clearTimeout(s),t.data("paused",!0);var e=Date.now();u-=e-a,t.trigger("timerpaused.zf."+o)}}function i(e,i){function a(){s--,0===s&&i()}var s=e.length;0===s&&i(),e.each(function(){if(this.complete||4===this.readyState||"complete"===this.readyState)a();else{var e=t(this).attr("src");t(this).attr("src",e+(e.indexOf("?")>=0?"&":"?")+(new Date).getTime()),t(this).one("load",function(){a()})}})}Foundation.Timer=e,Foundation.onImagesLoaded=i}(jQuery);
\ No newline at end of file
index d1d81fc6662677df11615d77ebde61d155938108..002e7770b4c94faeb249930b5076b78c9b107f7c 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.touch"] = factory(require("./foundation.core"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.touch"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
+/******/               }
+/******/       };
+/******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
 /******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
 /******/       };
 /******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 107);
+/******/       return __webpack_require__(__webpack_require__.s = 28);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 107:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(41);
-
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 41:
+/***/ "./js/entries/plugins/foundation.util.touch.js":
+/*!*****************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.touch.js ***!
+  \*****************************************************/
+/*! exports provided: Foundation, Touch */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_touch__ = __webpack_require__(71);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.touch */ "./js/foundation.util.touch.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Touch", function() { return _foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__["Touch"]; });
+
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_2__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_2__["Foundation"]; });
 
 
 
+_foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__["Touch"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);
+window.Foundation.Touch = _foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__["Touch"];
 
-__WEBPACK_IMPORTED_MODULE_1__foundation_util_touch__["a" /* Touch */].init(__WEBPACK_IMPORTED_MODULE_0_jquery___default.a);
 
-window.Foundation.Touch = __WEBPACK_IMPORTED_MODULE_1__foundation_util_touch__["a" /* Touch */];
 
 /***/ }),
 
-/***/ 71:
+/***/ "./js/foundation.util.touch.js":
+/*!*************************************!*\
+  !*** ./js/foundation.util.touch.js ***!
+  \*************************************/
+/*! exports provided: Touch */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Touch; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-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; }; }();
-
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Touch", function() { return Touch; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
 function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a 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); } }
+
+function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
+
 //**************************************************
 //**Work inspired by multiple jquery swipe plugins**
 //**Done by Yohai Ararat ***************************
 //**************************************************
 
-
-
 var Touch = {};
-
 var startPosX,
     startPosY,
     startTime,
     elapsedTime,
-    isMoving = false;
+    startEvent,
+    isMoving = false,
+    didMoved = false;
 
-function onTouchEnd() {
-  //  alert(this);
+function onTouchEnd(e) {
   this.removeEventListener('touchmove', onTouchMove);
-  this.removeEventListener('touchend', onTouchEnd);
+  this.removeEventListener('touchend', onTouchEnd); // If the touch did not move, consider it as a "tap"
+
+  if (!didMoved) {
+    var tapEvent = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('tap', startEvent || e);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(tapEvent);
+  }
+
+  startEvent = null;
   isMoving = false;
+  didMoved = false;
 }
 
 function onTouchMove(e) {
-  if (__WEBPACK_IMPORTED_MODULE_0_jquery___default.a.spotSwipe.preventDefault) {
+  if (jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.preventDefault) {
     e.preventDefault();
   }
+
   if (isMoving) {
     var x = e.touches[0].pageX;
     var y = e.touches[0].pageY;
     var dx = startPosX - x;
     var dy = startPosY - y;
     var dir;
+    didMoved = true;
     elapsedTime = new Date().getTime() - startTime;
-    if (Math.abs(dx) >= __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.spotSwipe.moveThreshold && elapsedTime <= __WEBPACK_IMPORTED_MODULE_0_jquery___default.a.spotSwipe.timeThreshold) {
+
+    if (Math.abs(dx) >= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.moveThreshold && elapsedTime <= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.timeThreshold) {
       dir = dx > 0 ? 'left' : 'right';
-    }
-    // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
+    } // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {
     //   dir = dy > 0 ? 'down' : 'up';
     // }
+
+
     if (dir) {
       e.preventDefault();
-      onTouchEnd.call(this);
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('swipe', dir).trigger('swipe' + dir);
+      onTouchEnd.apply(this, arguments);
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('swipe', e), dir).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event("swipe".concat(dir), e));
     }
   }
 }
@@ -163,7 +213,9 @@ function onTouchStart(e) {
   if (e.touches.length == 1) {
     startPosX = e.touches[0].pageX;
     startPosY = e.touches[0].pageY;
+    startEvent = e;
     isMoving = true;
+    didMoved = false;
     startTime = new Date().getTime();
     this.addEventListener('touchmove', onTouchMove, false);
     this.addEventListener('touchend', onTouchEnd, false);
@@ -178,7 +230,9 @@ function teardown() {
   this.removeEventListener('touchstart', onTouchStart);
 }
 
-var SpotSwipe = function () {
+var SpotSwipe =
+/*#__PURE__*/
+function () {
   function SpotSwipe($) {
     _classCallCheck(this, SpotSwipe);
 
@@ -188,26 +242,32 @@ var SpotSwipe = function () {
     this.moveThreshold = 75;
     this.timeThreshold = 200;
     this.$ = $;
+
     this._init();
   }
 
   _createClass(SpotSwipe, [{
-    key: '_init',
+    key: "_init",
     value: function _init() {
       var $ = this.$;
-      $.event.special.swipe = { setup: init };
-
+      $.event.special.swipe = {
+        setup: init
+      };
+      $.event.special.tap = {
+        setup: init
+      };
       $.each(['left', 'up', 'down', 'right'], function () {
-        $.event.special['swipe' + this] = { setup: function () {
+        $.event.special["swipe".concat(this)] = {
+          setup: function setup() {
             $(this).on('swipe', $.noop);
-          } };
+          }
+        };
       });
     }
   }]);
 
   return SpotSwipe;
 }();
-
 /****************************************************
  * As far as I can tell, both setupSpotSwipe and    *
  * setupTouchHandler should be idempotent,          *
@@ -215,24 +275,26 @@ var SpotSwipe = function () {
  * values, and do not add event handlers directly.  *
  ****************************************************/
 
+
 Touch.setupSpotSwipe = function ($) {
   $.spotSwipe = new SpotSwipe($);
 };
-
 /****************************************************
  * Method for adding pseudo drag events to elements *
  ***************************************************/
+
+
 Touch.setupTouchHandler = function ($) {
   $.fn.addTouch = function () {
     this.each(function (i, el) {
-      $(el).bind('touchstart touchmove touchend touchcancel', function () {
+      $(el).bind('touchstart touchmove touchend touchcancel', function (event) {
         //we pass the original event object because the jQuery event
         //object is normalized to w3c specs and does not provide the TouchList
         handleTouch(event);
       });
     });
 
-    var handleTouch = function (event) {
+    var handleTouch = function handleTouch(event) {
       var touches = event.changedTouches,
           first = touches[0],
           eventTypes = {
@@ -254,8 +316,11 @@ Touch.setupTouchHandler = function ($) {
         });
       } else {
         simulatedEvent = document.createEvent('MouseEvent');
-        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0 /*left*/, null);
+        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0
+        /*left*/
+        , null);
       }
+
       first.target.dispatchEvent(simulatedEvent);
     };
   };
@@ -270,6 +335,31 @@ Touch.init = function ($) {
 
 
 
+/***/ }),
+
+/***/ 28:
+/*!***********************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.touch.js ***!
+  \***********************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.touch.js */"./js/entries/plugins/foundation.util.touch.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
+
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.touch.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.touch.js.map b/dist/js/plugins/foundation.util.touch.js.map
new file mode 100644 (file)
index 0000000..bc36358
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.touch.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.touch.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Touch","init","$","window","Foundation","startPosX","startPosY","startTime","elapsedTime","startEvent","isMoving","didMoved","onTouchEnd","e","removeEventListener","onTouchMove","tapEvent","Event","trigger","spotSwipe","preventDefault","x","touches","pageX","y","pageY","dx","dy","dir","Date","getTime","Math","abs","moveThreshold","timeThreshold","apply","arguments","onTouchStart","length","addEventListener","teardown","SpotSwipe","version","enabled","document","documentElement","_init","event","special","swipe","setup","tap","each","on","noop","setupSpotSwipe","setupTouchHandler","fn","addTouch","i","el","bind","handleTouch","changedTouches","first","eventTypes","touchstart","touchmove","touchend","type","simulatedEvent","MouseEvent","screenX","screenY","clientX","clientY","createEvent","initMouseEvent","target","dispatchEvent"],"mappings":"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","file":"foundation.util.touch.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.touch\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 28);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","import $ from 'jquery';\n\nimport { Touch } from '../../foundation.util.touch';\n\nTouch.init($);\n\nwindow.Foundation.Touch = Touch;\n\nexport { Foundation } from './foundation.core';\nexport { Touch };\n","//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nimport $ from 'jquery';\n\nvar Touch = {};\n\nvar startPosX,\n    startPosY,\n    startTime,\n    elapsedTime,\n    startEvent,\n    isMoving = false,\n    didMoved = false;\n\nfunction onTouchEnd(e) {\n  this.removeEventListener('touchmove', onTouchMove);\n  this.removeEventListener('touchend', onTouchEnd);\n\n  // If the touch did not move, consider it as a \"tap\"\n  if (!didMoved) {\n    var tapEvent = $.Event('tap', startEvent || e);\n    $(this).trigger(tapEvent);\n  }\n\n  startEvent = null;\n  isMoving = false;\n  didMoved = false;\n}\n\nfunction onTouchMove(e) {\n  if ($.spotSwipe.preventDefault) { e.preventDefault(); }\n\n  if(isMoving) {\n    var x = e.touches[0].pageX;\n    var y = e.touches[0].pageY;\n    var dx = startPosX - x;\n    var dy = startPosY - y;\n    var dir;\n    didMoved = true;\n    elapsedTime = new Date().getTime() - startTime;\n    if(Math.abs(dx) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n      dir = dx > 0 ? 'left' : 'right';\n    }\n    // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n    //   dir = dy > 0 ? 'down' : 'up';\n    // }\n    if(dir) {\n      e.preventDefault();\n      onTouchEnd.apply(this, arguments);\n      $(this)\n        .trigger($.Event('swipe', e), dir)\n        .trigger($.Event(`swipe${dir}`, e));\n    }\n  }\n\n}\n\nfunction onTouchStart(e) {\n\n  if (e.touches.length == 1) {\n    startPosX = e.touches[0].pageX;\n    startPosY = e.touches[0].pageY;\n    startEvent = e;\n    isMoving = true;\n    didMoved = false;\n    startTime = new Date().getTime();\n    this.addEventListener('touchmove', onTouchMove, false);\n    this.addEventListener('touchend', onTouchEnd, false);\n  }\n}\n\nfunction init() {\n  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);\n}\n\nfunction teardown() {\n  this.removeEventListener('touchstart', onTouchStart);\n}\n\nclass SpotSwipe {\n  constructor($) {\n    this.version = '1.0.0';\n    this.enabled = 'ontouchstart' in document.documentElement;\n    this.preventDefault = false;\n    this.moveThreshold = 75;\n    this.timeThreshold = 200;\n    this.$ = $;\n    this._init();\n  }\n\n  _init() {\n    var $ = this.$;\n    $.event.special.swipe = { setup: init };\n    $.event.special.tap = { setup: init };\n\n    $.each(['left', 'up', 'down', 'right'], function () {\n      $.event.special[`swipe${this}`] = { setup: function(){\n        $(this).on('swipe', $.noop);\n      } };\n    });\n  }\n}\n\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and    *\n * setupTouchHandler should be idempotent,          *\n * because they directly replace functions &        *\n * values, and do not add event handlers directly.  *\n ****************************************************/\n\nTouch.setupSpotSwipe = function($) {\n  $.spotSwipe = new SpotSwipe($);\n};\n\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\nTouch.setupTouchHandler = function($) {\n  $.fn.addTouch = function(){\n    this.each(function(i,el){\n      $(el).bind('touchstart touchmove touchend touchcancel', function(event)  {\n        //we pass the original event object because the jQuery event\n        //object is normalized to w3c specs and does not provide the TouchList\n        handleTouch(event);\n      });\n    });\n\n    var handleTouch = function(event){\n      var touches = event.changedTouches,\n          first = touches[0],\n          eventTypes = {\n            touchstart: 'mousedown',\n            touchmove: 'mousemove',\n            touchend: 'mouseup'\n          },\n          type = eventTypes[event.type],\n          simulatedEvent\n        ;\n\n      if('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n        simulatedEvent = new window.MouseEvent(type, {\n          'bubbles': true,\n          'cancelable': true,\n          'screenX': first.screenX,\n          'screenY': first.screenY,\n          'clientX': first.clientX,\n          'clientY': first.clientY\n        });\n      } else {\n        simulatedEvent = document.createEvent('MouseEvent');\n        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0/*left*/, null);\n      }\n      first.target.dispatchEvent(simulatedEvent);\n    };\n  };\n};\n\nTouch.init = function ($) {\n\n  if(typeof($.spotSwipe) === 'undefined') {\n    Touch.setupSpotSwipe($);\n    Touch.setupTouchHandler($);\n  }\n};\n\nexport {Touch};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index 8670fc3949b9841d103b021ae93aa3962dd682ee..e3a239f0a9b146173a57987c4c05fe593a97aa96 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(o){if(n[o])return n[o].exports;var i=n[o]={i:o,l:!1,exports:{}};return e[o].call(i.exports,i,i.exports,t),i.l=!0,i.exports}var n={};t.m=e,t.c=n,t.i=function(e){return e},t.d=function(e,n,o){t.o(e,n)||Object.defineProperty(e,n,{configurable:!1,enumerable:!0,get:o})},t.n=function(e){var n=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(n,"a",n),n},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=107)}({0:function(e,t){e.exports=jQuery},107:function(e,t,n){e.exports=n(41)},41:function(e,t,n){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var o=n(0),i=n.n(o),u=n(71);u.a.init(i.a),window.Foundation.Touch=u.a},71:function(e,t,n){"use strict";function o(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}function i(){this.removeEventListener("touchmove",u),this.removeEventListener("touchend",i),w=!1}function u(e){if(l.a.spotSwipe.preventDefault&&e.preventDefault(),w){var t,n=e.touches[0].pageX,o=(e.touches[0].pageY,s-n);p=(new Date).getTime()-h,Math.abs(o)>=l.a.spotSwipe.moveThreshold&&p<=l.a.spotSwipe.timeThreshold&&(t=o>0?"left":"right"),t&&(e.preventDefault(),i.call(this),l()(this).trigger("swipe",t).trigger("swipe"+t))}}function r(e){1==e.touches.length&&(s=e.touches[0].pageX,a=e.touches[0].pageY,w=!0,h=(new Date).getTime(),this.addEventListener("touchmove",u,!1),this.addEventListener("touchend",i,!1))}function c(){this.addEventListener&&this.addEventListener("touchstart",r,!1)}n.d(t,"a",function(){return v});var s,a,h,p,f=n(0),l=n.n(f),d=function(){function e(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}return function(t,n,o){return n&&e(t.prototype,n),o&&e(t,o),t}}(),v={},w=!1,m=function(){function e(t){o(this,e),this.version="1.0.0",this.enabled="ontouchstart"in document.documentElement,this.preventDefault=!1,this.moveThreshold=75,this.timeThreshold=200,this.$=t,this._init()}return d(e,[{key:"_init",value:function(){var e=this.$;e.event.special.swipe={setup:c},e.each(["left","up","down","right"],function(){e.event.special["swipe"+this]={setup:function(){e(this).on("swipe",e.noop)}}})}}]),e}();v.setupSpotSwipe=function(e){e.spotSwipe=new m(e)},v.setupTouchHandler=function(e){e.fn.addTouch=function(){this.each(function(n,o){e(o).bind("touchstart touchmove touchend touchcancel",function(){t(event)})});var t=function(e){var t,n=e.changedTouches,o=n[0],i={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup"},u=i[e.type];"MouseEvent"in window&&"function"==typeof window.MouseEvent?t=new window.MouseEvent(u,{bubbles:!0,cancelable:!0,screenX:o.screenX,screenY:o.screenY,clientX:o.clientX,clientY:o.clientY}):(t=document.createEvent("MouseEvent"),t.initMouseEvent(u,!0,!0,window,1,o.screenX,o.screenY,o.clientX,o.clientY,!1,!1,!1,!1,0,null)),o.target.dispatchEvent(t)}}},v.init=function(e){void 0===e.spotSwipe&&(v.setupSpotSwipe(e),v.setupTouchHandler(e))}}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","jquery"],t):"object"==typeof exports?exports["foundation.util.touch"]=t(require("./foundation.core"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.util.touch"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.jQuery))}(window,function(n,o){return function(n){var o={};function i(e){if(o[e])return o[e].exports;var t=o[e]={i:e,l:!1,exports:{}};return n[e].call(t.exports,t,t.exports,i),t.l=!0,t.exports}return i.m=n,i.c=o,i.d=function(e,t,n){i.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:n})},i.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},i.t=function(t,e){if(1&e&&(t=i(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var n=Object.create(null);if(i.r(n),Object.defineProperty(n,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var o in t)i.d(n,o,function(e){return t[e]}.bind(null,o));return n},i.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return i.d(t,"a",t),t},i.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},i.p="",i(i.s=28)}({"./foundation.core":function(e,t){e.exports=n},"./js/entries/plugins/foundation.util.touch.js":function(e,t,n){"use strict";n.r(t);var o=n("jquery"),i=n.n(o),u=n("./js/foundation.util.touch.js");n.d(t,"Touch",function(){return u.Touch});var r=n("./foundation.core");n.d(t,"Foundation",function(){return r.Foundation}),u.Touch.init(i.a),window.Foundation.Touch=u.Touch},"./js/foundation.util.touch.js":function(e,t,n){"use strict";n.r(t),n.d(t,"Touch",function(){return f});var o=n("jquery"),i=n.n(o);function u(e,t){for(var n=0;n<t.length;n++){var o=t[n];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,o.key,o)}}var r,c,s,a,f={},p=!1,d=!1;function l(e){if(this.removeEventListener("touchmove",h),this.removeEventListener("touchend",l),!d){var t=i.a.Event("tap",a||e);i()(this).trigger(t)}a=null,d=p=!1}function h(e){if(i.a.spotSwipe.preventDefault&&e.preventDefault(),p){var t,n=e.touches[0].pageX,o=(e.touches[0].pageY,r-n);d=!0,s=(new Date).getTime()-c,Math.abs(o)>=i.a.spotSwipe.moveThreshold&&s<=i.a.spotSwipe.timeThreshold&&(t=0<o?"left":"right"),t&&(e.preventDefault(),l.apply(this,arguments),i()(this).trigger(i.a.Event("swipe",e),t).trigger(i.a.Event("swipe".concat(t),e)))}}function v(e){1==e.touches.length&&(r=e.touches[0].pageX,e.touches[0].pageY,a=e,d=!(p=!0),c=(new Date).getTime(),this.addEventListener("touchmove",h,!1),this.addEventListener("touchend",l,!1))}function w(){this.addEventListener&&this.addEventListener("touchstart",v,!1)}var m=function(){function t(e){!function(e,t){if(!(e instanceof t))throw new TypeError("Cannot call a class as a function")}(this,t),this.version="1.0.0",this.enabled="ontouchstart"in document.documentElement,this.preventDefault=!1,this.moveThreshold=75,this.timeThreshold=200,this.$=e,this._init()}var e,n,o;return e=t,(n=[{key:"_init",value:function(){var e=this.$;e.event.special.swipe={setup:w},e.event.special.tap={setup:w},e.each(["left","up","down","right"],function(){e.event.special["swipe".concat(this)]={setup:function(){e(this).on("swipe",e.noop)}}})}}])&&u(e.prototype,n),o&&u(e,o),t}();f.setupSpotSwipe=function(e){e.spotSwipe=new m(e)},f.setupTouchHandler=function(o){o.fn.addTouch=function(){this.each(function(e,t){o(t).bind("touchstart touchmove touchend touchcancel",function(e){n(e)})});var n=function(e){var t,n=e.changedTouches[0],o={touchstart:"mousedown",touchmove:"mousemove",touchend:"mouseup"}[e.type];"MouseEvent"in window&&"function"==typeof window.MouseEvent?t=new window.MouseEvent(o,{bubbles:!0,cancelable:!0,screenX:n.screenX,screenY:n.screenY,clientX:n.clientX,clientY:n.clientY}):(t=document.createEvent("MouseEvent")).initMouseEvent(o,!0,!0,window,1,n.screenX,n.screenY,n.clientX,n.clientY,!1,!1,!1,!1,0,null),n.target.dispatchEvent(t)}}},f.init=function(e){void 0===e.spotSwipe&&(f.setupSpotSwipe(e),f.setupTouchHandler(e))}},28:function(e,t,n){e.exports=n("./js/entries/plugins/foundation.util.touch.js")},jquery:function(e,t){e.exports=o}})});
+//# sourceMappingURL=foundation.util.touch.min.js.map
diff --git a/dist/js/plugins/foundation.util.touch.min.js.map b/dist/js/plugins/foundation.util.touch.min.js.map
new file mode 100644 (file)
index 0000000..186d43a
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.touch.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./js/entries/plugins/foundation.util.touch.js","__webpack_exports__","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__","_foundation_core__WEBPACK_IMPORTED_MODULE_2__","init","a","Foundation","Touch","./js/foundation.util.touch.js","_defineProperties","target","props","length","descriptor","configurable","writable","startPosX","startTime","elapsedTime","startEvent","isMoving","didMoved","onTouchEnd","e","this","removeEventListener","onTouchMove","tapEvent","Event","trigger","spotSwipe","preventDefault","dir","x","touches","pageX","dx","pageY","Date","getTime","Math","abs","moveThreshold","timeThreshold","apply","arguments","concat","onTouchStart","addEventListener","SpotSwipe","$","instance","Constructor","TypeError","_classCallCheck","version","enabled","document","documentElement","_init","protoProps","staticProps","event","special","swipe","setup","tap","each","on","noop","setupSpotSwipe","setupTouchHandler","fn","addTouch","el","handleTouch","simulatedEvent","first","changedTouches","type","touchstart","touchmove","touchend","MouseEvent","bubbles","cancelable","screenX","screenY","clientX","clientY","createEvent","initMouseEvent","dispatchEvent","28","jquery"],"mappings":"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","file":"foundation.util.touch.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.touch\"] = factory(require(\"./foundation.core\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.touch\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 28);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.touch.js\":\n/*!*****************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.touch.js ***!\n  \\*****************************************************/\n/*! exports provided: Foundation, Touch */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../foundation.util.touch */ \"./js/foundation.util.touch.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Touch\", function() { return _foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__[\"Touch\"]; });\n\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_2__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_2__[\"Foundation\"]; });\n\n\n\n_foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__[\"Touch\"].init(jquery__WEBPACK_IMPORTED_MODULE_0___default.a);\nwindow.Foundation.Touch = _foundation_util_touch__WEBPACK_IMPORTED_MODULE_1__[\"Touch\"];\n\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.touch.js\":\n/*!*************************************!*\\\n  !*** ./js/foundation.util.touch.js ***!\n  \\*************************************/\n/*! exports provided: Touch */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Touch\", function() { return Touch; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\nfunction _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError(\"Cannot call a class as a function\"); } }\n\nfunction _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); } }\n\nfunction _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }\n\n//**************************************************\n//**Work inspired by multiple jquery swipe plugins**\n//**Done by Yohai Ararat ***************************\n//**************************************************\n\nvar Touch = {};\nvar startPosX,\n    startPosY,\n    startTime,\n    elapsedTime,\n    startEvent,\n    isMoving = false,\n    didMoved = false;\n\nfunction onTouchEnd(e) {\n  this.removeEventListener('touchmove', onTouchMove);\n  this.removeEventListener('touchend', onTouchEnd); // If the touch did not move, consider it as a \"tap\"\n\n  if (!didMoved) {\n    var tapEvent = jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('tap', startEvent || e);\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(tapEvent);\n  }\n\n  startEvent = null;\n  isMoving = false;\n  didMoved = false;\n}\n\nfunction onTouchMove(e) {\n  if (jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.preventDefault) {\n    e.preventDefault();\n  }\n\n  if (isMoving) {\n    var x = e.touches[0].pageX;\n    var y = e.touches[0].pageY;\n    var dx = startPosX - x;\n    var dy = startPosY - y;\n    var dir;\n    didMoved = true;\n    elapsedTime = new Date().getTime() - startTime;\n\n    if (Math.abs(dx) >= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.moveThreshold && elapsedTime <= jquery__WEBPACK_IMPORTED_MODULE_0___default.a.spotSwipe.timeThreshold) {\n      dir = dx > 0 ? 'left' : 'right';\n    } // else if(Math.abs(dy) >= $.spotSwipe.moveThreshold && elapsedTime <= $.spotSwipe.timeThreshold) {\n    //   dir = dy > 0 ? 'down' : 'up';\n    // }\n\n\n    if (dir) {\n      e.preventDefault();\n      onTouchEnd.apply(this, arguments);\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event('swipe', e), dir).trigger(jquery__WEBPACK_IMPORTED_MODULE_0___default.a.Event(\"swipe\".concat(dir), e));\n    }\n  }\n}\n\nfunction onTouchStart(e) {\n  if (e.touches.length == 1) {\n    startPosX = e.touches[0].pageX;\n    startPosY = e.touches[0].pageY;\n    startEvent = e;\n    isMoving = true;\n    didMoved = false;\n    startTime = new Date().getTime();\n    this.addEventListener('touchmove', onTouchMove, false);\n    this.addEventListener('touchend', onTouchEnd, false);\n  }\n}\n\nfunction init() {\n  this.addEventListener && this.addEventListener('touchstart', onTouchStart, false);\n}\n\nfunction teardown() {\n  this.removeEventListener('touchstart', onTouchStart);\n}\n\nvar SpotSwipe =\n/*#__PURE__*/\nfunction () {\n  function SpotSwipe($) {\n    _classCallCheck(this, SpotSwipe);\n\n    this.version = '1.0.0';\n    this.enabled = 'ontouchstart' in document.documentElement;\n    this.preventDefault = false;\n    this.moveThreshold = 75;\n    this.timeThreshold = 200;\n    this.$ = $;\n\n    this._init();\n  }\n\n  _createClass(SpotSwipe, [{\n    key: \"_init\",\n    value: function _init() {\n      var $ = this.$;\n      $.event.special.swipe = {\n        setup: init\n      };\n      $.event.special.tap = {\n        setup: init\n      };\n      $.each(['left', 'up', 'down', 'right'], function () {\n        $.event.special[\"swipe\".concat(this)] = {\n          setup: function setup() {\n            $(this).on('swipe', $.noop);\n          }\n        };\n      });\n    }\n  }]);\n\n  return SpotSwipe;\n}();\n/****************************************************\n * As far as I can tell, both setupSpotSwipe and    *\n * setupTouchHandler should be idempotent,          *\n * because they directly replace functions &        *\n * values, and do not add event handlers directly.  *\n ****************************************************/\n\n\nTouch.setupSpotSwipe = function ($) {\n  $.spotSwipe = new SpotSwipe($);\n};\n/****************************************************\n * Method for adding pseudo drag events to elements *\n ***************************************************/\n\n\nTouch.setupTouchHandler = function ($) {\n  $.fn.addTouch = function () {\n    this.each(function (i, el) {\n      $(el).bind('touchstart touchmove touchend touchcancel', function (event) {\n        //we pass the original event object because the jQuery event\n        //object is normalized to w3c specs and does not provide the TouchList\n        handleTouch(event);\n      });\n    });\n\n    var handleTouch = function handleTouch(event) {\n      var touches = event.changedTouches,\n          first = touches[0],\n          eventTypes = {\n        touchstart: 'mousedown',\n        touchmove: 'mousemove',\n        touchend: 'mouseup'\n      },\n          type = eventTypes[event.type],\n          simulatedEvent;\n\n      if ('MouseEvent' in window && typeof window.MouseEvent === 'function') {\n        simulatedEvent = new window.MouseEvent(type, {\n          'bubbles': true,\n          'cancelable': true,\n          'screenX': first.screenX,\n          'screenY': first.screenY,\n          'clientX': first.clientX,\n          'clientY': first.clientY\n        });\n      } else {\n        simulatedEvent = document.createEvent('MouseEvent');\n        simulatedEvent.initMouseEvent(type, true, true, window, 1, first.screenX, first.screenY, first.clientX, first.clientY, false, false, false, false, 0\n        /*left*/\n        , null);\n      }\n\n      first.target.dispatchEvent(simulatedEvent);\n    };\n  };\n};\n\nTouch.init = function ($) {\n  if (typeof $.spotSwipe === 'undefined') {\n    Touch.setupSpotSwipe($);\n    Touch.setupTouchHandler($);\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 28:\n/*!***********************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.touch.js ***!\n  \\***********************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.touch.js */\"./js/entries/plugins/foundation.util.touch.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.touch.js.map"]}
\ No newline at end of file
index 160ce5c6235498870a08b3851b159d44baa86161..202cde18321d49960fbca81d3f52103ba556e398 100644 (file)
@@ -1,4 +1,14 @@
-/******/ (function(modules) { // webpackBootstrap
+(function webpackUniversalModuleDefinition(root, factory) {
+       if(typeof exports === 'object' && typeof module === 'object')
+               module.exports = factory(require("./foundation.core"), require("./foundation.util.motion"), require("jquery"));
+       else if(typeof define === 'function' && define.amd)
+               define(["./foundation.core", "./foundation.util.motion", "jquery"], factory);
+       else if(typeof exports === 'object')
+               exports["foundation.util.triggers"] = factory(require("./foundation.core"), require("./foundation.util.motion"), require("jquery"));
+       else
+               root["__FOUNDATION_EXTERNAL__"] = root["__FOUNDATION_EXTERNAL__"] || {}, root["__FOUNDATION_EXTERNAL__"]["foundation.util.triggers"] = factory(root["__FOUNDATION_EXTERNAL__"]["foundation.core"], root["__FOUNDATION_EXTERNAL__"]["foundation.util.motion"], root["jQuery"]);
+})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {
+return /******/ (function(modules) { // webpackBootstrap
 /******/       // The module cache
 /******/       var installedModules = {};
 /******/
 /******/       // expose the module cache
 /******/       __webpack_require__.c = installedModules;
 /******/
-/******/       // identity function for calling harmony imports with the correct context
-/******/       __webpack_require__.i = function(value) { return value; };
-/******/
 /******/       // define getter function for harmony exports
 /******/       __webpack_require__.d = function(exports, name, getter) {
 /******/               if(!__webpack_require__.o(exports, name)) {
-/******/                       Object.defineProperty(exports, name, {
-/******/                               configurable: false,
-/******/                               enumerable: true,
-/******/                               get: getter
-/******/                       });
+/******/                       Object.defineProperty(exports, name, { enumerable: true, get: getter });
 /******/               }
 /******/       };
 /******/
+/******/       // define __esModule on exports
+/******/       __webpack_require__.r = function(exports) {
+/******/               if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
+/******/                       Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
+/******/               }
+/******/               Object.defineProperty(exports, '__esModule', { value: true });
+/******/       };
+/******/
+/******/       // create a fake namespace object
+/******/       // mode & 1: value is a module id, require it
+/******/       // mode & 2: merge all properties of value into the ns
+/******/       // mode & 4: return value when already ns object
+/******/       // mode & 8|1: behave like require
+/******/       __webpack_require__.t = function(value, mode) {
+/******/               if(mode & 1) value = __webpack_require__(value);
+/******/               if(mode & 8) return value;
+/******/               if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
+/******/               var ns = Object.create(null);
+/******/               __webpack_require__.r(ns);
+/******/               Object.defineProperty(ns, 'default', { enumerable: true, value: value });
+/******/               if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
+/******/               return ns;
+/******/       };
+/******/
 /******/       // getDefaultExport function for compatibility with non-harmony modules
 /******/       __webpack_require__.n = function(module) {
 /******/               var getter = module && module.__esModule ?
 /******/       // __webpack_public_path__
 /******/       __webpack_require__.p = "";
 /******/
+/******/
 /******/       // Load entry module and return exports
-/******/       return __webpack_require__(__webpack_require__.s = 108);
+/******/       return __webpack_require__(__webpack_require__.s = 29);
 /******/ })
 /************************************************************************/
 /******/ ({
 
-/***/ 0:
-/***/ (function(module, exports) {
-
-module.exports = jQuery;
-
-/***/ }),
-
-/***/ 1:
+/***/ "./foundation.core":
+/*!****************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.core"],"amd":"./foundation.core","commonjs":"./foundation.core","commonjs2":"./foundation.core"} ***!
+  \****************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Foundation: window.Foundation};
-
-/***/ }),
-
-/***/ 108:
-/***/ (function(module, exports, __webpack_require__) {
-
-module.exports = __webpack_require__(42);
-
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;
 
 /***/ }),
 
-/***/ 4:
+/***/ "./foundation.util.motion":
+/*!********************************************************************************************************************************************************************************************!*\
+  !*** external {"root":["__FOUNDATION_EXTERNAL__","foundation.util.motion"],"amd":"./foundation.util.motion","commonjs":"./foundation.util.motion","commonjs2":"./foundation.util.motion"} ***!
+  \********************************************************************************************************************************************************************************************/
+/*! no static exports found */
 /***/ (function(module, exports) {
 
-module.exports = {Motion: window.Foundation.Motion, Move: window.Foundation.Move};
+module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;
 
 /***/ }),
 
-/***/ 42:
+/***/ "./js/entries/plugins/foundation.util.triggers.js":
+/*!********************************************************!*\
+  !*** ./js/entries/plugins/foundation.util.triggers.js ***!
+  \********************************************************/
+/*! exports provided: Foundation, Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core__ = __webpack_require__(1);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__foundation_core___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__foundation_core__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__foundation_util_triggers__ = __webpack_require__(7);
+__webpack_require__.r(__webpack_exports__);
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ "./foundation.core");
+/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Foundation", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]; });
+
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../foundation.util.triggers */ "./js/foundation.util.triggers.js");
+/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_2__["Triggers"]; });
+
 
 
 
+_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_2__["Triggers"].init(jquery__WEBPACK_IMPORTED_MODULE_1___default.a, _foundation_core__WEBPACK_IMPORTED_MODULE_0__["Foundation"]);
 
-__WEBPACK_IMPORTED_MODULE_2__foundation_util_triggers__["a" /* Triggers */].init(__WEBPACK_IMPORTED_MODULE_1_jquery___default.a, __WEBPACK_IMPORTED_MODULE_0__foundation_core__["Foundation"]);
 
 /***/ }),
 
-/***/ 7:
+/***/ "./js/foundation.util.triggers.js":
+/*!****************************************!*\
+  !*** ./js/foundation.util.triggers.js ***!
+  \****************************************/
+/*! exports provided: Triggers */
 /***/ (function(module, __webpack_exports__, __webpack_require__) {
 
 "use strict";
-/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return Triggers; });
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery__ = __webpack_require__(0);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0_jquery___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0_jquery__);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__ = __webpack_require__(4);
-/* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__);
+__webpack_require__.r(__webpack_exports__);
+/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "Triggers", function() { return Triggers; });
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ "jquery");
+/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ "./foundation.core");
+/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ "./foundation.util.motion");
+/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);
+
+
+function _typeof(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
 
 
 
@@ -131,17 +170,19 @@ __WEBPACK_IMPORTED_MODULE_2__foundation_util_triggers__["a" /* Triggers */].init
 
 var MutationObserver = function () {
   var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];
+
   for (var i = 0; i < prefixes.length; i++) {
-    if (prefixes[i] + 'MutationObserver' in window) {
-      return window[prefixes[i] + 'MutationObserver'];
+    if ("".concat(prefixes[i], "MutationObserver") in window) {
+      return window["".concat(prefixes[i], "MutationObserver")];
     }
   }
+
   return false;
 }();
 
-var triggers = function (el, type) {
+var triggers = function triggers(el, type) {
   el.data(type).split(' ').forEach(function (id) {
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id)[type === 'close' ? 'trigger' : 'triggerHandler'](type + '.zf.trigger', [el]);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler']("".concat(type, ".zf.trigger"), [el]);
   });
 };
 
@@ -152,138 +193,142 @@ var Triggers = {
   },
   Initializers: {}
 };
-
 Triggers.Listeners.Basic = {
-  openListener: function () {
-    triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'open');
+  openListener: function openListener() {
+    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');
   },
-  closeListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('close');
+  closeListener: function closeListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'close');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('close.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');
     }
   },
-  toggleListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle');
+  toggleListener: function toggleListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');
+
     if (id) {
-      triggers(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), 'toggle');
+      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('toggle.zf.trigger');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');
     }
   },
-  closeableListener: function (e) {
+  closeableListener: function closeableListener(e) {
     e.stopPropagation();
-    var animation = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('closable');
+    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');
 
     if (animation !== '') {
-      __WEBPACK_IMPORTED_MODULE_1__foundation_util_motion__["Motion"].animateOut(__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this), animation, function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).trigger('closed.zf');
+      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__["Motion"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');
       });
     } else {
-      __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).fadeOut().trigger('closed.zf');
+      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');
     }
   },
-  toggleFocusListener: function () {
-    var id = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).data('toggle-focus');
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()('#' + id).triggerHandler('toggle.zf.trigger', [__WEBPACK_IMPORTED_MODULE_0_jquery___default()(this)]);
+  toggleFocusListener: function toggleFocusListener() {
+    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()("#".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);
   }
-};
+}; // Elements with [data-open] will reveal a plugin that supports it when clicked.
 
-// Elements with [data-open] will reveal a plugin that supports it when clicked.
 Triggers.Initializers.addOpenListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);
   $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);
-};
-
-// Elements with [data-close] will close a plugin that supports it when clicked.
+}; // Elements with [data-close] will close a plugin that supports it when clicked.
 // If used without a value on [data-close], the event will bubble, allowing it to close a parent component.
+
+
 Triggers.Initializers.addCloseListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);
   $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);
-};
+}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.
+
 
-// Elements with [data-toggle] will toggle a plugin that supports it when clicked.
 Triggers.Initializers.addToggleListener = function ($elem) {
   $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);
   $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);
-};
+}; // Elements with [data-closable] will respond to close.zf.trigger events.
+
 
-// Elements with [data-closable] will respond to close.zf.trigger events.
 Triggers.Initializers.addCloseableListener = function ($elem) {
   $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);
   $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);
-};
+}; // Elements with [data-toggle-focus] will respond to coming in and out of focus
+
 
-// Elements with [data-toggle-focus] will respond to coming in and out of focus
 Triggers.Initializers.addToggleFocusListener = function ($elem) {
   $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);
   $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);
-};
+}; // More Global/complex listeners and triggers
+
 
-// More Global/complex listeners and triggers
 Triggers.Listeners.Global = {
-  resizeListener: function ($nodes) {
+  resizeListener: function resizeListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('resizeme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a resize event
+    } //trigger all listening elements and signal a resize event
+
+
     $nodes.attr('data-events', "resize");
   },
-  scrollListener: function ($nodes) {
+  scrollListener: function scrollListener($nodes) {
     if (!MutationObserver) {
       //fallback for IE 9
       $nodes.each(function () {
-        __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this).triggerHandler('scrollme.zf.trigger');
+        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');
       });
-    }
-    //trigger all listening elements and signal a scroll event
+    } //trigger all listening elements and signal a scroll event
+
+
     $nodes.attr('data-events', "scroll");
   },
-  closeMeListener: function (e, pluginId) {
+  closeMeListener: function closeMeListener(e, pluginId) {
     var plugin = e.namespace.split('.')[0];
-    var plugins = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-' + plugin + ']').not('[data-yeti-box="' + pluginId + '"]');
-
+    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()("[data-".concat(plugin, "]")).not("[data-yeti-box=\"".concat(pluginId, "\"]"));
     plugins.each(function () {
-      var _this = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(this);
+      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);
+
       _this.triggerHandler('close.zf.trigger', [_this]);
     });
-  }
+  } // Global, parses whole document.
+
+};
 
-  // Global, parses whole document.
-};Triggers.Initializers.addClosemeListener = function (pluginName) {
-  var yetiBoxes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-yeti-box]'),
+Triggers.Initializers.addClosemeListener = function (pluginName) {
+  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),
       plugNames = ['dropdown', 'tooltip', 'reveal'];
 
   if (pluginName) {
     if (typeof pluginName === 'string') {
       plugNames.push(pluginName);
-    } else if (typeof pluginName === 'object' && typeof pluginName[0] === 'string') {
-      plugNames.concat(pluginName);
+    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {
+      plugNames = plugNames.concat(pluginName);
     } else {
       console.error('Plugin names must be strings');
     }
   }
+
   if (yetiBoxes.length) {
     var listeners = plugNames.map(function (name) {
-      return 'closeme.zf.' + name;
+      return "closeme.zf.".concat(name);
     }).join(' ');
-
-    __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
+    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);
   }
 };
 
 function debounceGlobalListener(debounce, trigger, listener) {
-  var timer = void 0,
+  var timer,
       args = Array.prototype.slice.call(arguments, 3);
-  __WEBPACK_IMPORTED_MODULE_0_jquery___default()(window).off(trigger).on(trigger, function (e) {
+  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {
     if (timer) {
       clearTimeout(timer);
     }
+
     timer = setTimeout(function () {
       listener.apply(null, args);
     }, debounce || 10); //default time to emit scroll event
@@ -291,14 +336,16 @@ function debounceGlobalListener(debounce, trigger, listener) {
 }
 
 Triggers.Initializers.addResizeListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-resize]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);
   }
 };
 
 Triggers.Initializers.addScrollListener = function (debounce) {
-  var $nodes = __WEBPACK_IMPORTED_MODULE_0_jquery___default()('[data-scroll]');
+  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');
+
   if ($nodes.length) {
     debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);
   }
@@ -308,25 +355,27 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
   if (!MutationObserver) {
     return false;
   }
-  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');
 
-  //element callback
-  var listeningElementsMutation = function (mutationRecordsList) {
-    var $target = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(mutationRecordsList[0].target);
+  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback
+
+  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {
+    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type
 
-    //trigger the event handler for the element depending on type
     switch (mutationRecordsList[0].type) {
       case "attributes":
         if ($target.attr("data-events") === "scroll" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);
         }
+
         if ($target.attr("data-events") === "resize" && mutationRecordsList[0].attributeName === "data-events") {
           $target.triggerHandler('resizeme.zf.trigger', [$target]);
         }
+
         if (mutationRecordsList[0].attributeName === "style") {
           $target.closest("[data-mutate]").attr("data-events", "mutate");
           $target.closest("[data-mutate]").triggerHandler('mutateme.zf.trigger', [$target.closest("[data-mutate]")]);
         }
+
         break;
 
       case "childList":
@@ -344,14 +393,19 @@ Triggers.Initializers.addMutationEventsListener = function ($elem) {
     //for each element that needs to listen for resizing, scrolling, or mutation add a single observer
     for (var i = 0; i <= $nodes.length - 1; i++) {
       var elementObserver = new MutationObserver(listeningElementsMutation);
-      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: ["data-events", "style"] });
+      elementObserver.observe($nodes[i], {
+        attributes: true,
+        childList: true,
+        characterData: false,
+        subtree: true,
+        attributeFilter: ["data-events", "style"]
+      });
     }
   }
 };
 
 Triggers.Initializers.addSimpleListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
-
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addOpenListener($document);
   Triggers.Initializers.addCloseListener($document);
   Triggers.Initializers.addToggleListener($document);
@@ -360,7 +414,7 @@ Triggers.Initializers.addSimpleListeners = function () {
 };
 
 Triggers.Initializers.addGlobalListeners = function () {
-  var $document = __WEBPACK_IMPORTED_MODULE_0_jquery___default()(document);
+  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);
   Triggers.Initializers.addMutationEventsListener($document);
   Triggers.Initializers.addResizeListener();
   Triggers.Initializers.addScrollListener();
@@ -368,31 +422,48 @@ Triggers.Initializers.addGlobalListeners = function () {
 };
 
 Triggers.init = function ($, Foundation) {
-  if (typeof $.triggersInitialized === 'undefined') {
-    var $document = $(document);
-
-    if (document.readyState === "complete") {
+  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__["onLoad"])($(window), function () {
+    if ($.triggersInitialized !== true) {
       Triggers.Initializers.addSimpleListeners();
       Triggers.Initializers.addGlobalListeners();
-    } else {
-      $(window).on('load', function () {
-        Triggers.Initializers.addSimpleListeners();
-        Triggers.Initializers.addGlobalListeners();
-      });
+      $.triggersInitialized = true;
     }
-
-    $.triggersInitialized = true;
-  }
+  });
 
   if (Foundation) {
-    Foundation.Triggers = Triggers;
-    // Legacy included to be backwards compatible for now.
+    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.
+
     Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;
   }
 };
 
 
 
+/***/ }),
+
+/***/ 29:
+/*!**************************************************************!*\
+  !*** multi ./js/entries/plugins/foundation.util.triggers.js ***!
+  \**************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports, __webpack_require__) {
+
+module.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.triggers.js */"./js/entries/plugins/foundation.util.triggers.js");
+
+
+/***/ }),
+
+/***/ "jquery":
+/*!********************************************************************************************!*\
+  !*** external {"root":["jQuery"],"amd":"jquery","commonjs":"jquery","commonjs2":"jquery"} ***!
+  \********************************************************************************************/
+/*! no static exports found */
+/***/ (function(module, exports) {
+
+module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;
+
 /***/ })
 
-/******/ });
\ No newline at end of file
+/******/ });
+});
+//# sourceMappingURL=foundation.util.triggers.js.map
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.util.triggers.js.map b/dist/js/plugins/foundation.util.triggers.js.map
new file mode 100644 (file)
index 0000000..1a8d661
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/universalModuleDefinition","webpack://__FOUNDATION_EXTERNAL__.[name]/webpack/bootstrap","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"}","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/entries/plugins/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/./js/foundation.util.triggers.js","webpack://__FOUNDATION_EXTERNAL__.[name]/external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"}"],"names":["Triggers","init","$","Foundation","MutationObserver","prefixes","i","length","window","triggers","el","type","data","split","forEach","id","Listeners","Basic","Global","Initializers","openListener","closeListener","trigger","toggleListener","closeableListener","e","stopPropagation","animation","Motion","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","off","on","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","attr","scrollListener","closeMeListener","pluginId","plugin","namespace","plugins","not","_this","addClosemeListener","pluginName","yetiBoxes","plugNames","push","concat","console","error","listeners","map","name","join","debounceGlobalListener","debounce","listener","timer","args","Array","prototype","slice","call","arguments","clearTimeout","setTimeout","apply","addResizeListener","addScrollListener","addMutationEventsListener","find","listeningElementsMutation","mutationRecordsList","$target","target","attributeName","pageYOffset","closest","elementObserver","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","document","addGlobalListeners","onLoad","triggersInitialized","IHearYou"],"mappings":"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","file":"foundation.util.triggers.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.triggers\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.triggers\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 29);\n","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;","module.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;","import { Foundation } from './foundation.core';\nimport $ from 'jquery';\n\nimport { Triggers } from '../../foundation.util.triggers';\nTriggers.init($, Foundation);\n\nexport { Foundation, Triggers };\n","'use strict';\n\nimport $ from 'jquery';\nimport { onLoad } from './foundation.core.utils';\nimport { Motion } from './foundation.util.motion';\n\nconst MutationObserver = (function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n  for (var i=0; i < prefixes.length; i++) {\n    if (`${prefixes[i]}MutationObserver` in window) {\n      return window[`${prefixes[i]}MutationObserver`];\n    }\n  }\n  return false;\n}());\n\nconst triggers = (el, type) => {\n  el.data(type).split(' ').forEach(id => {\n    $(`#${id}`)[ type === 'close' ? 'trigger' : 'triggerHandler'](`${type}.zf.trigger`, [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n}\n\nTriggers.Listeners.Basic  = {\n  openListener: function() {\n    triggers($(this), 'open');\n  },\n  closeListener: function() {\n    let id = $(this).data('close');\n    if (id) {\n      triggers($(this), 'close');\n    }\n    else {\n      $(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function() {\n    let id = $(this).data('toggle');\n    if (id) {\n      triggers($(this), 'toggle');\n    } else {\n      $(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function(e) {\n    e.stopPropagation();\n    let animation = $(this).data('closable');\n\n    if(animation !== ''){\n      Motion.animateOut($(this), animation, function() {\n        $(this).trigger('closed.zf');\n      });\n    }else{\n      $(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function() {\n    let id = $(this).data('toggle-focus');\n    $(`#${id}`).triggerHandler('toggle.zf.trigger', [$(this)]);\n  }\n};\n\n// Elements with [data-open] will reveal a plugin that supports it when clicked.\nTriggers.Initializers.addOpenListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}\n\n// Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\nTriggers.Initializers.addCloseListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}\n\n// Elements with [data-toggle] will toggle a plugin that supports it when clicked.\nTriggers.Initializers.addToggleListener = ($elem) => {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}\n\n// Elements with [data-closable] will respond to close.zf.trigger events.\nTriggers.Initializers.addCloseableListener = ($elem) => {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}\n\n// Elements with [data-toggle-focus] will respond to coming in and out of focus\nTriggers.Initializers.addToggleFocusListener = ($elem) => {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}\n\n\n\n// More Global/complex listeners and triggers\nTriggers.Listeners.Global  = {\n  resizeListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('resizeme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a resize event\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function($nodes) {\n    if(!MutationObserver){//fallback for IE 9\n      $nodes.each(function(){\n        $(this).triggerHandler('scrollme.zf.trigger');\n      });\n    }\n    //trigger all listening elements and signal a scroll event\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function(e, pluginId){\n    let plugin = e.namespace.split('.')[0];\n    let plugins = $(`[data-${plugin}]`).not(`[data-yeti-box=\"${pluginId}\"]`);\n\n    plugins.each(function(){\n      let _this = $(this);\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  }\n}\n\n// Global, parses whole document.\nTriggers.Initializers.addClosemeListener = function(pluginName) {\n  var yetiBoxes = $('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if(pluginName){\n    if(typeof pluginName === 'string'){\n      plugNames.push(pluginName);\n    }else if(typeof pluginName === 'object' && typeof pluginName[0] === 'string'){\n      plugNames = plugNames.concat(pluginName);\n    }else{\n      console.error('Plugin names must be strings');\n    }\n  }\n  if(yetiBoxes.length){\n    let listeners = plugNames.map((name) => {\n      return `closeme.zf.${name}`;\n    }).join(' ');\n\n    $(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n}\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  let timer, args = Array.prototype.slice.call(arguments, 3);\n  $(window).off(trigger).on(trigger, function(e) {\n    if (timer) { clearTimeout(timer); }\n    timer = setTimeout(function(){\n      listener.apply(null, args);\n    }, debounce || 10);//default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function(debounce){\n  let $nodes = $('[data-resize]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addScrollListener = function(debounce){\n  let $nodes = $('[data-scroll]');\n  if($nodes.length){\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n}\n\nTriggers.Initializers.addMutationEventsListener = function($elem) {\n  if(!MutationObserver){ return false; }\n  let $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]');\n\n  //element callback\n  var listeningElementsMutation = function (mutationRecordsList) {\n    var $target = $(mutationRecordsList[0].target);\n\n    //trigger the event handler for the element depending on type\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n         }\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\",\"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], { attributes: true, childList: true, characterData: false, subtree: true, attributeFilter: [\"data-events\", \"style\"] });\n    }\n  }\n}\n\nTriggers.Initializers.addSimpleListeners = function() {\n  let $document = $(document);\n\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n\n}\n\nTriggers.Initializers.addGlobalListeners = function() {\n  let $document = $(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n}\n\n\nTriggers.init = function ($, Foundation) {\n  onLoad($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if(Foundation) {\n    Foundation.Triggers = Triggers;\n    // Legacy included to be backwards compatible for now.\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners\n  }\n}\n\nexport {Triggers};\n","module.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;"],"sourceRoot":""}
\ No newline at end of file
index cd11d1e4ae85947dc966cc22fc9f1304929da1a6..473c0e494e1643461ff056f82baf8023062f9d17 100644 (file)
@@ -1 +1,2 @@
-!function(e){function t(r){if(i[r])return i[r].exports;var n=i[r]={i:r,l:!1,exports:{}};return e[r].call(n.exports,n,n.exports,t),n.l=!0,n.exports}var i={};t.m=e,t.c=i,t.i=function(e){return e},t.d=function(e,i,r){t.o(e,i)||Object.defineProperty(e,i,{configurable:!1,enumerable:!0,get:r})},t.n=function(e){var i=e&&e.__esModule?function(){return e.default}:function(){return e};return t.d(i,"a",i),i},t.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},t.p="",t(t.s=108)}({0:function(e,t){e.exports=jQuery},1:function(e,t){e.exports={Foundation:window.Foundation}},108:function(e,t,i){e.exports=i(42)},4:function(e,t){e.exports={Motion:window.Foundation.Motion,Move:window.Foundation.Move}},42:function(e,t,i){"use strict";Object.defineProperty(t,"__esModule",{value:!0});var r=i(1),n=(i.n(r),i(0)),s=i.n(n);i(7).a.init(s.a,r.Foundation)},7:function(e,t,i){"use strict";function r(e,t,i){var r=void 0,n=Array.prototype.slice.call(arguments,3);s()(window).off(t).on(t,function(t){r&&clearTimeout(r),r=setTimeout(function(){i.apply(null,n)},e||10)})}i.d(t,"a",function(){return c});var n=i(0),s=i.n(n),a=i(4),o=(i.n(a),function(){for(var e=["WebKit","Moz","O","Ms",""],t=0;t<e.length;t++)if(e[t]+"MutationObserver"in window)return window[e[t]+"MutationObserver"];return!1}()),l=function(e,t){e.data(t).split(" ").forEach(function(i){s()("#"+i)["close"===t?"trigger":"triggerHandler"](t+".zf.trigger",[e])})},c={Listeners:{Basic:{},Global:{}},Initializers:{}};c.Listeners.Basic={openListener:function(){l(s()(this),"open")},closeListener:function(){s()(this).data("close")?l(s()(this),"close"):s()(this).trigger("close.zf.trigger")},toggleListener:function(){s()(this).data("toggle")?l(s()(this),"toggle"):s()(this).trigger("toggle.zf.trigger")},closeableListener:function(e){e.stopPropagation();var t=s()(this).data("closable");""!==t?a.Motion.animateOut(s()(this),t,function(){s()(this).trigger("closed.zf")}):s()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var e=s()(this).data("toggle-focus");s()("#"+e).triggerHandler("toggle.zf.trigger",[s()(this)])}},c.Initializers.addOpenListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.openListener),e.on("click.zf.trigger","[data-open]",c.Listeners.Basic.openListener)},c.Initializers.addCloseListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.closeListener),e.on("click.zf.trigger","[data-close]",c.Listeners.Basic.closeListener)},c.Initializers.addToggleListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.toggleListener),e.on("click.zf.trigger","[data-toggle]",c.Listeners.Basic.toggleListener)},c.Initializers.addCloseableListener=function(e){e.off("close.zf.trigger",c.Listeners.Basic.closeableListener),e.on("close.zf.trigger","[data-closeable], [data-closable]",c.Listeners.Basic.closeableListener)},c.Initializers.addToggleFocusListener=function(e){e.off("focus.zf.trigger blur.zf.trigger",c.Listeners.Basic.toggleFocusListener),e.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",c.Listeners.Basic.toggleFocusListener)},c.Listeners.Global={resizeListener:function(e){o||e.each(function(){s()(this).triggerHandler("resizeme.zf.trigger")}),e.attr("data-events","resize")},scrollListener:function(e){o||e.each(function(){s()(this).triggerHandler("scrollme.zf.trigger")}),e.attr("data-events","scroll")},closeMeListener:function(e,t){var i=e.namespace.split(".")[0];s()("[data-"+i+"]").not('[data-yeti-box="'+t+'"]').each(function(){var e=s()(this);e.triggerHandler("close.zf.trigger",[e])})}},c.Initializers.addClosemeListener=function(e){var t=s()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(e&&("string"==typeof e?i.push(e):"object"==typeof e&&"string"==typeof e[0]?i.concat(e):console.error("Plugin names must be strings")),t.length){var r=i.map(function(e){return"closeme.zf."+e}).join(" ");s()(window).off(r).on(r,c.Listeners.Global.closeMeListener)}},c.Initializers.addResizeListener=function(e){var t=s()("[data-resize]");t.length&&r(e,"resize.zf.trigger",c.Listeners.Global.resizeListener,t)},c.Initializers.addScrollListener=function(e){var t=s()("[data-scroll]");t.length&&r(e,"scroll.zf.trigger",c.Listeners.Global.scrollListener,t)},c.Initializers.addMutationEventsListener=function(e){if(!o)return!1;var t=e.find("[data-resize], [data-scroll], [data-mutate]"),i=function(e){var t=s()(e[0].target);switch(e[0].type){case"attributes":"scroll"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("scrollme.zf.trigger",[t,window.pageYOffset]),"resize"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("resizeme.zf.trigger",[t]),"style"===e[0].attributeName&&(t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]));break;case"childList":t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]);break;default:return!1}};if(t.length)for(var r=0;r<=t.length-1;r++){var n=new o(i);n.observe(t[r],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},c.Initializers.addSimpleListeners=function(){var e=s()(document);c.Initializers.addOpenListener(e),c.Initializers.addCloseListener(e),c.Initializers.addToggleListener(e),c.Initializers.addCloseableListener(e),c.Initializers.addToggleFocusListener(e)},c.Initializers.addGlobalListeners=function(){var e=s()(document);c.Initializers.addMutationEventsListener(e),c.Initializers.addResizeListener(),c.Initializers.addScrollListener(),c.Initializers.addClosemeListener()},c.init=function(e,t){if(void 0===e.triggersInitialized){e(document);"complete"===document.readyState?(c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners()):e(window).on("load",function(){c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners()}),e.triggersInitialized=!0}t&&(t.Triggers=c,t.IHearYou=c.Initializers.addGlobalListeners)}}});
\ No newline at end of file
+!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t(require("./foundation.core"),require("./foundation.util.motion"),require("jquery")):"function"==typeof define&&define.amd?define(["./foundation.core","./foundation.util.motion","jquery"],t):"object"==typeof exports?exports["foundation.util.triggers"]=t(require("./foundation.core"),require("./foundation.util.motion"),require("jquery")):(e.__FOUNDATION_EXTERNAL__=e.__FOUNDATION_EXTERNAL__||{},e.__FOUNDATION_EXTERNAL__["foundation.util.triggers"]=t(e.__FOUNDATION_EXTERNAL__["foundation.core"],e.__FOUNDATION_EXTERNAL__["foundation.util.motion"],e.jQuery))}(window,function(i,r,n){return function(i){var r={};function n(e){if(r[e])return r[e].exports;var t=r[e]={i:e,l:!1,exports:{}};return i[e].call(t.exports,t,t.exports,n),t.l=!0,t.exports}return n.m=i,n.c=r,n.d=function(e,t,i){n.o(e,t)||Object.defineProperty(e,t,{enumerable:!0,get:i})},n.r=function(e){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(e,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(e,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var i=Object.create(null);if(n.r(i),Object.defineProperty(i,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var r in t)n.d(i,r,function(e){return t[e]}.bind(null,r));return i},n.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return n.d(t,"a",t),t},n.o=function(e,t){return Object.prototype.hasOwnProperty.call(e,t)},n.p="",n(n.s=29)}({"./foundation.core":function(e,t){e.exports=i},"./foundation.util.motion":function(e,t){e.exports=r},"./js/entries/plugins/foundation.util.triggers.js":function(e,t,i){"use strict";i.r(t);var r=i("./foundation.core");i.d(t,"Foundation",function(){return r.Foundation});var n=i("jquery"),o=i.n(n),s=i("./js/foundation.util.triggers.js");i.d(t,"Triggers",function(){return s.Triggers}),s.Triggers.init(o.a,r.Foundation)},"./js/foundation.util.triggers.js":function(e,t,i){"use strict";i.r(t),i.d(t,"Triggers",function(){return c});var r=i("jquery"),o=i.n(r),n=i("./foundation.core"),s=i("./foundation.util.motion");function a(e){return(a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e})(e)}var l=function(){for(var e=["WebKit","Moz","O","Ms",""],t=0;t<e.length;t++)if("".concat(e[t],"MutationObserver")in window)return window["".concat(e[t],"MutationObserver")];return!1}(),u=function(t,i){t.data(i).split(" ").forEach(function(e){o()("#".concat(e))["close"===i?"trigger":"triggerHandler"]("".concat(i,".zf.trigger"),[t])})},c={Listeners:{Basic:{},Global:{}},Initializers:{}};function f(t,e,i){var r,n=Array.prototype.slice.call(arguments,3);o()(window).off(e).on(e,function(e){r&&clearTimeout(r),r=setTimeout(function(){i.apply(null,n)},t||10)})}c.Listeners.Basic={openListener:function(){u(o()(this),"open")},closeListener:function(){o()(this).data("close")?u(o()(this),"close"):o()(this).trigger("close.zf.trigger")},toggleListener:function(){o()(this).data("toggle")?u(o()(this),"toggle"):o()(this).trigger("toggle.zf.trigger")},closeableListener:function(e){e.stopPropagation();var t=o()(this).data("closable");""!==t?s.Motion.animateOut(o()(this),t,function(){o()(this).trigger("closed.zf")}):o()(this).fadeOut().trigger("closed.zf")},toggleFocusListener:function(){var e=o()(this).data("toggle-focus");o()("#".concat(e)).triggerHandler("toggle.zf.trigger",[o()(this)])}},c.Initializers.addOpenListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.openListener),e.on("click.zf.trigger","[data-open]",c.Listeners.Basic.openListener)},c.Initializers.addCloseListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.closeListener),e.on("click.zf.trigger","[data-close]",c.Listeners.Basic.closeListener)},c.Initializers.addToggleListener=function(e){e.off("click.zf.trigger",c.Listeners.Basic.toggleListener),e.on("click.zf.trigger","[data-toggle]",c.Listeners.Basic.toggleListener)},c.Initializers.addCloseableListener=function(e){e.off("close.zf.trigger",c.Listeners.Basic.closeableListener),e.on("close.zf.trigger","[data-closeable], [data-closable]",c.Listeners.Basic.closeableListener)},c.Initializers.addToggleFocusListener=function(e){e.off("focus.zf.trigger blur.zf.trigger",c.Listeners.Basic.toggleFocusListener),e.on("focus.zf.trigger blur.zf.trigger","[data-toggle-focus]",c.Listeners.Basic.toggleFocusListener)},c.Listeners.Global={resizeListener:function(e){l||e.each(function(){o()(this).triggerHandler("resizeme.zf.trigger")}),e.attr("data-events","resize")},scrollListener:function(e){l||e.each(function(){o()(this).triggerHandler("scrollme.zf.trigger")}),e.attr("data-events","scroll")},closeMeListener:function(e,t){var i=e.namespace.split(".")[0];o()("[data-".concat(i,"]")).not('[data-yeti-box="'.concat(t,'"]')).each(function(){var e=o()(this);e.triggerHandler("close.zf.trigger",[e])})}},c.Initializers.addClosemeListener=function(e){var t=o()("[data-yeti-box]"),i=["dropdown","tooltip","reveal"];if(e&&("string"==typeof e?i.push(e):"object"===a(e)&&"string"==typeof e[0]?i=i.concat(e):console.error("Plugin names must be strings")),t.length){var r=i.map(function(e){return"closeme.zf.".concat(e)}).join(" ");o()(window).off(r).on(r,c.Listeners.Global.closeMeListener)}},c.Initializers.addResizeListener=function(e){var t=o()("[data-resize]");t.length&&f(e,"resize.zf.trigger",c.Listeners.Global.resizeListener,t)},c.Initializers.addScrollListener=function(e){var t=o()("[data-scroll]");t.length&&f(e,"scroll.zf.trigger",c.Listeners.Global.scrollListener,t)},c.Initializers.addMutationEventsListener=function(e){if(!l)return!1;var t=e.find("[data-resize], [data-scroll], [data-mutate]"),i=function(e){var t=o()(e[0].target);switch(e[0].type){case"attributes":"scroll"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("scrollme.zf.trigger",[t,window.pageYOffset]),"resize"===t.attr("data-events")&&"data-events"===e[0].attributeName&&t.triggerHandler("resizeme.zf.trigger",[t]),"style"===e[0].attributeName&&(t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]));break;case"childList":t.closest("[data-mutate]").attr("data-events","mutate"),t.closest("[data-mutate]").triggerHandler("mutateme.zf.trigger",[t.closest("[data-mutate]")]);break;default:return!1}};if(t.length)for(var r=0;r<=t.length-1;r++){new l(i).observe(t[r],{attributes:!0,childList:!0,characterData:!1,subtree:!0,attributeFilter:["data-events","style"]})}},c.Initializers.addSimpleListeners=function(){var e=o()(document);c.Initializers.addOpenListener(e),c.Initializers.addCloseListener(e),c.Initializers.addToggleListener(e),c.Initializers.addCloseableListener(e),c.Initializers.addToggleFocusListener(e)},c.Initializers.addGlobalListeners=function(){var e=o()(document);c.Initializers.addMutationEventsListener(e),c.Initializers.addResizeListener(),c.Initializers.addScrollListener(),c.Initializers.addClosemeListener()},c.init=function(e,t){Object(n.onLoad)(e(window),function(){!0!==e.triggersInitialized&&(c.Initializers.addSimpleListeners(),c.Initializers.addGlobalListeners(),e.triggersInitialized=!0)}),t&&(t.Triggers=c,t.IHearYou=c.Initializers.addGlobalListeners)}},29:function(e,t,i){e.exports=i("./js/entries/plugins/foundation.util.triggers.js")},jquery:function(e,t){e.exports=n}})});
+//# sourceMappingURL=foundation.util.triggers.min.js.map
diff --git a/dist/js/plugins/foundation.util.triggers.min.js.map b/dist/js/plugins/foundation.util.triggers.min.js.map
new file mode 100644 (file)
index 0000000..1cf841c
--- /dev/null
@@ -0,0 +1 @@
+{"version":3,"sources":["foundation.util.triggers.min.js"],"names":["root","factory","exports","module","require","define","amd","window","__WEBPACK_EXTERNAL_MODULE__foundation_core__","__WEBPACK_EXTERNAL_MODULE__foundation_util_motion__","__WEBPACK_EXTERNAL_MODULE_jquery__","modules","installedModules","__webpack_require__","moduleId","i","l","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","./foundation.core","./foundation.util.motion","./js/entries/plugins/foundation.util.triggers.js","__webpack_exports__","_foundation_core__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_1__","jquery__WEBPACK_IMPORTED_MODULE_1___default","_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_2__","init","a","./js/foundation.util.triggers.js","Triggers","jquery__WEBPACK_IMPORTED_MODULE_0__","jquery__WEBPACK_IMPORTED_MODULE_0___default","_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__","_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__","_typeof","obj","iterator","constructor","MutationObserver","prefixes","length","concat","triggers","el","type","data","split","forEach","id","Listeners","Basic","Global","Initializers","debounceGlobalListener","debounce","trigger","listener","timer","args","Array","slice","arguments","off","on","e","clearTimeout","setTimeout","apply","openListener","this","closeListener","toggleListener","closeableListener","stopPropagation","animation","animateOut","fadeOut","toggleFocusListener","triggerHandler","addOpenListener","$elem","addCloseListener","addToggleListener","addCloseableListener","addToggleFocusListener","resizeListener","$nodes","each","attr","scrollListener","closeMeListener","pluginId","plugin","namespace","not","_this","addClosemeListener","pluginName","yetiBoxes","plugNames","push","console","error","listeners","map","join","addResizeListener","addScrollListener","addMutationEventsListener","find","listeningElementsMutation","mutationRecordsList","$target","target","attributeName","pageYOffset","closest","observe","attributes","childList","characterData","subtree","attributeFilter","addSimpleListeners","$document","document","addGlobalListeners","$","Foundation","triggersInitialized","IHearYou","29","jquery"],"mappings":"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","file":"foundation.util.triggers.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory(require(\"./foundation.core\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([\"./foundation.core\", \"./foundation.util.motion\", \"jquery\"], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"foundation.util.triggers\"] = factory(require(\"./foundation.core\"), require(\"./foundation.util.motion\"), require(\"jquery\"));\n\telse\n\t\troot[\"__FOUNDATION_EXTERNAL__\"] = root[\"__FOUNDATION_EXTERNAL__\"] || {}, root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.triggers\"] = factory(root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.core\"], root[\"__FOUNDATION_EXTERNAL__\"][\"foundation.util.motion\"], root[\"jQuery\"]);\n})(window, function(__WEBPACK_EXTERNAL_MODULE__foundation_core__, __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__, __WEBPACK_EXTERNAL_MODULE_jquery__) {\nreturn /******/ (function(modules) { // webpackBootstrap\n/******/ \t// The module cache\n/******/ \tvar installedModules = {};\n/******/\n/******/ \t// The require function\n/******/ \tfunction __webpack_require__(moduleId) {\n/******/\n/******/ \t\t// Check if module is in cache\n/******/ \t\tif(installedModules[moduleId]) {\n/******/ \t\t\treturn installedModules[moduleId].exports;\n/******/ \t\t}\n/******/ \t\t// Create a new module (and put it into the cache)\n/******/ \t\tvar module = installedModules[moduleId] = {\n/******/ \t\t\ti: moduleId,\n/******/ \t\t\tl: false,\n/******/ \t\t\texports: {}\n/******/ \t\t};\n/******/\n/******/ \t\t// Execute the module function\n/******/ \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n/******/\n/******/ \t\t// Flag the module as loaded\n/******/ \t\tmodule.l = true;\n/******/\n/******/ \t\t// Return the exports of the module\n/******/ \t\treturn module.exports;\n/******/ \t}\n/******/\n/******/\n/******/ \t// expose the modules object (__webpack_modules__)\n/******/ \t__webpack_require__.m = modules;\n/******/\n/******/ \t// expose the module cache\n/******/ \t__webpack_require__.c = installedModules;\n/******/\n/******/ \t// define getter function for harmony exports\n/******/ \t__webpack_require__.d = function(exports, name, getter) {\n/******/ \t\tif(!__webpack_require__.o(exports, name)) {\n/******/ \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n/******/ \t\t}\n/******/ \t};\n/******/\n/******/ \t// define __esModule on exports\n/******/ \t__webpack_require__.r = function(exports) {\n/******/ \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n/******/ \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n/******/ \t\t}\n/******/ \t\tObject.defineProperty(exports, '__esModule', { value: true });\n/******/ \t};\n/******/\n/******/ \t// create a fake namespace object\n/******/ \t// mode & 1: value is a module id, require it\n/******/ \t// mode & 2: merge all properties of value into the ns\n/******/ \t// mode & 4: return value when already ns object\n/******/ \t// mode & 8|1: behave like require\n/******/ \t__webpack_require__.t = function(value, mode) {\n/******/ \t\tif(mode & 1) value = __webpack_require__(value);\n/******/ \t\tif(mode & 8) return value;\n/******/ \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n/******/ \t\tvar ns = Object.create(null);\n/******/ \t\t__webpack_require__.r(ns);\n/******/ \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n/******/ \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n/******/ \t\treturn ns;\n/******/ \t};\n/******/\n/******/ \t// getDefaultExport function for compatibility with non-harmony modules\n/******/ \t__webpack_require__.n = function(module) {\n/******/ \t\tvar getter = module && module.__esModule ?\n/******/ \t\t\tfunction getDefault() { return module['default']; } :\n/******/ \t\t\tfunction getModuleExports() { return module; };\n/******/ \t\t__webpack_require__.d(getter, 'a', getter);\n/******/ \t\treturn getter;\n/******/ \t};\n/******/\n/******/ \t// Object.prototype.hasOwnProperty.call\n/******/ \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n/******/\n/******/ \t// __webpack_public_path__\n/******/ \t__webpack_require__.p = \"\";\n/******/\n/******/\n/******/ \t// Load entry module and return exports\n/******/ \treturn __webpack_require__(__webpack_require__.s = 29);\n/******/ })\n/************************************************************************/\n/******/ ({\n\n/***/ \"./foundation.core\":\n/*!****************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.core\"],\"amd\":\"./foundation.core\",\"commonjs\":\"./foundation.core\",\"commonjs2\":\"./foundation.core\"} ***!\n  \\****************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_core__;\n\n/***/ }),\n\n/***/ \"./foundation.util.motion\":\n/*!********************************************************************************************************************************************************************************************!*\\\n  !*** external {\"root\":[\"__FOUNDATION_EXTERNAL__\",\"foundation.util.motion\"],\"amd\":\"./foundation.util.motion\",\"commonjs\":\"./foundation.util.motion\",\"commonjs2\":\"./foundation.util.motion\"} ***!\n  \\********************************************************************************************************************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE__foundation_util_motion__;\n\n/***/ }),\n\n/***/ \"./js/entries/plugins/foundation.util.triggers.js\":\n/*!********************************************************!*\\\n  !*** ./js/entries/plugins/foundation.util.triggers.js ***!\n  \\********************************************************/\n/*! exports provided: Foundation, Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./foundation.core */ \"./foundation.core\");\n/* harmony import */ var _foundation_core__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_foundation_core__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Foundation\", function() { return _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]; });\n\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ../../foundation.util.triggers */ \"./js/foundation.util.triggers.js\");\n/* harmony reexport (safe) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return _foundation_util_triggers__WEBPACK_IMPORTED_MODULE_2__[\"Triggers\"]; });\n\n\n\n\n_foundation_util_triggers__WEBPACK_IMPORTED_MODULE_2__[\"Triggers\"].init(jquery__WEBPACK_IMPORTED_MODULE_1___default.a, _foundation_core__WEBPACK_IMPORTED_MODULE_0__[\"Foundation\"]);\n\n\n/***/ }),\n\n/***/ \"./js/foundation.util.triggers.js\":\n/*!****************************************!*\\\n  !*** ./js/foundation.util.triggers.js ***!\n  \\****************************************/\n/*! exports provided: Triggers */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\n__webpack_require__.r(__webpack_exports__);\n/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, \"Triggers\", function() { return Triggers; });\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! jquery */ \"jquery\");\n/* harmony import */ var jquery__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(jquery__WEBPACK_IMPORTED_MODULE_0__);\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./foundation.core.utils */ \"./foundation.core\");\n/* harmony import */ var _foundation_core_utils__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__);\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./foundation.util.motion */ \"./foundation.util.motion\");\n/* harmony import */ var _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__);\n\n\nfunction _typeof(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof(obj); }\n\n\n\n\n\nvar MutationObserver = function () {\n  var prefixes = ['WebKit', 'Moz', 'O', 'Ms', ''];\n\n  for (var i = 0; i < prefixes.length; i++) {\n    if (\"\".concat(prefixes[i], \"MutationObserver\") in window) {\n      return window[\"\".concat(prefixes[i], \"MutationObserver\")];\n    }\n  }\n\n  return false;\n}();\n\nvar triggers = function triggers(el, type) {\n  el.data(type).split(' ').forEach(function (id) {\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id))[type === 'close' ? 'trigger' : 'triggerHandler'](\"\".concat(type, \".zf.trigger\"), [el]);\n  });\n};\n\nvar Triggers = {\n  Listeners: {\n    Basic: {},\n    Global: {}\n  },\n  Initializers: {}\n};\nTriggers.Listeners.Basic = {\n  openListener: function openListener() {\n    triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'open');\n  },\n  closeListener: function closeListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('close');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'close');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('close.zf.trigger');\n    }\n  },\n  toggleListener: function toggleListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle');\n\n    if (id) {\n      triggers(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), 'toggle');\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('toggle.zf.trigger');\n    }\n  },\n  closeableListener: function closeableListener(e) {\n    e.stopPropagation();\n    var animation = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('closable');\n\n    if (animation !== '') {\n      _foundation_util_motion__WEBPACK_IMPORTED_MODULE_2__[\"Motion\"].animateOut(jquery__WEBPACK_IMPORTED_MODULE_0___default()(this), animation, function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).trigger('closed.zf');\n      });\n    } else {\n      jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).fadeOut().trigger('closed.zf');\n    }\n  },\n  toggleFocusListener: function toggleFocusListener() {\n    var id = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).data('toggle-focus');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"#\".concat(id)).triggerHandler('toggle.zf.trigger', [jquery__WEBPACK_IMPORTED_MODULE_0___default()(this)]);\n  }\n}; // Elements with [data-open] will reveal a plugin that supports it when clicked.\n\nTriggers.Initializers.addOpenListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.openListener);\n  $elem.on('click.zf.trigger', '[data-open]', Triggers.Listeners.Basic.openListener);\n}; // Elements with [data-close] will close a plugin that supports it when clicked.\n// If used without a value on [data-close], the event will bubble, allowing it to close a parent component.\n\n\nTriggers.Initializers.addCloseListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.closeListener);\n  $elem.on('click.zf.trigger', '[data-close]', Triggers.Listeners.Basic.closeListener);\n}; // Elements with [data-toggle] will toggle a plugin that supports it when clicked.\n\n\nTriggers.Initializers.addToggleListener = function ($elem) {\n  $elem.off('click.zf.trigger', Triggers.Listeners.Basic.toggleListener);\n  $elem.on('click.zf.trigger', '[data-toggle]', Triggers.Listeners.Basic.toggleListener);\n}; // Elements with [data-closable] will respond to close.zf.trigger events.\n\n\nTriggers.Initializers.addCloseableListener = function ($elem) {\n  $elem.off('close.zf.trigger', Triggers.Listeners.Basic.closeableListener);\n  $elem.on('close.zf.trigger', '[data-closeable], [data-closable]', Triggers.Listeners.Basic.closeableListener);\n}; // Elements with [data-toggle-focus] will respond to coming in and out of focus\n\n\nTriggers.Initializers.addToggleFocusListener = function ($elem) {\n  $elem.off('focus.zf.trigger blur.zf.trigger', Triggers.Listeners.Basic.toggleFocusListener);\n  $elem.on('focus.zf.trigger blur.zf.trigger', '[data-toggle-focus]', Triggers.Listeners.Basic.toggleFocusListener);\n}; // More Global/complex listeners and triggers\n\n\nTriggers.Listeners.Global = {\n  resizeListener: function resizeListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('resizeme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a resize event\n\n\n    $nodes.attr('data-events', \"resize\");\n  },\n  scrollListener: function scrollListener($nodes) {\n    if (!MutationObserver) {\n      //fallback for IE 9\n      $nodes.each(function () {\n        jquery__WEBPACK_IMPORTED_MODULE_0___default()(this).triggerHandler('scrollme.zf.trigger');\n      });\n    } //trigger all listening elements and signal a scroll event\n\n\n    $nodes.attr('data-events', \"scroll\");\n  },\n  closeMeListener: function closeMeListener(e, pluginId) {\n    var plugin = e.namespace.split('.')[0];\n    var plugins = jquery__WEBPACK_IMPORTED_MODULE_0___default()(\"[data-\".concat(plugin, \"]\")).not(\"[data-yeti-box=\\\"\".concat(pluginId, \"\\\"]\"));\n    plugins.each(function () {\n      var _this = jquery__WEBPACK_IMPORTED_MODULE_0___default()(this);\n\n      _this.triggerHandler('close.zf.trigger', [_this]);\n    });\n  } // Global, parses whole document.\n\n};\n\nTriggers.Initializers.addClosemeListener = function (pluginName) {\n  var yetiBoxes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-yeti-box]'),\n      plugNames = ['dropdown', 'tooltip', 'reveal'];\n\n  if (pluginName) {\n    if (typeof pluginName === 'string') {\n      plugNames.push(pluginName);\n    } else if (_typeof(pluginName) === 'object' && typeof pluginName[0] === 'string') {\n      plugNames = plugNames.concat(pluginName);\n    } else {\n      console.error('Plugin names must be strings');\n    }\n  }\n\n  if (yetiBoxes.length) {\n    var listeners = plugNames.map(function (name) {\n      return \"closeme.zf.\".concat(name);\n    }).join(' ');\n    jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(listeners).on(listeners, Triggers.Listeners.Global.closeMeListener);\n  }\n};\n\nfunction debounceGlobalListener(debounce, trigger, listener) {\n  var timer,\n      args = Array.prototype.slice.call(arguments, 3);\n  jquery__WEBPACK_IMPORTED_MODULE_0___default()(window).off(trigger).on(trigger, function (e) {\n    if (timer) {\n      clearTimeout(timer);\n    }\n\n    timer = setTimeout(function () {\n      listener.apply(null, args);\n    }, debounce || 10); //default time to emit scroll event\n  });\n}\n\nTriggers.Initializers.addResizeListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-resize]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'resize.zf.trigger', Triggers.Listeners.Global.resizeListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addScrollListener = function (debounce) {\n  var $nodes = jquery__WEBPACK_IMPORTED_MODULE_0___default()('[data-scroll]');\n\n  if ($nodes.length) {\n    debounceGlobalListener(debounce, 'scroll.zf.trigger', Triggers.Listeners.Global.scrollListener, $nodes);\n  }\n};\n\nTriggers.Initializers.addMutationEventsListener = function ($elem) {\n  if (!MutationObserver) {\n    return false;\n  }\n\n  var $nodes = $elem.find('[data-resize], [data-scroll], [data-mutate]'); //element callback\n\n  var listeningElementsMutation = function listeningElementsMutation(mutationRecordsList) {\n    var $target = jquery__WEBPACK_IMPORTED_MODULE_0___default()(mutationRecordsList[0].target); //trigger the event handler for the element depending on type\n\n    switch (mutationRecordsList[0].type) {\n      case \"attributes\":\n        if ($target.attr(\"data-events\") === \"scroll\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('scrollme.zf.trigger', [$target, window.pageYOffset]);\n        }\n\n        if ($target.attr(\"data-events\") === \"resize\" && mutationRecordsList[0].attributeName === \"data-events\") {\n          $target.triggerHandler('resizeme.zf.trigger', [$target]);\n        }\n\n        if (mutationRecordsList[0].attributeName === \"style\") {\n          $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n          $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        }\n\n        break;\n\n      case \"childList\":\n        $target.closest(\"[data-mutate]\").attr(\"data-events\", \"mutate\");\n        $target.closest(\"[data-mutate]\").triggerHandler('mutateme.zf.trigger', [$target.closest(\"[data-mutate]\")]);\n        break;\n\n      default:\n        return false;\n      //nothing\n    }\n  };\n\n  if ($nodes.length) {\n    //for each element that needs to listen for resizing, scrolling, or mutation add a single observer\n    for (var i = 0; i <= $nodes.length - 1; i++) {\n      var elementObserver = new MutationObserver(listeningElementsMutation);\n      elementObserver.observe($nodes[i], {\n        attributes: true,\n        childList: true,\n        characterData: false,\n        subtree: true,\n        attributeFilter: [\"data-events\", \"style\"]\n      });\n    }\n  }\n};\n\nTriggers.Initializers.addSimpleListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addOpenListener($document);\n  Triggers.Initializers.addCloseListener($document);\n  Triggers.Initializers.addToggleListener($document);\n  Triggers.Initializers.addCloseableListener($document);\n  Triggers.Initializers.addToggleFocusListener($document);\n};\n\nTriggers.Initializers.addGlobalListeners = function () {\n  var $document = jquery__WEBPACK_IMPORTED_MODULE_0___default()(document);\n  Triggers.Initializers.addMutationEventsListener($document);\n  Triggers.Initializers.addResizeListener();\n  Triggers.Initializers.addScrollListener();\n  Triggers.Initializers.addClosemeListener();\n};\n\nTriggers.init = function ($, Foundation) {\n  Object(_foundation_core_utils__WEBPACK_IMPORTED_MODULE_1__[\"onLoad\"])($(window), function () {\n    if ($.triggersInitialized !== true) {\n      Triggers.Initializers.addSimpleListeners();\n      Triggers.Initializers.addGlobalListeners();\n      $.triggersInitialized = true;\n    }\n  });\n\n  if (Foundation) {\n    Foundation.Triggers = Triggers; // Legacy included to be backwards compatible for now.\n\n    Foundation.IHearYou = Triggers.Initializers.addGlobalListeners;\n  }\n};\n\n\n\n/***/ }),\n\n/***/ 29:\n/*!**************************************************************!*\\\n  !*** multi ./js/entries/plugins/foundation.util.triggers.js ***!\n  \\**************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports, __webpack_require__) {\n\nmodule.exports = __webpack_require__(/*! /Volumes/Data/Development/Foundation/foundation-sites/js/entries/plugins/foundation.util.triggers.js */\"./js/entries/plugins/foundation.util.triggers.js\");\n\n\n/***/ }),\n\n/***/ \"jquery\":\n/*!********************************************************************************************!*\\\n  !*** external {\"root\":[\"jQuery\"],\"amd\":\"jquery\",\"commonjs\":\"jquery\",\"commonjs2\":\"jquery\"} ***!\n  \\********************************************************************************************/\n/*! no static exports found */\n/***/ (function(module, exports) {\n\nmodule.exports = __WEBPACK_EXTERNAL_MODULE_jquery__;\n\n/***/ })\n\n/******/ });\n});\n//# sourceMappingURL=foundation.util.triggers.js.map"]}
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.zf.responsiveAccordionTabs.js b/dist/js/plugins/foundation.zf.responsiveAccordionTabs.js
deleted file mode 100644 (file)
index d8f55a7..0000000
+++ /dev/null
@@ -1,262 +0,0 @@
-'use strict';
-
-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 _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
-
-!function ($) {
-
-  /**
-   * ResponsiveAccordionTabs module.
-   * @module foundation.responsiveAccordionTabs
-   * @requires foundation.util.keyboard
-   * @requires foundation.util.timerAndImageLoader
-   * @requires foundation.util.motion
-   * @requires foundation.accordion
-   * @requires foundation.tabs
-   */
-
-  var ResponsiveAccordionTabs = function () {
-    /**
-     * Creates a new instance of a responsive accordion tabs.
-     * @class
-     * @fires ResponsiveAccordionTabs#init
-     * @param {jQuery} element - jQuery object to make into a dropdown menu.
-     * @param {Object} options - Overrides to the default plugin settings.
-     */
-    function ResponsiveAccordionTabs(element, options) {
-      _classCallCheck(this, ResponsiveAccordionTabs);
-
-      this.$element = $(element);
-      this.options = $.extend({}, this.$element.data(), options);
-      this.rules = this.$element.data('responsive-accordion-tabs');
-      this.currentMq = null;
-      this.currentPlugin = null;
-      if (!this.$element.attr('id')) {
-        this.$element.attr('id', Foundation.GetYoDigits(6, 'responsiveaccordiontabs'));
-      };
-
-      this._init();
-      this._events();
-
-      Foundation.registerPlugin(this, 'ResponsiveAccordionTabs');
-    }
-
-    /**
-     * Initializes the Menu by parsing the classes from the 'data-responsive-accordion-tabs' attribute on the element.
-     * @function
-     * @private
-     */
-
-
-    _createClass(ResponsiveAccordionTabs, [{
-      key: '_init',
-      value: function _init() {
-        // The first time an Interchange plugin is initialized, this.rules is converted from a string of "classes" to an object of rules
-        if (typeof this.rules === 'string') {
-          var rulesTree = {};
-
-          // Parse rules from "classes" pulled from data attribute
-          var rules = this.rules.split(' ');
-
-          // Iterate through every rule found
-          for (var i = 0; i < rules.length; i++) {
-            var rule = rules[i].split('-');
-            var ruleSize = rule.length > 1 ? rule[0] : 'small';
-            var rulePlugin = rule.length > 1 ? rule[1] : rule[0];
-
-            if (MenuPlugins[rulePlugin] !== null) {
-              rulesTree[ruleSize] = MenuPlugins[rulePlugin];
-            }
-          }
-
-          this.rules = rulesTree;
-        }
-
-        this._getAllOptions();
-
-        if (!$.isEmptyObject(this.rules)) {
-          this._checkMediaQueries();
-        }
-      }
-    }, {
-      key: '_getAllOptions',
-      value: function _getAllOptions() {
-        //get all defaults and options
-        var _this = this;
-        _this.allOptions = {};
-        for (var key in MenuPlugins) {
-          if (MenuPlugins.hasOwnProperty(key)) {
-            var obj = MenuPlugins[key];
-            try {
-              var dummyPlugin = $('<ul></ul>');
-              var tmpPlugin = new obj.plugin(dummyPlugin, _this.options);
-              for (var keyKey in tmpPlugin.options) {
-                if (tmpPlugin.options.hasOwnProperty(keyKey) && keyKey !== 'zfPlugin') {
-                  var objObj = tmpPlugin.options[keyKey];
-                  _this.allOptions[keyKey] = objObj;
-                }
-              }
-              tmpPlugin.destroy();
-            } catch (e) {}
-          }
-        }
-      }
-
-      /**
-       * Initializes events for the Menu.
-       * @function
-       * @private
-       */
-
-    }, {
-      key: '_events',
-      value: function _events() {
-        var _this = this;
-
-        $(window).on('changed.zf.mediaquery', function () {
-          _this._checkMediaQueries();
-        });
-      }
-
-      /**
-       * Checks the current screen width against available media queries. If the media query has changed, and the plugin needed has changed, the plugins will swap out.
-       * @function
-       * @private
-       */
-
-    }, {
-      key: '_checkMediaQueries',
-      value: function _checkMediaQueries() {
-        var matchedMq,
-            _this = this;
-        // Iterate through each rule and find the last matching rule
-        $.each(this.rules, function (key) {
-          if (Foundation.MediaQuery.atLeast(key)) {
-            matchedMq = key;
-          }
-        });
-
-        // No match? No dice
-        if (!matchedMq) return;
-
-        // Plugin already initialized? We good
-        if (this.currentPlugin instanceof this.rules[matchedMq].plugin) return;
-
-        // Remove existing plugin-specific CSS classes
-        $.each(MenuPlugins, function (key, value) {
-          _this.$element.removeClass(value.cssClass);
-        });
-
-        // Add the CSS class for the new plugin
-        this.$element.addClass(this.rules[matchedMq].cssClass);
-
-        // Create an instance of the new plugin
-        if (this.currentPlugin) {
-          //don't know why but on nested elements data zfPlugin get's lost
-          if (!this.currentPlugin.$element.data('zfPlugin') && this.storezfData) this.currentPlugin.$element.data('zfPlugin', this.storezfData);
-          this.currentPlugin.destroy();
-        }
-        this._handleMarkup(this.rules[matchedMq].cssClass);
-        this.currentPlugin = new this.rules[matchedMq].plugin(this.$element, {});
-        this.storezfData = this.currentPlugin.$element.data('zfPlugin');
-      }
-    }, {
-      key: '_handleMarkup',
-      value: function _handleMarkup(toSet) {
-        var _this = this,
-            fromString = 'accordion';
-        var $panels = $('[data-tabs-content=' + this.$element.attr('id') + ']');
-        if ($panels.length) fromString = 'tabs';
-        if (fromString === toSet) {
-          return;
-        };
-
-        var tabsTitle = _this.allOptions.linkClass ? _this.allOptions.linkClass : 'tabs-title';
-        var tabsPanel = _this.allOptions.panelClass ? _this.allOptions.panelClass : 'tabs-panel';
-
-        this.$element.removeAttr('role');
-        var $liHeads = this.$element.children('.' + tabsTitle + ',[data-accordion-item]').removeClass(tabsTitle).removeClass('accordion-item').removeAttr('data-accordion-item');
-        var $liHeadsA = $liHeads.children('a').removeClass('accordion-title');
-
-        if (fromString === 'tabs') {
-          $panels = $panels.children('.' + tabsPanel).removeClass(tabsPanel).removeAttr('role').removeAttr('aria-hidden').removeAttr('aria-labelledby');
-          $panels.children('a').removeAttr('role').removeAttr('aria-controls').removeAttr('aria-selected');
-        } else {
-          $panels = $liHeads.children('[data-tab-content]').removeClass('accordion-content');
-        };
-
-        $panels.css({ display: '', visibility: '' });
-        $liHeads.css({ display: '', visibility: '' });
-        if (toSet === 'accordion') {
-          $panels.each(function (key, value) {
-            $(value).appendTo($liHeads.get(key)).addClass('accordion-content').attr('data-tab-content', '').removeClass('is-active').css({ height: '' });
-            $('[data-tabs-content=' + _this.$element.attr('id') + ']').after('<div id="tabs-placeholder-' + _this.$element.attr('id') + '"></div>').remove();
-            $liHeads.addClass('accordion-item').attr('data-accordion-item', '');
-            $liHeadsA.addClass('accordion-title');
-          });
-        } else if (toSet === 'tabs') {
-          var $tabsContent = $('[data-tabs-content=' + _this.$element.attr('id') + ']');
-          var $placeholder = $('#tabs-placeholder-' + _this.$element.attr('id'));
-          if ($placeholder.length) {
-            $tabsContent = $('<div class="tabs-content"></div>').insertAfter($placeholder).attr('data-tabs-content', _this.$element.attr('id'));
-            $placeholder.remove();
-          } else {
-            $tabsContent = $('<div class="tabs-content"></div>').insertAfter(_this.$element).attr('data-tabs-content', _this.$element.attr('id'));
-          };
-          $panels.each(function (key, value) {
-            var tempValue = $(value).appendTo($tabsContent).addClass(tabsPanel);
-            var hash = $liHeadsA.get(key).hash.slice(1);
-            var id = $(value).attr('id') || Foundation.GetYoDigits(6, 'accordion');
-            if (hash !== id) {
-              if (hash !== '') {
-                $(value).attr('id', hash);
-              } else {
-                hash = id;
-                $(value).attr('id', hash);
-                $($liHeadsA.get(key)).attr('href', $($liHeadsA.get(key)).attr('href').replace('#', '') + '#' + hash);
-              };
-            };
-            var isActive = $($liHeads.get(key)).hasClass('is-active');
-            if (isActive) {
-              tempValue.addClass('is-active');
-            };
-          });
-          $liHeads.addClass(tabsTitle);
-        };
-      }
-
-      /**
-       * Destroys the instance of the current plugin on this element, as well as the window resize handler that switches the plugins out.
-       * @function
-       */
-
-    }, {
-      key: 'destroy',
-      value: function destroy() {
-        if (this.currentPlugin) this.currentPlugin.destroy();
-        $(window).off('.zf.ResponsiveAccordionTabs');
-        Foundation.unregisterPlugin(this);
-      }
-    }]);
-
-    return ResponsiveAccordionTabs;
-  }();
-
-  ResponsiveAccordionTabs.defaults = {};
-
-  // The plugin matches the plugin classes with these plugin instances.
-  var MenuPlugins = {
-    tabs: {
-      cssClass: 'tabs',
-      plugin: Foundation._plugins.tabs || null
-    },
-    accordion: {
-      cssClass: 'accordion',
-      plugin: Foundation._plugins.accordion || null
-    }
-  };
-
-  // Window exports
-  Foundation.plugin(ResponsiveAccordionTabs, 'ResponsiveAccordionTabs');
-}(jQuery);
\ No newline at end of file
diff --git a/dist/js/plugins/foundation.zf.responsiveAccordionTabs.min.js b/dist/js/plugins/foundation.zf.responsiveAccordionTabs.min.js
deleted file mode 100644 (file)
index a373082..0000000
+++ /dev/null
@@ -1 +0,0 @@
-"use strict";function _classCallCheck(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}var _createClass=function(){function t(t,e){for(var a=0;a<e.length;a++){var i=e[a];i.enumerable=i.enumerable||!1,i.configurable=!0,"value"in i&&(i.writable=!0),Object.defineProperty(t,i.key,i)}}return function(e,a,i){return a&&t(e.prototype,a),i&&t(e,i),e}}();!function(t){var e=function(){function e(a,i){_classCallCheck(this,e),this.$element=t(a),this.options=t.extend({},this.$element.data(),i),this.rules=this.$element.data("responsive-accordion-tabs"),this.currentMq=null,this.currentPlugin=null,this.$element.attr("id")||this.$element.attr("id",Foundation.GetYoDigits(6,"responsiveaccordiontabs")),this._init(),this._events(),Foundation.registerPlugin(this,"ResponsiveAccordionTabs")}return _createClass(e,[{key:"_init",value:function(){if("string"==typeof this.rules){for(var e={},i=this.rules.split(" "),n=0;n<i.length;n++){var s=i[n].split("-"),r=s.length>1?s[0]:"small",l=s.length>1?s[1]:s[0];null!==a[l]&&(e[r]=a[l])}this.rules=e}this._getAllOptions(),t.isEmptyObject(this.rules)||this._checkMediaQueries()}},{key:"_getAllOptions",value:function(){var e=this;e.allOptions={};for(var i in a)if(a.hasOwnProperty(i)){var n=a[i];try{var s=t("<ul></ul>"),r=new n.plugin(s,e.options);for(var l in r.options)if(r.options.hasOwnProperty(l)&&"zfPlugin"!==l){var o=r.options[l];e.allOptions[l]=o}r.destroy()}catch(t){}}}},{key:"_events",value:function(){var e=this;t(window).on("changed.zf.mediaquery",function(){e._checkMediaQueries()})}},{key:"_checkMediaQueries",value:function(){var e,i=this;t.each(this.rules,function(t){Foundation.MediaQuery.atLeast(t)&&(e=t)}),e&&(this.currentPlugin instanceof this.rules[e].plugin||(t.each(a,function(t,e){i.$element.removeClass(e.cssClass)}),this.$element.addClass(this.rules[e].cssClass),this.currentPlugin&&(!this.currentPlugin.$element.data("zfPlugin")&&this.storezfData&&this.currentPlugin.$element.data("zfPlugin",this.storezfData),this.currentPlugin.destroy()),this._handleMarkup(this.rules[e].cssClass),this.currentPlugin=new this.rules[e].plugin(this.$element,{}),this.storezfData=this.currentPlugin.$element.data("zfPlugin")))}},{key:"_handleMarkup",value:function(e){var a=this,i="accordion",n=t("[data-tabs-content="+this.$element.attr("id")+"]");if(n.length&&(i="tabs"),i!==e){var s=a.allOptions.linkClass?a.allOptions.linkClass:"tabs-title",r=a.allOptions.panelClass?a.allOptions.panelClass:"tabs-panel";this.$element.removeAttr("role");var l=this.$element.children("."+s+",[data-accordion-item]").removeClass(s).removeClass("accordion-item").removeAttr("data-accordion-item"),o=l.children("a").removeClass("accordion-title");if("tabs"===i?(n=n.children("."+r).removeClass(r).removeAttr("role").removeAttr("aria-hidden").removeAttr("aria-labelledby"),n.children("a").removeAttr("role").removeAttr("aria-controls").removeAttr("aria-selected")):n=l.children("[data-tab-content]").removeClass("accordion-content"),n.css({display:"",visibility:""}),l.css({display:"",visibility:""}),"accordion"===e)n.each(function(e,i){t(i).appendTo(l.get(e)).addClass("accordion-content").attr("data-tab-content","").removeClass("is-active").css({height:""}),t("[data-tabs-content="+a.$element.attr("id")+"]").after('<div id="tabs-placeholder-'+a.$element.attr("id")+'"></div>').remove(),l.addClass("accordion-item").attr("data-accordion-item",""),o.addClass("accordion-title")});else if("tabs"===e){var c=t("[data-tabs-content="+a.$element.attr("id")+"]"),d=t("#tabs-placeholder-"+a.$element.attr("id"));d.length?(c=t('<div class="tabs-content"></div>').insertAfter(d).attr("data-tabs-content",a.$element.attr("id")),d.remove()):c=t('<div class="tabs-content"></div>').insertAfter(a.$element).attr("data-tabs-content",a.$element.attr("id")),n.each(function(e,a){var i=t(a).appendTo(c).addClass(r),n=o.get(e).hash.slice(1),s=t(a).attr("id")||Foundation.GetYoDigits(6,"accordion");n!==s&&(""!==n?t(a).attr("id",n):(n=s,t(a).attr("id",n),t(o.get(e)).attr("href",t(o.get(e)).attr("href").replace("#","")+"#"+n)));var d=t(l.get(e)).hasClass("is-active");d&&i.addClass("is-active")}),l.addClass(s)}}}},{key:"destroy",value:function(){this.currentPlugin&&this.currentPlugin.destroy(),t(window).off(".zf.ResponsiveAccordionTabs"),Foundation.unregisterPlugin(this)}}]),e}();e.defaults={};var a={tabs:{cssClass:"tabs",plugin:Foundation._plugins.tabs||null},accordion:{cssClass:"accordion",plugin:Foundation._plugins.accordion||null}};Foundation.plugin(e,"ResponsiveAccordionTabs")}(jQuery);
\ No newline at end of file